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

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

?? c_demo.c

?? 是用51單片機檢測色度色差的算法和具體實現的代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
{
	X[i] = p->Kr1*Ir + p->Kr2*Ig + p->Kr3*Ib;
	Y[i] = p->Kg1*Ir + p->Kg2*Ig + p->Kg3*Ib;
	Z[i] = p->Kb1*Ir + p->Kb2*Ig + p->Kb3*Ib;	/*計算三刺激值*/
}

void color(float Ir, float Ig, float Ib, uchar i)
{
	float point_x, point_y;
	uchar area = 0;
	mulmatrix(Ir, Ig, Ib, i, K);	/* 區域1 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if (((point_y >= 1.3169*point_x - 0.1056) && (point_x <= 0.3333))
		||((point_y >= 1.9982*point_x - 0.3327) && (point_x > 0.3333)))
	{
		area |= 0x01;
	}
	mulmatrix(Ir, Ig, Ib, i, K+1);	/* 區域2 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if ((point_y >= -0.1667*point_x + 0.3889) && (point_y <= 1.9982*point_x -0.3327))
	{
		area |= 0x02;
	}
	mulmatrix(Ir, Ig, Ib, i, K+2);	/* 區域3 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if (((point_y <= 1.3169*point_x - 0.1056) && (point_x <= 0.3333))
		||((point_y <= -0.1667*point_x + 0.3889) && (point_x > 0.3333)))
	{
		area |= 0x04;
	}
	switch (area)
	{
		case 1:	mulmatrix(Ir, Ig, Ib, i, K);
			point_x = X[i]/(X[i]+Y[i]+Z[i]);
			point_y = Y[i]/(X[i]+Y[i]+Z[i]);
			break;
		case 2:	mulmatrix(Ir, Ig, Ib, i, K+1);
			point_x = X[i]/(X[i]+Y[i]+Z[i]);
			point_y = Y[i]/(X[i]+Y[i]+Z[i]);
			break;
		case 4:	mulmatrix(Ir, Ig, Ib, i, K+2);
			point_x = X[i]/(X[i]+Y[i]+Z[i]);
			point_y = Y[i]/(X[i]+Y[i]+Z[i]);
			break;
		default:
			area = 0;
			break;
	}
	if (area != 0)
	{
		if (((point_x-0.333)*(point_x-0.333)	/* 區域7 */
			+(point_y-0.333)*(point_y-0.333)) < 0.02 )
		{
			mulmatrix(Ir, Ig, Ib, i, K+6);
		}
		return;
	}
	mulmatrix(Ir, Ig, Ib, i, K+3);	/* 區域4 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if (((point_y >= -1.3053*point_x - 0.7683) && (point_x <= 0.3333))
		||((point_y >= -0.1667*point_x + 0.3889) && (point_x > 0.3333)))
	{
		area |= 0x08;
	}
	mulmatrix(Ir, Ig, Ib, i, K+4);	/* 區域5 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if (((point_y <= -1.3053*point_x - 0.7683) && (point_x <= 0.3333))
		||((point_y <= -0.1667*point_x + 0.3889) && (point_x > 0.3333)))
	{
		area |= 0x10;
	}
	switch (area)
	{
		case 8:	mulmatrix(Ir, Ig, Ib, i, K+3);
			point_x = X[i]/(X[i]+Y[i]+Z[i]);
			point_y = Y[i]/(X[i]+Y[i]+Z[i]);
			break;
		case 16:mulmatrix(Ir, Ig, Ib, i, K+4);
			point_x = X[i]/(X[i]+Y[i]+Z[i]);
			point_y = Y[i]/(X[i]+Y[i]+Z[i]);
			break;;
		default:
			area = 0;
			break;
	}
	if (area != 0)
	{
		if (((point_x-0.333)*(point_x-0.333)	/* 區域7 */
			+(point_y-0.333)*(point_y-0.333)) < 0.02 )
		{
			mulmatrix(Ir, Ig, Ib, i, K+6);
		}
		return;
	}
	mulmatrix(Ir, Ig, Ib, i, K+5);	/* 區域6 */
	point_x = X[i]/(X[i]+Y[i]+Z[i]);
	point_y = Y[i]/(X[i]+Y[i]+Z[i]);
	if (((point_x-0.333)*(point_x-0.333)	/* 區域7 */
		+(point_y-0.333)*(point_y-0.333)) < 0.02 )
	{
		mulmatrix(Ir, Ig, Ib, i, K+6);
	}
	return;
}
/***************************************************************************
*	函數原型:uint adconvert(void);
*	函數功能:本函數返回TLC1549的轉換結果。
***************************************************************************/
uint adconvert(void)
{
	uchar i;
	uint adresult;
	ADCS = 1;
	ADCLK = 0;
	ADCS = 0;
	_nop_();
	adresult = (uint)ADOUT;
	for (i=0; i<9; i++)
	{
		ADCLK = 1;
		adresult = _irol_(adresult, 1);
		ADCLK = 0;
		_nop_();
		adresult += (uint)ADOUT;
	}				/*10位數據串行寫入adresult*/
	ADCLK = 1;
	_nop_();
	ADCLK = 0;
	_nop_();
	ADCS = 1;
	wait();
	return adresult;
}
/***************************************************************************
*	函數原型:uint measure(uchar led);
*	函數功能:本函數計算R或G或B發光二極管的光強相對值。
***************************************************************************/
uint measure(uchar led)
{
	uint count;
	uchar i,j;
	dis816(guage, (led-1)*4+2, 4);
	switch(led)		/*選擇相應顏色的LED*/
	{
		case 1:
			for (i=0; i<100; i++)
			{
				for (j=0; j<50; j++)
				{
					LIGHT_R = 1;
					wait();wait();wait();wait();wait();
					LIGHT_R = 0;
					wait();wait();wait();wait();wait();wait();wait();
				}
				if (i == 40)
				{
					dis816(guage, (led-1)*4+3, 4);
				}
				if (i == 75)
				{
					dis816(guage, (led-1)*4+4, 4);
				}
			}
			LIGHT_R = 1;		/*點亮紅燈*/
			break;
		case 2:
			for (i=0; i<100; i++)
			{
				for (j=0; j<50; j++)
				{
					LIGHT_G = 1;
					wait();wait();wait();wait();wait();wait();
					LIGHT_G = 0;
					wait();wait();wait();wait();wait();wait();wait();
				}
				if (i == 40)
				{
					dis816(guage, (led-1)*4+3, 4);
				}
				if (i == 75)
				{
					dis816(guage, (led-1)*4+4, 4);
				}
			}
			LIGHT_G = 1;		/*點亮綠燈*/
			break;
		case 3:
			for(i=0; i<100; i++)
			{
				for(j=0; j<50; j++)
				{
					LIGHT_B = 1;
					wait();wait();wait();wait();wait();
					LIGHT_B = 0;
					wait();wait();wait();wait();wait();wait();wait();
				}
				if (i == 40)
				{
					dis816(guage, (led-1)*4+3, 4);
				}
				if (i == 75)
				{
					dis816(guage, (led-1)*4+4, 4);
				}
			}
			LIGHT_B = 1;		/*點亮藍燈*/
			break;
		default:
			LIGHT_R = 0;
			LIGHT_G = 0;
			LIGHT_B = 0;
			break;
	}
	dis816(guage, (led-1)*4+5, 4);	
	delay(10);
	count = 0;
	for (i=0; i<50; i++)
	{
		count += adconvert();
		wait();
	}
	delay(2);
	LIGHT_R = 0;
	LIGHT_G = 0;
	LIGHT_B = 0;
	return count;
}

