Home
JAQForum Ver 24.01
Log In or Join  
Active Topics
Local Time 21:14 22 Nov 2024 Privacy Policy
Jump to

Notice. New forum software under development. It's going to miss a few functions and look a bit ugly for a while, but I'm working on it full time now as the old forum was too unstable. Couple days, all good. If you notice any issues, please contact me.

Forum Index : Electronics : Various aspects of home brew inverters

     Page 46 of 47    
Author Message
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 10:47am 22 Jan 2021
Copy link to clipboard 
Print this post

Hello,
I'm actually studying the DDS implementation like this:

http://interface.khm.de/index.php/lab/interfaces-advanced/arduino-dds-sinewave-generator/

the signal comes out from pin11 or pin3 if it is enabled through TCCR2A registers
and pinMode.

I need it to study some behaviors of a sine wave,
strictly at low voltage such as the output from a 50w class A/B amplifier,
superimposed on another sine wave, but for this they must
be in phase with PLL as on nanoverter sketch.

thanks A.
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 12:20am 24 Jan 2021
Copy link to clipboard 
Print this post

Here is the B-H curve of a IE transformer taken from a cheap UPS.
I think it was 600VA and had 2 x 12V 7AH SLA batteries.
You get about 15 minutes run time when you have a typical low
spec office PC and LCD monitor as the load.

This is at 50Hz:



This is a lot of saturation.
No wonder the UPS is cheap to buy. And the battery powered run times are poor.
wronger than a phone book full of wrong phone numbers
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 01:10am 24 Jan 2021
Copy link to clipboard 
Print this post

  iannez said  Hello,
I'm actually studying the DDS implementation like this:

http://interface.khm.de/index.php/lab/interfaces-advanced/arduino-dds-sinewave-generator/

the signal comes out from pin11 or pin3 if it is enabled through TCCR2A registers
and pinMode.

I need it to study some behaviors of a sine wave,
strictly at low voltage such as the output from a 50w class A/B amplifier,
superimposed on another sine wave, but for this they must
be in phase with PLL as on nanoverter sketch.

thanks A.


Hi Angelo

This is how nano1_7_etc type code works:

a 20KHz timer with PWM is set up. Each time the timer calls it's interrupt
some work is done. For the inverter application, we need a PWM pulse train
on one pin (D9) and the other pin (D10) is held LOW. This is maintained for 1/2 of
the 50 Hz cycle. Then for the other 1/2, D9 and D10 functions are swapped.

We are driving 2 half bridge inverter output stages.
The PWM pulse train is taken from a lookup table of precomputed values of
a 1/2 cycle sine wave.

I wonder what your project entails. I guess you are studying this at school or university. I think you would like one pin only to output PWM pulse widths
that range from near 0% to near 100%. This implies "zero AC volts" would be 50% width exactly. Now you will have a DC offset of about 1/2. This can be removed with AC coupling.

here you go:

nano_1_v7_no_bessel_angelo.ino.zip

Here is D9, low pass filtered with 4.7K R and 220nF cap, Light Blue
Yellow is D7, the 50Hz heartbeat or CRO trigger

Note the vertical scale and zero position for D9. It is DC coupled.


wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 03:31pm 24 Jan 2021
Copy link to clipboard 
Print this post

Hello Podia,
thanks for the edited sketch!
I almost understood how everything works ...

I am over 40 and I don't go to university, even if that's one thing
in the lineup that I would like to do sooner or later.
I consider myself an experimental physicist in heart and mind, first
because I love physics and then because I adopt this type of philosophy also in life, but in my daily work I am
a humble linux system administrator.

I have always had a passion for electronics.
 but unfortunately I discovered microcontrollers only this last year due to Covid as I am working from home and I have some time to devote myself to these studies.

I tested your sketch and obviously it works perfectly: D

as a generator I used the sketch present at the link on the previous page which uses the dds technique and produces a very stable sinusoid in frequency, also modifiable via pot if desired.

some photos:

phase KO, no pin D2 linked







phase OK, pin D2 linked via optocoupler and green LED light







in the last photo there are the two superimposed waves


I apologize for the awful setup.
I will buy a rigol 1054 as soon as possible :)


I only had to "modify" a couple of things to get the two waves in perfect phase with the same zerocross.
I read about this practice in one of your previous posts.
I inserted the _pcorrect variable which is managed through pin A0 mapped in the boundary values -200, 200 because I did not know regardless the correct value.
I did some tests :)
then I made the variable fixed so it doesn't flicker in real use.


volatile int _pcorrect;

void loop()
 _pcorrect = map(analogRead(A0), 0, 1023, -200, 200);
 //_pcorrect = -169;

ISR (INT0_vect)
phase_error = (pcint - _pcorrect);  //default value sketch orig. 4


I guess there is an automatic way to make the phase shift tend to about 0.

in practice now it is like the nano variac but with PLL and fullwave,
great for experimenting with a couple of things without using the H bridge
and using low voltage for now :)

I hope I can ask you a few more questions about the
operation of the sketch without abusing your patience.

I have already read all the threads concerning the nanoverter,
but I can't find the correlations in the use of some variables.

#define NPWM 200
here it is clear, number of sinusoid points created in array l,
even if you then create one with 201 points.

#define PPWM 800
here I imagine that 800 derives from dividing the arduino clock (16mhz) by 20khz of the PWM carrier
16 000 000/20 000 = 800 correct?
but when you use it here OCR1A = PPWM / 2 + c; what does it mean?

uint16_t l [NPWM + 1];
why do you use 200 + 1 values? to something to do with the v1low toggle?
to get 50hz we use 20khz / 400 = 50hz if I use 201 I get 20khz / 402 = 49,7512hz
what logic should i follow?

I probably lost something on the way :)

thanks for your time, A.
Edited 2021-01-25 01:33 by iannez
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 11:04pm 24 Jan 2021
Copy link to clipboard 
Print this post

Angelo:

it's good to see you having a play with this code.
I was wrong with my guess you were a student! sorry.
(I also do linux IT system admin.)

PPWM is the time, in clocks for a 20KHz PWM, and so it is
put into ICR1. 200 of these 20KHz pulses is 1/100 second, so
we can make one half of the 50 Hz sine wave using the 200 PWM duty width
values. The Nano (and a lot of other microcontrollers) use tiny crystals
for the clock, and they can be quite stable but not so accurate.

The nano I tested your code on gives 49.900 Hz with PPWM = 800
Using 798 it is now 50.027 Hz

Feel free to change this to obtain a closer output to 50Hz.
Note that this was done without any signal on D2, potentially altering the
output via the phase lock loop

OCR1A = PPWM / 2 + c;

In your version of the firmware, we need to use one pin only for PWM output.
Sine wave is bipolar. It ranges between positive and negative values.
I can't output a negative voltage via a pin.
So I offset the sine wave 1/2 it's amplitude to permit it to vary
between 0 and 5V so it needs to be offset by 2.5V
PWM duty width ranges from 0 to PPWM (in clocks)
To make 2.5V use a duty width of 800/2 or 400 clocks.
So I always output a duty width of 400 plus or minus the sine wave modulation
which will vary +/- 400 clocks or a little smaller for safely avoiding under or over flow.

why do you use 200 + 1 values?

Just in case I make a mistake in code and go "out by one" in my counting or addressing. This does not happen with the code now since it's so mature and so
we can remove this to save 2 bytes of RAM.
Always use NPWM = 200

The phase lock code is an unprofessional solution to synchronising a signal with
an input. But it works.
The end result of the code is to add or subtract one extra
PWM output for the nominal 50 Hz output frequency, to make the output track the
input pulse on D2.
This is the smallest change I can make to the output but it contributes to
a lot of phase noise.

I do fractional math to carry 10 bits of precision in the PLL error term.
The performance of this PLL is not bad, it always locks when given an input within
about 50Hz +/- 1Hz. It can maintain lock +/- 2 Hz when I test it.
wronger than a phone book full of wrong phone numbers
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 03:37am 25 Jan 2021
Copy link to clipboard 
Print this post

I just made a big change to the sync code where instead of adding +/- 1 extra pwm pulse to the output, I am now adding +/- 1 clock to the 20kHz PWM pulse generator.
This means finer control over the output waveform.

The width of the Dark Blue trace is the tracking error.
Before:




After:



It's about 5x better.

here is the improved PLL code:

nano_1_v7_no_bessel_angelo_syncv2.ino.zip

Again I use fractional math to calculate a running trim factor to the main PWM pulse gen frequency.

The tracking error is about 20us for a 50Hz frequency so it's
20uS / 20mS x 360 = 1/1000 * 360 or 0.36 degrees wide
It's +/- 0.18 degrees tracking error!
Edited 2021-01-25 13:43 by poida
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 01:33pm 25 Jan 2021
Copy link to clipboard 
Print this post

Good evening everyone and hello podia!

