View previous topic :: View next topic |
Author |
Message |
wewe
Joined: 17 Apr 2010 Posts: 31
|
help in writing in C language for a pic18f4331 |
Posted: Sat Apr 17, 2010 10:19 am |
|
|
This is a program that is supposed to convert an analog to digital value and output it on port B. It's not working. I tried to simulate it in Proteus.
Code: |
void main()
{
int16 value;
int1 done;
setup_adc_ports(NO_ANALOGS|VSS_VDD);
setup_adc(ADC_OFF|ADC_TAD_MUL_0|ADC_CONT_A|ADC_WHE N_INT0|ADC_INT_EVERY_OTHER);
setup_spi(SPI_SS_DISABLED);
setup_wdt(WDT_OFF);
setup_timer_0(RTCC_INTERNAL);
setup_timer_1(T1_DISABLED);
setup_timer_2(T2_DISABLED,0,1);
//Setup_Oscillator parameter not selected from Intr Oscillotar Config tab
// TODO: USER CODE!!
set_tris_a(0xff);
setup_adc_ports (all_analog);
set_adc_channel (0);
setup_adc(ADC_CLOCK_INTERNAL);
read_adc(ADC_START_AND_READ);
done = adc_done();
while(!done) {
done=adc_done();
}
value = read_adc();
OUTPUT_B(value);
} |
|
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Sat Apr 17, 2010 12:36 pm |
|
|
Can i ask a couple of questions ???
I am new to CCS , today is my first day of writing codes for pic in c language.
First of all, how can you guys simulate your codes ??? I use Proteus but it seems like the "cof" file generated with CCS cannot be used with Proteus (or I am just unable to do it)
And output_b outputs a number on an entire port while printf is only suitable for a LCD (or I think so).
Second, is there any program here that was made before, that is suitable to control a dc motor ??
I need something that generates a pwm with a variable duty cycle (1 to 99% ) from a potentiometer and it must use the power pwms (2 complementary pwms). Because I need to have a dead time, I cannot risk any short circuit.
I was trying to adapt to this C language by first successfully making an analog to digital conversion and then move on to make a pwm but it seems like i am stuck on analog to digital. I understood your program but still can't figure out what's wrong with mine. Really without any simulation available, no one can be so sure. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Sat Apr 17, 2010 2:16 pm |
|
|
Aha I understand now, but I cannot simulate in hardware.
As for the program, what I need is to control a DC motor with an H bridge of MOSFETs and not with an H-bridge chip. That's why controlling a DC motor with a PIC other than an 18f with the complementary pwms is impossible, because the H-bridge chip takes a pwm as an input and generates a direct output for the motor.
Anyway, if I wrote a code for pic18f, are you capable of simulating it with hardware?? Do you have the equipment (mosfet, oscilloscope..) ??
and it will probably take too much of your time anyway ....
First of all my program have to be with a PIC like 18f4331 or 18f2331
and then the result of the analog to digital conversion must generate a pwm and its complementary pwm. The frequency is stable (10khz) and the deadtime is optional (I would go for 0.5 to 1 micro seconds).
I think that it's easy to write the code in CCS, but how easy it is to test it LOL, that's the question. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Sat Apr 17, 2010 2:20 pm |
|
|
I don't want to sign up to be a testing lab. You need to build your own
testing environment. |
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Sat Apr 17, 2010 2:28 pm |
|
|
PCM programmer wrote: | I don't want to sign up to be a testing lab. You need to build your own
testing environment. |
Hehe, ok, I wasn't expecting that.
I thought that you have a previously made circuit like this, that's why I described it.
I was looking for a way to simulate my codes by software anyway.
I have to run a 1.5 KW DC motor, with a 280 v input voltage. I cannot risk anything going wrong, so I need a software simulation.
First of all I was happy with Proteus, but then mplab programing is hard, then I was happy with C language, but it turned out that the "cof" files generated do not work with Proteus (apparently).
I think it's a dead end for me.
Btw, when I compile or build, is there any files with assembly language that's generated??
Maybe I can use that in mplab, then compile and build that and use the "cof" output for Proteus. Maybe that can work. |
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Sun Apr 18, 2010 12:56 am |
|
|
Btw if I choose the pic18f4331 along with the the internal oscillator, what's the frequency of that oscillator ???
I need a formula to calculate the period if I want to use one of the power pwms in pic18f4331. |
|
|
SherpaDoug
Joined: 07 Sep 2003 Posts: 1640 Location: Cape Cod Mass USA
|
|
Posted: Sun Apr 18, 2010 6:15 am |
|
|
Quote: | As for the program, what I need is to control a DC motor with an H bridge of MOSFETs and not with an H-bridge chip. That's why controlling a DC motor with a PIC other than an 18f with the complementary pwms is impossible, because the H-bridge chip takes a pwm as an input and generates a direct output for the motor. |
People have been using PICs to control H bridges since long before the 18f series was ever dreamed of. If you are controlling a 1.5kW motor from 280V you are going to need some serious driver hardware between your PIC and the FETs. Usually dead time to prevent shoot through is built into the driver electronics. It is built to turn on slow and shut off fast, usually with a RC network with a diode across it.
You need to study how FET drivers are built, or team up with an analog power engineer who knows.
Also try building your circuit for 12VDC first before shooting for 280V. At 12V the shrapnel from exploding components is much less painful. _________________ The search for better is endless. Instead simply find very good and get the job done. |
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Sun Apr 18, 2010 8:20 am |
|
|
SherpaDoug wrote: | Quote: | As for the program, what I need is to control a DC motor with an H bridge of MOSFETs and not with an H-bridge chip. That's why controlling a DC motor with a PIC other than an 18f with the complementary pwms is impossible, because the H-bridge chip takes a pwm as an input and generates a direct output for the motor. |
People have been using PICs to control H bridges since long before the 18f series was ever dreamed of. If you are controlling a 1.5kW motor from 280V you are going to need some serious driver hardware between your PIC and the FETs. Usually dead time to prevent shoot through is built into the driver electronics. It is built to turn on slow and shut off fast, usually with a RC network with a diode across it.
You need to study how FET drivers are built, or team up with an analog power engineer who knows.
Also try building your circuit for 12VDC first before shooting for 280V. At 12V the shrapnel from exploding components is much less painful. |
I chose a driver, it's the tlp25. I will not connect my pic directly to the mosfet.
But this driver cannot help me with my request for a dead time for the pwms since the pic16f877 doesn't really have a mottor control pwm generator, that's my problem.
Can you explain me the "RC" network with a diode across it method ??
If I have a PWM output, I can use an inverter to have a complementary pwm, so now I have 2 pwms, without any dead time.
How can I make the RC circuit across one of these ???
Please help, with this I can now completely drop the pic18f , which is a big plus because I don't have time to learn it anymore (in assembly) and I really don't need all the options in the pic18f. If this dead time can be generated by hardware then it's for my best anyway.
And yes I will start with a 12Vdc motor, but first I need to generate the right command circuit to control the mosfets.
You can help by naming some of the ICs that I can use. My problem is that I am not in USA or in an advanced country and if the IC is new to the market I will not find it in the market, so I will need to look for a relatively old IC that does the job. |
|
|
SherpaDoug
Joined: 07 Sep 2003 Posts: 1640 Location: Cape Cod Mass USA
|
|
Posted: Sun Apr 18, 2010 12:54 pm |
|
|
I wish there was a decent way to post a schematic here...
Consider a resistor between your PIC and the driver chip. Add a capacitor from the driver input to ground. This slows the action of the driver by about the RC time constant. Put a diode in parallel with the resistor, cathode to the PIC. Now the rising edge from the PIC is slowed by the RC but the the falling edge is only slowed by the smaller resistance of the diode. Your FETs shut off fast and turn on slower. This avoids shoot through.
You can also do it between the driver and the FET, but the dynamic capacitance of the FET gate makes predicting the behavior tougher. _________________ The search for better is endless. Instead simply find very good and get the job done. |
|
|
bkamen
Joined: 07 Jan 2004 Posts: 1615 Location: Central Illinois, USA
|
|
Posted: Sun Apr 18, 2010 3:09 pm |
|
|
wewe wrote: | Btw if I choose the pic18f4331 along with the the internal oscillator, what's the frequency of that oscillator ???
|
It's on the datasheet...
Always make sure to look at the datasheet...
The datasheet is your friend.
Have I mentioned how important the datasheet is?
:D
-Ben
p.s. I believe the built in oscillator is 8MHz. _________________ Dazed and confused? I don't think so. Just "plain lost" will do. :D |
|
|
dyeatman
Joined: 06 Sep 2003 Posts: 1941 Location: Norman, OK
|
|
|
wewe
Joined: 17 Apr 2010 Posts: 31
|
|
Posted: Mon Apr 19, 2010 10:58 am |
|
|
bkamen wrote: | wewe wrote: | Btw if I choose the pic18f4331 along with the the internal oscillator, what's the frequency of that oscillator ???
|
It's on the datasheet...
Always make sure to look at the datasheet...
The datasheet is your friend.
Have I mentioned how important the datasheet is?
:D
-Ben
p.s. I believe the built in oscillator is 8MHz. |
Believe me I have read the datasheet and the only thing that I understood is that I can use one of 8 frequencies available for the internal oscillator.
But my problem with the datasheet is that they are never clear.
For example you can't find a sentence like this " this pic is equipped with an internal oscillator with a 8 MHz frequency".
They always have this fancy way of displaying data, quite long, boring, too much technical and in the end I don't get anything :D
SherpaDoug wrote: | I wish there was a decent way to post a schematic here...
Consider a resistor between your PIC and the driver chip. Add a capacitor from the driver input to ground. This slows the action of the driver by about the RC time constant. Put a diode in parallel with the resistor, cathode to the PIC. Now the rising edge from the PIC is slowed by the RC but the the falling edge is only slowed by the smaller resistance of the diode. Your FETs shut off fast and turn on slower. This avoids shoot through.
You can also do it between the driver and the FET, but the dynamic capacitance of the FET gate makes predicting the behavior tougher. |
thx for the help
Now I want to ask a couple of questions
1- The capacitor comes between the PIC output and the ground, and after this node comes a resistor and a diode in parallel ????
2- Didn't you mean anode to the PIC???
Since the diode doesn't open unless the positive voltage is on the anode...
I am not smarter than you in electronics but I believe that you may have meant this.
3- Can you remind me how to calculate the delay on the rising edge ??
4- I will be operating on a frequency of 10KHZ, is this method of delay applicable on this frequency and is there a specific kind of capacitor I should use ??
thx for the help |
|
|
MikeP
Joined: 07 Sep 2003 Posts: 49
|
|
Posted: Mon Apr 19, 2010 1:35 pm |
|
|
What version of Proteus are you using ? The cof file work fine here. I use version 7.7 SP1. |
|
|
|