一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

手机号码,快捷登录

手机号码,快捷登录

搜索
查看: 9135|回复: 0

基于FPGA的自治型SPWM波形发生器的设计

[复制链接]
发表于 2008-12-5 16:43 | 显示全部楼层 |阅读模式
摘  要:本文针对静止补偿器(STATCOM)对触发脉冲信号的要求,设计了一种基于FPGA的正弦脉宽调制(SPWM)波形发生器。通过正弦调制波与三角载波的比较,产生了六路PWM脉冲信号。正弦调制波的产生采用查表法,但仅将1/4周期的正弦波数据存入FPGA内部硬件所构造的ROM中,减少了系统的硬件开销,仿真结果证明了本设计的正确性。
7 h$ V9 O# p$ V) B: K' m& B: o
6 P' {9 \0 L  O5 h/ S0 V引言
) g, u6 a' y/ `3 E, Q. p7 v    正弦脉宽调制(SPWM)技术在以电压源逆变电路为核心的电力电子装置中有着广泛的应用,如何产生SPWM脉冲序列及其实现手段是PWM技术的关键。利用模拟比较法,对三角载波与正弦调制波进行比较,即可产生SPWM脉冲;利用数字算法和定时逻辑,也可产生SPWM脉冲[5]。目前已有多种微处理器芯片(如 80C196MC、TMS320F240等)本身集成有数字化PWM发生电路[3]。模拟方法简单直观,但与数字控制器接口不便,难以满足复杂要求;数字方法结构灵活,尤其是微处理器内置了PWM发生器的,使用更加方便。通常状况下,微处理器通过定时中断服务程序产生SPWM脉冲,在每个载波周期必须进行中断处理,对处理速度要求较高,从而也限制了载波频率进一步的提高,同时微处理器的处理任务也更加繁重。文献[1]指出,微处理器中不确定的中断响应会导致PWM脉冲的相位抖动。
. }+ b# l& q2 {3 m    FPGA以其可*性高、功耗低、保密性强等特点,在电子产品设计中得到广泛的应用。文献[1]~[5]也论述了FPGA或CPLD在PWM脉冲产生时刻的计算仍由微处理器来完成,实际上微处理器的任务仍然繁重。作者针对静止补偿器(STATCOM)对SPWM脉冲发生器的特定要求,采用Altera公司的 FLEX10K10芯片开发了一种专用SPWM波形发生器,微处理器只需在必要时改变逆变器PWM调制深度即可,其余工作全由FPGA完成,从而大大减轻了CPU的负担。
$ w/ Y' k$ P$ ~1 n5 [- |+ Q% cSPWM发生原理/ j' t6 I( ]* y' X9 w
    针对静止补偿器的电路结构,要求SPWM发生器可以发出三相六路PWM脉冲信号,脉冲宽度应根据微处理器输出的调制深度来调节。SPWM脉冲产生方法采用三角载波与正弦调制波比较的传统方法,但是三角载波、正弦调制波和比较逻辑等均采用基于FPGA的数字化方法来实现。该SPWM发生器的内部逻辑结构。总线接口逻辑单元首先接收来自微处理器的调制深度信号并锁存,正弦调制波产生电路在同步信号作用下从正弦函数表读取标准正弦信号幅值,与调制深度相乘,得出正弦调制信号幅值。三角载波发生电路在同步信号作用下,通过可逆计数器,发出三角载波幅值。正弦调制波幅值与三角载波幅值进行比较,就可以产生出SPWM脉冲信号。2 j$ v" Z) W; k0 F# [& R' v
