for( vector<double*>::iterator rangeIt = paraIt->second.begin(); rangeIt != paraIt->second.end(); ++rangeIt)
rangestring << "-" << paraIt->first << (*rangeIt)[0] << "_" << (*rangeIt)[1] << "_" << (*rangeIt)[2];
- for (vector< pair<string,string> >::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
- rangestring << "-" << linkit->first << "--" << linkit->second;
+ for (vector<paralink>::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
+ rangestring << "-" << linkit->first << "--" << linkit->linktype << "--" << linkit->second;
for( map<string,double>::iterator defIt = defaultPara.begin(); defIt != defaultPara.end(); ++defIt )
if( rangeMap.find(defIt->first) == rangeMap.end() ) {
bool linkedpara = false;
- for (vector< pair<string,string> >::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
+ for (vector<paralink>::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
if (linkit->first == defIt->first) {
linkedpara = true;
break;
jobList.back()[paraIt->first] = *valIt;
/* also set linked parameters */
- for (vector< pair<string,string> >::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
+ for (vector<paralink>::iterator linkit = linkedParas.begin(); linkit != linkedParas.end(); ++linkit)
if (linkit->second == paraIt->first)
- jobList.back()[linkit->first] = *valIt;
+ jobList.back()[linkit->first] = linkTypeFunction(*valIt, linkit->linktype);
}
jobList.erase( jobList.begin() );
}
}
}
+double paraq::linkTypeFunction (double linkval, int linktype) {
+ switch (linktype) {
+
+ case LINK_1TO1:
+ return linkval;
+
+ case LINK_NEGATIVE:
+ return -linkval;
+
+ }
+}
+
int paraq::nextParas()
{
if( thisjob == -1 ) {
#include <map>
#include <vector>
+#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);
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) { linkedParas.push_back( make_pair(paraid1,paraid2) ); }
+ 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<string> allParaIds;
map<string,double> defaultPara;
map< string, vector<double> > paraMap;
map< string, vector<double*> > rangeMap;
- vector< pair<string,string> > linkedParas;
+ vector<paralink> linkedParas;
vector< map<string,double> > jobList;
void initJobList();
bool inParas(vector<double>& paraVec, double& tofind);
double masterdefault;
bool jobListInitialized;
void uniqueAllParaIdsAdd(const string& paraid);
+ double linkTypeFunction (double linkval, int linktype);
};
#endif