]> 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   string getParaNames();
23   string getParaVals();
24
25  private:
26   int nprocs, rank;
27   int thisjob;
28   map<string,double> defaultPara;
29   map< string, vector<double> > paraMap;
30   map< string, vector<double*> > rangeMap;
31   vector< map<string,double>  > jobList;
32   void initJobList();
33   bool inParas(vector<double>& paraVec, double& tofind);
34   double masterdefault;
35   bool jobListInitialized;
36   void uniqueAllParaIdsAdd(const string& paraid);
37 };
38
39 #endif