微型计算机课程设计论文—通用微机发声程序的汇编设计 本文讲述了在微型计算机中利用可编程时间间隔定时器的通用发声程序设计,重点讲述了程序的发声原理,节拍的产生,按节拍改变的动画程序原理,并以设计一个简单的乐曲评分程序为引子,分析程序设计的细节。关键字:微机 8253 通用发声程序 动画技术 直接写屏 1. 可编程时间间隔定时器8253在通用个人计算机中,有一个可编程时间间隔定时器8253,它能够根据程序提供的计数值和工作方式,产生各种形状和各种频率的计数/定时脉冲,提供给系统各个部件使用。本设计是利用计算机控制发声的原理,编写演奏乐曲的程序。 在8253/54定时器内部有3个独立工作的计数器:计数器0,计数器1和计数器2,每个计数器都分配有一个断口地址,分别为40H,41H和42H.8253/54内部还有一个公用的控制寄存器,端地址为43H.端口地址输入到8253/54的CS,AL,A0端,分别对3个计数器和控制器寻址. 对8353/54编程时,先要设定控制字,以选择计数器,确定工作方式和计数值的格式.每计数器由三个引脚与外部联系,见教材第320页图9-1.CLK为时钟输入端,GATE为门控信号输入端,OUT为计数/定时信号输入端.每个计数器中包含一个16位计数寄存器,这个计数器时以倒计数的方式计数的,也就是说,从计数初值逐次减1,直到减为0为止. 8253/54的三个计数器是分别编程的,在对任一个计数器编程时,必须首先讲控制字节写入控制寄存器.控制字的作用是告诉8253/54选择哪个计数器工作,要求输出什么样的脉冲波形.另外,对8253/54的初始化工作还包括,向选定的计数器输入一个计数初值,因为这个计数值可以是8为的,也可以是16为的,而8253/5的数据总线是8位的,所以要用两条输出指令来写入初值.下面给出8253/54初始化程序段的一个例子,将计数器2设定为方式3,(关于计数器的工作方式参阅教材第325—330页)计数初值为65536. MOV AL,10110110B ;选择计数器2,按方式3工作,计数值是二进制格式 OUT 43H,AL ; j将控制字送入控制寄存器 MOV AL,0 ;计数初值为0 OUT 42H,AL ;将计数初值的低字节送入计数器2 OUT 42H,AL ;将计数初值的高字节送入计数器2 在IBM PC中8253/54的三个时钟端CLK0,CLK1和CLK2的输入频率都是1.1931817MHZ. PC机上的大多数I/O都是由主板上的8255(或8255A)可编程序外围接口芯片(PPI)管理的.关于8255A的结构和工作原理及应用举例参阅教材第340—373页.教材第364页的”PC/XT机中的扬声器接口电路”一节介绍了扬声器的驱动原理,并给出了通用发声程序.本设计正是基于这个原理,通过编程,控制加到扬声器上的信号的频率,奏出乐曲的.2.发声程序的设计下面是能产生频率为f的通用发声程序:MOV AL, 10110110B ;8253控制字:通道2,先写低字节,后写高字节 ;方式3,二进制计数OUT 43H, AL ;写入控制字MOV DX, 0012H ;被除数高位MOV AX, 35DEH ;被除数低位 DIV ID ;求计数初值n,结果在AX中OUT 42H, AL ;送出低8位MOV AL, AHOUT 42H,AL ;送出高8位IN AL, 61H ;读入8255A端口B的内容MOV AH, AL ;保护B口的原状态OR AL, 03H ;使B口后两位置1,其余位保留OUT 61H,AL ;接通扬声器,使它发声
上传时间: 2013-10-17
上传用户:sunjet
/****************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
这是一个带有充电管理的无线€€充,适合600mA内的小功率方案,只要接个锂电池就OK 了CPS3039是一种高效、符合QI要求,单片无线电€€源接收和充电管理的产品,。它集成接收模块和线性充电模块,最多支持5W输出 。集成线性充电模块提供最低无线解决方案,节省印刷电路板成本。它是非常适合低功率电池供电应用。CPS3039通过集成低RDS(ON)全桥同步整流电路 ,转换从无线接收线接收到的交流能量信号。CPS3039集成了一个MCU和片上存储器提供用户可编程性,以及高级电源管理电路实现极低备用电源。CPS3039集成了精确的故障保护电路:包括过温、过流、过流电压保护,确保安全运行。一个连接温度传感器和外部NTC接口,集成了温度感测和补偿。CPS3039有QFN 3mmx 4mm封装。该产品的额定值在温度范围0至85摄氏度。
上传时间: 2022-06-04
上传用户:
电动车充电ICNCN5201DX AC-DC采用台湾进口IC,性能稳定,效率更高的NCN5201DX这颗IC,适用于宽泛围应用。LED电源,适配器,电源转换器,电动车充电器…等行业。 功率可达250w 300w 500w 800w 1200w(500-700W 72V10A后续推出),5V50A、12V、24V、48V、60-72V3A。如完全可以满足多种需要。效率可达90以上,让充电器可以省去风扇,外壳设计成防水防虫,适用于户外充电设备充电。适用于蓄电池,铅酸电池,锂电池充电。 ●智能充电管理芯片技术。 ●三段式充电,恒流、恒压、浮充 ●智能控制:适时跟踪充电状态,调节充电参数,保证100%充满电。 ●延长电池使用寿命:有效去除电池极化,控制电池温升,减少失水。 ●均衡充电:均衡电池组电池的电压,使每个电池电压基本保持一致。 ●省电:待机功率低,符合节能标准。 ●短路/过流/过压/过温/反接/过充/欠充/故障保护。 ●我们不只是提供IC,还提供全套全程服务。 如图:客户提供的现有板子 ●只换IC周围是电阻电容,即可实现高性能的品质提升,从原先85%左右的效率升到90%↑左右,(原板85%效率有15w损失转化成发热量/温度高:100w-100w*85%=15w。用NCN5201替换即可减少10w↓的功率,发热量/温度比原板减少近一半以上,温度降低,可去风扇,外壳密封,防水防虫)
上传时间: 2022-07-03
上传用户:
该文主要研究了以TI公司的16位定点TMS320F240型DSP为控制核心的全数字交流变频调速系统硬件、软件的设计理论和设计方法.该系统主要由主电路、系统保护电路、控制回路和采样回路组成.主电路部分包括整流、滤波、逆变器(IPM)、IPM驱动电路等;系统保护电路包括过压欠压保护、限流启动、IPM故障保护、过流保护等;控制回路包括DSP最小系统电路、与PC机通讯接口电路、仿真接口电路、PWM信号发生电路、A/D、D/A转换电路等;采样电路包括电流采样、电压采样、转速采样.在软件方面,考虑到SVPWM相对于SPWM具有较高的直流电压利用率,以及更适合于数字控制系统,该文在研究SVPWM控制原理的基础上,编制了基于SVPWM的开环控制程序.该文最后给出了试验结果,开环运行试验结果表明,该系统可以在0-50Hz范围内平滑调速,在10Hz以上具有较强的带负载能力,以及抗干扰能力.
上传时间: 2013-05-21
上传用户:fyerd
隔离升压DC-DC变换器在电动汽车、储能系统、可再生能源发电以及超导储能系统等领域有广阔的应用前景。本文以隔离升压全桥变换器(Isolated Boost Full Bridge Converter,简称IBFBC)为研究对象,针对隔离升压型变换器的拓扑结构、起动问题、隔离变压器漏感问题、软开关问题和输入电感磁复位问题等进行了系统深入的研究,解决了这一类拓扑所共有技术问题。 提出了隔离升压DC-DC变换器拓扑族,分析比较了各种拓扑的特点,确定了以IBFBC为研究对象。对IBFBC进行了详细的稳态分析和小信号建模分析,为其分析、设计和搭建实验平台提供了电路理论基础。 理论上分析了IBFBC起动时存在电流冲击的原因。提出了二种数字化软起动方案,该方案对主电路进行了改造,利用DSP能灵活产生PWM波的特点采用了新的控制策略,成功实现了该系统的软起动。 理论上分析了IBFBC隔离变压器漏感引起功率开关管关断电压尖峰的原因,采用了有源箝位的方法,有效的解决电压尖峰问题。提出了带有源箝位IBFBC的九种PWM控制策略,提出了一种控制型软PWM方法,在不增加主电路元器件的基础上,通过控制PWM的发生方法,实现了有源箝位功率开关管和桥臂功率开关管的零电压开通。 从理论上分析了IBFBC输入电感磁复位问题。在正常停机时提出了一种数字化软停止的方法,控制变换器由Boost工作状态逐渐过渡到Buck工作状态,让输入电感存储的能量逐渐释放掉,最后停止工作。对于故障保护停机,采用了绕组磁复位的方法,把输入电感设计成反激式变换器形式,突然停机时,电感中存储的能量通过反激式绕组释放到输出端,这样保护了变换器不会损坏。 给出了主电路关键器件参数的设计方法,设计了以DSP-TMS320F2407为核心的数字控制单元,编写了DSP控制程序和CPLD逻辑处理程序。研制了一台输出功率5KW,输入电压直流24V,输出电压直流300V的IBFBC,通过全面的性能实验验证了理论分析和仿真结果。 本文立足于IBFBC的关键技术要求,并充分考虑工程应用中的实际因素,进行了理论分析和实验研究,为实际系统方案设计提供理论依据,并已经在实际应用中得到验证。
上传时间: 2013-04-24
上传用户:lifevast
无功功率是影响电网稳定的一个重要因素,无功补偿是保证电力系统高效可靠运行的有效措施之一,它关系到整个电力系统能否安全稳定的运行。基于国内电力市场的需求现状,考虑到无功补偿的实现条件和经济适应性,研制出了一种基于DSPTMS320LF2407A控制的TSC型低压动态无功补偿装置。 本文主要研究了TSC无功补偿的基本原理,无功补偿的控制方式和原理,MATLAB系统仿真以及控制器的软、硬件的设计。在硬件设计方面,由DSPTMS320LF2407A作为主控制器,能够实现自动采样计算、无功自动调节、故障保护、数据存储等功能,具有比传统的单片机控制运算速度高,实时性好的特点。采用晶闸管控制投切电容器,完全实现了电容器的快速,无弧,无冲击投切,具有优良的性能。在软件上,采用C语言和汇编语言混合编程。在投切原则上,与常见的功率因数控制方案相比较,采用无功功率和功率因数相结合控制方式,避免了轻载投切振荡,使无功调节更为合理。 为了实现装置应具有的功能,本文设计并制作了较为完整的控制电路及其外围设备的硬件电路。文中设计编写了整个控制系统的控制程序,给出了控制软件的结构框图。结果表明本装置软硬件设计合理,控制方法可行,系统运行可靠,达到了预期的目的。
上传时间: 2013-07-05
上传用户:fff4444
在能源枯竭环境污染日益严重的今天,光伏发电结合其自身的特点,日益得到各国的重视并将成为各国竞向发展的热点。而光伏并网发电又是光伏利用中的发展趋势,基于此,本文对单相并网发电系统进行了研究,并设计了一台1.5KW的单相光伏并网装置。在对主电路拓扑、MPPT、防孤岛效应、逆变并网控制方法详细分析的基础上,选用了一种双重BOOST前级电压匹配、后级全桥逆变的非隔离型的主电路拓扑结构,这种结构具有前级DC/DC变换控制简单、中间直流母线电压波动小、效率高、体积小等优点。MPPT采用后级实现方式;防孤岛效应采用有被动和主动两种方式;逆变并网控制是光伏并网发电系统中最为重要的环节,其功能作用是把前级的直流电转化为与电网电压同频同相的交流电与电网并联,并使其输出电流为单位功率因数、总谐波畸变率小于5%,本文对各种逆变并网控制策略分析比较的基础上,采用了带有电网电压前馈补偿的瞬时电流控制方式来实现。系统整体以UC3875和TMS320LF2812为控制核心,前级有UC3875进行双环控制直流母线电压,后级最大功率跟踪、防孤岛效应、逆变并网、并联通讯及故障保护有TMS320LF2812来实现。本文总体工作包括详细的理论分析、主电路设计、软件及硬件电路的设计、调试及实验波形分析等。
上传时间: 2013-04-24
上传用户:924484786
在电力系统中,无功功率是影响电网稳定的一个重要因素,它关系到整个电力系统能否安全稳定的运行,无功补偿是保证电力系统高效可靠运行的有效措施之一。基于国内电力市场的需求现状,考虑到无功补偿的实现条件和经济适应性,研制出了一种基于DSP TMS320LF2407A控制的TSC型低压动态无功补偿装置。该装置以实时的电网监测数据为依据,以低压网的最佳无功补偿为对象。 本文主要研究了TSC无功补偿的基本原理,无功补偿的控制方式和原理,以及控制器的软、硬件的设计。在硬件设计方面,由DSP TMS320LF2407A作为主控制器,能够实现自动采样计算、无功自动调节、故障保护、数据存储等功能,具有比传统的单片机控制运算速度高,实时性好的特点。采用晶闸管控制投切电容器,完全实现了电容器的快速,无弧,无冲击投切,具有优良的性能。在软件上,采用C语言和汇编语言混合编程,遵循模块化设计原则,提高了系统的通用性和维护的简易程度。在投切原则上,与常见的功率因数控制方案相比较,采用电压无功复合控制,避免了轻载投切振荡,使无功调节更为合理。为了实现装置应具有的功能,本文设计并制作了较为完整的控制电路及其外围设备的硬件电路。它们包括触发电路、采样电路及通讯电路等。文中设计编写了整个控制系统的控制程序,给出了控制软件的结构框图。在本文中,还设计了电容器保护电路,以及装置在电网谐波含量超标时采取的保护措施。实验结果表明,本装置软硬件设计合理,控制方法可行,系统运行可靠,达到了预期的目的。
上传时间: 2013-04-24
上传用户:zaizaibang
断路器是电力系统中重要的控制和保护设备,对维护电力系统的安全、稳定和可靠运行起着重要的作用。如何使断路器高度智能化,并且更安全和可靠,是电力系统保护的发展要求,也是本论文研究的目的。 本文在深入研究了智能断路器国内外发展状况的基础上,精心设计了以数字信号处理器DSP和复杂可编程逻辑器件CPLD为核心的系统硬件。DSP是智能断路器测控单元的核心器件,它实现断路器的各种保护、报警、显示与控制功能。CPLD完成状态量的监测,以及各种逻辑信号的输出。两种器件相互配合使得断路器系统更加智能化。研究了断路器测控单元的测量原理及保护算法,并进行了具体的硬件和软件模块的设计,旨在实现断路器的智能保护、远程控制和集中管理。本设计以TI公司的DSP芯片TMS320LF2407为核心。硬件设计主要包括信号调理模块设计、信号采样模块设计、保护执行模块设计、CPLD模块设计和输入输出模块设计。并且利用TMS320LF2407本身具有的CAN2.0模块,通过CAN总线实现断路器和上位机的通信,实现遥测、遥调、遥控、遥信等“四遥”功能。软件采用模块化设计,每一个模块相对独立,完成某个特定功能,便于维护和添加新功能,并且调试灵活方便。文中给出了主程序及各个子程序的流程图,其中子程序有数据采集子程序、FFT计算子程序、液晶显示子程序、短路瞬时保护子程序、过载长延时保护子程序、接地故障保护子程序和短路短延时保护子程序等。并且设计中充分考虑了断路器工作环境的恶劣性,分析了各种干扰的来源,并针对各种干扰采取了对应的软件和硬件的抗干扰措施。最后,为了验证全波傅氏算法能否满足电网数据处理精度的要求,利用MATLAB搭建仿真平台,对其进行了仿真。结果表明全波傅氏算法能达到系统的要求。
上传时间: 2013-04-24
上传用户:BK094