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
00029 #ifndef _chemistry_qc_mbpt_distsh_h
00030 #define _chemistry_qc_mbpt_distsh_h
00031
00032 #ifdef __GNUC__
00033 #pragma interface
00034 #endif
00035
00036 #include <util/misc/regtime.h>
00037 #include <util/group/message.h>
00038 #include <util/group/thread.h>
00039 #include <chemistry/qc/basis/basis.h>
00040
00042 class DistShellPair {
00043 private:
00044 Ref<MessageGrp> msg_;
00045 int nthread_;
00046 Ref<ThreadLock> lock_;
00047 Ref<GaussianBasisSet> basis_;
00048 int dynamic_;
00049 int debug_;
00050 int print_percent_;
00051
00052
00053 int req_type_;
00054 int ans_type_;
00055 int ncpu_less_0_;
00056 void serve_tasks();
00057
00058
00059 int S_, R_;
00060 int ncpu_;
00061 int mythread_;
00062 int ntask_;
00063 int print_interval_;
00064 int print_index_;
00065 public:
00066 DistShellPair(const Ref<MessageGrp> &, int nthread, int mythread,
00067 const Ref<ThreadLock> &,
00068 const Ref<GaussianBasisSet> &);
00069 ~DistShellPair();
00071 void init();
00073 void set_dynamic(int d);
00075 void set_debug(int d) { debug_ = d; }
00077 void set_print_percent(int p) { print_percent_ = p; }
00082 int get_task(int &P, int &Q);
00083 };
00084
00085 #endif
00086
00087
00088
00089
00090
00091
00092