搜索
bottom↓
回复: 2

基于FPGA的正弦信号发生器频率问题

[复制链接]

出0入0汤圆

发表于 2010-8-11 19:40:22 | 显示全部楼层 |阅读模式
先发个整体代码
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

---- Uncomment the following library declaration if instantiating
---- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;

entity sin is
    Port ( CLK : in  STD_LOGIC;    ------50M开发板内部时钟     
           Q : out  STD_LOGIC_VECTOR (7 downto 0));------8位正弦信号输出
end sin;

architecture Behavioral of sin is
component sin_generate   ----------利用ISE中block memory IP核(ROM加入了64个数据)存放正弦信号数据
    port (
    clka: IN std_logic;
    addra: IN std_logic_VECTOR(5 downto 0);
    douta: OUT std_logic_VECTOR(7 downto 0));
end component;

signal q1:std_logic_VECTOR(5 downto 0);--------rom地址计数端
signal cnt:std_logic_vector(3 downto 0);-------分频计数子
signal clk5M:std_logic;------------------------实际使用时钟
begin
process(clk)------------------------分频进程
        begin
        if (clk'event and clk='1') then
                if cnt=5 then clk5M<=not clk5M;
                            cnt<=(others=>'0');
                else cnt<=cnt+1;
                end if;
        end if;
end process;

process(clk5M)-------------ROM地址产生进程
begin
        if (clk5M'event and clk5M='1')
                then q1 <= q1+1;
        end if;
end process;

inst_sin_generate : sin_generate
        port map (
            clka => clk5M,
            addra => q1,
            douta => Q);
end Behavioral;

数模转换电路图ourdev_574399.doc(文件大小:46K) (原文件名:新建 Microsoft Word 文档.doc)



开发板输出端接数模转换模块,再到示波器。最终示波器上看到了正弦波形。但是问题是不管怎么改分频,在示波器上读出的频率总是5Khz。请问各位大牛这是怎么回事呀?

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2010-8-12 08:12:42 | 显示全部楼层
改频率是要改采集点的个数···

出0入0汤圆

 楼主| 发表于 2010-8-12 09:12:08 | 显示全部楼层
回复【1楼】sunemnqsu
改频率是要改采集点的个数···
-----------------------------------------------------------------------

我是想通过改频率来改变正弦波形的频率(我想是这样的,不知道对不对,当CLK5Mhz上升沿到来时从ROM读出一个数据,一共64个数据。那么正弦波形的频率就应该是64 * CLK5Mhz),但是现在的问题是不管分频到5Mhz还是其他频率,示波器上读出的频率总是5Khz。这就让人不理解了,再怎么说修改了分频程序示波器上读出的频率也应该不同呀!

请各位高手帮忙分析分析!小弟先谢了!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 17:25

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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