|
MADNESS 0.10.1
|
Evolves the hydrogen atom in imaginary and also real time. More...
#include <madness/mra/mra.h>#include <madness/mra/qmprop.h>#include <madness/mra/operator.h>#include <madness/constants.h>#include <madness/tensor/vmath.h>#include <madness/mra/lbdeux.h>
Classes | |
| struct | InputParameters |
| struct | lbcost< T, NDIM > |
| class | LevelPmap |
| struct | unaryexp< T, NDIM > |
| struct | unaryexp< double_complex, NDIM > |
Typedefs | |
| typedef FunctionFactory< double_complex, 3 > | complex_factoryT |
| typedef Function< double_complex, 3 > | complex_functionT |
| typedef std::shared_ptr< FunctionFunctorInterface< double_complex, 3 > > | complex_functorT |
| typedef SeparatedConvolution< double_complex, 3 > | complex_operatorT |
| typedef Vector< double, 3 > | coordT |
| typedef FunctionFactory< double, 3 > | factoryT |
| typedef Function< double, 3 > | functionT |
| typedef std::shared_ptr< FunctionFunctorInterface< double, 3 > > | functorT |
| typedef SeparatedConvolution< double, 3 > | operatorT |
| typedef std::shared_ptr< WorldDCPmapInterface< Key< 3 > > > | pmapT |
Functions | |
| complex_functionT | chin_chen (const complex_functionT &expV_0, const complex_functionT &expV_tilde, const complex_functionT &expV_1, const complex_operatorT &G, const complex_functionT &psi0) |
| void | converge (World &world, functionT &potn, functionT &psi, double &eps) |
| static double | d_smoothed_potential (double r) |
| void | doit (World &world) |
| void | doplot (World &world, int step, const complex_functionT &psi, double Lplot, long numpt, const char *fname) |
| static double | dVdx (const coordT &r) |
| static double | dVdy (const coordT &r) |
| static double | dVdz (const coordT &r) |
| template<typename T > | |
| double | energy (World &world, const Function< T, 3 > &psi, const functionT &potn) |
| static double | guess (const coordT &r) |
| double | laser (double t) |
| void | line_plot (World &world, int step, complex_functionT &psi) |
| void | loadbal (World &world, functionT &potn, functionT &vt, functionT &dpotn_dx, functionT &dpotn_dy, functionT &dpotn_dz, functionT &dpotn_dx_sq, functionT &dpotn_dy_sq, complex_functionT &psi, complex_functionT &psi0, functionT &x, functionT &y, functionT &z) |
| int | main (int argc, char **argv) |
| complex_functionT | make_exp (double t, const functionT &v) |
| double | myreal (const double_complex &t) |
| double | myreal (double t) |
| ostream & | operator<< (ostream &s, const InputParameters &p) |
| void | print_stats (World &world, int step, double t, const functionT &v, const functionT &x, const functionT &y, const functionT &z, const functionT &dV_dz, const complex_functionT &psi0, const complex_functionT &psi) |
| void | print_stats_header (World &world) |
| void | propagate (World &world, int step0) |
| static double | smoothed_potential (double r) |
| complex_functionT | trotter (World &world, const complex_functionT &expV, const complex_operatorT &G, const complex_functionT &psi0) |
| static double | V (const coordT &r) |
| bool | wave_function_exists (World &world, int step) |
| const char * | wave_function_filename (int step) |
| const char * | wave_function_large_plot_filename (int step) |
| complex_functionT | wave_function_load (World &world, int step) |
| const char * | wave_function_small_plot_filename (int step) |
| void | wave_function_store (World &world, int step, const complex_functionT &psi) |
| double | xdipole (const coordT &r) |
| double | ydipole (const coordT &r) |
| double | zdipole (const coordT &r) |
Variables | |
| InputParameters | param |
| static double | zero_field_time |
Evolves the hydrogen atom in imaginary and also real time.
| typedef FunctionFactory<double_complex,3> complex_factoryT |
| typedef Function<double_complex,3> complex_functionT |
| typedef std::shared_ptr< FunctionFunctorInterface<double_complex,3> > complex_functorT |
| typedef SeparatedConvolution<double_complex,3> complex_operatorT |
| typedef FunctionFactory<double,3> factoryT |
| typedef std::shared_ptr< FunctionFunctorInterface<double,3> > functorT |
| typedef SeparatedConvolution<double,3> operatorT |
| typedef std::shared_ptr< WorldDCPmapInterface< Key<3> > > pmapT |
| complex_functionT chin_chen | ( | const complex_functionT & | expV_0, |
| const complex_functionT & | expV_tilde, | ||
| const complex_functionT & | expV_1, | ||
| const complex_operatorT & | G, | ||
| const complex_functionT & | psi0 | ||
| ) |
References madness::apply(), param, psi0(), madness::World::rank(), InputParameters::thresh, madness::Function< T, NDIM >::truncate(), madness::wall_time(), and madness::Function< T, NDIM >::world().
Referenced by propagate().
References madness::apply(), InputParameters::cut, e(), madness::inner(), InputParameters::k, norm(), madness::Function< T, NDIM >::norm2(), op(), param, potn(), madness::print(), psi(), madness::World::rank(), madness::Function< T, NDIM >::scale(), InputParameters::thresh, madness::Function< T, NDIM >::truncate(), and madness::wall_time().
Referenced by doit().
|
static |
References e(), and madness::r2().
| void doit | ( | World & | world | ) |
References madness::LoadBalanceDeux< NDIM >::add_tree(), madness::WorldGopInterface::broadcast(), madness::WorldGopInterface::broadcast_serializable(), converge(), madness::copy(), energy, madness::error(), madness::WorldGopInterface::fence(), madness::World::gop, guess(), InputParameters::k, InputParameters::L, madness::LoadBalanceDeux< NDIM >::load_balance(), param, potn(), madness::print(), propagate(), psi(), madness::World::rank(), InputParameters::read(), InputParameters::safety, madness::Function< T, NDIM >::scale(), madness::FunctionDefaults< NDIM >::set_apply_randomize(), madness::FunctionDefaults< NDIM >::set_autorefine(), madness::FunctionDefaults< NDIM >::set_cubic_cell(), madness::FunctionDefaults< NDIM >::set_initial_level(), madness::FunctionDefaults< NDIM >::set_k(), madness::FunctionDefaults< NDIM >::set_pmap(), madness::FunctionDefaults< NDIM >::set_thresh(), madness::FunctionDefaults< NDIM >::set_truncate_mode(), InputParameters::thresh, madness::Function< T, NDIM >::truncate(), V(), madness::wall_time(), wave_function_exists(), and wave_function_store().
Referenced by main().
| void doplot | ( | World & | world, |
| int | step, | ||
| const complex_functionT & | psi, | ||
| double | Lplot, | ||
| long | numpt, | ||
| const char * | fname | ||
| ) |
References madness::_(), madness::print(), madness::World::rank(), and madness::wall_time().
Referenced by propagate().
|
static |
References InputParameters::cut, d_smoothed_potential(), InputParameters::natom, param, InputParameters::R, sum, and InputParameters::Z.
Referenced by propagate().
|
static |
References InputParameters::cut, d_smoothed_potential(), InputParameters::natom, param, InputParameters::R, sum, and InputParameters::Z.
Referenced by propagate().
|
static |
References InputParameters::cut, d_smoothed_potential(), InputParameters::natom, param, InputParameters::R, sum, and InputParameters::Z.
Referenced by propagate().
|
static |
References InputParameters::cut, InputParameters::natom, param, InputParameters::R, sum, and InputParameters::Z.
Referenced by madness::Znemo::custom_guess(), doit(), madness::TDHF::initialize(), main(), madness::Zcis::make_guess(), opt(), opt(), madness::Zcis::read_guess(), run(), madness::Nemo::solve_cphf(), test_with_function(), and test_with_function_vector().
| double laser | ( | double | t | ) |
References InputParameters::F, InputParameters::ncycle, InputParameters::omega, param, and madness::constants::pi.
Referenced by print_stats(), and propagate().
| void line_plot | ( | World & | world, |
| int | step, | ||
| complex_functionT & | psi | ||
| ) |
| void loadbal | ( | World & | world, |
| functionT & | potn, | ||
| functionT & | vt, | ||
| functionT & | dpotn_dx, | ||
| functionT & | dpotn_dy, | ||
| functionT & | dpotn_dz, | ||
| functionT & | dpotn_dx_sq, | ||
| functionT & | dpotn_dy_sq, | ||
| complex_functionT & | psi, | ||
| complex_functionT & | psi0, | ||
| functionT & | x, | ||
| functionT & | y, | ||
| functionT & | z | ||
| ) |
References madness::LoadBalanceDeux< NDIM >::add_tree(), madness::copy(), madness::WorldGopInterface::fence(), madness::World::gop, madness::LoadBalanceDeux< NDIM >::load_balance(), potn(), madness::print(), psi(), psi0(), madness::World::rank(), madness::FunctionDefaults< NDIM >::set_pmap(), and madness::World::size().
Referenced by propagate().
| int main | ( | int | argc, |
| char ** | argv | ||
| ) |
| complex_functionT make_exp | ( | double | t, |
| const functionT & | v | ||
| ) |
Referenced by propagate().
| double myreal | ( | const double_complex & | t | ) |
References madness::real().
| double myreal | ( | double | t | ) |
Referenced by energy().
| ostream & operator<< | ( | ostream & | s, |
| const InputParameters & | p | ||
| ) |
References p().
| void print_stats | ( | World & | world, |
| int | step, | ||
| double | t, | ||
| const functionT & | v, | ||
| const functionT & | x, | ||
| const functionT & | y, | ||
| const functionT & | z, | ||
| const functionT & | dV_dz, | ||
| const complex_functionT & | psi0, | ||
| const complex_functionT & | psi | ||
| ) |
References std::abs(), energy, madness::inner(), laser(), norm(), psi(), psi0(), madness::World::rank(), madness::real(), v, and madness::wall_time().
Referenced by main(), and propagate().
| void print_stats_header | ( | World & | world | ) |
References madness::World::rank().
Referenced by propagate().
| void propagate | ( | World & | world, |
| int | step0 | ||
| ) |
References madness::Function< T, NDIM >::add_scalar(), madness::WorldGopInterface::broadcast(), c, chin_chen(), madness::Function< T, NDIM >::clear(), madness::Function< T, NDIM >::compress(), madness::copy(), ctarget, InputParameters::cut, doplot(), dVdx(), dVdy(), dVdz(), expV(), madness::WorldGopInterface::fence(), madness::Function< T, NDIM >::gaxpy(), madness::World::gop, InputParameters::k, InputParameters::L, laser(), line_plot(), InputParameters::Llarge, loadbal(), InputParameters::Lsmall, make_exp(), InputParameters::ndump, InputParameters::nloadbal, InputParameters::nplot, InputParameters::nprint, param, madness::constants::pi, potn(), madness::print(), print_stats(), print_stats_header(), psi(), psi0(), madness::World::rank(), InputParameters::target_time, tcrit, trotter(), madness::Function< T, NDIM >::truncate(), InputParameters::tScale, V(), madness::wall_time(), wave_function_large_plot_filename(), wave_function_load(), wave_function_small_plot_filename(), wave_function_store(), xdipole(), ydipole(), zdipole(), and zero_field_time.
Referenced by doit().
|
static |
References e(), and madness::r2().
Referenced by V().
| complex_functionT trotter | ( | World & | world, |
| const complex_functionT & | expV, | ||
| const complex_operatorT & | G, | ||
| const complex_functionT & | psi0 | ||
| ) |
References madness::apply(), expV(), param, madness::print(), psi0(), madness::World::rank(), madness::Function< T, NDIM >::size(), InputParameters::thresh, and madness::Function< T, NDIM >::truncate().
Referenced by propagate().
|
static |
References InputParameters::cut, InputParameters::natom, param, InputParameters::R, smoothed_potential(), sum, and InputParameters::Z.
Referenced by doit(), and propagate().
| bool wave_function_exists | ( | World & | world, |
| int | step | ||
| ) |
References wave_function_filename().
Referenced by doit().
| const char * wave_function_filename | ( | int | step | ) |
References param, and InputParameters::prefix.
Referenced by line_plot(), wave_function_exists(), wave_function_load(), and wave_function_store().
| const char * wave_function_large_plot_filename | ( | int | step | ) |
References param, and InputParameters::prefix.
Referenced by propagate().
| complex_functionT wave_function_load | ( | World & | world, |
| int | step | ||
| ) |
References psi(), and wave_function_filename().
Referenced by propagate().
| const char * wave_function_small_plot_filename | ( | int | step | ) |
References param, and InputParameters::prefix.
Referenced by propagate().
| void wave_function_store | ( | World & | world, |
| int | step, | ||
| const complex_functionT & | psi | ||
| ) |
References InputParameters::nio, param, psi(), and wave_function_filename().
Referenced by doit(), and propagate().
| double xdipole | ( | const coordT & | r | ) |
Referenced by propagate().
| double ydipole | ( | const coordT & | r | ) |
Referenced by propagate().
| double zdipole | ( | const coordT & | r | ) |
Referenced by propagate().
| InputParameters param |
|
static |
Referenced by propagate().