INFRA RED REMOTE CONTROLLED ROBOCAR USING AVR (ATMEGA32) MCU

by RudraNarayanG in Circuits > Microcontrollers

11142 Views, 17 Favorites, 0 Comments

INFRA RED REMOTE CONTROLLED ROBOCAR USING AVR (ATMEGA32) MCU

tsop-avr-robo.JPG

The present PROJECT describes a design and implementation of an infrared (IR) remote controlled RoboCar which can be used for various automated unmanned control applications. I have designed remote controlled RoboCar(left-right/front-back motion). The entire system is based on microcontroller (Atmega32) that makes the control system smarter and easy to modify for other applications. It enables the user to operate or control a RoboCar and operate the mains power switch from about 5 meters away.

Key words: IR Decoder, AVR (Atmega32) Microcontroller, TV remote Controller, Wireless communication

__________________________________________________________________________

​IntraRed Communication

ttrtrt.JPG

IR Communication principle:

a) IR transmission

The transmitter of an IR LED inside its circuit, which emits infrared light for every electric pulse given to it. This pulse is generated as a button on the remote is pressed, thus completing the circuit, providing bias to the LED. The LED on being biased emits light of the wavelength of 940nm as a series of pulses, corresponding to the button pressed. However since along with the IR LED many other sources of infrared light such as us human beings, light bulbs, sun, etc, the transmitted information can be interfered. A solution to this problem is by modulation. The transmitted signal is modulated using a carrier frequency of 38 KHz (or any other frequency between 36 to 46 KHz). The IR LED is made to oscillate at this frequency for the time duration of the pulse. The information or the light signals are pulse width modulated and are contained in the 38 KHz frequency. Infrared transmission refers to energy in the region of the electromagnetic radiation spectrum at wavelengths longer than those of visible light, but shorter than those of radio waves. Correspondingly, infrared frequencies are higher than those of microwaves, but lower than those of visible light. Scientists divide the infrared radiation (IR) spectrum into three regions. The wavelengths are specified in microns (symbolized µ, where 1 µ = 10-6 meter) or in nanometers (abbreviated nm, where 1 nm = 10-9 meter = 0.001 5). The near IR band contains energy in the range of wavelengths closest to the visible, from approximately 0.750 to 1.300 5 (750 to 1300 nm). The intermediate IR band (also called the middle IR band) consists of energy in the range 1.300 to 3.000 5 (1300 to 3000 nm). The far IR band extends from 2.000 to 14.000 5 (3000 nm to 1.4000 x 104nm).

b) IR Reception

The receiver consists of a photo detector which develops an output electrical signal as light is incident on it. The output of the detector is filtered using a narrow band filter that discards all the frequencies below or above the carrier frequency (38 KHz in this case). The filtered output is then given to the suitable device like a Microcontroller or a Microprocessor which controls devices like a PC or a Robot. The output from the filters can also be connected to the Oscilloscope to read the pulses.

Applications of IR:

Infrared is used in a variety of wireless communications, monitoring, and control applications. Here are some examples:

· Home-entertainment remote-control boxes

· Wireless (local area networks)

· Links between notebook computers and desktop computers

· Cordless modem

· Intrusion detectors

· Motion detectors

· Fire sensors

· Night-vision systems

· Medical diagnostic equipment

· Missile guidance systems

· Geological monitoring devices

Transmitting IR data from one device to another is sometimes referred to as beaming.

IR Sensor & NEC Protocol Fromat

tsop17xx.JPG
ircodes4.png
ircodes5.png
ircodes6.png
ircodes7.png
NECMessageFrame.png
NECRepeat.png

IR sensors(Fig1)

  • TSOP1738, SFH-5110-38 (38kHz)

TSOP sensors Features:

  • The preamplifier and photo detector both are in single package
  • Internal filter for PCM frequency
  • Improved shielding against electrical field disturbance
  • TTL and CMOS compatibility
  • Output active low Low power consumption
  • High immunity against ambient light
  • Continuous data transmission possible

NEC Protocol:

The NEC IR transmission protocol uses pulse distance encoding of the message bits. Each pulse burst is 562.5µs in length, at a carrier frequency of 38kHz (26.3µs). Logical bits are transmitted as follows (Fig2):

  • Logical '0' – a 562.5µs pulse burst followed by a 562.5µs space, with a total transmit time of 1.125ms
  • Logical '1' – a 562.5µs pulse burst followed by a 1.6875ms space, with a total transmit time of 2.25ms

The carrier pulse consists of 21 cycles at 38kHz. The pulses usually have a mark/space ratio of 1:4, to reduce the current consumption:

(Fig3)

.

Each code sequence starts with a 9ms pulse, known as the AGC pulse. This is followed by a 4.5ms silence:

(Fig4)

.

The data then consists of 32 bits, a 16-bit address followed by a 16-bit command, shown in the order in which they are transmitted (left to right) :

(Fig5)

.

The four bytes of data bits are each sent least significant bit first. Figure 1 illustrates the format of an NEC IR transmission frame, for an address of 00h(00000000b) and a command of ADh (10101101b).

A total of 67.5ms is required to transmit a message frame. It needs 27ms to transmit the 16 bits of address (address + inverse) and the 16 bits of command (command + inverse).

(Fig6)

.

Time required to transmit the frame:

16 bits for the address (address + inverse) require 27ms to transmit time .and the 16 bits for the command (command + inverse) also require 27ms to transmit time. because (address + address inverse) or (command+command inverse) will always contain 8 '0's and 8 '1's so (8 * 1.125ms) + (8 * 2.25ms) == 27 ms . according to this total time required to transmit the frame is (9ms +4.5ms +27ms+27ms) = 67.5 ms.

REPEAT CODES:
If the key on the remote controller is kept depressed, a repeat code will be issued, typically around 40ms after the pulse burst that signified the end of the message. A repeat code will continue to be sent out at 108ms intervals, until the key is finally released. The repeat code consists of the following, in order:

  • a 9ms leading pulse burst
  • a 2.25ms space
  • a 562.5µs pulse burst to mark the end of the space (and hence end of the transmitted repeat code).

(Fig7)

.

Delay Calculation(1ms):

Clock Freq=11.0592 Mhz

Machine Cycle = 12

Delay=1ms

TimerValue= 65536 - ((Delay * ClockFreq)/Machine Cycle)=65536-((1ms * 11.0592Mhz)/12)

= 65536 - 921= 0xFC67

DC Motor Control Using L293D

l293d-circuit.jpg

DC Motor

A DC-motor converts electrical energy into mechanical energy that can be used to do many useful works. It can produce mechanical movement like Go Forward/Backword of my RoboCar. DC motors comes in various ratings like 6V and 12V. It has two wires or pins. We can reverse the direction of rotation by reversing the polarity of input.

Here we prefer L293D as a rating of 600mA is good for driving small DC motors and protection diodes are included in the IC itself. The description of each pin is as follows:
Enable pins: These are pin no. 1 and pin no. 9. Pin no. 1 is used to enable Half-H driver 1 and 2. ( H bridge on Left side). Pin no. 9 is used to enable H-bridge driver 3 and 4.(H bridge on right side).

The concept is simple, if you want to use a particular H bridge you have to give a high logic to corresponding enable pins along with the power supply to the IC. This pin can also be used to control speed of the motor using PWM technique.VCC1 (Pin 16): Power supply pin. Connect it to 5V supply. VCC2 (Pin 8): Power supply for motor. Apply +ve voltage to it as per motor rating. If you want to drive your motor at 12V, apply 12V on this pin.

It is also possible to drive motor directly on a battery, other than the one used for supplying power to the circuit, Just connect +ve terminal of that battery to VCC2 pin and make GND of both the batteries common. (MAX voltage at this pin is 36V as per its datasheet).GND (Pins 4,5,12,13): Connect them to common GND of circuit.Inputs (Pins 2,7,10,15):

These are input pins through which control signals are given by microcontrollers or other circuits/ICs. For example, if on pin 2 (Input of 1st half H driver) we give Logic 1 ( 5V), we will get a voltage equal to VCC2 on corresponding output pin of 1st half H driver i.e pin no. 3. Similarly for Logic 0 (0V) on Pin 2, 0V on Pin 3 appears.Outputs ( Pin 3,6,11,14): Outputs pins. According to input signal output signal comes.


Motor Movements A B

-------------------------------------------------------------------------------------------

...............Stop: Low : Low

......Clockwise: Low : High

Anticlockwise: High : Low

................Stop: High : High

Circuit Diagrams for Motor Driver and IR Sensor

TSOP1736.jpg
tsop1738 con.png
P2.jpg

The ATmega32 is a low-power CMOS 8-bit microcontroller based on the AVR enhanced RISC
architecture. By executing powerful instructions in a single clock cycle, the ATmega32 achieves throughputs approaching 1 MIPS per MHz allowing the system designer to optimize power consumption versus processing speed.

The AVR core combines a rich instruction set with 32 general purpose working registers. All the
32 registers are directly connected to the Arithmetic Logic Unit (ALU), allowing two independent registers to be accessed in one single instruction executed in one clock cycle. The resulting architecture is more code efficient while achieving throughputs up to ten times faster than conventional CISC microcontrollers.

The ATmega32 provides the following features:

  • 32 Kbytes of In-System Programmable Flash Program memory with Read-While-Write capabilities,
  • 1024 bytes EEPROM, 2K byte SRAM,
  • 32 general purpose I/O lines,
  • 32 general purpose working registers,
  • a JTAG interface for Boundaryscan,
  • On-chip Debugging support and programming, three flexible Timer/Counters with compare modes, Internal and External Interrupts, a serial programmable USART, a byte oriented Two-wire Serial Interface, an 8-channel,
  • 10-bit ADC with optional differential input stage with programmable gain (TQFP package only),
  • a programmable Watchdog Timer with Internal Oscillator,
  • an SPI serial port, and
  • six software selectable power saving modes.
    • The Idle mode stops the CPU while allowing the USART,
    • Two-wire interface, A/D Converter,
    • SRAM,
    • Timer/Counters,
    • SPI port, and
    • interrupt system to continue functioning.
    • The Power-down mode saves the register contents but freezes the Oscillator, disabling all other chip functions until the next External Interrupt or Hardware Reset.
    • In Power-save mode, the Asynchronous Timer continues to run, allowing the user to maintain a timer base while the rest of the device is sleeping.
    • The ADC Noise Reduction mode stops the CPU and all I/O modules except Asynchronous Timer and ADC, to minimize switching noise during ADC conversions
    • In Standby mode, the crystal/resonator Oscillator is running while the rest of the device is sleeping. This allows very fast start-up combined with low-power consumption.
    • In Extended Standby mode, both the main Oscillator and the Asynchronous Timer continue to run.

All related circuits are give here and main circuit(atmega32) is also given.

Avr Programs

Photo2566.jpg
photo2565.jpg

1. For "remote sensor":


#include
#include

#include "remote.h"

//Globals volatile unsigned int Time; //Main timer, stores time in 10us, //Updated by ISR(TIMER0_COMP) volatile unsigned char BitNo; //Pos of next BIT volatile unsigned char ByteNo; //Pos of current Byte

volatile unsigned char IrData[4]; //The four data Bytes of Ir Packet //2-Byte Address 2-Byte Data volatile unsigned char IrCmdQ[QMAX];//Final Command Received (Buffer)

volatile unsigned char PrevCmd; //Used for repeat

//Variables used for start repeating only after a key is pressed for certain time

volatile unsigned char Repeat; //1=yes 0=no volatile unsigned char RCount; //Repeat count

volatile char QFront=-1,QEnd=-1;

volatile unsigned char State; //State of receiver

volatile unsigned char Edge; //Edge of interrupt [ RISING=1 OR FALLING=0 ]

volatile unsigned int stop;

/**********************************************************************************************/ /* F U N C T I O N S S T A R T S */ /**********************************************************************************************/

void RemoteInit() {

char i; for(i=0;i<4;i++) IrData[i]=0;

stop=0; State=IR_VALIDATE_LEAD_HIGH; Edge=0; Repeat=0;

//Setup Timer1 //------------ TCCR0|=((1<

TIMSK|=(1<

OCR0=TIMER_COMP_VAL; //Set Compare Value

unsigned char GetRemoteCmd(char wait) { unsigned char cmd;

if(wait) while(QFront==-1); else if(QFront==-1) return (RC_NONE);

cmd=IrCmdQ[QFront];

if(QFront==QEnd) QFront=QEnd=-1; else { if(QFront==(QMAX-1)) QFront=0; else QFront++; }

return cmd;

}


2. main():


int main(void)
{

uint8_t cmd=0; DDRB=0x08;

DDRD=0x80;

DDRC=0x0f; PORTC=0x00;

while (1) //Infinite Loop to active IR-sensor {

cmd=GetRemoteCmd(1);

switch(cmd) {

case xx: { //BOT Moves forward //Ch+ btn forwardmotor();

break; // Both Motors in Forward Direction

}

..........................................................

..........................................................

..........................................................

default: PORTC=0x00;break; // Both left and right motors halt }

}

}/*End of main*/

....................................................................................................................................

// It a basic model, but I can use it in PWM mode.

//.....................................................Have Fun............................................................//