annotate src/testApp.cpp @ 52:13194a9dca77 tip

Added exporting of image and text data
author Andrew N Robertson <andrew.robertson@eecs.qmul.ac.uk>
date Tue, 17 Jul 2012 22:13:10 +0100
parents 5a11b19906c7
children
rev   line source
andrew@0 1 #include "testApp.h"
andrew@0 2
andrew@0 3 //--------------------------------------------------------------
andrew@0 4 void testApp::setup(){
andrew@0 5 midiFileName = "../../../data/entertainer.mid";
andrew@0 6 int retVal = cannamMainFunction();
andrew@0 7
andrew@0 8 playing = false;
andrew@0 9 /*
andrew@0 10 bayesStruct.resetSize(1000);
andrew@0 11 bayesStruct.resetSpeedSize(200);
andrew@0 12 bayesStruct.setRelativeSpeedScalar(0.01);
andrew@0 13 bayesStruct.simpleExample();
andrew@0 14 */
andrew@0 15
andrew@0 16 receiver.setup( PORT );
andrew@0 17
andrew@0 18 screenWidth = ofGetWidth();
andrew@0 19 screenHeight = ofGetHeight();
andrew@0 20 midiEvents.screenWidth = &screenWidth;
andrew@0 21 midiEvents.screenHeight = &screenHeight;
andrew@2 22 midiEvents.drawTempoMode = false;
andrew@2 23 ofSetFrameRate(30);
andrew@0 24 }
andrew@0 25
andrew@0 26 //--------------------------------------------------------------
andrew@0 27 void testApp::update(){
andrew@0 28 if (playing){
andrew@0 29 midiEvents.updatePlayPosition();
andrew@14 30 // midiEvents.bayesStruct.updateBestEstimate();
andrew@0 31 }
andrew@0 32 // drawer.tickLocation+=20;
andrew@0 33
andrew@0 34 // check for waiting messages
andrew@0 35 while( receiver.hasWaitingMessages() )
andrew@0 36 {
andrew@0 37 ofxOscMessage m;
andrew@0 38 receiver.getNextMessage( &m );
andrew@0 39
andrew@0 40 if ( m.getAddress() == "/midinoteon" )
andrew@0 41 {
andrew@0 42 int newMidiOnPitch = m.getArgAsInt32(0);
andrew@0 43 int velocity = m.getArgAsInt32(1);
andrew@0 44 double time = m.getArgAsFloat(2);
andrew@0 45
andrew@0 46 if (velocity != 0)
andrew@0 47 midiEvents.newNoteOnEvent(newMidiOnPitch, velocity, time);
andrew@0 48
andrew@0 49 }
andrew@0 50
andrew@3 51 if ( m.getAddress() == "/setSpeedPrior" )
andrew@3 52 {
andrew@3 53 float speedPrior = m.getArgAsFloat(0);
andrew@3 54 printf("speed prior set to %f\n", speedPrior);
andrew@3 55 midiEvents.speedPriorValue = speedPrior;
andrew@3 56 midiEvents.bayesStruct.speedPriorValue = speedPrior;
andrew@3 57 }
andrew@3 58
andrew@0 59 if ( m.getAddress() == "/startplaying" )
andrew@0 60 {
andrew@0 61 startPlaying();
andrew@0 62 }
andrew@0 63
andrew@0 64 if ( m.getAddress() == "/stopplaying" )
andrew@0 65 {
andrew@0 66 stopPlaying();
andrew@0 67 }
andrew@15 68
andrew@15 69
andrew@24 70 if ( m.getAddress() == "/integratedEstimate" )
andrew@24 71 {
andrew@24 72 midiEvents.bayesStruct.usingIntegratedTempoEstimate = true;
andrew@24 73 }
andrew@24 74
andrew@24 75 if ( m.getAddress() == "/MAPestimate" )
andrew@24 76 {
andrew@24 77 midiEvents.bayesStruct.usingIntegratedTempoEstimate = false;
andrew@24 78 }
andrew@24 79
andrew@15 80
andrew@15 81 if ( m.getAddress() == "/realtime" )
andrew@15 82 {
andrew@15 83 midiEvents.runningInRealTime = true;
andrew@15 84 }
andrew@15 85
andrew@15 86
andrew@15 87 if ( m.getAddress() == "/offline" )
andrew@15 88 {
andrew@15 89 midiEvents.runningInRealTime = false;
andrew@15 90 }
andrew@15 91
andrew@24 92 if ( m.getAddress() == "/minimumSpeedRatio" )
andrew@24 93 {
andrew@24 94
andrew@24 95 float minSpeed = m.getArgAsFloat(0);
andrew@24 96 //printf("minimum speed received is %f and max is %f\n", minSpeed, midiEvents.bayesStruct.relativeSpeedLikelihood.getIndexInRealTerms(midiEvents.bayesStruct.relativeSpeedLikelihood.length-1));
andrew@24 97 if (minSpeed > 0 && minSpeed < midiEvents.bayesStruct.relativeSpeedLikelihood.getIndexInRealTerms(midiEvents.bayesStruct.relativeSpeedLikelihood.length-1)){
andrew@24 98 printf("minimum speed accepted is %f\n", minSpeed);
andrew@24 99 midiEvents.minimumMatchSpeed = minSpeed;
andrew@24 100 }
andrew@24 101 }
andrew@24 102
andrew@0 103 }//end while osc
andrew@0 104
andrew@0 105 }
andrew@0 106
andrew@0 107 //--------------------------------------------------------------
andrew@0 108 void testApp::draw(){
andrew@0 109
andrew@0 110 midiEvents.drawFile();
andrew@23 111
andrew@0 112 }
andrew@0 113
andrew@0 114 //--------------------------------------------------------------
andrew@0 115 void testApp::keyPressed(int key){
andrew@0 116
andrew@0 117
andrew@22 118 // if (key == ' '){
andrew@22 119 // startPlaying();
andrew@22 120 // }
andrew@0 121
andrew@0 122 if (key == 'c'){
andrew@0 123 double timenow = ofGetElapsedTimeMillis();
andrew@0 124 midiEvents.exampleCrossUpdate();
andrew@0 125 timenow *= -1;
andrew@0 126 timenow += ofGetElapsedTimeMillis();
andrew@0 127 printf("CROSS UPDATE TOOK %f", timenow);
andrew@0 128 }
andrew@0 129
andrew@0 130 if (key == OF_KEY_RETURN)
andrew@0 131 stopPlaying();
andrew@0 132
andrew@0 133 if (key == OF_KEY_UP){
andrew@0 134 if (midiEvents.ticksPerScreen >= 4000)
andrew@0 135 midiEvents.ticksPerScreen += 2000;
andrew@0 136 else
andrew@0 137 midiEvents.ticksPerScreen += 500;
andrew@0 138 }
andrew@0 139
andrew@0 140 if (key == 'm'){
andrew@0 141 // midiEvents.findMatch(84, 0, 10000);
andrew@0 142 }
andrew@0 143
andrew@0 144 if (key == OF_KEY_DOWN){
andrew@0 145 if (midiEvents.ticksPerScreen >= 4000)
andrew@0 146 midiEvents.ticksPerScreen -= 2000;
andrew@0 147 else if (midiEvents.ticksPerScreen > 500)
andrew@0 148 midiEvents.ticksPerScreen -= 500;
andrew@0 149 }
andrew@0 150
andrew@0 151 if (key == 'w')
andrew@0 152 midiEvents.printMatchMatrix();
andrew@0 153
andrew@0 154 if (key == 'p'){
andrew@0 155 midiEvents.printNotes();
andrew@0 156 }
andrew@0 157
andrew@0 158 if (key == 'l')
andrew@0 159 midiEvents.bayesStruct.decaySpeedDistribution(100);
andrew@0 160
andrew@1 161 if (key == 't')
andrew@1 162 midiEvents.drawTempoMode = !midiEvents.drawTempoMode;
andrew@1 163
andrew@9 164 if (key == 'r')
andrew@9 165 midiEvents.drawPhaseMode = !midiEvents.drawPhaseMode;
andrew@9 166
andrew@0 167 if (key == 'o'){
andrew@0 168 //open audio file
andrew@0 169 string *filePtr;
andrew@0 170 filePtr = &midiFileName;
andrew@0 171
andrew@0 172 if (getFilenameFromDialogBox(filePtr)){
andrew@0 173 printf("Midifile: Loaded name okay :\n'%s' \n", midiFileName.c_str());
andrew@0 174 cannamMainFunction();
andrew@0 175 }
andrew@22 176 }
andrew@22 177
andrew@0 178
andrew@22 179
andrew@0 180 }
andrew@0 181
andrew@0 182 //--------------------------------------------------------------
andrew@0 183 void testApp::keyReleased(int key){
andrew@0 184
andrew@0 185 }
andrew@0 186
andrew@0 187 //--------------------------------------------------------------
andrew@0 188 void testApp::mouseMoved(int x, int y ){
andrew@1 189 midiEvents.mouseX = midiEvents.getEventTimeMillis((x * midiEvents.ticksPerScreen)/ screenWidth);
andrew@0 190 }
andrew@0 191
andrew@0 192 //--------------------------------------------------------------
andrew@0 193 void testApp::mouseDragged(int x, int y, int button){
andrew@0 194
andrew@0 195 }
andrew@0 196
andrew@0 197 //--------------------------------------------------------------
andrew@0 198 void testApp::mousePressed(int x, int y, int button){
andrew@0 199
andrew@0 200 }
andrew@0 201
andrew@0 202 //--------------------------------------------------------------
andrew@0 203 void testApp::mouseReleased(int x, int y, int button){
andrew@0 204
andrew@0 205 }
andrew@0 206
andrew@0 207 //--------------------------------------------------------------
andrew@0 208 void testApp::windowResized(int w, int h){
andrew@0 209 screenWidth = w;
andrew@0 210 screenHeight = h;
andrew@0 211 midiEvents.noteHeight = screenHeight / (float)(midiEvents.noteMaximum - midiEvents.noteMinimum);
andrew@0 212
andrew@0 213 }
andrew@0 214
andrew@0 215
andrew@0 216
andrew@0 217 void testApp::startPlaying(){
andrew@0 218 playing = !playing;
andrew@0 219 midiEvents.reset();
andrew@0 220 midiEvents.setStartPlayingTimes();
andrew@0 221 //this is where we stop and start playing
andrew@0 222 }
andrew@0 223
andrew@0 224 void testApp::stopPlaying(){
andrew@0 225 playing = false;
andrew@0 226 }
andrew@0 227
andrew@0 228 bool testApp::getFilenameFromDialogBox(string* fileNameToSave){
andrew@0 229 //this uses a pointer structure within the loader and returns true if the dialogue box was used successfully
andrew@0 230 // first, create a string that will hold the URL
andrew@0 231 string URL;
andrew@0 232
andrew@0 233 // openFile(string& URL) returns 1 if a file was picked
andrew@0 234 // returns 0 when something went wrong or the user pressed 'cancel'
andrew@0 235 int response = ofxFileDialogOSX::openFile(URL);
andrew@0 236 if(response){
andrew@0 237 // now you can use the URL
andrew@0 238 *fileNameToSave = URL;
andrew@0 239 //printf("\n filename is %s \n", soundFileName.c_str());
andrew@0 240 return true;
andrew@0 241 }
andrew@0 242 else {
andrew@0 243 // soundFileName = "OPEN canceled. ";
andrew@0 244 printf("\n open file cancelled \n");
andrew@0 245 return false;
andrew@0 246 }
andrew@0 247
andrew@0 248
andrew@0 249
andrew@0 250 }
andrew@0 251
andrew@0 252
andrew@0 253
andrew@0 254
andrew@0 255 int testApp::cannamMainFunction(){
andrew@0 256
andrew@0 257
andrew@2 258 midiEvents.clearAllEvents();
andrew@0 259
andrew@0 260 //int main(int argc, char **argv)
andrew@0 261 //{
andrew@0 262 // if (argc != 2) {
andrew@0 263 // cerr << "Usage: midifile <file.mid>" << endl;
andrew@0 264 // return 1;
andrew@0 265 // }
andrew@0 266
andrew@0 267 std::string filename = midiFileName;//argv[1];
andrew@2 268
andrew@3 269 // fileLoader.chopBeginning = true;
andrew@2 270 fileLoader.loadFile(filename, midiEvents);
andrew@2 271
andrew@2 272 }//new end of load function
andrew@2 273
andrew@2 274
andrew@2 275
andrew@2 276
andrew@2 277 //trying to port to new class
andrew@2 278 /*
andrew@2 279 MIDIFileReader fr(filename);
andrew@2 280
andrew@0 281 if (!fr.isOK()) {
andrew@0 282 std::cerr << "Error: " << fr.getError().c_str() << std::endl;
andrew@0 283 return 1;
andrew@0 284 }
andrew@0 285
andrew@0 286 MIDIComposition c = fr.load();
andrew@0 287
andrew@0 288 switch (fr.getFormat()) {
andrew@0 289 case MIDI_SINGLE_TRACK_FILE: cout << "Format: MIDI Single Track File" << endl; break;
andrew@0 290 case MIDI_SIMULTANEOUS_TRACK_FILE: cout << "Format: MIDI Simultaneous Track File" << endl; break;
andrew@0 291 case MIDI_SEQUENTIAL_TRACK_FILE: cout << "Format: MIDI Sequential Track File" << endl; break;
andrew@0 292 default: cout << "Format: Unknown MIDI file format?" << endl; break;
andrew@0 293 }
andrew@0 294
andrew@0 295 cout << "Tracks: " << c.size() << endl;
andrew@0 296
andrew@0 297 int td = fr.getTimingDivision();
andrew@0 298 if (td < 32768) {
andrew@0 299 cout << "Timing division: " << fr.getTimingDivision() << " ppq" << endl;
andrew@0 300
andrew@0 301 midiEvents.pulsesPerQuarternote = fr.getTimingDivision();
andrew@0 302 } else {
andrew@0 303 int frames = 256 - (td >> 8);
andrew@0 304 int subframes = td & 0xff;
andrew@0 305 cout << "SMPTE timing: " << frames << " fps, " << subframes << " subframes" << endl;
andrew@0 306 }
andrew@0 307
andrew@0 308 for (MIDIComposition::const_iterator i = c.begin(); i != c.end(); ++i) {
andrew@0 309
andrew@0 310 cout << "Start of track: " << i->first+1 << endl;
andrew@0 311
andrew@0 312 for (MIDITrack::const_iterator j = i->second.begin(); j != i->second.end(); ++j) {
andrew@0 313
andrew@0 314 unsigned int t = j->getTime();
andrew@0 315 int ch = j->getChannelNumber();
andrew@0 316
andrew@0 317 if (j->isMeta()) {
andrew@0 318 int code = j->getMetaEventCode();
andrew@0 319 string name;
andrew@0 320 bool printable = true;
andrew@0 321 switch (code) {
andrew@0 322
andrew@0 323 case MIDI_END_OF_TRACK:
andrew@0 324 cout << t << ": End of track" << endl;
andrew@0 325 break;
andrew@0 326
andrew@0 327 case MIDI_TEXT_EVENT: name = "Text"; break;
andrew@0 328 case MIDI_COPYRIGHT_NOTICE: name = "Copyright"; break;
andrew@0 329 case MIDI_TRACK_NAME: name = "Track name"; break;
andrew@0 330 case MIDI_INSTRUMENT_NAME: name = "Instrument name"; break;
andrew@0 331 case MIDI_LYRIC: name = "Lyric"; break;
andrew@0 332 case MIDI_TEXT_MARKER: name = "Text marker"; break;
andrew@0 333 case MIDI_SEQUENCE_NUMBER: name = "Sequence number"; printable = false; break;
andrew@0 334 case MIDI_CHANNEL_PREFIX_OR_PORT: name = "Channel prefix or port"; printable = false; break;
andrew@0 335 case MIDI_CUE_POINT: name = "Cue point"; break;
andrew@0 336 case MIDI_CHANNEL_PREFIX: name = "Channel prefix"; printable = false; break;
andrew@0 337 case MIDI_SEQUENCER_SPECIFIC: name = "Sequencer specific"; printable = false; break;
andrew@0 338 case MIDI_SMPTE_OFFSET: name = "SMPTE offset"; printable = false; break;
andrew@0 339
andrew@0 340 case MIDI_SET_TEMPO:
andrew@0 341 {
andrew@0 342 int m0 = j->getMetaMessage()[0];
andrew@0 343 int m1 = j->getMetaMessage()[1];
andrew@0 344 int m2 = j->getMetaMessage()[2];
andrew@0 345 long tempo = (((m0 << 8) + m1) << 8) + m2;
andrew@0 346
andrew@0 347 cout << t << ": Tempo: " << 60000000.0 / double(tempo) << endl;
andrew@0 348 midiEvents.tempo = 60000000.0 / double(tempo);
andrew@0 349 midiEvents.period = double(tempo)/1000.0;
andrew@0 350
andrew@0 351 printf("period double is %f\n", midiEvents.period);
andrew@0 352 }
andrew@0 353 break;
andrew@0 354
andrew@0 355 case MIDI_TIME_SIGNATURE:
andrew@0 356 {
andrew@0 357 int numerator = j->getMetaMessage()[0];
andrew@0 358 int denominator = 1 << (int)j->getMetaMessage()[1];
andrew@0 359
andrew@0 360 cout << t << ": Time signature: " << numerator << "/" << denominator << endl;
andrew@0 361 }
andrew@0 362
andrew@0 363 case MIDI_KEY_SIGNATURE:
andrew@0 364 {
andrew@0 365 int accidentals = j->getMetaMessage()[0];
andrew@0 366 int isMinor = j->getMetaMessage()[1];
andrew@0 367 bool isSharp = accidentals < 0 ? false : true;
andrew@0 368 accidentals = accidentals < 0 ? -accidentals : accidentals;
andrew@0 369 cout << t << ": Key signature: " << accidentals << " "
andrew@0 370 << (isSharp ?
andrew@0 371 (accidentals > 1 ? "sharps" : "sharp") :
andrew@0 372 (accidentals > 1 ? "flats" : "flat"))
andrew@0 373 << (isMinor ? ", minor" : ", major") << endl;
andrew@0 374 }
andrew@0 375
andrew@0 376 }
andrew@0 377
andrew@0 378
andrew@0 379 if (name != "") {
andrew@0 380 if (printable) {
andrew@0 381 cout << t << ": File meta event: code " << code
andrew@0 382 << ": " << name << ": \"" << j->getMetaMessage()
andrew@0 383 << "\"" << endl;
andrew@0 384 } else {
andrew@0 385 cout << t << ": File meta event: code " << code
andrew@0 386 << ": " << name << ": ";
andrew@0 387 for (int k = 0; k < j->getMetaMessage().length(); ++k) {
andrew@0 388 cout << (int)j->getMetaMessage()[k] << " ";
andrew@0 389 }
andrew@0 390 }
andrew@0 391 }
andrew@0 392 continue;
andrew@0 393 }
andrew@0 394
andrew@0 395 switch (j->getMessageType()) {
andrew@0 396
andrew@0 397 case MIDI_NOTE_ON:
andrew@0 398 cout << t << ": Note: channel " << ch
andrew@0 399 << " duration " << j->getDuration()
andrew@0 400 << " pitch " << j->getPitch()
andrew@0 401 << " velocity " << j->getVelocity()
andrew@0 402 << "event time " << midiEvents.getEventTimeMillis(t) << endl;
andrew@0 403 v.clear();
andrew@0 404 v.push_back(t);
andrew@0 405 v.push_back(j->getPitch());
andrew@0 406 v.push_back(j->getVelocity());
andrew@0 407 v.push_back(j->getDuration());
andrew@0 408 midiEvents.recordedNoteOnMatrix.push_back(v);
andrew@0 409 midiEvents.recordedEventTimes.push_back(midiEvents.getEventTimeMillis(t));
andrew@0 410 break;
andrew@0 411
andrew@0 412 case MIDI_POLY_AFTERTOUCH:
andrew@0 413 cout << t << ": Polyphonic aftertouch: channel " << ch
andrew@0 414 << " pitch " << j->getPitch()
andrew@0 415 << " pressure " << j->getData2() << endl;
andrew@0 416 break;
andrew@0 417
andrew@0 418 case MIDI_CTRL_CHANGE:
andrew@0 419 {
andrew@0 420 int controller = j->getData1();
andrew@0 421 string name;
andrew@0 422 switch (controller) {
andrew@0 423 case MIDI_CONTROLLER_BANK_MSB: name = "Bank select MSB"; break;
andrew@0 424 case MIDI_CONTROLLER_VOLUME: name = "Volume"; break;
andrew@0 425 case MIDI_CONTROLLER_BANK_LSB: name = "Bank select LSB"; break;
andrew@0 426 case MIDI_CONTROLLER_MODULATION: name = "Modulation wheel"; break;
andrew@0 427 case MIDI_CONTROLLER_PAN: name = "Pan"; break;
andrew@0 428 case MIDI_CONTROLLER_SUSTAIN: name = "Sustain"; break;
andrew@0 429 case MIDI_CONTROLLER_RESONANCE: name = "Resonance"; break;
andrew@0 430 case MIDI_CONTROLLER_RELEASE: name = "Release"; break;
andrew@0 431 case MIDI_CONTROLLER_ATTACK: name = "Attack"; break;
andrew@0 432 case MIDI_CONTROLLER_FILTER: name = "Filter"; break;
andrew@0 433 case MIDI_CONTROLLER_REVERB: name = "Reverb"; break;
andrew@0 434 case MIDI_CONTROLLER_CHORUS: name = "Chorus"; break;
andrew@0 435 case MIDI_CONTROLLER_NRPN_1: name = "NRPN 1"; break;
andrew@0 436 case MIDI_CONTROLLER_NRPN_2: name = "NRPN 2"; break;
andrew@0 437 case MIDI_CONTROLLER_RPN_1: name = "RPN 1"; break;
andrew@0 438 case MIDI_CONTROLLER_RPN_2: name = "RPN 2"; break;
andrew@0 439 case MIDI_CONTROLLER_SOUNDS_OFF: name = "All sounds off"; break;
andrew@0 440 case MIDI_CONTROLLER_RESET: name = "Reset"; break;
andrew@0 441 case MIDI_CONTROLLER_LOCAL: name = "Local"; break;
andrew@0 442 case MIDI_CONTROLLER_ALL_NOTES_OFF: name = "All notes off"; break;
andrew@0 443 }
andrew@0 444 cout << t << ": Controller change: channel " << ch
andrew@0 445 << " controller " << j->getData1();
andrew@0 446 if (name != "") cout << " (" << name << ")";
andrew@0 447 cout << " value " << j->getData2() << endl;
andrew@0 448 }
andrew@0 449 break;
andrew@0 450
andrew@0 451 case MIDI_PROG_CHANGE:
andrew@0 452 cout << t << ": Program change: channel " << ch
andrew@0 453 << " program " << j->getData1() << endl;
andrew@0 454 break;
andrew@0 455
andrew@0 456 case MIDI_CHNL_AFTERTOUCH:
andrew@0 457 cout << t << ": Channel aftertouch: channel " << ch
andrew@0 458 << " pressure " << j->getData1() << endl;
andrew@0 459 break;
andrew@0 460
andrew@0 461 case MIDI_PITCH_BEND:
andrew@0 462 cout << t << ": Pitch bend: channel " << ch
andrew@0 463 << " value " << (int)j->getData2() * 128 + (int)j->getData1() << endl;
andrew@0 464 break;
andrew@0 465
andrew@0 466 case MIDI_SYSTEM_EXCLUSIVE:
andrew@0 467 cout << t << ": System exclusive: code "
andrew@0 468 << (int)j->getMessageType() << " message length " <<
andrew@0 469 j->getMetaMessage().length() << endl;
andrew@0 470 break;
andrew@0 471
andrew@0 472
andrew@0 473 }
andrew@0 474
andrew@0 475
andrew@0 476 }
andrew@0 477
andrew@0 478
andrew@0 479 }
andrew@0 480
andrew@2 481 }//end cannam midi main
andrew@0 482
andrew@2 483 */
andrew@0 484
andrew@0 485