逻辑设计8 [/ o0 J/ {: G" u
    SPWM脉冲发生器由微处理器总线接口电路、三角载波产生电路、正弦调制波产生电路、正弦函数表和比较控制电路等逻辑功能模块组成。
' r  u8 k' {. F' Y: ?3 l总线接口单元& Q7 a: p  u- _. R$ S* w: w
    总线接口电路如图2所示的微处理器接口电路部分。其中D0~D7为数据总线,芯片选择信号为CS,写信号为WR,总线地址选择信号为A0~A2。微处理器接口电路主要用于FPGA芯片接收来自微处理器的调制深度信号 。+ o4 s- q: j- p$ \
三角载波发生器9 g4 A! ~3 K, m/ G
    利用可逆计数器对系统时钟进行计数。计数器先执行加法,从0计数到255,再执行减法计数从255到0,从而实现三角载波。三角载波的峰峰值为255。
4 g" K; q$ D/ w5 N正弦调制波发生器
4 M; g1 s& \! \    FPGA芯片只能综合一些简单的加、减、乘、除等算术逻辑,要其实现正弦函数的计算非常不经济,正弦调制波的产生通过查正弦函数表来完成。在FPGA芯片内部开辟一块ROM区域,将离散时间正弦波幅值存入其中。在需要时,按照相位与地址一一对应的关系从表中依次读出即可。
7 H. X8 ^# {: C% x* ^" w( P7 [. C; B    由于FPGA芯片的硬件资源有限,如何有效的利用资源成为非常关键的一点。考虑到正弦的周期性与对称性,因此在ROM表中只需存正弦函数\frac{ }{2}周期的波形数据即可。在本设计中,一个正弦波周期内共采样2048个点,相位分辩率为0.176 ,而实际在ROM表中只需存512个采样点,这样大大减少了芯片硬件资源的消耗。/ h8 L0 ?5 v( P# I$ B% c
正弦调制波幅值的调节
4 ]/ z8 V. u- m3 D2 j4 ]    PWM脉冲发生器必须根据正弦调制波幅值的大小来调整PWM脉冲的宽度。在本设计中,由于三角载波峰值固定,正弦调制波幅值仅由调制深度决定。FPGA芯片通过总线接口从微处理器接收到调制深度信号,再利用乘法器对从正弦函数表中取出的正弦幅值进行调制深度加权调整。设调制深度为,当前时刻正弦幅值为Sin_Data,利用下式得出正弦调制波幅值Data为:
0 l7 P  G% i% d% f  Q    Data=( *Sin_Data)/255 取值范围[0~1]
/ \7 T$ z4 l4 o% u2 {, z/ q    本设计采用双极性调制方式,而三角载波的取值范围为0~255,其中位线值为127,故实际产生的正弦调制波幅值按照下列公式进行调整,其中Adjust为调整后的正弦调制波数据。7 Z/ ^5 \$ c  ~
    Adjust =127+Data { 2 k < Data<(2k+1) } k=0.1.2......N* G: L  T: t' A' U% ]
    Adjust =127-Data {(2k+1) <Data<(2k+2) } k=0.1.2......N
7 R8 o4 ]- w+ s" y, r4 d三相正弦信号的产生
. d; p0 Y8 u% M! F+ @# _. o    针对静止补偿器主电路,需要产生出三个相位彼此互差120 的SPWM脉冲信号。而通过一个正弦函数表来发出三相正弦信号,不仅需要考虑三个正弦信号的起始相位,而且需要三个可逆计数器分别来控制查找正弦函数表。例如,在本设计中产生三个初相位为零,相位互差120 的三相正弦信号。如图3所示,A相首先从正弦函数表的地址0 开始累加读起,当读到地址90 处,再从地址90 处累减读到地址0 处,这样在A相可逆计数器的控制下,就可以得到周期为的单向半波正弦信号;C相首先从正弦函数表的地址60 开始递减读起,当读到地址0 处,再从地址0 处递增读到地址90 处,然后从地址90 处递减读到地址0 处,这样在C相可逆计数器的控制下,就可以得到周期为、初相位滞后A相60 的单向半波正弦信号;同理,B相从正弦函数表的地址60 开始累加读起,在B相可逆计数器的控制下,就可以得到周期为 、初相位滞后C相60 的单向半波正弦信号。这样,通过一个\frac{ }{2}周期的正弦函数表,就可以发出三个相位互差60 、周期为的单向半波正弦信号。然后,查出的数据经过正弦调制波幅值调节,使输出的三个单向半波正弦幅值满足设计的幅值调节要求后,再与三角载波进行比较,就可以得出三个相位互差120 的SPWM脉冲信号。
: l. ^% I: ^7 ^6 u' ]    由于三相正弦信号的产生在整个系统设计中非常关键,下面给出VHDL设计的主要程序。
9 B' d. S2 d; G3 M. K; w    process(clk)8 a( g4 O4 y1 @1 _7 n* |9 s4 U; M
    variable m :integer range 511 downto 0& {- K4 B3 E' P' j
    begin$ P1 c. o- Z2 O% ]3 k* O' R6 u
    if clk'event and clk='1'then ;产生A相地址$ ?( [2 u7 r- d+ O7 ^+ P
    if SAdir='1' then ;SAdir为A相可逆计数器的标志位,当为"1"计数器递增
0 a, J7 b/ M1 J2 Q! |( ^    m:=1+m
" D2 Z9 e& ]# q9 C9 O% t7 Y    else m:=m-1; 当SAdir="0",计数器递减
: `4 E! N/ f6 m6 V4 Z    end if, u% p" K$ G; {% ^3 b# q4 v/ H
    A_Address<=m; A_Address为A相对应查找内部ROM表的地址值+ k: _# j9 ?/ T% `+ j0 x5 ~
    end if0 S: j4 d  V5 ~, X7 P7 Y
    end process  D+ d0 m7 |- a
    process(clk)8 z! q5 C7 A8 G: o
    variable m, n :integer range 511 downto 0
4 T9 m" f: \! E3 M+ m3 i    begin
6 S3 N9 _+ h6 ^2 \8 ^* J    if clk'event and clk='1'then; 产生C相地址0 Y- a7 j( F# k
    if SCdir='0' then
6 g8 Y6 a/ p. r5 f    m:=m+1;
6 V, {7 b6 J5 L+ B$ N' m    else n:=n-1;m:=341+n; C相首先从60 处开始递减产生查表地址8 C( f. j+ q5 z" i/ r- v" ~
    end if;
8 T- e( q( |) e- A    C_ Address<=m;
1 _/ j8 g7 D1 q# D4 i: ?. m% M. e    end process;( B7 g! M) d8 N" d  q* Y/ E, S
    process(clk)8 n6 A; v' S( e
    variable m, n :integer range 511 downto 0 ;* L: i+ b5 R- s' [( u
    begin9 C3 A, n3 X  u0 T
    if clk'event and clk='1'then ;产生B相地址; s* D% ]0 T. F8 w9 z5 e# a# }* z* n' X" i
    if SBCdir='1' then- q5 a7 `7 E) N+ _* v
    n:=n+1;m:=341+n;保证B相首先从60 处开始递增产生查表地址' p6 o0 v% H- }, H3 E
    else m:=m-1;
3 G4 l  @; T- o* B$ r* S. L8 S9 _" f8 {    end if;5 n- \) ~& Z+ S8 \' _" q
    B_ Address <=m;. H' I. b3 M% j4 H: e
    end if;
' ], j  i9 _6 K- ]    end process;
/ j" H& u0 r: P8 V4 e    process(Div_clk,AA,BB,CC,input)
8 U6 L3 h3 }4 @; X" _; S- o* b8 s    begin
) Q3 O. H- m) O3 a    if Div_clk'event and Div_clk='1' then ;Div_clk为clk的分频时钟- F# J' d3 E8 X) S: y( R2 B9 X
    if AA='1' then ;AA为A相查表控制位,当为"1" 时,从ROM中取正弦值,
/ d( t6 B; n% y: W    q<= A_ Address ; q为ROM表对应正弦值的地址入口! F3 c& Q  F: P' j+ E
    A_Data <= *ROM_Data; 为输入的调制深度,ROM_Data为ROM正弦表的正弦值. L1 C; Z7 T  E* L! @
    PA<=A_Data(14 downto 8); 除法运算,舍取最低8位实现! b( Z6 j* [2 n/ i* O
    elsif BB='1' then;AA为A相查表控制位,当为"1" 时,从ROM中取正弦值,
) f& E- i$ k% P7 ~" U    q<= B_ Address; PB<=B_Data(14 downto 8); B_Data <= *ROM_Data;
+ E- s( W. T% o& Q, O    elsif CC='1' then1 _! K) M! f, w  E5 S  H- l- ?+ D
    q<= C_ Address ; PC<=C_Data(14 downto 8); C_Data <= *ROM_Data;7 a" F# M) u: r! @& v
    end if; end if;! ^1 s7 s2 R: ]# j. N: a2 t
    end process;$ \# E2 ?3 `# r7 w  J$ g2 i
    process(clk,flagA)- Q0 R1 c/ s: `$ s% _7 o  w
    begin# Z* D2 C( ]1 L6 c, k
    if clk'event and clk='1' then
; }, g# E! q+ Y  p4 W    if flagA='1' then ;flagA为 A相同步信号控制位,flagA='1' 表示当前A相正弦--波处于正半周期
9 b! W9 l+ ~+ E6 A9 V    A_Adjust <=PA+"1111111" ; 正半周期正弦调制波幅值调整) O, |7 H% I3 G( t6 U
    elsif flagA='0' then ;flagA='1' 表示当前A相正弦波处于处于负半周期
5 P/ M2 k4 `0 ?. X  l) O0 r    A_Adjust <="1111111"- PA; 负半周期调幅3 W1 H9 j& N6 d. t4 X* ~& }" x8 }
    end if;
4 j; b" B3 i' b' G) n    end if;( d3 v2 a$ I; _3 d7 w& L3 |- V
    End process;2 V2 g" B& v2 \" K4 G; H' i
系统逻辑与时序功能仿真2 I/ b! S. Q% t; E9 T5 d3 H
    利用MAX+PlusII的波形仿真功能可以得到芯片输入输出仿真图。Atlera公司的这种软件非常方便的提供了验证方式。不但提供逻辑输出的验证,而且提供了时序的验证,包括芯片内部的各点之间的延时,以及竞争冒险现象的出现。
; N2 |8 a: ], ~  K9 \" w    输入调制频率为50Hz、调制深度为0.75时的三相六路SPWM波形,三相彼此相位互差120 。其中AH与AL为A相没有加死区的上桥信号与下桥信号,后面以此类推。flagA、flagB和flagC为三相正弦同步信号,以保证三相六路数据严格按相互滞后120 的相位输出。
8 \" U1 a2 ]" q    输入调制频率为50Hz、调制深度为0.25时的三相六路SPWM波形。可以看到,输出的六路PWM信号脉冲宽度有了明显的改变。! ^( ?: ]+ W8 h7 y6 n5 M
结束语2 M8 C4 r3 p) w$ u3 s! }4 U4 O% k
     本文提出了一种利用FPGA产生PWM波的方案,并给出了具体的实现方法以及相应的PWM波发生框图。该电路通过系统可编程芯片实现,用硬件描述语言以及图形输入完成了整个功能模块的全部设计工作,使得触发电路更加可*和稳定,为高载波SPWM波形生成提供了一条快速实现的途径。如果改变输入时钟的频率以及相应的载波频率,以此电路为核心,配合相应的外部保护电路与其它逻辑控制电路,完全可以应用于逆变系统中

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2026-4-17 18:33 , Processed in 0.032533 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表