- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
UPS不間断电源的研究与设计软件程序
PAGE \* MERGEFORMAT
PAGE \* MERGEFORMAT 6
流程图
图1 CCP1中断服务子程序
算法实现程序
//
// SPWM信号调制
//
#include pic16f7x.h
#include pic.h
//系统配置
__CONFIG(HSPWRTENBORENPROTECTWDTEN);
//打开看门狗,选择高速晶振,上电延时复位,掉电复位使能,代码保护
//
//AD1通道转换
void ad_0()
{
AN0; //选择通道0
DELAY(); //延时,采样电容充电
ADGO=1; //开启AD
while(ADGO); //等待AD结束
ad_res_0=ADRES; //结果转存到变量AD_RES_0
}
//AD1通道转换
void ad_1()
{
AN1; DELAY();
ADGO=1;while(ADGO);
ad_res_1=ADRES;
if(ad_res_1132){sin_am-=0.005;if((ad_res_1-132)10)sin_am-=0.04; }
else
if((ad_res_1=132)(ad_res_1=130))sin_am+=0;
else
if(ad_res_1130) {sin_am+=0.005;if((130-ad_res_1) 10)sin_am+=0.04;}
if(sin_am1.6)sin_am=1.6;
}
//AD2通道转换
void ad_2()
{
AN2; DELAY();
ADGO=1;while(ADGO);
ad_res_2=ADRES;
}
const unsigned char
sin_[]={40,50,73,85,100,113,127,141,157,170,180,189,196,200,203,204, //正半周
204,203,200,195,188,179,169,157,144,129,113,96,78,59,39,15 //负半周
};
unsigned char sin_num; //sin函数表查表变量
//
void CCP_start()
{
CCPR2L=0X0; //设置CCP2,0%的脉宽输出
CCPR1L=0X0; //设置CCP1,0%的脉宽输出
TRISC=0X00; //PORTC are outputs
PR2=0Xff; //设置PWM的工作周期,16MHz,PWM周期15.562kHz
CCP1M3=1;CCP1M2=1; //CCP1模块PWM模式
CCP2M3=1;CCP2M2=1; //CCP2模块PWM模式
sin_up=1; //正负半周SIN函数
sin_num=0; //脉宽周期调整计数器
sin_am=0; //sin函数的幅值
sin_am=0.3000; //sin函数的幅值
crut_ie=1; //电流慢保护允许
}
//中断服务程序
void interrupt key_ccp_timer() //定时器1中断服务函数
{
if(TMR2IFTMR2IE){
TMR2IF=0; //定时器2中断服务函数
if(sin_num==31){sin_num=0;sin_up=!sin_up;}
sin_d=sin_[sin_num];
sin_l=sin_am*sin_d;if(sin_l=255)sin_l=255; //限幅
if(sin_up) {CCPR2L=(unsigned char)sin_l;CCPR1L=0;} //换向
else
{CCPR1L=(unsigned char)sin_l;CCPR2L=0;} //换向
sin_num++;
}
CLRWDT(); //清除看门狗
if(RBIFRBIE){RBIF=0;if((!RB6)power_ie)k=1;} //端口b中断服务函数
if(TMR1IFTMR1IE){
TMR1IF=0;tm_sum++;
if(tm_sum==31){
tm_sum=0;tmr_s=!tmr_s;tmr_d=1;
}
}
}
//
//主程序
main()
{
CLRWDT(); //清除看门狗
port_init(); //端口初始化
init_start(); //开机状态
adc_init(); //ad通道初始化
//
RC4=0; //继电器关闭
RC3=1; //关闭脉冲封锁
//
TMR1CS=0; //同步模式
T1SYNC=0; //内部指令周期
TMR1H=0XFD;
TMR1L=0X10; //定时器1初值
TMR1IE=1; //定
文档评论(0)