⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cmpbindata.cc

📁 torch tracking code, it is a good code
💻 CC
字号:
const char *help = "\progname: cmpbindata.cc\n\code2html: This program compares two bindata files.\n\version: Torch3 vision2.0, 2004-2005\n\(c) Sebastien Marcel (marcel@idiap.ch)\n";#include "DiskXFile.h"#include "CmdLine.h"using namespace Torch;real MSE(int n_inputs, real *x, real *y){	real d_ = 0.0;	for(int i = 0 ; i < n_inputs ; i++)	{		real z = x[i] - y[i];		d_ += z * z;	}		return d_ / (real) n_inputs;}int main(int argc, char *argv[]){	char *filename_in1;	char *filename_in2;	bool verbose;		CmdLine cmd;	cmd.setBOption("write log", false);	cmd.info(help);	cmd.addText("\nArguments:");	cmd.addSCmdArg("filename in1", &filename_in1, "input bindata filename 1");	cmd.addSCmdArg("filename in2", &filename_in2, "input bindata filename 2");	cmd.addText("\nArguments:");	cmd.addBCmdOption("-verbose", &verbose, false, "verbose");	cmd.read(argc, argv);	DiskXFile *file1 = NULL;	DiskXFile *file2 = NULL;  	int n_patterns1;	int n_inputs1;	file1 = new DiskXFile(filename_in1, "r");			file1->read(&n_patterns1, sizeof(int), 1);	file1->read(&n_inputs1, sizeof(int), 1);	if(verbose)	{		print("Reading bindata file (%s)\n", filename_in1);		print("   n_inputs = %d\n", n_inputs1);		print("   n_patterns = %d\n", n_patterns1);  	}	int n_patterns2;	int n_inputs2;	file2 = new DiskXFile(filename_in2, "r");			file2->read(&n_patterns2, sizeof(int), 1);	file2->read(&n_inputs2, sizeof(int), 1);	if(verbose)	{		print("Reading bindata file (%s)\n", filename_in2);		print("   n_inputs = %d\n", n_inputs2);		print("   n_patterns = %d\n", n_patterns2);  	}	if(n_inputs1 != n_inputs2) error("n_inputs different");	int n_inputs = n_inputs1;		real **inputs1 = new real*[n_patterns1];	for(int p = 0 ; p < n_patterns1 ; p++)	{		inputs1[p] = new real [n_inputs];		file1->read(inputs1[p], sizeof(real), n_inputs);	}	real **inputs2 = new real*[n_patterns2];	for(int p = 0 ; p < n_patterns2 ; p++)	{		inputs2[p] = new real [n_inputs];		file2->read(inputs2[p], sizeof(real), n_inputs);	}	// Compare each pattern of file to patterns of file 1	real mean = 0.0;	for(int p2 = 0 ; p2 < n_patterns2 ; p2++)	{	   	real mean_ = 0.0;		print("Pattern %d:\n", p2);		for(int p1 = 0 ; p1 < n_patterns1 ; p1++)		{			real d_ = MSE(n_inputs, inputs1[p1], inputs2[p2]);			print("   > %g\n", d_);			mean_ += d_;		}		mean_ /= (real) n_patterns1;		print("   mean = %g\n", mean_);		mean += mean_;	}		mean /= (real) n_patterns2;	print("Average distance between %s and %s:\n", filename_in1, filename_in2);	print(" > %g\n", mean);	for(int p = 0 ; p < n_patterns1 ; p++) delete [] inputs1[p];	delete [] inputs1;	for(int p = 0 ; p < n_patterns2 ; p++) delete [] inputs2[p];	delete [] inputs2;	delete file1;	delete file2;	return 0;}   

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -