X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/03a0d20d92b54e75ac862b9e41ede061b1918498..f6dad6a4230bed002b51de0ec8ff34410bac27ec:/paraq.h?ds=sidebyside diff --git a/paraq.h b/paraq.h index 6f6a1a0..70070f3 100644 --- a/paraq.h +++ b/paraq.h @@ -5,28 +5,58 @@ #include #include +#define LINK_1TO1 0 +#define LINK_NEGATIVE 1 + using namespace std; class paraq { + private: + struct paralink { + string first; + string second; + int linktype; + }; + public: paraq(int nprocs, int rank); void addRange(const string& paraid, double min, double max, double step); int nextParas(); double& operator[] (string paraid); void addRange(const string& paraid, double range[3]) { addRange(paraid, range[0], range[1], range[2]); } - void setDefault(const string& paraid, double value) { defaultPara[paraid] = value; } + void addRange(const string& paraid, char *range); + void setDefault(const string& paraid, double value) { defaultPara[paraid] = value; uniqueAllParaIdsAdd(paraid); } + + void linkParas(const string& paraid1, const string ¶id2, int linktype=LINK_1TO1) { + paralink tmpLink; + + tmpLink.first = paraid1; + tmpLink.second = paraid2; + tmpLink.linktype = linktype; + + linkedParas.push_back( tmpLink ); + //linkedParas.push_back( make_pair(paraid1,paraid2) ); + } int getTotalJobs(); + string rangeString(); + vector allParaIds; + string getParaNames(); + string getParaVals(); private: int nprocs, rank; int thisjob; map defaultPara; map< string, vector > paraMap; + map< string, vector > rangeMap; + vector linkedParas; vector< map > jobList; void initJobList(); bool inParas(vector& paraVec, double& tofind); double masterdefault; bool jobListInitialized; + void uniqueAllParaIdsAdd(const string& paraid); + double linkTypeFunction (double linkval, int linktype); }; #endif