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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? outctrltempthread.cpp

?? 高精度控溫算法,使用PID控制思想
?? CPP
?? 第 1 頁 / 共 2 頁
字號(hào):
    if(TempDeviate<=12*TempDeviateWave && TempDeviate>2*TempDeviateWave)/////80%~45%//80%+20%
    {
        CycleWork=CycleWorkDefault;
        count_i=0;
        if(TempDeviateDifferentialValid>0)
        {
            proportion = I_two*TempDeviate + P_two_positive*TempDeviateDifferentialValid + Cobble_two;
        }
        else
        {
            proportion = I_two*TempDeviate + P_two_negative*TempDeviateDifferentialValid + Cobble_two;
        }
        ///////////////
//        printf("%lf\n",proportion);/////////////////////////////////////////////////////////////////////////////////////////////////////
        //////////////////////////////////////
//        fprintf(fp,"%4d ",count_record);
//        fprintf(fp,"%0 .4f\n",proportion);
        /////////////////////////////////////
        DelayPlanningSign=0;
        ///////////////
        if(proportion>0&& proportion<0.9)
        {
            CycleWorkOccupy=int (proportion*CycleWork*CaiWenJianGe);           if(CycleWorkOccupy==0)        	{        	CycleWork=2;        	}            return;
        }
        if(proportion>0.9 && proportion<=1)
        {
            CycleWorkOccupy=int (0.9*CycleWork*CaiWenJianGe);return;
        }
        if(proportion>1)
        {
            CycleWorkOccupy=int (CycleWork*CaiWenJianGe);return;
        }
        if(proportion<0)
        {
            CycleWorkOccupy=0;CycleWork=2;return;
        }
        ////////////////////
    }
    if(TempDeviate<=2*TempDeviateWave && TempDeviate>revision*TempDeviateWave)//////50%~20%//55%+40%+5%
    {
        CycleWork=CycleWorkDefault;
        count_i=0;
        TempDeviateLast=TempDeviate;
        if(TempDeviateDifferentialValid>0)
        {
            proportion = I_three*TempDeviate + P_three_positive*TempDeviateDifferentialValid
                + D_three*TempDeviateDifferentialVariance + Cobble_three;
        }
        else
        {
            proportion = I_three*TempDeviate + P_three_negative*TempDeviateDifferentialValid
                + D_three*TempDeviateDifferentialVariance + Cobble_three;
        }
 //       printf("%lf\n",proportion);///////////////////////////////////////////////////////////////////////////////////////
        ////////////////////////////////////////
 //       fprintf(fp,"%4d ",count_record);
 //       fprintf(fp,"%0 .4f\n",proportion);
        ///////////////////////////////////////
        DelayPlanningSign=0;
        ///////////////
        if(proportion>0 && proportion<0.7)
        {
            CycleWorkOccupy=int (proportion*CycleWork*CaiWenJianGe);        	if(CycleWorkOccupy==0)        	{        	CycleWork=2;        	}            return;
        }
        if(proportion>0.7 && proportion<=0.8)
        {
            CycleWorkOccupy=int (0.7*CycleWork*CaiWenJianGe);return;
        }
        if(proportion>0.8 && proportion<=0.9)
        {
            CycleWorkOccupy=int (0.8*CycleWork*CaiWenJianGe);return;
        }
        if(proportion>0.9)
        {
            CycleWorkOccupy=int (0.9*CycleWork*CaiWenJianGe);return;
        }
        if(proportion<=0)
        {
            CycleWorkOccupy=0;CycleWork=2;return;/////////////
        }
    }
    if(TempDeviate<=revision*TempDeviateWave && TempDeviate>-revision*TempDeviateWave)//////15%~5%//30%+60%+10%
    {
        count_i=0;
        ///////////////
        if(TempDeviateDifferentialValid>=0)
        {
            proportion = I_four*TempDeviate + P_four_positive*TempDeviateDifferentialValid
                + D_four*TempDeviateDifferentialVariance + Cobble_four;
        }
        else
        {
            proportion = I_four*TempDeviate + P_four_negative*TempDeviateDifferentialValid
                + D_four*TempDeviateDifferentialVariance + Cobble_four;
        }
//        printf("%lf\n",proportion);///////////////////////////////////////////////////////////////////////////////////////////
        ///////////////////////////////////////
//        fprintf(fp,"%4d ",count_record);
//        fprintf(fp,"%0 .4f\n",proportion);
        //////////////////////////////////////
        if(proportion>0.05)
        {
            CycleWorkOccupy=regular;
        }
        else
        {
            CycleWorkOccupy=0;
        }
        ////////////
        if(CycleWorkOccupy==regular)
        {
            CycleWork=CycleWorkChange;
            if(TempDeviateDifferentialValid>=0)
            {
                DelayPlanningSign=1;
            }
            else
            {
                DelayPlanningSign=0;
            }
        }
        else
        {
            CycleWork=2;
            DelayPlanningSign=0;
        }
        ////////////
        if(TempDeviateLast<=2*TempDeviateWave && TempDeviateLast>revision*TempDeviateWave)
        {
            revision=0.4f;
        }
        if(TempDeviateLast<=0.3*TempDeviateWave && TempDeviateLastLast<=0.3*TempDeviateWave &&
            TempDeviateLastLastLast<=0.3*TempDeviateWave)
        {
            revision=0.3f;
        }
        TempDeviateLastLastLast=TempDeviateLastLast;
        TempDeviateLastLast=TempDeviateLast;
        TempDeviateLast=TempDeviate;
        return;
    }
    if(TempDeviate<=-revision*TempDeviateWave)//////////////////////////0%
    {
        count_i=0;
        CycleWorkOccupy=0;
        CycleWork=2;
        TempDeviateLastLastLast=TempDeviateLastLast;
        TempDeviateLastLast=TempDeviateLast;
        TempDeviateLast=TempDeviate;
        return;
    }
}
#define PT_EVT(x) {CKYEVT data(x,0); \(m_calorimeter.GetEventQueue()).Push(data);}void COutCtrlTempThread::CKYSleep( int nSeconds ){	for( int i = 0; i < nSeconds; i ++ )	{		if( m_bExitFlag )		{			//add code here, and run the clear action of exit.			m_calorimeter.OutsideBarrelCycle( false );			m_calorimeter.PotHeatFull( false );					if( m_hInsideTemp != NULL )				fclose( m_hInsideTemp );			if( m_hOutsideTemp != NULL )				fclose( m_hOutsideTemp );						CExperimentData &expData = m_calorimeter.GetExperimentData();			PT_EVT( SUB_CTRL_TEMP_BEGIN );			expData.InvalidateCtrlTempTime();						ExitThread();  //Halt;		}		sleep( 1 );	}}

void COutCtrlTempThread::run( void ){	//m_calorimeter.SwitchOnMixer( true ); //	CExperimentData &expData = m_calorimeter.GetExperimentData();		expData.EnableCtrlTempTime();	PT_EVT( SUB_CTRL_TEMP_BEGIN );		TempAim = expData.GetOutCtrlTemp();	/**/	int mSave = 0;		m_hInsideTemp = fopen( "/usr/sd/insideTemp.txt", "a+" );	m_hOutsideTemp = fopen( "/usr/sd/outsideTemp.txt", "a+" );
	/**/	if( m_hInsideTemp == NULL || m_hOutsideTemp == NULL )	{		printf( "create file insideTemp.txt or outsideTemp.txt fail!\n" );
		CExperimentData &expData = m_calorimeter.GetExperimentData();
		PT_EVT( SUB_CTRL_TEMP_BEGIN );
		expData.InvalidateCtrlTempTime();
		
		ExitThread();  		//return;	}
		//m_calorimeter.OutsideBarrelCycle( true );	sleep(5);		char szBuffer[ 100 ];	float dInsideTemp=0.0, dOutTemp=0.0,TempDe=0.0,TempDelast = 0.0f;	int nCounter = 0,OutLevel=0,InLevel=0;	
	//time_t c_start, c_end;  //
		while( true )	{	/////////////////////////////////////////////////////////////
		//CKYSleep( 1 );		dOutTemp = m_calorimeter.ReadOutsideBarrelTemperature();//		dOutTemp = Temp;
		TempDe = TempAim - dOutTemp;		if( TempDe > 1.2f )		{
			InLevel=0;
			if(OutLevel==0)
			{
				TempDelast=TempDe;
			}
			OutLevel++;
			if(OutLevel>=45)
			{
				OutLevel=0;
				if(TempDelast-TempDe<0.015f)
				{
					//add code here, and run the clear action of exit.
					m_calorimeter.OutsideBarrelCycle( false );
					m_calorimeter.PotHeatFull( false );
		
					if( m_hInsideTemp != NULL )
						fclose( m_hInsideTemp );
					if( m_hOutsideTemp != NULL )
						fclose( m_hOutsideTemp );
			
					CExperimentData &expData = m_calorimeter.GetExperimentData();
					PT_EVT( SUB_CTRL_TEMP_BEGIN );
					expData.InvalidateCtrlTempTime();
			
					//ExitThread();  //Halt;
				}
				TempDelast=TempDe;
			}
			//m_calorimeter.PotHeatFull( true );		}		else		{
			if(TempDe<=1.2 && TempDe>0.6)
			{
				OutLevel=0;
				if(InLevel==0)
				{
					TempDelast=TempDe;
				}
				InLevel++;
				if(InLevel>=90)
				{
					InLevel=0;
					if(TempDelast-TempDe<0.01f)
					{
						//add code here, and run the clear action of exit.
						m_calorimeter.OutsideBarrelCycle( false );
						m_calorimeter.PotHeatFull( false );
		
						if( m_hInsideTemp != NULL )
							fclose( m_hInsideTemp );
						if( m_hOutsideTemp != NULL )
							fclose( m_hOutsideTemp );
			
						CExperimentData &expData = m_calorimeter.GetExperimentData();
						PT_EVT( SUB_CTRL_TEMP_BEGIN );
						expData.InvalidateCtrlTempTime();
			
						//ExitThread();  //Halt;
					}
					TempDelast=TempDe;
				}
			}
			else
			{
				OutLevel=0;
				InLevel=0;
			}
			nCounter ++;			nCounter = Mathematical(nCounter,TempDe,TempAim);
	        if(nCounter < CycleWorkOccupy)
			{
				//m_calorimeter.PotHeatPart( true );
	        }
	        else
	        {
				m_calorimeter.PotHeatPart( false );
	        }		}		///////////////////////////////////////////////////////////		dInsideTemp= m_calorimeter.ReadInsideBarrelTemperature();		if( mSave >= 5 )		{
			mSave = 0;						double dTherTemp = m_calorimeter.ReadThermostatTemperature();			struct tm *newtime; 				time_t long_time; 			time( &long_time );            			newtime = localtime( &long_time ); 					sprintf( szBuffer,  "  %02d:%02d:%02d		%.4f	%.4f	%.4f\r\n", 					 newtime->tm_hour,					 newtime->tm_min,					 newtime->tm_sec, dInsideTemp, dOutTemp, dTherTemp );			fwrite( szBuffer, 1, strlen( szBuffer ),  m_hInsideTemp );					}		mSave++;
		CKYSleep( 1 );
				m_calorimeter.ReadThermostatTemperature();		m_calorimeter.ReadEnviromentTemperature();	}}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久久免费桃花 | 久久午夜老司机| 91丝袜美腿高跟国产极品老师 | 99视频国产精品| 青青草91视频| 亚洲黄色小视频| 久久精品亚洲精品国产欧美| 欧美日本不卡视频| 97久久精品人人做人人爽 | 国产精品亚洲一区二区三区妖精 | 国产亚洲午夜高清国产拍精品 | 粉嫩av一区二区三区粉嫩| 日本视频在线一区| 一区二区欧美国产| 国产精品久久久爽爽爽麻豆色哟哟| 日韩欧美的一区| 欧美色区777第一页| 99久久国产免费看| 成人av电影在线观看| 国产剧情一区在线| 久久精品999| 蜜臀av性久久久久蜜臀aⅴ流畅 | 成人中文字幕电影| 欧美伊人久久久久久久久影院| 成人丝袜18视频在线观看| 久久国产乱子精品免费女| 视频一区二区中文字幕| 一区二区三区日韩在线观看| 日韩理论片中文av| 亚洲欧洲日韩av| 亚洲欧洲三级电影| 中文字幕日韩一区二区| 日韩一区中文字幕| 亚洲美女免费视频| 一区二区三区av电影| 亚洲摸摸操操av| 亚洲国产欧美在线人成| 亚洲小说欧美激情另类| 亚洲成人av一区| 日韩福利电影在线| 乱中年女人伦av一区二区| 免费高清在线一区| 黄色精品一二区| 国产黑丝在线一区二区三区| 国产91丝袜在线播放0| 风间由美一区二区三区在线观看| 成人一级黄色片| 波波电影院一区二区三区| 99久久国产综合精品麻豆| 色婷婷亚洲综合| 欧美日韩中文字幕一区| 欧美高清视频一二三区 | 91在线国内视频| 色94色欧美sute亚洲线路二| 91激情五月电影| 欧美日韩一区久久| 精品日韩一区二区三区免费视频| 欧美mv日韩mv国产网站app| 国产午夜三级一区二区三| 国产精品成人网| 亚洲一区二区在线视频| 婷婷一区二区三区| 国产麻豆成人精品| 91色九色蝌蚪| 91精品欧美福利在线观看| 亚洲精品在线观| 国产在线一区二区综合免费视频| 成人免费av网站| 欧美午夜精品一区| 精品久久久久久无| 亚洲欧美色综合| 日韩精品91亚洲二区在线观看| 另类欧美日韩国产在线| a亚洲天堂av| 3d动漫精品啪啪| 国产欧美日韩久久| 亚洲国产wwwccc36天堂| 国产精品综合在线视频| 色噜噜狠狠色综合欧洲selulu| 日韩欧美中文字幕精品| 国产精品久久久久影院亚瑟| 午夜精品久久久久久久久久| 国产.欧美.日韩| 欧美日韩国产综合一区二区 | 日韩成人精品在线观看| 成人aaaa免费全部观看| 欧美一区二区免费观在线| 国产精品国产三级国产普通话99 | 欧美最新大片在线看| 久久久久久久久久电影| 香蕉加勒比综合久久| 成人黄色大片在线观看| 日韩视频在线永久播放| 成人欧美一区二区三区白人 | 国产精品天天摸av网| 日本亚洲免费观看| 91成人免费电影| 国产精品久久久久久久浪潮网站| 美女网站色91| 欧美日韩激情一区二区三区| 国产喷白浆一区二区三区| 日本免费在线视频不卡一不卡二| 色婷婷国产精品| 日本一区二区成人| 久久99国产精品免费网站| 精品视频在线免费看| 中文字幕一区二区三区在线不卡 | 亚洲综合一二三区| 成人晚上爱看视频| 精品国一区二区三区| 日本亚洲三级在线| 亚洲三级在线看| 国产成人一级电影| 精品国产乱码久久久久久久久 | 91麻豆免费看| 国产精品色一区二区三区| 国产乱子伦一区二区三区国色天香| 欧美日韩在线播放一区| 伊人色综合久久天天| 成人av小说网| 国产精品视频第一区| 国产成人精品一区二| 久久久午夜精品| 国内成人免费视频| 日韩免费观看高清完整版在线观看| 亚洲一区日韩精品中文字幕| 欧美专区日韩专区| 一区二区成人在线视频| 欧洲国内综合视频| 亚洲在线观看免费视频| 一本一本久久a久久精品综合麻豆| 成人欧美一区二区三区在线播放| 99麻豆久久久国产精品免费| 久久精品日产第一区二区三区高清版| 精品午夜久久福利影院| 久久久久久久久久久久电影 | 国产精品电影一区二区| av资源网一区| 亚洲色图制服丝袜| 在线精品观看国产| 水蜜桃久久夜色精品一区的特点| 欧美日韩精品免费| 麻豆精品一二三| 亚洲成年人影院| 91精品国产欧美一区二区| 日本中文一区二区三区| wwwwww.欧美系列| 处破女av一区二区| 一区二区三区国产豹纹内裤在线| 欧美在线观看视频一区二区| 日本欧美久久久久免费播放网| 精品美女一区二区三区| 国产91精品入口| 亚洲美女视频一区| 欧美一区二区在线免费观看| 久久精品国产第一区二区三区| 久久久久久久性| 色综合久久久久久久| 日韩精品一二三区| 2023国产精华国产精品| 91偷拍与自偷拍精品| 日韩二区三区四区| 国产亚洲精品aa| 在线视频国内自拍亚洲视频| 日本欧美肥老太交大片| 日本一区二区不卡视频| 欧美日韩大陆一区二区| 激情丁香综合五月| 一区二区三区产品免费精品久久75 | 一本色道久久综合亚洲91| 视频一区欧美精品| 国产精品天天看| 在线成人高清不卡| 国产福利一区二区三区视频在线| 亚洲老妇xxxxxx| 欧美videos大乳护士334| 99久久久久免费精品国产| 免费久久精品视频| 1024成人网| 久久综合久久综合久久| 一本高清dvd不卡在线观看| 裸体在线国模精品偷拍| 成人欧美一区二区三区视频网页| 欧美一区三区四区| 99久久精品国产麻豆演员表| 另类小说综合欧美亚洲| 亚洲女人小视频在线观看| 日韩女优av电影在线观看| 色综合久久中文字幕综合网| 国产一区二区在线电影| 亚洲高清免费观看| 日韩美女视频一区| 久久精品亚洲乱码伦伦中文| 欧美精品在线一区二区| 91丝袜呻吟高潮美腿白嫩在线观看| 精品一区免费av| 日韩综合在线视频| 一区二区欧美国产| 亚洲国产精品99久久久久久久久| 欧美一级黄色录像|