Reverted back types dumper to display only used types for features

This commit is contained in:
Alex Zolotarev 2011-08-17 16:06:58 +03:00 committed by Alex Zolotarev
parent 7732d884c7
commit 0a42ad5ded

View file

@ -10,81 +10,62 @@
namespace feature
{
class TypesCollector
{
public:
typedef map<uint32_t, size_t> value_type;
value_type m_stats;
{
vector<uint32_t> m_currFeatureTypes;
public:
typedef unordered_map<vector<uint32_t>, size_t> value_type;
value_type m_stats;
size_t m_namesCount;
size_t m_totalCount;
TypesCollector() : m_namesCount(0), m_totalCount(0) {}
void operator() (FeatureType & f, uint32_t)
void operator()(FeatureType & f, uint32_t)
{
++m_totalCount;
if (!f.GetPreferredDrawableName().empty())
++m_namesCount;
m_currFeatureTypes.clear();
f.ForEachTypeRef(*this);
CHECK(!m_currFeatureTypes.empty(), ("Feature without any type???"));
pair<value_type::iterator, bool> found = m_stats.insert(make_pair(m_currFeatureTypes, 1));
if (!found.second)
found.first->second++;
}
void operator() (uint32_t type)
void operator()(uint32_t type)
{
++m_stats[type];
m_currFeatureTypes.push_back(type);
}
};
struct GreaterSecond
template <class T>
static bool SortFunc(T const & first, T const & second)
{
template <class T> bool operator() (T const & t1, T const & t2)
{
return (t1.second > t2.second);
}
};
namespace
{
void CallCollect(ClassifObject * p, vector<string> & path, TypesCollector & c);
void CollectRecursive(ClassifObject * p, vector<string> & path, TypesCollector & c)
{
path.push_back(p->GetName());
c(classif().GetTypeByPath(path));
CallCollect(p, path, c);
path.pop_back();
}
void CallCollect(ClassifObject * p, vector<string> & path, TypesCollector & c)
{
p->ForEachObject(bind(&CollectRecursive, _1, ref(path), ref(c)));
}
return first.second > second.second;
}
void DumpTypes(string const & fPath)
{
// get all types from mwm file
TypesCollector doClass;
feature::ForEachFromDat(fPath, doClass);
// add types from initial classificator (to get full mapping)
vector<string> path;
CallCollect(classif().GetMutableRoot(), path, doClass);
// sort types by frequency
typedef vector<pair<uint32_t, size_t> > vec_to_sort;
typedef pair<vector<uint32_t>, size_t> stats_elem_type;
typedef vector<stats_elem_type> vec_to_sort;
vec_to_sort vecToSort(doClass.m_stats.begin(), doClass.m_stats.end());
sort(vecToSort.begin(), vecToSort.end(), GreaterSecond());
sort(vecToSort.begin(), vecToSort.end(), &SortFunc<stats_elem_type>);
// print types to out stream
Classificator & c = classif();
for (vec_to_sort::iterator i = vecToSort.begin(); i != vecToSort.end(); ++i)
cout << c.GetFullObjectName(i->first) << endl;
//cout << "Total features: " << doClass.m_totalCount << endl;
//cout << "Features with names: " << doClass.m_namesCount << endl;
for (vec_to_sort::iterator it = vecToSort.begin(); it != vecToSort.end(); ++it)
{
cout << it->second << " ";
for (size_t i = 0; i < it->first.size(); ++i)
cout << classif().GetFullObjectName(it->first[i]) << " ";
cout << endl;
}
cout << "Total features: " << doClass.m_totalCount << endl;
cout << "Features with names: " << doClass.m_namesCount << endl;
}
class NamesCollector
@ -130,9 +111,10 @@ namespace feature
typedef vector<NameElemT> VecToSortT;
VecToSortT vecToSort(doClass.m_stats.begin(), doClass.m_stats.end());
sort(vecToSort.begin(), vecToSort.end(), GreaterSecond());
sort(vecToSort.begin(), vecToSort.end(), &SortFunc<NameElemT>);
for (VecToSortT::iterator it = vecToSort.begin(); it != vecToSort.end(); ++it)
cout << it->second << " " << it->first << endl;
}
}