/***************************************************************************
*	函數原型:float Eab(void);
*	函數功能:本函數用于計算Lab色差。
***************************************************************************/
float Eab(void)
{
	float E;
	float L[2];
	float a[2];
	float b[2];
	uchar i;
	for(i=0;i<2;i++)
	{
		if(Y[i] > 0.8856)
		{
			L[i] = 116*tqrt(Y[i]/100) - 16;
		}
		else
		{
			L[i] = 9.033*Y[i];
		}
		
		if(X[i] > 0.8856)
		{
			a[i] = 500*(tqrt(X[i]/100) - tqrt(Y[i]/100));
		}
		else
		{
			a[i] = 38.935*(X[i] - Y[i]);
		}
		
		if(Z[i] > 0.8856)
		{
			b[i] = 200*(tqrt(Y[i]/100) - tqrt(Z[i]/100));
		}
		else
		{
			b[i] = 15.574*(Y[i] - Z[i]);
		}
	}
	E = sqrt((L[1]-L[0])*(L[1]-L[0]) + (a[1]-a[0])*(a[1]-a[0]) + (b[1]-b[0])*(b[1]-b[0]));
	return(E);
}

/***************************************************************************
*	函數原型:float Euv();
*	函數功能:本函數用于計算Luv色差。
***************************************************************************/

float Euv(void)
{
	float E;
	float L[2];
	float u[2];
	float v[2];
	uchar i;
	
	for(i=0;i<2;i++)
	{
		if(Y[i] > 0.8856)
		{
			L[i] = 116*tqrt(Y[i]/100) - 16;
		}
		else
		{
			L[i] = 9.033*Y[i];
		}
		u[i] = 13*L[i]*(4*X[i]/(X[i]+15*Y[i]+3*Z[i]) - 0.2105);
		v[i] = 13*L[i]*(9*Y[i]/(X[i]+15*Y[i]+3*Z[i]) - 0.4737);
	}
	E = sqrt((L[1]-L[0])*(L[1]-L[0]) + (u[1]-u[0])*(u[1]-u[0]) + (v[1]-v[0])*(v[1]-v[0]));
	return(E);
}

/***************************************************************************
*	函數原型:float tqrt(float x);
*	函數功能:本函數用于計算x開三次方。
***************************************************************************/
float tqrt(float x)
{
	x = log(x);
	x = x/3;
	x = exp(x);
	return(x);
}

/***************************************************************************
*	函數原型:int wavelength(float x, float y);
*	函數功能:本函數返回待測溶液顏色的主波長。
***************************************************************************/
int wavelength(float x, float y)
{
	long k;		/* 色品點與E點構成直線的斜率 */
	uchar n;
	k = ((y-0.3333)/(x-0.3333))*10000;	/* 擴大10000倍 */
	if(((x-0.333)*(x-0.333)+(y-0.333)*(y-0.333))<0.002)
	{
		return(0);
	}
	if((x<=0.333)&&(k<=20621)&&(k>-10000))
	{
		n = wl_num(0, 25, k);
	}
	else if((x>0.333)&&(k<10000)&&(k>=-1649))
	{
		n = wl_num(40, 64, k);
	}
		else
		{
			k = ((x-0.3333)/(y-0.3333))*10000;
			if((y>=0.333)&&(k<10000)&&(k>=-10000))
			{
				n = wl_num(26, 39, k);
			}
			else
			{
				if (k <= -10000)
				{
					n = wl_num(23, 25, k);
				}
				else
				{
					k = ((y-0.3333)/(x-0.3333))*10000;
					n = wl_num(26, 39, k);
				}
				return(-(380 + n*5));
			}
		}
	return(380 + n*5);
}

/***************************************************************************
*	函數原型:uchar wl_num(uchar n1, uchar n2, long k);
*	函數功能:本函數返回待測溶液顏色的主波長的中間參數。
***************************************************************************/
uchar wl_num(uchar n1, uchar n2, long k)
{
	if(n1 != 26)
	{
		do
		{
			if(k < slope[(n1+n2)/2])
			{
				n1 = (n1+n2)/2;
			}
			else
			{
				if((n1+n2)%2==0)
				{
					n2 = (n1+n2)/2;
				}
				else
				{
					n2 = (n1+n2+1)/2;
				}
			}
		}while(((n2-n1)>1));
	}
	else
	{		
		do
		{
			if(k > slope[(n1+n2)/2])
			{
				n1 = (n1+n2)/2;
			}
			else
			{
				if((n1+n2)%2==0)
				{
					n2 = (n1+n2)/2;
				}
				else
				{
					n2 = (n1+n2+1)/2;
				}
			}
		}while(((n2-n1)>1));		
	}	
	return(n2);
}

