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

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

?? liver_tree_template.cpp

?? vc++為集成開發環境
?? CPP
?? 第 1 頁 / 共 2 頁
字號:

/* -------------------------------------------------------------------------
 * Callback Name: LIVER_TREE_constructor
 * This is a callback function associated with an action taken from a
 * UIStyler object. 
 *
 * Input: dialog_id   -   The dialog id indicate which dialog this callback
 *                        is associated with.  The dialog id is a dynamic,
 *                        unique id and should not be stored.  It is
 *                        strictly for the use in the NX Open API:
 *                               UF_STYLER_ask_value(s) 
 *                               UF_STYLER_set_value   
 *        client_data -   Client data is user defined data associated
 *                        with your dialog.  Client data may be bound
 *                        to your dialog with UF_MB_add_styler_actions
 *                        or UF_STYLER_create_dialog.                 
 *        callback_data - This structure pointer contains information
 *                        specific to the UIStyler Object type that  
 *                        invoked this callback and the callback type.
 * -----------------------------------------------------------------------*/
int LIVER_TREE_constructor ( int dialog_id,
             void * client_data,
             UF_STYLER_item_value_type_p_t callback_data)
{
     /* Make sure User Function is available. */  
     if ( UF_initialize() != 0) 
          return ( UF_UI_CB_CONTINUE_DIALOG );

     /* ---- Enter your callback code here ----- */

     UF_terminate ();

    /* Callback acknowledged, do not terminate dialog */
    return (UF_UI_CB_CONTINUE_DIALOG); 
    /* A return value of UF_UI_CB_EXIT_DIALOG will not be accepted    */
    /* for this callback type.  You must continue dialog construction.*/

}


/* -------------------------------------------------------------------------
 * Callback Name: LIVER_TREE_destructor
 * This is a callback function associated with an action taken from a
 * UIStyler object. 
 *
 * Input: dialog_id   -   The dialog id indicate which dialog this callback
 *                        is associated with.  The dialog id is a dynamic,
 *                        unique id and should not be stored.  It is
 *                        strictly for the use in the NX Open API:
 *                               UF_STYLER_ask_value(s) 
 *                               UF_STYLER_set_value   
 *        client_data -   Client data is user defined data associated
 *                        with your dialog.  Client data may be bound
 *                        to your dialog with UF_MB_add_styler_actions
 *                        or UF_STYLER_create_dialog.                 
 *        callback_data - This structure pointer contains information
 *                        specific to the UIStyler Object type that  
 *                        invoked this callback and the callback type.
 * -----------------------------------------------------------------------*/
int LIVER_TREE_destructor ( int dialog_id,
             void * client_data,
             UF_STYLER_item_value_type_p_t callback_data)
{
     /* Make sure User Function is available. */  
     if ( UF_initialize() != 0) 
          return ( UF_UI_CB_CONTINUE_DIALOG );

     /* ---- Enter your callback code here ----- */

     UF_terminate ();

    /* Callback acknowledged, do not terminate dialog.              */
    /* A return value of UF_UI_CB_EXIT_DIALOG will not be accepted  */
    /* for this callback type.  You must continue dialog destruction*/
    return (UF_UI_CB_CONTINUE_DIALOG); 

}


/* -------------------------------------------------------------------------
 * Callback Name: LIVER_TREE_ok
 * This is a callback function associated with an action taken from a
 * UIStyler object. 
 *
 * Input: dialog_id   -   The dialog id indicate which dialog this callback
 *                        is associated with.  The dialog id is a dynamic,
 *                        unique id and should not be stored.  It is
 *                        strictly for the use in the NX Open API:
 *                               UF_STYLER_ask_value(s) 
 *                               UF_STYLER_set_value   
 *        client_data -   Client data is user defined data associated
 *                        with your dialog.  Client data may be bound
 *                        to your dialog with UF_MB_add_styler_actions
 *                        or UF_STYLER_create_dialog.                 
 *        callback_data - This structure pointer contains information
 *                        specific to the UIStyler Object type that  
 *                        invoked this callback and the callback type.
 * -----------------------------------------------------------------------*/
