]> git.treefish.org Git - phys/latlib.git/blob - paraq.h
added virtual equilibration.
[phys/latlib.git] / paraq.h
1 #ifndef PARAQ_H
2 #define PARAQ_H
3
4 #include <string>
5 #include <map>
6 #include <vector>
7
8 using namespace std;
9
10 class paraq {
11  public: 
12   paraq(int nprocs, int rank);
13   void addRange(const string& paraid, double min, double max, double step);
14   int nextParas();
15   double& operator[] (string paraid);
16   void addRange(const string& paraid, double range[3]) { addRange(paraid, range[0], range[1], range[2]); }
17   void addRange(const string& paraid, char *range);
18   void setDefault(const string& paraid, double value) { defaultPara[paraid] = value; }
19   int getTotalJobs();
20   string rangeString();
21
22  private:
23   int nprocs, rank;
24   int thisjob;
25   map<string,double> defaultPara;
26   map< string, vector<double> > paraMap;
27   map< string, vector<double*> > rangeMap;
28   vector< map<string,double>  > jobList;
29   void initJobList();
30   bool inParas(vector<double>& paraVec, double& tofind);
31   double masterdefault;
32   bool jobListInitialized;
33 };
34
35 #endif