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

PIC24FV16KM202 DAC

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



Joined: 29 Apr 2019
Posts: 3

View user's profile Send private message

PIC24FV16KM202 DAC
PostPosted: Mon Apr 29, 2019 5:04 am     Reply with quote

Hello,
I am quite new to PIC but have worked on ATmel series.
I have several issues in using "PIC24FV16KM202" with CCS compiler, since there is not enough examples with this specific UC.

Can anyone help and point out all the mistakes, i am not reading any output at DAC.
I have connected an LED on PIN_RB14 (DAC2) and a variable voltage source at sANO (RA0).

Code:

//#device *=24 ICD=TRUE
#device PIC24FV16KM202
#device ICD=TRUE
#device ADC=12
#include <24FV16KM202.h>
#fuses NOPROTECT, DEBUG
#use delay(clock=16M)
#use rs232(baud=9600,UART1)



void main() {

setup_dac(2, VREF_VSS_VDD | DAC_OUTPUT);
setup_dac(2, DAC_ON);

   unsigned int8 value, min, max;

   printf("Sampling:");                      // Printf function included in RS232 library


   
   setup_adc(ADC_CLOCK_INTERNAL);            // Built-in A/D setup function
   set_adc_channel(0); 
   value = read_adc();
   do {
     
             delay_ms(100);                      // Built-in delay function
         read_adc(ADC_START_ONLY);           // Built-in start A/D conversion
        // sleep();                            // Reduce power and noise during conversion
         value = read_adc(ADC_READ_ONLY);    // Built-in A/D read function
         value = read_adc();
     
         
         if(value>200)
         {
         output_high(PIN_B13);
            min=value;}
           
         
            if(value>50 && value<100)
         {output_low(PIN_B13);
         
            min=value;}
            dac_write(2, value);
       
     
 printf("\r\nMin: %2X  Max: %2X\n\r",min,max);     
} while (TRUE);
}
temtronic



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

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 5:32 am     Reply with quote

I don't use that PIC but I'd start over doing the following.

Program #1, 1Hz LED. Attach an LED and 470r to an I/O pin, toggle that pin to confirm the PIC actually runs as expected.

Program #2, send a value to the DAC, then measure DAC pin.

Program #3, send 0 to DAC ,delay 1/2 second, send 1/4 of DAC FSR,delay 1/2 second, send 1/2 DAC FSR, delay 1/2 second, send 3/4 DAC FSR, delay 1/2 second, send DAS FSR, delay 1/2 second, loop back to start.

If that PIC has 'pin selectable peripherals', you need to assign them BEFORE accessing them. There is a 'sticky' at the top of the forum with notes.
Program 3 should 'step' the output of the DAC, so a DMM, DVM or scope will see it.

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 6:38 am     Reply with quote

Comments inline:
Code:

//#device *=24 ICD=TRUE
#include <24FV16KM202.h>
//This should always be first

//#device PIC24FV16KM202
//Not needed it is set in the include file

#device ICD=TRUE
#device ADC=12

#fuses NOPROTECT, DEBUG
#use delay(clock=16M)
//Where is this clock to come from?. You need to tell the compiler
//Either a source selection fuse, or: 'INTERNAL=16M' will say
//to use the internal clock.

#use rs232(baud=9600,UART1,ERRORS)
//Always use 'ERRORS' when using the hardware UART, unless you
//are ading your own error handling code

void main() {
   
   setup_dac(2, DAC_REF_VDD | DAC_OUTPUT | DAC_ON);
   //all one line - also your Vref setting was wrong.
   
   unsigned int8 value, min, max;
   
   printf("Sampling:"); // Printf function included in RS232 library
   
   
   
   setup_adc(ADC_CLOCK_INTERNAL); // Built-in A/D setup function
   set_adc_channel(0);
   value = read_adc();
   //You need to pause for Tacq between selecting a channel and
   //taking a reading. Then you have declared 'value' as an int8, but
   //setup read_adc to return an int12. You need to be using an int16
   //for 'value'
   
   do {
     
      delay_ms(100); // Built-in delay function
      read_adc(ADC_START_ONLY); // Built-in start A/D conversion
      // sleep(); // Reduce power and noise during conversion
      value = read_adc(ADC_READ_ONLY); // Built-in A/D read function
      //You are starting, then reading without time for the ADC to acquire.
      //Wrong.
      //If you were wanting to use sleep, the sequence would be to call
      //sleep, and _then_ start the adc. The sleep always executes the
      //following instruction _before_ beginning. You would also need to
      //enable INT_ADC so that the ADC completion can wake from the
      //sleep.
     
      value = read_adc();
      //This is OK with the already made comment about the size of value...
     
     
      if(value>200)
      {
         output_high(PIN_B13);
         min=value;
      }       
         if(value>50 && value<100)
         {output_low(PIN_B13);
         
         min=value;
      }
      dac_write(2, value);
      //You need to scale this value before feeding it to the DAC.
      //Much too large a number.

      printf("\r\nMin: %2X Max: %2X\n\r",min,max);
   } while (TRUE);
}


Then the DAC is a _low current_ output. Couldn't feed an LED without
a buffer amplifier.

Use ADC=8, then your ADC value will fit in the int8, and be a suitable
size to drive the DAC.
Saad khan



Joined: 29 Apr 2019
Posts: 3

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 7:03 am     Reply with quote

That seems to be a logical reason, but I tried to measure the output voltage with no load, still no response.
I believe I am missing some declaration in the code.
Also ADC = 8 still no output.
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 8:30 am     Reply with quote

Have you updated the clock, and added acquisition times.

You also do not have the ADC setup correctly. Currently no connections
are made to the ADC multiplexer, and no Vref is selected, so add:

setup_adc_ports(sAN0, VSS_VDD);

As Temtronic says _start with one thing at a time_. Can you pulse an output
pin?. Is it pulsing at the right speed?. (proves the chip is actually working
and at the right clock rate). Then try generating a simple output on the DAC.
Only then move forward to doing multiple things.
Saad khan



Joined: 29 Apr 2019
Posts: 3

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 9:00 am     Reply with quote

Ttelmah wrote:
Have you updated the clock, and added acquisition times.

You also do not have the ADC setup correctly. Currently no connections
are made to the ADC multiplexer, and no Vref is selected, so add:

setup_adc_ports(sAN0, VSS_VDD);

As Temtronic says _start with one thing at a time_. Can you pulse an output
pin?. Is it pulsing at the right speed?. (proves the chip is actually working
and at the right clock rate). Then try generating a simple output on the DAC.
Only then move forward to doing multiple things.


Thanks for the prompt response,
The ADC is working fine, even without adding setup_adc_ports(sAN0, VSS_VDD);
If you see the code there is another LED connected at RB_13, which toggles according to the IF condition.

Also, I tried the blink code as well, it works fine. but no DAC code is running, even individually.

Also i just realized my Serial port is also showing some garbage data, i have checked the baud rate on both sides also have verified the pin connection.
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Mon Apr 29, 2019 10:32 am     Reply with quote

When you say 'checked the baud rate', have you actually measured with a
scope, rather than just setting 'to' 9600?.
The point is the baud rate will not be right, unless the clock is right.
This goes back to testing the one per second flash, with a stopwatch, and
verifying what clock rate the chip is actually running.

The Frc oscillator is meant to be +/-2% on that chip, so should be good
enough if the clock is being setup correctly, but you really do need to test what speed the chip is running.

Also, how is this connected to the PC?. Are you using a USB converter module?
Do you know what voltage this accepts as an input?. Remember this is
a 3.3v chip, so needs a unit that supports 3.3v inputs.

As I said, start by testing the DAC _on it's own'. Send a count from 0 to 255,
output a new value every 10mSec, so you should have a nice ramp, and see what it does. Always test _one thing at a time_.

Though it is an output, not an input, I'd also turn the analog select
bit on for your DAC output. So:

Code:

#word ANSB=getenv("SFR:ANSB")

//then in the code
    bit_set(ANSB, 14);


This is done automatically for the ADC, but is only 'recommended' for the
DAC, so may not be happening.
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