haustorial/prosthesis_controller/prosthesis_controller.ino

105 lines
2.5 KiB
Arduino
Raw Normal View History

2024-09-06 13:33:19 +00:00
#include "definitions.h"
#include "vacuum.h"
#include "servo.h"
2024-09-11 09:40:46 +00:00
#include "bodytemp.h"
#include "behaviour.h"
2024-09-12 09:23:52 +00:00
#include "barometer.h"
2024-09-11 12:19:10 +00:00
#include "imu.h"
2024-09-06 13:33:19 +00:00
void setup() {
Serial.begin(115200);
pinMode(PIN_VIBRATION,OUTPUT);
analogWrite(PIN_VIBRATION,0);
2024-09-06 13:33:19 +00:00
pinMode(PIN_BUTTON,INPUT_PULLDOWN);
2024-09-11 09:40:46 +00:00
pinMode(PIN_LED,OUTPUT);
digitalWrite(PIN_LED,HIGH); //LOW=Light, HIGH=Off
2024-09-06 13:33:19 +00:00
initVacuum();
2024-09-11 09:40:46 +00:00
initBodytemp();
2024-09-06 13:33:19 +00:00
2024-09-12 09:23:52 +00:00
initBarometer();
2024-09-11 12:19:10 +00:00
initIMU(7.54,-15.26,-1.41);
2024-09-06 13:33:19 +00:00
pinMode(PIN_INPUTARM1,INPUT);
2024-09-11 09:40:46 +00:00
pinMode(PIN_INPUTARM2,INPUT);
pinMode(PIN_INPUTARM3,INPUT);
2024-09-06 14:51:50 +00:00
pinMode(PIN_INPUTAUX,INPUT);
2024-09-06 14:51:50 +00:00
initServos();
2024-09-06 13:33:19 +00:00
}
void loop() {
unsigned long loopmillis=millis();
2024-09-11 09:40:46 +00:00
bool body_present=checkBodypresence(loopmillis);
digitalWrite(PIN_LED,!body_present);
2024-09-06 13:33:19 +00:00
loopVacuum(loopmillis);
2024-09-11 12:19:10 +00:00
2024-09-12 09:23:52 +00:00
loopBarometer(loopmillis);
2024-09-11 12:19:10 +00:00
loopIMU(loopmillis);
bool bellyup=isBellyUp();
2024-09-11 09:40:46 +00:00
bool buttonstate=digitalRead(PIN_BUTTON); //Temporary Vacuum Button. HIGH=Pressed
if (buttonstate) { //Button pressed
setVacuum(false); //release
}else{
setVacuum(body_present);
}
bool contact_main=digitalRead(PIN_INPUTARM1); //Sensor on tip of arm
2024-09-11 12:19:10 +00:00
bool contact_peripheralL=digitalRead(PIN_INPUTARM2); //Sensor on tip of arm
bool contact_peripheralR=digitalRead(PIN_INPUTARM3); //Sensor on tip of arm
2024-09-11 15:15:34 +00:00
float pitch=-getAngleY();
float roll=-getAngleX();
2024-09-12 09:23:52 +00:00
updateMood(loopmillis,getGyroAngleX(),getGyroAngleY(),getGyroAngleZ(),bellyup,body_present,contact_main,contact_peripheralL,contact_peripheralR,getBarometerHeight(),getAmbienttemp(),getObjecttemp(),getAveragePumpspeed(),getAverageServoPositionerror());
2024-09-11 15:15:34 +00:00
updateMatrixWeights(loopmillis,bellyup,body_present,contact_main,contact_peripheralL,contact_peripheralR,pitch,roll);
updateServosByWeights(loopmillis,pitch,roll);
2024-09-11 09:40:46 +00:00
2024-09-11 15:15:34 +00:00
loopServos(loopmillis);
2024-09-06 14:51:50 +00:00
2024-09-06 13:33:19 +00:00
2024-09-11 09:40:46 +00:00
2024-09-06 13:33:19 +00:00
//Print Debug Information
static unsigned long last_print=0;
if (loopmillis - last_print >100) {
last_print=loopmillis;
2024-09-06 14:51:50 +00:00
//printVacuumValues();
//Serial.print(" Vac="); Serial.print(vac);
2024-09-11 12:19:10 +00:00
//printServoDebug();
//Serial.println();
2024-09-11 09:40:46 +00:00
//printBodytempDebug();
2024-09-11 12:19:10 +00:00
2024-09-11 09:40:46 +00:00
2024-09-12 09:23:52 +00:00
Serial.print("Servo Error:");Serial.print(getAverageServoPositionerror()); Serial.println();
Serial.print("Avg Pump:");Serial.print(getAveragePumpspeed()); Serial.println();
Serial.print("Height:");Serial.print(getBarometerHeight()); Serial.println();
2024-09-06 14:51:50 +00:00
2024-09-12 09:23:52 +00:00
Serial.print("GyroAngle: ");Serial.print(getGyroAngleX()); Serial.print(", ");Serial.print(getGyroAngleY()); Serial.print(", ");Serial.print(getGyroAngleZ()); Serial.println();
2024-09-06 13:33:19 +00:00
2024-09-12 09:23:52 +00:00
Serial.println();
2024-09-06 13:33:19 +00:00
}
}