详细讲解下RGB颜色图像检索

详细讲解下RGB颜色图像检索,第1张

这个是求取图像的颜色矩的程序,最终求取的是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呼吸灯程序怎么写、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/9758274.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存