




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、STC15系列单片机TSL1401线性CCD例程(带 PID 自适应曝光程序)/*/*main.C*/*/*/* Written By LYM-20160729/*Version 1.0 /*/ #include <CCD.h>#include <ADC.h>#include <timer.h>/ 数据变量定义/=extern uint8 Time0flag_10ms;extern uint8 Time0flag_20ms;uint8 Pixel128;/ 具体函数实现/= void main()uint8 i=0,send_data_cnt=0;uint8
2、 *pixel_pt;Timer0_Init();Timer0_Enable();Usart1_Init(115200);Usart1_ENABLE();CCD_GPIO_Init();pixel_pt=Pixel;for(i=0;i<138;i+)*pixel_pt+ =0;while(1)if(Time0flag_20ms=1)Time0flag_20ms=0;CCD_ImageCapture(Pixel);CalculateIntegrationTime();if(+send_data_cnt>=5)send_data_cnt=0;SendImageData(Pixel);L
3、ED1_Flag();/ Show_ADC();/*/*main.C*/*/*/* Written By LYM-20160729/*Version 1.0 /*/ #include <ADC.h>/ 数据变量定义/=uint8 Show30=0;/ 具体函数实现/=void Adc_Init()P1ASF |=0x08;ADC_RES=0;ADC_RESL=0;ADC_CONTR=ADC_POWER|ADC_SPEEDLL;P1M0 &=0x08;P1M1 |=0x08;DelayAdc(2);uint16 GetAdc(uint8 Channel)uint16 adc;
4、ADC_CONTR=ADC_POWER|ADC_SPEEDLL|Channel|ADC_START;_nop_();_nop_();_nop_();_nop_();while(!(ADC_CONTR & ADC_FLAG);ADC_CONTR &=ADC_FLAG;adc=ADC_RES;adc=adc<<2;adc+=ADC_RESL;adc=(adc*0.33);/ 三位的整数,max=3.3Vreturn adc; void Show_ADC()float show;show=GetAdc(3);sprintf(Show,"VCC=%4.1f &qu
5、ot;,show);Usart1_SendString(Show);/*/*CCD.C*/*/*/*/* Written By LYM-20160803/*Version 1.0 /* #include <CCD.h>/ 数据变量定义/=/ 具体函数实现/=void CCD_GPIO_Init()P2M0 &=0x03;/P20 CLK 准双向口P2M1 &=0x03;/P21 SIvoid CCD_StartIntegration()uint8 i;CCD_SI=1;Delaynus(1);CCD_CLK=1;Delaynus(1);CCD_SI=0;Delayn
6、us(1);CCD_CLK=0;for(i=0;i<127;i+)Delaynus(2);CCD_CLK=1;Delaynus(2);CCD_CLK=0;Delaynus(2);CCD_CLK=1;Delaynus(2);CCD_CLK=0;void CCD_ImageCapture(uint8 * ImageData)uint8 i;CCD_SI=1;Delaynus(20);CCD_CLK=1;Delaynus(20);CCD_SI=0;Delaynus(30);for(i = 0; i< 250; i+)/更改250,让CCD的图像看上去比较平滑,Delaynus(1); /
7、200ns/把该值改大或者改小达到自己满意的结果。for(i=0;i<128;i+)Delaynus(30);CCD_CLK=1;Delaynus(30);*ImageData=GetAdc(3)+90;/ 通道 7ImageData+;CCD_CLK=0;Delaynus(30);CCD_CLK=1;Delaynus(30);CCD_CLK=0;uint8 PixelAverage(uint8 len,uint8 *Data)uint8 i;uint16 sum;for(i=0;i<len;i+)sum=sum+*Data+;return (uint8)(sum/len);uin
8、t8 IntegrationTime=10;void CalculateIntegrationTime()extern uint8 Pixel128;/* 128 个像素点的平均AD值*/uint8 PixelAverageValue;/* 128 个像素点的平均电压值的10 倍 */uint8 PixelAverageVoltage;/* 设定目标平均电压值,实际电压的10 倍 */int16 TargetPixelAverageVoltage = 20;/* 设定目标平均电压值与实际值的偏差,实际电压的10 倍 */int16 PixelAverageVoltageError = 0;/*
9、 设定目标平均电压值允许的偏差,实际电压的10 倍 */int16 TargetPixelAverageVoltageAllowError = 2;/* 计算 128 个像素点的平均AD值 */PixelAverageValue = PixelAverage(128,Pixel);/* 计算 128 个像素点的平均电压值, 实际值的10 倍 */PixelAverageVoltage = (uint8)(int16)PixelAverageValue * 25 / 194);PixelAverageVoltageError = TargetPixelAverageVoltage - Pixel
10、AverageVoltage;if(PixelAverageVoltageError< -TargetPixelAverageVoltageAllowError)PixelAverageVoltageError = 0- PixelAverageVoltageError ;PixelAverageVoltageError /= 5;if(PixelAverageVoltageError> 10 )PixelAverageVoltageError = 10 ;IntegrationTime -= PixelAverageVoltageError;if(PixelAverageVolt
11、ageError>TargetPixelAverageVoltageAllowError)PixelAverageVoltageError /= 5;if(PixelAverageVoltageError> 10 )PixelAverageVoltageError = 10 ;IntegrationTime += PixelAverageVoltageError;if(IntegrationTime<= 1)IntegrationTime = 1;if(IntegrationTime>= 100)IntegrationTime = 100;void SendHex(un
12、signed char hex) unsigned char temp;temp = hex >> 4;if(temp < 10) Usart1_SendDataChar(temp + '0'); else Usart1_SendDataChar(temp - 10 + 'A');temp = hex & 0x0F;if(temp < 10) Usart1_SendDataChar(temp + '0'); else Usart1_SendDataChar(temp - 10 + 'A');void SendImageData(unsigned char * ImageData) unsigned char i;unsigned char crc = 0;/* Send Data */Usart1_SendDataChar('*');/向串口 1 发送数据/uart_putchar(UART0,'*');Us
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 食品饮料供应链合作合同
- 医学领域实习经历证明(7篇)
- 货物原材料销售协议
- 合作开展医疗业务活动协议及保密条款
- 加油站股份转让协议
- 农村电商物流合作方案与战略合作协议
- 资产评估与转让协议
- 2025年公文处理考试要点试题及答案
- 收入及奖金证明书金融行业(7篇)
- 突破自我2025年建筑工程试题及答案
- 与合作伙伴的战略合作洽谈纪要
- 课件-DeepSeek从入门到精通
- 2025国家工作人员保密教育线上培训必考题库附含参考答案
- DB11-T 751-2010 住宅物业服务标准
- 智慧矿山无人机自动巡检解决方案
- 人文艺术活动与展览
- 测绘地理信息从业人员保密知识培训
- 《智慧化工园区系统运维管理要求》
- 第3章通风空调工程3.1通风工程3.2空调工程57课件讲解
- 公益事业对外捐赠管理办法
- OEE培训课件教学课件
评论
0/150
提交评论