-
Notifications
You must be signed in to change notification settings - Fork 0
/
sonar.ino
103 lines (64 loc) · 1.6 KB
/
sonar.ino
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#include <Servo.h>
#define MAX_DISTANCE_RANGE 50
int triger_pin = 2;
int echo_pin = 4;
long prev_duration = 0;
long current_duration = 0;
float distance_cm = 0;
int angle = 0;
Servo servo;
void setup() {
Serial.begin(9600);
servo.attach(9);
}
void loop() {
for(angle= 90; angle >= 1; angle -= 1){
servo.write(angle);
current_duration = get_duration();
distance_cm = current_duration/29/2;
if(prev_duration < current_duration && distance_cm < MAX_DISTANCE_RANGE) {
Serial.print(angle_from_vertical(angle));
Serial.print(" ,");
Serial.print(distance_cm);
Serial.print(",");
Serial.print(get_y_distance(to_radian(angle_from_vertical(angle)),distance_cm));
Serial.println();
}
prev_duration = current_duration;
}
delay(1000);
}
/**
* it returns the duration after hitting the object
*/
long get_duration() {
long duration;
pinMode(triger_pin,OUTPUT);
digitalWrite(triger_pin,LOW);
delayMicroseconds(2);
digitalWrite(triger_pin,HIGH);
delayMicroseconds(10);
digitalWrite(triger_pin,LOW);
pinMode(echo_pin,INPUT);
duration = pulseIn(echo_pin,HIGH);
delay(15);
return duration;
}
/**
* Converts angle into Radian
*/
float to_radian(int angle) {
return (PI/180) * angle;
}
/*
* To find y cordinate we have do x * tan(angle)
*/
float get_y_distance(float radian,float x_distance) {
return x_distance*tan(radian);
}
/*
* returns the absolute angle from vertical
*/
long angle_from_vertical(long angle) {
return abs(angle - 45);
}