2013-08-08 05:34:54 +08:00
|
|
|
#ifndef SCHRODINGER_SOLVER_H
|
|
|
|
#define SCHRODINGER_SOLVER_H
|
|
|
|
|
|
|
|
// ATC includes
|
|
|
|
#include "Array2D.h"
|
|
|
|
#include "LinearSolver.h"
|
|
|
|
|
|
|
|
// other includes
|
|
|
|
#include <vector>
|
|
|
|
#include <map>
|
2013-08-22 07:06:07 +08:00
|
|
|
#include <set>
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
namespace ATC {
|
|
|
|
|
|
|
|
// Forward class declarations
|
|
|
|
class ATC_Coupling;
|
|
|
|
class FE_Engine;
|
|
|
|
class PrescribedDataManager;
|
|
|
|
class PhysicsModel;
|
|
|
|
class PoissonSolver;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a class to solve the (time-independent) Schrodinger equation
|
|
|
|
*/
|
|
|
|
class SchrodingerSolver {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/** Constructor */
|
|
|
|
SchrodingerSolver(
|
|
|
|
const FieldName fieldName,
|
|
|
|
const PhysicsModel * physicsModel,
|
|
|
|
const FE_Engine * feEngine,
|
|
|
|
const PrescribedDataManager * prescribedDataMgr,
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
2014-11-21 02:59:03 +08:00
|
|
|
bool parallel = true
|
2013-08-08 05:34:54 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Destructor */
|
2014-11-21 02:59:03 +08:00
|
|
|
virtual ~SchrodingerSolver(){};
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** parser */
|
2019-10-20 23:24:13 +08:00
|
|
|
bool modify(int /* narg */, char ** /* arg */){ return false;}
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** initialize */
|
|
|
|
void initialize(void);
|
|
|
|
|
|
|
|
/** solve */
|
|
|
|
virtual bool solve(FIELDS & fields);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
/** Pointer to ATC */
|
|
|
|
ATC_Coupling * atc_;
|
|
|
|
|
|
|
|
/** Pointer to FE_Engine */
|
|
|
|
const FE_Engine * feEngine_;
|
|
|
|
|
|
|
|
/** Pointer to PrescribedDataManager */
|
|
|
|
const PrescribedDataManager * prescribedDataMgr_;
|
|
|
|
|
|
|
|
/** Pointer to FE_Engine */
|
|
|
|
const PhysicsModel * physicsModel_;
|
|
|
|
|
|
|
|
/** field to solve for */
|
|
|
|
FieldName fieldName_;
|
|
|
|
|
|
|
|
/** number of nodes */
|
|
|
|
int nNodes_;
|
|
|
|
|
2014-11-21 02:59:03 +08:00
|
|
|
/** mass matrix */
|
2013-08-08 05:34:54 +08:00
|
|
|
DENS_MAT M_;
|
|
|
|
|
|
|
|
bool parallel_;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2014-11-21 02:59:03 +08:00
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a class to solve the Schrodinger equation on slices
|
|
|
|
*/
|
2013-08-08 05:34:54 +08:00
|
|
|
class SliceSchrodingerSolver : public SchrodingerSolver {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/** Constructor */
|
|
|
|
SliceSchrodingerSolver(
|
|
|
|
const FieldName fieldName,
|
|
|
|
const PhysicsModel * physicsModel,
|
|
|
|
const FE_Engine * feEngine,
|
|
|
|
const PrescribedDataManager * prescribedDataMgr,
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
2013-08-22 07:06:07 +08:00
|
|
|
const Array< std::set<int> > & oneDslices,
|
2014-11-21 02:59:03 +08:00
|
|
|
const Array< double > & oneDdxs,
|
|
|
|
bool parallel = true
|
2013-08-08 05:34:54 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Destructor */
|
2014-11-21 02:59:03 +08:00
|
|
|
virtual ~SliceSchrodingerSolver(){};
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** parser */
|
2019-10-20 23:24:13 +08:00
|
|
|
bool modify(int /* narg */, char ** /* arg */){return false;}
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** initialize */
|
|
|
|
void initialize(void);
|
|
|
|
|
|
|
|
/** solve */
|
|
|
|
virtual bool solve(FIELDS & fields);
|
|
|
|
|
2013-08-22 07:06:07 +08:00
|
|
|
Array< std::set<int> > & slices(void){ return oneDslices_;}
|
2014-11-21 02:59:03 +08:00
|
|
|
Array< double > & dxs(void){ return oneDdxs_;}
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
2013-08-22 07:06:07 +08:00
|
|
|
Array< std::set<int> > oneDslices_;
|
2014-11-21 02:59:03 +08:00
|
|
|
Array< double > oneDdxs_;
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2014-11-21 02:59:03 +08:00
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a class to solve the Schrodinger-Poisson system
|
|
|
|
*/
|
2013-08-08 05:34:54 +08:00
|
|
|
class SchrodingerPoissonSolver {
|
|
|
|
public:
|
|
|
|
SchrodingerPoissonSolver(
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
|
|
|
SchrodingerSolver * schrodingerSolver,
|
|
|
|
PoissonSolver * poissonSolver,
|
|
|
|
const PhysicsModel * physicsModel,
|
|
|
|
int maxConsistencyIter
|
|
|
|
);
|
2014-11-21 02:59:03 +08:00
|
|
|
virtual ~SchrodingerPoissonSolver(void){};
|
2013-08-08 05:34:54 +08:00
|
|
|
virtual void solve(
|
|
|
|
FIELDS & rhs,
|
|
|
|
GRAD_FIELD_MATS & fluxes
|
|
|
|
);
|
|
|
|
protected:
|
|
|
|
ATC_Coupling * atc_;
|
|
|
|
SchrodingerSolver * schrodingerSolver_;
|
|
|
|
PoissonSolver * poissonSolver_;
|
|
|
|
const PhysicsModel * physicsModel_;
|
|
|
|
int maxConsistencyIter_;
|
2014-11-21 02:59:03 +08:00
|
|
|
int maxConstraintIter_;
|
2013-08-08 05:34:54 +08:00
|
|
|
int nNodes_;
|
2014-11-21 02:59:03 +08:00
|
|
|
double Ef0_;
|
|
|
|
double Ef_shift_;
|
|
|
|
double safe_dEf_;
|
|
|
|
double tol_;
|
2013-08-08 05:34:54 +08:00
|
|
|
};
|
|
|
|
|
2014-11-21 02:59:03 +08:00
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a class to solve the Schrodinger-Poisson system on slices
|
|
|
|
*/
|
2013-08-08 05:34:54 +08:00
|
|
|
class SliceSchrodingerPoissonSolver : public SchrodingerPoissonSolver {
|
|
|
|
public:
|
|
|
|
SliceSchrodingerPoissonSolver(
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
|
|
|
SchrodingerSolver * schrodingerSolver,
|
|
|
|
PoissonSolver * poissonSolver,
|
|
|
|
const PhysicsModel * physicsModel,
|
|
|
|
int maxConsistencyIter,
|
|
|
|
int maxConstraintIter,
|
|
|
|
int oneDconserve,
|
|
|
|
double Ef_shift,
|
|
|
|
double safe_dEf
|
|
|
|
);
|
2014-11-21 02:59:03 +08:00
|
|
|
virtual ~SliceSchrodingerPoissonSolver(void){};
|
2013-08-08 05:34:54 +08:00
|
|
|
virtual void solve(
|
|
|
|
FIELDS & rhs,
|
|
|
|
GRAD_FIELD_MATS & fluxes
|
|
|
|
);
|
|
|
|
protected:
|
2014-11-21 02:59:03 +08:00
|
|
|
int nslices_;
|
2013-08-08 05:34:54 +08:00
|
|
|
double update_fermi_energy(double target, bool first,
|
|
|
|
GRAD_FIELD_MATS & fluxes);
|
|
|
|
int oneDconserve_;
|
|
|
|
int oneDcoor_;
|
2013-08-22 07:06:07 +08:00
|
|
|
Array< std::set<int> > & oneDslices_;
|
2014-11-21 02:59:03 +08:00
|
|
|
Array< double > & oneDdxs_;
|
2013-08-08 05:34:54 +08:00
|
|
|
Array2D<double> EfHistory_;
|
|
|
|
};
|
|
|
|
|
2014-11-21 02:59:03 +08:00
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a class to solve the Schrodinger-Poisson system on slices
|
|
|
|
*/
|
|
|
|
class GlobalSliceSchrodingerPoissonSolver : public SliceSchrodingerPoissonSolver {
|
|
|
|
public:
|
|
|
|
GlobalSliceSchrodingerPoissonSolver(
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
|
|
|
SchrodingerSolver * schrodingerSolver,
|
|
|
|
PoissonSolver * poissonSolver,
|
|
|
|
const PhysicsModel * physicsModel,
|
|
|
|
int maxConsistencyIter,
|
|
|
|
int maxConstraintIter,
|
|
|
|
int oneDconserve,
|
|
|
|
double Ef0,
|
|
|
|
double alpha,
|
|
|
|
double safe_dEf,
|
|
|
|
double tol,
|
|
|
|
double mu, double D
|
|
|
|
);
|
|
|
|
virtual ~GlobalSliceSchrodingerPoissonSolver(void);
|
|
|
|
virtual void solve(
|
|
|
|
FIELDS & rhs,
|
|
|
|
GRAD_FIELD_MATS & fluxes
|
|
|
|
);
|
|
|
|
protected:
|
|
|
|
void compute_flux(const DENS_MAT & n, const DENS_MAT & phi);
|
|
|
|
void update_fermi_level();
|
|
|
|
void report(int i);
|
|
|
|
void exponential_electron_density();
|
|
|
|
class LinearSolver * solver_;
|
|
|
|
double alpha_;
|
|
|
|
int sliceSize_, nNodes_, nfreeSlices_, nfixed_, nLambda_;
|
|
|
|
SPAR_MAT K_;
|
|
|
|
SPAR_MAT G_,G2_; // 1D & 2D grad mats = int N gradN dv
|
|
|
|
DENS_VEC J_;
|
|
|
|
DENS_VEC flux_;
|
|
|
|
DENS_VEC dJ_;
|
|
|
|
DENS_VEC lambda_;
|
|
|
|
DENS_VEC F_;
|
|
|
|
DENS_VEC Phi_;
|
|
|
|
DENS_VEC n_;
|
|
|
|
Array2D <bool> rhsMask_;
|
|
|
|
double mobility_;
|
|
|
|
double diffusivity_;
|
|
|
|
double norm_, norm0_;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class SchrodingerSolver
|
|
|
|
* @brief a manager class
|
|
|
|
*/
|
2013-08-08 05:34:54 +08:00
|
|
|
class SchrodingerPoissonManager {
|
|
|
|
public:
|
|
|
|
SchrodingerPoissonManager();
|
2014-11-21 02:59:03 +08:00
|
|
|
~SchrodingerPoissonManager(){};
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** parser */
|
|
|
|
bool modify(int narg, char **arg);
|
|
|
|
|
|
|
|
/** initialize */
|
|
|
|
SchrodingerPoissonSolver * initialize(
|
|
|
|
/*const*/ ATC_Coupling * atc,
|
|
|
|
SchrodingerSolver * schrodingerSolver,
|
|
|
|
PoissonSolver * poissonSolver,
|
|
|
|
const PhysicsModel * physicsModel
|
|
|
|
);
|
|
|
|
protected:
|
|
|
|
int maxConsistencyIter_;
|
|
|
|
int maxConstraintIter_;
|
|
|
|
bool oneD_;
|
|
|
|
int oneDconserve_;
|
|
|
|
double Ef_shift_;
|
|
|
|
double safe_dEf_;
|
2014-11-21 02:59:03 +08:00
|
|
|
double alpha_;
|
|
|
|
double tol_;
|
|
|
|
double mu_, D_;
|
2013-08-08 05:34:54 +08:00
|
|
|
};
|
|
|
|
} // namespace ATC
|
|
|
|
#endif
|