亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cgcm.cpp

?? 數學計算程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
		}
		else if(strcmp(argv[i], "-outpdb") == 0){
			i++;
			if(i >= argc){
				cerr << argv[0] << ": -outpdb needs a filename.\n";
				exit(1);
			}
			else{
				str << argv[i];
				str >> outpdb;
			}
		}
		else if(strcmp(argv[i], "-outtxt") == 0){
			i++;
			if(i >= argc){
				cerr << argv[0] << ": -outtxt needs a filename.\n";
				exit(1);
			}
			else{
				str << argv[i];
				str >> outtxt;
			}
		}
		else if(strcmp(argv[i], "-center") == 0){
			i++;
			if(i >= argc){
				cerr << argv[0] << ": -outtxt needs a filename.\n";
				exit(1);
			}
			else{
				str << argv[i];
				str >> center;
			}
		}
		else if(strcmp(argv[i], "-element") == 0){
			i++;
			if(i >= argc){
				cerr << argv[0] << ": -element needs a filename.\n";
				exit(1);
			}
			else{
				str << argv[i];
				str >> element;
			}
		}
		else if(strcmp(argv[i], "-parafile") == 0){
			i++;
		}
		else{
			cerr << argv[0] << ": unrecognized arguement:"
				<< argv[i] << "\n\n";
			cerr << "parameters include: \n"
				 << " -grad_tol  -g_rho_min  -g_rho_max  -g_phi_min  -g_phi_max \n"
				 << " -g_z_min   -g_z_max    -rho_scale  -z_scale    -center \n"
				 << " -outpdb    -outtxt     -element    -parafile \n";
			exit(1);
		}
	}

	////////////////////////////////////////////////////////////
	/// read .pdb file to obtain number of atoms
	num = pdb_num(infile);
	dim = num*3;
	atoms = new CParticles(num);
	////////////////////////////////////////////////////////////

	ofstream fout(outtxt.c_str());
	if(!fout)
	{
		cerr << "-------------------------------------------------------" << endl;
		cerr << "Warning: Cannot write to " << outtxt.c_str()
			 << " for output." << endl;
		cerr << "-------------------------------------------------------" << endl;
	}

	double *x = new double[num];
	double *y = new double[num];
	double *z = new double[num];
	double *low = new double[dim];
	double *up = new double[dim];
	double *var = new double[dim];

	/// change epsilon  Parm->eps = 1.e-8;
	/// line 698 file asa_cg.cpp
	/*asacg_parm cgParm ;
	asa_parm asaParm ;
	asa_cg_default (&cgParm) ;
	asa_default (&asaParm) ;
	cgParm.eps = epsilon;
	asaParm.eps = epsilon;*/

	read_pdb(infile, x, y, z, element);
	if(center == 1) center_cyl(x, y, z, num);
	//write_pdb(string("testtest.pdb"), x, y, z, num, string("Ni"));

	atoms->Read(x, y, z);
	atoms->WriteCyl(x, y, z);

	_3d_1d(x, y, z, num, var);
	/*_1d_3d(var, x, y, z, num);
	write_pdb(string("cyl_xyz2.pdb"), x, y, z, num, string("Ni"));*/

	/// Boundary constraints
	atoms->SetBound(low, up, g_rho_min, g_rho_max, g_phi_min, g_phi_max, g_z_min, g_z_max);
	/// parameter corresponding to element
	setup_param(element);
	for(int i = 0; i < dim;)
	{
		var[i] *= rho_scale;//0.95;
		var[i+2] *= z_scale;
		i += 3;
	}

	///////////////////////////////////////////////////////////////////////////
	/// simple boundary test module, you need to improve it later.
	double rhom, zm;
	boundary_cyl(var, dim, rhom, zm);
	if(rhom > g_rho_max) 
	{
		cerr << "-------------------------------------------------------" << endl;
		cerr << "Warning: rho_max = " << rhom 
			 << " of atoms out of constraints " << g_rho_max << endl;
		cerr << "Suggestion: set rho_scale smaller than " << g_rho_max/rhom << endl;
		cerr << "      But the algorithm may not be tolerant. " << endl;
		cerr << "-------------------------------------------------------" << endl;
	}
	if(zm > g_z_max) 
	{
		cerr << "-------------------------------------------------------" << endl;
		cerr << "Warning: z_max " << zm 
			 << "of atoms out of constraints " << g_z_max << endl;
		cerr << "Suggestion: set z_scale smaller than " << g_z_max/zm << endl;
		cerr << "      But the algorithm may not be tolerant. " << endl;
		cerr << "-------------------------------------------------------" << endl;
	} 
	/// simple boundary, you need to improve it later
	///////////////////////////////////////////////////////////////////////////

	//asa_cg (var, low, up, dim, NULL, NULL, NULL, grad_tol, EnergySC_CYL, ForceSC_CYL, ForceEnergySC_CYL, NULL);

	asa_cg (var, low, up, dim, NULL, NULL, NULL, grad_tol, EnergySC_CYL, ForceSC_CYL, NULL, NULL);

	_1d_3d(var, x, y, z, num);
	atoms->ReadCyl(x, y, z);
	atoms->Write(x, y, z);

	//// //// Test if energy caculated by EnergySC and ForceSC is equal.
	//int flag = 0; //////////
	//for(int i = 0; i < num; i++)/////////
	//{////////
	//	if(fabs(x[i]-x1[i]) > 1.e-3) flag = 1;///
	//	if(fabs(y[i]-y1[i]) > 1.e-3) flag = 1;///
	//	if(fabs(z[i]-z1[i]) > 1.e-3) flag = 1;///
	//}////////
	//cout << "flag: " << flag << endl;//////
	//cout << "energy: " << EnergySC_CYL(var, dim) << endl;/////////////
	//ForceSC_CYL(ff, var, dim);/////////////
	////for(int i = 0; i < dim; i ++)///////////
	//	//cout << ff[i] << "  ";/////////////
	//cout << "ff energy: " << ForceSC(x, y, z, num, fff, string("Ni")) << endl;//////////

	write_pdb(outpdb, x, y, z, num, element);
	cout << num << " atoms" << endl << endl;
	fout << num << " atoms" << endl << endl;

	fout.close();
	delete []x;
	delete []y;
	delete []z;
	delete []var;
	delete []low;
	delete []up;
	delete atoms;

	//delete []x1;/////
	//delete []y1;////
	//delete []z1;////
	//delete []ff;////
	//for(int i = 0; i < 3; i++) delete []fff[i];/////
	//delete []fff;//////

	//double xxx[2] = {0,0};//////////////////////////////////////////////////////////////////////////
	//double yxx[2] = {0,0};
	//double zxx[2] = {0, 0.09 };
	//double **ffff = new double*[3];
	//for(int i=0; i<3; i++) ffff[i] = new double[2];
	//
	//cout << EnergySC(xxx, yxx, zxx, 2, string("Ni"))<<endl;
	//ForceSC(xxx,yxx,zxx,2,ffff,string("Ni"));
	//for(int i=0; i < 3; i++)
	//{//////////////////////////////////////////////////////////////////////////
	//	for(int j=0; j<2 ; j++)
	//	{
	//		cout << ffff[i][j] << "  ";
	//	}
	//	cout << endl;
	//}
	//for(int i=0; i<3; i++) delete []ffff[i];
	//delete []ffff;//////////////////////////////////////////////////////////////////////////
}

