CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Half-Bridge PWM

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
witte



Joined: 07 Feb 2018
Posts: 5

View user's profile Send private message

Half-Bridge PWM
PostPosted: Wed Feb 07, 2018 5:47 pm     Reply with quote

Hello,

I'm having problems to run a simple code to generate a half-bridge PWM signal.

This is the code:
Code:

#include <18F4550.h>
#device ADC = 10
#fuses NOMCLR INTRC_IO
#use delay(clock = 8000000)

unsigned int16 i ;
void main(){
  setup_oscillator(OSC_8MHZ);            // Set internal oscillator to 8MHz
  setup_adc(ADC_CLOCK_DIV_8);            // Set ADC conversion time to 8Tosc
  setup_adc_ports(AN0);                  // Configure AN0 as analog input
  set_adc_channel(0);                    // Select channel AN0
  setup_timer_2(T2_DIV_BY_16, 250, 1);   // Set PWM frequency to 500Hz
  setup_ccp1(CCP_PWM_HALF_BRIDGE | CCP_PWM_H_H);

  delay_ms(100);                         // Wait 100ms
  while(TRUE){
    i = read_adc();                      // Read from AN0 and store in i
    set_pwm1_duty(i);                    // Set pwm1 duty cycle to i
    delay_ms(1);                         // Wait 1ms
   }
}


I am simulating these code into Proteus.
My problem is that I only can see one channel generating the PWM signal.
The other channel stay low level.

My compiler version is Version 4.104.

What am I doing wrong?

Thank you!!
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Feb 07, 2018 6:51 pm     Reply with quote

If you were running real hardware, you should see waveforms on the
P1A and P1B pins, which are pins C2 and D5 in the 18F4550.
witte



Joined: 07 Feb 2018
Posts: 5

View user's profile Send private message

PostPosted: Wed Feb 07, 2018 7:02 pm     Reply with quote

In my case I'm running with Proteus.
temtronic



Joined: 01 Jul 2010
Posts: 9226
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Feb 07, 2018 7:27 pm     Reply with quote

Proteus is busted, broken,corrupted, nonfunctional. As a PIC 'simulator' it does NOT function properly, it is a failure. Please read the sticky called PIC101.
As for 'fixing' Proteus, please ask the Proteus people. Neither Microchip, CCS nor anyone on this forum (I think I speak for most posters here) want to spend any time repairing someone else's code. It would literally take 10s of thousands of hours to get it to 'simulate' a PIC properly. The fact that it's been broken for years and they won't fix it is a clear indication they don't care.
If you're interested in PICs, spend $50 for real hardware and get some quality 'bench time'. Every hour on the bench is worth 100 or more 'proteus' hours.

Jay
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Feb 07, 2018 9:24 pm     Reply with quote

Quote:
My compiler version is Version 4.104.

Apparently your version of the compiler doesn't do things quite right,
but it can be fixed as shown in this thread:
https://www.ccsinfo.com/forum/viewtopic.php?t=46458
Note the call to the output_drive() function.
witte



Joined: 07 Feb 2018
Posts: 5

View user's profile Send private message

PostPosted: Thu Feb 08, 2018 9:15 am     Reply with quote

temtronic wrote:
Proteus is busted, broken,corrupted, nonfunctional. As a PIC 'simulator' it does NOT function properly, it is a failure. Please read the sticky called PIC101.
As for 'fixing' Proteus, please ask the Proteus people. Neither Microchip, CCS nor anyone on this forum (I think I speak for most posters here) want to spend any time repairing someone else's code. It would literally take 10s of thousands of hours to get it to 'simulate' a PIC properly. The fact that it's been broken for years and they won't fix it is a clear indication they don't care.
If you're interested in PICs, spend $50 for real hardware and get some quality 'bench time'. Every hour on the bench is worth 100 or more 'proteus' hours.

Jay


Hi temtronic, I'm realizing that problems.
I appreciate your comment and I'll do that, buy a development kit and test on it.
But exist some things we'd like to do quickly test, proof of concept, but unfortunately it never works fine.
Thanks!
temtronic



Joined: 01 Jul 2010
Posts: 9226
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Thu Feb 08, 2018 10:06 am     Reply with quote

