- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PIC16F7X正弦程序
//------------------------------------------------------------
// spwm信号调制
//------------------------------------------------------------
#include pic16f7x.h
#includepic.h
//系统配置
__CONFIG(HSPWRTENBORENPROTECTWDTEN);
//打开看门狗,选择高速晶振,上电延时复位,掉电复位使能,代码保护
//------------------------------------------------------------
//指示灯宏定义
#define L1_RED_ON RB1=1;RB2=0;//L1红灯亮
#define L1_OFF RB1=0;RB2=0;
#define L2_RED_ON RB4=1;RB3=0;//L2红灯亮
#define L2_OFF RB4=0;RB3=0;
#define L3_RED_ON RB7=1;RB5=0;//L3红灯亮
#define L3_OFF RB7=0;RB5=0;
#define L1_GREE_ON RB2=1;RB1=0;//L1绿灯亮
#define L2_GREE_ON RB3=1;RB4=0;//L2绿灯亮
#define L3_GREE_ON RB5=1;RB7=0;//L3绿灯亮
//-----------------------------------------------------------
//模拟输入通道宏定义
#define AN0 CHS2=0;CHS1=0;CHS0=0;//ADCON0寄存器定义,选择通道AN0
#define AN1 CHS2=0;CHS1=0;CHS0=1;//ADCON0寄存器定义,选择通道AN1
#define AN2 CHS2=0;CHS1=1;CHS0=0;//ADCON0寄存器定义,选择通道AN2
//-----------------------------------------------------------
//-----------------------------------------------------------
void adc_init()
{
//ADCS1:ADCS0:A/D 转换时钟选择位
//10 Fosc/32 外部晶振32分频
ADCS1=1;//FOSC/32
ADCS0=0;
/*IF CPU IS PIC16F7X7
VCFG1=0;
VCFG0=0;//vref=vdd-vss
*/
//PCFG2:PCFG0: A/D 端口配置控制位
//000 A端口0,1,2,3,5为A/D 模拟输入
PCFG0=0;
PCFG1=0;
PCFG2=0;//VREF=VDD-VSS
ADON=1;//打开ad模块
ADIF=0;//清除ad中断标志
ADIE=0;//打开ad模块中断
}
//-----------------------------------------------------------
void port_init()//端口初始化
{
//端口b设置
/*TRISB0=0;TRISB1=0;TRISB2=0;TRISB3=0;TRISB4=0;TRISB5=0;//RB0||RB5输出
TRISB6=1;//输入
TRISB7=0;//RB7输出*/
TRISB=0x40;//0100 0000 RB6为输入,其他为输出
PORTB=0;//输出0
RBPU=0;//由端口的各个锁存值使能PORTB 上拉
INTE=0;//禁止RB0/INT 外部中断
RBIF=0;//RB7:RB4 引脚的电平状态没有变化(RB端口电平变化中断标志位)
RBIE=1;//允许RB 端口电平变化中断
//端口c设置
TRISC=0X00;//PORTC are outputs
PORTC=0;//输出为0
RC1=RC2=0;
RC3=1;RC4=0;
//timer0 init
T0CS=0;//选择内部指令时钟(可能为外部时钟4分频)
T0IF=0;//TIMER0 溢出标志位清零
//T0IE=1;//在第一次ccp1比较后打开中断使能
//timer1
TMR1CS=0;//使用内部时钟(FOSC/4)
}
//----------------------------------------------------------
//------------------------------------
原创力文档


文档评论(0)