<< Chapter < Page Chapter >> Page >

Calibration

Like anything in the real world, your sensors and devices won't necessarily work perfectly all the time. Many analog semiconductor devices are light, temperature, and pressure sensitive, so your actual readings can vary depending on outside conditions. Also, while sensors are usually manufactured to within pretty tight tolerances, every sensor has some finite error that you will need to account for to get maximum performance.

Some kind of calibration routine can help alleviate many of these concerns. By calibrating your sensors against a trusted source, you can correct a lot of the skew caused by outside conditions. Calibration will also eliminate any steady state error caused by the device itself.

A calibration routine collects a set of known data points and scales the input signal to fit the calibration data. Since we are calibrating a fairly linear device, we only need two data points to determine its operating curve. To get the most out of the calibration, you should use two data points that are as far from each other as possible. In the case of our light sensor, that will be darkness, and a reference value that is very bright . You can either download a free smartphone LUX meter to measure a reference source to use to calibrate your board, or use an approximation from the computer monitors in the lab. The monitors are about 620 lux when showing white at full brightness with the measurement device held within a few inches of the monitor.

Calibration routine pseudocode (not in c syntax)

flag=0; interrupt function: calibrate()returns: lowMeasured, highMeasured {if flag=0: set low and set flag=1if flag=1: set highreturn }

Interrupts in c

Code Composer Studio has a special way of handling interrupts in C. It uses "compiler directives" (special instructions to the compiler, assembler, and linker) to specify which functions should go in the interrupt vector table. ISRs in C are written like any other function, except that they can take and return no values. This fits with the convention that ISRs don't interfere with or depend on the code around them.

Formatting an interrupt in code composer c

#pragma vector=PORT3_VECTOR //compiler directive saying that this function should correspond with the port3 interrupt vector__interrupt void interruptHandle() {//your ISR CODE }void main() {... all setup __enable_interrupt();//Enables general maskable interrupts ... the rest of your program}

Other concerns

Even though interrupts should work in isolation, you often need to get or modify data inside them. This can be done using volatile global variables. A global variable simply means a variable that any function in your code can see and modify. Using global variables is generally discouraged (they can be easily abused and lead to problems if you repeat common variable names), but in this case they allow you to interface with your ISR. Volatile is a directive that tells the processor to never cache the variable's value. When dealing with ISRs, cached variables could lead to problems if the ISR updates the cached data while another function is using it. Be careful using the volatile keyword excessively though-- the lack of caching slows down performance.

Full range light meter assignment details

Using Code Composer Studio 5, write a C language program to drive a simple 3 digit lux meter. Use the ADC to read the voltage and display back the actual lux value. Write a calibration routine for your lux meter and an output routine that will allow you to display each of the output digits.

    Your program should include:

  • A setup section to setup the GPIO, configure the ADC, and enable interrupts
  • An ISR that runs the calibration routine and keeps track of what has been calibrated so far (so it will only run once)
  • A main loop that continuously samples, filters, and scales the ADC input to the output range as determined by your calibration.

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Elec 220 lab course (escape). OpenStax CNX. Apr 07, 2013 Download for free at http://cnx.org/content/col11513/1.1
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Elec 220 lab course (escape)' conversation and receive update notifications?

Ask