#ifndef _DTRAIN_NET_H_ #define _DTRAIN_NET_H_ #include "dtrain.h" namespace dtrain { template inline void vectorAsString(SparseVector& v, ostringstream& os) { SparseVector::iterator it = v.begin(); for (; it != v.end(); ++it) { os << FD::Convert(it->first) << "=" << it->second; auto peek = it; if (++peek != v.end()) os << " "; } } template inline void updateVectorFromString(string& s, SparseVector& v) { string buf; istringstream ss; while (ss >> buf) { size_t p = buf.find_last_of("="); istringstream c(buf.substr(p+1,buf.size())); weight_t val; c >> val; v[FD::Convert(buf.substr(0,p))] = val; } } bool dtrain_net_init(int argc, char** argv, po::variables_map* conf) { po::options_description ini("Configuration File Options"); ini.add_options() ("decoder_conf,C", po::value(), "configuration file for decoder") ("k", po::value()->default_value(100), "size of kbest list") ("N", po::value()->default_value(4), "N for BLEU approximation") ("margin,m", po::value()->default_value(0.), "margin for margin perceptron") ("output,o", po::value()->default_value(""), "final weights file"); po::options_description cl("Command Line Options"); cl.add_options() ("conf,c", po::value(), "dtrain configuration file") ("addr,a", po::value(), "address of master"); cl.add(ini); po::store(parse_command_line(argc, argv, cl), *conf); if (conf->count("conf")) { ifstream f((*conf)["conf"].as().c_str()); po::store(po::parse_config_file(f, ini), *conf); } po::notify(*conf); if (!conf->count("decoder_conf")) { cerr << "Missing decoder configuration. Exiting." << endl; return false; } if (!conf->count("addr")) { cerr << "No master address given! Exiting." << endl; return false; } return true; } } // namespace #endif