diff options
Diffstat (limited to 'training/dtrain')
46 files changed, 933 insertions, 1577 deletions
| diff --git a/training/dtrain/Makefile.am b/training/dtrain/Makefile.am index 7717ec86..aadd376d 100644 --- a/training/dtrain/Makefile.am +++ b/training/dtrain/Makefile.am @@ -1,6 +1,6 @@  bin_PROGRAMS = dtrain -dtrain_SOURCES = dtrain.cc dtrain.h sample.h pairs.h score.h +dtrain_SOURCES = dtrain.cc dtrain.h sample.h update.h score.h  dtrain_LDADD   = ../../decoder/libcdec.a ../../klm/search/libksearch.a ../../mteval/libmteval.a ../../utils/libutils.a ../../klm/lm/libklm.a ../../klm/util/libklm_util.a ../../klm/util/double-conversion/libklm_util_double.a  AM_CPPFLAGS = -W -Wall -Wno-sign-compare -I$(top_srcdir)/utils -I$(top_srcdir)/decoder -I$(top_srcdir)/mteval diff --git a/training/dtrain/dtrain.cc b/training/dtrain/dtrain.cc index 69630206..1b7047b0 100644 --- a/training/dtrain/dtrain.cc +++ b/training/dtrain/dtrain.cc @@ -1,541 +1,207 @@  #include "dtrain.h"  #include "score.h"  #include "sample.h" -#include "pairs.h" +#include "update.h"  using namespace dtrain; - -bool -dtrain_init(int argc, char** argv, po::variables_map* conf) -{ -  po::options_description ini("Configuration File Options"); -  ini.add_options() -    ("bitext,b",          po::value<string>(),                                            "bitext: 'src ||| tgt ||| tgt ||| ...'") -    ("output,o",          po::value<string>()->default_value("-"),                          "output weights file, '-' for STDOUT") -    ("input_weights,w",   po::value<string>(),                                "input weights file (e.g. from previous iteration)") -    ("decoder_config,d",  po::value<string>(),                                                      "configuration file for cdec") -    ("print_weights",     po::value<string>(),                                               "weights to print on each iteration") -    ("stop_after",        po::value<unsigned>()->default_value(0),                                 "stop after X input sentences") -    ("keep",              po::value<bool>()->zero_tokens(),                               "keep weights files for each iteration") -    ("epochs",            po::value<unsigned>()->default_value(10),                               "# of iterations T (per shard)") -    ("k",                 po::value<unsigned>()->default_value(100),                            "how many translations to sample") -    ("filter",            po::value<string>()->default_value("uniq"),                          "filter kbest list: 'not', 'uniq'") -    ("hi_lo",             po::value<float>()->default_value(0.1),                   "hi and lo (X) for XYX (default 0.1), <= 0.5") -    ("N",                 po::value<unsigned>()->default_value(4),                                          "N for Ngrams (BLEU)") -    ("scorer",            po::value<string>()->default_value("stupid_bleu"),      "scoring: bleu, stupid_, smooth_, approx_, lc_") -    ("learning_rate",     po::value<weight_t>()->default_value(1.0),                                              "learning rate") -    ("gamma",             po::value<weight_t>()->default_value(0.),                            "gamma for SVM (0 for perceptron)") -    ("select_weights",    po::value<string>()->default_value("last"),     "output best, last, avg weights ('VOID' to throw away)") -    ("rescale",           po::value<bool>()->zero_tokens(),                     "(re)scale data and weight vector to unit length") -    ("l1_reg",            po::value<string>()->default_value("none"),      "apply l1 regularization with clipping as in 'Tsuroka et al' (2010)") -    ("l1_reg_strength",   po::value<weight_t>(),                                                     "l1 regularization strength") -    ("fselect",           po::value<weight_t>()->default_value(-1), "select top x percent (or by threshold) of features after each epoch NOT IMPLEMENTED") // TODO -    ("loss_margin",       po::value<weight_t>()->default_value(0.),  "update if no error in pref pair but model scores this near") -    ("pclr",              po::value<string>()->default_value("no"),         "use a (simple|adagrad) per-coordinate learning rate") -    ("batch",             po::value<bool>()->zero_tokens(),                                               "do batch optimization") -    ("repeat",            po::value<unsigned>()->default_value(1),     "repeat optimization over kbest list this number of times") -    ("output_ranking",    po::value<string>()->default_value(""),                                   "output scored kbests to dir") -    ("noup",              po::value<bool>()->zero_tokens(),                                                     "dont't optimize"); -  po::options_description cl("Command Line Options"); -  cl.add_options() -    ("config,c",         po::value<string>(),              "dtrain config file") -    ("quiet,q",          po::value<bool>()->zero_tokens(),           "be quiet") -    ("verbose,v",        po::value<bool>()->zero_tokens(),         "be verbose"); -  cl.add(ini); -  po::store(parse_command_line(argc, argv, cl), *conf); -  if (conf->count("config")) { -    ifstream ini_f((*conf)["config"].as<string>().c_str()); -    po::store(po::parse_config_file(ini_f, ini), *conf); -  } -  po::notify(*conf); -  if (!conf->count("decoder_config")) { -    cerr << cl << endl; -    return false; -  } -  if ((*conf)["hi_lo"].as<float>() > 0.5 || (*conf)["hi_lo"].as<float>() < 0.01) { -    cerr << "hi_lo must lie in [0.01, 0.5]" << endl; -    return false; -  } -  if (!conf->count("bitext")) { -    cerr << "No training data given." << endl; -    return false; -  } -  if ((*conf)["select_weights"].as<string>() != "last" && (*conf)["select_weights"].as<string>() != "best" && -        (*conf)["select_weights"].as<string>() != "avg" && (*conf)["select_weights"].as<string>() != "VOID") { -    cerr << "Wrong 'select_weights' param: '" << (*conf)["select_weights"].as<string>() << "', use 'last' or 'best'." << endl; -    return false; -  } -  return true; -} -  int  main(int argc, char** argv)  { -  // handle most parameters +  // get configuration    po::variables_map conf; -  if (!dtrain_init(argc, argv, &conf)) exit(1); // something is wrong - -  bool quiet = false; -  if (conf.count("quiet")) quiet = true; -  bool verbose = false; -  if (conf.count("verbose")) verbose = true; -  bool noup = false; -  if (conf.count("noup")) noup = true; -  bool keep = false; -  if (conf.count("keep")) keep = true; -  bool rescale = false; -  if (conf.count("rescale")) rescale = true; - -  const unsigned k = conf["k"].as<unsigned>(); -  const unsigned N = conf["N"].as<unsigned>(); -  const unsigned T = conf["epochs"].as<unsigned>(); -  const unsigned stop_after = conf["stop_after"].as<unsigned>(); -  const string select_weights = conf["select_weights"].as<string>(); -  const string output_ranking = conf["output_ranking"].as<string>(); -  const float hi_lo = conf["hi_lo"].as<float>(); -  int repeat = conf["repeat"].as<unsigned>(); -  weight_t loss_margin = conf["loss_margin"].as<weight_t>(); -  bool batch = false; -  if (conf.count("batch")) batch = true; -  if (loss_margin > 9998.) loss_margin = std::numeric_limits<float>::max(); -  const string pclr = conf["pclr"].as<string>(); -  bool average = false; -  if (select_weights == "avg") -    average = true; +  if (!dtrain_init(argc, argv, &conf)) +    exit(1); // something is wrong +  const size_t k              = conf["k"].as<size_t>(); +  const size_t N              = conf["N"].as<size_t>(); +  const size_t T              = conf["iterations"].as<size_t>(); +  const weight_t eta          = conf["learning_rate"].as<weight_t>(); +  const weight_t error_margin = conf["error_margin"].as<weight_t>(); +  const bool average          = conf["average"].as<bool>(); +  const bool keep             = conf["keep"].as<bool>(); +  const weight_t l1_reg       = conf["l1_reg"].as<weight_t>(); +  const string output_fn      = conf["output"].as<string>();    vector<string> print_weights; -  if (conf.count("print_weights")) -    boost::split(print_weights, conf["print_weights"].as<string>(), boost::is_any_of(" ")); +  boost::split(print_weights, conf["print_weights"].as<string>(), boost::is_any_of(" "));    // setup decoder    register_feature_functions();    SetSilent(true); -  ReadFile ini_rf(conf["decoder_config"].as<string>()); -  if (!quiet) -    cerr << setw(25) << "cdec conf " << "'" << conf["decoder_config"].as<string>() << "'" << endl; -  Decoder decoder(ini_rf.stream()); +  ReadFile f(conf["decoder_config"].as<string>()); +  Decoder decoder(f.stream());    // setup decoder observer    ScoredKbest* observer = new ScoredKbest(k, new PerSentenceBleuScorer(N)); -  // init weights +  // weights    vector<weight_t>& decoder_weights = decoder.CurrentWeightVector(); - -  SparseVector<weight_t> lambdas, cumulative_penalties, w_average, fixed; -  if (conf.count("input_weights")) +  SparseVector<weight_t> lambdas, w_average; +  if (conf.count("input_weights")) {      Weights::InitFromFile(conf["input_weights"].as<string>(), &decoder_weights); -  Weights::InitSparseVector(decoder_weights, &lambdas); - -  // meta params for perceptron, SVM -  weight_t eta = conf["learning_rate"].as<weight_t>(); -  weight_t gamma = conf["gamma"].as<weight_t>(); - -  // faster perceptron: consider only misranked pairs, see -  bool faster_perceptron = false; -  if (gamma==0 && loss_margin==0) faster_perceptron = true; - -  // l1 regularization -  bool l1naive = false; -  bool l1clip = false; -  bool l1cumul = false; -  weight_t l1_reg = 0; -  if (conf["l1_reg"].as<string>() != "none") { -    string s = conf["l1_reg"].as<string>(); -    if (s == "naive") l1naive = true; -    else if (s == "clip") l1clip = true; -    else if (s == "cumul") l1cumul = true; -    l1_reg = conf["l1_reg_strength"].as<weight_t>(); +    Weights::InitSparseVector(decoder_weights, &lambdas);    } -  // output -  string output_fn = conf["output"].as<string>();    // input -  string input_fn; -  ReadFile input(conf["bitext"].as<string>()); -  // buffer input for t > 0 -  vector<string> src_str_buf;          // source strings (decoder takes only strings) -  vector<vector<vector<WordID> > > refs_as_ids_buf; // references as WordID vecs - -  unsigned in_sz = std::numeric_limits<unsigned>::max(); // input index, input size -  vector<pair<score_t, score_t> > all_scores; -  score_t max_score = 0.; -  unsigned best_it = 0; -  float overall_time = 0.; - -  // output conf -  if (!quiet) { -    cerr << _p5; -    cerr << endl << "dtrain" << endl << "Parameters:" << endl; -    cerr << setw(25) << "k " << k << endl; -    cerr << setw(25) << "N " << N << endl; -    cerr << setw(25) << "T " << T << endl; -    cerr << setw(25) << "batch " << batch << endl; -    cerr << setw(25) << "learning rate " << eta << endl; -    cerr << setw(25) << "gamma " << gamma << endl; -    cerr << setw(25) << "loss margin " << loss_margin << endl; -    cerr << setw(25) << "faster perceptron " << faster_perceptron << endl; -    cerr << setw(25) << "hi lo " << hi_lo << endl; -    cerr << setw(25) << "select weights " << "'" << select_weights << "'" << endl; -    if (conf.count("l1_reg")) -      cerr << setw(25) << "l1 reg " << l1_reg << " '" << conf["l1_reg"].as<string>() << "'" << endl; -    if (rescale) -      cerr << setw(25) << "rescale " << rescale << endl; -    cerr << setw(25) << "pclr " << pclr << endl; -    cerr << setw(25) << "repeat " << repeat << endl; -    cerr << setw(25) << "cdec conf " << "'" << conf["decoder_config"].as<string>() << "'" << endl; -    cerr << setw(25) << "input " << "'" << input_fn << "'" << endl; -    cerr << setw(25) << "output " << "'" << output_fn << "'" << endl; -    if (conf.count("input_weights")) -      cerr << setw(25) << "weights in " << "'" << conf["input_weights"].as<string>() << "'" << endl; -    if (stop_after > 0) -      cerr << setw(25) << "stop_after " << stop_after << endl; -    if (!verbose) cerr << "(a dot represents " << DTRAIN_DOTS << " inputs)" << endl; -  } +  string input_fn = conf["bitext"].as<string>(); +  ReadFile input(input_fn); +  vector<string> buf;              // source strings (decoder takes only strings) +  vector<vector<Ngrams> > buf_ngs;  // compute ngrams and lengths of references +  vector<vector<size_t> > buf_ls; // just once +  size_t input_sz = 0; + +  // output configuration +  cerr << _p5 << "dtrain" << endl << "Parameters:" << endl; +  cerr << setw(25) << "k " << k << endl; +  cerr << setw(25) << "N " << N << endl; +  cerr << setw(25) << "T " << T << endl; +  cerr << setw(25) << "learning rate " << eta << endl; +  cerr << setw(25) << "error margin " << error_margin << endl; +  cerr << setw(25) << "l1 reg " << l1_reg << endl; +  cerr << setw(25) << "decoder conf " << "'" << conf["decoder_config"].as<string>() << "'" << endl; +  cerr << setw(25) << "input " << "'" << input_fn << "'" << endl; +  cerr << setw(25) << "output " << "'" << output_fn << "'" << endl; +  if (conf.count("input_weights")) +    cerr << setw(25) << "weights in " << "'" << conf["input_weights"].as<string>() << "'" << endl; +  cerr << "(a dot per input)" << endl; -  // pclr -  SparseVector<weight_t> learning_rates; -  // batch -  SparseVector<weight_t> batch_updates; -  score_t batch_loss; +  // meta +  weight_t best=0., gold_prev=0.; +  size_t best_iteration = 0; +  time_t total_time = 0.; -  for (unsigned t = 0; t < T; t++) // T epochs +  for (size_t t = 0; t < T; t++) // T iterations    {    time_t start, end;    time(&start); -  score_t score_sum = 0.; -  score_t model_sum(0); -  unsigned ii = 0, rank_errors = 0, margin_violations = 0, npairs = 0, f_count = 0, list_sz = 0, kbest_loss_improve = 0; -  batch_loss = 0.; -  if (!quiet) cerr << "Iteration #" << t+1 << " of " << T << "." << endl; +  weight_t gold_sum=0., model_sum=0.; +  size_t i = 0, num_pairs = 0, feature_count = 0, list_sz = 0; + +  cerr << "Iteration #" << t+1 << " of " << T << "." << endl;    while(true)    { +    bool next = true; -    string in; -    vector<string> refs; -    bool next = false, stop = false; // next iteration or premature stop +    // getting input      if (t == 0) { -      if(!getline(*input, in)) next = true; -        boost::algorithm::split_regex(refs, in, boost::regex(" \\|\\|\\| ")); -        in = refs[0]; -        refs.erase(refs.begin()); -    } else { -      if (ii == in_sz) next = true; // stop if we reach the end of our input -    } -    // stop after X sentences (but still go on for those) -    if (stop_after > 0 && stop_after == ii && !next) stop = true; - -    // produce some pretty output -    if (!quiet && !verbose) { -      if (ii == 0) cerr << " "; -      if ((ii+1) % (DTRAIN_DOTS) == 0) { -        cerr << "."; -        cerr.flush(); -      } -      if ((ii+1) % (20*DTRAIN_DOTS) == 0) { -        cerr << " " << ii+1 << endl; -        if (!next && !stop) cerr << " "; -      } -      if (stop) { -        if (ii % (20*DTRAIN_DOTS) != 0) cerr << " " << ii << endl; -        cerr << "Stopping after " << stop_after << " input sentences." << endl; +      string in; +      if(!getline(*input, in)) { +        next = false;        } else { -        if (next) { -          if (ii % (20*DTRAIN_DOTS) != 0) cerr << " " << ii << endl; +        vector<string> parts; +        boost::algorithm::split_regex(parts, in, boost::regex(" \\|\\|\\| ")); +        buf.push_back(parts[0]); +        parts.erase(parts.begin()); +        buf_ngs.push_back({}); +        buf_ls.push_back({}); +        for (auto s: parts) { +          vector<WordID> r; +          vector<string> tok; +          boost::split(tok, s, boost::is_any_of(" ")); +          RegisterAndConvert(tok, r); +          buf_ngs.back().emplace_back(MakeNgrams(r, N)); +          buf_ls.back().push_back(r.size());          }        } +    } else { +      next = i<input_sz;      } -    // next iteration -    if (next || stop) break; - -    // weights -    lambdas.init_vector(&decoder_weights); - -    // getting input -    if (t == 0) { -      vector<vector<WordID> > cur_refs; -      for (auto r: refs) { -        vector<WordID> cur_ref; -        vector<string> tok; -        boost::split(tok, r, boost::is_any_of(" ")); -        RegisterAndConvert(tok, cur_ref); -        cur_refs.push_back(cur_ref); -      } -      refs_as_ids_buf.push_back(cur_refs); -      src_str_buf.push_back(in); -    } -    observer->SetReference(refs_as_ids_buf[ii]); -    if (t == 0) -      decoder.Decode(in, observer); -    else -      decoder.Decode(src_str_buf[ii], observer); - -    // get (scored) samples +    // produce some pretty output +    if (i == 0 || (i+1)%20==0) +      cerr << " "; +    cerr << "."; +    cerr.flush(); +    if (!next) +      if (i%20 != 0) cerr << " " << i << endl; + +    // stop iterating +    if (!next) break; + +    // decode +    if (t > 0 || i > 0) +      lambdas.init_vector(&decoder_weights); +    observer->SetReference(buf_ngs[i], buf_ls[i]); +    decoder.Decode(buf[i], observer);      vector<ScoredHyp>* samples = observer->GetSamples(); -    if (output_ranking != "") { -      WriteFile of(output_ranking+"/"+to_string(t)+"."+to_string(ii)+".list"); // works with '-' -      stringstream ss; -      for (auto s: *samples) { -        ss << ii << " ||| "; -        PrintWordIDVec(s.w, ss); -        ss << " ||| " << s.model << " ||| " << s.score << endl; -      } -      of.get() << ss.str(); -    } - -    if (verbose) { -      cerr << "--- refs for " << ii << ": "; -      for (auto r: refs_as_ids_buf[ii]) { -        PrintWordIDVec(r); -        cerr << endl; -      } -      for (unsigned u = 0; u < samples->size(); u++) { -        cerr << _p2 << _np << "[" << u << ". '"; -        PrintWordIDVec((*samples)[u].w); -        cerr << "'" << endl; -        cerr << "SCORE=" << (*samples)[u].score << ",model="<< (*samples)[u].model << endl; -        cerr << "F{" << (*samples)[u].f << "} ]" << endl << endl; -      } -    } - -    if (repeat == 1) { -      score_sum += (*samples)[0].score; // stats for 1best -      model_sum += (*samples)[0].model; -    } - -    f_count += observer->GetFeatureCount(); +    // stats for 1best +    gold_sum += samples->front().gold; +    model_sum += samples->front().model; +    feature_count += observer->GetFeatureCount();      list_sz += observer->GetSize(); -    // weight updates -    if (!noup) { -      // get pairs -      vector<pair<ScoredHyp,ScoredHyp> > pairs; -      MakePairs(samples, pairs, faster_perceptron, hi_lo); -      int cur_npairs = pairs.size(); -      npairs += cur_npairs; - -      score_t kbest_loss_first = 0.0, kbest_loss_last = 0.0; - -      for (vector<pair<ScoredHyp,ScoredHyp> >::iterator it = pairs.begin(); -           it != pairs.end(); it++) { -        if (rescale) { -          it->first.f /= it->first.f.l2norm(); -          it->second.f /= it->second.f.l2norm(); -        } -        score_t model_diff = it->first.model - it->second.model; -        score_t loss = max(0.0, -1.0 * model_diff); -        kbest_loss_first += loss; -      } - -      score_t kbest_loss = 0.0; -      for (int ki=0; ki < repeat; ki++) { - -      SparseVector<weight_t> lambdas_copy; // for l1 regularization -      SparseVector<weight_t> sum_up; // for pclr -      if (l1naive||l1clip||l1cumul) lambdas_copy = lambdas; - -      for (vector<pair<ScoredHyp,ScoredHyp> >::iterator it = pairs.begin(); -           it != pairs.end(); it++) { -        score_t model_diff = it->first.model - it->second.model; -        score_t loss = max(0.0, -1.0 * model_diff); - -        if (repeat > 1) { -          model_diff = lambdas.dot(it->first.f) - lambdas.dot(it->second.f); -          kbest_loss += loss; -        } -        bool rank_error = false; -        score_t margin; -        if (faster_perceptron) { // we only have considering misranked pairs -          rank_error = true; // pair sampling already did this for us -          margin = std::numeric_limits<float>::max(); -        } else { -          rank_error = model_diff<=0.0; -          margin = fabs(model_diff); -          if (!rank_error && margin < loss_margin) margin_violations++; -        } -        if (rank_error && ki==0) rank_errors++; -        if (rank_error || margin < loss_margin) { -          SparseVector<weight_t> diff_vec = it->first.f - it->second.f; -          if (batch) { -            batch_loss += max(0., -1.0 * model_diff); -            batch_updates += diff_vec; -            continue; -          } -          if (pclr != "no") { -            sum_up += diff_vec; +    // get pairs and update +    vector<pair<ScoredHyp,ScoredHyp> > pairs; +    SparseVector<weight_t> updates; +    num_pairs += CollectUpdates(samples, updates, error_margin); +    SparseVector<weight_t> lambdas_copy; +    if (l1_reg) +      lambdas_copy = lambdas; +    lambdas.plus_eq_v_times_s(updates, eta); + +    // l1 regularization +    // NB: regularization is done after each sentence, +    //     not after every single pair! +    if (l1_reg) { +      SparseVector<weight_t>::iterator it = lambdas.begin(); +      for (; it != lambdas.end(); ++it) { +        if (it->second == 0) continue; +        if (!lambdas_copy.get(it->first)                // new or.. +            || lambdas_copy.get(it->first)!=it->second) // updated feature +        { +          weight_t v = it->second; +          if (v > 0) { +            it->second = max(0., v - l1_reg);            } else { -            lambdas.plus_eq_v_times_s(diff_vec, eta); -            if (gamma) lambdas.plus_eq_v_times_s(lambdas, -2*gamma*eta*(1./cur_npairs)); -          } -        } -      } - -      // per-coordinate learning rate -      if (pclr != "no") { -        SparseVector<weight_t>::iterator it = sum_up.begin(); -        for (; it != sum_up.end(); ++it) { -          if (pclr == "simple") { -           lambdas[it->first] += it->second / max(1.0, learning_rates[it->first]); -           learning_rates[it->first]++; -          } else if (pclr == "adagrad") { -            if (learning_rates[it->first] == 0) { -             lambdas[it->first] +=  it->second * eta; -            } else { -             lambdas[it->first] +=  it->second * eta * learning_rates[it->first]; -            } -            learning_rates[it->first] += pow(it->second, 2.0); +            it->second = min(0., v + l1_reg);            }          }        } +    } -      // l1 regularization -      // please note that this regularizations happen -      // after a _sentence_ -- not after each example/pair! -      if (l1naive) { -        SparseVector<weight_t>::iterator it = lambdas.begin(); -        for (; it != lambdas.end(); ++it) { -          if (!lambdas_copy.get(it->first) || lambdas_copy.get(it->first)!=it->second) { -              it->second *= max(0.0000001, eta/(eta+learning_rates[it->first])); // FIXME -              learning_rates[it->first]++; -            it->second -= sign(it->second) * l1_reg; -          } -        } -      } else if (l1clip) { -        SparseVector<weight_t>::iterator it = lambdas.begin(); -        for (; it != lambdas.end(); ++it) { -          if (!lambdas_copy.get(it->first) || lambdas_copy.get(it->first)!=it->second) { -            if (it->second != 0) { -              weight_t v = it->second; -              if (v > 0) { -                it->second = max(0., v - l1_reg); -              } else { -                it->second = min(0., v + l1_reg); -              } -            } -          } -        } -      } else if (l1cumul) { -        weight_t acc_penalty = (ii+1) * l1_reg; // ii is the index of the current input -        SparseVector<weight_t>::iterator it = lambdas.begin(); -        for (; it != lambdas.end(); ++it) { -          if (!lambdas_copy.get(it->first) || lambdas_copy.get(it->first)!=it->second) { -            if (it->second != 0) { -              weight_t v = it->second; -              weight_t penalized = 0.; -              if (v > 0) { -                penalized = max(0., v-(acc_penalty + cumulative_penalties.get(it->first))); -              } else { -                penalized = min(0., v+(acc_penalty - cumulative_penalties.get(it->first))); -              } -              it->second = penalized; -              cumulative_penalties.set_value(it->first, cumulative_penalties.get(it->first)+penalized); -            } -          } -        } -      } - -      if (ki==repeat-1) { // done -        kbest_loss_last = kbest_loss; -        if (repeat > 1) { -          score_t best_model = -std::numeric_limits<score_t>::max(); -          unsigned best_idx = 0; -          for (unsigned i=0; i < samples->size(); i++) { -            score_t s = lambdas.dot((*samples)[i].f); -            if (s > best_model) { -              best_idx = i; -              best_model = s; -            } -          } -          score_sum += (*samples)[best_idx].score; -          model_sum += best_model; -        } -      } -    } // repeat - -    if ((kbest_loss_first - kbest_loss_last) >= 0) kbest_loss_improve++; - -    } // noup - -    if (rescale) lambdas /= lambdas.l2norm(); - -    ++ii; +    i++;    } // input loop -  if (t == 0) in_sz = ii; // remember size of input (# lines) - -  if (batch) { -    lambdas.plus_eq_v_times_s(batch_updates, eta); -    if (gamma) lambdas.plus_eq_v_times_s(lambdas, -2*gamma*eta*(1./npairs)); -    batch_updates.clear(); -  } - -  if (average) w_average += lambdas; - -  // print some stats -  score_t score_avg = score_sum/(score_t)in_sz; -  score_t model_avg = model_sum/(score_t)in_sz; -  score_t score_diff, model_diff; -  if (t > 0) { -    score_diff = score_avg - all_scores[t-1].first; -    model_diff = model_avg - all_scores[t-1].second; -  } else { -    score_diff = score_avg; -    model_diff = model_avg; +  if (t == 0) +    input_sz = i; // remember size of input (# lines) + +  // update average +  if (average) +    w_average += lambdas; + +  // stats +  weight_t gold_avg = gold_sum/(weight_t)input_sz; +  size_t non_zero = (size_t)lambdas.num_nonzero(); +  cerr << _p5 << _p << "WEIGHTS" << endl; +  for (auto name: print_weights) +    cerr << setw(18) << name << " = " << lambdas.get(FD::Convert(name)) << endl; +  cerr << "        ---" << endl; +  cerr << _np << "       1best avg score: " << gold_avg; +  cerr << _p << " (" << gold_avg-gold_prev << ")" << endl; +  cerr << _np << " 1best avg model score: " << model_sum/(weight_t)input_sz << endl; +  cerr << "           avg # pairs: "; +  cerr << _np << num_pairs/(float)input_sz << endl; +  cerr << "   non-0 feature count: " <<  non_zero << endl; +  cerr << "           avg list sz: " << list_sz/(float)input_sz << endl; +  cerr << "           avg f count: " << feature_count/(float)list_sz << endl; + +  if (gold_avg > best) { +    best = gold_avg; +    best_iteration = t;    } +  gold_prev = gold_avg; -  unsigned nonz = 0; -  if (!quiet) nonz = (unsigned)lambdas.num_nonzero(); - -  if (!quiet) { -    cerr << _p5 << _p << "WEIGHTS" << endl; -    for (vector<string>::iterator it = print_weights.begin(); it != print_weights.end(); it++) { -      cerr << setw(18) << *it << " = " << lambdas.get(FD::Convert(*it)) << endl; -    } -    cerr << "        ---" << endl; -    cerr << _np << "       1best avg score: " << score_avg; -    cerr << _p << " (" << score_diff << ")" << endl; -    cerr << _np << " 1best avg model score: " << model_avg; -    cerr << _p << " (" << model_diff << ")" << endl; -    cerr << "           avg # pairs: "; -    cerr << _np << npairs/(float)in_sz << endl; -    cerr << "        avg # rank err: "; -    cerr << rank_errors/(float)in_sz; -    if (faster_perceptron) cerr << " (meaningless)"; -    cerr << endl; -    cerr << "     avg # margin viol: "; -    cerr << margin_violations/(float)in_sz << endl; -    if (batch) cerr << "            batch loss: " << batch_loss << endl; -    cerr << "       k-best loss imp: " << ((float)kbest_loss_improve/in_sz)*100 << "%" << endl; -    cerr << "    non0 feature count: " <<  nonz << endl; -    cerr << "           avg list sz: " << list_sz/(float)in_sz << endl; -    cerr << "           avg f count: " << f_count/(float)list_sz << endl; -  } - -  pair<score_t,score_t> remember; -  remember.first = score_avg; -  remember.second = model_avg; -  all_scores.push_back(remember); -  if (score_avg > max_score) { -    max_score = score_avg; -    best_it = t; -  }    time (&end); -  float time_diff = difftime(end, start); -  overall_time += time_diff; -  if (!quiet) { -    cerr << _p2 << _np << "(time " << time_diff/60. << " min, "; -    cerr << time_diff/in_sz << " s/S)" << endl; -  } -  if (t+1 != T && !quiet) cerr << endl; - -  if (noup) break; +  time_t time_diff = difftime(end, start); +  total_time += time_diff; +  cerr << _p2 << _np << "(time " << time_diff/60. << " min, "; +  cerr << time_diff/input_sz << " s/S)" << endl; +  if (t+1 != T) cerr << endl; -  // write weights to file -  if (select_weights == "best" || keep) { +  if (keep) { // keep intermediate weights      lambdas.init_vector(&decoder_weights);      string w_fn = "weights." + boost::lexical_cast<string>(t) + ".gz";      Weights::WriteToFile(w_fn, decoder_weights, true); @@ -543,51 +209,19 @@ main(int argc, char** argv)    } // outer loop -  if (average) w_average /= (weight_t)T; - -  if (!noup) { -    if (!quiet) cerr << endl << "Writing weights file to '" << output_fn << "' ..." << endl; -    if (select_weights == "last" || average) { // last, average -      WriteFile of(output_fn); -      ostream& o = *of.stream(); -      o.precision(17); -      o << _np; -      if (average) { -        for (SparseVector<weight_t>::iterator it = w_average.begin(); it != w_average.end(); ++it) { -	      if (it->second == 0) continue; -          o << FD::Convert(it->first) << '\t' << it->second << endl; -        } -      } else { -        for (SparseVector<weight_t>::iterator it = lambdas.begin(); it != lambdas.end(); ++it) { -	      if (it->second == 0) continue; -          o << FD::Convert(it->first) << '\t' << it->second << endl; -        } -      } -    } else if (select_weights == "VOID") { // do nothing with the weights -    } else { // best -      if (output_fn != "-") { -        CopyFile("weights."+boost::lexical_cast<string>(best_it)+".gz", output_fn); -      } else { -        ReadFile bestw("weights."+boost::lexical_cast<string>(best_it)+".gz"); -        string o; -        cout.precision(17); -        cout << _np; -        while(getline(*bestw, o)) cout << o << endl; -      } -      if (!keep) { -        for (unsigned i = 0; i < T; i++) { -          string s = "weights." + boost::lexical_cast<string>(i) + ".gz"; -          unlink(s.c_str()); -        } -      } -    } -    if (!quiet) cerr << "done" << endl; +  // final weights +  if (average) { +    w_average /= (weight_t)T; +    w_average.init_vector(decoder_weights); +  } else if (!keep) { +    lambdas.init_vector(decoder_weights);    } +  Weights::WriteToFile(output_fn, decoder_weights, true); -  if (!quiet) { -    cerr << _p5 << _np << endl << "---" << endl << "Best iteration: "; -    cerr << best_it+1 << " [SCORE = " << max_score << "]." << endl; -    cerr << "This took " << overall_time/60. << " min." << endl; -  } +  cerr << _p5 << _np << endl << "---" << endl << "Best iteration: "; +  cerr << best_iteration+1 << " [GOLD = " << best << "]." << endl; +  cerr << "This took " << total_time/60. << " min." << endl; + +  return 0;  } diff --git a/training/dtrain/dtrain.h b/training/dtrain/dtrain.h index 2b466930..728b0698 100644 --- a/training/dtrain/dtrain.h +++ b/training/dtrain/dtrain.h @@ -1,9 +1,6 @@  #ifndef _DTRAIN_H_  #define _DTRAIN_H_ -#define DTRAIN_DOTS 10 // after how many inputs to display a '.' -#define DTRAIN_SCALE 100000 -  #include <iomanip>  #include <climits>  #include <string.h> @@ -25,20 +22,17 @@ namespace po = boost::program_options;  namespace dtrain  { -typedef double score_t; -  struct ScoredHyp  { -  vector<WordID> w; +  vector<WordID>         w;    SparseVector<weight_t> f; -  score_t model, score; -  unsigned rank; +  weight_t               model, gold; +  size_t               rank;  };  inline void  RegisterAndConvert(const vector<string>& strs, vector<WordID>& ids)  { -  vector<string>::const_iterator it;    for (auto s: strs)      ids.push_back(TD::Convert(s));  } @@ -46,7 +40,7 @@ RegisterAndConvert(const vector<string>& strs, vector<WordID>& ids)  inline void  PrintWordIDVec(vector<WordID>& v, ostream& os=cerr)  { -  for (unsigned i = 0; i < v.size(); i++) { +  for (size_t i = 0; i < v.size(); i++) {      os << TD::Convert(v[i]);      if (i < v.size()-1) os << " ";    } @@ -57,12 +51,45 @@ inline ostream& _p(ostream& out)  { return out << setiosflags(ios::showpos); }  inline ostream& _p2(ostream& out) { return out << setprecision(2); }  inline ostream& _p5(ostream& out) { return out << setprecision(5); } -template<typename T> -inline T -sign(T z) +bool +dtrain_init(int argc, char** argv, po::variables_map* conf)  { -  if (z == 0) return 0; -  return z < 0 ? -1 : +1; +  po::options_description ini("Configuration File Options"); +  ini.add_options() +    ("bitext,b",          po::value<string>(),                                                   "bitext") +    ("decoder_config,C",  po::value<string>(),                           "configuration file for decoder") +    ("iterations,T",      po::value<size_t>()->default_value(10),    "number of iterations T (per shard)") +    ("k",                 po::value<size_t>()->default_value(100),                   "size of kbest list") +    ("learning_rate,l",   po::value<weight_t>()->default_value(1.0),                      "learning rate") +    ("l1_reg,r",          po::value<weight_t>()->default_value(0.),          "l1 regularization strength") +    ("error_margin,m",    po::value<weight_t>()->default_value(0.),        "margin for margin perceptron") +    ("N",                 po::value<size_t>()->default_value(4),               "N for BLEU approximation") +    ("input_weights,w",   po::value<string>(),                                       "input weights file") +    ("average,a",         po::value<bool>()->default_value(false),               "output average weights") +    ("keep,K",            po::value<bool>()->default_value(false),   "output a weight file per iteration") +    ("output,o",          po::value<string>()->default_value("-"),  "output weights file, '-' for STDOUT") +    ("print_weights,P",   po::value<string>()->default_value("EgivenFCoherent SampleCountF CountEF MaxLexFgivenE MaxLexEgivenF IsSingletonF IsSingletonFE Glue WordPenalty PassThrough LanguageModel LanguageModel_OOV"), +                                                          "list of weights to print after each iteration"); +  po::options_description cl("Command Line Options"); +  cl.add_options() +    ("config,c", po::value<string>(), "dtrain config file"); +  cl.add(ini); +  po::store(parse_command_line(argc, argv, cl), *conf); +  if (conf->count("config")) { +    ifstream f((*conf)["config"].as<string>().c_str()); +    po::store(po::parse_config_file(f, ini), *conf); +  } +  po::notify(*conf); +  if (!conf->count("decoder_config")) { +    cerr << "Missing decoder configuration." << endl; +    return false; +  } +  if (!conf->count("bitext")) { +    cerr << "No training data given." << endl; +    return false; +  } + +  return true;  }  } // namespace diff --git a/training/dtrain/examples/parallelized/README b/training/dtrain/examples/parallelized/README index 2fb3b54e..c4addd81 100644 --- a/training/dtrain/examples/parallelized/README +++ b/training/dtrain/examples/parallelized/README @@ -1,5 +1,5 @@  run for example -  ../../parallelize.rb -c dtrain.ini -s 4 -e 3 -z -d ../../dtrain -p 2 -i in +  ../../parallelize.rb -c dtrain.ini -s 4 -e 3 -d ../../dtrain -p 2 -i in  final weights will be in the file work/weights.2 diff --git a/training/dtrain/examples/parallelized/dtrain.ini b/training/dtrain/examples/parallelized/dtrain.ini index 0b0932d6..9fc205a3 100644 --- a/training/dtrain/examples/parallelized/dtrain.ini +++ b/training/dtrain/examples/parallelized/dtrain.ini @@ -1,14 +1,7 @@  k=100  N=4  learning_rate=0.0001 -gamma=0 -loss_margin=1.0 -epochs=1 -scorer=stupid_bleu -sample_from=kbest -filter=uniq -pair_sampling=XYX -hi_lo=0.1 -select_weights=last -print_weights=Glue WordPenalty LanguageModel LanguageModel_OOV PhraseModel_0 PhraseModel_1 PhraseModel_2 PhraseModel_3 PhraseModel_4 PhraseModel_5 PhraseModel_6 PassThrough +error_margin=1.0 +iterations=1  decoder_config=cdec.ini +print_weights=Glue WordPenalty LanguageModel LanguageModel_OOV PhraseModel_0 PhraseModel_1 PhraseModel_2 PhraseModel_3 PhraseModel_4 PhraseModel_5 PhraseModel_6 PassThrough diff --git a/training/dtrain/examples/parallelized/work/out.0.0 b/training/dtrain/examples/parallelized/work/out.0.0 index 9154c906..77749404 100644 --- a/training/dtrain/examples/parallelized/work/out.0.0 +++ b/training/dtrain/examples/parallelized/work/out.0.0 @@ -1,65 +1,43 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 4087834873 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.0.0.in'                    output 'work/weights.0.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = +0.257 -       WordPenalty = +0.026926 -     LanguageModel = +0.67342 - LanguageModel_OOV = -0.046 -     PhraseModel_0 = +0.25329 -     PhraseModel_1 = +0.20036 -     PhraseModel_2 = +0.00060731 -     PhraseModel_3 = +0.65578 -     PhraseModel_4 = +0.47916 -     PhraseModel_5 = +0.004 -     PhraseModel_6 = +0.1829 -       PassThrough = -0.082 +              Glue = +0.3404 +       WordPenalty = -0.017632 +     LanguageModel = +0.72958 + LanguageModel_OOV = -0.235 +     PhraseModel_0 = -0.43721 +     PhraseModel_1 = +1.01 +     PhraseModel_2 = +1.3525 +     PhraseModel_3 = -0.25541 +     PhraseModel_4 = -0.78115 +     PhraseModel_5 = +0 +     PhraseModel_6 = -0.3681 +       PassThrough = -0.3304          --- -       1best avg score: 0.04518 (+0.04518) - 1best avg model score: 32.803 (+32.803) -           avg # pairs: 1266.3 -        avg # rank err: 857 -     avg # margin viol: 386.67 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.19474 (+0.19474) + 1best avg model score: 0.52232 +           avg # pairs: 2513 +   non-0 feature count: 11             avg list sz: 100 -           avg f count: 10.853 -(time 0.47 min, 9.3 s/S) - -Writing weights file to 'work/weights.0.0' ... -done +           avg f count: 11.42 +(time 0.32 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.04518]. -This took 0.46667 min. +Best iteration: 1 [GOLD = 0.19474]. +This took 0.31667 min. diff --git a/training/dtrain/examples/parallelized/work/out.0.1 b/training/dtrain/examples/parallelized/work/out.0.1 index 0dbc7bd3..d0dee623 100644 --- a/training/dtrain/examples/parallelized/work/out.0.1 +++ b/training/dtrain/examples/parallelized/work/out.0.1 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 2283043509 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.0.0.in'                    output 'work/weights.0.1'                weights in 'work/weights.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.17905 -       WordPenalty = +0.062126 -     LanguageModel = +0.66825 - LanguageModel_OOV = -0.15248 -     PhraseModel_0 = -0.55811 -     PhraseModel_1 = +0.12741 -     PhraseModel_2 = +0.60388 -     PhraseModel_3 = -0.44464 -     PhraseModel_4 = -0.63137 -     PhraseModel_5 = -0.0084 -     PhraseModel_6 = -0.20165 -       PassThrough = -0.23468 +              Glue = -0.40908 +       WordPenalty = +0.12967 +     LanguageModel = +0.39892 + LanguageModel_OOV = -0.6314 +     PhraseModel_0 = -0.63992 +     PhraseModel_1 = +0.74198 +     PhraseModel_2 = +1.3096 +     PhraseModel_3 = -0.1216 +     PhraseModel_4 = -1.2274 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.21093 +       PassThrough = -0.66155          --- -       1best avg score: 0.14066 (+0.14066) - 1best avg model score: -37.614 (-37.614) -           avg # pairs: 1244.7 -        avg # rank err: 728 -     avg # margin viol: 516.67 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.15735 (+0.15735) + 1best avg model score: 46.831 +           avg # pairs: 2132.3 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 11.507 -(time 0.45 min, 9 s/S) - -Writing weights file to 'work/weights.0.1' ... -done +           avg f count: 10.64 +(time 0.38 min, 7 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.14066]. -This took 0.45 min. +Best iteration: 1 [GOLD = 0.15735]. +This took 0.38333 min. diff --git a/training/dtrain/examples/parallelized/work/out.0.2 b/training/dtrain/examples/parallelized/work/out.0.2 index fcecc7e1..9c4b110b 100644 --- a/training/dtrain/examples/parallelized/work/out.0.2 +++ b/training/dtrain/examples/parallelized/work/out.0.2 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 3693132895 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.0.0.in'                    output 'work/weights.0.2'                weights in 'work/weights.1' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.019275 -       WordPenalty = +0.022192 -     LanguageModel = +0.40688 - LanguageModel_OOV = -0.36397 -     PhraseModel_0 = -0.36273 -     PhraseModel_1 = +0.56432 -     PhraseModel_2 = +0.85638 -     PhraseModel_3 = -0.20222 -     PhraseModel_4 = -0.48295 -     PhraseModel_5 = +0.03145 -     PhraseModel_6 = -0.26092 -       PassThrough = -0.38122 +              Glue = -0.44422 +       WordPenalty = +0.1032 +     LanguageModel = +0.66474 + LanguageModel_OOV = -0.62252 +     PhraseModel_0 = -0.59993 +     PhraseModel_1 = +0.78992 +     PhraseModel_2 = +1.3149 +     PhraseModel_3 = +0.21434 +     PhraseModel_4 = -1.0174 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.18452 +       PassThrough = -0.65268          --- -       1best avg score: 0.18982 (+0.18982) - 1best avg model score: 1.7096 (+1.7096) -           avg # pairs: 1524.3 -        avg # rank err: 813.33 -     avg # margin viol: 702.67 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.24722 (+0.24722) + 1best avg model score: 61.971 +           avg # pairs: 2017.7 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 11.32 -(time 0.53 min, 11 s/S) - -Writing weights file to 'work/weights.0.2' ... -done +           avg f count: 10.42 +(time 0.3 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.18982]. -This took 0.53333 min. +Best iteration: 1 [GOLD = 0.24722]. +This took 0.3 min. diff --git a/training/dtrain/examples/parallelized/work/out.1.0 b/training/dtrain/examples/parallelized/work/out.1.0 index 595dfc94..3dc4dca6 100644 --- a/training/dtrain/examples/parallelized/work/out.1.0 +++ b/training/dtrain/examples/parallelized/work/out.1.0 @@ -1,65 +1,43 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 859043351 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.1.0.in'                    output 'work/weights.1.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.3229 -       WordPenalty = +0.27969 -     LanguageModel = +1.3645 - LanguageModel_OOV = -0.0443 -     PhraseModel_0 = -0.19049 -     PhraseModel_1 = -0.077698 -     PhraseModel_2 = +0.058898 -     PhraseModel_3 = +0.017251 -     PhraseModel_4 = -1.5474 -     PhraseModel_5 = +0 -     PhraseModel_6 = -0.1818 -       PassThrough = -0.193 +              Glue = -0.2722 +       WordPenalty = +0.05433 +     LanguageModel = +0.69948 + LanguageModel_OOV = -0.2641 +     PhraseModel_0 = -1.4208 +     PhraseModel_1 = -1.563 +     PhraseModel_2 = -0.21051 +     PhraseModel_3 = -0.17764 +     PhraseModel_4 = -1.6583 +     PhraseModel_5 = +0.0794 +     PhraseModel_6 = +0.1528 +       PassThrough = -0.2367          --- -       1best avg score: 0.070229 (+0.070229) - 1best avg model score: -44.01 (-44.01) -           avg # pairs: 1294 -        avg # rank err: 878.67 -     avg # margin viol: 350.67 -       k-best loss imp: 100% -    non0 feature count: 11 +       1best avg score: 0.071329 (+0.071329) + 1best avg model score: -41.362 +           avg # pairs: 1862.3 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 11.487 -(time 0.28 min, 5.7 s/S) - -Writing weights file to 'work/weights.1.0' ... -done +           avg f count: 11.847 +(time 0.28 min, 5 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.070229]. +Best iteration: 1 [GOLD = 0.071329].  This took 0.28333 min. diff --git a/training/dtrain/examples/parallelized/work/out.1.1 b/training/dtrain/examples/parallelized/work/out.1.1 index 9346fc82..79ac35dc 100644 --- a/training/dtrain/examples/parallelized/work/out.1.1 +++ b/training/dtrain/examples/parallelized/work/out.1.1 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 3557309480 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.1.0.in'                    output 'work/weights.1.1'                weights in 'work/weights.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.26425 -       WordPenalty = +0.047881 -     LanguageModel = +0.78496 - LanguageModel_OOV = -0.49307 -     PhraseModel_0 = -0.58703 -     PhraseModel_1 = -0.33425 -     PhraseModel_2 = +0.20834 -     PhraseModel_3 = -0.043346 -     PhraseModel_4 = -0.60761 -     PhraseModel_5 = +0.123 -     PhraseModel_6 = -0.05415 -       PassThrough = -0.42167 +              Glue = -0.20488 +       WordPenalty = -0.0091745 +     LanguageModel = +0.79433 + LanguageModel_OOV = -0.4309 +     PhraseModel_0 = -0.56242 +     PhraseModel_1 = +0.85363 +     PhraseModel_2 = +1.3458 +     PhraseModel_3 = -0.13095 +     PhraseModel_4 = -0.94762 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.16003 +       PassThrough = -0.46105          --- -       1best avg score: 0.085952 (+0.085952) - 1best avg model score: -45.175 (-45.175) -           avg # pairs: 1180.7 -        avg # rank err: 668.33 -     avg # margin viol: 512.33 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.13017 (+0.13017) + 1best avg model score: 14.53 +           avg # pairs: 1968 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 12 -(time 0.27 min, 5.3 s/S) - -Writing weights file to 'work/weights.1.1' ... -done +           avg f count: 11 +(time 0.33 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.085952]. -This took 0.26667 min. +Best iteration: 1 [GOLD = 0.13017]. +This took 0.33333 min. diff --git a/training/dtrain/examples/parallelized/work/out.1.2 b/training/dtrain/examples/parallelized/work/out.1.2 index 08f07a75..8c4f8b03 100644 --- a/training/dtrain/examples/parallelized/work/out.1.2 +++ b/training/dtrain/examples/parallelized/work/out.1.2 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 56743915 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.1.0.in'                    output 'work/weights.1.2'                weights in 'work/weights.1' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.23608 -       WordPenalty = +0.10931 -     LanguageModel = +0.81339 - LanguageModel_OOV = -0.33238 -     PhraseModel_0 = -0.53685 -     PhraseModel_1 = -0.049658 -     PhraseModel_2 = +0.40277 -     PhraseModel_3 = +0.14601 -     PhraseModel_4 = -0.72851 -     PhraseModel_5 = +0.03475 -     PhraseModel_6 = -0.27192 -       PassThrough = -0.34763 +              Glue = -0.49853 +       WordPenalty = +0.07636 +     LanguageModel = +1.3183 + LanguageModel_OOV = -0.60902 +     PhraseModel_0 = -0.22481 +     PhraseModel_1 = +0.86369 +     PhraseModel_2 = +1.0747 +     PhraseModel_3 = +0.18002 +     PhraseModel_4 = -0.84661 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = +0.11247 +       PassThrough = -0.63918          --- -       1best avg score: 0.10073 (+0.10073) - 1best avg model score: -38.422 (-38.422) -           avg # pairs: 1505.3 -        avg # rank err: 777 -     avg # margin viol: 691.67 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.15478 (+0.15478) + 1best avg model score: -7.2154 +           avg # pairs: 1776 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 12 -(time 0.35 min, 7 s/S) - -Writing weights file to 'work/weights.1.2' ... -done +           avg f count: 11.327 +(time 0.27 min, 5 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.10073]. -This took 0.35 min. +Best iteration: 1 [GOLD = 0.15478]. +This took 0.26667 min. diff --git a/training/dtrain/examples/parallelized/work/out.2.0 b/training/dtrain/examples/parallelized/work/out.2.0 index 25ef6d4e..07c85963 100644 --- a/training/dtrain/examples/parallelized/work/out.2.0 +++ b/training/dtrain/examples/parallelized/work/out.2.0 @@ -1,65 +1,43 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 2662215673 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.2.0.in'                    output 'work/weights.2.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.1259 -       WordPenalty = +0.048294 -     LanguageModel = +0.36254 - LanguageModel_OOV = -0.1228 -     PhraseModel_0 = +0.26357 -     PhraseModel_1 = +0.24793 -     PhraseModel_2 = +0.0063763 -     PhraseModel_3 = -0.18966 -     PhraseModel_4 = -0.226 +              Glue = -0.2109 +       WordPenalty = +0.14922 +     LanguageModel = +0.79686 + LanguageModel_OOV = -0.6627 +     PhraseModel_0 = +0.37999 +     PhraseModel_1 = +0.69213 +     PhraseModel_2 = +0.3422 +     PhraseModel_3 = +1.1426 +     PhraseModel_4 = -0.55413       PhraseModel_5 = +0 -     PhraseModel_6 = +0.0743 -       PassThrough = -0.1335 +     PhraseModel_6 = +0.0676 +       PassThrough = -0.6343          --- -       1best avg score: 0.072836 (+0.072836) - 1best avg model score: -0.56296 (-0.56296) -           avg # pairs: 1094.7 -        avg # rank err: 658 -     avg # margin viol: 436.67 -       k-best loss imp: 100% -    non0 feature count: 11 +       1best avg score: 0.072374 (+0.072374) + 1best avg model score: -27.384 +           avg # pairs: 2582 +   non-0 feature count: 11             avg list sz: 100 -           avg f count: 10.813 -(time 0.13 min, 2.7 s/S) - -Writing weights file to 'work/weights.2.0' ... -done +           avg f count: 11.54 +(time 0.32 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.072836]. -This took 0.13333 min. +Best iteration: 1 [GOLD = 0.072374]. +This took 0.31667 min. diff --git a/training/dtrain/examples/parallelized/work/out.2.1 b/training/dtrain/examples/parallelized/work/out.2.1 index 8e4efde9..c54bb1b1 100644 --- a/training/dtrain/examples/parallelized/work/out.2.1 +++ b/training/dtrain/examples/parallelized/work/out.2.1 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 3092904479 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.2.0.in'                    output 'work/weights.2.1'                weights in 'work/weights.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.10385 -       WordPenalty = +0.038717 -     LanguageModel = +0.49413 - LanguageModel_OOV = -0.24887 -     PhraseModel_0 = -0.32102 -     PhraseModel_1 = +0.34413 -     PhraseModel_2 = +0.62366 -     PhraseModel_3 = -0.49337 -     PhraseModel_4 = -0.77005 -     PhraseModel_5 = +0.007 -     PhraseModel_6 = -0.05055 -       PassThrough = -0.23928 +              Glue = -0.76608 +       WordPenalty = +0.15938 +     LanguageModel = +1.5897 + LanguageModel_OOV = -0.521 +     PhraseModel_0 = -0.58348 +     PhraseModel_1 = +0.29828 +     PhraseModel_2 = +0.78493 +     PhraseModel_3 = +0.083222 +     PhraseModel_4 = -0.93843 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.27382 +       PassThrough = -0.55115          --- -       1best avg score: 0.10245 (+0.10245) - 1best avg model score: -20.384 (-20.384) -           avg # pairs: 1741.7 -        avg # rank err: 953.67 -     avg # margin viol: 585.33 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.12881 (+0.12881) + 1best avg model score: -9.6731 +           avg # pairs: 2020.3 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 11.977 -(time 0.12 min, 2.3 s/S) - -Writing weights file to 'work/weights.2.1' ... -done +           avg f count: 12 +(time 0.32 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.10245]. -This took 0.11667 min. +Best iteration: 1 [GOLD = 0.12881]. +This took 0.31667 min. diff --git a/training/dtrain/examples/parallelized/work/out.2.2 b/training/dtrain/examples/parallelized/work/out.2.2 index e0ca2110..f5d6229f 100644 --- a/training/dtrain/examples/parallelized/work/out.2.2 +++ b/training/dtrain/examples/parallelized/work/out.2.2 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 2803362953 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.2.0.in'                    output 'work/weights.2.2'                weights in 'work/weights.1' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  3 + .... 3  WEIGHTS -              Glue = -0.32907 -       WordPenalty = +0.049596 -     LanguageModel = +0.33496 - LanguageModel_OOV = -0.44357 -     PhraseModel_0 = -0.3068 -     PhraseModel_1 = +0.59376 -     PhraseModel_2 = +0.86416 -     PhraseModel_3 = -0.21072 -     PhraseModel_4 = -0.65734 -     PhraseModel_5 = +0.03475 -     PhraseModel_6 = -0.10653 -       PassThrough = -0.46082 +              Glue = -0.90863 +       WordPenalty = +0.10819 +     LanguageModel = +0.5239 + LanguageModel_OOV = -0.41623 +     PhraseModel_0 = -0.86868 +     PhraseModel_1 = +0.40784 +     PhraseModel_2 = +1.1793 +     PhraseModel_3 = -0.24698 +     PhraseModel_4 = -1.2353 +     PhraseModel_5 = +0.03375 +     PhraseModel_6 = -0.17883 +       PassThrough = -0.44638          --- -       1best avg score: 0.25055 (+0.25055) - 1best avg model score: -1.4459 (-1.4459) -           avg # pairs: 1689 -        avg # rank err: 755.67 -     avg # margin viol: 829.33 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.12788 (+0.12788) + 1best avg model score: 41.302 +           avg # pairs: 2246.3 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 10.53 -(time 0.13 min, 2.7 s/S) - -Writing weights file to 'work/weights.2.2' ... -done +           avg f count: 10.98 +(time 0.35 min, 7 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.25055]. -This took 0.13333 min. +Best iteration: 1 [GOLD = 0.12788]. +This took 0.35 min. diff --git a/training/dtrain/examples/parallelized/work/out.3.0 b/training/dtrain/examples/parallelized/work/out.3.0 index 3c074f04..fa499523 100644 --- a/training/dtrain/examples/parallelized/work/out.3.0 +++ b/training/dtrain/examples/parallelized/work/out.3.0 @@ -1,65 +1,43 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 316107185 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.3.0.in'                    output 'work/weights.3.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  1 + .. 1  WEIGHTS -              Glue = +0.046 -       WordPenalty = +0.17328 -     LanguageModel = +1.1667 - LanguageModel_OOV = +0.066 -     PhraseModel_0 = -1.1694 -     PhraseModel_1 = -0.9883 -     PhraseModel_2 = +0.036205 -     PhraseModel_3 = -0.77387 -     PhraseModel_4 = -1.5019 -     PhraseModel_5 = +0.024 -     PhraseModel_6 = -0.514 -       PassThrough = +0.031 +              Glue = -0.09 +       WordPenalty = +0.32442 +     LanguageModel = +2.5769 + LanguageModel_OOV = -0.009 +     PhraseModel_0 = -0.58972 +     PhraseModel_1 = +0.063691 +     PhraseModel_2 = +0.5366 +     PhraseModel_3 = +0.12867 +     PhraseModel_4 = -1.9801 +     PhraseModel_5 = +0.018 +     PhraseModel_6 = -0.486 +       PassThrough = -0.09          --- -       1best avg score: 0.032916 (+0.032916) - 1best avg model score: 0 (+0) -           avg # pairs: 900 -        avg # rank err: 900 -     avg # margin viol: 0 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.034204 (+0.034204) + 1best avg model score: 0 +           avg # pairs: 1700 +   non-0 feature count: 12             avg list sz: 100 -           avg f count: 11.72 -(time 0.23 min, 14 s/S) - -Writing weights file to 'work/weights.3.0' ... -done +           avg f count: 10.8 +(time 0.1 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.032916]. -This took 0.23333 min. +Best iteration: 1 [GOLD = 0.034204]. +This took 0.1 min. diff --git a/training/dtrain/examples/parallelized/work/out.3.1 b/training/dtrain/examples/parallelized/work/out.3.1 index 241d3455..c4b3aa3c 100644 --- a/training/dtrain/examples/parallelized/work/out.3.1 +++ b/training/dtrain/examples/parallelized/work/out.3.1 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 353677750 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.3.0.in'                    output 'work/weights.3.1'                weights in 'work/weights.0' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  1 + .. 1  WEIGHTS -              Glue = -0.08475 -       WordPenalty = +0.11151 -     LanguageModel = +1.0635 - LanguageModel_OOV = -0.11468 -     PhraseModel_0 = -0.062922 -     PhraseModel_1 = +0.0035552 -     PhraseModel_2 = +0.039692 -     PhraseModel_3 = +0.080265 -     PhraseModel_4 = -0.57787 -     PhraseModel_5 = +0.0174 -     PhraseModel_6 = -0.17095 -       PassThrough = -0.18248 +              Glue = +0.31832 +       WordPenalty = +0.11139 +     LanguageModel = +0.95438 + LanguageModel_OOV = -0.0608 +     PhraseModel_0 = -0.98113 +     PhraseModel_1 = -0.090531 +     PhraseModel_2 = +0.79088 +     PhraseModel_3 = -0.57623 +     PhraseModel_4 = -1.4382 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.10812 +       PassThrough = -0.09095          --- -       1best avg score: 0.16117 (+0.16117) - 1best avg model score: -67.89 (-67.89) -           avg # pairs: 1411 -        avg # rank err: 460 -     avg # margin viol: 951 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.084989 (+0.084989) + 1best avg model score: -52.323 +           avg # pairs: 2487 +   non-0 feature count: 12             avg list sz: 100             avg f count: 12 -(time 0.22 min, 13 s/S) - -Writing weights file to 'work/weights.3.1' ... -done +(time 0.1 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.16117]. -This took 0.21667 min. +Best iteration: 1 [GOLD = 0.084989]. +This took 0.1 min. diff --git a/training/dtrain/examples/parallelized/work/out.3.2 b/training/dtrain/examples/parallelized/work/out.3.2 index b995daf5..eb27dac2 100644 --- a/training/dtrain/examples/parallelized/work/out.3.2 +++ b/training/dtrain/examples/parallelized/work/out.3.2 @@ -1,66 +1,44 @@ -                cdec cfg 'cdec.ini'  Loading the LM will be faster if you build a binary file.  Reading ../standard/nc-wmt11.en.srilm.gz  ----5---10---15---20---25---30---35---40---45---50---55---60---65---70---75---80---85---90---95--100  **************************************************************************************************** -Seeding random number sequence to 3001145976 -  dtrain  Parameters:                         k 100                         N 4                         T 1 -                   batch 0 -                  scorer 'stupid_bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 0.0001 -                   gamma 0 -             loss margin 1 -       faster perceptron 0 -                   pairs 'XYX' -                   hi lo 0.1 -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' +            error margin 1 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'work/shard.3.0.in'                    output 'work/weights.3.2'                weights in 'work/weights.1' -(a dot represents 10 inputs) +(a dot per input)  Iteration #1 of 1. -  1 + .. 1  WEIGHTS -              Glue = -0.13247 -       WordPenalty = +0.053592 -     LanguageModel = +0.72105 - LanguageModel_OOV = -0.30827 -     PhraseModel_0 = -0.37053 -     PhraseModel_1 = +0.17551 -     PhraseModel_2 = +0.5 -     PhraseModel_3 = -0.1459 -     PhraseModel_4 = -0.59563 -     PhraseModel_5 = +0.03475 -     PhraseModel_6 = -0.11143 -       PassThrough = -0.32553 +              Glue = -0.12993 +       WordPenalty = +0.13651 +     LanguageModel = +0.58946 + LanguageModel_OOV = -0.48362 +     PhraseModel_0 = -0.81262 +     PhraseModel_1 = +0.44273 +     PhraseModel_2 = +1.1733 +     PhraseModel_3 = -0.1826 +     PhraseModel_4 = -1.2213 +     PhraseModel_5 = +0.02435 +     PhraseModel_6 = -0.18823 +       PassThrough = -0.51378          --- -       1best avg score: 0.12501 (+0.12501) - 1best avg model score: -62.128 (-62.128) -           avg # pairs: 979 -        avg # rank err: 539 -     avg # margin viol: 440 -       k-best loss imp: 100% -    non0 feature count: 12 +       1best avg score: 0.12674 (+0.12674) + 1best avg model score: -7.2878 +           avg # pairs: 1769 +   non-0 feature count: 12             avg list sz: 100             avg f count: 12 -(time 0.22 min, 13 s/S) - -Writing weights file to 'work/weights.3.2' ... -done +(time 0.1 min, 6 s/S)  --- -Best iteration: 1 [SCORE 'stupid_bleu'=0.12501]. -This took 0.21667 min. +Best iteration: 1 [GOLD = 0.12674]. +This took 0.1 min. diff --git a/training/dtrain/examples/parallelized/work/shard.0.0.in b/training/dtrain/examples/parallelized/work/shard.0.0.in index d1b48321..a0ef6f54 100644 --- a/training/dtrain/examples/parallelized/work/shard.0.0.in +++ b/training/dtrain/examples/parallelized/work/shard.0.0.in @@ -1,3 +1,3 @@ -<seg grammar="grammar/grammar.out.8.gz" id="8">der erste schritt , um mit der rassenfrage umzugehen ist , ursache und folgen rassistischer feindseligkeiten zu verstehen , auch dann , wenn das bedeutet , unangenehme tatsachen aufzudecken .</seg> ||| the first step to address racial politics is to understand the origin and consequences of racial animosity , even if it means uncovering unpleasant truths . -<seg grammar="grammar/grammar.out.5.gz" id="5">die großen parteien der rechten und der linken mitte haben sich dem problem gestellt , in dem sie den kopf in den sand gesteckt und allen aussichten zuwider gehofft haben , es möge bald verschwinden .</seg> ||| mainstream parties of the center left and center right have confronted this prospect by hiding their heads in the ground , hoping against hope that the problem will disappear . +<seg grammar="grammar/grammar.out.0.gz" id="0">europas nach rassen geteiltes haus</seg> ||| europe 's divided racial house +<seg grammar="grammar/grammar.out.1.gz" id="1">ein gemeinsames merkmal aller extremen rechten in europa ist ihr rassismus und die tatsache , daß sie das einwanderungsproblem als politischen hebel benutzen .</seg> ||| a common feature of europe 's extreme right is its racism and use of the immigration issue as a political wedge .  <seg grammar="grammar/grammar.out.2.gz" id="2">der lega nord in italien , der vlaams block in den niederlanden , die anhänger von le pens nationaler front in frankreich , sind beispiele für parteien oder bewegungen , die sich um das gemeinsame thema : ablehnung der zuwanderung gebildet haben und um forderung nach einer vereinfachten politik , um sie zu regeln .</seg> ||| the lega nord in italy , the vlaams blok in the netherlands , the supporters of le pen 's national front in france , are all examples of parties or movements formed on the common theme of aversion to immigrants and promotion of simplistic policies to control them . diff --git a/training/dtrain/examples/parallelized/work/shard.1.0.in b/training/dtrain/examples/parallelized/work/shard.1.0.in index a63f05bd..05f0273b 100644 --- a/training/dtrain/examples/parallelized/work/shard.1.0.in +++ b/training/dtrain/examples/parallelized/work/shard.1.0.in @@ -1,3 +1,3 @@ -<seg grammar="grammar/grammar.out.4.gz" id="4">eine alternde einheimische bevölkerung und immer offenere grenzen vermehren die rassistische zersplitterung in den europäischen ländern .</seg> ||| an aging population at home and ever more open borders imply increasing racial fragmentation in european countries . -<seg grammar="grammar/grammar.out.9.gz" id="9">genau das haben in den usa eine große anzahl an forschungsvorhaben in wirtschaft , soziologie , psychologie und politikwissenschaft geleistet . diese forschungen zeigten , daß menschen unterschiedlicher rasse einander deutlich weniger vertrauen .</seg> ||| this is precisely what a large amount of research in economics , sociology , psychology and political science has done for the us .  <seg grammar="grammar/grammar.out.3.gz" id="3">während individuen wie jörg haidar und jean @-@ marie le pen kommen und ( leider nicht zu bald ) wieder gehen mögen , wird die rassenfrage aus der europäischer politik nicht so bald verschwinden .</seg> ||| while individuals like jorg haidar and jean @-@ marie le pen may come and ( never to soon ) go , the race question will not disappear from european politics anytime soon . +<seg grammar="grammar/grammar.out.4.gz" id="4">eine alternde einheimische bevölkerung und immer offenere grenzen vermehren die rassistische zersplitterung in den europäischen ländern .</seg> ||| an aging population at home and ever more open borders imply increasing racial fragmentation in european countries . +<seg grammar="grammar/grammar.out.5.gz" id="5">die großen parteien der rechten und der linken mitte haben sich dem problem gestellt , in dem sie den kopf in den sand gesteckt und allen aussichten zuwider gehofft haben , es möge bald verschwinden .</seg> ||| mainstream parties of the center left and center right have confronted this prospect by hiding their heads in the ground , hoping against hope that the problem will disappear . diff --git a/training/dtrain/examples/parallelized/work/shard.2.0.in b/training/dtrain/examples/parallelized/work/shard.2.0.in index fe542b40..0528d357 100644 --- a/training/dtrain/examples/parallelized/work/shard.2.0.in +++ b/training/dtrain/examples/parallelized/work/shard.2.0.in @@ -1,3 +1,3 @@ -<seg grammar="grammar/grammar.out.1.gz" id="1">ein gemeinsames merkmal aller extremen rechten in europa ist ihr rassismus und die tatsache , daß sie das einwanderungsproblem als politischen hebel benutzen .</seg> ||| a common feature of europe 's extreme right is its racism and use of the immigration issue as a political wedge . -<seg grammar="grammar/grammar.out.0.gz" id="0">europas nach rassen geteiltes haus</seg> ||| europe 's divided racial house  <seg grammar="grammar/grammar.out.6.gz" id="6">das aber wird es nicht , wie die geschichte des rassismus in amerika deutlich zeigt .</seg> ||| it will not , as america 's racial history clearly shows . +<seg grammar="grammar/grammar.out.7.gz" id="7">die beziehungen zwischen den rassen standen in den usa über jahrzehnte - und tun das noch heute - im zentrum der politischen debatte . das ging so weit , daß rassentrennung genauso wichtig wie das einkommen wurde , - wenn nicht sogar noch wichtiger - um politische zuneigungen und einstellungen zu bestimmen .</seg> ||| race relations in the us have been for decades - and remain - at the center of political debate , to the point that racial cleavages are as important as income , if not more , as determinants of political preferences and attitudes . +<seg grammar="grammar/grammar.out.8.gz" id="8">der erste schritt , um mit der rassenfrage umzugehen ist , ursache und folgen rassistischer feindseligkeiten zu verstehen , auch dann , wenn das bedeutet , unangenehme tatsachen aufzudecken .</seg> ||| the first step to address racial politics is to understand the origin and consequences of racial animosity , even if it means uncovering unpleasant truths . diff --git a/training/dtrain/examples/parallelized/work/shard.3.0.in b/training/dtrain/examples/parallelized/work/shard.3.0.in index 4a8fa5b1..f7cbb3e3 100644 --- a/training/dtrain/examples/parallelized/work/shard.3.0.in +++ b/training/dtrain/examples/parallelized/work/shard.3.0.in @@ -1 +1 @@ -<seg grammar="grammar/grammar.out.7.gz" id="7">die beziehungen zwischen den rassen standen in den usa über jahrzehnte - und tun das noch heute - im zentrum der politischen debatte . das ging so weit , daß rassentrennung genauso wichtig wie das einkommen wurde , - wenn nicht sogar noch wichtiger - um politische zuneigungen und einstellungen zu bestimmen .</seg> ||| race relations in the us have been for decades - and remain - at the center of political debate , to the point that racial cleavages are as important as income , if not more , as determinants of political preferences and attitudes . +<seg grammar="grammar/grammar.out.9.gz" id="9">genau das haben in den usa eine große anzahl an forschungsvorhaben in wirtschaft , soziologie , psychologie und politikwissenschaft geleistet . diese forschungen zeigten , daß menschen unterschiedlicher rasse einander deutlich weniger vertrauen .</seg> ||| this is precisely what a large amount of research in economics , sociology , psychology and political science has done for the us . diff --git a/training/dtrain/examples/parallelized/work/weights.0 b/training/dtrain/examples/parallelized/work/weights.0 index c560fdbd..816269cd 100644 --- a/training/dtrain/examples/parallelized/work/weights.0 +++ b/training/dtrain/examples/parallelized/work/weights.0 @@ -1,12 +1,12 @@ -PhraseModel_4	-0.6990170657294328 -LanguageModel	0.891784887346263 -PhraseModel_0	-0.2107507586515428 -PhraseModel_1	-0.15442709655871997 -PhraseModel_3	-0.07262514338204715 -PhraseModel_6	-0.10965000000000148 -Glue	-0.03644999999999783 -WordPenalty	0.13204723722268177 -PassThrough	-0.09437500000000089 -LanguageModel_OOV	-0.036775000000000564 -PhraseModel_2	0.025521702385571707 -PhraseModel_5	0.006999999999999977 +LanguageModel	1.200704259340465 +PhraseModel_4	-1.2434381298299035 +PhraseModel_1	0.050697726409824076 +PhraseModel_0	-0.516923312932941 +PhraseModel_2	0.5051987092783867 +PhraseModel_3	0.20955092377784057 +PassThrough	-0.32285 +LanguageModel_OOV	-0.29269999999999996 +PhraseModel_6	-0.158425 +Glue	-0.05817500000000002 +WordPenalty	0.12758486142112804 +PhraseModel_5	0.02435 diff --git a/training/dtrain/examples/parallelized/work/weights.0.0 b/training/dtrain/examples/parallelized/work/weights.0.0 index 91eedc7b..be386c62 100644 --- a/training/dtrain/examples/parallelized/work/weights.0.0 +++ b/training/dtrain/examples/parallelized/work/weights.0.0 @@ -1,12 +1,11 @@ -PassThrough	-0.082000000000001058 -Glue	0.25700000000000267 -LanguageModel_OOV	-0.046000000000000034 -LanguageModel	0.67341721152744249 -PhraseModel_6	0.18290000000000028 -PhraseModel_5	0.0039999999999999975 -PhraseModel_4	0.47916377173928498 -PhraseModel_3	0.65577926367715722 -PhraseModel_2	0.00060731048591637909 -PhraseModel_0	0.25329462707903372 -WordPenalty	0.026926257878001431 -PhraseModel_1	0.20035945197369062 +WordPenalty -0.017632355965271129 +LanguageModel 0.72957628464102753 +LanguageModel_OOV -0.23499999999999999 +PhraseModel_0 -0.43720953659541578 +PhraseModel_1 1.0100170838129212 +PhraseModel_2 1.3524984123857073 +PhraseModel_3 -0.25541132249775761 +PhraseModel_4 -0.78115161368856911 +PhraseModel_6 -0.36810000000000004 +Glue 0.34040000000000004 +PassThrough -0.33040000000000003 diff --git a/training/dtrain/examples/parallelized/work/weights.0.1 b/training/dtrain/examples/parallelized/work/weights.0.1 index 6fcc9999..d4c77d07 100644 --- a/training/dtrain/examples/parallelized/work/weights.0.1 +++ b/training/dtrain/examples/parallelized/work/weights.0.1 @@ -1,12 +1,12 @@ -PassThrough	-0.2346750000000028 -Glue	-0.17904999999999763 -WordPenalty	0.062125825636256168 -LanguageModel	0.66824625053667575 -LanguageModel_OOV	-0.15247500000000355 -PhraseModel_0	-0.5581144363944085 -PhraseModel_1	0.12740874153205478 -PhraseModel_2	0.6038779278708799 -PhraseModel_3	-0.44463820299544454 -PhraseModel_4	-0.63136538282212662 -PhraseModel_5	-0.0084000000000000324 -PhraseModel_6	-0.20164999999999911 +WordPenalty 0.12966947493426365 +LanguageModel 0.3989224621154368 +LanguageModel_OOV -0.63139999999999996 +PhraseModel_0 -0.63991953012355962 +PhraseModel_1 0.74197897612368646 +PhraseModel_2 1.3096163833051435 +PhraseModel_3 -0.12160001974680773 +PhraseModel_4 -1.2274031286515816 +PhraseModel_5 0.02435 +PhraseModel_6 -0.210925 +Glue -0.40907500000000002 +PassThrough -0.66155000000000008 diff --git a/training/dtrain/examples/parallelized/work/weights.0.2 b/training/dtrain/examples/parallelized/work/weights.0.2 index 5668915d..8ce1449b 100644 --- a/training/dtrain/examples/parallelized/work/weights.0.2 +++ b/training/dtrain/examples/parallelized/work/weights.0.2 @@ -1,12 +1,12 @@ -PassThrough	-0.38122499999999337 -Glue	-0.019274999999998679 -WordPenalty	0.022192448025253487 -LanguageModel	0.4068780855136106 -LanguageModel_OOV	-0.363974999999992 -PhraseModel_0	-0.36273429313029715 -PhraseModel_1	0.56431752511029298 -PhraseModel_2	0.85638010019687694 -PhraseModel_3	-0.20222345248738063 -PhraseModel_4	-0.48295466434310252 -PhraseModel_5	0.031450000000000339 -PhraseModel_6	-0.26092499999998625 +WordPenalty 0.10319922626226019 +LanguageModel 0.6647396869692952 +LanguageModel_OOV -0.622525 +PhraseModel_0 -0.59993441316076157 +PhraseModel_1 0.78991513935858193 +PhraseModel_2 1.3148638774685031 +PhraseModel_3 0.2143393571820455 +PhraseModel_4 -1.0173894637028262 +PhraseModel_5 0.02435 +PhraseModel_6 -0.18452499999999999 +Glue -0.44422499999999998 +PassThrough -0.65267500000000012 diff --git a/training/dtrain/examples/parallelized/work/weights.1 b/training/dtrain/examples/parallelized/work/weights.1 index f52e07b8..2a00be2e 100644 --- a/training/dtrain/examples/parallelized/work/weights.1 +++ b/training/dtrain/examples/parallelized/work/weights.1 @@ -1,12 +1,12 @@ -LanguageModel	0.7527067666152598 -PhraseModel_4	-0.6467221787583058 -PhraseModel_2	0.36889175522051015 -PhraseModel_0	-0.38227173053779245 -PhraseModel_3	-0.2252732111174934 -LanguageModel_OOV	-0.25227499999999975 -PassThrough	-0.2695250000000011 -PhraseModel_1	0.03521067244127414 -Glue	-0.1579749999999981 -PhraseModel_6	-0.11932500000000047 -WordPenalty	0.0650573133891042 -PhraseModel_5	0.03475000000000043 +PhraseModel_4	-1.1379250444170055 +PhraseModel_2	1.0578050661336098 +LanguageModel	0.9343385461706668 +PhraseModel_0	-0.6917392152965985 +PhraseModel_1	0.4508371141128957 +PassThrough	-0.4411750000000001 +Glue	-0.265425 +LanguageModel_OOV	-0.411025 +PhraseModel_3	-0.186390082624459 +PhraseModel_6	-0.188225 +WordPenalty	0.09781397468665984 +PhraseModel_5	0.02435 diff --git a/training/dtrain/examples/parallelized/work/weights.1.0 b/training/dtrain/examples/parallelized/work/weights.1.0 index 31e08d81..cdcf959e 100644 --- a/training/dtrain/examples/parallelized/work/weights.1.0 +++ b/training/dtrain/examples/parallelized/work/weights.1.0 @@ -1,11 +1,12 @@ -LanguageModel_OOV	-0.044300000000000235 -PassThrough	-0.19300000000000087 -PhraseModel_6	-0.18180000000000701 -LanguageModel	1.3644969337716422 -PhraseModel_3	0.017250706134911725 -PhraseModel_4	-1.5473728273858063 -Glue	-0.32289999999999447 -PhraseModel_1	-0.077697953502182365 -WordPenalty	0.27968564634568688 -PhraseModel_0	-0.19048660891012237 -PhraseModel_2	0.05889844333199834 +WordPenalty 0.05433023968609621 +LanguageModel 0.69947965605855011 +LanguageModel_OOV -0.2641 +PhraseModel_0 -1.4207505705360111 +PhraseModel_1 -1.563047680441811 +PhraseModel_2 -0.21050528366541305 +PhraseModel_3 -0.17764037275860439 +PhraseModel_4 -1.6583462458159566 +PhraseModel_5 0.079399999999999998 +PhraseModel_6 0.15280000000000002 +Glue -0.27220000000000005 +PassThrough -0.23670000000000002 diff --git a/training/dtrain/examples/parallelized/work/weights.1.1 b/training/dtrain/examples/parallelized/work/weights.1.1 index 544ff462..c1bb2cf0 100644 --- a/training/dtrain/examples/parallelized/work/weights.1.1 +++ b/training/dtrain/examples/parallelized/work/weights.1.1 @@ -1,12 +1,12 @@ -PassThrough	-0.42167499999999858 -Glue	-0.26424999999999721 -WordPenalty	0.04788096662983269 -LanguageModel	0.78495517342352483 -LanguageModel_OOV	-0.49307499999999477 -PhraseModel_0	-0.58703462849498356 -PhraseModel_1	-0.33425278954714266 -PhraseModel_2	0.20834221229630179 -PhraseModel_3	-0.043345645640208569 -PhraseModel_4	-0.60760531115816907 -PhraseModel_5	0.12300000000000186 -PhraseModel_6	-0.054150000000001031 +WordPenalty -0.0091744709302067785 +LanguageModel 0.79433413663506514 +LanguageModel_OOV -0.43090000000000001 +PhraseModel_0 -0.56242499947237046 +PhraseModel_1 0.85362516703032698 +PhraseModel_2 1.3457900890481096 +PhraseModel_3 -0.13095079554478939 +PhraseModel_4 -0.94761908497413061 +PhraseModel_5 0.02435 +PhraseModel_6 -0.160025 +Glue -0.20487500000000003 +PassThrough -0.46105000000000007 diff --git a/training/dtrain/examples/parallelized/work/weights.1.2 b/training/dtrain/examples/parallelized/work/weights.1.2 index ac3284b9..c9598a04 100644 --- a/training/dtrain/examples/parallelized/work/weights.1.2 +++ b/training/dtrain/examples/parallelized/work/weights.1.2 @@ -1,12 +1,12 @@ -PassThrough	-0.34762500000000224 -Glue	-0.23607500000000026 -WordPenalty	0.10931192109504413 -LanguageModel	0.81339027211983694 -LanguageModel_OOV	-0.33237500000000098 -PhraseModel_0	-0.53685104648974269 -PhraseModel_1	-0.049657790506137042 -PhraseModel_2	0.40277066454544108 -PhraseModel_3	0.14600791389785803 -PhraseModel_4	-0.72850673041349101 -PhraseModel_5	0.034750000000000433 -PhraseModel_6	-0.27192499999999448 +WordPenalty 0.076359827280638559 +LanguageModel 1.3183380272921175 +LanguageModel_OOV -0.60902499999999993 +PhraseModel_0 -0.2248075206657828 +PhraseModel_1 0.86368802571834491 +PhraseModel_2 1.0746702462261808 +PhraseModel_3 0.18002263643876637 +PhraseModel_4 -0.84660750337519441 +PhraseModel_5 0.02435 +PhraseModel_6 0.11247499999999999 +Glue -0.49852500000000005 +PassThrough -0.63917500000000005 diff --git a/training/dtrain/examples/parallelized/work/weights.2 b/training/dtrain/examples/parallelized/work/weights.2 index dedaf165..310973ec 100644 --- a/training/dtrain/examples/parallelized/work/weights.2 +++ b/training/dtrain/examples/parallelized/work/weights.2 @@ -1,12 +1,12 @@ -PhraseModel_2	0.6558266927225778 -PhraseModel_4	-0.6161090299356294 -LanguageModel	0.5690697644415413 -PhraseModel_1	0.32098232482479416 -PhraseModel_0	-0.39422813904895143 -PassThrough	-0.37879999999999764 -LanguageModel_OOV	-0.3620499999999963 -Glue	-0.1792249999999967 -PhraseModel_6	-0.18769999999999526 -PhraseModel_3	-0.10321074877850786 -WordPenalty	0.05867318450512617 -PhraseModel_5	0.03392500000000041 +PhraseModel_2	1.185520780812669 +PhraseModel_4	-1.0801541070647134 +LanguageModel	0.7741099486587568 +PhraseModel_0	-0.6265095873268189 +PhraseModel_1	0.6260421233840029 +PassThrough	-0.5630000000000002 +Glue	-0.495325 +LanguageModel_OOV	-0.53285 +PhraseModel_3	-0.008805626854390465 +PhraseModel_6	-0.10977500000000001 +WordPenalty	0.1060655698428214 +PhraseModel_5	0.026699999999999998 diff --git a/training/dtrain/examples/parallelized/work/weights.2.0 b/training/dtrain/examples/parallelized/work/weights.2.0 index f7ece54d..3e87fed4 100644 --- a/training/dtrain/examples/parallelized/work/weights.2.0 +++ b/training/dtrain/examples/parallelized/work/weights.2.0 @@ -1,11 +1,11 @@ -LanguageModel_OOV	-0.12280000000000209 -PassThrough	-0.13350000000000165 -Glue	-0.1259000000000001 -PhraseModel_1	0.24792740418949952 -WordPenalty	0.048293546387642321 -PhraseModel_0	0.26356693580129958 -PhraseModel_2	0.0063762787517740458 -PhraseModel_3	-0.18966358382769741 -PhraseModel_4	-0.22599681869670471 -PhraseModel_6	0.074299999999999047 -LanguageModel	0.3625416478537038 +WordPenalty 0.14922358398195767 +LanguageModel 0.79685677298009394 +LanguageModel_OOV -0.66270000000000007 +PhraseModel_0 0.37998874905310187 +PhraseModel_1 0.69213063228111271 +PhraseModel_2 0.34219807728516061 +PhraseModel_3 1.1425846772648622 +PhraseModel_4 -0.55412548521619742 +PhraseModel_6 0.067599999999999993 +Glue -0.21090000000000003 +PassThrough -0.63429999999999997 diff --git a/training/dtrain/examples/parallelized/work/weights.2.1 b/training/dtrain/examples/parallelized/work/weights.2.1 index 0946609d..d129dc49 100644 --- a/training/dtrain/examples/parallelized/work/weights.2.1 +++ b/training/dtrain/examples/parallelized/work/weights.2.1 @@ -1,12 +1,12 @@ -PassThrough	-0.23927500000000015 -Glue	-0.10384999999999919 -WordPenalty	0.038717353061671053 -LanguageModel	0.49412782572695274 -LanguageModel_OOV	-0.24887499999999915 -PhraseModel_0	-0.32101572713801541 -PhraseModel_1	0.34413149733472631 -PhraseModel_2	0.62365535622061474 -PhraseModel_3	-0.49337445280658987 -PhraseModel_4	-0.77004673375347765 -PhraseModel_5	0.0069999999999999767 -PhraseModel_6	-0.05055000000000108 +WordPenalty 0.1593752174964457 +LanguageModel 1.5897162231676281 +LanguageModel_OOV -0.52100000000000002 +PhraseModel_0 -0.5834836741748588 +PhraseModel_1 0.29827543837280185 +PhraseModel_2 0.78493316593562568 +PhraseModel_3 0.083221832554333464 +PhraseModel_4 -0.93843312963279457 +PhraseModel_5 0.02435 +PhraseModel_6 -0.27382499999999999 +Glue -0.76607500000000006 +PassThrough -0.55115000000000003 diff --git a/training/dtrain/examples/parallelized/work/weights.2.2 b/training/dtrain/examples/parallelized/work/weights.2.2 index b766fc75..bcc83b44 100644 --- a/training/dtrain/examples/parallelized/work/weights.2.2 +++ b/training/dtrain/examples/parallelized/work/weights.2.2 @@ -1,12 +1,12 @@ -PassThrough	-0.46082499999999499 -Glue	-0.32907499999998979 -WordPenalty	0.049596429833348527 -LanguageModel	0.33496341201347335 -LanguageModel_OOV	-0.44357499999999361 -PhraseModel_0	-0.30679883980783829 -PhraseModel_1	0.5937585900939707 -PhraseModel_2	0.86415970329021152 -PhraseModel_3	-0.21072279838022553 -PhraseModel_4	-0.65734339854224544 -PhraseModel_5	0.034750000000000433 -PhraseModel_6	-0.10652500000000011 +WordPenalty 0.10819361280414735 +LanguageModel 0.52389743342585859 +LanguageModel_OOV -0.41622500000000001 +PhraseModel_0 -0.86867995703334211 +PhraseModel_1 0.40783818771767943 +PhraseModel_2 1.1792706530114188 +PhraseModel_3 -0.2469805689928464 +PhraseModel_4 -1.2352895858909159 +PhraseModel_5 0.033750000000000002 +PhraseModel_6 -0.17882500000000001 +Glue -0.90862500000000002 +PassThrough -0.44637500000000013 diff --git a/training/dtrain/examples/parallelized/work/weights.3.0 b/training/dtrain/examples/parallelized/work/weights.3.0 index 403ffbb3..e3586048 100644 --- a/training/dtrain/examples/parallelized/work/weights.3.0 +++ b/training/dtrain/examples/parallelized/work/weights.3.0 @@ -1,12 +1,12 @@ -PhraseModel_4	-1.501862388574505 -PhraseModel_3	-0.77386695951256013 -PhraseModel_6	-0.51399999999999824 -PhraseModel_5	0.02399999999999991 -LanguageModel	1.1666837562322641 -PhraseModel_2	0.036204776972598059 -PassThrough	0.030999999999999975 -Glue	0.046000000000000582 -PhraseModel_1	-0.98829728889588764 -WordPenalty	0.1732834982793964 -PhraseModel_0	-1.1693779885763822 -LanguageModel_OOV	0.066000000000000086 +WordPenalty 0.32441797798172944 +LanguageModel 2.5769043236821889 +LanguageModel_OOV -0.0090000000000000011 +PhraseModel_0 -0.58972189365343919 +PhraseModel_1 0.063690869987073351 +PhraseModel_2 0.53660363110809217 +PhraseModel_3 0.12867071310286207 +PhraseModel_4 -1.9801291745988916 +PhraseModel_5 0.018000000000000002 +PhraseModel_6 -0.48600000000000004 +Glue -0.090000000000000011 +PassThrough -0.090000000000000011 diff --git a/training/dtrain/examples/parallelized/work/weights.3.1 b/training/dtrain/examples/parallelized/work/weights.3.1 index c171d586..b27687d3 100644 --- a/training/dtrain/examples/parallelized/work/weights.3.1 +++ b/training/dtrain/examples/parallelized/work/weights.3.1 @@ -1,12 +1,12 @@ -PassThrough	-0.18247500000000313 -Glue	-0.084749999999998368 -WordPenalty	0.11150510822865688 -LanguageModel	1.063497816773886 -LanguageModel_OOV	-0.1146750000000015 -PhraseModel_0	-0.062922130123762257 -PhraseModel_1	0.0035552404454581212 -PhraseModel_2	0.039691524494244249 -PhraseModel_3	0.080265456972269417 -PhraseModel_4	-0.57787128729945014 -PhraseModel_5	0.017399999999999922 -PhraseModel_6	-0.17095000000000066 +WordPenalty 0.11138567724613679 +LanguageModel 0.95438136276453733 +LanguageModel_OOV -0.060799999999999937 +PhraseModel_0 -0.98112865741560529 +PhraseModel_1 -0.090531125075232435 +PhraseModel_2 0.79088062624556033 +PhraseModel_3 -0.57623134776057228 +PhraseModel_4 -1.4382448344095151 +PhraseModel_5 0.02435 +PhraseModel_6 -0.108125 +Glue 0.31832499999999997 +PassThrough -0.090950000000000003 diff --git a/training/dtrain/examples/parallelized/work/weights.3.2 b/training/dtrain/examples/parallelized/work/weights.3.2 index 3ff0411d..ccb591a2 100644 --- a/training/dtrain/examples/parallelized/work/weights.3.2 +++ b/training/dtrain/examples/parallelized/work/weights.3.2 @@ -1,12 +1,12 @@ -PassThrough	-0.32552500000000006 -Glue	-0.13247499999999815 -WordPenalty	0.053591939066858545 -LanguageModel	0.72104728811924446 -LanguageModel_OOV	-0.30827499999999869 -PhraseModel_0	-0.37052837676792744 -PhraseModel_1	0.17551097460105014 -PhraseModel_2	0.49999630285778179 -PhraseModel_3	-0.14590465814428336 -PhraseModel_4	-0.59563132644367889 -PhraseModel_5	0.034750000000000433 -PhraseModel_6	-0.11142500000000025 +WordPenalty 0.13650961302423945 +LanguageModel 0.58946464694775647 +LanguageModel_OOV -0.48362499999999997 +PhraseModel_0 -0.81261645844738917 +PhraseModel_1 0.44272714074140529 +PhraseModel_2 1.1732783465445731 +PhraseModel_3 -0.18260393204552733 +PhraseModel_4 -1.2213298752899167 +PhraseModel_5 0.02435 +PhraseModel_6 -0.188225 +Glue -0.12992500000000001 +PassThrough -0.51377500000000009 diff --git a/training/dtrain/examples/standard/dtrain.ini b/training/dtrain/examples/standard/dtrain.ini index a515db02..f2698007 100644 --- a/training/dtrain/examples/standard/dtrain.ini +++ b/training/dtrain/examples/standard/dtrain.ini @@ -1,27 +1,10 @@ -#input=./nc-wmt11.de.gz -#refs=./nc-wmt11.en.gz -bitext=./nc-wmt11.gz +bitext=./nc-wmt11.gz      # input bitext  output=-                  # a weights file (add .gz for gzip compression) or STDOUT '-' -select_weights=avg        # output average (over epochs) weight vector  decoder_config=./cdec.ini # config for cdec -# weights for these features will be printed on each iteration +iterations=3              # run over input 3 times +k=100                     # use 100best lists +N=4                       # optimize (approx.) BLEU4 +learning_rate=0.1         # learning rate +error_margin=1.0          # margin for margin perceptron  print_weights=Glue WordPenalty LanguageModel LanguageModel_OOV PhraseModel_0 PhraseModel_1 PhraseModel_2 PhraseModel_3 PhraseModel_4 PhraseModel_5 PhraseModel_6 PassThrough -# newer version of the grammar extractor use different feature names:  -#print_weights= EgivenFCoherent SampleCountF CountEF MaxLexFgivenE MaxLexEgivenF IsSingletonF IsSingletonFE Glue WordPenalty PassThrough LanguageModel LanguageModel_OOV -stop_after=10 # stop epoch after 10 inputs -# interesting stuff -epochs=3                 # run over input 3 times -k=100                    # use 100best lists -N=4                      # optimize (approx) BLEU4 -scorer=fixed_stupid_bleu # use 'stupid' BLEU+1 -learning_rate=0.1        # learning rate, don't care if gamma=0 (perceptron) and loss_margin=0 (not margin perceptron) -gamma=0                  # use SVM reg -sample_from=kbest        # use kbest lists (as opposed to forest) -filter=uniq              # only unique entries in kbest (surface form) -pair_sampling=XYX        # -hi_lo=0.1                # 10 vs 80 vs 10 and 80 vs 10 here -pair_threshold=0         # minimum distance in BLEU (here: > 0) -loss_margin=0            # update if correctly ranked, but within this margin -repeat=1                 # repeat training on a kbest list 1 times  -#batch=true              # batch tuning, update after accumulating over all sentences and all kbest lists diff --git a/training/dtrain/examples/toy/dtrain.ini b/training/dtrain/examples/toy/dtrain.ini index 70c7331c..378224b8 100644 --- a/training/dtrain/examples/toy/dtrain.ini +++ b/training/dtrain/examples/toy/dtrain.ini @@ -1,12 +1,8 @@  decoder_config=cdec.ini  bitext=in -output=- -print_weights=logp shell_rule house_rule small_rule little_rule PassThrough PassThrough_1 PassThrough_2 PassThrough_3 PassThrough_4 PassThrough_5 PassThrough_6 +output=weights  k=4  N=4 -epochs=2 -scorer=bleu -sample_from=kbest -filter=uniq -pair_sampling=all +iterations=2  learning_rate=1 +print_weights=logp shell_rule house_rule small_rule little_rule PassThrough PassThrough_1 PassThrough_2 PassThrough_3 PassThrough_4 PassThrough_5 PassThrough_6 diff --git a/training/dtrain/examples/toy/expected-output b/training/dtrain/examples/toy/expected-output index 3c3a5a18..8c758d00 100644 --- a/training/dtrain/examples/toy/expected-output +++ b/training/dtrain/examples/toy/expected-output @@ -1,40 +1,24 @@ -Warning: hi_lo only works with pair_sampling XYX. -                cdec cfg 'cdec.ini' -Seeding random number sequence to 3644621239 -  dtrain  Parameters:                         k 4                         N 4                         T 2 -                   batch 0 -                  scorer 'bleu' -             sample from 'kbest' -                  filter 'uniq'             learning rate 1 -                   gamma 0 -             loss margin 0 -       faster perceptron 1 -                   pairs 'all' -          pair threshold 0 -          select weights 'last' -                  l1 reg 0 'none' -                    pclr no -               max pairs 4294967295 -                  repeat 1 -                cdec cfg 'cdec.ini' -                   input '' -                  output '-' -(a dot represents 10 inputs) +            error margin 0 +                  l1 reg 0 +            decoder conf 'cdec.ini' +                   input 'in' +                  output 'weights' +(a dot per input)  Iteration #1 of 2. -  2 + ... 2  WEIGHTS                logp = +0 -        shell_rule = -1 -        house_rule = +2 -        small_rule = -2 +        shell_rule = +0 +        house_rule = +3 +        small_rule = +0         little_rule = +3 -       PassThrough = -5 +       PassThrough = -15       PassThrough_1 = +0       PassThrough_2 = +0       PassThrough_3 = +0 @@ -42,26 +26,23 @@ WEIGHTS       PassThrough_5 = +0       PassThrough_6 = +0          --- -       1best avg score: 0.5 (+0.5) - 1best avg model score: 2.5 (+2.5) -           avg # pairs: 1.5 -        avg # rank err: 1.5 (meaningless) -     avg # margin viol: 0 -       k-best loss imp: 100% -    non0 feature count: 6 +       1best avg score: 0.40937 (+0.40937) + 1best avg model score: 3 +           avg # pairs: 2.5 +   non-0 feature count: 4             avg list sz: 4             avg f count: 2.875  (time 0 min, 0 s/S)  Iteration #2 of 2. -  2 + ... 2  WEIGHTS                logp = +0 -        shell_rule = -1 -        house_rule = +2 -        small_rule = -2 +        shell_rule = +0 +        house_rule = +3 +        small_rule = +0         little_rule = +3 -       PassThrough = -5 +       PassThrough = -15       PassThrough_1 = +0       PassThrough_2 = +0       PassThrough_3 = +0 @@ -69,26 +50,14 @@ WEIGHTS       PassThrough_5 = +0       PassThrough_6 = +0          --- -       1best avg score: 1 (+0.5) - 1best avg model score: 5 (+2.5) +       1best avg score: 0.81873 (+0.40937) + 1best avg model score: 6             avg # pairs: 0 -        avg # rank err: 0 (meaningless) -     avg # margin viol: 0 -       k-best loss imp: 100% -    non0 feature count: 6 +   non-0 feature count: 4             avg list sz: 4             avg f count: 3  (time 0 min, 0 s/S) -Writing weights file to '-' ... -house_rule	2 -little_rule	3 -Glue	-4 -PassThrough	-5 -small_rule	-2 -shell_rule	-1 -done -  --- -Best iteration: 2 [SCORE 'bleu'=1]. +Best iteration: 2 [GOLD = 0.81873].  This took 0 min. diff --git a/training/dtrain/examples/toy/weights b/training/dtrain/examples/toy/weights new file mode 100644 index 00000000..f6f32772 --- /dev/null +++ b/training/dtrain/examples/toy/weights @@ -0,0 +1,4 @@ +house_rule 3 +little_rule 3 +Glue -12 +PassThrough -15 diff --git a/training/dtrain/lplp.rb b/training/dtrain/lplp.rb index 86e835e8..a1fcd1a3 100755 --- a/training/dtrain/lplp.rb +++ b/training/dtrain/lplp.rb @@ -19,7 +19,8 @@ end  # stats  def median(feature_column, n) -  return feature_column.concat(0.step(n-feature_column.size-1).map{|i|0}).sort[feature_column.size/2] +  return feature_column.concat(0.step(n-feature_column.size-1).map{|i|0})\ +    .sort[feature_column.size/2]  end  def mean(feature_column, n) @@ -28,7 +29,7 @@ end  # selection  def select_k(weights, norm_fun, n, k=10000) -  weights.sort{|a,b| norm_fun.call(b[1], n) <=> norm_fun.call(a[1], n)}.each { |p| +  weights.sort{|a,b| norm_fun.call(b[1], n)<=>norm_fun.call(a[1], n)}.each { |p|      puts "#{p[0]}\t#{mean(p[1], n)}"      k -= 1      if k == 0 then break end diff --git a/training/dtrain/pairs.h b/training/dtrain/pairs.h deleted file mode 100644 index dea0dabc..00000000 --- a/training/dtrain/pairs.h +++ /dev/null @@ -1,55 +0,0 @@ -#ifndef _DTRAIN_PAIRS_H_ -#define _DTRAIN_PAIRS_H_ - -namespace dtrain -{ - -bool -CmpHypsByScore(ScoredHyp a, ScoredHyp b) -{ -  return a.score > b.score; -} - -/* - * multipartite ranking - *  sort (descending) by bleu - *  compare top X (hi) to middle Y (med) and low X (lo) - *  cmp middle Y to low X - */ -inline void -MakePairs(vector<ScoredHyp>* s, -          vector<pair<ScoredHyp,ScoredHyp> >& training, -          bool misranked_only, -          float hi_lo) -{ -  unsigned sz = s->size(); -  if (sz < 2) return; -  sort(s->begin(), s->end(), CmpHypsByScore); -  unsigned sep = round(sz*hi_lo); -  // hi vs. med vs. low -  unsigned sep_hi = sep; -  if (sz > 4) while (sep_hi < sz && (*s)[sep_hi-1].score == (*s)[sep_hi].score) ++sep_hi; -  else sep_hi = 1; -  for (unsigned i = 0; i < sep_hi; i++) { -    for (unsigned j = sep_hi; j < sz; j++) { -      if (misranked_only && !((*s)[i].model <= (*s)[j].model)) continue; -      if ((*s)[i].score != (*s)[j].score) -        training.push_back(make_pair((*s)[i], (*s)[j])); -    } -  } -  // med vs. low -  unsigned sep_lo = sz-sep; -  while (sep_lo > 0 && (*s)[sep_lo-1].score == (*s)[sep_lo].score) --sep_lo; -  for (unsigned i = sep_hi; i < sep_lo; i++) { -    for (unsigned j = sep_lo; j < sz; j++) { -      if (misranked_only && !((*s)[i].model <= (*s)[j].model)) continue; -      if ((*s)[i].score != (*s)[j].score) -        training.push_back(make_pair((*s)[i], (*s)[j])); -    } -  } -} - -} // namespace - -#endif - diff --git a/training/dtrain/parallelize.rb b/training/dtrain/parallelize.rb index 9315b7f7..29f3e609 100755 --- a/training/dtrain/parallelize.rb +++ b/training/dtrain/parallelize.rb @@ -3,61 +3,52 @@  require 'trollop'  require 'zipf' -def usage -  STDERR.write "Usage: " -  STDERR.write "ruby parallelize.rb -c <dtrain.ini> [-e <epochs=10>] [--randomize/-z] [--reshard/-y] -s <#shards|0> [-p <at once=9999>] -i <input> [--qsub/-q] [--dtrain_binary <path to dtrain binary>] [-l \"l2 select_k 100000\"] [--extra_qsub \"-l mem_free=24G\"]\n" -  exit 1 +conf = Trollop::options do +  opt :config,                    "dtrain configuration",                  :type => :string +  opt :input,                     "input as bitext (f ||| e)",             :type => :string +  opt :epochs,                    "number of epochs",                      :type => :int, :default => 10 +  opt :lplp_args,                 "arguments for lplp.rb",                 :type => :string, :default => "l2 select_k 100000" +  opt :randomize,                 "randomize shards once",                 :type => :bool,   :default => false, :short => '-z' +  opt :reshard,                   "randomize after each epoch",            :type => :bool,   :default => false, :short => '-y' +  opt :shards,                    "number of shards",                      :type => :int +  opt :weights,                   "input weights for first epoch",         :type => :string, :default => '' +  opt :per_shard_decoder_configs, "give custom decoder config per shard",  :type => :string, :short => '-o' +  opt :processes_at_once,         "jobs to run at oce",                    :type => :int,    :default => 9999 +  opt :qsub,                      "use qsub",                              :type => :bool,   :default => false +  opt :qsub_args,                 "extra args for qsub",                   :type => :string, :default => "-l h_vmem=5G" +  opt :dtrain_binary,             "path to dtrain binary",                 :type => :string  end -opts = Trollop::options do -  opt :config, "dtrain config file", :type => :string -  opt :epochs, "number of epochs", :type => :int, :default => 10 -  opt :lplp_args, "arguments for lplp.rb", :type => :string, :default => "l2 select_k 100000" -  opt :randomize, "randomize shards before each epoch", :type => :bool, :short => '-z', :default => false -  opt :reshard, "reshard after each epoch", :type => :bool, :short => '-y', :default => false -  opt :shards, "number of shards", :type => :int -  opt :processes_at_once, "have this number (max) running at the same time", :type => :int, :default => 9999 -  opt :input, "input (bitext f ||| e ||| ...)", :type => :string -  opt :dtrain_binary, "path to dtrain binary", :type => :string -  opt :qsub, "use qsub", :type => :bool, :default => false -  opt :qsub_args, "extra args for qsub", :type => :string, :default => "-l h_vmem=5G" -  opt :first_input_weights, "input weights for first iter", :type => :string, :default => '', :short => '-w' -  opt :per_shard_decoder_configs, "give special decoder config per shard", :type => :string, :short => '-o' -end -usage if not opts[:config]&&opts[:shards]&&opts[:input] -  dtrain_dir = File.expand_path File.dirname(__FILE__) -if not opts[:dtrain_binary] +if not conf[:dtrain_binary]    dtrain_bin = "#{dtrain_dir}/dtrain"  else -  dtrain_bin = opts[:dtrain_binary] +  dtrain_bin = conf[:dtrain_binary]  end -ruby       = '/usr/bin/ruby'  lplp_rb    = "#{dtrain_dir}/lplp.rb" -lplp_args  = opts[:lplp_args] -cat        = '/bin/cat' +lplp_args  = conf[:lplp_args] -ini        = opts[:config] -epochs     = opts[:epochs] -rand       = opts[:randomize] -reshard    = opts[:reshard] -predefined_shards = false +dtrain_conf       = conf[:config] +epochs            = conf[:epochs] +rand              = conf[:randomize] +reshard           = conf[:reshard] +predefined_shards         = false  per_shard_decoder_configs = false -if opts[:shards] == 0 +if conf[:shards] == 0    predefined_shards = true    num_shards = 0 -  per_shard_decoder_configs = true if opts[:per_shard_decoder_configs] +  per_shard_decoder_configs = true if conf[:per_shard_decoder_configs]  else -  num_shards = opts[:shards] +  num_shards = conf[:shards]  end -input = opts[:input] -use_qsub       = opts[:qsub] -shards_at_once = opts[:processes_at_once] -first_input_weights  = opts[:first_input_weights] +input               = conf[:input] +use_qsub            = conf[:qsub] +shards_at_once      = conf[:processes_at_once] +first_input_weights = conf[:weights]  `mkdir work` -def make_shards(input, num_shards, epoch, rand) +def make_shards input, num_shards, epoch, rand    lc = `wc -l #{input}`.split.first.to_i    index = (0..lc-1).to_a    index.reverse! @@ -97,7 +88,8 @@ input_files = []  if predefined_shards    input_files = File.new(input).readlines.map {|i| i.strip }    if per_shard_decoder_configs -    decoder_configs = File.new(opts[:per_shard_decoder_configs]).readlines.map {|i| i.strip} +    decoder_configs = ReadFile.readlines_strip(conf[:per_shard_decoder_configs] +                                              ).map { |i| i.strip }    end    num_shards = input_files.size  else @@ -118,22 +110,29 @@ end        qsub_str_start = qsub_str_end = ''        local_end = ''        if use_qsub -        qsub_str_start = "qsub #{opts[:qsub_args]} -cwd -sync y -b y -j y -o work/out.#{shard}.#{epoch} -N dtrain.#{shard}.#{epoch} \"" +        qsub_str_start = "qsub #{conf[:qsub_args]} -cwd -sync y -b y -j y\ +                           -o work/out.#{shard}.#{epoch}\ +                           -N dtrain.#{shard}.#{epoch} \""          qsub_str_end = "\""          local_end = ''        else          local_end = "2>work/out.#{shard}.#{epoch}"        end        if per_shard_decoder_configs -        cdec_cfg = "--decoder_config #{decoder_configs[shard]}" +        cdec_conf = "--decoder_config #{decoder_configs[shard]}"        else -        cdec_cfg = "" +        cdec_conf = ""        end        if first_input_weights!='' && epoch == 0          input_weights = "--input_weights #{first_input_weights}"        end        pids << Kernel.fork { -        `#{qsub_str_start}#{dtrain_bin} -c #{ini} #{cdec_cfg} #{input_weights}\ +        puts         "#{qsub_str_start}#{dtrain_bin} -c #{dtrain_conf} #{cdec_conf}\ +          #{input_weights}\ +          --bitext #{input_files[shard]}\ +          --output work/weights.#{shard}.#{epoch}#{qsub_str_end} #{local_end}" +        `#{qsub_str_start}#{dtrain_bin} -c #{dtrain_conf} #{cdec_conf}\ +          #{input_weights}\            --bitext #{input_files[shard]}\            --output work/weights.#{shard}.#{epoch}#{qsub_str_end} #{local_end}`        } @@ -144,8 +143,9 @@ end      pids.each { |pid| Process.wait(pid) }      pids.clear    end -  `#{cat} work/weights.*.#{epoch} > work/weights_cat` -  `#{ruby} #{lplp_rb} #{lplp_args} #{num_shards} < work/weights_cat > work/weights.#{epoch}` +  `cat work/weights.*.#{epoch} > work/weights_cat` +  `ruby #{lplp_rb} #{lplp_args} #{num_shards} < work/weights_cat\ +                                                 > work/weights.#{epoch}`    if rand and reshard and epoch+1!=epochs      input_files, num_shards = make_shards input, num_shards, epoch+1, rand    end diff --git a/training/dtrain/sample.h b/training/dtrain/sample.h index 64d93cb0..c3586c58 100644 --- a/training/dtrain/sample.h +++ b/training/dtrain/sample.h @@ -9,14 +9,16 @@ namespace dtrain  struct ScoredKbest : public DecoderObserver  { -  const unsigned k_; +  const size_t k_;    vector<ScoredHyp> s_; -  unsigned src_len_; +  size_t src_len_;    PerSentenceBleuScorer* scorer_;    vector<vector<WordID> >* refs_; -  unsigned f_count_, sz_; +  vector<Ngrams>* ref_ngs_; +  vector<size_t>* ref_ls_; +  size_t f_count_, sz_; -  ScoredKbest(const unsigned k, PerSentenceBleuScorer* scorer) : +  ScoredKbest(const size_t k, PerSentenceBleuScorer* scorer) :      k_(k), scorer_(scorer) {}    virtual void @@ -26,7 +28,7 @@ struct ScoredKbest : public DecoderObserver      s_.clear(); sz_ = f_count_ = 0;      KBest::KBestDerivations<vector<WordID>, ESentenceTraversal,        KBest::FilterUnique, prob_t, EdgeProb> kbest(*hg, k_); -    for (unsigned i = 0; i < k_; ++i) { +    for (size_t i = 0; i < k_; ++i) {        const KBest::KBestDerivations<vector<WordID>, ESentenceTraversal, KBest::FilterUnique,                prob_t, EdgeProb>::Derivation* d =              kbest.LazyKthBest(hg->nodes_.size() - 1, i); @@ -36,7 +38,7 @@ struct ScoredKbest : public DecoderObserver        h.f = d->feature_values;        h.model = log(d->score);        h.rank = i; -      h.score = scorer_->Score(h.w, *refs_); +      h.gold = scorer_->Score(h.w, *ref_ngs_, *ref_ls_);        s_.push_back(h);        sz_++;        f_count_ += h.f.size(); @@ -44,9 +46,13 @@ struct ScoredKbest : public DecoderObserver    }    vector<ScoredHyp>* GetSamples() { return &s_; } -  inline void SetReference(vector<vector<WordID> >& refs) { refs_ = &refs; } -  inline unsigned GetFeatureCount() { return f_count_; } -  inline unsigned GetSize() { return sz_; } +  inline void SetReference(vector<Ngrams>& ngs, vector<size_t>& ls) +  { +    ref_ngs_ = &ngs; +    ref_ls_ = &ls; +  } +  inline size_t GetFeatureCount() { return f_count_; } +  inline size_t GetSize() { return sz_; }  }; diff --git a/training/dtrain/score.h b/training/dtrain/score.h index c727dd30..d51aef82 100644 --- a/training/dtrain/score.h +++ b/training/dtrain/score.h @@ -8,17 +8,17 @@ namespace dtrain  struct NgramCounts  { -  unsigned N_; -  map<unsigned, score_t> clipped_; -  map<unsigned, score_t> sum_; +  size_t N_; +  map<size_t, weight_t> clipped_; +  map<size_t, weight_t> sum_; -  NgramCounts(const unsigned N) : N_(N) { Zero(); } +  NgramCounts(const size_t N) : N_(N) { Zero(); }    inline void    operator+=(const NgramCounts& rhs)    {      if (rhs.N_ > N_) Resize(rhs.N_); -    for (unsigned i = 0; i < N_; i++) { +    for (size_t i = 0; i < N_; i++) {        this->clipped_[i] += rhs.clipped_.find(i)->second;        this->sum_[i] += rhs.sum_.find(i)->second;      } @@ -34,16 +34,16 @@ struct NgramCounts    }    inline void -  operator*=(const score_t rhs) +  operator*=(const weight_t rhs)    { -    for (unsigned i = 0; i < N_; i++) { +    for (size_t i = 0; i < N_; i++) {        this->clipped_[i] *= rhs;        this->sum_[i] *= rhs;      }    }    inline void -  Add(const unsigned count, const unsigned ref_count, const unsigned i) +  Add(const size_t count, const size_t ref_count, const size_t i)    {      assert(i < N_);      if (count > ref_count) { @@ -57,40 +57,31 @@ struct NgramCounts    inline void    Zero()    { -    for (unsigned i = 0; i < N_; i++) { +    for (size_t i = 0; i < N_; i++) {        clipped_[i] = 0.;        sum_[i] = 0.;      }    }    inline void -  One() +  Print(ostream& os=cerr)    { -    for (unsigned i = 0; i < N_; i++) { -      clipped_[i] = 1.; -      sum_[i] = 1.; +    for (size_t i = 0; i < N_; i++) { +      os << i+1 << "grams (clipped):\t" << clipped_[i] << endl; +      os << i+1 << "grams:\t\t\t" << sum_[i] << endl;      }    } -  inline void -  Print() -  { -    for (unsigned i = 0; i < N_; i++) { -      cout << i+1 << "grams (clipped):\t" << clipped_[i] << endl; -      cout << i+1 << "grams:\t\t\t" << sum_[i] << endl; -    } -  } - -  inline void Resize(unsigned N) +  inline void Resize(size_t N)    {      if (N == N_) return;      else if (N > N_) { -      for (unsigned i = N_; i < N; i++) { +      for (size_t i = N_; i < N; i++) {          clipped_[i] = 0.;          sum_[i] = 0.;        }      } else { // N < N_ -      for (unsigned i = N_-1; i > N-1; i--) { +      for (size_t i = N_-1; i > N-1; i--) {          clipped_.erase(i);          sum_.erase(i);        } @@ -99,16 +90,16 @@ struct NgramCounts    }  }; -typedef map<vector<WordID>, unsigned> Ngrams; +typedef map<vector<WordID>, size_t> Ngrams;  inline Ngrams -MakeNgrams(const vector<WordID>& s, const unsigned N) +MakeNgrams(const vector<WordID>& s, const size_t N)  {    Ngrams ngrams;    vector<WordID> ng;    for (size_t i = 0; i < s.size(); i++) {      ng.clear(); -    for (unsigned j = i; j < min(i+N, s.size()); j++) { +    for (size_t j = i; j < min(i+N, s.size()); j++) {        ng.push_back(s[j]);        ngrams[ng]++;      } @@ -118,24 +109,21 @@ MakeNgrams(const vector<WordID>& s, const unsigned N)  }  inline NgramCounts -MakeNgramCounts(const vector<WordID>& hyp, const vector<vector<WordID> >& refs, const unsigned N) +MakeNgramCounts(const vector<WordID>& hyp, +                const vector<Ngrams>& ref, +                const size_t N)  {    Ngrams hyp_ngrams = MakeNgrams(hyp, N); -  vector<Ngrams> refs_ngrams; -  for (auto r: refs) { -    Ngrams r_ng = MakeNgrams(r, N); -    refs_ngrams.push_back(r_ng); -  }    NgramCounts counts(N);    Ngrams::iterator it, ti;    for (it = hyp_ngrams.begin(); it != hyp_ngrams.end(); it++) { -    unsigned max_ref_count = 0; -    for (auto ref_ngrams: refs_ngrams) { -      ti = ref_ngrams.find(it->first); -      if (ti != ref_ngrams.end()) +    size_t max_ref_count = 0; +    for (auto r: ref) { +      ti = r.find(it->first); +      if (ti != r.end())          max_ref_count = max(max_ref_count, ti->second);      } -    counts.Add(it->second, min(it->second, max_ref_count), it->first.size() - 1); +    counts.Add(it->second, min(it->second, max_ref_count), it->first.size()-1);    }    return counts; @@ -150,56 +138,65 @@ MakeNgramCounts(const vector<WordID>& hyp, const vector<vector<WordID> >& refs,   * [simply add 1 to reference length for calculation of BP]   *   */ -  struct PerSentenceBleuScorer  { -  const unsigned N_; -  vector<score_t> w_; +  const size_t     N_; +  vector<weight_t> w_; -  PerSentenceBleuScorer(unsigned n) : N_(n) +  PerSentenceBleuScorer(size_t n) : N_(n)    { -    for (auto i = 1; i <= N_; i++) +    for (size_t i = 1; i <= N_; i++)        w_.push_back(1.0/N_);    } -  inline score_t -  BrevityPenalty(const unsigned hyp_len, const unsigned ref_len) +  inline weight_t +  BrevityPenalty(const size_t hl, const size_t rl)    { -    if (hyp_len > ref_len) return 1; -    return exp(1 - (score_t)ref_len/hyp_len); +    if (hl > rl) +      return 1; + +    return exp(1 - (weight_t)rl/hl);    } -  score_t -  Score(const vector<WordID>& hyp, const vector<vector<WordID> >& refs) +  weight_t +  Score(const vector<WordID>& hyp, +        const vector<Ngrams>& ref_ngs, +        const vector<size_t>& ref_ls)    { -    unsigned hyp_len = hyp.size(), ref_len = 0; +    size_t hl = hyp.size(), rl = 0; +    if (hl == 0) return 0.;      // best match reference length -    if (refs.size() == 1)  { -      ref_len = refs[0].size(); +    if (ref_ls.size() == 1)  { +      rl = ref_ls.front();      } else { -      unsigned i = 0, best_idx = 0; -      unsigned best = std::numeric_limits<unsigned>::max(); -      for (auto r: refs) { -        unsigned d = abs(hyp_len-r.size()); -        if (best > d) best_idx = i; +      size_t i = 0, best_idx = 0; +      size_t best = numeric_limits<size_t>::max(); +      for (auto l: ref_ls) { +        size_t d = abs(hl-l); +        if (d < best) {  +          best_idx = i; +          best = d; +        } +        i += 1;        } -      ref_len = refs[best_idx].size(); +      rl = ref_ls[best_idx];      } -    if (hyp_len == 0 || ref_len == 0) return 0.; -    NgramCounts counts = MakeNgramCounts(hyp, refs, N_); -    unsigned M = N_; -    vector<score_t> v = w_; -    if (ref_len < N_) { -      M = ref_len; -      for (unsigned i = 0; i < M; i++) v[i] = 1/((score_t)M); +    if (rl == 0) return 0.; +    NgramCounts counts = MakeNgramCounts(hyp, ref_ngs, N_); +    size_t M = N_; +    vector<weight_t> v = w_; +    if (rl < N_) { +      M = rl; +      for (size_t i = 0; i < M; i++) v[i] = 1/((weight_t)M);      } -    score_t sum = 0, add = 0; -    for (unsigned i = 0; i < M; i++) { +    weight_t sum = 0, add = 0; +    for (size_t i = 0; i < M; i++) {        if (i == 0 && (counts.sum_[i] == 0 || counts.clipped_[i] == 0)) return 0.;        if (i == 1) add = 1; -      sum += v[i] * log(((score_t)counts.clipped_[i] + add)/((counts.sum_[i] + add))); +      sum += v[i] * log(((weight_t)counts.clipped_[i] + add)/((counts.sum_[i] + add)));      } -    return  BrevityPenalty(hyp_len, ref_len+1) * exp(sum); + +    return  BrevityPenalty(hl, rl+1) * exp(sum);    }  }; diff --git a/training/dtrain/update.h b/training/dtrain/update.h new file mode 100644 index 00000000..57671ce1 --- /dev/null +++ b/training/dtrain/update.h @@ -0,0 +1,65 @@ +#ifndef _DTRAIN_UPDATE_H_ +#define _DTRAIN_UPDATE_H_ + +namespace dtrain +{ + +bool +CmpHypsByGold(ScoredHyp a, ScoredHyp b) +{ +  return a.gold > b.gold; +} + +/* + * multipartite ranking + *  sort (descending) by bleu + *  compare top X (hi) to middle Y (med) and low X (lo) + *  cmp middle Y to low X + */ +inline size_t +CollectUpdates(vector<ScoredHyp>* s, +               SparseVector<weight_t>& updates, +               float margin=1.0) +{ +  size_t num_pairs = 0; +  size_t sz = s->size(); +  if (sz < 2) return 0; +  sort(s->begin(), s->end(), CmpHypsByGold); +  size_t sep = round(sz*0.1); +  size_t sep_hi = sep; +  if (sz > 4) { +    while +      (sep_hi < sz && (*s)[sep_hi-1].gold == (*s)[sep_hi].gold) ++sep_hi; +  } +  else sep_hi = 1; +  for (size_t i = 0; i < sep_hi; i++) { +    for (size_t j = sep_hi; j < sz; j++) { +      if (((*s)[i].model-(*s)[j].model) > margin) +        continue; +      if ((*s)[i].gold != (*s)[j].gold) { +        updates += (*s)[i].f-(*s)[j].f; +        num_pairs++; +      } +    } +  } +  size_t sep_lo = sz-sep; +  while (sep_lo > 0 && (*s)[sep_lo-1].gold == (*s)[sep_lo].gold) +    --sep_lo; +  for (size_t i = sep_hi; i < sep_lo; i++) { +    for (size_t j = sep_lo; j < sz; j++) { +      if (((*s)[i].model-(*s)[j].model) > margin) +        continue; +      if ((*s)[i].gold != (*s)[j].gold) { +        updates += (*s)[i].f-(*s)[j].f; +        num_pairs++; +      } +    } +  } + +  return num_pairs; +} + +} // namespace + +#endif + | 
