]> git.treefish.org Git - phys/latlib.git/blob - paraq.h
...
[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; uniqueAllParaIdsAdd(paraid); }
19   int getTotalJobs();
20   string rangeString();
21   vector<string> allParaIds;
22
23  private:
24   int nprocs, rank;
25   int thisjob;
26   map<string,double> defaultPara;
27   map< string, vector<double> > paraMap;
28   map< string, vector<double*> > rangeMap;
29   vector< map<string,double>  > jobList;
30   void initJobList();
31   bool inParas(vector<double>& paraVec, double& tofind);
32   double masterdefault;
33   bool jobListInitialized;
34   void uniqueAllParaIdsAdd(const string& paraid);
35 };
36
37 #endif