X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/d3e332b13eccd2fa7e467770f6d973b4f34904cf..074bd4d5f4b73c85da8f105ba3bfca00bf490ac8:/paraq.h diff --git a/paraq.h b/paraq.h index 9aaf1d0..70070f3 100644 --- a/paraq.h +++ b/paraq.h @@ -5,19 +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); - map* nextParas(); + int nextParas(); + double& operator[] (string paraid); + void addRange(const string& paraid, double range[3]) { addRange(paraid, range[0], range[1], range[2]); } + 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 lastjob; - map< string, vector< double* > > paraMap; + 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