/* evaluate the objective function */
double EnergySC_CYL(double *xx, int n)
{
    double f;
    double *x = new double[n/3];
	double *y = new double[n/3];
	double *z = new double[n/3];
	for(int i = 0; i < n;)
	{
		x[i/3] = xx[i];
		y[i/3] = xx[i+1];
		z[i/3] = xx[i+2];
		i += 3;
	}
	//setup_param(string("Ni"));
	/// cylindrical coordination to cartesian coordination
	atoms->ReadCyl(x, y, z);
	atoms->Write(x, y, z);
	//Rc = 100;
	f = EnergySC(x, y, z, n/3, string("Ni"));
	delete []x;
	delete []y;
	delete []z;
    return (f);
}

/* evaluate the gradient of the objective function */
void ForceSC_CYL(double  *g, double  *xx, int n)
{
	int i;
	double phi;
    double *x = new double[n/3];
	double *y = new double[n/3];
	double *z = new double[n/3];
	double **f = new double*[3];
	for(i = 0; i < 3; i++) f[i] = new double[n/3];
	for(i = 0; i < n;)
	{
		x[i/3] = xx[i];
		y[i/3] = xx[i+1];
		z[i/3] = xx[i+2];
		i += 3;
	}
	//setup_param(string("Ni"));
	//Rc = 100;
	/// cylindrical coordination to cartesian coordination
	/// need converted matrix
	atoms->ReadCyl(x, y, z);
	atoms->Write(x, y, z);
	ForceSC(x, y, z, n/3, f, string("Ni"));
	for(i = 0; i < n/3; i++)
	{
		phi = atoms->atoms[i]->cyl.phi;
		g[3*i] = -( f[0][i]*cos(phi) + f[1][i]*sin(phi) );
		g[3*i+1] = -( -f[0][i]*sin(phi) + f[1][i]*cos(phi) );
		g[3*i+2] = -( f[2][i] );
	}
	delete []y;
	delete []z;
	delete []x;
	for(i = 0; i < 3; i++) delete []f[i];
	delete []f;
}