Yes, the problem is you 'assume' that Proteus is a 100% working program and as you've found out it isn't.
sadly, there are 1,000s who have assumed it as well.
In over 3 decades of 'playing with PICs' I've yet to find a simulator that does actually simulate a PIC properly.
Currently I use a PICKit 3 as my programmer, white boards for testing and use 2 or 3 PICs. Typically I'll use an 18F46K22 for 90% of the projects. While far more than needed for simple tasks, it has 2 hardware UARTs, 2 HW I2C, lots of memory and pins. There may be a similar 16 series PIC (haven't checked) but by using one PIC, I have a set of functions and drivers that I know work and frankly I don't want to spend time reading a new PICs 500 pages of datasheet ! If you can concentrate your time on ONE PIC you'll be better off. BTW a 'newer' PIC might not be a good choice. Some times they have bugs...maybe the compiler has a bug, so if possible find one that's say 2-3 years old( or older ).
Also if you need USB ( to connect to a PC), consider a TTL<>USB module. At $2 you get an EASY way to interface to a PC. NO drivers, NO codespace,NO pcb.... makes life easy.

Jay
witte



Joined: 07 Feb 2018
Posts: 5

View user's profile Send private message

PostPosted: Thu Feb 08, 2018 10:23 am     Reply with quote

PCM programmer wrote:
Quote:
My compiler version is Version 4.104.

Apparently your version of the compiler doesn't do things quite right,
but it can be fixed as shown in this thread:
https://www.ccsinfo.com/forum/viewtopic.php?t=46458
Note the call to the output_drive() function.


Not works for me, but thanks!
witte



Joined: 07 Feb 2018
Posts: 5

View user's profile Send private message

PostPosted: Thu Feb 08, 2018 10:27 am     Reply with quote

temtronic wrote:
Yes, the problem is you 'assume' that Proteus is a 100% working program and as you've found out it isn't.
sadly, there are 1,000s who have assumed it as well.
In over 3 decades of 'playing with PICs' I've yet to find a simulator that does actually simulate a PIC properly.
Currently I use a PICKit 3 as my programmer, white boards for testing and use 2 or 3 PICs. Typically I'll use an 18F46K22 for 90% of the projects. While far more than needed for simple tasks, it has 2 hardware UARTs, 2 HW I2C, lots of memory and pins. There may be a similar 16 series PIC (haven't checked) but by using one PIC, I have a set of functions and drivers that I know work and frankly I don't want to spend time reading a new PICs 500 pages of datasheet ! If you can concentrate your time on ONE PIC you'll be better off. BTW a 'newer' PIC might not be a good choice. Some times they have bugs...maybe the compiler has a bug, so if possible find one that's say 2-3 years old( or older ).
Also if you need USB ( to connect to a PC), consider a TTL<>USB module. At $2 you get an EASY way to interface to a PC. NO drivers, NO codespace,NO pcb.... makes life easy.

Jay


I don't have problem learn another MCUs, and otherwise each project have a specification and target of cost.
For that problem, I'll buy a dev kit and test.

Thanks a lot!!
ZEYNEL



Joined: 15 Feb 2018
Posts: 1

View user's profile Send private message

code is not missing.
PostPosted: Thu Feb 15, 2018 4:06 am     Reply with quote

Hello.
Proteus is a nice program. It does what you say.
However, each program and device must be set correctly.
It can not be left idle.

No required Registers are left unset.

For this, the fuse settings must be made absolutely.

it works like this.

Code:

#include <18F4550.h>
#device ADC = 10
// Fuses: PLL1,PLL2,PLL3,PLL4,PLL5,PLL6,PLL10,PLL12,CPUDIV1,CPUDIV2   
// Fuses: CPUDIV3,CPUDIV4,NOUSBDIV,USBDIV,XT,XTPLL,EC_IO,EC,ECPLL_IO 
// Fuses: ECPLL,INTRC_IO,INTRC,INTXT,INTHS,HS,HSPLL,NOFCMEN,FCMEN     
// Fuses: NOIESO,IESO,PUT,NOPUT,NOBROWNOUT,BROWNOUT_SW,BROWNOUT_NOSL 
// Fuses: BROWNOUT,BORV45,BORV43,BORV27,BORV21,NOVREGEN,VREGEN,NOWDT 
// Fuses: WDT,WDT1,WDT2,WDT4,WDT8,WDT16,WDT32,WDT64,WDT128,WDT256     
// Fuses: WDT512,WDT1024,WDT2048,WDT4096,WDT8192,WDT16384,WDT32768   
// Fuses: CCP2B3,CCP2C1,NOPBADEN,PBADEN,NOLPT1OSC,LPT1OSC,NOMCLR,MCLR
// Fuses: NOSTVREN,STVREN,NOLVP,LVP,ICSP1,ICSP2,NOXINST,XINST,DEBUG   
// Fuses: NODEBUG,PROTECT,NOPROTECT,CPB,NOCPB,CPD,NOCPD,WRT,NOWRT,WRTC
// Fuses: NOWRTC,WRTB,NOWRTB,WRTD,NOWRTD,EBTR,NOEBTR,EBTRB,NOEBTRB

#fuses NOBROWNOUT,NOVREGEN,NOWDT,CCP2C1,NOPBADEN,NOLPT1OSC,NOSTVREN
#fuses NOLVP,ICSP1,NOXINST,NODEBUG,NOPROTECT,NOCPB,NOCPD,NOWRT
#fuses MCLR,INTHS

#use delay(clock=8000000)

#use fast_io(a)
#use fast_io(b)
#use fast_io(c)
#use fast_io(d)
#use fast_io(e)

unsigned int16 i ;
void main()
{
  setup_oscillator(OSC_8MHZ|OSC_STATE_STABLE);            // Set internal oscillator to 8MHz
  setup_wdt(WDT_OFF);
  port_b_pullups(False);
  port_d_pullups(False); 
  output_a(0x00);
  set_tris_e(0b00001000); //MCLR-INPUT
  set_tris_a(0b00000001);
  set_tris_b(0b00000000);
  set_tris_c(0b00000000); output_c(0x00);
  set_tris_d(0b00000000);
  setup_comparator(NC_NC_NC_NC);
  setup_psp(PSP_DISABLED);
  setup_spi(SPI_DISABLED);
  setup_spi2(SPI_DISABLED);
  setup_timer_0(T0_OFF);
  setup_timer_1(T1_DISABLED);
  setup_timer_3(T3_DISABLED);
  setup_ccp2(CCP_OFF);
 
 
 
  setup_adc_ports(AN0|VSS_VDD);                  // Configure AN0 as analog input
  setup_adc(ADC_CLOCK_DIV_8|ADC_TAD_MUL_0);            // Set ADC conversion time to 8Tosc 
  set_adc_channel(0);                    // Select channel AN0
  setup_timer_2(T2_DIV_BY_16, 250, 1);   // Set PWM frequency to 500Hz
  setup_ccp1(CCP_PWM_HALF_BRIDGE | CCP_PWM_H_H);

  delay_ms(100);                         // Wait 100ms
  while(TRUE)
  {
    i = read_adc();                      // Read from AN0 and store in i
    set_pwm1_duty(i);                    // Set pwm1 duty cycle to i
    delay_ms(1);                         // Wait 1ms
   }
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19515

View user's profile Send private message

PostPosted: Thu Feb 15, 2018 4:52 am     Reply with quote

I'm sorry, but you are 'riding for a fall' if you believe Proteus works at all well....

For a simple set of code, properly set up, it can work. However as soon as you move to more complex peripherals (and even worse _combinations_ of peripherals), it shows it's problems.

It many cases it can be made to work, but often you will find that settings you use to get it working, then stop the real chip from working. Problem then is the poster has spent time getting all the settings 'right' for Proteus, and then has to start again to actually get them to work in the chip. Mad

Now there is a tendency here to simply say 'Proteus is busted', and not look at underlying problems, but this is because many people here are just exhausted from trying to get things working, that 'should work', only then to find it is being tried on Proteus, and there is actually a Proteus problem.

Don't kid yourself that Proteus is useful as a PIC simulator for anything at all complex.
temtronic



Joined: 01 Jul 2010
Posts: 9226
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Thu Feb 15, 2018 6:26 am     Reply with quote

The huge problem I have with Proteus is it's ability to allow a PIC program to run, properly, even though according to the schematic, there is NO xtal or caps connected ! While those that 'love' Proteus will say,'well obviously we install them', as an educational tool Proteus fails,since this SIMPLE basic flaw doesn't show a student what is wrong. Most schematics presented here cannot be assembled in the real World and work. The missing xtal and caps is just the classic example. Were any student to present such a schematic to me ,he would lose 30% for those missing parts. Same holds true for not having a power switch in battery operated products.
I understand some of Proteus does work BUT I do not have any confidence is WHAT portions do work and how accurately they simulate. We all know that CCS does it's best to keep up with the new PICs and bugs reported about older ones,usually some oddball register bits or seldom used peripherals so one has to be very very cautious about how Proteus is updated and corrected.
The best way to learn about PIC is 'on the bench'. You can buy a LOT of PICs and parts for less than $50,even PICs on PCB of $2 ! I know money can be tight but considering cellphones are $500 and sneakers are $200, spending $50 on a hobby that can lead to a future job is money well spent.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group