I tried the new sketch, it's perfect!
the wave is tracked perfectly,
in a short time I will do the test of the two superimposed voltages with connected light load.

I have inserted these lines in the sketch which probably improve
the overall system noise.
with my instruments I do not appreciate the differences,
maybe with your rigol1054 you notice something.


#include <avr/power.h>

setup()
{
 //https://www.gammon.com.au/forum/?id=11497
 //power_adc_disable(); // ADC converter
 power_spi_disable(); // SPI
 //power_usart0_disable();// Serial (USART)
 power_timer0_disable();// Timer 0
 //power_timer1_disable();// Timer 1
 power_timer2_disable();// Timer 2
 power_twi_disable(); // TWI (I2C)
 DIDR0 = DIDR0 | B00111111;           //Digital input disabled on all ADC 0-5 ports
}


let me know otherwise if there are no differences I delete them: D

to see if I understand how the new sketch works I will try to experiment on a sketch with different PWM freq and NPWM
in order to verify how the parameters affect.

thank you soon, A.
Cheers, Angelo
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 03:35pm 25 Jan 2021
Copy link to clipboard 
Print this post

I added another control led sync on pin 11
for synchronism check, visually.

every so often a blink comes out a led though
remains in sync, probable threshold to be adjusted.

if (abs (phase_error) <3 && abs (new_delta) <80)

A.
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 11:14pm 25 Jan 2021
Copy link to clipboard 
Print this post

  iannez said  
..
#include <avr/power.h>

setup()
{
 //https://www.gammon.com.au/forum/?id=11497
 //power_adc_disable(); // ADC converter
 power_spi_disable(); // SPI
 //power_usart0_disable();// Serial (USART)
 power_timer0_disable();// Timer 0
 //power_timer1_disable();// Timer 1
 power_timer2_disable();// Timer 2
 power_twi_disable(); // TWI (I2C)
 DIDR0 = DIDR0 | B00111111;           //Digital input disabled on all ADC 0-5 ports
}


let me know otherwise if there are no differences I delete them: D
..


NO difference.
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 04:37pm 26 Jan 2021
Copy link to clipboard 
Print this post

Good evening everyone,

thanks podia for the test,
I immediately deleted those lines.
there was a test, sometimes a trivial line changes everything
I am continuously in test :D

I did some tests NPWM at 400 and PPWM 399
as per eq. of the manual for timer1 mode14:


ICR1 = (F_CPU / ( timer1Prescaler * DesideredFreq )) - 1;


the wave is good but it is more stable in the eye with prev values.

perhaps the RC filter should be reviewed or probably micro at the limit.
also the memory is obviously almost full, just a test.

i am waiting for two power supply to power
the test bench I plan to do.
maybe a friend offers a 4channel oscilloscope

so

in the new line:


ICR1 = PPWM - (pcount_delta / 256);


now it is clear to me that from the ICR1 which regulates frequency,
subtract a part of the out of phase that was calculated in INT0,
so as to follow the wave for the sync minimizing the phase difference.

but where does 256 come from?

and also:


new_delta = 8 * (phase_error / 2 + 8 * (phase_error - old_phase_error));


in the comment I read PID but obviously the logic behind it
is foreign to me

thanks for the clarifications and good evening, A.
Edited 2021-01-27 02:39 by iannez
Cheers, Angelo
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 04:46pm 26 Jan 2021
Copy link to clipboard 
Print this post

I also post this video of a guy I was following long ago.
he had implemented a core saturation protection
of transformers so as to save the H bridge in the event of a short
because of the saturated core => short.

poida, it could be useful in the study of a few posts ago.

https://www.youtube.com/watch?v=3LkpzQ_LuJ0

bye A.
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 12:47am 27 Jan 2021
Copy link to clipboard 
Print this post

Angelo:

I see you experimented with 2x PWM frequency which becomes 40kHz.
It can help some things such as reduce inductor saturation
but it means also 2x switching losses. In our inverter builds switching losses
are not very large to begin with so you and I have scope to experiment.

In the PLL code, which executes once each falling input zero crossing
of the 50Hz input, some calculations are made.

First I get a phase error.
I also get the change in phase error from the prior interrupt.
Next I obtain a correction factor, to be applied to the timer counter
of the 20kHz timer. The correction trims the normally 800 by a small amount
to alter the 20kHz by a small amount, up or down.

The trim factor is
new_delta = 8 * (phase_error / 2 + 8 * (phase_error - old_phase_error));

