diff options
author | saurabhb17 | 2019-11-28 12:23:50 +0530 |
---|---|---|
committer | saurabhb17 | 2019-11-28 12:23:50 +0530 |
commit | d2411e6515fbd81c325fcbf34113e04a121ec694 (patch) | |
tree | fcac92561a3faf38ad74b9b68ebfb0b81000ee60 /Example/PWM | |
parent | f9c1cefc99ecd38583e0fb32b5613632bc7ebf2d (diff) | |
download | nghdl-d2411e6515fbd81c325fcbf34113e04a121ec694.tar.gz nghdl-d2411e6515fbd81c325fcbf34113e04a121ec694.tar.bz2 nghdl-d2411e6515fbd81c325fcbf34113e04a121ec694.zip |
VHDL codes for PWM
Diffstat (limited to 'Example/PWM')
-rw-r--r-- | Example/PWM/pwmdecrement.vhdl | 41 | ||||
-rw-r--r-- | Example/PWM/pwmincrement.vhdl | 41 |
2 files changed, 82 insertions, 0 deletions
diff --git a/Example/PWM/pwmdecrement.vhdl b/Example/PWM/pwmdecrement.vhdl new file mode 100644 index 0000000..b58ab86 --- /dev/null +++ b/Example/PWM/pwmdecrement.vhdl @@ -0,0 +1,41 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity pwmdecrement is +port(C : in std_logic; + D : in std_logic; + Q : out std_logic); +end pwmdecrement; + + +architecture bhv of pwmdecrement is + signal count: integer:=0; + signal alpha: integer:=0; --counts number of clocks + signal beta : integer:=1; --counts number of times 'D' is low w.r.t Clock signal(C) + signal tmp : integer:=9; --stores the value of beta for which Q will be set HIGH + begin + process (C,D) + + begin + if(C='1' and C'event) then + alpha<=alpha+1; --counts number of rising edges + if(count=0) then --initial pulse + Q <= '1'; + count<=1; + end if; + if(D='0') then --if D is low, increase beta by 1 + beta<=beta+1; + end if; + if(alpha=9) then --when aplha is 9, decrease beta by 1 and store in tmp //--set to 9 on purpose(so that first pwm signal has 90% duty cycle) + tmp<=beta-1; --decrease beta and store in tmp, so that we get 10% less duty cycle than previous + alpha<=0; + beta<=0; + count<=0; + end if; + if(tmp=alpha) then --the moment when number of clocks(alpha) equals previous number of times Q was high(tmp), we turn Q off. + Q<='0'; + end if; + end if; + end process; +end bhv; diff --git a/Example/PWM/pwmincrement.vhdl b/Example/PWM/pwmincrement.vhdl new file mode 100644 index 0000000..fd84d37 --- /dev/null +++ b/Example/PWM/pwmincrement.vhdl @@ -0,0 +1,41 @@ +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity pwmincrement is +port(C : in std_logic; + D : in std_logic; + Q : out std_logic); +end pwmincrement; +--working code for incrementing duty cycle \ Output of oscillator is fed back using a LPF and Comparator in F/B loop +architecture bhv of pwmincrement is + signal count: integer:=0; + signal alpha: integer:=0; --counts number of clocks + signal beta : integer:=0; --counts number of times 'D' is low w.r.t Clock signal(C) + signal tmp : integer:=0; --stores the value of beta for which Q will be set HIGH + begin + process (C,D) + + begin + if(C='1' and C'event) then + alpha<=alpha+1; --counts number of rising edges + if(count=0) then --initial pulse + Q <= '1'; + count<=1; + end if; + if(D='0') then --if D is low, increase beta by 1 + beta<=beta+1; + end if; + if(alpha=8) then --when aplha is 8, incremement beta by 1 and store in tmp //--set to 8 on purpose(so that first pwm signal has 10% duty cycle) + tmp<=beta+1; --increase beta and store in tmp, so that we get 10% more duty cycle than previous + alpha<=0; --reset alpha + beta<=0; --reset beta + count<=0; --reset count + end if; + if(tmp=alpha) then --the moment when number of clocks(alpha) equals previous number of times Q was high(tmp), we turn Q off. Effectively incrementing duty cycle by 10% + Q<='0'; + tmp<=0; + end if; + end if; + end process; +end bhv; |