arduino-projects/pneumatic-titration/pneumatic-titration.ino

179 lines
4.5 KiB
C++

int timeInterval = 0;
int analogPin = 5;
int drips = 0;
float grams = 30;
float totgrams = 0;
float phSense;
float mass = 39.99711;
bool titrate = false;
void setup() {
// put your setup code here, to run once:
if (drips > 0) {
grams = grams - (2.333333/20 * drips);
}
pinMode(2, OUTPUT);
pinMode(3, OUTPUT);
pinMode(4, OUTPUT);
pinMode(9, INPUT); //stream; 2 seconds
pinMode(10, OUTPUT);
pinMode(11, INPUT); //squirt; 0.5 seconds
pinMode(12, INPUT); //drip; 0.01 seconds
Serial.begin(9600);
digitalWrite(4, LOW); // start extended
}
void loop() {
timeInterval=0;
if(digitalRead(7) == 0) {
digitalWrite(4, HIGH); // up and down
delay(2500);
digitalWrite(3, HIGH); // number 3 is spring-loaded
delay(1500);
digitalWrite(4, LOW);
delay(250);
motor(255);
delay(3000);
titrate = true; //true, false for now
if(digitalRead(7) == 0 || titrate == false) {
Serial.println("CANCELLING");
stopmotor();
titrate = false;
digitalWrite(4, HIGH); // up and down
delay(2500);
digitalWrite(3, LOW); // number 3 is spring-loaded
delay(1500);
digitalWrite(4, LOW);
delay(500);
while(true) {
loop();
}
}
}
if(digitalRead(9) == 0)
{
motor(255);
delay(2000);
stopmotor();
//timeInterval = 175 * grams;
//totgrams = totgrams + grams;
}
else if(digitalRead(11) == 0 || titrate == true)
{
takepH();
float rate = 1 - (phSense / 7)*(phSense / 7);
while (rate > 0 && rate <=1) {
motor(255);
if(digitalRead(7) == 0) {
Serial.println("CANCELLING");
titrate = false;
stopmotor();
digitalWrite(4, HIGH); // up and down
delay(1500);
digitalWrite(3, LOW); // number 3 is spring-loaded
delay(2000);
digitalWrite(4, LOW);
while(true) {
loop();
}
}
if(rate > 0.8) {
rate = rate * 2;
}
if(phSense > 3) {
rate = 0.01;
}
timeInterval = rate * 175;
if (timeInterval < 30) {
timeInterval = 15;
}
totgrams = totgrams + timeInterval / 175;
digitalWrite(2, HIGH);
delay(timeInterval);
digitalWrite(2, LOW);
for(int i = 0; i < 10; i += 1){
delay(rate * 900);
if(digitalRead(7) == 0) {
Serial.println("CANCELLING");
titrate = false;
stopmotor();
digitalWrite(4, HIGH); // up and down
delay(1500);
digitalWrite(3, LOW); // spring-loaded
delay(2000);
digitalWrite(4, LOW);
while(true) {
loop();
}
}
}
takepH();
rate = 1 - (phSense / 7)*(phSense / 7);
delay(125);
}
Serial.println("done, returning pneumatics to holding point");
titrate = false;
stopmotor();
digitalWrite(4, HIGH); // up and down
delay(1500);
digitalWrite(3, LOW); // spring-loaded
delay(1500);
digitalWrite(4, LOW);
timeInterval = 0;
//timeInterval = 500;
//totgrams = totgrams + 2.857143;
}
else if (digitalRead(12) == 0 || drips > 0)
{
timeInterval = 15;
totgrams = totgrams + 2.333333/20;
drips --;
}
//Serial.print("Time Valve is open = ");
//Serial.println(timeInterval);
if(timeInterval > 0)
{
digitalWrite(2, HIGH);
delay(timeInterval);
digitalWrite(2, LOW);
takepH();
}
delay(50);
}
float takepH()
{
int samples = 30;
int aRead = 0;
for (int i = 0; i < samples ; i++)
{
aRead += analogRead(analogPin);
delay(100);
}
phSense = 0;
float phvolt = 5.0 * aRead/ (1023 * samples); // assuming 5V reference
phSense = 14 - phvolt/0.25; // convert voltage to pH
phSense = phSense - 1.3;
Serial.print("Time Interval = ");
Serial.println(timeInterval);
Serial.print("Analog in reading: ");
Serial.print(aRead/20); // print pH value on serial monitor
Serial.print(" - Calculated pH Level: ");
Serial.println(phSense, 2); // 1 = one decimal, 2 = two decimals, etc
Serial.print("Grams: ");
Serial.println(totgrams * 0.87, 4);
float molarity = 0.0025 * totgrams * 0.9 / 49.6;
Serial.print("Molarity of 20 mL of acid: ");
Serial.println(molarity, 10);
// removed the /10
delay(500);
}
void motor(int speed) {
analogWrite(10, speed);
//delay(timerun);
//analogWrite(10, 0);
}
void stopmotor() {
analogWrite(10, 0);
//delay(timerun);
//analogWrite(10, 0);
}