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

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

?? d.h

?? 使用蒙特卡洛方法研究中子屏蔽以活求碰撞情況
?? H
?? 第 1 頁 / 共 2 頁
字號:

bool Nucleus::return_type(Nreactiontype react)
{
	if(accompany) {mynuc.close(); accompany=false;}
	switch (nucleustype)
	{										//enum Nreactiontype{N2N,Elastic_Deflection,Nonelastic_Deflection,Capture};
		                                    //   enum Type{H,Be,B,C,N,O,F};
	case H:							
		switch (react)
		{
		case N2N:
			    return false;
			break;
		case Elastic_Deflection:
			mynuc.open("H-Elastic.txt",ios::in);
			if (mynuc.bad())
				return false;
			break;
		case Nonelastic_Deflection:
			    return false;
			break;
		case Capture:
			mynuc.open("H-Capture.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Total_Reaction:
			mynuc.open("H-Total.txt",ios::in);
			if (mynuc.bad())
			{		    return false; }
            break;
		default:
			return false;
			break;
		}
		break;
	case O:
		switch (react)
		{
		case N2N:
			mynuc.open("O-N2N.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Elastic_Deflection:
			mynuc.open("O-Elastic.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Nonelastic_Deflection:
			mynuc.open("O-Nonelastic.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Capture:
			mynuc.open("O-Capture.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Total_Reaction:
			mynuc.open("O-Total.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		default:
			return false;
			break;
		}
		break;
	case N:
		switch (react)
		{
		case N2N:
			mynuc.open("N-N2N.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Elastic_Deflection:
			mynuc.open("N-Elastic.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Nonelastic_Deflection:
			mynuc.open("N-Nonelastic.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Capture:
			mynuc.open("N-Capture.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		case Total_Reaction:
			mynuc.open("N-Total.txt",ios::in);
			if (mynuc.bad())	
			    return false;
			break;
		default:
			return false;
			break;
		}
		break;
	default:
		return false;
		break;
	}
    return true;
}





Neutron::Neutron(double px,double py,double pz,double cx,double cy,double cz,double E)
{
	PositionX=px;
	PositionY=py;
	PZ=pz;
	CosX=cx;
	CosY=cy;
	CosZ=cz;
	Energy=E;
	Mass=1;
	boardnode=NULL;
	previous=NULL;
	next=NULL;
	free=0;

}

void Neutron::Move(double TimeInterval)
{
	double Velocity=sqrt(2*Energy/Mass);
	PositionX+=Velocity*CosX*TimeInterval;
	PositionY+=Velocity*CosY*TimeInterval;
    PZ+=Velocity*CosZ*TimeInterval;
	free+=Velocity*TimeInterval;
}





void Neutron::Collision( Nucleus nuc)
{		
	double ccs=nuc.N_Capture_Cross_Section( *this);
	double edcs=nuc.N_Elastic_Deflection_Cross_Section(*this);
	double ndcs=nuc.N_Nonelastic_Deflection_Cross_Section( *this );
	double n2ncs=nuc.N2N_Cross_Section( *this );
	double total=ccs+edcs+ndcs+n2ncs;
	double k=(double)rand()/RAND_MAX;
	if (k<=ccs/total)            nuc.Reaction(Capture,this);                               
	else if (k<=(ccs+edcs)/total)       nuc.Reaction(Elastic_Deflection,this);
	else if (k<=(ccs+edcs+ndcs)/total)  nuc.Reaction(Nonelastic_Deflection,this);
	else if (k<=1)       nuc.Reaction(N2N, this);
}


MainSpace::MainSpace(Nucleus * ptr,double Size)
{
	head=end=unitcurrent=NULL;
	current=headneutron=endneutron=NULL;
	Pointer=NULL;
	for(int i=1;i<=Size/Interwidth;i++)
	    Addboard(ptr);
	headneutron=NULL;
	endneutron=NULL;
	count=false;
}

void MainSpace::Addboard(Nucleus * ptr)
{
	if (head==NULL) 
	{
		head=new Unitboard(NULL,0,Dist);
		end=new Unitboard(ptr,1,Interwidth);
		head->next=end;
		end->previous=head;
	}
	else
	{
		unitcurrent=new Unitboard(ptr,end->PlaceZ+1,Interwidth);
		end->next=unitcurrent;
		unitcurrent->previous=end;
		end=end->next;
	}
}


void MainSpace::Addneutron(double px,double py,double pz,double cx,double cy,double cz,double E,Unitboard * ptr)
{
	current=new Neutron(px,py,pz,cx,cy,cz,E);
	current->boardnode=ptr;
	current->mainnode=this;
//	Neutron a(1,1,1,1,-1,1,20);
//	Neutron b(1.2,1,1,1,-1,1,20);
	if (headneutron==NULL) 
	{
		headneutron=endneutron=current;
	}
	else
	{
		current->previous=endneutron;
		endneutron->next=current;
		endneutron=endneutron->next;
	}
	Total++;
}

bool MainSpace::Deleteneutron()
{
	count=true;
	if (Pointer==NULL) return 1;
	else if (Pointer==headneutron && Pointer==endneutron) {  headneutron=endneutron=NULL; delete Pointer; Pointer=NULL; return 1;}
	else if (Pointer==headneutron) { headneutron=Pointer->next;  headneutron->previous=NULL; delete Pointer; Pointer->next=headneutron; return 1;}
	else if (Pointer==endneutron) { endneutron=Pointer->previous; endneutron->next=NULL; delete Pointer; Pointer=NULL; return 1;}
	else 
	{
		Pointer->previous->next=Pointer->next;
		Pointer=Pointer->previous;
		delete Pointer->next->previous;
		Pointer->next->previous=Pointer;
		return 1;
	}
 }

 void MainSpace::Generateneutron(double emissivity)
 { 
	 //  add code here
	 //
	 if ((double)rand()/RAND_MAX<emissivity)
	 {
		 Addneutron((double)rand()/RAND_MAX,(double)rand()/RAND_MAX,0,0,0,1,30,head);
	 }
	 //

 }                                        // the emission of neutron

 void MainSpace::JudgeCollision()
 {
	 Nucleus * ptr=Pointer->boardnode->indicator;
	 double Total_Cross_Section=0;;
	 while(ptr!=NULL)
	 {
		 Total_Cross_Section+=ptr->NReaction_Cross_Section(*Pointer);
		 ptr=ptr->next;
	 }
	 if(Total_Cross_Section)
	 {
	    double mean_free_pass=1/Total_Cross_Section;
	    if (rand()/RAND_MAX<1-exp((-Pointer->free)/mean_free_pass))
		{
		    double k=(double)rand()/RAND_MAX;
		    double possibility=0;
		    Nucleus * p=Pointer->boardnode->indicator;
		    do
			{
			   possibility+=p->NReaction_Cross_Section(*Pointer);
			   if (k<=possibility/Total_Cross_Section) 
			   {
				   Pointer->free=0;
				   Pointer->Collision(*(p));
				   break;
			   }
			   else p=p->next;
			} while (p!=NULL);
		}
	 }
 }


 void MainSpace::JudgeEdge()
 {
	 if (Pointer->PZ>0 && Pointer->PZ<Pointer->boardnode->width) 
	 {}
	 else if (Pointer->PZ<0 && Pointer->boardnode==head->next)
	 {
		 Deleteneutron();
		 LostNumber++;
	 }
	 else if (Pointer->PZ>Pointer->boardnode->width && Pointer->boardnode==end)
	 {
		 Deleteneutron();
		 EscapeNumber++;
	 }
	 else if (Pointer->PZ>Pointer->boardnode->width && Pointer->boardnode!=end)
	 {
		 Pointer->boardnode->AddToBoard(Pointer);
		 Pointer->PZ-=Pointer->boardnode->width;
		 Pointer->boardnode=Pointer->boardnode->next;
	 }
	 else if (Pointer->PZ<Pointer->boardnode->width && Pointer->boardnode!=head)
	 {
		 Pointer->boardnode->AddToBoard(Pointer);
		 Pointer->boardnode=Pointer->boardnode->previous;
		 Pointer->PZ+=Pointer->boardnode->width;
	 }
 }



 void MainSpace::Action(double TimeInterval)
 {
	 Generateneutron(0.3);
	 Pointer=headneutron;
	 while (Pointer!=NULL)
	 {	 
		 JudgeCollision();
		 if (!count)
		 {
			 Pointer->Move(TimeInterval);
		     JudgeEdge();
		 }
		 if (Pointer) Pointer=Pointer->next;
		 count=false;
	 }
	 MainTime+=TimeInterval;
 }


 Unitboard * MainSpace::GetPlace(int i)
 {
	 int number=0;  Unitboard * temp=head;
	 do
	 {
		 if (number==i)	 { return temp;	  break;}
		 else { temp=temp->next;  number++;}
	 }while (temp!=NULL);
	 return NULL;
 }

#endif
 ///////////////////////////////////////////////////////////////////////////////////////////
 ///////////////////////////////////////////////////////////////////////////////////////////
 ///////////////////////////////////////////////////////////////////////////////////////////


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
gogo大胆日本视频一区| 欧美一三区三区四区免费在线看| 日韩免费视频线观看| 色偷偷成人一区二区三区91 | 亚洲免费观看高清完整版在线观看 | 欧美日韩免费一区二区三区| 丁香桃色午夜亚洲一区二区三区| 日韩毛片精品高清免费| 欧美国产丝袜视频| 亚洲激情在线激情| 日韩亚洲国产中文字幕欧美| 精品三级av在线| 久久久噜噜噜久久中文字幕色伊伊| 欧美午夜理伦三级在线观看| 国产mv日韩mv欧美| 一区二区三区欧美| 蜜臀久久久久久久| 韩日av一区二区| 国产乱子轮精品视频| 丁香婷婷综合五月| 欧美精品色综合| 91精品国产综合久久久久| 亚洲欧洲日本在线| 91在线观看免费视频| 欧美偷拍一区二区| 欧美日韩一级视频| 国产精品国产三级国产普通话三级 | 奇米777欧美一区二区| 久久99国产精品麻豆| 色噜噜狠狠成人中文综合| 欧美一级免费大片| 天堂蜜桃91精品| 欧美日韩精品欧美日韩精品一| 九九久久精品视频| 欧美久久一区二区| 国产精品剧情在线亚洲| 在线精品视频小说1| 日韩精品一区二区在线观看| 亚洲国产视频直播| 色妹子一区二区| 国产精品乱码人人做人人爱| 日本一道高清亚洲日美韩| 在线不卡的av| 五月天激情小说综合| 欧美一级高清大全免费观看| 亚洲国产视频a| 这里是久久伊人| 另类小说色综合网站| 欧美成人r级一区二区三区| 丝袜亚洲精品中文字幕一区| 欧美丰满高潮xxxx喷水动漫| 免费成人在线观看| 久久久精品tv| 在线视频国产一区| 久久av中文字幕片| 久久99国产乱子伦精品免费| 久久久久亚洲蜜桃| 国产麻豆91精品| 欧美性受极品xxxx喷水| 亚洲国产综合在线| 久久久99免费| 亚洲欧美一区二区三区极速播放 | 亚洲亚洲精品在线观看| 韩国欧美国产1区| 欧美在线三级电影| 亚洲视频免费看| 风间由美一区二区av101| 6080国产精品一区二区| 国产高清一区日本| 一卡二卡欧美日韩| 2019国产精品| 777亚洲妇女| 在线免费观看成人短视频| 久久99国产乱子伦精品免费| 久久精品久久久精品美女| 国产高清不卡一区| 欧美电影免费观看高清完整版在线| 亚洲欧洲韩国日本视频| 国产在线精品免费| 日韩免费视频一区二区| 国产精品国产三级国产三级人妇 | 亚洲一区视频在线| av毛片久久久久**hd| 久久久精品国产免费观看同学| 青青草91视频| 在线不卡免费av| 青青草成人在线观看| 欧美肥大bbwbbw高潮| 日本欧美一区二区| 欧美一区二区三区免费在线看| 五月婷婷色综合| 91精品免费观看| 国产一区二区三区四区五区美女| 全部av―极品视觉盛宴亚洲| 国产在线精品视频| 成人在线视频一区| 成人av在线电影| 91久久国产综合久久| 亚洲免费资源在线播放| 日韩高清一区在线| 成人妖精视频yjsp地址| 亚洲欧洲一区二区三区| 色综合一个色综合亚洲| 亚洲成人av免费| 2019国产精品| 在线观看视频一区| 日本不卡的三区四区五区| 久久久久久久精| 一本到不卡精品视频在线观看| 亚洲成人动漫精品| 国产视频不卡一区| 在线观看av一区| 国产精品中文字幕欧美| 亚洲女人****多毛耸耸8| 欧美高清性hdvideosex| 国产精品综合二区| 亚洲国产一区二区三区| 久久久91精品国产一区二区三区| 99久久精品国产麻豆演员表| 亚洲成人高清在线| 综合婷婷亚洲小说| 久久中文娱乐网| 91久久国产最好的精华液| 国产真实乱子伦精品视频| 亚洲一区二区三区三| 国产午夜精品美女毛片视频| 欧美视频三区在线播放| 成人国产精品免费观看| 久久成人羞羞网站| 日韩一区精品视频| 亚洲摸摸操操av| 国产精品不卡一区二区三区| 欧美va日韩va| 欧美精品一卡二卡| 91片黄在线观看| 岛国av在线一区| 国产麻豆一精品一av一免费| 毛片不卡一区二区| 日本美女一区二区| 午夜精品久久久久久久| 亚洲午夜电影在线观看| 亚洲欧洲综合另类| 中文字幕一区二区三区不卡| 欧美精品一区二区三区高清aⅴ| 欧美日本在线一区| 欧美在线播放高清精品| 色综合一区二区三区| jlzzjlzz亚洲日本少妇| 成人丝袜高跟foot| 不卡一二三区首页| 黄色成人免费在线| 日韩精品欧美精品| 免费在线观看日韩欧美| 日韩高清在线电影| 免费看欧美美女黄的网站| 丝袜诱惑制服诱惑色一区在线观看| 亚洲毛片av在线| 亚洲成人精品在线观看| 日韩精品一二区| 久久精品国产亚洲5555| 激情综合五月婷婷| 国产一区二区三区精品视频| 久久精品国产亚洲一区二区三区| 老司机精品视频导航| 国产毛片精品国产一区二区三区| 国内不卡的二区三区中文字幕| 国产伦精品一区二区三区视频青涩| 久久99精品国产.久久久久久 | 日本黄色一区二区| 色婷婷激情综合| 555www色欧美视频| 精品国产自在久精品国产| 国产性做久久久久久| 亚洲你懂的在线视频| 亚洲国产精品视频| 美脚の诱脚舐め脚责91| 高清视频一区二区| 欧美自拍丝袜亚洲| 精品国精品自拍自在线| 中文字幕 久热精品 视频在线| 亚洲欧洲综合另类| 六月丁香综合在线视频| 国产99久久久国产精品免费看| 91麻豆精品在线观看| 91麻豆精品国产91| 欧美激情一区二区三区在线| 亚洲一区中文日韩| 经典一区二区三区| 日本韩国欧美一区二区三区| 91精品国产高清一区二区三区蜜臀 | 91在线看国产| 精品视频免费看| 久久综合九色欧美综合狠狠| 亚洲欧美aⅴ...| 九一九一国产精品| 91久久国产综合久久| 国产免费观看久久| 免费在线一区观看| 欧美亚洲尤物久久| 中文字幕av一区二区三区高|