Skip to content
Snippets Groups Projects
Commit 16edce7d authored by Christophe Geuzaine's avatar Christophe Geuzaine
Browse files

cleanup

parent ce7f8364
No related branches found
No related tags found
No related merge requests found
......@@ -27,29 +27,35 @@ class eigenSolver{
public:
eigenSolver(dofManager<double> *manager, std::string A,
std::string B="", bool hermitian=true);
eigenSolver(linearSystemPETSc<double> *A,linearSystemPETSc<double>* B = NULL, bool hermitian=true);
eigenSolver(linearSystemPETSc<double> *A, linearSystemPETSc<double>* B = NULL,
bool hermitian=true);
bool solve(int numEigenValues=0, std::string which="");
int getNumEigenValues(){ return _eigenValues.size(); }
std::complex<double> getEigenValue(int num){ return _eigenValues[num]; }
std::vector<std::complex<double> > &getEigenVector(int num){ return _eigenVectors[num]; }
void clear(){
_eigenValues.clear();
_eigenVectors.clear();
};
std::complex<double> getEigenVectorComp(int num, int com){
return _eigenVectors[num][com];
};
void clear()
{
_eigenValues.clear();
_eigenVectors.clear();
};
std::complex<double> getEigenVectorComp(int num, int com)
{
return _eigenVectors[num][com];
};
};
#else
#include "linearSystemPETSc.h"
class eigenSolver{
private:
std::vector<std::complex<double> > _dummy;
public:
eigenSolver(dofManager<double> *manager, std::string A,
std::string B="", bool hermitian=false){}
eigenSolver(linearSystemPETSc<double> *A,linearSystemPETSc<double>* B = NULL, bool hermitian=false){}
eigenSolver(linearSystemPETSc<double> *A,linearSystemPETSc<double>* B = NULL,
bool hermitian=false){}
bool solve(int numEigenValues=0, std::string which="")
{
Msg::Error("Eigen solver requires SLEPc");
......@@ -58,8 +64,8 @@ class eigenSolver{
int getNumEigenValues(){ return 0; }
std::complex<double> getEigenValue(int num){ return 0.; }
std::vector<std::complex<double> > &getEigenVector(int num){ return _dummy; }
void clear(){};
std::complex<double> getEigenVectorComp(int num, int com) {return 0.;};
void clear(){}
std::complex<double> getEigenVectorComp(int num, int com) { return 0.; }
};
#endif
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment