请问如何用verilog hdl编写频率可调的脉冲信号

小弟初学verilog,现在想编写一个频率可以调节的脉冲发送程序,用于驱动伺服电机。比如频率在50--500之间,发送10000个脉冲(2500线电机。10000个脉冲刚... 小弟初学verilog,现在想编写一个频率可以调节的脉冲发送程序,用于驱动伺服电机。比如频率在50--500之间,发送10000个脉冲(2500线电机。10000个脉冲刚好转一圈),我现在用的是ZLG easyFPGA030学习板,48MHZ的时钟频率。
请各位大侠指点
要是您有现成程序发给我参看学习
lieij@163.com
谢谢了
展开
 我来答
火云杂谈
高粉答主

推荐于2017-09-15 · 从希望了解到放弃明白从浑浑噩噩到了然于心
火云杂谈
采纳数:16231 获赞数:163180

向TA提问 私信TA
展开全部
原理:
用一个足够大的计数器,对主时钟进行计数,(比如计数器定义为reg[5:0]count;那么你可以定义当count为何值时翻转时钟,那么就可以得到频率可变的时钟)。
但是这样做的话,只能得到50%占空比的脉冲。用于伺服电机,脉冲应该也是可变的才对。这时候再加一个计数器count2,两个计数器同时计数,一个代表正脉宽,另一个代表负脉宽,调节两个计数器的大小就可以实现频率、脉冲同时可变了。
具体方法:
1、当保持count+count2值不变时,则频率不变,调节count和count2的值(其实就是一个加多少另一个就减多少了)就可以改变占空比
2、如果count+count2的值也改变,那么频率也就改变了。
百度网友52286a6
推荐于2017-09-30 · TA获得超过1021个赞
知道小有建树答主
回答量:402
采纳率:0%
帮助的人:274万
展开全部
频率可调的信号可以这么实现:
用一个足够大的计数器,对主时钟进行计数,比如计数器定义为reg[5:0]count;那么你可以定义当count为何值时翻转时钟,那么就可以得到频率可变的时钟。
但是这样做的话,只能得到50%占空比的脉冲。
用于伺服电机,脉冲应该也是可变的才对。这时,你可以再加一个计数器count2,两个计数器同时计数,一个代表正脉宽,另一个代表负脉宽,调节两个计数器的大小就可以实现频率、脉冲同时可变了。
具体方法是,当保持count+count2值不变时,则频率不变,调节count和count2的值(其实就是一个加多少另一个就减多少了)就可以改变占空比;如果count+count2的值也改变,那么频率也就改变了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
从零学电子技术
2021-01-15 · 贡献了超过132个回答
知道答主
回答量:132
采纳率:100%
帮助的人:7万
展开全部

Arduino怎么输出占空比可调的PWM信号?能够输出PWM信号引脚的使用方法

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
南方血
2010-01-27 · TA获得超过114个赞
知道答主
回答量:84
采纳率:0%
帮助的人:44.7万
展开全部
这个简单,参看DDS的原理,可是直流电机?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ineedpower
2010-01-26
知道答主
回答量:15
采纳率:0%
帮助的人:0
展开全部
对时钟进行分频操作就可以了~~~~

可以用 FPGA自己的核来完成,不必自己码代码~~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式