-
Notifications
You must be signed in to change notification settings - Fork 1
/
flexProcessing.pde
102 lines (84 loc) · 5.36 KB
/
flexProcessing.pde
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
/*
Saving Values from Arduino to a .csv File Using Processing - Pseduocode
This sketch provides a basic framework to read data from Arduino over the serial port and save it to .csv file on your computer.
The .csv file will be saved in the same folder as your Processing sketch.
This sketch takes advantage of Processing 2.0's built-in Table class.
This sketch assumes that values read by Arduino are separated by commas, and each Arduino reading is separated by a newline character.
Each reading will have it's own row and timestamp in the resulting csv file. This sketch will write a new file a set number of times. Each file will contain all records from the beginning of the sketch's run.
This sketch pseduo-code only. Comments will direct you to places where you should customize the code.
This is a beginning level sketch.
The hardware:
* Sensors connected to Arduino input pins
* Arduino connected to computer via USB cord
The software:
*Arduino programmer
*Processing (download the Processing software here: https://www.processing.org/download/
*Download the Software Serial library from here: http://arduino.cc/en/Reference/softwareSerial
Created 12 November 2014
By Elaine Laguerta
http://url/of/online/tutorial.cc
*/
import processing.serial.*;
Serial myPort; //creates a software serial port on which you will listen to Arduino
Table dataTable; //table where we will read in and store values. You can name it something more creative!
int numReadings = 3000; //keeps track of how many readings you'd like to take before writing the file.
int readingCounter = 0; //counts each reading to compare to numReadings.
String fileName;
void setup()
{
//String portName = Serial.list()[0];
String portName = "COM17";
//CAUTION: your Arduino port number is probably different! Mine happened to be 1. Use a "handshake" sketch to figure out and test which port number your Arduino is talking on. A "handshake" establishes that Arduino and Processing are listening/talking on the same port.
//Here's a link to a basic handshake tutorial: https://processing.org/tutorials/overview/
myPort = new Serial(this, portName, 9600); //set up your port to listen to the serial port
dataTable = new Table();
dataTable.addColumn("id"); //This column stores a unique identifier for each record. We will just count up from 0 - so your first reading will be ID 0, your second will be ID 1, etc.
//the following adds columns for time. You can also add milliseconds. See the Time/Date functions for Processing: https://www.processing.org/reference/
/*dataTable.addColumn("year");
dataTable.addColumn("month");
dataTable.addColumn("day");
dataTable.addColumn("hour");
dataTable.addColumn("minute");
dataTable.addColumn("second");*/
//the following are dummy columns for each data value. Add as many columns as you have data values. Customize the names as needed. Make sure they are in the same order as the order that Arduino is sending them!
dataTable.addColumn("little");
dataTable.addColumn("ring");
dataTable.addColumn("middle");
dataTable.addColumn("index");
dataTable.addColumn("thumb");
}
void serialEvent(Serial myPort) {
String val = myPort.readStringUntil('\n'); //The newline separator separates each Arduino loop. We will parse the data by each newline separator.
if(val!=null){
//if (val== "$,") { //We have a reading! Record it.
val = trim(val); //gets rid of any whitespace or Unicode nonbreakable space
println(val); //Optional, useful for debugging. If you see this, you know data is being sent. Delete if you like.
int sensorVals[] = int(split(val, ',')); //parses the packet from Arduino and places the valeus into the sensorVals array. I am assuming floats. Change the data type to match the datatype coming from Arduino.
TableRow newRow = dataTable.addRow(); //add a row for this new reading
newRow.setInt("id", dataTable.lastRowIndex());//record a unique identifier (the row's index)
//record time stamp
/*newRow.setInt("year", year());
newRow.setInt("month", month());
newRow.setInt("day", day());
newRow.setInt("hour", hour());
newRow.setInt("minute", minute());
newRow.setInt("second", second());*/
//record sensor information. Customize the names so they match your sensor column names.
newRow.setInt("little", sensorVals[0]);
newRow.setInt("ring", sensorVals[1]);
newRow.setInt("middle", sensorVals[2]);
newRow.setInt("index", sensorVals[3]);
newRow.setInt("thumb", sensorVals[4]);
readingCounter++; //optional, use if you'd like to write your file every numReadings reading cycles
//saves the table as a csv in the same folder as the sketch every numReadings.
if (readingCounter % numReadings ==0)//The % is a modulus, a math operator that signifies remainder after division. The if statement checks if readingCounter is a multiple of numReadings (the remainder of readingCounter/numReadings is 0)
{
fileName = /*str(year()) + str(month()) + str(day()) + str(dataTable.lastRowIndex())*/"Digit 2(new)"+".csv"; //this filename is of the form year+month+day+readingCounter
saveTable(dataTable, fileName); //Woo! save it to your computer. It is ready for all your spreadsheet dreams.
}
}
}
void draw()
{
//visualize your sensor data in real time here! In the future we hope to add some cool and useful graphic displays that can be tuned to different ranges of values.
}