int LIVER_TREE_ok ( int dialog_id,
             void * client_data,
             UF_STYLER_item_value_type_p_t callback_data)
{
     /* Make sure User Function is available. */  
     if ( UF_initialize() != 0) 
          return ( UF_UI_CB_CONTINUE_DIALOG );

     /* ---- Enter your callback code here ----- */

     UF_terminate ();

    /* Callback acknowledged, terminate dialog             */
    /* It is STRONGLY recommended that you exit your       */
    /* callback with UF_UI_CB_EXIT_DIALOG in a ok callback.*/
    /* return ( UF_UI_CB_EXIT_DIALOG );                    */
    return (UF_UI_CB_EXIT_DIALOG);                           

}


/* -------------------------------------------------------------------------
 * Callback Name: LIVER_TREE_cancel
 * This is a callback function associated with an action taken from a
 * UIStyler object. 
 *
 * Input: dialog_id   -   The dialog id indicate which dialog this callback
 *                        is associated with.  The dialog id is a dynamic,
 *                        unique id and should not be stored.  It is
 *                        strictly for the use in the NX Open API:
 *                               UF_STYLER_ask_value(s) 
 *                               UF_STYLER_set_value   
 *        client_data -   Client data is user defined data associated
 *                        with your dialog.  Client data may be bound
 *                        to your dialog with UF_MB_add_styler_actions
 *                        or UF_STYLER_create_dialog.                 
 *        callback_data - This structure pointer contains information
 *                        specific to the UIStyler Object type that  
 *                        invoked this callback and the callback type.
 * -----------------------------------------------------------------------*/
int LIVER_TREE_cancel ( int dialog_id,
             void * client_data,
             UF_STYLER_item_value_type_p_t callback_data)
{
     /* Make sure User Function is available. */  
     if ( UF_initialize() != 0) 
          return ( UF_UI_CB_CONTINUE_DIALOG );

     /* ---- Enter your callback code here ----- */

     UF_terminate ();

    /* Callback acknowledged, terminate dialog             */
    /* It is STRONGLY recommended that you exit your       */
    /* callback with UF_UI_CB_EXIT_DIALOG in a cancel call */
    /* back rather than UF_UI_CB_CONTINUE_DIALOG.          */
    return ( UF_UI_CB_EXIT_DIALOG );                       

}


/* -------------------------------------------------------------------------
 * Callback Name: LIVER_TREE_FORM_cb
 * This is a callback function associated with an action taken from a
 * UIStyler object. 
 *
 * Input: dialog_id   -   The dialog id indicate which dialog this callback
 *                        is associated with.  The dialog id is a dynamic,
 *                        unique id and should not be stored.  It is
 *                        strictly for the use in the NX Open API:
 *                               UF_STYLER_ask_value(s) 
 *                               UF_STYLER_set_value   
 *        client_data -   Client data is user defined data associated
 *                        with your dialog.  Client data may be bound
 *                        to your dialog with UF_MB_add_styler_actions
 *                        or UF_STYLER_create_dialog.                 
 *        callback_data - This structure pointer contains information
 *                        specific to the UIStyler Object type that  
 *                        invoked this callback and the callback type.
 * -----------------------------------------------------------------------*/
int LIVER_TREE_FORM_cb ( int dialog_id,
             void * client_data,
             UF_STYLER_item_value_type_p_t callback_data)
{
     /* Make sure User Function is available. */  
     if ( UF_initialize() != 0) 
          return ( UF_UI_CB_CONTINUE_DIALOG );

     /* ---- Enter your callback code here ----- */

	float Qperf=0.125,pperf=100,pterm=60;
    float x0=0,y0=0;
    float dthresh=2.5;
    float deltap=pperf-pterm;
	float obfun=0;	//目標函數計算


	struct node
	{
		float x,y;
		node *parent,*left,*right;
		float Resist;
		float r,l;
		int subterm;	
	}; 

	struct node seg[N_MAX],seg_copy[N_MAX];
	int live_branch=0;
	struct node p,q,p_copy,q_copy;//定義兩個結構體,來存儲新生成的兩個枝的數據,因為需對每個已存在連接比較

	for(int m=0;m<N_MAX;m++)//initialization
	{
		seg[m].x=0;
		seg[m].y=0;
		seg[m].parent=NULL;
		seg[m].left=NULL;
		seg[m].right=NULL;
		seg[m].r=0;
		seg[m].l=0;
		seg[m].Resist=0;
		seg[m].subterm=0;
	}


	float x,y,l,Resist,r;
    do
	{ 
	    x=rand()%500/100.;
        y=rand()%500/100.;
        l=sqrt(x*x+y*y);
		Resist=deltap/Qperf;
		r=sqrt(sqrt((l/Resist)*(8*eta/pi)));  		
	}while(l<=2*r||l<=dthresh);

	seg[0].x=x;
	seg[0].y=y;
	seg[0].parent=NULL;
	seg[0].left=NULL;
	seg[0].right=NULL;
	seg[0].r=r;
	seg[0].l=l;
	seg[0].Resist=Resist;
	seg[0].subterm=1;



	for(int i=2;i<M;i++)//生成末端
	{
		for(int k=0;k<N_MAX;k++)//duplicate original data
			seg_copy[k]=seg[k];


		x=rand()%500/100.;//新生成的點坐標
        y=rand()%500/100.;// 
		
		dthresh=dthresh*0.9;//新的門限值
		float T=1000;//假設目標函數值,及連接枝的序號


		for(int j=0;j<2*i-3;j++)//對每個已經存在的節進行連接比較
		{
			if(seg[j].parent==NULL)		//如果要加到第一條邊上;
			{
				q.x=seg[j].x/2;
			    q.y=seg[j].y/2;
			}
			else
			{
				q.x=(seg[j].x+seg[j].parent->x)/2;
				q.y=(seg[j].y+seg[j].parent->y)/2;
			}
			
			l=sqrt((x-q.x)*(x-q.x)+(y-q.y)*(y-q.y));
			p.x=x;
			p.y=y;
			p.l=l;

			seg[j].l=seg[j].l/2;
			seg[j].Resist=seg[j].Resist-8*eta/pi*seg[j].l/seg[j].r/seg[j].r/seg[j].r/seg[j].r;
			
/////////////////////////////////////////////////////////////////////////
			p.subterm = 1;
			p.Resist = seg[j].Resist*seg[j].subterm;
			p.r = pow(8*eta*p.l/(pi*p.Resist),0.25);

			
			if(p.l<2*p.r||p.l<dthresh)
			{
				seg[j] = seg_copy[j];	//如果此邊不符合邊界條件,需要將剛才所做的修改恢復
				continue;				
			}

/////////////此次產生的隨機點符合邊界條件,可以被添加到現有樹中
			live_branch = 1;		


			
			q.l = seg[j].l;
			q.subterm = seg[j].subterm + 1;
			q.r=sqrt(p.r*p.r + seg[j].r*seg[j].r);
			q.Resist=8*eta*q.l/pi/q.r/q.r/q.r/q.r+
				1/(1/p.Resist + 1/seg[j].Resist);

			q.parent=seg[j].parent;
			q.left=&seg[j];
			q.right=&p; 

			p.parent=&q;
			p.left=NULL;
			p.right=NULL;

		    //////將q的父結點的兒子指針指向q
			if(q.parent != NULL)
			{
				if(q.parent->left == &seg[j])
					q.parent->left = &q;
				if(q.parent->right == &seg[j])
					q.parent->right = &q;
			}


			node * temp;//對該節點以上的父枝的半徑改變
			temp=&q;
			
			while(temp->parent != NULL)
			{
				temp= temp->parent;
				temp->r=sqrt(pow(temp->left->r,2)+pow(temp->right->r,2));
			}
		

			for(int t=0;t<2*i-3;t++)
			{
				obfun=obfun+seg[t].l*seg[t].r*seg[t].r;
			}
			obfun=obfun+p.l*p.r*p.r;
			if(T>obfun)
			{
				T=obfun;
				p_copy = p;
				q_copy = q;
			}
			seg[j]=seg_copy[j];
		}

		if(live_branch)
		{
			live_branch = 0;

			//////////////////////////真正添加新邊
			//不只是添加數值,而且要將指針指向正確的位置,此處要注意q的地址單元不在seg[]數組中

			seg[2*i-3]=q_copy;
			seg[2*i-3].left = &seg[j];
			seg[2*i-3].right = &seg[2*i-2];

			struct node * temp = seg[2*i-3].parent;
						
			if(temp != NULL)
			{
				if(temp->parent->left == &seg[j])
					temp->parent->left = &seg[2*i-3];
				if(temp->parent->right == &seg[j])
					temp->parent->right = &seg[2*i-3];
			}

			seg[2*i-2]=p_copy;
			seg[2*i-2].parent=&seg[2*i-3];

		}
		else
			i--;	//為了保證 i 和所添加的末端數一致,即此循環結束后,末端數目為M,否則,可能比M少而且會出現空指針引用
	}

	for(i=0;i<N_MAX;i++)
	{
		double origin[3],direction[3];
		char height[256],diam[256];
		height[0]='\0';
		diam[0]='\0';
		tag_t cyl_tag;
		origin[0]=seg[i].x;
		origin[1]=seg[i].y;
		origin[2]=0;

		direction[0]=seg[i].x-seg[i].parent->x;
		direction[1]=seg[i].y-seg[i].parent->y;
		direction[2]=0;

		height[0]='\0';
					diam[0]='\0';
					sprintf(height,"%f",seg[i].l);
					sprintf(diam,"%f",seg[i].r*2);
		
		UF_MODL_create_cyl1(UF_NULLSIGN,origin,height,diam,direction,&cyl_tag);
	}






     UF_terminate ();

    /* Callback acknowledged, do not terminate dialog */
    return (UF_UI_CB_CONTINUE_DIALOG); 
    
    /* or Callback acknowledged, terminate dialog.    */
    /* return ( UF_UI_CB_EXIT_DIALOG );               */

}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费看视频| 久久精品99国产精品| 国产精品国产三级国产三级人妇 | 欧美色区777第一页| 91看片淫黄大片一级在线观看| 成人动漫一区二区| 99久久久无码国产精品| 欧美亚洲国产bt| 884aa四虎影成人精品一区| 51精品国自产在线| 国产人妖乱国产精品人妖| 国产精品久99| 一区二区三区四区精品在线视频| 亚洲精品欧美专区| 日本特黄久久久高潮| 成人小视频免费观看| 日本高清不卡在线观看| 在线观看成人免费视频| 欧美一区二区精美| 国产精品国产自产拍高清av| 亚洲观看高清完整版在线观看| 免费观看成人av| 精品在线免费观看| 麻豆精品新av中文字幕| 成人精品免费看| 欧美一级在线观看| 天堂在线一区二区| 色综合色狠狠综合色| 中文字幕欧美区| 国产在线视视频有精品| 日韩午夜激情av| 午夜精品一区在线观看| 在线一区二区三区| 亚洲欧洲日本在线| av欧美精品.com| 国产精品你懂的| 国产高清不卡一区二区| 精品国产第一区二区三区观看体验 | 91小宝寻花一区二区三区| 精品国产一区二区亚洲人成毛片| 亚洲自拍都市欧美小说| 欧美日韩一区二区三区视频| 亚洲日本va午夜在线影院| 成人av网站大全| 国产精品二三区| 欧美专区在线观看一区| 久久精品人人爽人人爽| 免费观看在线综合色| 在线观看91精品国产麻豆| 亚洲第一福利一区| 日韩美女在线视频 | 欧美在线观看你懂的| 亚洲成av人综合在线观看| 日韩一区二区中文字幕| 国产高清在线精品| 亚洲成人www| 精品日韩在线观看| 国产乱码精品一区二区三区忘忧草| 久久亚洲二区三区| 在线一区二区三区| 国产精品一区二区视频| 亚洲伦在线观看| 日韩欧美一二三四区| 国产91清纯白嫩初高中在线观看| 亚洲精品亚洲人成人网在线播放| 欧美日韩在线播放一区| 国产91精品在线观看| 亚洲成人免费在线观看| 国产精品美女久久久久久| 欧美肥妇bbw| 一本大道久久a久久综合| 国产精品自拍毛片| 中文字幕中文字幕一区| 欧美午夜片在线观看| 国产成人免费在线观看不卡| 亚洲国产成人av网| 亚洲精品菠萝久久久久久久| 久久精品综合网| 欧美变态tickle挠乳网站| 欧美日韩亚洲国产综合| 一本到一区二区三区| 成人91在线观看| gogo大胆日本视频一区| 成人三级伦理片| 国产福利一区二区三区在线视频| 麻豆一区二区在线| 国产资源在线一区| 国产精品夜夜爽| 国产69精品久久777的优势| 极品少妇xxxx偷拍精品少妇| 男人的天堂亚洲一区| 天天色综合天天| 精品一区二区三区免费| 久久91精品国产91久久小草| 蜜桃一区二区三区在线观看| 狠狠色狠狠色合久久伊人| 国产精品一二三四区| 不卡的av在线播放| 欧美午夜在线观看| 26uuu国产日韩综合| 国产精品第一页第二页第三页| 一区二区三区日韩精品视频| 日韩欧美在线123| 精品国产乱子伦一区| 中国av一区二区三区| 亚洲综合色区另类av| 久久99精品国产91久久来源| 丁香五精品蜜臀久久久久99网站| 91视频观看免费| 久久久91精品国产一区二区精品| 国产精品国产精品国产专区不蜜 | 在线观看一区二区视频| 在线免费视频一区二区| 337p粉嫩大胆色噜噜噜噜亚洲| 国产精品日产欧美久久久久| 婷婷综合在线观看| 99精品国产视频| 欧美经典一区二区| 美女高潮久久久| 色播五月激情综合网| 日本一区二区三区四区| 日本女人一区二区三区| 在线视频一区二区三| 国产精品美女久久久久久2018| 美女网站在线免费欧美精品| 欧美日韩国产影片| 亚洲午夜久久久久久久久电影网| 久久99热狠狠色一区二区| 国产成人在线视频网站| 欧美成人r级一区二区三区| 午夜精品久久久久久久久| 91高清视频在线| 亚洲蜜桃精久久久久久久| 91亚洲精品久久久蜜桃网站 | 麻豆精品一区二区综合av| 欧美日韩mp4| 另类小说色综合网站| 精品久久久久久久久久久久包黑料| 天涯成人国产亚洲精品一区av| 欧美视频日韩视频| 美女网站在线免费欧美精品| 精品国产青草久久久久福利| 韩日精品视频一区| 国产精品美日韩| 日韩一区二区三区电影在线观看| 日韩av在线发布| 久久五月婷婷丁香社区| 成人精品高清在线| 亚洲自拍偷拍欧美| 久久精品欧美一区二区三区不卡| 国产suv一区二区三区88区| 亚洲美女一区二区三区| 日韩一区二区三区在线观看| 国产成人在线观看免费网站| 一区二区三区在线视频免费| 欧美一区二区不卡视频| 成人免费视频caoporn| 日韩不卡一二三区| 亚洲女爱视频在线| 日韩一级完整毛片| 国产在线不卡视频| 免费在线观看日韩欧美| 国产精品初高中害羞小美女文| 日韩视频免费直播| 欧美人妖巨大在线| 色综合久久88色综合天天6| 国产裸体歌舞团一区二区| 午夜精品一区二区三区电影天堂| 国产精品系列在线| 精品电影一区二区三区| 欧美丰满嫩嫩电影| 欧美疯狂做受xxxx富婆| 欧美日韩精品二区第二页| 在线中文字幕不卡| 日本高清视频一区二区| 色婷婷激情一区二区三区| 99视频一区二区三区| 丰满白嫩尤物一区二区| 粉嫩欧美一区二区三区高清影视 | 91.com在线观看| 91精品国产品国语在线不卡| 欧美人狂配大交3d怪物一区| 欧美日韩免费一区二区三区 | 偷窥少妇高潮呻吟av久久免费| 亚洲老司机在线| 五月天激情综合| 久久成人羞羞网站| 成人黄色大片在线观看| 91蝌蚪porny| 欧美va亚洲va香蕉在线| 一区二区中文字幕在线| 久久久欧美精品sm网站| 日本一区二区免费在线观看视频 | 国产经典欧美精品| 99久久精品国产毛片| 欧美日韩中文另类| 日本一区二区免费在线| 午夜精品一区二区三区电影天堂| 久久精品国产成人一区二区三区 | 久久午夜羞羞影院免费观看|