- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于fpga的无刷直流电机控制软件篇之霍尔信号)
霍尔信号根据在电机安装位置的不同,有2种不同的时序图,分别是60度和120度。这个要根据电机的厂家提供的资料。我这次选型的电机是60度。时序图如下:?s1-s6分别对应6个状态,每一个状态的电气角度是60度。霍尔信号在这里不仅要用来换向。还要用测速,提高电机控制系统的测速反馈。先来说换向。s1-s6代表6个状态,每个状态对应6个开关管的开启和关闭。?上图为6个状态对应霍尔信号逻辑电平和对应6个开关管的开关逻辑状态。软件部分这里很好处理,简单的状态机就可以实现了。但是,不要忘记我们的集成模块是dvr8312,它的控制接口为pwm_a pwm_b,pwm_c rst_a,rst_b,rst_c,并不是对应6个开关管。?这是dvr8312手册上给出的用常规6个开关管信号的逻辑图。我们就按手册的来。程序如下:`timescale 1ns / 1psmodule PWM_ctrl(clk,rst_n,? ???pwm_ah,pwm_bh,pwm_ch,? ???rst_an,rst_bn,rst_cn,? ???hall_a,hall_b,hall_c? ???);input clk;input rst_n;input hall_a;? ?? ?? ?? ? //三相霍尔信号input hall_b;input hall_c;output pwm_ah;? ?? ?? ?? ? //a相输出output pwm_bh;? ?? ?? ?? ? //b相输出output pwm_ch;? ?? ?? ?? ? //c相输出output rst_an;? ?? ?? ?? ? //rst_a输出output rst_bn;? ?? ?? ?? ? //rst_b输出output rst_cn;? ?? ?? ?? ? //rst_c输出//---------------------------------------------------------------------//霍尔换相 分为6状态 每状态只有2相通电?//? ?? ?? ? s1??s2??s3??s4??s5??s6//hall_a? ?1??1??1??0??0??0//hall_b? ?0??0??1??1??1??0//hall_c? ?1??0??0??0??1??1//pwm_ah? ?1??1??0??0??0??0//pwm_al? ?0??0??0??1??1??0//pwm_bh? ?0??0??1??1??0??0//pwm_bl? ?1??0??0??0??0??1//pwm_ch? ?0??0??0??0??1??1?//pwm_cl? ?0??1??1??0??0??0//----------------------------------------------------------------------reg [2:0] hall1;reg [2:0] hall2;reg pwm_ahr;reg pwm_bhr;reg pwm_chr;reg pwm_alr;reg pwm_blr;reg pwm_clr;//reg??[9:0] ctrl_reg;reg??pwm_reg;reg [9:0] cnt;parameter ctrl_reg = 200; HYPERLINK mailto:always@(posedge \t _blank always@(posedge?clk or negedge rst_n)??if(!rst_n)begin? ?pwm_reg =??1b0;? ?cnt = 10b0;? ?end??else begin? ?if(cnt =ctrl_reg)? ? pwm_reg = 1b1;? ?else pwm_reg = 1b0;? ??? ?endalways @(posedge clk or negedge rst_n)??if(!rst_n) cnt = 10b0;??else cnt = cnt + 1b1;always @(posedge clk or negedge rst_n)??if(!rst_n)begin? ?hall1 = 3b0;? ?hall2 = 3b0;? ?end??else begin? ?hall1 = {hall_a,hall_b,hall_c};? ?hall2 = hall1;? ?end//------------------------------------------------
文档评论(0)