I could simplify this expression but it allows me to easily try
changes to the expression.
It takes 4 x phase error and 64 x phase error change and this result is
accumulated (or subtracted) into a running total called pcount_delta

This is going to be large number and it will continue to grow larger or smaller
while the PLL is not locked.
pcount_delta is divided by 256, which can be executed fast without a divide instruction
and THIS result is subtracted from the base value of the 20kHz timer count of 800
to yield the new timer count.

The divide by 256 is used to maintain 8 bits of remainder in the division
to carry over better accuracy in the system. It's just factional math and it's
fast.

PLL background:

some PLL designs multiply the lock signal by the system output signal.
You get a cosine (sine x sine = cosine) and then take all but the DC from it and
use the DC to steer the local oscillator into phase lock via a feedback mechanism.

This PLL obtains the phase error directly and infers the two terms needed
for feedback to work (phase and frequency). I produce a feedback correction term
from something like 4 x phase error + 64 x frequency where the units are 8 Mhz clock counts.
The control loop is a simple first order PID.
The proportional component is phase error
The differential component is frequency
There is no integral term.

I can not discuss the PLL workings any more since I lack the mathematical background
required (loop stability, Bode plots, S transforms, etc.)
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 11:36am 27 Jan 2021
Copy link to clipboard 
Print this post

Goodmorning everyone!

thanks Poida for illustrating the logic you constantly implement.
you use the powers of two as truncators to then keep the 8bit in the calculations.
as a bitshift >> 8 (2 ^ 8) which the cpu interprets quickly.
and the PID as a filter of a certain order via software.

i like this type of mod, something slowly I understand

I actually experienced the possibility of increasing the number of NPWM p
oints to give a better shape to the output wave (not that at 20khz it is bad!)
unfortunately I don't have a distortion meter or a better oscilloscope that allows me to visually check.
the rise in frequency is the consequence.

I calculated a whole series of useful frequencies that gave out
integers that can be used.
there may be problems with the PLL but that's another story

PPWM: 200 | FREQ: 80000 | NPWM: 800
PPWM: 250 | FREQ: 64000 | NPWM: 640
PPWM: 256 | FREQ: 62500 | NPWM: 625
PPWM: 320 | FREQ: 50000 | NPWM: 500
PPWM: 400 | FREQ: 40000 | NPWM: 400
PPWM: 500 | FREQ: 32000 | NPWM: 320
PPWM: 625 | FREQ: 25600 | NPWM: 256
PPWM: 640 | FREQ: 25000 | NPWM: 250
PPWM: 800 | FREQ: 20000 | NPWM: 200
PPWM: 1000 | FREQ: 16000 | NPWM: 160
PPWM: 1203 | FREQ: 13300 | NPWM: 133
PPWM: 1250 | FREQ: 12800 | NPWM: 128
PPWM: 1280 | FREQ: 12500 | NPWM: 125
PPWM: 1600 | FREQ: 10000 | NPWM: 100
PPWM: 2000 | FREQ: 8000 | NPWM: 80

i found the limits using timer1 mode14 with values

PPWM: 200 | FREQ: 80000 | NPWM: 800

because it goes beyond the memory ability, that would be 1600 per fullwave.

I haven't tried with the PROGMEM but I think the limit is the same.

and below

PPWM: 1000 | FREQ: 16000 | NPWM: 160

it might not make sense because the frequency would become audible
on an H-bridge and the number of NPWM points would be too low in my opinion.

I remember that my application is for now different from the inverter one.
I say for now why the Chinese inveter taken on aliexpress must arrive: D

now i just need to have a super imposed sine wave
in phase and with the same zerocross.
adjusting amplitude should decrease the overall output voltage or increase it.
almost like putting two secondaries of a transformer in series.
Transformer AVRs work like this through relays that switch on various secondaries.

so...

I took a while to understand how I could reset the distance between the two zerocross of the waves.
so automatically have superimposed wave with concident zero cross,
without using the _pcorrect variable that I introduced and which refers to the analog pin.

i thought if i used another ISR interrupt (INT1_vect) on pin3
on which then to enter with our filtered rc wave
(of course a square would be better but it should go anyway)
in the ISR I could calculate an additional pcint.


ISR (INT1_vect)
{
  pcint1 = pcount + (v1low == 1? NPWM: 0) - NPWM; // get position in 50Hz waveform, -200 to 200 counts
                                                                                  // pcint is position in output waveform when this interrupt occurs
}


the difference between the two pcint of the two ISRs should give the distance
in pcount between the two zerocross.


