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