Ks0192 keyestudio 4WD Bluetooth Multi-functional Car
keyestudio 4WD Bluetooth Multi-functional Car
Introduction
keyestudio 4WD Bluetooth Multi-functional Car is a learning application development system based on microcontroller and with ATmega-328 as core. It has functions of line tracking, obstacle avoidance, IR remote control , Bluetooth remote control and detecting distance. This kit contains plenty of interesting programs and can extend an external circuit module to increase more functions of this car. The kit aims to disengage users from boring theories and obtain capacity of system development when they are learning Arduino.
Parameters
1.Motor: Voltage: 6-9V Reduction Ratio: 1:48
2.Choosing L298N driver module as control motor, separated from microcontrollor
3.Three line tracking modules, having higher precision when detecting white and black lines,able to realize anti-falling
4.IR remote control module making up a remote control system of the car
5.Using ultrasonic module to realize obstacle avoidance
6.Pairing mobile phone Bluetooth with Bluetooth remote control module to control the car
7.Able to connect with external voltage at 7~12V,and equip with various sensors to complete different functions as much as possible
Component List
Project List
Project 1:Line Tracking Sensor
Project 2:Ultrasonic Sensor
Project 3: Digital IR Receiver Module
Project 4: Servo Motor
Project 5: Bluetooth Module
Project 6: L298N Motor Driver
Project 7: I2C 1602 LCD
Project 8:Line Tracking of Smart Car
Project 9:Obstacle Avoidance of Smart Car
Project 10:IR Remote Control of Smart Car
Project 11:Distance Detecting of Smart Car
Project 12:Bluetooth Remote Control of Smart Car
Project 13:5 in 1 Muilti-functional Car
Address of Assembly Video
http://www.keyestudio.com/wp/2016/09/ks0192
Address of Demonstration Video
Project Details
Project 1:Line Tracking Sensor
Introduction:
This Line Tracking Sensor can detect white lines in black and black lines in white. The single line-tracking signal provides a stable output signal TTL for a more accurate and more stable line. Multi-channel option can be easily achieved by installing required line-tracking robot sensors.
Specification:
Power Supply: +5V
Operating Current: <10mA
Operating Temperature Range: 0°C ~ + 50°C
Output Interface: 3-wire interface (1 - signal, 2 - power, 3 - power supply negative)
Output Level: TTL level
Connection Diagram:
Sample Code:
const int sensorPin = 3; // the number of the sensor pin const int ledPin = 13; // the number of the LED pin int sensorState = 0; // variable for reading the sensor status void setup() { pinMode(ledPin, OUTPUT); pinMode(sensorPin, INPUT); } void loop(){ // read the state of the sensor value: sensorState = digitalRead(sensorPin); // if the sensorState is HIGH: if (sensorState == HIGH) { digitalWrite(ledPin, HIGH); } else {digitalWrite(ledPin, LOW); }}
Project 2: Ultrasonic Sensor
Introduction:
The HC-SR04 Ultrasonic Sensor is a very affordable proximity/distance sensor that has been used mainly for object avoidance in various robotics projects. It essentially gives your Arduino eyes / spacial awareness and can prevent your robot from crashing or falling off a table. It has also been used in turret applications, water level sensing, and even as a parking sensor. This simple project will use the HC-SR04 sensor with an Arduino and a Processing sketch to provide a neat little interactive display on your computer screen.
Specification:
Working Voltage: DC 5V
Working Current: 15mA
Working Frequency: 40Hz
Max Range: 4m
Min Range: 2cm
Measuring Angle: 15 degree
Trigger Input Signal: 10µS TTL pulse
Echo Output Signal Input TTL lever signal and the range in proportion
Size: 46*20.4mm
Weight: 9g
Connection Diagram:
Sample Code:
VCC to arduino 5v
GND to arduino GND
Echo to Arduino pin 7
Trig to Arduino pin 8
#define echoPin 7 // Echo Pin #define trigPin 8 // Trigger Pin #define LEDPin 13 // Onboard LED int maximumRange = 200; // Maximum range needed int minimumRange = 0; // Minimum range needed long duration, distance; // Duration used to calculate distance void setup() { Serial.begin (9600); pinMode(trigPin, OUTPUT); pinMode(echoPin, INPUT); pinMode(LEDPin, OUTPUT); // Use LED indicator (if required) } void loop() { /* The following trigPin/echoPin cycle is used to determine the distance of the nearest object by bouncing soundwaves off of it. */ digitalWrite(trigPin, LOW); delayMicroseconds(2); digitalWrite(trigPin, HIGH); delayMicroseconds(10); digitalWrite(trigPin, LOW); duration = pulseIn(echoPin, HIGH); //Calculate the distance (in cm) based on the speed of sound. distance = duration/58.2; if (distance >= maximumRange || distance <= minimumRange){ /* Send a negative number to computer and Turn LED ON to indicate "out of range" */ Serial.println("-1"); digitalWrite(LEDPin, HIGH); } else { /* Send the distance to the computer using Serial protocol, and turn LED OFF to indicate successful reading. */ Serial.println(distance); digitalWrite(LEDPin, LOW); } //Delay 50ms before next reading. delay(50); }
Project 3: Digital IR Receiver Module
Introduction:
IR is widely used in remote control. With this IR receiver, Arduino project is able to receive command from any IR remoter controller if you have the right decoder. Well, it will be also easy to make your own IR controller using IR transmitter.
Specification:
Power Supply: 5V
Interface: Digital
Modulate Frequency: 38Khz
Module Interface Socket: JST PH2.0
NOTE: In the sample code below Digital pin 11 is in use, you may either change your wiring or change the sample code to match.
Connection Diagram:
Sample Code:
#include <IRremote.h> int RECV_PIN = 11; IRrecv irrecv(RECV_PIN); decode_results results; void setup() { Serial.begin(9600); irrecv.enableIRIn(); // Start the receiver } void loop() { if (irrecv.decode(&results)) { Serial.println(results.value, HEX); irrecv.resume(); // Receive the next value } }
IR Remote Library includes some sample codes for sending and receiving.
https://github.com/shirriff/Arduino-IRremote
Project 4: Servo Motor
Introduction
Servomotor is a position control rotary actuator. It mainly consists of housing, circuit board, core-less motor, gear and position sensor. The receiver or MCU outputs a signal to the servomotor. The motor has a built-in reference circuit that gives out reference signal, cycle of 20ms and width of 1.5ms. The motor compares the acquired DC bias voltage to the voltage of the potentiometer and outputs a voltage difference. The IC on the circuit board will decide the rotate direction accordingly and drive the core-less motor. The gear then pass the force to the shaft. The sensor will determine if it has reached the commanded position according to the feedback signal. Servomotors are used in control systems that requires to have and maintain different angles. When the motor speed is definite, the gear will cause the potentiometer to rotate. When the voltage difference reduces to zero, the motor stops. Normally, the rotation angle range is among 0-180 degrees.
Servomotor comes with many specifications. But all of them have three connection wires, distinguished by brown, red, orange colors(different brand may have different color). Brown one is for GND, red one for power positive, orange one for signal Line.
The rotate angle of the servo motor is controlled by regulating the duty cycle of the PWM(Pulse-Width Modulation) signal. The standard cycle of the PWM signal is 20ms(50Hz). Theoretically, the width is distributed between 1ms-2ms, but in fact, it's between 0.5ms-2.5ms. The width corresponds the rotate angle from 0° to 180°. But note that for different brand motor, the same signal may have different rotate angle.
After some basic knowledge, let's learn how to control a servomotor. For this experiment, you only need a servomotor and several jumper wires.
Connection & Sample Program
There are two ways to control a servomotor with Arduino. One is to use a common digital sensor port of Arduino to produce square wave with different duty cycle to simulate PWM signal and use that signal to control the positioning of the motor. Another way is to directly use the Servo function of the Arduino to control the motor. In this way, the program will be easier but it can only control two-contact motor because for the servo function, only digital pin 9 ang 10 can be used. The Arduino drive capacity is limited. So if you need to control more than one motor, you will need external power.
Connection Diagram:
Sample Code:
int servopin=9;// select digital pin 9 for servomotor signal line int myangle;// initialize angle variable int pulsewidth;// initialize width variable int val; void servopulse(int servopin,int myangle)// define a servo pulse function { pulsewidth=(myangle*11)+500;// convert angle to 500-2480 pulse width digitalWrite(servopin,HIGH);// set the level of servo pin as “high” delayMicroseconds(pulsewidth);// delay microsecond of pulse width digitalWrite(servopin,LOW);// set the level of servo pin as “low” delay(20-pulsewidth/1000); } void setup() { pinMode(servopin,OUTPUT);// set servo pin as “output” Serial.begin(9600);// connect to serial port, set baud rate at “9600” Serial.println("servo=o_seral_simple ready" ) ; } void loop()// convert number 0 to 9 to corresponding 0-180 degree angle, LED blinks corresponding number of time { val=Serial.read();// read serial port value if(val>'0'&&val<='9') { val=val-'0';// convert characteristic quantity to numerical variable val=val*(180/9);// convert number to angle Serial.print("moving servo to "); Serial.print(val,DEC); Serial.println(); for(int i=0;i<=50;i++) // giving the servo time to rotate to commanded position { servopulse(servopin,val);// use the pulse function } } }
Project 5: Bluetooth Module
Introduction:
This Bluetooth module can easily achieve serial wireless data transmission. Its operating frequency is among the most popular 2.4GHz ISM frequency band (i.e. Industrial, scientific and medical). It adopts Bluetooth 2.1+EDR standard. In Bluetooth 2.1, signal transmit time of different devices stands at a 0.5 seconds interval so that the workload of bluetooth chip can be reduced substantially and more sleeping time can be saved for bluetooth. This module is set with serial interface, which is easy-to-use and simplifying overall design/development cycle.
Specification:
Bluetooth Protocol: Bluetooth 2.1+ EDR Standard
USB Protocol: USB v1.1/2.0
Operating Frequency: 2.4GHz ISM Frequency Band
Modulation Mode: Gauss Frequency Shift Keying
Transmit Power: ≤ 4dBm, Second Stage
Sensitivity: ≤-84dBm at 0.1% Bit Error Rate
Transmission Speed: 2.1Mbps(Max)/160 kbps(Asynchronous); 1Mbps/1Mbps(Synchronous)
Safety Feature: Authentication and Encryption
Supported Configuration: Bluetooth Serial Port (major and minor)
Supply Voltage: +3.3 VDC 50mA
Operating Temperature: -20 to 55℃
Connection Diagram:
Sample Code:
int val; int ledpin=13; void setup() { Serial.begin(9600); pinMode(ledpin,OUTPUT); } void loop() { val=Serial.read(); if(val=='a') { digitalWrite(ledpin,HIGH); delay(250); digitalWrite(ledpin,LOW); delay(250); Serial.println("keyestudio");
Project 6: L298N Motor Driver
Introduction:
Using L298N made by ST Company as the control chip, the module has characteristics of strong driving ability, low calorific value and strong anti-interference ability. This module can use built-in 78M05 for electric work via a driving power supply part. But to avoid the damage of the voltage stabilizing chip, please use an external 5V logic supply when using more than 12V driving voltage.
Using large capacity filter capacitor, this module can follow current to protect diodes, and improve reliability.
Specification:
Working Mode: H bridge (double lines)
Control Chip: L298N (ST)
Logical Voltage: 5V
Driving Voltage: 5V-35V
Logical Current: 0mA-36mA
Driving Current: 2A (MAX single bridge)
Storage Temperature: (-20 °C)-(+135 °C)
Maximum Power: 25W
Weight: 30g
Periphery Dimension: 43 x 43 x 27 mm(L x W x H)
Circuit Connection:
Sample Code:
int IN2=6; int IN3=7; int IN4=8; int ENA=9; int ENB=10; void setup() { for (int i = 5; i <11; i ++) { pinMode(i, OUTPUT); } } void loop() { // rotate CW digitalWrite(IN1,LOW); digitalWrite(IN2,HIGH); analogWrite(ENA,200); digitalWrite(IN3,LOW); digitalWrite(IN4,HIGH); analogWrite(ENB,200); delay(1000); // pause for 1S analogWrite(ENA,0); analogWrite(ENB,0); delay(1000); // rotate CCW digitalWrite(IN1,HIGH); digitalWrite(IN2,LOW); analogWrite(ENA,100); digitalWrite(IN3,HIGH); digitalWrite(IN4,LOW); analogWrite(ENB,100); delay(1000); // pause for 1S analogWrite(ENA,0); analogWrite(ENB,0); delay(1000); }
Project 7:keyestudio 1602 I2C Module
Introduction:
This is great LCD display compatible with arduino. With limited pin resources, your project will quickly run out of resources using normal LCDs. With this I2C interface LCD module, you only need 2 lines (I2C)to display the information.If you already have I2C devices in your project, this LCD module actually cost no more resources at all. The address can be set 0x27.
Specification:
I2C Address: 0x27
Back Lit (Blue with white char color)
Supply Voltage: 5V
Interface:I2C/TWI x1,Gadgeteer interface x2
Adjustable Contrast
Size:82x35x18 mm
Connection Diagram:
I602 is equipped with 4 pins in total. SCL should be connected to analog 5, SDA to analog 4, VCC to +5V and GND to ground.
Connection :
Sample Code:
//Compatible with the Arduino IDE 1.0 //Library version:1.1 #include <Wire.h> #include <LiquidCrystal_I2C.h> LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display void setup() { lcd.init(); // initialize the lcd lcd.init(); // Print a message to the LCD. lcd.backlight(); lcd.setCursor(3,0); lcd.print("Hello, world!"); lcd.setCursor(2,1); lcd.print("keyestudio!"); } void loop() {}
Get libraries of Wire and LiquidCrystal_I2C from :
Project 8: Line Tracking of Smart Car
Introduction:
This project introduces a simple and automatic line tracking system of a car based on Arduino microcontroller.This car ,regarding UNO as main control, detect black line by IR photoelectric sensor and send the feedback to Arduino. Arduino will analyses the feedback signal and then control the driver motor to adjust the car diversion. Finally the car is able to go around the black line automatically. In addition, you can observe the state of the car through keyestudio 1602 I2C Module.
Principle:
1.Black absorbs most light. When the plane isn’t black, most IR emitted by the sensor is reflected back. So the sensor output low level at 0.
2.When there is a sensor above black line, since reflectivity of black is small ,little IR is reflected back under demand that the sensor works. Therefore, the sensor output 1.
3.We just need to know the output of the sensor is 1 or 0 with Arduino to detect black line.
4.Arduino control the motion of the car according to receiving signal. The system scheme is showed by following picture 1-1.
5.The system is composed of main control circuit, power supply, IR detecting module ,motor and driver module. The structure chart of the system is showed by picture 2-1.
Schematic Diagram:
Connection Diagram:
Sample Code:
#include <LiquidCrystal_I2C.h> #include <Wire.h> #define SensorLeft 6 //input pin of left sensor #define SensorMiddle 9 //input pin of middle sensor #define SensorRight 11 //input pin of right sensor unsigned char SL; //state of left sensor unsigned char SM; //state of middle sensor unsigned char SR; //state of right sensor #define Lpwm_pin 5 //pin of controlling speed---- ENA of motor driver board #define Rpwm_pin 10 //pin of controlling speed---- ENA of motor driver board int pinLB=2; //pin of controlling diversion----IN1 of motor driver board int pinLF=4; //pin of controlling diversion----IN2 of motor driver board int pinRB=7; //pin of controlling diversion----IN3 of motor driver board int pinRF=8; //pin of controlling diversion----IN4 of motor driver board unsigned char Lpwm_val =180;//the speed of left wheel at 180 in initialization unsigned char Rpwm_val = 180;//the speed of right wheel at 180 in initialization int Car_state=0; //state of car moving LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 void LCD1602_init(void) { lcd.init(); lcd.backlight(); lcd.clear(); } void Sensor_IO_Config() { pinMode(SensorLeft,INPUT); pinMode(SensorMiddle,INPUT); pinMode(SensorRight,INPUT); } void Sensor_Scan(void) { SL = digitalRead(SensorLeft); SM = digitalRead(SensorMiddle); SR = digitalRead(SensorRight); } void M_Control_IO_config(void)//initialized function of IO of motor driver { pinMode(pinLB,OUTPUT); // pin 2--IN1 of motor driver board pinMode(pinLF,OUTPUT); // pin 4--IN2 of motor driver board pinMode(pinRB,OUTPUT); // pin 7--IN3 of motor driver board pinMode(pinRF,OUTPUT); // pin 8--IN4 of motor driver board pinMode(Lpwm_pin,OUTPUT); // pin 5 (PWM) --ENA of motor driver board pinMode(Rpwm_pin,OUTPUT); // pin 10 (PWM) --ENB of motor driver board } void Set_Speed(unsigned char Left,unsigned char Right)//setting function of speed { analogWrite(Lpwm_pin,Left); analogWrite(Rpwm_pin,Right); } void advance() // going forwards { digitalWrite(pinRB,LOW); // making motor move towards right rear digitalWrite(pinRF,HIGH); digitalWrite(pinLB,LOW); // making motor move towards left rear digitalWrite(pinLF,HIGH); Car_state = 1; show_state(); } void turnR() //turning on the right(dual wheels) { digitalWrite(pinRB,LOW); //making motor move towards right rear digitalWrite(pinRF,HIGH); digitalWrite(pinLB,HIGH); digitalWrite(pinLF,LOW); //making motor move towards left front Car_state = 4; show_state(); } void turnL() //turning on the left(dual wheels) { digitalWrite(pinRB,HIGH); digitalWrite(pinRF,LOW ); //making motor move towards right front digitalWrite(pinLB,LOW); //making motor move towards left rear digitalWrite(pinLF,HIGH); Car_state = 3; show_state(); } void stopp() //stop { digitalWrite(pinRB,HIGH); digitalWrite(pinRF,HIGH); digitalWrite(pinLB,HIGH); digitalWrite(pinLF,HIGH); Car_state = 5; show_state(); } void back() //back { digitalWrite(pinRB,HIGH); //making motor move towards right rear digitalWrite(pinRF,LOW); digitalWrite(pinLB,HIGH); //making motor move towards left rear digitalWrite(pinLF,LOW); Car_state = 2; show_state() ; } void show_state(void) //showing current state of the car { lcd.setCursor(0, 1); //showing from second row switch(Car_state) { case 1:lcd.print(" Go ");Serial.print("\n GO"); break; case 2:lcd.print("Back ");Serial.print("\n Back"); break; case 3:lcd.print("Left ");Serial.print("\n Left"); break; case 4:lcd.print("Right");Serial.print("\n Right"); break; case 5:lcd.print("Stop ");Serial.print("\n Stop"); break; default: break; } } void setup() { LCD1602_init(); Sensor_IO_Config(); M_Control_IO_config(); //motor controlling the initialization of IO Set_Speed(Lpwm_val,Rpwm_val); //setting initialization of speed lcd.clear(); lcd.setCursor(0, 0); //cursor set in first row and first column, lcd.print(" Wait Signal "); stopp(); } unsigned char old_SL,old_SM,old_SR; void loop() { Sensor_Scan(); if (SM == HIGH)// middle sensor in black area { if (SL == LOW & SR == HIGH) // black on left, white on right, turn left { turnR(); } else if (SR == LOW & SL == HIGH) // white on left, black on right, turn right { turnL(); } else // white on both sides, going forward { advance(); } } else // middle sensor on white area { if (SL== LOW & SR == HIGH)// black on left, white on right, turn left { turnR(); } else if (SR == LOW & SL == HIGH) // white on left, black on right, turn right { turnL(); } else // all white, stop { back(); delay(100); stopp() ; } } }
Project 9: Ultraviolet Obstacle Avoidance of Smart Car
Introduction:
This project ,regarding Arduino UNO as main control, detect front obstacle by ultrasonic sensor and platform motor, and send the feedback to Arduino. Arduino will analyses the feedback signal and then control the driver motor to adjust the car diversion. Finally the car is able to avoid obstacle automatically and keep going.
Principle:
1.Ultrasonic detecting distance: one port emits high level more than 10 US. Once it outputting level, open potentiometer to time. When the port becomes low level, read out current value. Use the time of detecting distance to calculate distance.
2.Use ultrasonic to detect the distance between obstacle and car, so that control the motion of the car according to the data.
3. If the distance between the car and obstacle is less than 20 cm, the car goes backward; if the distance is no less than 40 cm, the car goes forwards; if the distance is less than 40cm , the motor turns to detect the distance between car and left obstacle or right obstacle; if the distance between car and left obstacle, the distance between car and right obstacle are less than 15 cm, the car goes backward; if the distance between car and left obstacle is larger , the car turns left; if the distance between car and left obstacle is less than or equal to the distance between car and right obstacle, the car turns right.
Schematic Diagram:
Connection Diagram:
Sample Code:
#include <Servo.h> int pinLB = 2; // defining pin 12 int pinLF = 4; // defining pin 3 int pinRB = 7; // defining pin 13 int pinRF = 8; // defining pin 11 int Lpwm_pin = 5; //adjusting speed int Rpwm_pin = 10; //adjusting speed // unsigned char Lpwm_val = 200; unsigned char Rpwm_val = 200; int inputPin = A0; // defining receiving pin of ultrasonic signal int outputPin =A1; // defining emitting pin of ultrasonic signal int Fspeedd = 0; // forward speed int Rspeedd = 0; // right speed int Lspeedd = 0; // left speed int directionn = 0; // front=8 back=2 left=4 right=6 Servo myservo; // setting myservo int delay_time = 250; // time for servo motor turning backward int Fgo = 8; // going forward int Rgo = 6; // turning right int Lgo = 4; // turning left int Bgo = 2; // turning backward void setup() { Serial.begin(9600); // defining output pin of motor pinMode(pinLB,OUTPUT); // pin 12 pinMode(pinLF,OUTPUT); // pin 3 (PWM) pinMode(pinRB,OUTPUT); // pin 13 pinMode(pinRF,OUTPUT); // pin 11 (PWM) pinMode(inputPin, INPUT); // defining input pin of ultrasonic pinMode(outputPin, OUTPUT); // defining output pin of ultrasonic myservo.attach(3); // defining output pin9 of motor } void advance() // going forward { digitalWrite(pinLB,LOW); // right wheel going forward digitalWrite(pinRB, LOW); // left wheel going forward digitalWrite(pinLF,HIGH); digitalWrite(pinRF,HIGH); } void stopp() //stop { digitalWrite(pinRB,HIGH); digitalWrite(pinRF,HIGH); digitalWrite(pinLB,HIGH); digitalWrite(pinLF,HIGH); } void right() //turning right(single wheel) { digitalWrite(pinRB,LOW); //making motor move towards right rear digitalWrite(pinRF,HIGH); digitalWrite(pinLB,HIGH); digitalWrite(pinLF,LOW); //making motor move towards left front } void left() //turning left(single wheel) { digitalWrite(pinRB,HIGH); digitalWrite(pinRF,LOW ); //making motor move towards right front digitalWrite(pinLB,LOW); //making motor move towards left rear digitalWrite(pinLF,HIGH); } void back() //going backward { digitalWrite(pinRB,HIGH); //making motor move towards right rear digitalWrite(pinRF,LOW); digitalWrite(pinLB,HIGH); //making motor move towards left rear digitalWrite(pinLF,LOW); } void detection() //measuring 3 angles(0.90.179) { int delay_time = 250; // time for servo motor turning backward ask_pin_F(); // reading out the front distance if(Fspeedd < 20) // assuming the front distance less than 10cm { stopp(); // clear output material delay(100); back(); // going backward for 0.2 second delay(200); } if(Fspeedd < 40) // assuming the front distance less than 25cm { stopp(); delay(100); // clear output material ask_pin_L(); // reading out the left distance delay(delay_time); // waiting servo motor to be stable ask_pin_R(); // reading out the right distance delay(delay_time); // waiting servo motor to be stable if(Lspeedd > Rspeedd) //assuming left distance more than right distance { directionn = Lgo; //turning left } if(Lspeedd <= Rspeedd) //assuming left distance less than or equal to right distance { directionn = Rgo; //turning right } if (Lspeedd < 15 && Rspeedd < 15) //assuming both left distance and right distance less than 10cm { directionn = Bgo; //going backward } } else //assuming the front distance more than 25 cm { directionn = Fgo; //going forward } } void ask_pin_F() // measuring the front distance { myservo.write(90); digitalWrite(outputPin, LOW); // ultrasonic launching low voltage at 2μs delayMicroseconds(2); digitalWrite(outputPin, HIGH); // ultrasonic launching high voltage at 10μs,at least at10μs delayMicroseconds(10); digitalWrite(outputPin, LOW); // keeping ultrasonic launching low voltage float Fdistance = pulseIn(inputPin, HIGH); // time of error reading Fdistance= Fdistance/5.8/10; // converting time into distance(unit:cm) Fspeedd = Fdistance; // reading-in Fspeedd(fore speed) with distance } void ask_pin_L() // measuring left distance { myservo.write(5); delay(delay_time); digitalWrite(outputPin, LOW); // ultrasonic launching low voltage at 2μs delayMicroseconds(2); digitalWrite(outputPin, HIGH); // ultrasonic launching high voltage at 10μs,at least at10μs delayMicroseconds(10); digitalWrite(outputPin, LOW); // keeping ultrasonic launching low voltage float Ldistance = pulseIn(inputPin, HIGH); // time of error reading Ldistance= Ldistance/5.8/10; // converting time into distance(unit:cm) Lspeedd = Ldistance; //reading-in Lspeedd(left speed) with distance } void ask_pin_R() // measuring right distance { myservo.write(177); delay(delay_time); digitalWrite(outputPin, LOW); // ultrasonic launching low voltage at 2μs delayMicroseconds(2); digitalWrite(outputPin, HIGH); // ultrasonic launching high voltage at 10μs,at least at10μs delayMicroseconds(10); digitalWrite(outputPin, LOW); // keeping ultrasonic launching low voltage float Rdistance = pulseIn(inputPin, HIGH); // time of error reading Rdistance= Rdistance/5.8/10; // onverting time into distance(unit:cm) Rspeedd = Rdistance; // reading-in Rspeedd(right speed) with distance } void loop() { myservo.write(90); //making motor regression, being ready for next measurement detection(); //measuring angle and deciding which direction it moves towards if(directionn == 2) //supposing direction = 2(back up) { back(); delay(800); // back up left() ; delay(200); //moving slightly towards left(avoiding locked) } if(directionn == 6) //supposing direction = 6(turning right) { back(); delay(100); right(); delay(600); // turning right } if(directionn == 4) //supposing direction = 4(turning left) { back(); delay(600); left(); delay(600); // turning left } if(directionn == 8) //supposing direction = = 8(going forwards) { advance(); // going forwards normally delay(100); } }