2008-05-14 11:57:45 +04:00
|
|
|
/*
|
|
|
|
* FeatureStats.cpp
|
|
|
|
* met - Minimum Error Training
|
|
|
|
*
|
|
|
|
* Created by Nicola Bertoldi on 13/05/08.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <fstream>
|
|
|
|
#include "FeatureStats.h"
|
|
|
|
|
|
|
|
|
2008-05-16 00:32:37 +04:00
|
|
|
FeatureStats::FeatureStats()
|
2008-05-14 11:57:45 +04:00
|
|
|
{};
|
|
|
|
|
2008-05-27 20:50:52 +04:00
|
|
|
FeatureStats::FeatureStats(const FeatureStats &stats):
|
2008-05-16 00:32:37 +04:00
|
|
|
array_(stats.array_)
|
2008-05-14 11:57:45 +04:00
|
|
|
{};
|
|
|
|
|
2008-05-16 00:32:37 +04:00
|
|
|
FeatureStats::FeatureStats(const size_t size)
|
2008-05-14 11:57:45 +04:00
|
|
|
{
|
2008-05-23 15:48:16 +04:00
|
|
|
for(unsigned int i = 0; i < size; i++)
|
2008-05-14 11:57:45 +04:00
|
|
|
array_.push_back(0);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
FeatureStats::FeatureStats(std::string &theString)
|
|
|
|
{
|
|
|
|
set(theString);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FeatureStats::set(std::string &theString)
|
|
|
|
{
|
2008-05-27 20:50:52 +04:00
|
|
|
std::string substring, stringBuf;
|
2008-05-23 15:48:16 +04:00
|
|
|
|
2008-05-14 11:57:45 +04:00
|
|
|
int nextPound;
|
|
|
|
FeatureStatsType sc;
|
|
|
|
// TRACE_ERR("Decompounding string: " << theString << std::endl);
|
|
|
|
while (!theString.empty()){
|
|
|
|
nextPound = getNextPound(theString, substring);
|
|
|
|
sc = ATOFST(substring.c_str());
|
|
|
|
array_.push_back(sc);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void FeatureStats::loadtxt(std::ifstream& inFile)
|
|
|
|
{
|
2008-05-27 20:50:52 +04:00
|
|
|
std::string theString;
|
2008-05-14 11:57:45 +04:00
|
|
|
std::getline(inFile, theString);
|
|
|
|
set(theString);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FeatureStats::loadtxt(const std::string &file)
|
|
|
|
{
|
|
|
|
// TRACE_ERR("loading the stats from " << file << std::endl);
|
|
|
|
|
|
|
|
std::ifstream inFile(file.c_str(), std::ios::in); // matches a stream with a file. Opens the file
|
|
|
|
|
|
|
|
loadtxt(inFile);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FeatureStats::savetxt(const std::string &file)
|
|
|
|
{
|
|
|
|
// TRACE_ERR("saving the stats into " << file << std::endl);
|
|
|
|
|
|
|
|
std::ofstream outFile(file.c_str(), std::ios::out); // matches a stream with a file. Opens the file
|
|
|
|
|
|
|
|
savetxt(outFile);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FeatureStats::savetxt(std::ofstream& outFile)
|
|
|
|
{
|
2008-06-03 12:56:37 +04:00
|
|
|
TRACE_ERR("saving the stats" << std::endl);
|
2008-06-04 12:33:37 +04:00
|
|
|
outFile << *this;
|
2008-05-14 11:57:45 +04:00
|
|
|
}
|
|
|
|
|
2008-06-03 12:56:37 +04:00
|
|
|
void FeatureStats::savebin(std::ofstream& outFile)
|
|
|
|
{
|
|
|
|
outFile << "S|";
|
|
|
|
outFile << "|E";
|
|
|
|
}
|
2008-05-14 11:57:45 +04:00
|
|
|
|
|
|
|
FeatureStats& FeatureStats::operator=(const FeatureStats &stats)
|
|
|
|
{
|
|
|
|
array_ = stats.array_;
|
|
|
|
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-05-27 20:50:52 +04:00
|
|
|
/**write the whole object to a stream*/
|
|
|
|
ostream& operator<<(ostream& o, const FeatureStats& e){
|
|
|
|
for (featstats_t::iterator i = e.getArray().begin(); i != e.getArray().end(); i++)
|
|
|
|
o << *i << " ";
|
|
|
|
return o;
|
|
|
|
}
|