📄 ublasilupreconditioner.h
字号:
// Copyright (C) 2006 Garth N. Wells.// Licensed under the GNU LGPL Version 2.1.//// Modified by Anders Logg 2006.//// First added: 2006-06-23// Last changed: 2006-07-04#ifndef __UBLAS_ILU_PRECONDITIONER_H#define __UBLAS_ILU_PRECONDITIONER_H#include "ublas.h"#include <dolfin/common/Array.h>#include "uBlasPreconditioner.h"#include "uBlasMatrix.h"namespace dolfin{ template<class Mat> class uBlasMatrix; class uBlasVector; /// This class implements an incomplete LU factorization (ILU) /// preconditioner for the uBlas Krylov solver. class uBlasILUPreconditioner : public uBlasPreconditioner { public: /// Constructor uBlasILUPreconditioner(); /// Constructor uBlasILUPreconditioner(const uBlasMatrix<ublas_sparse_matrix>& A); /// Destructor ~uBlasILUPreconditioner(); /// Solve linear system Ax = b approximately void solve(uBlasVector& x, const uBlasVector& b) const; private: // Initialize preconditioner void init(const uBlasMatrix<ublas_sparse_matrix>& A); // Preconditioner matrix uBlasMatrix<ublas_sparse_matrix> M; // Diagonal Array<uint> diagonal; };}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -