完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
一.积分分频(小数分频)注:只是对平均频率,输出不均匀。
library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENtiTY FDIV IS ORT ( clkin : in std_logic; clkout ut std_logic); END FDIV; ARCHITECTURE epm570 OF FDIV IS SIGNAL delay : std_logic; SIGNAL q : std_logic_vector(3 downto 0); BEGIN ROCESS BEGIN WAIT UNTIL (clkin'EVENT AND clkin = '1'); delay <=q(3); q <= q+6; END PROCESS; clkout <=(q(3) xor delay) and not clkin; END epm570; 二.上升沿,下降沿微分电路。 clk :时钟大于大于din din :输入信号 up_diff :din 上升沿后输出一个clk周期宽的脉冲 dn_diff :din 下降沿后输出一个clk周期宽的脉冲 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DIFF IS ORT ( clk : in std_logic; din : in std_logic; up_diff,dn_diff ut std_logic); END DIFF; ARCHITECTURE epm570 OF DIFF IS SIGNAL t1,t2 : std_logic; BEGIN ROCESS BEGIN WAIT UNTIL (clk'EVENT AND clk = '1'); t2 <= t1; t1 <= din; END PROCESS; up_diff<=t1 AND NOT t2; dn_diff<=NOT t1 AND t2; END epm570; 三.下降沿单稳态电路,或类似定时器之类。 clk: 时钟 tclk: 触发输入 delayout :输出脉宽=delaymax*clk周期 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DELAY_T IS GENERIC (delaymax:integer:=4); ORT ( clk : in std_logic; tclk : in std_logic; delayout :buffer std_logic); END DELAY_T; ARCHITECTURE epm570 OF DELAY_T IS SIGNAL tclk_1 : std_logic; BEGIN PROCESS(tclk,tclk_1) BEGIN if (tclk_1='1')then delayout<='0'; elsif(tclk'EVENT AND tclk = '0')then delayout<='1'; end if; END PROCESS; PROCESS(clk,delayout) variable delayT: integer range 0 to delaymax:=0; BEGIN if (delayout='0')then delayT:=0; tclk_1<='0'; else if(clk'EVENT AND clk = '1')then if(delayT=delaymax)then tclk_1<='1'; end if; delayT:=delayT+1; end if; end if; END PROCESS; END epm570; 梯形加减脉冲产生程序,只提供方法,可简单应用。 load 加载参数,高电平 pulout 输出 puldata 产生脉冲的总数 smax 工作速度 1-250 smin 起始速度 1-250 lnub 到达最低速度后输出的脉冲个数 (原文件名:未命名.jpg) library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY TPJ IS GENERIC (lnub:integer:=0); ORT ( clk : IN std_logic; load : IN std_logic; en : IN std_logic; pulout : out std_logic; puldata : in std_logic_vector(15 DOWNTO 0); smax : in std_logic_vector(7 DOWNTO 0); smin : in std_logic_vector(7 DOWNTO 0)); END TPJ; ARCHITECTURE epm570 OF TPJ IS SIGNAL smax_0 : std_logic_vector(7 DOWNTO 0); SIGNAL sq_r : std_logic_vector(7 DOWNTO 0); SIGNAL smin_r: std_logic_vector(7 DOWNTO 0); SIGNAL dir_r : std_logic; SIGNAL puldata_r : std_logic_vector(15 DOWNTO 0); BEGIN PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if ((puldata-puldata_r) else dir_r<='1'; end if; end if; END PROCESS; PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if (load='1')then sq_r <="00000000" ; smin_r <=smin ; smax_0 <=smin ; end if; if (en='1')then if(puldata_r=puldata)then pulout<='0'; else if(dir_r='1')then if (sq_r pulout<='1'; else sq_r<="00000000"; if (smin_r>smax)then smin_r<=smin_r-1; else smin_r<=smax; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; else if (sq_r<(smin_r))then sq_r <= sq_r + 1; pulout<='1'; else sq_r<="00000000"; if (smin_r else smin_r<=smax_0; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; end if; end if; end if; end if; END PROCESS; END epm570; |
|
相关推荐
6个回答
|
|
一.积分分频(小数分频)注:只是对平均频率,输出不均匀。
library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY FDIV IS  ORT ( clkin : in std_logic; clkout ut std_logic); END FDIV; ARCHITECTURE epm570 OF FDIV IS SIGNAL delay : std_logic; SIGNAL q : std_logic_vector(3 downto 0); BEGIN  ROCESS BEGIN WAIT UNTIL (clkin'EVENT AND clkin = '1'); delay <=q(3); q <= q+6; END PROCESS; clkout <=(q(3) xor delay) and not clkin; END epm570; 二.上升沿,下降沿微分电路。 clk :时钟大于大于din din :输入信号 up_diff :din 上升沿后输出一个clk周期宽的脉冲 dn_diff :din 下降沿后输出一个clk周期宽的脉冲 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DIFF IS  ORT ( clk : in std_logic; din : in std_logic; up_diff,dn_diff ut std_logic); END DIFF; ARCHITECTURE epm570 OF DIFF IS SIGNAL t1,t2 : std_logic; BEGIN  ROCESS BEGIN WAIT UNTIL (clk'EVENT AND clk = '1'); t2 <= t1; t1 <= din; END PROCESS; up_diff<=t1 AND NOT t2; dn_diff<=NOT t1 AND t2; END epm570; 三.下降沿单稳态电路,或类似定时器之类。 clk: 时钟 tclk: 触发输入 delayout :输出脉宽=delaymax*clk周期 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DELAY_T IS GENERIC (delaymax:integer:=4);  ORT ( clk : in std_logic; tclk : in std_logic; delayout :buffer std_logic); END DELAY_T; ARCHITECTURE epm570 OF DELAY_T IS SIGNAL tclk_1 : std_logic; BEGIN PROCESS(tclk,tclk_1) BEGIN if (tclk_1='1')then delayout<='0'; elsif(tclk'EVENT AND tclk = '0')then delayout<='1'; end if; END PROCESS; PROCESS(clk,delayout) variable delayT: integer range 0 to delaymax:=0; BEGIN if (delayout='0')then delayT:=0; tclk_1<='0'; else if(clk'EVENT AND clk = '1')then if(delayT=delaymax)then tclk_1<='1'; end if; delayT:=delayT+1; end if; end if; END PROCESS; END epm570; 梯形加减脉冲产生程序,只提供方法,可简单应用。 load 加载参数,高电平 pulout 输出 puldata 产生脉冲的总数 smax 工作速度 1-250 smin 起始速度 1-250 lnub 到达最低速度后输出的脉冲个数 (原文件名:未命名.jpg) library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY TPJ IS GENERIC (lnub:integer:=0);  ORT ( clk : IN std_logic; load : IN std_logic; en : IN std_logic; pulout : out std_logic; puldata : in std_logic_vector(15 DOWNTO 0); smax : in std_logic_vector(7 DOWNTO 0); smin : in std_logic_vector(7 DOWNTO 0)); END TPJ; ARCHITECTURE epm570 OF TPJ IS SIGNAL smax_0 : std_logic_vector(7 DOWNTO 0); SIGNAL sq_r : std_logic_vector(7 DOWNTO 0); SIGNAL smin_r: std_logic_vector(7 DOWNTO 0); SIGNAL dir_r : std_logic; SIGNAL puldata_r : std_logic_vector(15 DOWNTO 0); BEGIN PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if ((puldata-puldata_r) else dir_r<='1'; end if; end if; END PROCESS; PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if (load='1')then sq_r <="00000000" ; smin_r <=smin ; smax_0 <=smin ; end if; if (en='1')then if(puldata_r=puldata)then pulout<='0'; else if(dir_r='1')then if (sq_r pulout<='1'; else sq_r<="00000000"; if (smin_r>smax)then smin_r<=smin_r-1; else smin_r<=smax; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; else if (sq_r<(smin_r))then sq_r <= sq_r + 1; pulout<='1'; else sq_r<="00000000"; if (smin_r else smin_r<=smax_0; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; end if; end if; end if; end if; END PROCESS; END epm570; |
|
|
|
二.上升沿,下降沿微分电路。
clk :时钟大于大于din din :输入信号 up_diff :din 上升沿后输出一个clk周期宽的脉冲 dn_diff :din 下降沿后输出一个clk周期宽的脉冲 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DIFF IS  ORT ( clk : in std_logic; din : in std_logic; up_diff,dn_diff ut std_logic); END DIFF; ARCHITECTURE epm570 OF DIFF IS SIGNAL t1,t2 : std_logic; BEGIN  ROCESS BEGIN WAIT UNTIL (clk'EVENT AND clk = '1'); t2 <= t1; t1 <= din; END PROCESS; up_diff<=t1 AND NOT t2; dn_diff<=NOT t1 AND t2; END epm570; 三.下降沿单稳态电路,或类似定时器之类。 clk: 时钟 tclk: 触发输入 delayout :输出脉宽=delaymax*clk周期 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY DELAY_T IS GENERIC (delaymax:integer:=4);  ORT ( clk : in std_logic; tclk : in std_logic; delayout :buffer std_logic); END DELAY_T; ARCHITECTURE epm570 OF DELAY_T IS SIGNAL tclk_1 : std_logic; BEGIN PROCESS(tclk,tclk_1) BEGIN if (tclk_1='1')then delayout<='0'; elsif(tclk'EVENT AND tclk = '0')then delayout<='1'; end if; END PROCESS; PROCESS(clk,delayout) variable delayT: integer range 0 to delaymax:=0; BEGIN if (delayout='0')then delayT:=0; tclk_1<='0'; else if(clk'EVENT AND clk = '1')then if(delayT=delaymax)then tclk_1<='1'; end if; delayT:=delayT+1; end if; end if; END PROCESS; END epm570; 梯形加减脉冲产生程序,只提供方法,可简单应用。 load 加载参数,高电平 pulout 输出 puldata 产生脉冲的总数 smax 工作速度 1-250 smin 起始速度 1-250 lnub 到达最低速度后输出的脉冲个数 (原文件名:未命名.jpg) library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; use ieee.std_logic_arith.all; ENTITY TPJ IS GENERIC (lnub:integer:=0);  ORT ( clk : IN std_logic; load : IN std_logic; en : IN std_logic; pulout : out std_logic; puldata : in std_logic_vector(15 DOWNTO 0); smax : in std_logic_vector(7 DOWNTO 0); smin : in std_logic_vector(7 DOWNTO 0)); END TPJ; ARCHITECTURE epm570 OF TPJ IS SIGNAL smax_0 : std_logic_vector(7 DOWNTO 0); SIGNAL sq_r : std_logic_vector(7 DOWNTO 0); SIGNAL smin_r: std_logic_vector(7 DOWNTO 0); SIGNAL dir_r : std_logic; SIGNAL puldata_r : std_logic_vector(15 DOWNTO 0); BEGIN PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if ((puldata-puldata_r) else dir_r<='1'; end if; end if; END PROCESS; PROCESS(clk) BEGIN IF (clk'EVENT AND clk = '1')THEN if (load='1')then sq_r <="00000000" ; smin_r <=smin ; smax_0 <=smin ; end if; if (en='1')then if(puldata_r=puldata)then pulout<='0'; else if(dir_r='1')then if (sq_r pulout<='1'; else sq_r<="00000000"; if (smin_r>smax)then smin_r<=smin_r-1; else smin_r<=smax; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; else if (sq_r<(smin_r))then sq_r <= sq_r + 1; pulout<='1'; else sq_r<="00000000"; if (smin_r else smin_r<=smax_0; end if; pulout<='0'; puldata_r<=puldata_r+'1'; END IF; end if; end if; end if; end if; END PROCESS; END epm570; |
|
|
|
DDA两轴直线插补
其中m就是一楼我要的Z值 m一个和积分有关的数,能改变整个周期,就是XY进给速度和m有关. library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; entity DDA is --generic (n : natural := 32); port ( Xe : in STD_LOGIC_VECTOR (31 DOWNTO 0); Ye : in STD_LOGIC_VECTOR (31 DOWNTO 0); n : in STD_LOGIC_VECTOR (31 DOWNTO 0); Clock,rest : in std_logic; Xout : out std_logic; Yout : out std_logic); end entity DDA; architecture maxcpld of DDA is SIGNAL Jrx : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL Jry : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL Jvx : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL Jvy : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL m : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL c : STD_LOGIC_VECTOR (31 DOWNTO 0); SIGNAL d : std_logic; begin process (Clock,rest) is begin if(rest='1')then Jrx <= "00000000000000000000000000000000"; Jry <= "00000000000000000000000000000000"; m <= n; Jvx <= Xe; Jvy <= Ye; d <='0'; elsif rising_edge(Clock) then if (c/=m)then c<=c+1; if((jvx+jrx)>=m )then jrx<=jvx+jrx-m; Xout<='1'; else jrx<=jvx+jrx; Xout<='0'; end if; if((jvy+jry)>=m )then jry<=jvy+jry-m; Yout<='1'; else jry<=jvy+jry; Yout<='0'; end if; else Yout<='0'; Xout<='0'; end if; end if; end process; end maxcpld; D (原文件名:1.jpg) m (原文件名:2.jpg) m (原文件名:3.jpg) |
|
|
|
PID VHDL [审核未通过] 2012-3-6 15:02阅读(0) 赞赞赞赞转载分享评论复制地址举报编辑 library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; entity pid_controller is generic ( -- size of input and output data -- iDataWidith : integer range 8 to 32:= 8; -- proportionally gain -- iKP : integer range 0 to 7:= 3; -- 0 - /2, 1 - /4, 2 - /8, 3 - /16, 4 - /32, 5 - /64, 6 - /128, 7 - /256 -- integral gain -- iKI : integer range 0 to 7:= 2; -- 0 - /2, 1 - /4, 2 - /8, 3 - /16, 4 - /32, 5 - /64, 6 - /128, 7 - /256 -- differential gain -- iKD : integer range 0 to 7:= 2; -- 0 - /2, 1 - /4, 2 - /8, 3 - /16, 4 - /32, 5 - /64, 6 - /128, 7 - /256 -- master gain -- iKM : integer range 0 to 7:= 1; -- 0 - /1, 1 - /2, 2 - /4, 3 - /8 , 4 - /16, 5 - /32, 6 - /64 , 7 - /128 -- delay between samples of error -- iDelayD : integer range 1 to 16:= 10; -- 0 - controller use derivative of ATERN_I and ATERN_ESTIMATION_I, 1 - controller use error to work -- iWork : integer range 0 to 1:= 1 ); port ( CLK_I : in std_logic; RESET_I : in std_logic; -- error -- ERROR_I : in std_logic_vector(iDataWidith - 1 downto 0); -- threshold  ATERN_I : in std_logic_vector(iDataWidith - 1 downto 0); -- current sample  ATERN_ESTIMATION_I: in std_logic_vector(iDataWidith - 1 downto 0); -- correction CORRECT_O : out std_logic_vector(iDataWidith - 1 downto 0) ); end entity pid_controller; architecture rtl of pid_controller is ------------------------------------------------------------------------------- -- functions -- ------------------------------------------------------------------------------- -- purpose: make a std_logic_vector of size c_size and build from c_value -- function f_something ( constant c_size: integer; signal c_value: std_logic) return std_logic_vector is variable var_temp: std_logic_vector(c_size - 1 downto 0); begin -- function f_something -- var_temp:= (others => c_value); return var_temp; end function f_something; -- examples: -- f_something(c_size => 3 , c_value => 'Z') == "ZZZ" -- f_something(c_size => 3 , c_value => '1') == "111" -- ... ------------------------------------------------------------------------------- -- types -- ------------------------------------------------------------------------------- -- delay register -- type type_sr is array (0 to iDelayD - 1) of std_logic_vector(iDataWidith - 1 downto 0); ------------------------------------------------------------------------------- -- signals -- ------------------------------------------------------------------------------- signal v_error : std_logic_vector(iDataWidith - 1 downto 0); signal v_error_KM: std_logic_vector(iDataWidith - 1 downto 0); signal v_error_KP: std_logic_vector(iDataWidith - 1 downto 0); signal v_error_KD: std_logic_vector(iDataWidith - 1 downto 0); signal v_error_KI: std_logic_vector(iDataWidith - 1 downto 0); signal t_div_late: type_sr; signal v_div : std_logic_vector(iDataWidith - 1 downto 0); signal v_acu_earl: std_logic_vector(iDataWidith - 1 downto 0); signal v_acu : std_logic_vector(iDataWidith - 1 downto 0); signal v_sum : std_logic_vector(iDataWidith - 1 downto 0); begin -- architecture rtl -- -- choice source of input data -- v_error <= ERROR_I when iWork = 1 else conv_std_logic_vector(signed(PATERN_I) - signed(PATERN_ESTIMATION_I) , iDataWidith) when iWork = 0 else (others => '0'); -- master gain execute by shift of iKM bits to the right -- v_error_KM <= v_error when iKM = 0 else f_something(c_size => iKM , c_value => v_error(iDataWidith - 1)) & v_error(iDataWidith - 1 downto iKM) when iKM > 0 else (others => '0'); -- proportionally gain execute by shift of (iKP - 1) bits to the right -- v_error_KP <= f_something(c_size => iKP + 1 , c_value => v_error_KM(iDataWidith - 1)) & v_error_KM(iDataWidith - 1 downto iKP + 1); -- derivative gain execute by shift of (iKD - 1) bits to the right -- v_error_KD <= f_something(c_size => iKD + 1 , c_value => v_error_KM(iDataWidith - 1)) & v_error_KM(iDataWidith - 1 downto iKD + 1); -- integral gain execute by shift of (iKI + 1) bits to the right -- v_error_KI <= f_something(c_size => iKI + 1 , c_value => v_error_KM(iDataWidith - 1)) & v_error_KM(iDataWidith - 1 downto iKI + 1); DI00: process (CLK_I) is begin -- process DI00 if rising_edge(CLK_I) then -- synchronous reset -- if RESET_I = '1' then t_div_late <= (others => (others => '0')); v_div <= (others => '0'); v_acu <= (others => '0'); v_acu_earl <= (others => '0'); else -- delay register -- t_div_late <= v_error_KD & t_div_late(0 to iDelayD - 2); -- difference between samples -- v_div <= conv_std_logic_vector(signed(v_error_KD) - signed(t_div_late(iDelayD - 1)) , iDataWidith); -- integration of error -- v_acu <= conv_std_logic_vector(signed(v_error_KI) + signed(v_acu_earl) , iDataWidith); -- sum of N - 1 samples of error -- v_acu_earl <= v_acu; end if; end if; end process DI00; -- first stage of adder -- v_sum <= conv_std_logic_vector(signed(v_acu) + signed(v_div) , iDataWidith); -- correction and second stage of adder -- CORRECT_O <= conv_std_logic_vector(signed(v_error_KP) + signed(v_sum) , iDataWidith) when RESET_I = '0' else (others => '0'); end architecture rtl; |
|
|
|
谢谢分享.
|
|
|
|
谢谢分享,有没有stm32的DDA插补程序呢,最近在做步进电机控制,希望多交流
|
|
|
|
只有小组成员才能发言,加入小组>>
2959 浏览 3 评论
27749 浏览 2 评论
3517 浏览 2 评论
4011 浏览 4 评论
基于采用FPGA控制MV-D1024E系列相机的图像采集系统设计
2374 浏览 3 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-25 04:46 , Processed in 0.634261 second(s), Total 87, Slave 68 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号