Bộ điều khiển PID - ứng dụng phần 2 - xe dò line dùng thuật toán PID

Tiép nối bài viết về xe dò line cảm ơn Đỗ Hữu Toàn đã viết hộ mình phần 4. hôm nay mình sẽ làm cho chiếc xe dò line đi mượt và có hồn hơn 

Các bạn chuẩn bị phần cứng như phần 4 có điều phải nối lại dây theo code sau mình không muốn nhắc đến phần cứng 

Xây dựng chương trình và thuật toán

Giá trị sensor Vị trí của xe
0 0 1 0 0 chính giữa
1 0 0 0 0 bên phải line
0 0 0 0 1   bên trái line

Như thế này nếu số 1 là giá trị khi nhận ra line thì số 1 càng dịch sang trái hoặc sang phải thì ta có 10 mức lệch line trong cả trường hợp có hai cảm biến cùng phát hiện ra line, khi đó chúng ta sẽ áp dụng PID để tính toán để đưa ra giá trị điều kiển PWM đến mạch cầu H

các giá trị khi lệch line

Giá trị sensor Giá trị tương ứng
0 0 0 0 1 4
0 0 0 1 1 3
0 0 0 1 0 2
0 0 1 1 0 1
0 0 1 0 0 0
0 1 1 0 0 -1
0 1 0 0 0 -2
1 1 0 0 0 -3
1 0 0 0 0 -4
0 0 0 0 0 -5

Lập trình để nhận và chuyển đổi giá trị

void read_sensor_values()
{
  sensor[0]=digitalRead(A0);
  sensor[1]=digitalRead(A1);
  sensor[2]=digitalRead(A2);
  sensor[3]=digitalRead(A3);
  sensor[4]=digitalRead(A4);
  
  if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==0)&&(sensor[4]==0)&&(sensor[4]==1))
  error=4;
  else if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==0)&&(sensor[4]==1)&&(sensor[4]==1))
  error=3;
  else if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==0)&&(sensor[4]==1)&&(sensor[4]==0))
  error=2;
  else if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==1)&&(sensor[4]==1)&&(sensor[4]==0))
  error=1;
  else if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==1)&&(sensor[4]==0)&&(sensor[4]==0))
  error=0;
  else if((sensor[0]==0)&&(sensor[1]==1)&&(sensor[2]==1)&&(sensor[4]==0)&&(sensor[4]==0))
  error=-1;
  else if((sensor[0]==0)&&(sensor[1]==1)&&(sensor[2]==0)&&(sensor[4]==0)&&(sensor[4]==0))
  error=-2;
  else if((sensor[0]==1)&&(sensor[1]==1)&&(sensor[2]==0)&&(sensor[4]==0)&&(sensor[4]==0))
  error=-3;
  else if((sensor[0]==1)&&(sensor[1]==0)&&(sensor[2]==0)&&(sensor[4]==0)&&(sensor[4]==0))
  error=-4;
  else if((sensor[0]==0)&&(sensor[1]==0)&&(sensor[2]==0)&&(sensor[4]==0)&&(sensor[4]==0))
    if(error==-4) error=-5;
    else error=5;

}

Bây giờ là phần quan trọng áp dụng công thức PID ta có code để tính toán đưa ra giá trị điều kiển PWM ( mình tham khảo trên internet nha )

PID_value chính là biến để lưu giá trị điều kiển động cơ
void calculate_pid()
{
    P = error;
    I = I + error;
    D = error – previous_error;
    
    PID_value = (Kp*P) + (Ki*I) + (Kd*D);
    
    previous_error=error;
}
Khi đã có PID_value lúc này chúng ta biết xe đang lệch line như thế nào và cần giá trị nào để phù hợp nhất điều kiển xe đi đúng line 

Motor control

void motor_control()
{
    // Calculating the effective motor speed:
    int left_motor_speed = initial_motor_speed-PID_value;
    int right_motor_speed = initial_motor_speed+PID_value;
    
    // The motor speed should not exceed the max PWM value
    constrain(left_motor_speed,0,255);
    constrain(right_motor_speed,0,255);
    
    analogWrite(9,left_motor_speed);   //Left Motor Speed
    analogWrite(10,right_motor_speed);  //Right Motor Speed
    //following lines of code are to make the bot move forward
    /*The pin numbers and high, low values might be different
    depending on your connections */
    digitalWrite(4,HIGH);
    digitalWrite(5,LOW);
    digitalWrite(6,LOW);
    digitalWrite(7,HIGH);
}

Bây giời đến void loop

void loop()
{
    read_sensor_values();
    calculate_pid();
    motor_control();
}

và đây là hoạt động của xe

Những hình ảnh về dự án: 
Bài viết truyền cảm hứng: 
lên
34 thành viên đã đánh giá bài viết này hữu ích.
Các dự án được truyền cảm hứng

ST7565 và ESP8266 - Màn hình LCD bự chà bá chưa đến 100k cho thế giới IoT

Mình rất thích LCD ST7565 này, và đã đặt liền 4 con mà mỗi con quá rẻ có 20k. Nhưng khổ một điều, điện áp hoạt động và IO của LCD ST7565 có 3.3V. Bản thân mình lại không thích việc chơi điện trở để chơi LCD này với Arduino. Lý do đơn giản là phải hàn quá nhiều, mình lại lười crying. Hổm nay, mình đang làm loạt bài về ESP8266 và cũng phải gặp vấn đề điện trở để làm cầu phân áp khi giao tiếp giữa ESP8266 và Arduino.

lên
17 thành viên đã đánh giá bài viết này hữu ích.

Thư viện ST7565 trên Arduino Create - Thử nghiệm đầu tiên: Hoàn hảo!

Mình rất tự hào và hãnh diện, khi thư viện made in Việt Nam đầu tiên của Thái Sơn (Nick Chung) được mình tải lên tại Arduino Create với mục đích thử nghiệm việc biên dịch code online trên Arduino Create đã hoàn thành công việc của nó ngay trong lần thử đầu tiên. Qua bài viết này, mình xin hướng dẫn các bạn lập trình Arduino với Arduino Create thông qua việc làm một ví dụ mẫu về việc cài thư viện và sử dụng nó trên Arduino Create.

lên
7 thành viên đã đánh giá bài viết này hữu ích.
Các bài viết cùng tác giả

Giới thiệu mô-đun Voice Recognition Module V3 ( điều kiển giọng nói với ARDUINO )

Bài viết sẽ gới thiệu với các bạn về một mô-đun nhận giạng giọng nói. Với mô-đun này các bạn có thể tạo ra nhiều sản phẩm rất ứng dụng với mình, mình sẽ ứng dụng nó cho người khuyết tật như điều khiển thiết bị bằng giọng nói trong thời gian thực.

lên
33 thành viên đã đánh giá bài viết này hữu ích.
Từ khóa: 

Nghiêng lắc điện thoại để điều kiển ô tô bạn đã thử chưa ???

Bài viết sẽ hướng dẫn các bạn cách để xây dựng một app để có thể nghiêng lắc điều kiển ô tô. Giống với game đua oto chúng ta thường chơi trên điện thoại "nói vậy thôi không giống lắm đâu" mà mình sưu tầm được từ một bài trên instructables

lên
27 thành viên đã đánh giá bài viết này hữu ích.