|
Chaste Release::3.1
|
#include <SimpleLinearEllipticSolver.hpp>
Inheritance diagram for SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >:
Collaboration diagram for SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >:Public Member Functions | |
| SimpleLinearEllipticSolver (AbstractTetrahedralMesh< ELEMENT_DIM, SPACE_DIM > *pMesh, AbstractLinearEllipticPde< ELEMENT_DIM, SPACE_DIM > *pPde, BoundaryConditionsContainer< ELEMENT_DIM, SPACE_DIM, 1 > *pBoundaryConditions, unsigned numQuadPoints=2) | |
| void | InitialiseForSolve (Vec initialSolution=NULL) |
Protected Member Functions | |
| virtual c_matrix< double, 1 *(ELEMENT_DIM+1), 1 *(ELEMENT_DIM+1)> | ComputeMatrixTerm (c_vector< double, ELEMENT_DIM+1 > &rPhi, c_matrix< double, SPACE_DIM, ELEMENT_DIM+1 > &rGradPhi, ChastePoint< SPACE_DIM > &rX, c_vector< double, 1 > &rU, c_matrix< double, 1, SPACE_DIM > &rGradU, Element< ELEMENT_DIM, SPACE_DIM > *pElement) |
| virtual c_vector< double, 1 *(ELEMENT_DIM+1)> | ComputeVectorTerm (c_vector< double, ELEMENT_DIM+1 > &rPhi, c_matrix< double, SPACE_DIM, ELEMENT_DIM+1 > &rGradPhi, ChastePoint< SPACE_DIM > &rX, c_vector< double, 1 > &rU, c_matrix< double, 1, SPACE_DIM > &rGradU, Element< ELEMENT_DIM, SPACE_DIM > *pElement) |
| void | SetupLinearSystem (Vec currentSolution, bool computeMatrix) |
Protected Attributes | |
| AbstractLinearEllipticPde < ELEMENT_DIM, SPACE_DIM > * | mpEllipticPde |
Solver for solving AbstractLinearEllipticPdes.
Definition at line 49 of file SimpleLinearEllipticSolver.hpp.
| SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::SimpleLinearEllipticSolver | ( | AbstractTetrahedralMesh< ELEMENT_DIM, SPACE_DIM > * | pMesh, |
| AbstractLinearEllipticPde< ELEMENT_DIM, SPACE_DIM > * | pPde, | ||
| BoundaryConditionsContainer< ELEMENT_DIM, SPACE_DIM, 1 > * | pBoundaryConditions, | ||
| unsigned | numQuadPoints = 2 |
||
| ) |
Constructor.
| pMesh | pointer to the mesh |
| pPde | pointer to the PDE |
| pBoundaryConditions | pointer to the boundary conditions |
| numQuadPoints | number of quadrature points (defaults to 2) |
Definition at line 75 of file SimpleLinearEllipticSolver.cpp.
References SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::mpEllipticPde.
| c_matrix< double, 1 *(ELEMENT_DIM+1), 1 *(ELEMENT_DIM+1)> SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::ComputeMatrixTerm | ( | c_vector< double, ELEMENT_DIM+1 > & | rPhi, |
| c_matrix< double, SPACE_DIM, ELEMENT_DIM+1 > & | rGradPhi, | ||
| ChastePoint< SPACE_DIM > & | rX, | ||
| c_vector< double, 1 > & | rU, | ||
| c_matrix< double, 1, SPACE_DIM > & | rGradU, | ||
| Element< ELEMENT_DIM, SPACE_DIM > * | pElement | ||
| ) | [protected, virtual] |
The term to be added to the element stiffness matrix - see AbstractFeVolumeIntegralAssembler
grad_phi[row] . ( pde_diffusion_term * grad_phi[col])
| rPhi | The basis functions, rPhi(i) = phi_i, i=1..numBases |
| rGradPhi | Basis gradients, rGradPhi(i,j) = d(phi_j)/d(X_i) |
| rX | The point in space |
| rU | The unknown as a vector, u(i) = u_i |
| rGradU | The gradient of the unknown as a matrix, rGradU(i,j) = d(u_i)/d(X_j) |
| pElement | Pointer to the element |
Definition at line 39 of file SimpleLinearEllipticSolver.cpp.
| c_vector< double, 1 *(ELEMENT_DIM+1)> SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::ComputeVectorTerm | ( | c_vector< double, ELEMENT_DIM+1 > & | rPhi, |
| c_matrix< double, SPACE_DIM, ELEMENT_DIM+1 > & | rGradPhi, | ||
| ChastePoint< SPACE_DIM > & | rX, | ||
| c_vector< double, 1 > & | rU, | ||
| c_matrix< double, 1, SPACE_DIM > & | rGradU, | ||
| Element< ELEMENT_DIM, SPACE_DIM > * | pElement | ||
| ) | [protected, virtual] |
The term arising from boundary conditions to be added to the element stiffness vector - see AbstractFeVolumeIntegralAssembler
| rPhi | The basis functions, rPhi(i) = phi_i, i=1..numBases |
| rGradPhi | Basis gradients, rGradPhi(i,j) = d(phi_j)/d(X_i) |
| rX | The point in space |
| rU | The unknown as a vector, u(i) = u_i |
| rGradU | The gradient of the unknown as a matrix, rGradU(i,j) = d(u_i)/d(X_j) |
| pElement | Pointer to the element |
Definition at line 62 of file SimpleLinearEllipticSolver.cpp.
| void SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::InitialiseForSolve | ( | Vec | initialSolution = NULL | ) | [virtual] |
Overloaded InitaliseForSolve() which just calls the base class but also sets the matrix as symmetric and sets Conjugate Gradients as the solver
| initialSolution | initialSolution (used in base class version of this method) |
Reimplemented from AbstractLinearPdeSolver< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >.
Reimplemented in CellBasedPdeSolver< DIM >.
Definition at line 87 of file SimpleLinearEllipticSolver.cpp.
References AbstractLinearPdeSolver< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::InitialiseForSolve().
Referenced by CellBasedPdeSolver< DIM >::InitialiseForSolve().
| void SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::SetupLinearSystem | ( | Vec | currentSolution, |
| bool | computeMatrix | ||
| ) | [inline, protected, virtual] |
Delegate to AbstractAssemblerSolverHybrid::SetupGivenLinearSystem.
| currentSolution | The current solution which can be used in setting up the linear system if needed (NULL if there isn't a current solution) |
| computeMatrix | Whether to compute the LHS matrix of the linear system (mainly for dynamic solves). |
Implements AbstractLinearPdeSolver< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >.
Definition at line 112 of file SimpleLinearEllipticSolver.hpp.
AbstractLinearEllipticPde<ELEMENT_DIM,SPACE_DIM>* SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::mpEllipticPde [protected] |
The PDE to be solved.
Definition at line 56 of file SimpleLinearEllipticSolver.hpp.
Referenced by SimpleLinearEllipticSolver< ELEMENT_DIM, SPACE_DIM >::SimpleLinearEllipticSolver().