• Multi-focus image fusion with dense SIFT.pdf

    多聚焦图像融合技术是获得全目标聚焦合成图像的重要方法。多聚焦图像融合的关键是建立一种有效的活动水平测量方法来评价源图像的清晰度。本文提出了一种基于密集尺度不变特征变换(SIFT)的多聚焦图像融合方法。本文的主要新颖之处在于它显示了图像局部特征的巨大潜力,如被用于图像融合的密度筛选。特别地,局部特征描述不仅可以作为活动水平的测量,而且可以用来匹配多个源图像之间错误注册的像素,以提高融合图像的质量。在我们的算法中,通过滑动窗口技术,首先利用密度筛选描述来度量源图像块的活动水平,得到初始的决策图,然后通过特征匹配和局部焦点度量比较来细化决策图。实验结果表明,该方法在主观视觉感知和客观评价两方面都能与目前最先进的融合方法相媲美,甚至优于后者。

    0
    249
    9.99MB
    2019-10-22
    20
  • 基于单片机的温度监测仿真

    基于单片机的温度监测仿真#include <reg52.h> /////////////头文件 //////////////////////////////////////////////////////////////////////////// void LcdShowStr(unsigned char x, unsigned char y, unsigned char *str); void ConfigTimer0(unsigned int ms); unsigned char IntToString(unsigned char *str, int dat); extern bit Start18B20(); extern bit Get18B20Temp(int *temp); extern void InitLcd1602(); bit DHT_Start(); void aj (void); bit DHT_ByteRead(unsigned char *dat); ///////////////////////////////////////////////////////////////////// sbit K1=P1^4; ///引脚声明 sbit K2=P1^5; sbit K3=P1^6; sbit K4=P1^7; sbit M1=P1^0; sbit M2=P1^1; sbit M3=P1^2; sbit M4=P1^3; sbit D1=P2^7; sbit D2=P2^6; sbit KD1=P2^3; sbit KD2=P2^4; ///////////////// ///////////////////////////// 数组命名 int SD,WD,x,xx,SDC,WDC,PWM1,PWM2; int KK1,KK2; int wdg=40,wdd=20,sdg=80,sdd=60; bit SZ,JB; bit flag1s = 0; //1s定时标志 unsigned char T0RH = 0; //T0重载值的高字节 unsigned char T0RL = 0; //T0重载值的低字节 ///////////////////////////////// 延时子程序 void delay () { x=99999; while(x--); } ///////////////////////////////// void main() ////////////////主程序 { bit tmp; unsigned char str[12]; unsigned char DHT[5]; ////初始化/////////////////////// EA = 1; //开总中断 ConfigTimer0(10); //T0定时10ms InitLcd1602(); //初始化液晶 M1=0; M1=0;M2=0;M3=0;D1=0;D2=0; //////////////////////////////////// DHT_Start(); delay(); delay(); delay(); delay(); while (1) { LcdShowStr(0, 0, "WD"); //显示到液晶屏上 LcdShowStr(0, 1, "SD"); //显示到液晶屏上 LcdShowStr(5, 0, "H"); //显示到液晶屏上 LcdShowStr(5, 1, "H"); //显示到液晶屏上 LcdShowStr(9, 0, "L"); //显示到液晶屏上 LcdShowStr(9, 1, "L"); //显示到液晶屏上 if (flag1s) //每秒更新一次温度 { str[0] = (wdg/10) + '0'; //十位转为ASCII码 str[1] = (wdg) + '0'; //个位转为ASCII str[2] = '\0'; LcdShowStr(6, 0, str); str[0] = (wdd/10) + '0'; //十位转为ASCII码 str[1] = (wdd) + '0'; //个位转为ASCII str[2] = '\0'; LcdShowStr(10,0, str); str[0] = (sdg/10) + '0'; //十位转为ASCII码 str[1] = (sdg) + '0'; //个位转为ASCII str[2] = '\0'; LcdShowStr(6, 1, str); str[0] = (sdd/10) + '0'; //十位转为ASCII码 str[1] = (sdd) + '0'; //个位转为ASCII str[2] = '\0'; LcdShowStr(10, 1, str); DHT_Start(); tmp=DHT_ByteRead(&DHT;); if(tmp==1) { str[0] = (DHT[0]/10) + '0'; //十位转为ASCII码 str[1] = (DHT[0]) + '0'; //个位转为ASCII LcdShowStr(2, 1, str); str[0] = (DHT[2]/10) + '0'; //十位转为ASCII码 str[1] = (DHT[2]) + '0'; //个位转为ASCII str[2] = '\0'; LcdShowStr(2,0, str); WD= DHT[2]; SD=DHT[0]; } } ////////////////////超热警报 if(wdg<=WD) { WDC=WD-wdg+2; M1=1; } else M1=0; if(wdd>=WD) { WDC=wdd-WD+2; M2=1; } else M2=0; if(sdg<=SD) { SDC=SD-sdg+2; M3=1; } else M3=0; if(sdd>=SD) { SDC=sdd-SD+2; M4=1; } else M4=0; if(wdg<=WD||wdd>=WD) { PWM1++; if(PWM1<WDC) D1=1; if(PWM1>=WDC) D1=0; if(PWM1==10) PWM1=0; } if(wdg>WD&&wdd;<WD&&KK1;==0) D1=0; if(sdg<=SD||sdd>=SD) { PWM2++; if(PWM2<SDC) D2=1; if(PWM2>=SDC) D2=0; if(PWM2==10) PWM2=0; } if(sdg>SD&&sdd;<SD&&KK2;==0) D2=0; /////////////////////////////按键设置 aj(); ////////////////////////////////////////////// } } void aj (void) { if(KD1==0) { delay(); KK1++; if(KK1==1) D1=1; if(KK1>=2) { D1=0; KK1=0; } } if(KD2==0) { delay(); KK2++; if(KK2==1) D2=1; if(KK2>=2) { D2=0; KK2=0; } } if(K1==0) { xx++; delay(); if(xx==1) LcdShowStr(12, 0, "WDH"); //显示到液晶屏上 if(xx==2) LcdShowStr(12, 0, "WDL"); //显示到液晶屏上 if(xx==3) LcdShowStr(12, 0, "SDH"); //显示到液晶屏上 if(xx==4) LcdShowStr(12, 0, "SDL"); //显示到液晶屏上 if(xx>=5) xx=0; } if(K2==0) { if(xx==1) { LcdShowStr(12, 1, "WD+"); //显示到液晶屏上 wdg++; } if(xx==2) { LcdShowStr(12, 1, "WD+"); //显示到液晶屏上 wdd++; } if(xx==3) { LcdShowStr(12, 1, "SD+"); //显示到液晶屏上 sdg++; } if(xx==4) { LcdShowStr(12, 1, "SD+"); //显示到液晶屏上 sdd++; } delay(); } if(K3==0) { if(xx==1) { LcdShowStr(12, 1, "WD-"); //显示到液晶屏上 wdg--; } if(xx==2) { LcdShowStr(12, 1, "WD-"); //显示到液晶屏上 wdd--; } if(xx==3) { LcdShowStr(12, 1, "SD-"); //显示到液晶屏上 sdg--; } if(xx==4) { LcdShowStr(12, 1, "SD-"); //显示到液晶屏上 sdd--; } delay(); } if(K4==0) { delay(); xx=0; InitLcd1602(); //初始化液晶 } } /* 整型数转换为字符串,str-字符串指针,dat-待转换数,返回值-字符串长度 */ unsigned char IntToString(unsigned char *str, int dat) { signed char i = 0; unsigned char len = 0; unsigned char buf[6]; if (dat < 0) //如果为负数,首先取绝对值,并在指针上添加负号 { dat = -dat; *str++ = '-'; len++; } do { //先转换为低位在前的十进制数组 buf[i++] = dat % 10; dat /= 10; } while (dat > 0); len += i; //i最后的值就是有效字符的个数 while (i-- > 0) //将数组值转换为ASCII码反向拷贝到接收指针上 { *str++ = buf[i] + '0'; } *str = '\0'; //添加字符串结束符 …………………… …………限于本文篇幅 余下代码请从51黑下载附件…………

    0
    160
    56KB
    2019-03-31
    30
上传资源赚积分or赚钱