annotate src/RecordedMultitrackAudio.cpp @ 36:eb43b2a007ea

changed newMatchOnset to have different way to calculate onsets vs noise, using the onsetLikelihoodNoise factor
author Andrew N Robertson <andrew.robertson@eecs.qmul.ac.uk>
date Tue, 24 Apr 2012 01:19:24 +0100
parents 6fb77b20413c
children 9c803369b229
rev   line source
andrew@1 1 /*
andrew@1 2 * RecordedMultitrackAudio.cpp
andrew@1 3 * MultipleAudioMathcher
andrew@1 4 *
andrew@1 5 * Created by Andrew on 31/01/2012.
andrew@1 6 * Copyright 2012 QMUL. All rights reserved.
andrew@1 7 *
andrew@1 8 */
andrew@1 9
andrew@1 10 #include "RecordedMultitrackAudio.h"
andrew@1 11
andrew@1 12
andrew@1 13 void RecordedMultitrackAudio::loadTestAudio(){
andrew@26 14
andrew@7 15 trackScreenHeight = 0.15;
andrew@26 16
andrew@1 17 printf("loaded max val is %f\n", loadedAudioFiles[0].fileLoader.onsetDetect.onsetDetector.maximumDetectionValue);
andrew@1 18
andrew@36 19 int multitrackToLoad = 13;
andrew@36 20 setDifferentMultitracks(multitrackToLoad);//command to load this set of audio files - see below
andrew@26 21
andrew@31 22 //number 7 is problematic with memory
andrew@26 23
andrew@26 24 printf("AFTER LOADING: \n");
andrew@1 25 printInfo();
andrew@7 26
andrew@1 27
andrew@31 28 numberOfAudioTracks = 4;
andrew@26 29
andrew@1 30
andrew@1 31 }
andrew@1 32
andrew@23 33 void RecordedMultitrackAudio::setDifferentMultitracks(const int& setToLoad){
andrew@23 34 const char *kickfilename ;//= "../../../data/sound/LiveDues/kick_liveDues.wav";
andrew@23 35 const char *bassfilename ;//"../../../data/sound/LiveDues/bass_upsideLive.wav";
andrew@23 36 const char *snarefilename ;
andrew@31 37 const char *guitarfilename ;
andrew@23 38
andrew@23 39 switch (setToLoad) {
andrew@23 40 case 0:
andrew@23 41 kickfilename = "../../../data/sound/LiveDues/kick_liveDues.wav";
andrew@23 42 bassfilename = "../../../data/sound/LiveDues/bass_upsideLive.wav";
andrew@23 43 snarefilename = "../../../data/sound/LiveDues/snare_liveDues.wav";
andrew@23 44 break;
andrew@23 45 case 1:
andrew@23 46 kickfilename = "../../../data/sound/DiamondMatch1/kick_bip.wav";
andrew@23 47 bassfilename = "../../../data/sound/DiamondMatch1/bass_bip.wav";
andrew@23 48 snarefilename = "../../../data/sound/DiamondMatch1/snare_bip.wav";
andrew@26 49 break;
andrew@23 50 case 2:
andrew@23 51 kickfilename = "../../../data/sound/LiveIdiot2/02kick_bip.wav";
andrew@23 52 bassfilename = "../../../data/sound/LiveIdiot2/01bass_bip.wav";
andrew@23 53 snarefilename = "../../../data/sound/LiveIdiot2/03snare_bip.wav";
andrew@23 54 break;
andrew@23 55 case 3:
andrew@23 56 kickfilename = "../../../data/sound/UistLive1/02kick_bip.wav";
andrew@23 57 bassfilename = "../../../data/sound/UistLive1/01bass_bip.wav";
andrew@23 58 snarefilename = "../../../data/sound/UistLive1/03snare_bip.wav";
andrew@23 59 break;
andrew@28 60
andrew@28 61 case 4:
andrew@28 62 kickfilename = "/Volumes/Supersaurus/TractorsAlbum/tractorsIdiotDance/tractorsSetToRecord2/Bounces/TakeTwo/kick d112_bip.wav";
andrew@28 63 bassfilename = "/Volumes/Supersaurus/TractorsAlbum/tractorsIdiotDance/tractorsSetToRecord2/Bounces/TakeTwo/bass di_bip.wav";
andrew@28 64 snarefilename = "/Volumes/Supersaurus/TractorsAlbum/tractorsIdiotDance/tractorsSetToRecord2/Bounces/TakeTwo/snare_bip.wav";
andrew@28 65 break;
andrew@29 66 case 5:
andrew@31 67 kickfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take12/02kick_bip.wav";
andrew@31 68 bassfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take12/01bass_bip.wav";
andrew@31 69 snarefilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take12/03snare_bip.wav";
andrew@32 70 guitarfilename ="/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take12/04elec_bip.wav";
andrew@29 71 break;
andrew@31 72 case 6:
andrew@31 73 kickfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take13/02kick_bip.wav";
andrew@31 74 bassfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take13/01bass_bip.wav";
andrew@31 75 snarefilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take13/03snare_bip.wav";
andrew@32 76 guitarfilename ="/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take13/04elec_bip.wav";
andrew@31 77 break;
andrew@31 78
andrew@31 79 case 7:
andrew@31 80 kickfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take14/02kick_bip.wav";
andrew@31 81 bassfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take14/01bass_bip.wav";
andrew@31 82 snarefilename ="/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take14/03snare_bip.wav";
andrew@31 83 guitarfilename ="/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/Take14/04elec_bip.wav";
andrew@31 84 break;
andrew@31 85
andrew@31 86 case 8:
andrew@31 87 kickfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine4/02kick_bip.wav";
andrew@31 88 bassfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine4/01bass_bip.wav";
andrew@31 89 snarefilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine4/03snare_bip.wav";
andrew@31 90 break;
andrew@31 91
andrew@31 92 case 9:
andrew@31 93 kickfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine5/02kick.wav";
andrew@31 94 bassfilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine5/01bass.wav";
andrew@31 95 snarefilename = "/Users/andrew/Documents/work/Alignment/MultitrackMatch/tractorsAlign/DownLine5/03snare.wav";
andrew@31 96 break;
andrew@31 97
andrew@33 98 case 10:
andrew@33 99 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take2/02Kick_bip.wav";
andrew@33 100 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take2/01Bass.wav";
andrew@33 101 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take2/03Snare_bip.wav";
andrew@33 102 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take2/04Elec_SM57_bip.wav";
andrew@33 103 break;
andrew@29 104
andrew@33 105 case 11:
andrew@33 106 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take3/02Kick_bip.wav";
andrew@33 107 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take3/01Bass.wav";
andrew@33 108 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take3/03Snare_bip.wav";
andrew@33 109 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take3/04Elec_SM57_bip.wav";
andrew@33 110 break;
andrew@33 111
andrew@33 112 case 12:
andrew@33 113 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take4/02Kick_bip.wav";
andrew@33 114 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take4/01Bass.wav";
andrew@33 115 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take4/03Snare_bip.wav";
andrew@33 116 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take4/04Elec_SM57_bip.wav";
andrew@33 117 break;
andrew@33 118
andrew@33 119 case 13:
andrew@33 120 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take6/02Kick_bip.wav";
andrew@33 121 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take6/01Bass.wav";
andrew@33 122 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take6/03Snare_bip.wav";
andrew@36 123 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/MarbleArchMultitracks/Take6/04Elec_SM57_bip.wav";
andrew@33 124 break;
andrew@34 125
andrew@34 126
andrew@34 127 case 14:
andrew@35 128 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeOneShorter/02Kick_bip.wav";
andrew@35 129 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeOneShorter/01Bass.wav";
andrew@35 130 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeOneShorter/03Snare_bip.wav";
andrew@35 131 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeOneShorter/04Elec_SM57_bip.wav";
andrew@34 132 break;
andrew@34 133
andrew@34 134 case 15:
andrew@35 135 kickfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeTwoShorter/02Kick_bip.wav";
andrew@35 136 bassfilename = "/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeTwoShorter/01Bass.wav";
andrew@35 137 snarefilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeTwoShorter/03Snare_bip.wav";
andrew@35 138 guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeTwoShorter/04Elec_SM57_bip.wav";
andrew@36 139 break;
andrew@36 140
andrew@36 141 case 16:
andrew@36 142 // std::string folder = "/Volumes/Supersaurus/SonOfMan/FollowYourLeaders/FollowYourLeaders/Bounces/FollowMultitracks/Follow_023_D/";
andrew@36 143 kickfilename = "/Volumes/Supersaurus/SonOfMan/FollowYourLeaders/FollowYourLeaders/Bounces/FollowMultitracks/Follow_023_D/02Kick_D112_bip.wav";
andrew@36 144 bassfilename = "/Volumes/Supersaurus/SonOfMan/FollowYourLeaders/FollowYourLeaders/Bounces/FollowMultitracks/Follow_023_D/01Bass.wav";
andrew@36 145 snarefilename = "/Volumes/Supersaurus/SonOfMan/FollowYourLeaders/FollowYourLeaders/Bounces/FollowMultitracks/Follow_023_D//03Snare_Top_bip.wav";
andrew@36 146 // guitarfilename ="/Volumes/Supersaurus/Gronk/Gronkn/Bounces/StationGateMultitracks/TakeTwoShorter/04Elec_SM57_bip.wav";
andrew@36 147 break;
andrew@36 148
andrew@36 149
andrew@36 150
andrew@36 151
andrew@36 152
andrew@29 153
andrew@23 154 }
andrew@23 155 loadAudioTrack(kickfilename, 0);
andrew@23 156 loadAudioTrack(bassfilename, 1);
andrew@23 157 loadAudioTrack(snarefilename, 2);
andrew@31 158
andrew@31 159 if (guitarfilename != NULL)
andrew@31 160 loadAudioTrack(guitarfilename, 3);
andrew@23 161
andrew@23 162 }
andrew@23 163
andrew@23 164 void RecordedMultitrackAudio::loadAudioTrack(std::string name, const int& channel){
andrew@23 165 //kick - track type 0
andrew@23 166 //bass - type 1
andrew@23 167 //snare type 2
andrew@23 168 if (channel >= 0 && channel <= 4){
andrew@23 169 loadedAudioPtr = new LoadedAudioHolder;
andrew@23 170 loadedAudioPtr->loadAudioFile(name);
andrew@23 171 loadedAudioFiles[channel] = *loadedAudioPtr;
andrew@23 172 loadedAudioFiles[channel].fileLoader.onsetDetect.window.setToRelativeSize(0, trackScreenHeight*channel, 1, trackScreenHeight);
andrew@23 173 loadedAudioFiles[channel].setTrackType(channel);
andrew@23 174 }
andrew@23 175 }
andrew@23 176
andrew@1 177
andrew@1 178
andrew@1 179 void RecordedMultitrackAudio::drawTracks(){
andrew@1 180
andrew@1 181 for (int i = 0;i < numberOfAudioTracks;i++){
andrew@1 182 loadedAudioFiles[i].draw();
andrew@1 183 }
andrew@1 184 }
andrew@1 185
andrew@1 186
andrew@1 187 void RecordedMultitrackAudio::updatePosition(){
andrew@1 188 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 189 loadedAudioFiles[i].updateToPlayPosition();
andrew@1 190 }
andrew@1 191
andrew@9 192 void RecordedMultitrackAudio::updatePositionToMillis(const double& millis){
andrew@9 193 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@9 194 loadedAudioFiles[i].updateToMillisPosition(millis);
andrew@9 195 }
andrew@2 196
andrew@1 197 void RecordedMultitrackAudio::switchScreens(){
andrew@1 198 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 199 loadedAudioFiles[i].switchScreens();
andrew@1 200 }
andrew@1 201
andrew@1 202
andrew@1 203 void RecordedMultitrackAudio::togglePlay(){
andrew@1 204 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 205 loadedAudioFiles[i].togglePlay();
andrew@1 206 }
andrew@1 207
andrew@1 208 void RecordedMultitrackAudio::stop(){
andrew@1 209 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 210 loadedAudioFiles[i].stop();
andrew@1 211 }
andrew@1 212
andrew@1 213
andrew@1 214 void RecordedMultitrackAudio::printInfo(){
andrew@1 215 loadedAudioFiles[0].fileLoader.onsetDetect.printChromaInfo();
andrew@1 216 loadedAudioFiles[0].printEvents();
andrew@1 217 }
andrew@1 218
andrew@1 219 void RecordedMultitrackAudio::windowResized(const int& w, const int& h){
andrew@1 220 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 221 loadedAudioFiles[i].windowResized(w, h);
andrew@1 222 }
andrew@1 223
andrew@1 224 void RecordedMultitrackAudio::zoomIn(){
andrew@1 225 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 226 loadedAudioFiles[i].fileLoader.zoomIn();
andrew@1 227 }
andrew@1 228
andrew@1 229 void RecordedMultitrackAudio::zoomOut(){
andrew@1 230 for (int i = 0;i < numberOfAudioTracks;i++)
andrew@1 231 loadedAudioFiles[i].fileLoader.zoomOut();
andrew@1 232 }
andrew@1 233
andrew@1 234