本文以数字图像处理、压缩技术和MATLAB应用为基础,偏重于MATLAB图像处理的分析和应用。涉及到关于图像处理的图像增强、二值处理、小波分析和图像压缩的基本概念,解决了利用低通、高通滤波,膨胀,腐蚀,平滑,边缘提取和基于DCT变换,小波变换的图像压缩技术的图像处理,制作了一个关于图像处理和图像压缩的系统。
上传时间: 2017-07-08
上传用户:dongqiangqiang
本书共分17章,第一章介绍了图像处理的基本知识,第二章介绍了图像处理编程的基本知识,以后各章分别介绍了区域分割与目标提取、边缘检测与提取、图像平滑、图像增强、特征选择与描述、彩色变换、彩色分割、几何变换、Hough变换、频率变换、小波变换、模式识别、神经网络、遗传算法、图像压缩的基本知识和应用实例,并且都附有相应的C语言图像处理程序。提供有一个Visual C++的学习版框架源程序和专业版演示程序,光盘里还附有专业版图像处理软件介绍和图像处理的工程应用介绍。
标签: 分
上传时间: 2017-08-23
上传用户:脚趾头
图像去噪研究,基于小波变换的图像去噪研究,图像复原是数字图像处理技术的重要研究内容,
标签: 图像去噪
上传时间: 2014-08-08
上传用户:zmy123
一种嵌入可读水印的自适应盲水印算法, 本文提出了一种基于DWT的嵌入可读水印的自适应盲水印算法,通过分析图像经离散小波变换后细 节子带系数的特性,把细节子带系数的均值和方差作为水印信息的一部分来自适应地修改图像小波分解后某些细节 子带的系数值,在满足水印不可感知性的条件下自适应地嵌入水印信息,实现了水印不可感知性和鲁棒性之间的折 衷. 同时,水印的提取无须求助于原图像,很好的实现了水印的盲检测. 这里的水印是一幅有实际意义的二值图像. 实 验结果和攻击测试表明,本文提出的算法对JPEG/ JPEG2000 压缩、添加噪声、剪切、像素移位等多种攻击有较强的鲁棒 性,同时对直方图均衡化、对比度调整和高斯滤波等图像处理操作也具有一定的抵抗能力.
上传时间: 2017-08-30
上传用户:阳光少年2016
本课题研究的主要内容是在空间域直接处理图像的基础上,几种典型的变 换域快速算法分析与研究及这些快速算法的程序设计实现。还研究了图像增强 中的变换域处理方法,主要针对几种典型变换域滤波器及其程序实现;最后对 小波变换的算法分析及在图像压缩中的应用进行了理论研究。
标签: 图像
上传时间: 2013-12-27
上传用户:zhaoq123
/****************temic*********t5557***********************************/ #include <at892051.h> #include <string.h> #include <intrins.h> #include <stdio.h> #define uchar unsigned char #define uint unsigned int #define ulong unsigned long //STC12C2051AD的SFR定义 sfr WDT_CONTR = 0xe1;//stc2051的看门狗?????? /**********全局常量************/ //写卡的命令 #define write_command0 0//写密码 #define write_command1 1//写配置字 #define write_command2 2//密码写数据 #define write_command3 3//唤醒 #define write_command4 4//停止命令 #define TRUE 1 #define FALSE 0 #define OK 0 #define ERROR 255 //读卡的时间参数us #define ts_min 250//270*11.0592/12=249//取近似的整数 #define ts_max 304//330*11.0592/12=304 #define t1_min 73//90*11.0592/12=83:-10调整 #define t1_max 156//180*11.0592/12=166 #define t2_min 184//210*11.0592/12=194 #define t2_max 267//300*11.0592/12=276 //***********不采用中断处理:采用查询的方法读卡时关所有中断****************/ sbit p_U2270B_Standby = P3^5;//p_U2270B_Standby PIN=13 sbit p_U2270B_CFE = P3^3;//p_U2270B_CFE PIN=6 sbit p_U2270B_OutPut = P3^7;//p_U2270B_OutPut PIN=2 sbit wtd_sck = P1^7;//SPI总线 sbit wtd_si = P1^3; sbit wtd_so = P1^2; sbit iic_data = P1^2;//lcd IIC sbit iic_clk = P1^7; sbit led_light = P1^6;//测试绿灯 sbit led_light1 = P1^5;//测试红灯 sbit led_light_ok = P1^1;//读卡成功标志 sbit fengmingqi = P1^5; /***********全局变量************************************/ uchar data Nkey_a[4] = {0xA0, 0xA1, 0xA2, 0xA3};//初始密码 //uchar idata card_snr[4]; //配置字 uchar data bankdata[28] = {1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7}; //存储卡上用户数据(1-7)7*4=28 uchar data cominceptbuff[6] = {1,2,3,4,5,6};//串口接收数组ram uchar command; //第一个命令 uchar command1;// //uint temp; uchar j,i; uchar myaddr = 8; //uchar ywqz_count,time_count; //ywqz jishu: uchar bdata DATA; sbit BIT0 = DATA^0; sbit BIT1 = DATA^1; sbit BIT2 = DATA^2; sbit BIT3 = DATA^3; sbit BIT4 = DATA^4; sbit BIT5 = DATA^5; sbit BIT6 = DATA^6; sbit BIT7 = DATA^7; uchar bdata DATA1; sbit BIT10 = DATA1^0; sbit BIT11 = DATA1^1; sbit BIT12 = DATA1^2; sbit BIT13 = DATA1^3; sbit BIT14 = DATA1^4; sbit BIT15 = DATA1^5; sbit BIT16 = DATA1^6; sbit BIT17 = DATA1^7; bit i_CurrentLevel;//i_CurrentLevel BIT 00H(Saves current level of OutPut pin of U2270B) bit timer1_end; bit read_ok = 0; //缓存定时值,因用同一个定时器 union HLint { uint W; struct { uchar H;uchar L; } B; };//union HLint idata a union HLint data a; //缓存定时值,因用同一个定时器 union HLint0 { uint W; struct { uchar H; uchar L; } B; };//union HLint idata a union HLint0 data b; /**********************函数原型*****************/ //读写操作 void f_readcard(void);//全部读出1~7 AOR唤醒 void f_writecard(uchar x);//根据命令写不同的内容和操作 void f_clearpassword(void);//清除密码 void f_changepassword(void);//修改密码 //功能子函数 void write_password(uchar data *data p);//写初始密码或数据 void write_block(uchar x,uchar data *data p);//不能用通用指针 void write_bit(bit x);//写位 /*子函数区*****************************************************/ void delay_2(uint x) //延时,时间x*10us@12mhz,最小20us@12mhz { x--; x--; while(x) { _nop_(); _nop_(); x--; } _nop_();//WDT_CONTR=0X3C;不能频繁的复位 _nop_(); } ///////////////////////////////////////////////////////////////////// void initial(void) { SCON = 0x50; //串口方式1,允许接收 //SCON =0x50; //01010000B:10位异步收发,波特率可变,SM2=0不用接收到有效停止位才RI=1, //REN=1允许接收 TMOD = 0x21; //定时器1 定时方式2(8位),定时器0 定时方式1(16位) TCON = 0x40; //设定时器1 允许开始计时(IT1=1) TH1 = 0xfD; //FB 18.432MHz 9600 波特率 TL1 = 0xfD; //fd 11.0592 9600 IE = 0X90; //EA=ES=1 TR1 = 1; //启动定时器 WDT_CONTR = 0x3c;//使能看门狗 p_U2270B_Standby = 0;//单电源 PCON = 0x00; IP = 0x10;//uart you xian XXXPS PT1 PX1 PT0 PX0 led_light1 = 1; led_light = 0; p_U2270B_OutPut = 1; } /************************************************/ void f_readcard()//读卡 { EA = 0;//全关,防止影响跳变的定时器计时 WDT_CONTR = 0X3C;//喂狗 p_U2270B_CFE = 1;// delay_2(232); //>2.5ms /* // aor 用唤醒功能来防碰撞 p_U2270B_CFE = 0; delay_2(18);//start gap>150us write_bit(1);//10=操作码读0页 write_bit(0); write_password(&bankdata[24]);//密码block7 p_U2270B_CFE =1 ;// delay_2(516);//编程及确认时间5.6ms */ WDT_CONTR = 0X3C;//喂狗 led_light = 0; b.W = 0; while(!(read_ok == 1)) { //while(p_U2270B_OutPut);//等一个稳定的低电平?超时判断? while(!p_U2270B_OutPut);//等待上升沿的到来同步信号检测1 TR0 = 1; //deng xia jiang while(p_U2270B_OutPut);//等待下降沿 TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1;//定时器晚启动10个周期 //同步头 if((324 < a.W) && (a.W < 353)) ;//检测同步信号1 else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } //等待上升沿 while(!p_U2270B_OutPut); TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1;//b.N1<<=8; if(a.B.L < 195);//0.5p else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } //读0~7块的数据 for(j = 0;j < 28;j++) { //uchar i; for(i = 0;i < 16;i++)//8个位 { //等待下降沿的到来 while(p_U2270B_OutPut); TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1; if(t2_max < a.W/*)&&(a.W < t2_max)*/)//1P { b.W >>= 2;//先左移再赋值 b.B.L += 0xc0; i++; } else if(t1_min < a.B.L/*)&&(a.B.L < t1_max)*/)//0.5p { b.W >>= 1; b.B.L += 0x80; } else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } i++; while(!p_U2270B_OutPut);//上升 TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1; if(t2_min < a.W/*)&&(a.W < t2_max)*/)//1P { b.W >>= 2; i++; } else if(t1_min < a.B.L/*a.W)&&(a.B.L < t1_max)*/)//0.5P //else if(!(a.W==0)) { b.W >>= 1; //temp+=0x00; //led_light1=0;led_light=1;delay_2(40000); } else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } i++; } //取出奇位 DATA = b.B.L; BIT13 = BIT7; BIT12 = BIT5; BIT11 = BIT3; BIT10 = BIT1; DATA = b.B.H; BIT17 = BIT7; BIT16 = BIT5; BIT15 = BIT3; BIT14 = BIT1; bankdata[j] = DATA1; } read_ok = 1;//读卡完成了 read_error: _nop_(); } } /***************************************************/ void f_writecard(uchar x)//写卡 { p_U2270B_CFE = 1; delay_2(232); //>2.5ms //psw=0 standard write if (x == write_command0)//写密码:初始化密码 { uchar i; uchar data *data p; p = cominceptbuff; p_U2270B_CFE = 0; delay_2(31);//start gap>330us write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_bit(0);//写锁定位0 for(i = 0;i < 35;i++) { write_bit(1);//写数据位1 } p_U2270B_CFE = 1; led_light1 = 0; led_light = 1; delay_2(40000);//测试使用 //write_block(cominceptbuff[4],p); p_U2270B_CFE = 1; bankdata[20] = cominceptbuff[0];//密码存入 bankdata[21] = cominceptbuff[1]; bankdata[22] = cominceptbuff[2]; bankdata[23] = cominceptbuff[3]; } else if (x == write_command1)//配置卡参数:初始化 { uchar data *data p; p = cominceptbuff; write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_bit(0);//写锁定位0 write_block(cominceptbuff[4],p); p_U2270B_CFE= 1; } //psw=1 pssword mode else if(x == write_command2) //密码写数据 { uchar data*data p; p = &bankdata[24]; write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_password(p);//发口令 write_bit(0);//写锁定位0 p = cominceptbuff; write_block(cominceptbuff[4],p);//写数据 } else if(x == write_command3)//aor //唤醒 { //cominceptbuff[1]操作码10 X xxxxxB uchar data *data p; p = cominceptbuff; write_bit(1);//10 write_bit(0); write_password(p);//密码 p_U2270B_CFE = 1;//此时数据不停的循环传出 } else //停止操作码 { write_bit(1);//11 write_bit(1); p_U2270B_CFE = 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /************************************/ void f_clearpassword()//清除密码 { uchar data *data p; uchar i,x; p = &bankdata[24];//原密码 p_U2270B_CFE = 0; delay_2(18);//start gap>150us //操作码10:10xxxxxxB write_bit(1); write_bit(0); for(x = 0;x < 4;x++)//发原密码 { DATA = *(p++); for(i = 0;i < 8;i++) { write_bit(BIT0); DATA >>= 1; } } write_bit(0);//锁定位0:0 p = &cominceptbuff[0]; write_block(0x00,p);//写新配置参数:pwd=0 //密码无效:即清除密码 DATA = 0x00;//停止操作码00000000B for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /*********************************/ void f_changepassword()//修改密码 { uchar data *data p; uchar i,x,addr; addr = 0x07;//block7 p = &Nkey_a[0];//原密码 DATA = 0x80;//操作码10:10xxxxxxB for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } for(x = 0;x < 4;x++)//发原密码 { DATA = *(p++); for(i = 0;i < 8;i++) { write_bit(BIT7); DATA >>= 1; } } write_bit(0);//锁定位0:0 p = &cominceptbuff[0]; write_block(0x07,p);//写新密码 p_U2270B_CFE = 1; bankdata[24] = cominceptbuff[0];//密码存入 bankdata[25] = cominceptbuff[1]; bankdata[26] = cominceptbuff[2]; bankdata[27] = cominceptbuff[3]; DATA = 0x00;//停止操作码00000000B for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /***************************子函数***********************************/ void write_bit(bit x)//写一位 { if(x) { p_U2270B_CFE = 1; delay_2(32);//448*11.0592/120=42延时448us p_U2270B_CFE = 0; delay_2(28);//280*11.0592/120=26写1 } else { p_U2270B_CFE = 1; delay_2(92);//192*11.0592/120=18 p_U2270B_CFE = 0; delay_2(28);//280*11.0592/120=26写0 } } /*******************写一个block*******************/ void write_block(uchar addr,uchar data *data p) { uchar i,j; for(i = 0;i < 4;i++)//block0数据 { DATA = *(p++); for(j = 0;j < 8;j++) { write_bit(BIT0); DATA >>= 1; } } DATA = addr <<= 5;//0地址 for(i = 0;i < 3;i++) { write_bit(BIT7); DATA <<= 1; } } /*************************************************/ void write_password(uchar data *data p) { uchar i,j; for(i = 0;i < 4;i++)// { DATA = *(p++); for(j = 0;j < 8;j++) { write_bit(BIT0); DATA >>= 1; } } } /*************************************************/ void main() { initial(); TI = RI = 0; ES = 1; EA = 1; delay_2(28); //f_readcard(); while(1) { f_readcard(); //读卡 f_writecard(command1); //写卡 f_clearpassword(); //清除密码 f_changepassword(); //修改密码 } }
标签: 12345
上传时间: 2017-10-20
上传用户:my_lcs
matlab的小波变换仿真时经常要用到的wavefast源码
上传时间: 2020-03-27
上传用户:穿长筒靴的猫
随着信息技术的发展以及嵌入式、人脸识别、计算机网络等技术的提高,人们正在感受着科技带来的便利和益处。 该系统通过摄像头获取人脸图像,在后台应用系统完成图像识别,然后给单片机发送命令来控制门禁系统。软件上首先利用小波变换对人脸图像进行2次小波分解,然后对低频分量进行离散余弦变换(DCT)提取特征值,最后利用欧氏距离和最近邻分类器进行识别。采用OpenCV人脸识别算法进行处理输出。达到该系统构建简单、方便,识别速度快且准确率较高。 本文主要介绍了基于人脸识别算法的门禁系统的设计与实现。在对人脸识别算法研究的基础上,进一步对整个门禁系统设计与实现进行了详细阐述。主要内容包含以下几点: 1.简单的介绍了课题研究的背景、目的及意义,介绍了人脸识别的背景,阐述了国内外人脸识别的现状以及人脸识别的难点,还介绍了相关的技术。 2.人脸识别算法的研究:主要对Gabor滤波算法、K-L变换算法、Haar特征提取算法这三种特征提取算法进行了详细介绍,也对PCA和LDA这两种人脸识别算法进行了详细的阐述和实验的对比。 3.门禁系统的设计与实现:从需求分析入手对系统的总体模式、总体结果、功能模块、数据库设计等各部分进行了简单的介绍。 4.系统的测试:在对核心算法人脸识别进行了详细的研究以及整个门禁系统的设计和实现结束后,对于整合实现的系统,进行了详细的测试,并给出了功能测试报告和性能测试报告。 本文设计的基于人脸识别的门禁系统,在一定程度上可以较好的识别人脸.
上传时间: 2022-05-28
上传用户:
微弱信号检测的目的是从噪声中提取有用信号,或用一些新技术和新方法来提高检测系统输出信号的信噪比。本文简要分析了常用的微弱信号检测理论,对小波变换的微弱信号检测原理进行了进一步的分析。然后提出了微弱信号检测系统的软硬件设计,在阐述了系统的整体设计的基础上,对电路所选芯片的结构和性能进行了简单的介绍,选用了具有14位分辨率的4路并行A/D转换器AD7865作为模数转换器,且选用Xilinx公司的Spartan-3系列FPGA逻辑器件作为控制器,控制整个系统的各功能模块。同时,利用FPGA设计了先入先出存储器,充分利用系统资源,降低了外围电路的复杂度,为电路调试及制板带来了极大的方便,且提升了系统的采集速度和集成度。系统的软件设计采用Verilog HDL语言编程,在Xilinx ISE软件开发平台上完成编译和综合,并选用ModelSim SE 6.0完成了波形仿真。关键词:微弱信号检测;信号调理:FPGA:AD7865;Verilog HDL信息时代需要获取许多有用的信息,多数科学研究及工程应用技术所需的信息都是通过检测的方法来获取的。若被检测的信号非常微弱,就很容易被噪声湮没,那么很难有效的从噪声中检测出有用信号。微弱信号在绝对意义上是指信号本身非常微弱,而在相对意义上是指信号相对于强背景噪声而言的非常微弱,也就是指信噪比极低。人们进行长期的研究工作来检测被噪声所覆盖的微弱信号,分析噪声产生的原因以及规律,且研究被测信号的特点、相关性以及噪声统计特性,从而研究出从背景噪声中检测有用信号的方法。1微弱信号检测(Weak Signal Detection)技术2.3.41主要是提高信号的信噪比,从噪声中检测出有用的微弱信号。对于这些微弱的被测量(如:微振动、微流量、微压力、微温差、弱光、弱磁、小位移、小电容等),大多数都是利用相应的传感器将微弱信号转换为微弱电流或者低电压,再经过放大器将其幅度放大到预期被测量的大小。
标签: 微弱信号检测
上传时间: 2022-06-18
上传用户:canderile
VIP专区-嵌入式/单片机编程源码精选合集系列(160)资源包含以下内容:1. i2c ipcore of altera fpga that uses ahdl lauguage..2. 嵌入式C编程与Atmel AVR 美 Richard Barnett等著 清华 周俊杰 等译.3. 一个POWERPC的原理图,包括ORCAD格式的原理图等.4. 51s系列单片机入门的最佳编程器制作资料.5. 一个开源的嵌入式flash播放器的源代码.6. 一个用LINUX GTK开发的嵌入式浏览器.7. 用C语言编的带数码管显示的电子琴.8. 希望从事C/C++嵌入式开发的朋友.9. 步进电机的单片机控制.10. 小波变换及滤波 小波变换及滤波.11. 基于单片机实现遥控编码器PT2262的软件解码.12. c_c++嵌入式系统编程.13. spi driver code one marve.14. 正弦波表生成工具.15. 多级抽取程序,适用于软件无线电系统.16. keil和Proteus联调所必须的一个文件.17. 用比较器实现AD转换.18. FLASH读写操作.19. 51单片机的串行通信仿真例子.20. armok01100828.21. 主要介绍了使用MTV230芯片的开发.22. MinGW5 在线安装程序.23. 这是本人调用small rtos51的函数来仿真写的基本代码.24. s3c2440开发板原理图 s3c2440开发板原理图.25. AT89c51单片机下,液晶显示LCD1602的c语言驱动程序,原创代码.26. 这是我的开发板的原理图.27. 51单片机SPI读取SCA100角度值,带温度补偿,精度达到0.008度..28. motorala模式对CPLD的读写和译码.29. 关于nucleus系统的教程文档.30. 单片机 严青新板调试程序 单片机最小系统及流水灯程序 更新时间:2006-12-29 执行结果:在单片机的P1口上的8个发光二极管按流水灯顺序而跑动.31. 實現利用8051單片機透過軟體I2C驅動TSEM0108L感測器之程式庫.32. 20060531am--Windows嵌入式开发系列课程(1):Windows CE系统定制开发入门.33. s3c2410 tesy program.34. s3c2440开发板元件库,希望对初学者有用.35. s3c2440开发板元件库,希望对初学者有用.36. 能够较好地实现大多数车牌的识别.37. 计算机主板pcb文件,可以拿来学习一下..38. wince操作系统下USB设备的驱动程序源码.39. 一本介绍嵌入式OS原理及编程的英文书籍.40. 【cacti】Weathermap使用手册.
上传时间: 2013-04-15
上传用户:eeworm