_pcorrect = pcint1 - pcint;


if the logic is correct you put this value in the final calculation of the phase_error.

what do you think about it?

thank you soon, A.
Edited 2021-01-27 21:43 by iannez
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 10:05pm 29 Jan 2021
Copy link to clipboard 
Print this post

Angelo:
feel free to alter the code and try out ideas.
I think it's a fun way to discover and learn.


nano_1_v7_no_bessel_angelo_syncv5.ino.zip

is the result of a couple of days play.
I found I could tune the 50Hz by altering the 20kHz timer,
adding or removing one of the 800 clocks from the timer count.
I now do this in a more sophisticated manner:
for the entire 50Hz cycle, I modify the 800 clock count
adding or subtracting a clock (or not) to give the
required trim. Again I need a bit of fractional integer math.

The guts of the change:


i = pcount_delta/256;
ICR1 = PPWM - i;
pcount_delta = (pcount_delta - 256 * i) + pcount_acc + 135;      
// 135 is trim for the 16MHz clock is not quite 16.0000MHz
// the trim puts the PLL loop correction at zero with a 50.0000Hz input signal.
// other wise pcount_acc would = 135 plus any calculated trim.


which occurs at the start of the 20kHz timer 1 overflow interrupt.
The PLL loop produces a value "pcount_acc" and this will increase or decrease
the frequency of the nominal 50Hz. If this = 0, then no change.

pcount_delta just accumulates the trim, and I get the top 8 bits, subtract it
from the 800 clocks, then calculate and leave the low 8 bits in it ready for the next
increment of pcount_acc.
This all permits me to carry 8 bits of accuracy after I do the integer division.

Results are good.

When the PLL is fed a fixed 50Hz to track from the signal generator
the original code is:

+ 50.0039 Hz
- 49.9988 Hz
with a 100uS wide uncertainty of lock position.

The above code gives:

+ 50.0014
+ 50.0003
and 20uS uncertainty

The frequencies are as reported by the DSO on the PLL locked 50 Hz output.
It's input was always 50.0000Hz
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 11:28am 01 Feb 2021
Copy link to clipboard 
Print this post

Goodmorning everyone!
Podia great job as always.
very hacker mode :)

done some tests and with my miniDSO the waves are superimposed
with perfect tracking, i am saving to buy a serious DSO
that allows me to appreciate any changes or software tests.
it is impossible for me to measure in this way.

I just changed the interrupt mode for testing


// EICRA = 3; // interrupt on falling edge from pin D2
 EICRA = 2;


in order to have the coinciding zerocross because in my case
the waves were out of phase but in lock.

the same thing can be done manually using the variable
_pcorrect in the ISR as I did before, but now it's not needed
if the interrupt catches the wave in the right rising / falling edge.


phase_error = (32 * (pcount - 32 + (v1low == 1? 200: 0) - 200 - _pcorrect) + pe_frac);


I believe we can do better if one wants to use this mode, if necessary.

the way you use the terms of the PID is great!
I have to practice using the PID because it is essential.

I did the double interrupt test INT0 and INT1 and it works but it is slower and less precise, it probably makes sense only if the phase tracking is not as good as the one used here, so everything is simpler and faster ...

I have a rigol ds1022 "waveform generator" with here I do some tests, but if I use direct the output inside the pin D2 of arduino nano, the waveform is distorted ... what can you advise me to avoid this problem?
should i use some buffer opamp before entering direct?
the ds1022 has the ability to phase out the wave so as to verify
the various locking modes of the PLL interrupts.

one of the packages from aliexpress has arrived but not that
with inveter inside, we wait :)

psu will also arrive this week for the tests of this sketch,
i hope

thanks always for your time,

bye, A.
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 02:03am 02 Feb 2021
Copy link to clipboard 
Print this post

The DG1022 is a good generator. Default output is bipolar.
You can set output to have a DC offset.
So, choose 2.5V DC offset with wave amplitude of 5V.
Output will now range from 0 to 5V.

The distortion you are seeing is probably due to the negative
part of the waveform output from the DG1022 being clamped to near zero
thanks to the nano digital pin internal diode protections.
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 12:59pm 03 Feb 2021
Copy link to clipboard 
Print this post

thanks Poida, it actually worked!

bye, A.
Cheers, Angelo
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 03:05pm 11 Feb 2021
Copy link to clipboard 
Print this post

Goodmorning everyone!

3 kinds of inverter arrived from aliexpress so i can also experiment.

the first, simple squarer that drives driversfinals:





the second, EG8010 which drives power amplifiers + recycled ups transformer.





the third, AC/DC converter with SG3525 and EG8010 for direct DC/AC
on H-bridge with high voltage.






with great amazement all 3 inverters work, proved simple
a few watt incandescent bulb + current limiter
DC input for safety, you never know.
life expectancy at 80% of power output is a mystery.

I have a couple of questions regarding the last two inverters
to which I cannot technically answer.


- we have a way / circuit to bypass EG8010 and use
Chinese low voltage hardware with arduino and sketch nano1?

I assume you need drivers like the ir2110 or similar present on the EG8010 and something that emulates the protections offered by the opamps.
I would like to be able to test the sketch with as little hardware as possible
on Chinese inverter.


- why is the high voltage inverter not used in the amateur field?

my first answer is to be sure not to handle DC at 310 or more volts.
I assume that the sketch nano1 can safely drive through drivers
with adequate dead time, a high voltage H bridge.
if safety and efficiency are not the problem, what would improve using the output transformer?


- is there a way to deform inverter output waveform in a controlled way?

i know series diode test on light bulb to saw waveform,
as did Peter in this thread pages ago.
but it would be useful to introduce other types of distortion such as the inductive type that is generated by a fridge motor or a starting drill.
but without using a fridge or a drill that consume too much current.
an LCR circuit that distorts in the same way but with low consumption?

I apologize in advance for the probably trivial questions for some people.

i am trying to figure out how to correct the inverter output shape.
this without relying only on the voltage peak dictated by the feedback to follow the output voltage on both half-waves (I imagine a half-wave on unipolar EG8010)

the idea is to sample the output waveform and compare each sample to the one present in array l[NPWM] at the same time of reading.

the difference between the comparison gives the value to be given in
the OCR1A when it will create the output PWM pulse to correct the output deformation.

can my logic be correct?

adding a few lines to the sketch I calculated the time it takes the ISRs and ADCs to do their thing, as Peter had already written in the comments.

if the ADC readings are few and accurate, thanks to internal VREF from 1.1, I think the waveform control idea is feasible.

I also ported the sketch to stm32f103c8 (blue pill) without using stm32duino but STM32 on IDE arduino.
bare metal registers are crazy, but once you understand everything works perfectly.

ln attached if anyone wants to experiment.
there are not all active pins but only those for testing which I played on breadboard.
obviously you can then import them if necessary.

2021-02-11_154623_stm32f103c_nano_1_v7_no_bessel_angelo_syncv5_forum.zip


I tried the port to understand how much the timing affects etc.
but it is how the code is written and the use of registers that make the difference, always.
I will also try to use the stm32f411 (blackpill 100mhz) but I assume there are no problems whatsoever o improvements apart from points per wave and pwm frequency tested only on breadboard for now.


thanks for your advice on my doubts,

Ciao! A.
Edited 2021-02-12 01:16 by iannez
Cheers, Angelo
 
poida

Guru

Joined: 02/02/2017
Location: Australia
Posts: 1418
Posted: 06:35am 12 Feb 2021
Copy link to clipboard 
Print this post

Hi Angelo
I've just got back from work where I had to make a $100,000 AU machine work
after one of it's 2 CPU Z80 based control boards died. Or die trying.

This most recent post is about 15 times more complex than I can deal with right now.

My first thoughts are that you can substitute the  EG8010 control modules
with a nanoverter. Just make a cable that takes the 10 pin IDC socket and goes to the
15 pin or whatever 0.1 inch header. It's all electrically compatible.
So that is one experiment: compare and contrast the EG8010 and the nanoverter.
I will help with how you do this, I think it's worthwhile.

But maybe tomorrow I will read the above and hopefully bring some extra value to
the conversation.
wronger than a phone book full of wrong phone numbers
 
iannez
Newbie

Joined: 05/07/2019
Location: Italy
Posts: 23
Posted: 08:12pm 12 Feb 2021
Copy link to clipboard 
Print this post

Hello Peter,
Z80 distant memories of youth!
my first"PC", a Toshiba MSX I was 9 years old,
gift for communion.
first steps with basic language,
the internet was still in Tim Berners-Lee's head
that I give it to the world a year later, in 1989.

Federico Faggin the father also of the Z80,
excellent physicist and superb engineer,
I follow a lot on youtube in his conferences
where he talks about his creations among others
companies that he founded and not.

really good times ...

good rest, A.
Cheers, Angelo
 
     Page 46 of 47    
Print this page
© JAQ Software 2024