summaryrefslogtreecommitdiff
path: root/Example/PWM
diff options
context:
space:
mode:
authorsaurabhb172019-11-28 12:23:50 +0530
committersaurabhb172019-11-28 12:23:50 +0530
commitd2411e6515fbd81c325fcbf34113e04a121ec694 (patch)
treefcac92561a3faf38ad74b9b68ebfb0b81000ee60 /Example/PWM
parentf9c1cefc99ecd38583e0fb32b5613632bc7ebf2d (diff)
downloadnghdl-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.vhdl41
-rw-r--r--Example/PWM/pwmincrement.vhdl41
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;