View previous topic :: View next topic |
Author |
Message |
bschriek
Joined: 18 Dec 2007 Posts: 80
|
Frequency Modulation |
Posted: Wed Dec 04, 2019 10:01 am |
|
|
Hello,
I want to synchronize 2 switched-mode pwm controllers and therefore i need a 45kHz pulse signal. The duty cycle is not important but must be quite low (5% max). So far so good.... This simple pulse can be realized with a PWM or NCO module.
But now I want to apply Frequency Modulation to the pulse signal.
The frequency must increase linear from 40kHz to 50kHz and linear back again to 40kHz.
This (frequency jitter) will spread the switching noise of the switched-mode power supply and so the result is reduced EMC noise.
The ideal modulation frequency is 250Hz.
Does anybody have an idea how to accomplish this as simple as possible.
I can use different 16F15xxx µcontrollers with PWM, NCO, Comparator or CLC module.
I need a hint.
Best regards,
Bas
Last edited by bschriek on Thu Dec 05, 2019 1:54 am; edited 1 time in total |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9271 Location: Greensville,Ontario
|
|
Posted: Wed Dec 04, 2019 10:11 am |
|
|
There are PICs that have that 'FM' peripheral ...though off the top of my head I don't know a number and can't remember what 3 letter 'device' it's called..
DSM ?? maybe... Data Signal Modulator
PIC16F1847, chapter 23....
it's designed to modulate one signal with another, had a whack of 'options'...just never used it...
Jay |
|
|
diode_blade
Joined: 18 Aug 2014 Posts: 55 Location: Sheffield, South Yorkshire
|
|
Posted: Wed Dec 04, 2019 1:15 pm |
|
|
Could go down the hardware route using a varactor diode fm modulator and mixer circuit. More components I know. Just a thought. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9271 Location: Greensville,Ontario
|
|
Posted: Wed Dec 04, 2019 1:52 pm |
|
|
Really ? Discrete parts ?? and here I was led to believe PICs can do EVERYTHING !
Sad thing is I have varactors in a bin here next to some NUMITRONs... |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Thu Dec 05, 2019 2:00 am |
|
|
The Data Signal Modulator....... I will check this immediately.
I'm even able to add a small µcontroller for the synchronize job only.
So now I can use a very fast interrupt or just a fast program loop because all other household routines are performed by the original µcontroller.
But I like the idea to combine all kind of hardware modules so the synchronization runs autonomous. I'm inspired by AN1890 where WS2812B leds are used. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19591
|
|
Posted: Thu Dec 05, 2019 4:03 am |
|
|
What is changing the duty cycle?.
What you describe, seems to be a fixed possibly 5% signal, not a PWM, whose
frequency is being dynamically changed?.
If so, then the way to do this is a simple table of time values, then have
an interrupt on Timer2 (assuming this controls the PWM), and have this
load a new limit time from the table each time the interrupt occurs.
What else does he PIC have to do?.
If there is actual control of the PWM, this will get much more complex, since
the effective duty cycle will change as you change period. |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Thu Dec 05, 2019 4:28 am |
|
|
Hello mr Ttelmah,
I use normal analog pwm controller IC's with an internal oscillator for our switched-mode power supply. Analog pwm controller IC's because of the simplicity, speed and cost. Both pwm controller IC's can be synchronized by a digital pulse.
https://www.ti.com/lit/an/slua110/slua110.pdf
At page 3-112 (fig 16, 17 and 18) you will find the "spike" I need to synchronize the analog pwm controller.
So the duty cycle of the synchonisation pulse is not important.
The PIC normally controls all protections of the psu and this is not very critical therefore I think a short interrupt with high repetition frequency is possible.
But I also use a 3rd analog pwm controller IC and this one has also digital parts inside. For example this IC doesn't allow synchronization pulses with a large frequency change. So the frequency must change linear from 40kHz to 50kHz and back in steps of 100Hz max.
There are a lot of other time critical requirements to fulfill but let's start with a simple synchronization pulse.
PS. welcome to the analog world! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19591
|
|
Posted: Thu Dec 05, 2019 5:36 am |
|
|
In which case the lookup table approach is the way to go.
Timer2 has the option to interrupt every pulse or every second, third etc..
Now if you set it to interrupt every eighth pulse, this will give an interrupt at
1/6250 second when the pulse is at 50KHz, and 1/5000th second when at
40KHz.
All the interrupt need to do is change the PR2 value in Timer2 (suggest
writing this directly). Since the interrupt should occur immediately after
the timer reset, the internal counter will be well short of reaching this
so the time should just change smoothly.
All you need is an array of 22 PR2 values, single byte for each, and the
interrupt just increments a counter, if it == 22 sets it back to zero, then
loads the value from this index and write it to the PR2 register. Then exit.
Will give you 11 frequencies changing every 8 cycles of the clock.
Now the value used will need to be not quite linear, since the time interval
will change with the frequency. So if (for instance), your master clock
was 32MHz, and your PWM setup with:
setup_timer2(T2_DIV_BY_1,160,8); //50000 Hz
Now the PR2 intervals would want to ramp from 159 to 199 for periods
of 160 to 200 counts. However because this first time is at the faster
50000Hz rate, we are only about 8% through the total 'time', so the value
in the table would have to be adjusted to give a straight result. |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Thu Dec 05, 2019 6:35 am |
|
|
Ok, I will give it a try but I hoped for an integrated solution without interrupts or even code changing. I will post the results when ready.
Thanks! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19591
|
|
Posted: Thu Dec 05, 2019 7:41 am |
|
|
There is going to be code whatever you do.
The PIC16F18424, might be what you need. This has the DSM peripheral,
which allows you to modulate one signal with another. You could use the
PWM, and modulate this with the NCO (which this also has). However
setting this all up is going to involve more code than the simple adjust
the PWM approach.... |
|
|
bschriek
Joined: 18 Dec 2007 Posts: 80
|
|
Posted: Fri Dec 06, 2019 8:43 am |
|
|
Here is my Low-tech interrupt routine solution for my problem.
But I always run my µcontrollers at 8MHz clock frequency maximum (never had a fail in noisy surroundings) and now I need to run at 32MHz. Does this mean a higher risk for the controller to get stuck? Is running at a lower frequency more safe?
Code: |
///////////////////////////////////////////////////////////////////////////////
// Frequency changes linear from 80kHz to 90kHz and back again in steps of 62Hz and cyle time is 3.8mSec
#INT_NCO
// SETUP_NCO(NCO_ENABLED|NCO_PULSE_FREQ_MODE|NCO_PULSE_WIDTH_8|NCO_CLOCK_HFINTOSC, 2621); // 32.000.000 / 4 / (1048576/ 2621)= 80 kHz, about 2.3% duty cycle.
// NCO 0A3D = 80kHz, 0AE1 = 85kHz, 0B85 = 90kHz
// NCO 2621d = 80kHz, 2785d = 85kHz, 2949d = 90kHz
void isr()
{
i = i + 1;
if (i < 161) // 1 to 161 = 160 steps
{
NCO_setting = NCO_setting + 2; // starts at 0x0A3D (2621d)
// NCO1INCU = 0;
NCO1INCH=make8(NCO_setting,1); // MSB
NCO1INCL=make8(NCO_setting,0); // LSB
output_high (Pin_C1); // Indicates frequency increases
}
if (i >= 161) // 161 to 321= 160 steps
{
NCO_setting = NCO_setting - 2; // returns to 0x0A3D (2621d)
// NCO1INCU = 0;
NCO1INCH=make8(NCO_setting,1); // MSB
NCO1INCL=make8(NCO_setting,0); // LSB
output_low (Pin_C1); // Indicates frequency decreases
}
if (i >= 321)
{
i = 0;
NCO_setting = 2621; // reset value, 0x0A3D (2621d) = 80kHz
}
NCO1IF = 0; // Required otherwise does not leave interrupt routine
}
/////////////////////////////////////////////////////////////////////////////// |
|
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9271 Location: Greensville,Ontario
|
|
Posted: Fri Dec 06, 2019 10:08 am |
|
|
Going from 8 to 32 megs shouldn't increase the possibilty of the controller 'getting stuck' provided resonable care has been taken in the PCB design (layout, bypass caps, traces,etc.).
You will have a slight increase in power comsumption though as CMOS draws power changing states, so more changes = more power. Not a big deal unless running off an itty, bitty battery.
Jay |
|
|
bkamen
Joined: 07 Jan 2004 Posts: 1615 Location: Central Illinois, USA
|
|
Posted: Sat Dec 07, 2019 2:58 pm |
|
|
temtronic wrote: | Really ? Discrete parts ?? and here I was led to believe PICs can do EVERYTHING !
Sad thing is I have varactors in a bin here next to some NUMITRONs... |
HAHAHAHA......
I have a TVB-2 Tube Tester on my shelf. (And I used it a couple years ago to restore someone's Westinghouse H-169 Console Radio)
Ahhh, the things gathering dust on our shelves. :P _________________ Dazed and confused? I don't think so. Just "plain lost" will do. :D |
|
|
|