X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/44862121803df9a22a5b88b8df2167f5f4afe6b1..d09f5f0aeff338a0262c3faf5272b82945a3bf8f:/paraq.h diff --git a/paraq.h b/paraq.h index 7108974..70070f3 100644 --- a/paraq.h +++ b/paraq.h @@ -5,25 +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