make acrylic art code actually work (using tinkercad, parts not in yet)
parent
a404925725
commit
b328a4b00e
@ -1,21 +1,108 @@
|
|||||||
|
#include <FastLED.h>
|
||||||
int light = 0;
|
int light = 0;
|
||||||
|
int r = 9;
|
||||||
|
int g = 10;
|
||||||
|
int b = 11;
|
||||||
void setup() {
|
void setup() {
|
||||||
|
Serial.begin(9600);
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
int ss = 30; // sample size for light sensor
|
int ss = 100; // sample size for light sensor
|
||||||
int average = 0;
|
int average = 0;
|
||||||
for (int x = 0; x < ss; x++) {
|
for (int x = 0; x < ss; x++) {
|
||||||
average += analogRead(light);
|
average += analogRead(light) / 4;
|
||||||
delay(1);
|
delay(3);
|
||||||
}
|
}
|
||||||
average /= ss;
|
average /= ss;
|
||||||
String bitIn = "";
|
CRGB color = CHSV(average, 255, 255);
|
||||||
for(int x = 0; x <9; x++) {
|
analogWrite(9, color.r);
|
||||||
bitIn += average >> x;
|
analogWrite(10, color.g);
|
||||||
}
|
analogWrite(11, color.b);
|
||||||
int a = bitIn.substring(0, 3).toInt();
|
Serial.print("Hue: ");
|
||||||
int b = bitIn.substring(3, 6).toInt();
|
Serial.print(average);
|
||||||
int c = bitIn.substring(6, 9).toInt();
|
Serial.print(", RGB : ");
|
||||||
// set LED strips to c, b, a (in order RGB)
|
Serial.print(color.r);
|
||||||
|
Serial.print(", ");
|
||||||
|
Serial.print(color.g);
|
||||||
|
Serial.print(", ");
|
||||||
|
Serial.println(color.b);
|
||||||
|
}
|
||||||
|
/* Library free version for regular RGB LEDs (tinkercad), using HSV --> RGB code not by me
|
||||||
|
//#include <FastLED.h>
|
||||||
|
int light = 0;
|
||||||
|
void setup() {
|
||||||
|
Serial.begin(9600);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
int ss = 20; // sample size for light sensor
|
||||||
|
int average = 0;
|
||||||
|
for (int x = 0; x < ss; x++) {
|
||||||
|
average += analogRead(light) / 4;
|
||||||
|
delay(3);
|
||||||
|
}
|
||||||
|
average /= ss;
|
||||||
|
byte RedLight;
|
||||||
|
byte GreenLight;
|
||||||
|
byte BlueLight;
|
||||||
|
|
||||||
|
// this is the algorithm to convert from RGB to HSV
|
||||||
|
byte h = average;
|
||||||
|
byte s = 255;
|
||||||
|
byte v = 60;
|
||||||
|
h = (h * 192) / 256; // 0..191
|
||||||
|
unsigned int i = h / 32; // We want a value of 0 thru 5
|
||||||
|
unsigned int f = (h % 32) * 8; // 'fractional' part of 'i' 0..248 in jumps
|
||||||
|
|
||||||
|
unsigned int sInv = 255 - s; // 0 -> 0xff, 0xff -> 0
|
||||||
|
unsigned int fInv = 255 - f; // 0 -> 0xff, 0xff -> 0
|
||||||
|
byte pv = v * sInv / 256; // pv will be in range 0 - 255
|
||||||
|
byte qv = v * (256 - s * f / 256) / 256;
|
||||||
|
byte tv = v * (256 - s * fInv / 256) / 256;
|
||||||
|
|
||||||
|
switch (i) {
|
||||||
|
case 0:
|
||||||
|
RedLight = v;
|
||||||
|
GreenLight = tv;
|
||||||
|
BlueLight = pv;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
RedLight = qv;
|
||||||
|
GreenLight = v;
|
||||||
|
BlueLight = pv;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
RedLight = pv;
|
||||||
|
GreenLight = v;
|
||||||
|
BlueLight = tv;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
RedLight = pv;
|
||||||
|
GreenLight = qv;
|
||||||
|
BlueLight = v;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
RedLight = tv;
|
||||||
|
GreenLight = pv;
|
||||||
|
BlueLight = v;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
RedLight = v;
|
||||||
|
GreenLight = pv;
|
||||||
|
BlueLight = qv;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
//CRGB& color = CHSV(average, 255, 255);
|
||||||
|
Serial.print("Hue: ");
|
||||||
|
Serial.print(average);
|
||||||
|
Serial.print(", RGB : ");
|
||||||
|
Serial.print(RedLight);
|
||||||
|
Serial.print(", ");
|
||||||
|
Serial.print(GreenLight);
|
||||||
|
Serial.print(", ");
|
||||||
|
Serial.println(BlueLight);
|
||||||
|
analogWrite(9, RedLight);
|
||||||
|
analogWrite(10, GreenLight);
|
||||||
|
analogWrite(11, BlueLight);
|
||||||
|
}*/
|
||||||
|
@ -1,180 +1,206 @@
|
|||||||
int timeInterval = 0;
|
#include <controller.h>
|
||||||
int analogPin = 5;
|
#include <noise.h>
|
||||||
int drips = 0;
|
#include <lib8tion.h>
|
||||||
float grams = 30;
|
#include <colorutils.h>
|
||||||
float totgrams = 0;
|
#include <fastspi.h>
|
||||||
float phSense;
|
#include <colorpalettes.h>
|
||||||
float mass = 39.99711;
|
#include <fastled_progmem.h>
|
||||||
bool titrate = false;
|
#include <fastspi_dma.h>
|
||||||
void setup() {
|
#include <dmx.h>
|
||||||
// put your setup code here, to run once:
|
#include <pixeltypes.h>
|
||||||
if (drips > 0) {
|
#include <cpp_compat.h>
|
||||||
grams = grams - (2.333333/20 * drips);
|
#include <led_sysdefs.h>
|
||||||
}
|
#include <platforms.h>
|
||||||
pinMode(2, OUTPUT);
|
#include <hsv2rgb.h>
|
||||||
pinMode(3, OUTPUT);
|
#include <fastled_delay.h>
|
||||||
pinMode(4, OUTPUT);
|
#include <pixelset.h>
|
||||||
pinMode(9, INPUT); //stream; 2 seconds
|
#include <fastspi_ref.h>
|
||||||
pinMode(10, OUTPUT);
|
#include <color.h>
|
||||||
pinMode(11, INPUT); //squirt; 0.5 seconds
|
#include <FastLED.h>
|
||||||
pinMode(12, INPUT); //drip; 0.01 seconds
|
#include <chipsets.h>
|
||||||
Serial.begin(9600);
|
#include <fastspi_types.h>
|
||||||
digitalWrite(4, LOW); // start extended
|
#include <fastspi_bitbang.h>
|
||||||
}
|
#include <fastled_config.h>
|
||||||
void loop() {
|
#include <fastpin.h>
|
||||||
timeInterval=0;
|
#include <bitswap.h>
|
||||||
if(digitalRead(7) == 0) {
|
#include <power_mgt.h>
|
||||||
digitalWrite(4, HIGH); // up and down
|
#include <fastspi_nop.h>
|
||||||
delay(2500);
|
|
||||||
digitalWrite(3, HIGH); // number 3 is spring-loaded
|
int timeInterval = 0;
|
||||||
delay(1500);
|
int analogPin = 5;
|
||||||
digitalWrite(4, LOW);
|
int drips = 0;
|
||||||
delay(250);
|
float grams = 30;
|
||||||
motor(255);
|
float totgrams = 0;
|
||||||
delay(3000);
|
float phSense;
|
||||||
titrate = true; //true, false for now
|
float mass = 39.99711;
|
||||||
if(digitalRead(7) == 0 || titrate == false) {
|
bool titrate = false;
|
||||||
Serial.println("CANCELLING");
|
void setup() {
|
||||||
stopmotor();
|
// put your setup code here, to run once:
|
||||||
titrate = false;
|
if (drips > 0) {
|
||||||
digitalWrite(4, HIGH); // up and down
|
grams = grams - (2.333333/20 * drips);
|
||||||
delay(2500);
|
}
|
||||||
digitalWrite(3, LOW); // number 3 is spring-loaded
|
pinMode(2, OUTPUT);
|
||||||
delay(1500);
|
pinMode(3, OUTPUT);
|
||||||
digitalWrite(4, LOW);
|
pinMode(4, OUTPUT);
|
||||||
delay(500);
|
pinMode(9, INPUT); //stream; 2 seconds
|
||||||
while(true) {
|
pinMode(10, OUTPUT);
|
||||||
loop();
|
pinMode(11, INPUT); //squirt; 0.5 seconds
|
||||||
}
|
pinMode(12, INPUT); //drip; 0.01 seconds
|
||||||
}
|
Serial.begin(9600);
|
||||||
}
|
digitalWrite(4, LOW); // start extended
|
||||||
if(digitalRead(9) == 0)
|
}
|
||||||
{
|
void loop() {
|
||||||
motor(255);
|
timeInterval=0;
|
||||||
delay(2000);
|
if(digitalRead(7) == 0) {
|
||||||
stopmotor();
|
digitalWrite(4, HIGH); // up and down
|
||||||
//timeInterval = 175 * grams;
|
delay(2500);
|
||||||
//totgrams = totgrams + grams;
|
digitalWrite(3, HIGH); // number 3 is spring-loaded
|
||||||
}
|
delay(1500);
|
||||||
else if(digitalRead(11) == 0 || titrate == true)
|
digitalWrite(4, LOW);
|
||||||
{
|
delay(250);
|
||||||
takepH();
|
motor(255);
|
||||||
float rate = 1 - (phSense / 7)*(phSense / 7);
|
delay(3000);
|
||||||
while (rate > 0 && rate <=1) {
|
titrate = true; //true, false for now
|
||||||
motor(255);
|
if(digitalRead(7) == 0 || titrate == false) {
|
||||||
if(digitalRead(7) == 0) {
|
Serial.println("CANCELLING");
|
||||||
Serial.println("CANCELLING");
|
stopmotor();
|
||||||
titrate = false;
|
titrate = false;
|
||||||
stopmotor();
|
digitalWrite(4, HIGH); // up and down
|
||||||
digitalWrite(4, HIGH); // up and down
|
delay(2500);
|
||||||
delay(1500);
|
digitalWrite(3, LOW); // number 3 is spring-loaded
|
||||||
digitalWrite(3, LOW); // number 3 is spring-loaded
|
delay(1500);
|
||||||
delay(2000);
|
digitalWrite(4, LOW);
|
||||||
digitalWrite(4, LOW);
|
delay(500);
|
||||||
while(true) {
|
while(true) {
|
||||||
loop();
|
loop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if(rate > 0.8) {
|
if(digitalRead(9) == 0)
|
||||||
rate = rate * 2;
|
{
|
||||||
}
|
motor(255);
|
||||||
if(phSense > 3) {
|
delay(2000);
|
||||||
rate = 0.01;
|
stopmotor();
|
||||||
}
|
//timeInterval = 175 * grams;
|
||||||
timeInterval = rate * 175;
|
//totgrams = totgrams + grams;
|
||||||
if (timeInterval < 30) {
|
}
|
||||||
timeInterval = 15;
|
else if(digitalRead(11) == 0 || titrate == true)
|
||||||
}
|
{
|
||||||
totgrams = totgrams + timeInterval / 175;
|
takepH();
|
||||||
digitalWrite(2, HIGH);
|
float rate = 1 - (phSense / 7)*(phSense / 7);
|
||||||
delay(timeInterval);
|
while (rate > 0 && rate <=1) {
|
||||||
digitalWrite(2, LOW);
|
motor(255);
|
||||||
for(int i = 0; i < 10; i += 1){
|
if(digitalRead(7) == 0) {
|
||||||
delay(rate * 900);
|
Serial.println("CANCELLING");
|
||||||
if(digitalRead(7) == 0) {
|
titrate = false;
|
||||||
Serial.println("CANCELLING");
|
stopmotor();
|
||||||
titrate = false;
|
digitalWrite(4, HIGH); // up and down
|
||||||
stopmotor();
|
delay(1500);
|
||||||
digitalWrite(4, HIGH); // up and down
|
digitalWrite(3, LOW); // number 3 is spring-loaded
|
||||||
delay(1500);
|
delay(2000);
|
||||||
digitalWrite(3, LOW); // spring-loaded
|
digitalWrite(4, LOW);
|
||||||
delay(2000);
|
while(true) {
|
||||||
digitalWrite(4, LOW);
|
loop();
|
||||||
while(true) {
|
}
|
||||||
loop();
|
}
|
||||||
}
|
|
||||||
}
|
if(rate > 0.8) {
|
||||||
}
|
rate = rate * 2;
|
||||||
takepH();
|
}
|
||||||
rate = 1 - (phSense / 7)*(phSense / 7);
|
if(phSense > 3) {
|
||||||
delay(125);
|
rate = 0.01;
|
||||||
}
|
}
|
||||||
Serial.println("done, returning pneumatics to holding point");
|
timeInterval = rate * 175;
|
||||||
titrate = false;
|
if (timeInterval < 30) {
|
||||||
stopmotor();
|
timeInterval = 15;
|
||||||
digitalWrite(4, HIGH); // up and down
|
}
|
||||||
delay(1500);
|
totgrams = totgrams + timeInterval / 175;
|
||||||
digitalWrite(3, LOW); // spring-loaded
|
digitalWrite(2, HIGH);
|
||||||
delay(1500);
|
delay(timeInterval);
|
||||||
digitalWrite(4, LOW);
|
digitalWrite(2, LOW);
|
||||||
timeInterval = 0;
|
for(int i = 0; i < 10; i += 1){
|
||||||
//timeInterval = 500;
|
delay(rate * 900);
|
||||||
//totgrams = totgrams + 2.857143;
|
if(digitalRead(7) == 0) {
|
||||||
}
|
Serial.println("CANCELLING");
|
||||||
else if (digitalRead(12) == 0 || drips > 0)
|
titrate = false;
|
||||||
{
|
stopmotor();
|
||||||
timeInterval = 15;
|
digitalWrite(4, HIGH); // up and down
|
||||||
totgrams = totgrams + 2.333333/20;
|
delay(1500);
|
||||||
drips --;
|
digitalWrite(3, LOW); // spring-loaded
|
||||||
}
|
delay(2000);
|
||||||
//Serial.print("Time Valve is open = ");
|
digitalWrite(4, LOW);
|
||||||
//Serial.println(timeInterval);
|
while(true) {
|
||||||
if(timeInterval > 0)
|
loop();
|
||||||
{
|
}
|
||||||
digitalWrite(2, HIGH);
|
}
|
||||||
delay(timeInterval);
|
}
|
||||||
digitalWrite(2, LOW);
|
takepH();
|
||||||
takepH();
|
rate = 1 - (phSense / 7)*(phSense / 7);
|
||||||
}
|
delay(125);
|
||||||
delay(50);
|
}
|
||||||
}
|
Serial.println("done, returning pneumatics to holding point");
|
||||||
float takepH()
|
titrate = false;
|
||||||
{
|
stopmotor();
|
||||||
int samples = 30;
|
digitalWrite(4, HIGH); // up and down
|
||||||
int aRead = 0;
|
delay(1500);
|
||||||
for (int i = 0; i < samples ; i++)
|
digitalWrite(3, LOW); // spring-loaded
|
||||||
{
|
delay(1500);
|
||||||
aRead += analogRead(analogPin);
|
digitalWrite(4, LOW);
|
||||||
delay(100);
|
timeInterval = 0;
|
||||||
}
|
//timeInterval = 500;
|
||||||
phSense = 0;
|
//totgrams = totgrams + 2.857143;
|
||||||
float phvolt = 5.0 * aRead/ (1023 * samples); // assuming 5V reference
|
}
|
||||||
phSense = 14 - phvolt/0.25; // convert voltage to pH
|
else if (digitalRead(12) == 0 || drips > 0)
|
||||||
phSense = phSense - 1.3;
|
{
|
||||||
Serial.print("Time Interval = ");
|
timeInterval = 15;
|
||||||
Serial.println(timeInterval);
|
totgrams = totgrams + 2.333333/20;
|
||||||
Serial.print("Analog in reading: ");
|
drips --;
|
||||||
Serial.print(aRead/20); // print pH value on serial monitor
|
}
|
||||||
Serial.print(" - Calculated pH Level: ");
|
//Serial.print("Time Valve is open = ");
|
||||||
Serial.println(phSense, 2); // 1 = one decimal, 2 = two decimals, etc
|
//Serial.println(timeInterval);
|
||||||
Serial.print("Grams: ");
|
if(timeInterval > 0)
|
||||||
Serial.println(totgrams * 0.87, 4);
|
{
|
||||||
float molarity = 0.0025 * totgrams * 0.9 / 49.6;
|
digitalWrite(2, HIGH);
|
||||||
Serial.print("Molarity of 20 mL of acid: ");
|
delay(timeInterval);
|
||||||
Serial.println(molarity, 10);
|
digitalWrite(2, LOW);
|
||||||
// removed the /10
|
takepH();
|
||||||
delay(500);
|
}
|
||||||
}
|
delay(50);
|
||||||
void motor(int speed) {
|
}
|
||||||
analogWrite(10, speed);
|
float takepH()
|
||||||
//delay(timerun);
|
{
|
||||||
//analogWrite(10, 0);
|
int samples = 30;
|
||||||
}
|
int aRead = 0;
|
||||||
void stopmotor() {
|
for (int i = 0; i < samples ; i++)
|
||||||
analogWrite(10, 0);
|
{
|
||||||
//delay(timerun);
|
aRead += analogRead(analogPin);
|
||||||
//analogWrite(10, 0);
|
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);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue