
这个是求取图像的颜色矩的程序,最终求取的是R、G、B三个分量的一阶矩(均值)、二阶矩(方差)、三阶矩(偏度)作为图像的特征矢量。
img_r=img(:,:,1); 这个是求取原始RGB彩色图像的R分量
u_r=sum(sum(img_r))/sum_pixel; 这个是求取R分量的平均值
theta_r=sqrt(sum(sum((img_r-img_u_r)^2))/sum_pixel); 这个是求取R分量的标准差
s_r=(sum(sum((img_r-img_u_r)^3))/sum_pixel)^(1/3); 这个是求取R分量的三阶矩
#include<reg52h>
//端口定义
sbit RED = P2^0;//红光控制端,0点亮
sbit GREEN = P2^1;//绿光控制端,0点亮
sbit BLUE = P2^2;//蓝光控制端,0点亮
//函数声明
void Delay(unsigned int t);
void RGB(unsigned char R ,unsigned char G ,unsigned char B);
//主函数
void main (void)
{
RED = 1 ; GREEN = 1 ; BLUE = 1 ;
//开始时先关闭LED,当然由于单片机上电就输出 1 ,所以可不写
while (1) //主循环
{
//7色光依次逐渐变亮
//改变调用顺序可以改变颜色先后次序
RGB(1,1,0);
RGB(1,0,1);
RGB(1,0,0);
RGB(0,1,1);
RGB(0,1,0);
RGB(0,0,1);
RGB(0,0,0);
}
}
void Delay(unsigned int t)
{
while(--t);
}
//7色光依次逐渐变亮
RGB(unsigned char R ,unsigned char G ,unsigned char B)
{
unsigned int pwm , set = 500 ;
for(pwm=1;pwm<set;pwm++)
{
RED = 1; //熄灭LED
GREEN = 1;
BLUE = 1;
Delay(set-pwm);//延时长度,500次循环中从599减至1
RED = R;
GREEN = G;
BLUE = B;
Delay(pwm);//延时长度,500次循环中从1加至599
}
}
//改变set可以改变变化快慢
//同理你可以写出7色逐渐变暗的程序
这里的程序只是提供一个思路,你如果直接复制粘贴的话会出现格式错误
把每两行中间的空行删掉一般就可消除格式错误
如果再有什么小问题根据编译信息提示稍作修改就行
串电阻的话一般这样算:
R = [ U - U(LED) ] / I
U是LED和电阻总的电压,U(LED)是LED工作电压,I 是LED工作电流,一般10--20mA
电流大小取的适中就行了,再计算要串联的电阻值
以上就是关于详细讲解下RGB颜色图像检索全部的内容,包括:详细讲解下RGB颜色图像检索、求助,51单片机用PWM的RGB呼吸灯程序怎么写、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)