当前位置: 首页>>代码示例>>C++>>正文


C++ FileParser::ReadSample方法代码示例

本文整理汇总了C++中FileParser::ReadSample方法的典型用法代码示例。如果您正苦于以下问题:C++ FileParser::ReadSample方法的具体用法?C++ FileParser::ReadSample怎么用?C++ FileParser::ReadSample使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在FileParser的用法示例。


在下文中一共展示了FileParser::ReadSample方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: main

int main(int argc, char* argv[]) {
	int ch;

	std::string test_file;
	std::string model_file;
	std::string output_file;

	while ((ch = getopt(argc, argv, "t:m:o:h")) != -1) {
		switch (ch) {
		case 't':
			test_file = optarg;
			break;
		case 'm':
			model_file = optarg;
			break;
		case 'o':
			output_file = optarg;
			break;
		case 'h':
		default:
			print_usage(argc, argv);
			exit(0);
		}
	}

	if (test_file.size() == 0 || model_file.size() == 0 || output_file.size() == 0) {
		print_usage(argc, argv);
		exit(1);
	}

	LRModel<double> model;
	model.Initialize(model_file.c_str());

	double y = 0.;
	std::vector<std::pair<size_t, double> > x;
	FILE* wfp = fopen(output_file.c_str(), "w");
	size_t cnt = 0, correct = 0;
	double loss = 0.;
	FileParser<double> parser;
	parser.OpenFile(test_file.c_str());

	std::vector<std::pair<double, unsigned> > pred_scores;

	while (1) {
		bool res = parser.ReadSample(y, x);
		if (!res) break;

		double pred = model.Predict(x);
		pred = std::max(std::min(pred, 1. - 10e-15), 10e-15);
		fprintf(wfp, "%lf\n", pred);

		pred_scores.push_back(std::move(
			std::make_pair(pred, static_cast<unsigned>(y))));

		++cnt;
		double pred_label = 0;
		if (pred > 0.5) pred_label = 1;
		if (util_equal(pred_label, y)) ++correct;

		pred = std::max(std::min(pred, 1. - 10e-15), 10e-15);
		loss += y > 0 ? -log(pred) : -log(1. - pred);
	}

	std::sort(
		pred_scores.begin(),
		pred_scores.end(),
		[] (const std::pair<double, unsigned>& l, const std::pair<double, unsigned>& r) {
		    return l.first > r.first;
		}
	);
	double auc = calc_auc(pred_scores);

	if (cnt > 0) {
		printf("Accuracy = %.2lf%% (%zu/%zu)\n",
			static_cast<double>(correct) / cnt * 100, correct, cnt);
		printf("Log-likelihood = %lf\n", loss / cnt);
		printf("AUC = %lf\n", auc);
	}

	parser.CloseFile();
	fclose(wfp);

	return 0;
}
开发者ID:BayronP,项目名称:ftrl_proximal_lr,代码行数:84,代码来源:ftrl_predict.cpp


注:本文中的FileParser::ReadSample方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。