/* value and gradient of the objective function */
double ForceEnergySC_CYL (double  *g, double  *xx, INT32 n)
{
	//double energy = ForceSC_CYL(double  *g, double  *xx, int n);
	int i;
	double energy, phi;
    double *x = new double[n/3];
	double *y = new double[n/3];
	double *z = new double[n/3];
	double **f = new double*[3];
	for(i = 0; i < 3; i++) f[i] = new double[n/3];
	for(i = 0; i < n;)
	{
		x[i/3] = xx[i];
		y[i/3] = xx[i+1];
		z[i/3] = xx[i+2];
		i += 3;
	}
	//setup_param(string("Ni"));
	//Rc = 100;
	/// cylindrical coordination to cartesian coordination
	atoms->ReadCyl(x, y, z);
	atoms->Write(x, y, z);
	energy = ForceSC(x, y, z, n/3, f, string("Ni"));
	for(i = 0; i < n/3; i++)
	{
		phi = atoms->atoms[i]->cyl.phi;
		g[3*i] = -( f[0][i]*cos(phi) + f[1][i]*sin(phi) );
		g[3*i+1] = -( -f[0][i]*sin(phi) + f[1][i]*cos(phi) );
		g[3*i+2] = -( f[2][i] );
	}
	delete []y;
	delete []z;
	delete []x;
	for(i = 0; i < 3; i++) delete []f[i];
	delete []f;
	return energy;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩在线视频| 91精品91久久久中77777| 天堂资源在线中文精品| 一区二区三区中文免费| 最好看的中文字幕久久| 国产精品国产精品国产专区不蜜 | 夜夜精品浪潮av一区二区三区| 日韩三级.com| 欧美性xxxxxxxx| 欧美色视频在线| 日韩亚洲欧美高清| 精品国产免费人成电影在线观看四季 | 石原莉奈一区二区三区在线观看| 亚洲图片有声小说| 久久精品国产99国产精品| 国产一区二区中文字幕| 成人黄色综合网站| 在线免费不卡电影| 日韩一级成人av| 国产婷婷色一区二区三区在线| 国产精品久线观看视频| 亚洲美女偷拍久久| 免费av成人在线| 成人黄色软件下载| 欧美日韩一级黄| 欧美精品一区二区三区在线| 国产日韩视频一区二区三区| 亚洲精品视频在线看| 人人超碰91尤物精品国产| 国产成人精品三级| 欧美日韩高清影院| 欧美国产精品一区| 天堂va蜜桃一区二区三区漫画版 | 欧美精品一区二区久久久| 中文字幕国产一区| 日本欧美加勒比视频| 成人av电影在线观看| 欧美性感一区二区三区| 精品国产网站在线观看| 亚洲免费大片在线观看| 激情图片小说一区| 色综合色综合色综合色综合色综合| 欧美巨大另类极品videosbest| 国产三级精品三级| 蜜臀av国产精品久久久久 | 国产精品久久久久永久免费观看 | eeuss国产一区二区三区| 欧美人与性动xxxx| 成人免费小视频| 国产剧情一区在线| 91精品国产福利在线观看| 亚洲美腿欧美偷拍| 成人久久视频在线观看| 欧美不卡在线视频| 亚洲成人动漫在线免费观看| 91视频免费播放| 国产日韩欧美电影| 极品少妇一区二区三区精品视频 | 国产成人午夜视频| 欧美一级xxx| 天天射综合影视| 在线视频欧美精品| 亚洲欧美视频一区| 波多野结衣亚洲一区| 国产视频911| 久久成人免费网站| 91精品国产综合久久久蜜臀图片| 亚洲一区欧美一区| a在线播放不卡| 国产精品视频麻豆| 成人午夜免费电影| 欧美国产一区视频在线观看| 国产成人欧美日韩在线电影| 国产亚洲短视频| 国产成人aaa| 国产欧美日韩另类一区| 国产成人免费在线| 国产精品久久看| 97精品电影院| 一区二区三区蜜桃| 欧美日韩电影在线播放| 日韩国产高清影视| 精品人伦一区二区色婷婷| 精油按摩中文字幕久久| 国产日韩视频一区二区三区| 成人性生交大片免费看中文网站| 欧美高清在线视频| 色综合 综合色| 亚洲一区二区三区爽爽爽爽爽| 7777精品伊人久久久大香线蕉超级流畅| 亚洲精品国久久99热| 欧美猛男男办公室激情| 麻豆专区一区二区三区四区五区| 日韩午夜小视频| 国产传媒欧美日韩成人| 亚洲色图第一区| 91.麻豆视频| 国内精品伊人久久久久av一坑 | 一本高清dvd不卡在线观看| 一区二区在线电影| 日韩情涩欧美日韩视频| 成人综合日日夜夜| 亚洲在线视频网站| 久久午夜色播影院免费高清| 91亚洲国产成人精品一区二三 | 成人免费在线播放视频| 欧美猛男男办公室激情| 国产成人av一区二区三区在线 | 亚洲国产精品视频| 久久综合网色—综合色88| 色噜噜狠狠色综合欧洲selulu | 久久久久88色偷偷免费| 91色.com| 精品在线播放免费| 亚洲一卡二卡三卡四卡五卡| 久久人人超碰精品| 欧美日韩一区二区三区在线| 国产乱一区二区| 香港成人在线视频| 中文字幕一区二区三区色视频| 69堂国产成人免费视频| 99re这里只有精品首页| 国产尤物一区二区在线| 亚洲国产三级在线| 国产精品美日韩| 欧美日韩国产综合视频在线观看 | 日韩欧美区一区二| 99精品国产91久久久久久| 狂野欧美性猛交blacked| 亚洲一区二三区| 国产精品久久免费看| 久久久91精品国产一区二区精品| 欧美在线观看一区| av激情亚洲男人天堂| 国内精品国产三级国产a久久| 亚洲一区二区欧美日韩 | 日韩欧美一级精品久久| 欧美亚洲综合另类| 91蜜桃免费观看视频| 成人午夜视频免费看| 国产91在线看| 国产91在线观看丝袜| 国产精品一区二区久久精品爱涩| 蜜臀久久99精品久久久久宅男| 亚洲丶国产丶欧美一区二区三区| 亚洲欧美一区二区三区孕妇| 久久久久久久久久久久久夜| 26uuu亚洲综合色欧美| 日韩精品一区二区三区中文精品| 在线欧美日韩国产| 欧美婷婷六月丁香综合色| 色综合中文字幕国产| 国产老肥熟一区二区三区| 精品一区二区三区欧美| 韩国成人在线视频| 美女视频一区二区| 精品一区二区三区不卡| 国产美女娇喘av呻吟久久| 国产一区二区免费在线| 国产美女久久久久| 99久久免费精品高清特色大片| 成人午夜在线播放| 99久久er热在这里只有精品66| 色综合视频在线观看| 欧美男男青年gay1069videost | 麻豆国产欧美日韩综合精品二区| 日韩专区在线视频| 久久精品国产亚洲一区二区三区| 精品综合免费视频观看| 国内精品免费在线观看| 成人综合在线观看| 欧美在线视频不卡| 精品人在线二区三区| 中国av一区二区三区| 亚洲黄一区二区三区| 日韩av网站在线观看| 狠狠色狠狠色综合日日91app| 粉嫩久久99精品久久久久久夜| av高清不卡在线| 91精品国产高清一区二区三区| 26uuu欧美| 亚洲精品国产成人久久av盗摄| 亚洲妇熟xx妇色黄| 国产在线一区二区综合免费视频| 成人网在线播放| 91麻豆精品91久久久久同性| 久久久久久久久免费| 一级中文字幕一区二区| 国产精品亚洲视频| 欧美日韩国产大片| 中文字幕在线免费不卡| 舔着乳尖日韩一区| 99久久伊人精品| 精品国产一二三| 亚洲国产综合人成综合网站| 国产黄色精品视频| 91精品久久久久久蜜臀| 日韩伦理av电影| 国产经典欧美精品| 日韩一区二区三区在线|