00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef _math_optimize_gdiis_h
00029 #define _math_optimize_gdiis_h
00030
00031 #ifdef __GNUC__
00032 #pragma interface
00033 #endif
00034
00035 #include <util/state/state.h>
00036 #include <util/class/class.h>
00037 #include <math/scmat/matrix.h>
00038 #include <math/optimize/function.h>
00039 #include <math/optimize/opt.h>
00040 #include <math/optimize/update.h>
00041
00042
00043
00044
00045 class GDIISOpt: public Optimize {
00046 protected:
00047 int nsave;
00048 int diis_iter;
00049
00050 double maxabs_gradient;
00051 double convergence_;
00052 double accuracy_;
00053
00054 RefSCVector *coords_;
00055 RefSCVector *grad_;
00056 RefSCVector *error_;
00057
00058 RefSymmSCMatrix ihessian_;
00059 Ref<HessianUpdate> update_;
00060
00061 public:
00062 GDIISOpt(const Ref<KeyVal>&);
00063 GDIISOpt(StateIn&);
00064 ~GDIISOpt();
00065 void save_data_state(StateOut&);
00066
00067 void init();
00068 int update();
00069 };
00070
00071 #endif
00072
00073
00074
00075
00076