In order to convert
digital values (n-bit vectors etc) to the equivalent analogue
value (for instance 0 to 5 volt) can it be necessary connect
hardware DAC to the system. Those usually based on a 2R-ladder
network and will be quite expensive when a higher resolution
needed (12-bit or more).
A cheaper alternative
could a Pulse Modulation based DAC - like the PWM and
Sigma-Delta types.
Lots of documentation can
be found on the net - concerning the theories behind and the
frequency spectres etc. The exercises below mostly about the
VHDL implementations of a PWM and a PPM Sigma-Delta conversion.
|
|
|
|
|
You may adjust the Clk-frequency
between 25, 50 and 100 MHz in order to observe the PWM
and PPM outputs.
SW6..SW0 = the 7- bit PCM value for the PWM and PPM
duty cycles.
SW7
= Selection between High and Low Clk frequency -
Calculate the exact number yourself
LD3
= The PWM output
LD4
= The PPM output |
|
|
|
|
|
|
The PWM generator basically a Counter and a Comparator.
If the Max counter value a power of 2 minus 1(like 127, 255 etc)
will this circuit normally work alright.
If the Max counter value below will there be a chance
(read - risk) of mal-functionality due to the fact that not all bit changes
simultaneously - Consider an extra register between the counter and the
comparator.
|
data:image/s3,"s3://crabby-images/c5524/c552443603234f76752ef419db8668b8255ace61" alt="" |
|
|
The PPM signal will have a
"more equal" contribution compared with the similar
PWM solution.Hence
will the requirements for filtering be less compared
with the similar PWM solution.
In case of power output
will the power-lost be equal to the number of
switches (on/off and off/on)
|
data:image/s3,"s3://crabby-images/cd3fd/cd3fda40bfef47bdb58a4187254a1d8f2adec737" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/20b9b/20b9bc26273e488ce94246904bdd9a1fa06bcbb6" alt="" |
Please note!
In order to avoid clock-skew are all F/F's driven by
the same Clk-signal.The
Scaled_Clk will only be high for one Clk-period and
hence can it serve as CE (Clock Enable) signal in
the processes for PWM and PPM generation.
|
data:image/s3,"s3://crabby-images/914ba/914ba9b89169ebac7aa6ef041f043e1421b3913e" alt="" |
|
|
|
|
|
Simulation with
N=4
and Max=16
|
|
Please note - The circuit above only a
suggestion which not optimized for size/speed.
It appears that the PPM value first will be 1 after
16 clock-pulses - this fact shouldn't be a problem
in real-life applications, but its possible fix "the
bug" with minor changes (how?)
|
|
data:image/s3,"s3://crabby-images/45d9a/45d9afc20193cef85dedcf81932267fda993ae34" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/b0b60/b0b608d78dc89aff5541ec3f7273c6d17a881c0b" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/b26bb/b26bb0242396c869c4cefb54df0b710380514cad" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/76bd9/76bd9ae5d317d8b4ee49323585dee786618e30e5" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/05fb8/05fb84d650665877d68a5d9444bc72060d72c6c4" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/51c92/51c92bbd04748bdd68d82d5e684528f0e953d0fc" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/0a4d1/0a4d1472941765d41a612e71b6895ccb7b55bb9e" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/fa822/fa8225f4addccc3213debaa2245b11c6dad1fef0" alt="" |
|
|
|
|