forked from yanyiwu/simhash
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdemo.cpp
34 lines (28 loc) · 1.34 KB
/
demo.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <iostream>
#include <fstream>
//this define can avoid some logs which you don't need to care about.
#define LOGGER_LEVEL LL_WARN
#include "simhash/Simhasher.hpp"
using namespace simhash;
int main(int argc, char** argv)
{
Simhasher simhasher("../dict/jieba.dict.utf8", "../dict/hmm_model.utf8", "../dict/idf.utf8", "../dict/stop_words.utf8");
string s("我是蓝翔技工拖拉机学院手扶拖拉机专业的。不用多久,我就会升职加薪,当上总经理,出任CEO,走上人生巅峰。");
size_t topN = 5;
uint64_t u64 = 0;
vector<pair<string ,double> > res;
simhasher.extract(s, res, topN);
simhasher.make(s, topN, u64);
cout<< "文本:\"" << s << "\"" << endl;
cout << "关键词序列是: " << res << endl;
cout<< "simhash值是: " << u64<<endl;
const char * bin1 = "100010110110";
const char * bin2 = "110001110011";
uint64_t u1, u2;
u1 = Simhasher::binaryStringToUint64(bin1);
u2 = Simhasher::binaryStringToUint64(bin2);
cout<< bin1 << "和" << bin2 << " simhash值的相等判断如下:"<<endl;
cout<< "海明距离阈值默认设置为3,则isEqual结果为:" << (Simhasher::isEqual(u1, u2)) << endl;
cout<< "海明距离阈值默认设置为5,则isEqual结果为:" << (Simhasher::isEqual(u1, u2, 5)) << endl;
return EXIT_SUCCESS;
}