2015-03-04 03:07:11 +03:00
|
|
|
#include "Optimizer.h"
|
2015-03-18 16:46:15 +03:00
|
|
|
#include <iostream>
|
2015-03-04 03:07:11 +03:00
|
|
|
|
|
|
|
namespace MosesServer
|
|
|
|
{
|
2015-05-02 13:45:24 +03:00
|
|
|
using namespace std;
|
2015-03-04 03:07:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
Optimizer::
|
|
|
|
Optimizer()
|
|
|
|
{
|
|
|
|
// signature and help strings are documentation -- the client
|
|
|
|
// can query this information with a system.methodSignature and
|
|
|
|
// system.methodHelp RPC.
|
|
|
|
this->_signature = "S:S";
|
|
|
|
this->_help = "Optimizes multi-model translation model";
|
|
|
|
}
|
2015-03-04 03:07:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
void
|
|
|
|
Optimizer::
|
|
|
|
execute(xmlrpc_c::paramList const& paramList,
|
|
|
|
xmlrpc_c::value * const retvalP)
|
|
|
|
{
|
2015-03-04 03:07:11 +03:00
|
|
|
#ifdef WITH_DLIB
|
2015-05-02 13:45:24 +03:00
|
|
|
const params_t params = paramList.getStruct(0);
|
|
|
|
params_t::const_iterator si;
|
|
|
|
if ((si = params.find("model_name")) == params.end()) {
|
|
|
|
string msg = "Missing name of model to be optimized";
|
|
|
|
msg += " (e.g. PhraseDictionaryMultiModelCounts0)";
|
|
|
|
throw xmlrpc_c::fault(msg, xmlrpc_c::fault::CODE_PARSE);
|
|
|
|
}
|
|
|
|
const string model_name = xmlrpc_c::value_string(si->second);
|
2015-04-30 08:05:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
if ((si = params.find("phrase_pairs")) == params.end()) {
|
|
|
|
throw xmlrpc_c::fault("Missing list of phrase pairs",
|
|
|
|
xmlrpc_c::fault::CODE_PARSE);
|
|
|
|
}
|
2015-04-30 08:05:11 +03:00
|
|
|
|
2015-03-04 03:07:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
vector<pair<string, string> > phrase_pairs;
|
2015-04-30 08:05:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
xmlrpc_c::value_array pp_array = xmlrpc_c::value_array(si->second);
|
|
|
|
vector<xmlrpc_c::value> ppValVec(pp_array.vectorValueValue());
|
|
|
|
for (size_t i = 0; i < ppValVec.size(); ++i) {
|
|
|
|
xmlrpc_c::value_array pp_array
|
|
|
|
= xmlrpc_c::value_array(ppValVec[i]);
|
|
|
|
vector<xmlrpc_c::value> pp(pp_array.vectorValueValue());
|
|
|
|
string L1 = xmlrpc_c::value_string(pp[0]);
|
|
|
|
string L2 = xmlrpc_c::value_string(pp[1]);
|
|
|
|
phrase_pairs.push_back(make_pair(L1,L2));
|
|
|
|
}
|
2015-04-30 08:05:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
// PhraseDictionaryMultiModel* pdmm
|
|
|
|
// = (PhraseDictionaryMultiModel*) FindPhraseDictionary(model_name);
|
|
|
|
PhraseDictionaryMultiModel* pdmm = FindPhraseDictionary(model_name);
|
|
|
|
vector<float> weight_vector = pdmm->MinimizePerplexity(phrase_pairs);
|
2015-04-30 08:05:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
vector<xmlrpc_c::value> weight_vector_ret;
|
|
|
|
for (size_t i=0; i < weight_vector.size(); i++)
|
|
|
|
weight_vector_ret.push_back(xmlrpc_c::value_double(weight_vector[i]));
|
2015-03-04 03:07:11 +03:00
|
|
|
|
2015-05-02 13:45:24 +03:00
|
|
|
*retvalP = xmlrpc_c::value_array(weight_vector_ret);
|
2015-03-04 03:07:11 +03:00
|
|
|
#else
|
2015-05-02 13:45:24 +03:00
|
|
|
string errmsg = "Error: Perplexity minimization requires dlib ";
|
|
|
|
errmsg += "(compilation option --with-dlib)";
|
|
|
|
std::cerr << errmsg << std::endl;
|
|
|
|
*retvalP = xmlrpc_c::value_string(errmsg);
|
2015-03-04 03:07:11 +03:00
|
|
|
#endif
|
2015-05-02 13:45:24 +03:00
|
|
|
}
|
2015-03-04 03:07:11 +03:00
|
|
|
}
|