/***** 主程序 *****/
void main(void)
{
	uchar i = 0;
	
	init();
	while (1)
	{
		switch (getkey())
		{
			case Up:
				if (i == 0)
				{
					i = 2;
				}
				else if (i == 1)
					{
						i = 0;
					}
					else if (i == 2)
					{
						i = 1;
					}
				dis_arrow(i);
				break;
			case Down:
				if (i == 0)
				{
					i = 1;
				}
				else if (i == 1)
					{
						i = 2;
					}
					else if (i == 2)
					{
						i = 0;
					}
				dis_arrow(i);
				break;
			case Enter:
				if (i == 0)
				{
					MeaC();
				}
				if (i == 1)
				{
					MeaE();
				}
				if (i == 2)
				{
					ChangeTime();
				}
				break;
			case Esc:
				i = 0;
				dis_menu();
				dis_arrow(0);
				break;
			default:
				break;
		}
	}
}


  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产激情一区二区三区四区| 91精品国产综合久久小美女| 亚洲色图另类专区| 欧美人与z0zoxxxx视频| 精品福利在线导航| 久久久久久综合| 日韩午夜激情视频| 国产曰批免费观看久久久| 99久精品国产| 欧美日韩免费一区二区三区视频| 欧美韩日一区二区三区四区| 欧美色图激情小说| 亚洲卡通欧美制服中文| 中文一区一区三区高中清不卡| 午夜激情综合网| 在线视频国内自拍亚洲视频| 一区二区三区**美女毛片| 日本韩国精品在线| 6080国产精品一区二区| 亚洲色图19p| 国产v综合v亚洲欧| 日韩欧美国产午夜精品| 不卡一区二区中文字幕| 国产日韩欧美精品综合| 56国语精品自产拍在线观看| 奇米精品一区二区三区在线观看 | 激情成人综合网| 日韩欧美国产一区二区三区| 精品久久久久久综合日本欧美| 午夜欧美在线一二页| 成人18精品视频| 午夜精品123| 国产宾馆实践打屁股91| 这里只有精品视频在线观看| 欧美日韩国产精品自在自线| 丝袜美腿亚洲一区二区图片| 欧美xxxxx裸体时装秀| 欧美精品自拍偷拍动漫精品| 久久尤物电影视频在线观看| 免费观看一级欧美片| 国产精品嫩草久久久久| 9i看片成人免费高清| 日本人妖一区二区| 欧洲一区在线观看| www.视频一区| 国产成人av电影在线观看| 亚洲视频一区二区在线| 国产精品69久久久久水密桃| 99re亚洲国产精品| 91丨九色丨黑人外教| 亚洲国产综合91精品麻豆| 韩国精品久久久| 国产精品福利一区二区三区| 床上的激情91.| 国产日韩一级二级三级| 亚洲超碰精品一区二区| 日本一区二区成人在线| 国产亚洲精久久久久久| 热久久国产精品| 色哦色哦哦色天天综合| 国产精品一区二区久久精品爱涩 | 亚洲丝袜精品丝袜在线| 91精选在线观看| 欧美精品一区二区三区蜜桃视频| 欧美老女人在线| 粉嫩av亚洲一区二区图片| 欧美一区二区三区视频在线观看| 欧美一区二区三区在线观看视频| 欧美国产在线观看| jiyouzz国产精品久久| 成人av片在线观看| 91精品欧美久久久久久动漫 | 欧美日韩国产影片| 亚洲二区在线观看| 91官网在线免费观看| xfplay精品久久| 老司机午夜精品| 欧美剧情电影在线观看完整版免费励志电影| 中文字幕高清不卡| 777xxx欧美| 亚洲一区二区三区视频在线播放| 奇米色777欧美一区二区| 欧美一区二区三区视频在线| 国产米奇在线777精品观看| 欧美高清在线一区| 欧美一区中文字幕| 国产精品美女久久久久久2018 | 国产精品一级在线| 国产精品久久久久久久浪潮网站| 欧美日韩aaaaa| 亚洲在线视频网站| 中文字幕成人av| 激情六月婷婷综合| 国产91精品在线观看| 亚洲男人都懂的| 亚洲精品一线二线三线| 91老师片黄在线观看| 97se亚洲国产综合在线| 午夜精品久久久久久久| www亚洲一区| 一本色道亚洲精品aⅴ| 五月婷婷综合在线| 日韩一区中文字幕| 亚洲欧洲韩国日本视频| 在线观看亚洲一区| 国产精品123| 日韩国产欧美一区二区三区| 亚洲精品少妇30p| 久久影院午夜论| 久久综合一区二区| 在线区一区二视频| 精油按摩中文字幕久久| 亚洲成年人影院| 亚洲国产综合91精品麻豆| 亚洲少妇30p| 亚洲免费观看视频| 亚洲精品中文在线| 2023国产精品自拍| 国产校园另类小说区| 日韩三级高清在线| 日韩一级片在线播放| 欧美视频一二三区| 精品国产自在久精品国产| 粗大黑人巨茎大战欧美成人| 精品一区二区三区在线观看国产| 美日韩黄色大片| 久久99精品久久久久久国产越南 | 91国产成人在线| 在线一区二区三区四区五区 | 在线观看av一区二区| 亚洲已满18点击进入久久| 亚洲在线免费播放| 精品一二三四区| av一二三不卡影片| 色综合久久久久久久久| 日韩欧美亚洲另类制服综合在线| 成人免费看视频| 粗大黑人巨茎大战欧美成人| 老司机精品视频在线| 国产成人亚洲精品青草天美| 不卡的av电影| 欧美精品久久天天躁| 亚洲制服丝袜av| 极品少妇xxxx精品少妇| 国产成人精品午夜视频免费| 欧美高清hd18日本| 亚洲丝袜美腿综合| 午夜精品影院在线观看| 成人性生交大片免费看中文| 免费人成精品欧美精品| 99国产麻豆精品| 久久精品亚洲精品国产欧美 | 青青草精品视频| 国产一区二区三区香蕉| 欧美一区二区黄色| 中文欧美字幕免费| 久久精品国产99国产精品| 欧美少妇性性性| 中文字幕综合网| 亚洲1区2区3区4区| 色偷偷成人一区二区三区91| 精品国产乱码久久久久久免费| 亚洲超碰精品一区二区| 欧美无人高清视频在线观看| 久久在线观看免费| 秋霞电影网一区二区| 欧美日韩一区二区三区高清 | 欧美日韩国产一级二级| 亚洲精选一二三| 国产成人aaaa| 亚洲午夜羞羞片| 日韩欧美国产综合| 久久狠狠亚洲综合| 久久久久久久电影| 老汉av免费一区二区三区| 欧美一区二区三区思思人| 五月天亚洲精品| 日韩免费视频一区二区| 国产精品一级二级三级| 一区二区三区电影在线播| 欧美精品在线一区二区三区| 午夜欧美大尺度福利影院在线看| 欧美高清你懂得| 91啪亚洲精品| 精品亚洲欧美一区| 国产视频一区二区在线| 91视频.com| 一区二区在线观看视频| 欧美一区二区三区色| 色婷婷av一区| 国产精品影视网| 国产精品亲子伦对白| 91精品国产乱| 经典三级一区二区| 午夜精品久久久久久久久| 精品国产乱码久久久久久牛牛| 在线电影欧美成精品| 99久久精品国产毛片| 日本va欧美va欧美va精品| 亚洲色图都市小说|