Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: mbed SDFileSystem_Copy_of_mbed_version I2S
NotchingDemo.cpp@38:3b4c05af5f36, 2019-06-02 (annotated)
- Committer:
- roryhand
- Date:
- Sun Jun 02 19:12:56 2019 +0000
- Revision:
- 38:3b4c05af5f36
- Parent:
- 37:a563899ac0df
- Child:
- 39:69d5a5dd9163
WIP - makes no sense. I can open up 15 files and close them one by one. But I CANNOT do this if it is done via Sound[aaa].FileInfo.WavFile... It will then hang....
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| roryhand | 1:aac37edee302 | 1 | |
| roryhand | 0:e89d7a0bfa3b | 2 | // 24/03/2018 update - I appear to be able to address the device and write something, as I am getting an ACK returned from the i2c write() function. | 
| roryhand | 0:e89d7a0bfa3b | 3 | //however if i use the write function with 4 arguments (as opposed to just 1 argument) then it doesnt work | 
| roryhand | 0:e89d7a0bfa3b | 4 | //only works with the 1 argument version!!! | 
| roryhand | 0:e89d7a0bfa3b | 5 | |
| roryhand | 0:e89d7a0bfa3b | 6 | |
| roryhand | 0:e89d7a0bfa3b | 7 | //THIS VERSION WORKED, CHANGED SOME THINGS, THEN CHANGED THEM BACK. NOW IT NO LONGER WORKS!!!! | 
| roryhand | 0:e89d7a0bfa3b | 8 | #include "mbed.h" | 
| roryhand | 0:e89d7a0bfa3b | 9 | #include "math.h" | 
| roryhand | 1:aac37edee302 | 10 | #include "I2S.h" | 
| roryhand | 1:aac37edee302 | 11 | #include "SDFileSystem.h" | 
| roryhand | 0:e89d7a0bfa3b | 12 | #include "wm8731_Config_setup.h" | 
| roryhand | 0:e89d7a0bfa3b | 13 | #include "WOLFSON_config_consts.h" | 
| roryhand | 37:a563899ac0df | 14 | #include <string> | 
| roryhand | 0:e89d7a0bfa3b | 15 | #include <stdlib.h> | 
| roryhand | 27:a378f1f937ee | 16 | #include <fstream> | 
| roryhand | 27:a378f1f937ee | 17 | #include <iostream> | 
| roryhand | 0:e89d7a0bfa3b | 18 | #include <vector> | 
| roryhand | 0:e89d7a0bfa3b | 19 | #include <string> | 
| roryhand | 0:e89d7a0bfa3b | 20 | #define sample_freq 11025 | 
| roryhand | 1:aac37edee302 | 21 | #pragma import __use_two_region_memory | 
| roryhand | 0:e89d7a0bfa3b | 22 | DigitalOut myled(LED1); | 
| roryhand | 0:e89d7a0bfa3b | 23 | DigitalOut led2(LED2); | 
| roryhand | 0:e89d7a0bfa3b | 24 | DigitalOut led3(LED3); | 
| roryhand | 0:e89d7a0bfa3b | 25 | DigitalIn NotchUp(p16); | 
| roryhand | 38:3b4c05af5f36 | 26 | DigitalIn NotchDown(p17);//check the pin!!! Dont know if this will actually work... | 
| roryhand | 0:e89d7a0bfa3b | 27 | InterruptIn Horn(p16); | 
| roryhand | 0:e89d7a0bfa3b | 28 | Ticker sampletick; | 
| roryhand | 32:6ee488c97dcc | 29 | Ticker fileswitch_tick; | 
| roryhand | 0:e89d7a0bfa3b | 30 | Ticker BellTick; | 
| roryhand | 0:e89d7a0bfa3b | 31 | Ticker EdTick; | 
| roryhand | 0:e89d7a0bfa3b | 32 | Ticker TickFadeOut; | 
| roryhand | 3:6169aeeaeeb4 | 33 | Ticker TestTick; | 
| roryhand | 0:e89d7a0bfa3b | 34 | Timer t; | 
| roryhand | 0:e89d7a0bfa3b | 35 | Timer t2; | 
| roryhand | 3:6169aeeaeeb4 | 36 | Timer NotchTimer; | 
| roryhand | 27:a378f1f937ee | 37 | Timer timer_open; | 
| roryhand | 0:e89d7a0bfa3b | 38 | |
| roryhand | 0:e89d7a0bfa3b | 39 | Serial pc(USBTX, USBRX); // tx, rx //FOR DEBUGGING PROGRAM USING GNU SCREEN | 
| roryhand | 0:e89d7a0bfa3b | 40 | DigitalOut cs(p8); | 
| roryhand | 0:e89d7a0bfa3b | 41 | I2S i2s(I2S_TRANSMIT, p5, p6, p7); | 
| roryhand | 0:e89d7a0bfa3b | 42 | SDFileSystem sd(p11, p12, p13, p8, "sd"); // the new pinout that i am using | 
| roryhand | 0:e89d7a0bfa3b | 43 | |
| roryhand | 0:e89d7a0bfa3b | 44 | |
| roryhand | 0:e89d7a0bfa3b | 45 | /*struct A { | 
| roryhand | 0:e89d7a0bfa3b | 46 | int data; | 
| roryhand | 0:e89d7a0bfa3b | 47 | B b; | 
| roryhand | 0:e89d7a0bfa3b | 48 | };*/ | 
| roryhand | 0:e89d7a0bfa3b | 49 | |
| roryhand | 0:e89d7a0bfa3b | 50 | |
| roryhand | 0:e89d7a0bfa3b | 51 | |
| roryhand | 0:e89d7a0bfa3b | 52 | |
| roryhand | 0:e89d7a0bfa3b | 53 | class classFade | 
| roryhand | 0:e89d7a0bfa3b | 54 | { | 
| roryhand | 1:aac37edee302 | 55 | public: | 
| roryhand | 1:aac37edee302 | 56 | |
| roryhand | 0:e89d7a0bfa3b | 57 | float powerval; | 
| roryhand | 0:e89d7a0bfa3b | 58 | float FadeIteration; | 
| roryhand | 0:e89d7a0bfa3b | 59 | float DecayFactor; | 
| roryhand | 0:e89d7a0bfa3b | 60 | float Denom; | 
| roryhand | 0:e89d7a0bfa3b | 61 | float FadeCoeff; | 
| roryhand | 0:e89d7a0bfa3b | 62 | float Natural_Exp; | 
| roryhand | 0:e89d7a0bfa3b | 63 | int LengthSecs; | 
| roryhand | 0:e89d7a0bfa3b | 64 | int Length; | 
| roryhand | 1:aac37edee302 | 65 | |
| roryhand | 0:e89d7a0bfa3b | 66 | //member Functions | 
| roryhand | 0:e89d7a0bfa3b | 67 | float FadeOut(void) | 
| roryhand | 0:e89d7a0bfa3b | 68 | { | 
| roryhand | 0:e89d7a0bfa3b | 69 | powerval = -FadeIteration/Denom; | 
| roryhand | 1:aac37edee302 | 70 | if (FadeIteration >=Length) { | 
| roryhand | 1:aac37edee302 | 71 | FadeCoeff = 0; | 
| roryhand | 1:aac37edee302 | 72 | |
| roryhand | 1:aac37edee302 | 73 | } else { | 
| roryhand | 0:e89d7a0bfa3b | 74 | FadeCoeff = (Length - FadeIteration)/Length; | 
| roryhand | 0:e89d7a0bfa3b | 75 | } | 
| roryhand | 1:aac37edee302 | 76 | FadeIteration = FadeIteration + 1; | 
| roryhand | 1:aac37edee302 | 77 | return FadeCoeff; | 
| roryhand | 1:aac37edee302 | 78 | |
| roryhand | 1:aac37edee302 | 79 | } | 
| roryhand | 1:aac37edee302 | 80 | float FadeIn(void) | 
| roryhand | 0:e89d7a0bfa3b | 81 | { | 
| roryhand | 0:e89d7a0bfa3b | 82 | powerval = FadeIteration/Denom; | 
| roryhand | 1:aac37edee302 | 83 | if (FadeIteration >=Length) { | 
| roryhand | 1:aac37edee302 | 84 | FadeCoeff = 1; | 
| roryhand | 1:aac37edee302 | 85 | |
| roryhand | 1:aac37edee302 | 86 | } else { | 
| roryhand | 0:e89d7a0bfa3b | 87 | FadeCoeff = FadeIteration/Length; | 
| roryhand | 0:e89d7a0bfa3b | 88 | } | 
| roryhand | 0:e89d7a0bfa3b | 89 | |
| roryhand | 1:aac37edee302 | 90 | FadeIteration = FadeIteration + 1; | 
| roryhand | 1:aac37edee302 | 91 | return FadeCoeff; | 
| roryhand | 1:aac37edee302 | 92 | |
| roryhand | 1:aac37edee302 | 93 | } | 
| roryhand | 0:e89d7a0bfa3b | 94 | }; | 
| roryhand | 0:e89d7a0bfa3b | 95 | |
| roryhand | 0:e89d7a0bfa3b | 96 | classFade IdleFadeOut; | 
| roryhand | 0:e89d7a0bfa3b | 97 | classFade N2FadeIn; | 
| roryhand | 0:e89d7a0bfa3b | 98 | |
| roryhand | 2:957d3b2afff4 | 99 | classFade NotchFadeOut; | 
| roryhand | 2:957d3b2afff4 | 100 | classFade NotchFadeIn; | 
| roryhand | 2:957d3b2afff4 | 101 | |
| roryhand | 0:e89d7a0bfa3b | 102 | |
| roryhand | 0:e89d7a0bfa3b | 103 | |
| roryhand | 0:e89d7a0bfa3b | 104 | |
| roryhand | 0:e89d7a0bfa3b | 105 | |
| roryhand | 1:aac37edee302 | 106 | typedef struct uFMT_STRUCT { | 
| roryhand | 1:aac37edee302 | 107 | short comp_code; | 
| roryhand | 1:aac37edee302 | 108 | short num_channels; | 
| roryhand | 1:aac37edee302 | 109 | unsigned sample_rate; | 
| roryhand | 1:aac37edee302 | 110 | unsigned avg_Bps; | 
| roryhand | 1:aac37edee302 | 111 | short block_align; | 
| roryhand | 1:aac37edee302 | 112 | short sig_bps; | 
| roryhand | 0:e89d7a0bfa3b | 113 | } FMT_STRUCT; | 
| roryhand | 0:e89d7a0bfa3b | 114 | |
| roryhand | 1:aac37edee302 | 115 | typedef struct uNotch_STRUCT { | 
| roryhand | 1:aac37edee302 | 116 | short Notch; | 
| roryhand | 1:aac37edee302 | 117 | short NotchTransUp; | 
| roryhand | 1:aac37edee302 | 118 | short NotchTransDown; | 
| roryhand | 1:aac37edee302 | 119 | short NotchDirection; | 
| roryhand | 1:aac37edee302 | 120 | } Notch_STRUCT; | 
| roryhand | 1:aac37edee302 | 121 | |
| roryhand | 0:e89d7a0bfa3b | 122 | typedef struct uDATA_STRUCT { | 
| roryhand | 1:aac37edee302 | 123 | unsigned subchunk2_ID; | 
| roryhand | 1:aac37edee302 | 124 | unsigned subchunk2_size; | 
| roryhand | 1:aac37edee302 | 125 | char * data_buf; | 
| roryhand | 1:aac37edee302 | 126 | } DATA_STRUCT; | 
| roryhand | 0:e89d7a0bfa3b | 127 | |
| roryhand | 1:aac37edee302 | 128 | typedef struct uWAV_FILE_STRUCT { | 
| roryhand | 1:aac37edee302 | 129 | FILE *WavFile; | 
| roryhand | 1:aac37edee302 | 130 | int id_number; | 
| roryhand | 1:aac37edee302 | 131 | char *slice_buf; | 
| roryhand | 1:aac37edee302 | 132 | int num_slices; | 
| roryhand | 1:aac37edee302 | 133 | FMT_STRUCT FileFormat; | 
| roryhand | 1:aac37edee302 | 134 | DATA_STRUCT FileData; | 
| roryhand | 0:e89d7a0bfa3b | 135 | } WAV_FILE_STRUCT; | 
| roryhand | 0:e89d7a0bfa3b | 136 | |
| roryhand | 0:e89d7a0bfa3b | 137 | /*typedef struct uWAV_FILE_STRUCT{ | 
| roryhand | 1:aac37edee302 | 138 | FILE* WavFile; | 
| roryhand | 1:aac37edee302 | 139 | |
| roryhand | 1:aac37edee302 | 140 | |
| roryhand | 0:e89d7a0bfa3b | 141 | }WAV_FILE_STRUCT;*/ | 
| roryhand | 0:e89d7a0bfa3b | 142 | class classSoundFile | 
| roryhand | 0:e89d7a0bfa3b | 143 | { | 
| roryhand | 1:aac37edee302 | 144 | public: | 
| roryhand | 1:aac37edee302 | 145 | |
| roryhand | 1:aac37edee302 | 146 | //add a class constructor | 
| roryhand | 1:aac37edee302 | 147 | WAV_FILE_STRUCT FileInfo; | 
| roryhand | 2:957d3b2afff4 | 148 | short * data_sptr; | 
| roryhand | 36:569ec4335f92 | 149 | string file_location; | 
| roryhand | 1:aac37edee302 | 150 | //classSoundFile(string filename);//this is the constructor | 
| roryhand | 1:aac37edee302 | 151 | //string filename; | 
| roryhand | 0:e89d7a0bfa3b | 152 | }; | 
| roryhand | 0:e89d7a0bfa3b | 153 | |
| roryhand | 1:aac37edee302 | 154 | //class constructor; | 
| roryhand | 1:aac37edee302 | 155 | /*classSoundFile::classSoundFile(string filename) | 
| roryhand | 1:aac37edee302 | 156 | { | 
| roryhand | 1:aac37edee302 | 157 | //Declare RootFolder and the directory for the appropriate file. | 
| roryhand | 1:aac37edee302 | 158 | //How we index into filename[] from the outside of this class is another | 
| roryhand | 1:aac37edee302 | 159 | //issue... | 
| roryhand | 1:aac37edee302 | 160 | FileInfo.WavFile = fopen("/sd/mydir/645Engine/Startup.wav","rb"); | 
| roryhand | 1:aac37edee302 | 161 | fseek(FileInfo.WavFile,20,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 162 | fread(&FileInfo.FileFormat,sizeof(FileInfo.FileFormat),1,FileInfo.WavFile); | 
| roryhand | 1:aac37edee302 | 163 | printf("wav_format.sample_rate: %d\n\r",FileInfo.FileFormat.sample_rate); | 
| roryhand | 1:aac37edee302 | 164 | fread(&FileInfo.FileData,sizeof(FileInfo.FileData),1,FileInfo.WavFile); | 
| roryhand | 1:aac37edee302 | 165 | printf("wav_data.subchunk2_size: %d\n\r",FileInfo.FileData.subchunk2_size); | 
| roryhand | 1:aac37edee302 | 166 | FileInfo.slice_buf = ( char *)malloc(FileInfo.FileFormat.block_align); | 
| roryhand | 1:aac37edee302 | 167 | fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,FileInfo.WavFile); //This isnt actually required, its just a test | 
| roryhand | 1:aac37edee302 | 168 | FileInfo.num_slices = FileInfo.FileData.subchunk2_size/FileInfo.FileFormat.block_align; | 
| roryhand | 1:aac37edee302 | 169 | }*/ | 
| roryhand | 1:aac37edee302 | 170 | |
| roryhand | 38:3b4c05af5f36 | 171 | int notch_flag = 0; | 
| roryhand | 0:e89d7a0bfa3b | 172 | int i = 0; | 
| roryhand | 0:e89d7a0bfa3b | 173 | int h = 0; | 
| roryhand | 0:e89d7a0bfa3b | 174 | short bufflen = 1; | 
| roryhand | 0:e89d7a0bfa3b | 175 | int buffer[1]; | 
| roryhand | 1:aac37edee302 | 176 | int AudioFormat, NumChannels, SampleRate, BitsPerSample ; | 
| roryhand | 0:e89d7a0bfa3b | 177 | char *slice_buf; | 
| roryhand | 0:e89d7a0bfa3b | 178 | short *data_sptr; | 
| roryhand | 0:e89d7a0bfa3b | 179 | short *data_sptr_horn; | 
| roryhand | 0:e89d7a0bfa3b | 180 | short *data_sptr_IdleN2; | 
| roryhand | 0:e89d7a0bfa3b | 181 | short * data_sptr_bell; | 
| roryhand | 0:e89d7a0bfa3b | 182 | short * data_sptr_N2; | 
| roryhand | 0:e89d7a0bfa3b | 183 | short * data_sptr_Flange; | 
| roryhand | 0:e89d7a0bfa3b | 184 | unsigned char *data_bptr; | 
| roryhand | 0:e89d7a0bfa3b | 185 | int *data_wptr; | 
| roryhand | 0:e89d7a0bfa3b | 186 | unsigned channel; | 
| roryhand | 0:e89d7a0bfa3b | 187 | long slice, num_slices; | 
| roryhand | 0:e89d7a0bfa3b | 188 | int verbosity = 0; | 
| roryhand | 0:e89d7a0bfa3b | 189 | int verbosity2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 190 | int verbosity3 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 191 | int verbosity4 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 192 | int verbosity5 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 193 | int interrupt_condition = 1; | 
| roryhand | 0:e89d7a0bfa3b | 194 | int sampling_freq = 11025; | 
| roryhand | 0:e89d7a0bfa3b | 195 | const int BufferLen = 2000; | 
| roryhand | 0:e89d7a0bfa3b | 196 | short Buffer1[BufferLen]; | 
| roryhand | 0:e89d7a0bfa3b | 197 | short Buffer2[BufferLen]; | 
| roryhand | 0:e89d7a0bfa3b | 198 | short place_hold1 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 199 | short place_hold2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 200 | |
| roryhand | 3:6169aeeaeeb4 | 201 | |
| roryhand | 3:6169aeeaeeb4 | 202 | string FOLDER; | 
| roryhand | 3:6169aeeaeeb4 | 203 | string RootFolder = "/sd/mydir/SoundDecoder/"; | 
| roryhand | 3:6169aeeaeeb4 | 204 | string filename[25]; | 
| roryhand | 3:6169aeeaeeb4 | 205 | classSoundFile Sound[22]; | 
| roryhand | 3:6169aeeaeeb4 | 206 | |
| roryhand | 0:e89d7a0bfa3b | 207 | volatile int flag1 = 1; | 
| roryhand | 0:e89d7a0bfa3b | 208 | volatile int flag2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 209 | volatile int flag3 = 1; | 
| roryhand | 0:e89d7a0bfa3b | 210 | volatile int flag4 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 211 | int FLAGBUFF1 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 212 | int FLAGBUFF2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 213 | int BellFlag = 0; | 
| roryhand | 0:e89d7a0bfa3b | 214 | int BellFlag2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 215 | int FadeFlag = 0; | 
| roryhand | 32:6ee488c97dcc | 216 | int FileSwitchFlag = 0; | 
| roryhand | 0:e89d7a0bfa3b | 217 | |
| roryhand | 0:e89d7a0bfa3b | 218 | |
| roryhand | 0:e89d7a0bfa3b | 219 | short value[1]; | 
| roryhand | 0:e89d7a0bfa3b | 220 | FILE *HornWav; | 
| roryhand | 0:e89d7a0bfa3b | 221 | FILE *edsheeran_wav; | 
| roryhand | 0:e89d7a0bfa3b | 222 | FILE *Startup_wav; | 
| roryhand | 0:e89d7a0bfa3b | 223 | FILE *IdleN2Wav; | 
| roryhand | 0:e89d7a0bfa3b | 224 | FILE *N2Wav; | 
| roryhand | 0:e89d7a0bfa3b | 225 | FILE *BellWav; | 
| roryhand | 0:e89d7a0bfa3b | 226 | FILE *FlangeWav; | 
| roryhand | 16:5e3420d0509b | 227 | FILE *HeyWav; | 
| roryhand | 0:e89d7a0bfa3b | 228 | //long long slice_value; | 
| roryhand | 0:e89d7a0bfa3b | 229 | int slice_value[1]; | 
| roryhand | 0:e89d7a0bfa3b | 230 | |
| roryhand | 0:e89d7a0bfa3b | 231 | |
| roryhand | 0:e89d7a0bfa3b | 232 | WAV_FILE_STRUCT WavInfo_Horn; | 
| roryhand | 0:e89d7a0bfa3b | 233 | WAV_FILE_STRUCT WavInfo_IdleN2; | 
| roryhand | 0:e89d7a0bfa3b | 234 | WAV_FILE_STRUCT WavInfo_N2; | 
| roryhand | 0:e89d7a0bfa3b | 235 | WAV_FILE_STRUCT WavInfo_Bell; | 
| roryhand | 0:e89d7a0bfa3b | 236 | WAV_FILE_STRUCT WavInfo_Flange; | 
| roryhand | 20:9cc7d825c07b | 237 | WAV_FILE_STRUCT WavInfo_Hey; | 
| roryhand | 32:6ee488c97dcc | 238 | WAV_FILE_STRUCT WavInfo_N3; | 
| roryhand | 16:5e3420d0509b | 239 | WAV_FILE_STRUCT WavInfo_Frustration; | 
| roryhand | 0:e89d7a0bfa3b | 240 | Ticker flipper; | 
| roryhand | 0:e89d7a0bfa3b | 241 | char * slice_buf_bell; | 
| roryhand | 0:e89d7a0bfa3b | 242 | char * slice_buf_ed; | 
| roryhand | 0:e89d7a0bfa3b | 243 | char * slice_buf_startup; | 
| roryhand | 0:e89d7a0bfa3b | 244 | char * slice_buf_N2; | 
| roryhand | 1:aac37edee302 | 245 | Notch_STRUCT NotchingSet; | 
| roryhand | 0:e89d7a0bfa3b | 246 | //test | 
| roryhand | 0:e89d7a0bfa3b | 247 | //short *data_sptr_bell = 0; | 
| roryhand | 0:e89d7a0bfa3b | 248 | short *data_sptr_ed = 0; | 
| roryhand | 0:e89d7a0bfa3b | 249 | short *data_sptr_startup = 0; | 
| roryhand | 32:6ee488c97dcc | 250 | FILE *StartupWav; | 
| roryhand | 32:6ee488c97dcc | 251 | FILE *N3Wav; | 
| roryhand | 33:a75f0a30fbdc | 252 | int temp = 0; | 
| roryhand | 1:aac37edee302 | 253 | void flip() | 
| roryhand | 1:aac37edee302 | 254 | { | 
| roryhand | 0:e89d7a0bfa3b | 255 | led2 = !led2; | 
| roryhand | 0:e89d7a0bfa3b | 256 | } | 
| roryhand | 0:e89d7a0bfa3b | 257 | |
| roryhand | 0:e89d7a0bfa3b | 258 | |
| roryhand | 0:e89d7a0bfa3b | 259 | void isr() | 
| roryhand | 0:e89d7a0bfa3b | 260 | { | 
| roryhand | 1:aac37edee302 | 261 | if(flag1 == 0) { | 
| roryhand | 0:e89d7a0bfa3b | 262 | value[0] = Buffer1[place_hold1]>>4; | 
| roryhand | 0:e89d7a0bfa3b | 263 | i2s.write(value,1);//Send next PWM value to amp | 
| roryhand | 0:e89d7a0bfa3b | 264 | place_hold1 = place_hold1 + 1; | 
| roryhand | 1:aac37edee302 | 265 | if( (place_hold1 >= BufferLen)) { | 
| roryhand | 0:e89d7a0bfa3b | 266 | led2 = !led2; | 
| roryhand | 0:e89d7a0bfa3b | 267 | place_hold1 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 268 | place_hold2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 269 | flag1 = 1; | 
| roryhand | 0:e89d7a0bfa3b | 270 | flag2 = 0; | 
| roryhand | 1:aac37edee302 | 271 | } | 
| roryhand | 1:aac37edee302 | 272 | } else if(flag2 == 0) { | 
| roryhand | 0:e89d7a0bfa3b | 273 | value[0] = Buffer2[place_hold2]>>4; | 
| roryhand | 0:e89d7a0bfa3b | 274 | i2s.write(value,1);//Send next PWM value to amp | 
| roryhand | 0:e89d7a0bfa3b | 275 | place_hold2 = place_hold2 + 1; | 
| roryhand | 1:aac37edee302 | 276 | if( (place_hold2 >= BufferLen) ) { | 
| roryhand | 0:e89d7a0bfa3b | 277 | led2 = !led2; | 
| roryhand | 0:e89d7a0bfa3b | 278 | place_hold1 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 279 | place_hold2 = 0; | 
| roryhand | 0:e89d7a0bfa3b | 280 | flag1 = 0; | 
| roryhand | 1:aac37edee302 | 281 | flag2 = 1; | 
| roryhand | 0:e89d7a0bfa3b | 282 | FLAGBUFF2 = 0; | 
| roryhand | 1:aac37edee302 | 283 | } | 
| roryhand | 0:e89d7a0bfa3b | 284 | } | 
| roryhand | 0:e89d7a0bfa3b | 285 | } | 
| roryhand | 1:aac37edee302 | 286 | |
| roryhand | 0:e89d7a0bfa3b | 287 | void horn_sound() | 
| roryhand | 0:e89d7a0bfa3b | 288 | { | 
| roryhand | 0:e89d7a0bfa3b | 289 | BellFlag = 1; | 
| roryhand | 0:e89d7a0bfa3b | 290 | fseek(HornWav,44,SEEK_SET); | 
| roryhand | 0:e89d7a0bfa3b | 291 | fseek(BellWav,44,SEEK_SET); | 
| roryhand | 0:e89d7a0bfa3b | 292 | fseek(FlangeWav,44,SEEK_SET); | 
| roryhand | 0:e89d7a0bfa3b | 293 | fseek(N2Wav,44,SEEK_SET); | 
| roryhand | 0:e89d7a0bfa3b | 294 | } | 
| roryhand | 0:e89d7a0bfa3b | 295 | |
| roryhand | 0:e89d7a0bfa3b | 296 | |
| roryhand | 32:6ee488c97dcc | 297 | void FileSwitch_isr() | 
| roryhand | 0:e89d7a0bfa3b | 298 | { | 
| roryhand | 32:6ee488c97dcc | 299 | FileSwitchFlag = 1; | 
| roryhand | 33:a75f0a30fbdc | 300 | temp = 1; | 
| roryhand | 33:a75f0a30fbdc | 301 | /*FILE* testwav = fopen("/sd/mydir/SoundDecoder_second/05.wav","rb"); | 
| roryhand | 33:a75f0a30fbdc | 302 | if(N3Wav == NULL) { | 
| roryhand | 33:a75f0a30fbdc | 303 | printf("Cannot Open testwav\n\r"); | 
| roryhand | 33:a75f0a30fbdc | 304 | } | 
| roryhand | 33:a75f0a30fbdc | 305 | */ | 
| roryhand | 32:6ee488c97dcc | 306 | fseek(N3Wav,44,SEEK_SET); | 
| roryhand | 32:6ee488c97dcc | 307 | // fclose(StartupWav); | 
| roryhand | 0:e89d7a0bfa3b | 308 | } | 
| roryhand | 0:e89d7a0bfa3b | 309 | |
| roryhand | 0:e89d7a0bfa3b | 310 | |
| roryhand | 0:e89d7a0bfa3b | 311 | void FadeOutIsr() | 
| roryhand | 0:e89d7a0bfa3b | 312 | { | 
| roryhand | 1:aac37edee302 | 313 | FadeFlag = 1; | 
| roryhand | 1:aac37edee302 | 314 | fseek(IdleN2Wav,44,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 315 | fseek(N2Wav,44,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 316 | fseek(HornWav,44,SEEK_SET); | 
| roryhand | 0:e89d7a0bfa3b | 317 | fseek(FlangeWav,44,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 318 | |
| roryhand | 0:e89d7a0bfa3b | 319 | } | 
| roryhand | 38:3b4c05af5f36 | 320 | /* | 
| roryhand | 38:3b4c05af5f36 | 321 | void filenotch_isr() | 
| roryhand | 38:3b4c05af5f36 | 322 | { | 
| roryhand | 38:3b4c05af5f36 | 323 | if(up) { | 
| roryhand | 38:3b4c05af5f36 | 324 | notch = notch+1; | 
| roryhand | 38:3b4c05af5f36 | 325 | notchtrans_up = notch + 8; | 
| roryhand | 38:3b4c05af5f36 | 326 | |
| roryhand | 38:3b4c05af5f36 | 327 | } else if(down) { | 
| roryhand | 38:3b4c05af5f36 | 328 | notch = notch-1; | 
| roryhand | 38:3b4c05af5f36 | 329 | notchtrans_down = notch + 15; | 
| roryhand | 38:3b4c05af5f36 | 330 | } | 
| roryhand | 38:3b4c05af5f36 | 331 | notch_flag = 1; | 
| roryhand | 38:3b4c05af5f36 | 332 | |
| roryhand | 38:3b4c05af5f36 | 333 | |
| roryhand | 38:3b4c05af5f36 | 334 | } | 
| roryhand | 38:3b4c05af5f36 | 335 | */ | 
| roryhand | 38:3b4c05af5f36 | 336 | |
| roryhand | 38:3b4c05af5f36 | 337 | |
| roryhand | 38:3b4c05af5f36 | 338 | |
| roryhand | 0:e89d7a0bfa3b | 339 | |
| roryhand | 3:6169aeeaeeb4 | 340 | classFade FadeDataInitialise(classFade FadeData); | 
| roryhand | 3:6169aeeaeeb4 | 341 | |
| roryhand | 3:6169aeeaeeb4 | 342 | |
| roryhand | 3:6169aeeaeeb4 | 343 | |
| roryhand | 3:6169aeeaeeb4 | 344 | |
| roryhand | 3:6169aeeaeeb4 | 345 | |
| roryhand | 3:6169aeeaeeb4 | 346 | //function prototypes | 
| roryhand | 3:6169aeeaeeb4 | 347 | WAV_FILE_STRUCT ReadFileInfo(WAV_FILE_STRUCT FileInfo, FILE * wav_file); | 
| roryhand | 3:6169aeeaeeb4 | 348 | classSoundFile LoadFileStream(classSoundFile FileInfo, string filename); | 
| roryhand | 3:6169aeeaeeb4 | 349 | |
| roryhand | 3:6169aeeaeeb4 | 350 | float FadeOut(void); | 
| roryhand | 3:6169aeeaeeb4 | 351 | void Play_WaveFile(FILE * my_wav, WAV_FILE_STRUCT FileInfo); | 
| roryhand | 32:6ee488c97dcc | 352 | void Play_WaveFileDual(FILE * my_wav, WAV_FILE_STRUCT FileInfo); | 
| roryhand | 3:6169aeeaeeb4 | 353 | //void Play_WaveFileLoop(FILE * my_wav, WAV_FILE_STRUCT FileInfo); | 
| roryhand | 3:6169aeeaeeb4 | 354 | //*********************INTERRUPT ROUTINE FOR NOTCHING*************************** | 
| roryhand | 0:e89d7a0bfa3b | 355 | |
| roryhand | 1:aac37edee302 | 356 | void NotchUpIsr() | 
| roryhand | 0:e89d7a0bfa3b | 357 | { | 
| roryhand | 1:aac37edee302 | 358 | if(1 <= NotchingSet.Notch < 8) { | 
| roryhand | 1:aac37edee302 | 359 | |
| roryhand | 1:aac37edee302 | 360 | NotchingSet.Notch = NotchingSet.Notch + 1; | 
| roryhand | 1:aac37edee302 | 361 | NotchingSet.NotchTransUp = NotchingSet.Notch + 7; | 
| roryhand | 1:aac37edee302 | 362 | NotchingSet.NotchDirection = 1; | 
| roryhand | 3:6169aeeaeeb4 | 363 | FadeDataInitialise(NotchFadeIn); | 
| roryhand | 3:6169aeeaeeb4 | 364 | FadeDataInitialise(NotchFadeOut); | 
| roryhand | 1:aac37edee302 | 365 | } | 
| roryhand | 0:e89d7a0bfa3b | 366 | } | 
| roryhand | 0:e89d7a0bfa3b | 367 | |
| roryhand | 0:e89d7a0bfa3b | 368 | void NotchDownIsr() | 
| roryhand | 0:e89d7a0bfa3b | 369 | { | 
| roryhand | 1:aac37edee302 | 370 | if(1 < NotchingSet.Notch <= 8) { | 
| roryhand | 1:aac37edee302 | 371 | NotchingSet.Notch = NotchingSet.Notch - 1; | 
| roryhand | 1:aac37edee302 | 372 | NotchingSet.NotchTransDown = NotchingSet.Notch + 15;; | 
| roryhand | 1:aac37edee302 | 373 | NotchingSet.NotchDirection = 0; | 
| roryhand | 3:6169aeeaeeb4 | 374 | FadeDataInitialise(NotchFadeIn); | 
| roryhand | 3:6169aeeaeeb4 | 375 | FadeDataInitialise(NotchFadeOut); | 
| roryhand | 1:aac37edee302 | 376 | } | 
| roryhand | 1:aac37edee302 | 377 | } | 
| roryhand | 0:e89d7a0bfa3b | 378 | |
| roryhand | 0:e89d7a0bfa3b | 379 | |
| roryhand | 3:6169aeeaeeb4 | 380 | /**********************END OF INTERRUPT ROUTINE FOR NOTCHING*******************/ | 
| roryhand | 3:6169aeeaeeb4 | 381 | |
| roryhand | 3:6169aeeaeeb4 | 382 | |
| roryhand | 1:aac37edee302 | 383 | |
| roryhand | 0:e89d7a0bfa3b | 384 | |
| roryhand | 3:6169aeeaeeb4 | 385 | |
| roryhand | 3:6169aeeaeeb4 | 386 | |
| roryhand | 9:dd9cae06b202 | 387 | void Play_WaveFileLoop(classSoundFile Sounds[], Notch_STRUCT NotchingSet); | 
| roryhand | 1:aac37edee302 | 388 | int main() | 
| roryhand | 1:aac37edee302 | 389 | { | 
| roryhand | 32:6ee488c97dcc | 390 | |
| roryhand | 0:e89d7a0bfa3b | 391 | NotchUp.mode(PullUp); | 
| roryhand | 38:3b4c05af5f36 | 392 | NotchDown.mode(PullUp); | 
| roryhand | 0:e89d7a0bfa3b | 393 | |
| roryhand | 0:e89d7a0bfa3b | 394 | WAV_FILE_STRUCT WavInfo_Startup; | 
| roryhand | 0:e89d7a0bfa3b | 395 | WAV_FILE_STRUCT WavInfo_Idle; | 
| roryhand | 0:e89d7a0bfa3b | 396 | |
| roryhand | 0:e89d7a0bfa3b | 397 | pc.printf("Beginning of program\n"); | 
| roryhand | 32:6ee488c97dcc | 398 | |
| roryhand | 0:e89d7a0bfa3b | 399 | FILE *IdleWav; | 
| roryhand | 1:aac37edee302 | 400 | |
| roryhand | 3:6169aeeaeeb4 | 401 | |
| roryhand | 37:a563899ac0df | 402 | char buf[10]; | 
| roryhand | 37:a563899ac0df | 403 | int a = 1; | 
| roryhand | 37:a563899ac0df | 404 | sprintf(buf, "%d", a); | 
| roryhand | 13:8e93396a27c5 | 405 | |
| roryhand | 37:a563899ac0df | 406 | string foo( "hello" ); | 
| roryhand | 37:a563899ac0df | 407 | string test( "how are" ); | 
| roryhand | 37:a563899ac0df | 408 | string hello; | 
| roryhand | 37:a563899ac0df | 409 | hello = foo + test; | 
| roryhand | 37:a563899ac0df | 410 | printf("%s\n\r",hello); | 
| roryhand | 37:a563899ac0df | 411 | |
| roryhand | 37:a563899ac0df | 412 | string RootFolder = "sd/mydir/SoundDecoder_second/"; | 
| roryhand | 37:a563899ac0df | 413 | string folder = RootFolder + "0" + buf + ".wav"; | 
| roryhand | 37:a563899ac0df | 414 | printf("FullFile location: %s\n\r",folder); | 
| roryhand | 13:8e93396a27c5 | 415 | |
| roryhand | 32:6ee488c97dcc | 416 | |
| roryhand | 1:aac37edee302 | 417 | |
| roryhand | 37:a563899ac0df | 418 | classSoundFile Sound[22]; | 
| roryhand | 37:a563899ac0df | 419 | string file_names[22]; | 
| roryhand | 38:3b4c05af5f36 | 420 | const char* FileName; | 
| roryhand | 37:a563899ac0df | 421 | for(int aaa = 0; aaa < 20; aaa ++) { | 
| roryhand | 37:a563899ac0df | 422 | a = aaa+1; | 
| roryhand | 37:a563899ac0df | 423 | sprintf(buf, "%d", a); | 
| roryhand | 37:a563899ac0df | 424 | Sound[aaa].file_location = RootFolder + "0" + buf + ".wav"; | 
| roryhand | 38:3b4c05af5f36 | 425 | FileName = Sound[aaa].file_location.c_str(); | 
| roryhand | 38:3b4c05af5f36 | 426 | /*Sound[aaa].FileInfo.WavFile = fopen(FileName,"rb"); | 
| roryhand | 38:3b4c05af5f36 | 427 | if(Sound[aaa].FileInfo.WavFile == NULL){ | 
| roryhand | 38:3b4c05af5f36 | 428 | printf("Cannot Open Sound[%d].FileInfo.WavFile\n\r",aaa); | 
| roryhand | 38:3b4c05af5f36 | 429 | |
| roryhand | 38:3b4c05af5f36 | 430 | } | 
| roryhand | 38:3b4c05af5f36 | 431 | */ | 
| roryhand | 37:a563899ac0df | 432 | printf("FileName: %s\n\r",Sound[aaa].file_location); | 
| roryhand | 38:3b4c05af5f36 | 433 | //fclose(Sound[aaa].FileInfo.WavFile); | 
| roryhand | 38:3b4c05af5f36 | 434 | //wait(1); | 
| roryhand | 37:a563899ac0df | 435 | } | 
| roryhand | 38:3b4c05af5f36 | 436 | |
| roryhand | 37:a563899ac0df | 437 | /* | 
| roryhand | 37:a563899ac0df | 438 | string RootFolder = "sd/mydir/SoundDecoder_second/"; | 
| roryhand | 37:a563899ac0df | 439 | string folder = RootFolder + "01.wav"; | 
| roryhand | 37:a563899ac0df | 440 | printf("Full file location: %s\n\r",folder); | 
| roryhand | 37:a563899ac0df | 441 | */ | 
| roryhand | 32:6ee488c97dcc | 442 | |
| roryhand | 1:aac37edee302 | 443 | |
| roryhand | 1:aac37edee302 | 444 | |
| roryhand | 37:a563899ac0df | 445 | /* | 
| roryhand | 37:a563899ac0df | 446 | for(int aaa = 0;aaa < 21; aaa ++ ) | 
| roryhand | 37:a563899ac0df | 447 | { | 
| roryhand | 37:a563899ac0df | 448 | folder = RootFolder + "\01.wav";//filename[aaa]; | 
| roryhand | 37:a563899ac0df | 449 | FOLDER = folder.c_str(); | 
| roryhand | 37:a563899ac0df | 450 | Sound[aaa].FileInfo.WavFile = fopen(FOLDER,"rb"); | 
| roryhand | 37:a563899ac0df | 451 | //MyNewWav.WavFile = fopen("/sd/mydir/Startup.wav","rb"); | 
| roryhand | 37:a563899ac0df | 452 | printf("we opened This file %d\n\r",aaa); | 
| roryhand | 37:a563899ac0df | 453 | |
| roryhand | 37:a563899ac0df | 454 | } | 
| roryhand | 37:a563899ac0df | 455 | */ | 
| roryhand | 1:aac37edee302 | 456 | |
| roryhand | 31:0f8c3adf09c3 | 457 | |
| roryhand | 31:0f8c3adf09c3 | 458 | |
| roryhand | 32:6ee488c97dcc | 459 | printf("About to Start ReadFileInfo Operations\n\r"); | 
| roryhand | 38:3b4c05af5f36 | 460 | |
| roryhand | 32:6ee488c97dcc | 461 | FILE* mywav1 = fopen("/sd/mydir/SoundDecoder_second/01.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 462 | if(mywav1 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 463 | printf("Cannot Open mywav1\n\r"); | 
| roryhand | 32:6ee488c97dcc | 464 | } | 
| roryhand | 38:3b4c05af5f36 | 465 | fclose(mywav1); | 
| roryhand | 38:3b4c05af5f36 | 466 | |
| roryhand | 32:6ee488c97dcc | 467 | FILE* mywav2 = fopen("/sd/mydir/SoundDecoder_second/02.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 468 | if(mywav2 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 469 | printf("Cannot Open mywav2\n\r"); | 
| roryhand | 32:6ee488c97dcc | 470 | } | 
| roryhand | 38:3b4c05af5f36 | 471 | fclose(mywav2); | 
| roryhand | 38:3b4c05af5f36 | 472 | |
| roryhand | 32:6ee488c97dcc | 473 | FILE* mywav3 = fopen("/sd/mydir/SoundDecoder_second/03.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 474 | if(mywav3 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 475 | printf("Cannot Open mywav3\n\r"); | 
| roryhand | 32:6ee488c97dcc | 476 | } | 
| roryhand | 38:3b4c05af5f36 | 477 | fclose(mywav3); | 
| roryhand | 38:3b4c05af5f36 | 478 | |
| roryhand | 32:6ee488c97dcc | 479 | FILE* mywav4 = fopen("/sd/mydir/SoundDecoder_second/04.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 480 | if(mywav4 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 481 | printf("Cannot Open mywav4\n\r"); | 
| roryhand | 32:6ee488c97dcc | 482 | } | 
| roryhand | 38:3b4c05af5f36 | 483 | fclose(mywav4); | 
| roryhand | 13:8e93396a27c5 | 484 | |
| roryhand | 38:3b4c05af5f36 | 485 | FILE* mywav5 = fopen("/sd/mydir/SoundDecoder_second/05.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 486 | if(mywav5 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 487 | printf("Cannot Open mywav5\n\r"); | 
| roryhand | 32:6ee488c97dcc | 488 | } | 
| roryhand | 38:3b4c05af5f36 | 489 | fclose(mywav5); | 
| roryhand | 38:3b4c05af5f36 | 490 | |
| roryhand | 38:3b4c05af5f36 | 491 | FILE* mywav6 = fopen("/sd/mydir/SoundDecoder_second/06.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 492 | if(mywav6 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 493 | printf("Cannot Open mywav6\n\r"); | 
| roryhand | 32:6ee488c97dcc | 494 | } | 
| roryhand | 38:3b4c05af5f36 | 495 | fclose(mywav6); | 
| roryhand | 38:3b4c05af5f36 | 496 | |
| roryhand | 38:3b4c05af5f36 | 497 | FILE* mywav7 = fopen("/sd/mydir/SoundDecoder_second/07.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 498 | if(mywav7 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 499 | printf("Cannot Open mywav7\n\r"); | 
| roryhand | 32:6ee488c97dcc | 500 | } | 
| roryhand | 38:3b4c05af5f36 | 501 | fclose(mywav7); | 
| roryhand | 38:3b4c05af5f36 | 502 | |
| roryhand | 38:3b4c05af5f36 | 503 | FILE* mywav8 = fopen("/sd/mydir/SoundDecoder_second/08.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 504 | if(mywav8 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 505 | printf("Cannot Open mywav8\n\r"); | 
| roryhand | 32:6ee488c97dcc | 506 | } | 
| roryhand | 38:3b4c05af5f36 | 507 | fclose(mywav8); | 
| roryhand | 38:3b4c05af5f36 | 508 | |
| roryhand | 38:3b4c05af5f36 | 509 | FILE* mywav9 = fopen("/sd/mydir/SoundDecoder_second/09.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 510 | if(mywav9 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 511 | printf("Cannot Open mywav9\n\r"); | 
| roryhand | 32:6ee488c97dcc | 512 | } | 
| roryhand | 38:3b4c05af5f36 | 513 | fclose(mywav9); | 
| roryhand | 38:3b4c05af5f36 | 514 | |
| roryhand | 38:3b4c05af5f36 | 515 | FILE* mywav10 = fopen("/sd/mydir/SoundDecoder_second/10.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 516 | if(mywav10 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 517 | printf("Cannot Open mywav10\n\r"); | 
| roryhand | 32:6ee488c97dcc | 518 | } | 
| roryhand | 38:3b4c05af5f36 | 519 | fclose(mywav10); | 
| roryhand | 38:3b4c05af5f36 | 520 | |
| roryhand | 38:3b4c05af5f36 | 521 | FILE* mywav11= fopen("/sd/mydir/SoundDecoder_second/11.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 522 | if(mywav11 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 523 | printf("Cannot Open mywav11\n\r"); | 
| roryhand | 32:6ee488c97dcc | 524 | } | 
| roryhand | 38:3b4c05af5f36 | 525 | fclose(mywav11); | 
| roryhand | 38:3b4c05af5f36 | 526 | |
| roryhand | 38:3b4c05af5f36 | 527 | FILE* mywav12 = fopen("/sd/mydir/SoundDecoder_second/12.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 528 | if(mywav12 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 529 | printf("Cannot Open mywav12\n\r"); | 
| roryhand | 32:6ee488c97dcc | 530 | } | 
| roryhand | 38:3b4c05af5f36 | 531 | fclose(mywav12); | 
| roryhand | 38:3b4c05af5f36 | 532 | |
| roryhand | 38:3b4c05af5f36 | 533 | FILE* mywav13 = fopen("/sd/mydir/SoundDecoder_second/13.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 534 | if(mywav13 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 535 | printf("Cannot Open mywav13\n\r"); | 
| roryhand | 32:6ee488c97dcc | 536 | } | 
| roryhand | 38:3b4c05af5f36 | 537 | fclose(mywav13); | 
| roryhand | 38:3b4c05af5f36 | 538 | |
| roryhand | 38:3b4c05af5f36 | 539 | FILE* mywav14 = fopen("/sd/mydir/SoundDecoder_second/14.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 540 | if(mywav14 == NULL){ | 
| roryhand | 32:6ee488c97dcc | 541 | printf("Cannot Open mywav14\n\r"); | 
| roryhand | 32:6ee488c97dcc | 542 | } | 
| roryhand | 38:3b4c05af5f36 | 543 | fclose(mywav14); | 
| roryhand | 28:6b2353fad12d | 544 | |
| roryhand | 38:3b4c05af5f36 | 545 | |
| roryhand | 13:8e93396a27c5 | 546 | |
| roryhand | 13:8e93396a27c5 | 547 | |
| roryhand | 13:8e93396a27c5 | 548 | |
| roryhand | 32:6ee488c97dcc | 549 | HeyWav = fopen("/sd/mydir/645Engine/EX_FlangeJoint1_11k_minus12dB.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 550 | if(HeyWav == NULL) { | 
| roryhand | 32:6ee488c97dcc | 551 | printf("Cannot Open HeyWav\n\r"); | 
| roryhand | 32:6ee488c97dcc | 552 | } | 
| roryhand | 32:6ee488c97dcc | 553 | |
| roryhand | 32:6ee488c97dcc | 554 | N3Wav = fopen("/sd/mydir/SoundDecoder_second/03.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 555 | if(N3Wav == NULL) { | 
| roryhand | 32:6ee488c97dcc | 556 | printf("Cannot Open N3Wav\n\r"); | 
| roryhand | 32:6ee488c97dcc | 557 | } | 
| roryhand | 32:6ee488c97dcc | 558 | WavInfo_N3 = ReadFileInfo(WavInfo_N3,N3Wav); | 
| roryhand | 32:6ee488c97dcc | 559 | fclose(N3Wav); | 
| roryhand | 25:5336e1cf38d6 | 560 | |
| roryhand | 25:5336e1cf38d6 | 561 | |
| roryhand | 13:8e93396a27c5 | 562 | |
| roryhand | 22:706e86dc0d45 | 563 | printf("About to Read HeyWav\n\r"); | 
| roryhand | 28:6b2353fad12d | 564 | |
| roryhand | 32:6ee488c97dcc | 565 | |
| roryhand | 32:6ee488c97dcc | 566 | |
| roryhand | 25:5336e1cf38d6 | 567 | WavInfo_Hey = ReadFileInfo(WavInfo_Hey,HeyWav); | 
| roryhand | 28:6b2353fad12d | 568 | |
| roryhand | 13:8e93396a27c5 | 569 | |
| roryhand | 13:8e93396a27c5 | 570 | |
| roryhand | 4:55fbbb049bae | 571 | |
| roryhand | 25:5336e1cf38d6 | 572 | printf("Do we even get to this stupid bloody point\n\r"); | 
| roryhand | 0:e89d7a0bfa3b | 573 | //Populate our class instances with some data (is there an implicit way to do this?) | 
| roryhand | 28:6b2353fad12d | 574 | |
| roryhand | 1:aac37edee302 | 575 | |
| roryhand | 3:6169aeeaeeb4 | 576 | printf("hello\n\r"); | 
| roryhand | 0:e89d7a0bfa3b | 577 | //Set up the wolfson Audio Codec board | 
| roryhand | 0:e89d7a0bfa3b | 578 | wm8731_Config_setup(); | 
| roryhand | 0:e89d7a0bfa3b | 579 | //i2s audio data transfer code?? | 
| roryhand | 0:e89d7a0bfa3b | 580 | i2s.stereomono(I2S_STEREO); | 
| roryhand | 0:e89d7a0bfa3b | 581 | i2s.masterslave(I2S_MASTER); | 
| roryhand | 0:e89d7a0bfa3b | 582 | led3 = 1; | 
| roryhand | 0:e89d7a0bfa3b | 583 | led2 = 1; | 
| roryhand | 30:4a8e80b243c4 | 584 | printf("Hello i2s has starrted!"); | 
| roryhand | 30:4a8e80b243c4 | 585 | i2s.start(); | 
| roryhand | 0:e89d7a0bfa3b | 586 | sampletick.attach(&isr,1.0/sampling_freq); //1/16000 | 
| roryhand | 32:6ee488c97dcc | 587 | fileswitch_tick.attach(&FileSwitch_isr,6.0);//So we can switch between playing file 1 and file 2, including opening and closing | 
| roryhand | 31:0f8c3adf09c3 | 588 | |
| roryhand | 31:0f8c3adf09c3 | 589 | |
| roryhand | 31:0f8c3adf09c3 | 590 | timer_open.reset(); | 
| roryhand | 32:6ee488c97dcc | 591 | timer_open.start(); | 
| roryhand | 32:6ee488c97dcc | 592 | N3Wav = fopen("/sd/mydir/SoundDecoder_second/03.wav","rb"); | 
| roryhand | 32:6ee488c97dcc | 593 | if(N3Wav == NULL) { | 
| roryhand | 32:6ee488c97dcc | 594 | printf("Cannot Open N3Wav\n\r"); | 
| roryhand | 32:6ee488c97dcc | 595 | } | 
| roryhand | 35:4469b508dda3 | 596 | fclose(N3Wav); | 
| roryhand | 30:4a8e80b243c4 | 597 | StartupWav = fopen("/sd/mydir/Startup.wav","rb"); | 
| roryhand | 31:0f8c3adf09c3 | 598 | timer_open.reset(); | 
| roryhand | 31:0f8c3adf09c3 | 599 | printf("It took %d useconds to open file\n\r",timer_open.read_us()); | 
| roryhand | 31:0f8c3adf09c3 | 600 | //const char* folder2 = folder.c_str(); | 
| roryhand | 31:0f8c3adf09c3 | 601 | |
| roryhand | 31:0f8c3adf09c3 | 602 | |
| roryhand | 31:0f8c3adf09c3 | 603 | |
| roryhand | 28:6b2353fad12d | 604 | fseek(StartupWav,44,SEEK_SET); | 
| roryhand | 32:6ee488c97dcc | 605 | timer_open.reset(); | 
| roryhand | 32:6ee488c97dcc | 606 | timer_open.start(); | 
| roryhand | 28:6b2353fad12d | 607 | WavInfo_Startup = ReadFileInfo(WavInfo_Startup,StartupWav); | 
| roryhand | 32:6ee488c97dcc | 608 | timer_open.stop(); | 
| roryhand | 32:6ee488c97dcc | 609 | printf("It took %d useconds to Read In File Info\n\r",timer_open.read_us()); | 
| roryhand | 13:8e93396a27c5 | 610 | |
| roryhand | 32:6ee488c97dcc | 611 | |
| roryhand | 32:6ee488c97dcc | 612 | |
| roryhand | 32:6ee488c97dcc | 613 | |
| roryhand | 31:0f8c3adf09c3 | 614 | |
| roryhand | 20:9cc7d825c07b | 615 | printf("about to play wav file\n\r"); | 
| roryhand | 32:6ee488c97dcc | 616 | Play_WaveFileDual(StartupWav,WavInfo_Startup); | 
| roryhand | 20:9cc7d825c07b | 617 | printf("finished playing Wav file\n\r"); | 
| roryhand | 31:0f8c3adf09c3 | 618 | timer_open.reset(); | 
| roryhand | 31:0f8c3adf09c3 | 619 | timer_open.start(); | 
| roryhand | 31:0f8c3adf09c3 | 620 | fclose(StartupWav); | 
| roryhand | 31:0f8c3adf09c3 | 621 | timer_open.stop(); | 
| roryhand | 31:0f8c3adf09c3 | 622 | printf("It took %d useconds to close file\n\r",timer_open.read_us()); | 
| roryhand | 9:dd9cae06b202 | 623 | /************************************PLAY WAV FILE LOOP*******************/ | 
| roryhand | 20:9cc7d825c07b | 624 | //Play_WaveFileLoop(Sound, NotchingSet); | 
| roryhand | 9:dd9cae06b202 | 625 | /************************************END OF PLAY WAV FILE LOOP*************/ | 
| roryhand | 13:8e93396a27c5 | 626 | |
| roryhand | 13:8e93396a27c5 | 627 | |
| roryhand | 13:8e93396a27c5 | 628 | |
| roryhand | 9:dd9cae06b202 | 629 | |
| roryhand | 3:6169aeeaeeb4 | 630 | |
| roryhand | 0:e89d7a0bfa3b | 631 | fseek(IdleN2Wav,44,SEEK_SET);//reset for use in the Loop code | 
| roryhand | 0:e89d7a0bfa3b | 632 | slice = 0; | 
| roryhand | 0:e89d7a0bfa3b | 633 | fseek(IdleWav,44,SEEK_SET); | 
| roryhand | 3:6169aeeaeeb4 | 634 | NotchingSet.Notch = 1; | 
| roryhand | 1:aac37edee302 | 635 | //Play_WaveFileLoop(IdleWav, WavInfo_Idle); | 
| roryhand | 1:aac37edee302 | 636 | |
| roryhand | 1:aac37edee302 | 637 | i2s.stop(); | 
| roryhand | 0:e89d7a0bfa3b | 638 | |
| roryhand | 0:e89d7a0bfa3b | 639 | } | 
| roryhand | 0:e89d7a0bfa3b | 640 | |
| roryhand | 0:e89d7a0bfa3b | 641 | |
| roryhand | 3:6169aeeaeeb4 | 642 | |
| roryhand | 3:6169aeeaeeb4 | 643 | |
| roryhand | 3:6169aeeaeeb4 | 644 | |
| roryhand | 3:6169aeeaeeb4 | 645 | |
| roryhand | 0:e89d7a0bfa3b | 646 | WAV_FILE_STRUCT ReadFileInfo(WAV_FILE_STRUCT FileInfo, FILE * wav_file) | 
| roryhand | 0:e89d7a0bfa3b | 647 | { | 
| roryhand | 0:e89d7a0bfa3b | 648 | fseek(wav_file,20,SEEK_SET); | 
| roryhand | 22:706e86dc0d45 | 649 | printf("We have just seeked through this file\n\r"); | 
| roryhand | 0:e89d7a0bfa3b | 650 | fread(&FileInfo.FileFormat,sizeof(FileInfo.FileFormat),1,wav_file); | 
| roryhand | 1:aac37edee302 | 651 | //printf("wav_format.sample_rate: %d\n\r",FileInfo.FileFormat.sample_rate); | 
| roryhand | 1:aac37edee302 | 652 | |
| roryhand | 0:e89d7a0bfa3b | 653 | fread(&FileInfo.FileData,sizeof(FileInfo.FileData),1,wav_file); | 
| roryhand | 1:aac37edee302 | 654 | //printf("wav_data.subchunk2_size: %d\n\r",FileInfo.FileData.subchunk2_size); | 
| roryhand | 0:e89d7a0bfa3b | 655 | FileInfo.slice_buf = ( char *)malloc(FileInfo.FileFormat.block_align); | 
| roryhand | 0:e89d7a0bfa3b | 656 | fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,wav_file); //This isnt actually required, its just a test | 
| roryhand | 1:aac37edee302 | 657 | FileInfo.num_slices = FileInfo.FileData.subchunk2_size/FileInfo.FileFormat.block_align; | 
| roryhand | 1:aac37edee302 | 658 | //printf("Number of Slices: %d\n\r",FileInfo.num_slices); | 
| roryhand | 1:aac37edee302 | 659 | return FileInfo; | 
| roryhand | 0:e89d7a0bfa3b | 660 | } | 
| roryhand | 1:aac37edee302 | 661 | |
| roryhand | 1:aac37edee302 | 662 | classSoundFile LoadFileStream(classSoundFile Sound, string filename) | 
| roryhand | 1:aac37edee302 | 663 | { | 
| roryhand | 1:aac37edee302 | 664 | //Declare RootFolder and the directory for the appropriate file. | 
| roryhand | 1:aac37edee302 | 665 | //How we index into filename[] from the outside of this class is another | 
| roryhand | 1:aac37edee302 | 666 | //issue... | 
| roryhand | 1:aac37edee302 | 667 | //printf("FileName: %s\n\r",filename); | 
| roryhand | 1:aac37edee302 | 668 | //string RootFolder = "/sd/mydir/SoundDecoder/"; | 
| roryhand | 1:aac37edee302 | 669 | //string Directory = RootFolder + "01.wav";// + filename[0]; | 
| roryhand | 1:aac37edee302 | 670 | //printf("%s\n\r",Directory); | 
| roryhand | 1:aac37edee302 | 671 | //const char* DirectoryChar = Directory.c_str(); | 
| roryhand | 1:aac37edee302 | 672 | //Sound.FileInfo.WavFile = fopen(DirectoryChar,"rb"); | 
| roryhand | 1:aac37edee302 | 673 | Sound.FileInfo.WavFile = fopen("/sd/mydir/645Engine/Startup.wav","rb"); | 
| roryhand | 1:aac37edee302 | 674 | fseek(Sound.FileInfo.WavFile,20,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 675 | fread(&Sound.FileInfo.FileFormat,sizeof(Sound.FileInfo.FileFormat),1,Sound.FileInfo.WavFile); | 
| roryhand | 1:aac37edee302 | 676 | printf("wav_format.sample_rate: %d\n\r",Sound.FileInfo.FileFormat.sample_rate); | 
| roryhand | 1:aac37edee302 | 677 | fread(&Sound.FileInfo.FileData,sizeof(Sound.FileInfo.FileData),1,Sound.FileInfo.WavFile); | 
| roryhand | 1:aac37edee302 | 678 | printf("wav_data.subchunk2_size: %d\n\r",Sound.FileInfo.FileData.subchunk2_size); | 
| roryhand | 1:aac37edee302 | 679 | Sound.FileInfo.slice_buf = ( char *)malloc(Sound.FileInfo.FileFormat.block_align); | 
| roryhand | 1:aac37edee302 | 680 | fread(Sound.FileInfo.slice_buf,Sound.FileInfo.FileFormat.block_align,1,Sound.FileInfo.WavFile); //This isnt actually required, its just a test | 
| roryhand | 1:aac37edee302 | 681 | Sound.FileInfo.num_slices = Sound.FileInfo.FileData.subchunk2_size/Sound.FileInfo.FileFormat.block_align; | 
| roryhand | 1:aac37edee302 | 682 | printf("Number of Slices: %d\n\r",Sound.FileInfo.num_slices); | 
| roryhand | 1:aac37edee302 | 683 | return Sound; | 
| roryhand | 1:aac37edee302 | 684 | } | 
| roryhand | 1:aac37edee302 | 685 | |
| roryhand | 1:aac37edee302 | 686 | |
| roryhand | 0:e89d7a0bfa3b | 687 | classFade FadeDataInitialise(classFade FadeData) | 
| roryhand | 0:e89d7a0bfa3b | 688 | { | 
| roryhand | 1:aac37edee302 | 689 | FadeData.DecayFactor = 1.3; | 
| roryhand | 0:e89d7a0bfa3b | 690 | FadeData.FadeIteration = 1; | 
| roryhand | 0:e89d7a0bfa3b | 691 | //FadeData.Denom = 11025*FadeData.DecayFactor; | 
| roryhand | 0:e89d7a0bfa3b | 692 | FadeData.Denom = 11025*FadeData.DecayFactor; | 
| roryhand | 0:e89d7a0bfa3b | 693 | FadeData.Natural_Exp = 2.7183; | 
| roryhand | 0:e89d7a0bfa3b | 694 | FadeData.Length = 11025*FadeData.LengthSecs; | 
| roryhand | 0:e89d7a0bfa3b | 695 | //FadeData.Natural_Exp = 2.7; | 
| roryhand | 0:e89d7a0bfa3b | 696 | return FadeData; | 
| roryhand | 0:e89d7a0bfa3b | 697 | } | 
| roryhand | 0:e89d7a0bfa3b | 698 | |
| roryhand | 0:e89d7a0bfa3b | 699 | //Playing Files Code | 
| roryhand | 0:e89d7a0bfa3b | 700 | /*float FadeIn(void) | 
| roryhand | 0:e89d7a0bfa3b | 701 | { | 
| roryhand | 0:e89d7a0bfa3b | 702 | powervalFadeIn = FadeIterationIn/denom; | 
| roryhand | 0:e89d7a0bfa3b | 703 | FadeCoeffFadeIn | 
| roryhand | 1:aac37edee302 | 704 | |
| roryhand | 1:aac37edee302 | 705 | |
| roryhand | 0:e89d7a0bfa3b | 706 | }*/ | 
| roryhand | 0:e89d7a0bfa3b | 707 | /*float FadeOut(void) | 
| roryhand | 0:e89d7a0bfa3b | 708 | { | 
| roryhand | 0:e89d7a0bfa3b | 709 | powerval = -FadeIteration/denom; | 
| roryhand | 0:e89d7a0bfa3b | 710 | FadeCoeff = pow(natural_exp,powerval); | 
| roryhand | 1:aac37edee302 | 711 | FadeIteration = FadeIteration + 1; | 
| roryhand | 1:aac37edee302 | 712 | return FadeCoeff; | 
| roryhand | 1:aac37edee302 | 713 | |
| roryhand | 0:e89d7a0bfa3b | 714 | }*/ | 
| roryhand | 0:e89d7a0bfa3b | 715 | |
| roryhand | 0:e89d7a0bfa3b | 716 | |
| roryhand | 0:e89d7a0bfa3b | 717 | void Play_WaveFile(FILE * my_wav, WAV_FILE_STRUCT FileInfo) | 
| roryhand | 0:e89d7a0bfa3b | 718 | { | 
| roryhand | 1:aac37edee302 | 719 | while(slice<FileInfo.num_slices) { | 
| roryhand | 1:aac37edee302 | 720 | fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,my_wav); | 
| roryhand | 1:aac37edee302 | 721 | data_sptr=(short *)FileInfo.slice_buf; // 16 bit samples | 
| roryhand | 1:aac37edee302 | 722 | for (channel=0; channel<FileInfo.FileFormat.num_channels; channel++) { | 
| roryhand | 1:aac37edee302 | 723 | if(flag1 == 1) { | 
| roryhand | 1:aac37edee302 | 724 | Buffer1[place_hold1] = data_sptr[channel]; | 
| roryhand | 1:aac37edee302 | 725 | place_hold1 = place_hold1 + 1; | 
| roryhand | 1:aac37edee302 | 726 | if(place_hold1 >= BufferLen) { | 
| roryhand | 1:aac37edee302 | 727 | while(1) { | 
| roryhand | 1:aac37edee302 | 728 | if(flag1 == 0) { | 
| roryhand | 0:e89d7a0bfa3b | 729 | |
| roryhand | 1:aac37edee302 | 730 | break; | 
| roryhand | 0:e89d7a0bfa3b | 731 | } | 
| roryhand | 1:aac37edee302 | 732 | |
| roryhand | 0:e89d7a0bfa3b | 733 | } | 
| roryhand | 1:aac37edee302 | 734 | } | 
| roryhand | 1:aac37edee302 | 735 | |
| roryhand | 1:aac37edee302 | 736 | } else if(flag2 == 1) { | 
| roryhand | 1:aac37edee302 | 737 | Buffer2[place_hold2] = data_sptr[channel]; | 
| roryhand | 1:aac37edee302 | 738 | place_hold2 = place_hold2 + 1; | 
| roryhand | 1:aac37edee302 | 739 | if(place_hold2 >= BufferLen) { | 
| roryhand | 1:aac37edee302 | 740 | |
| roryhand | 1:aac37edee302 | 741 | while(1) { | 
| roryhand | 1:aac37edee302 | 742 | if(flag2 == 0) { | 
| roryhand | 1:aac37edee302 | 743 | |
| roryhand | 1:aac37edee302 | 744 | break; | 
| roryhand | 1:aac37edee302 | 745 | } | 
| roryhand | 0:e89d7a0bfa3b | 746 | } | 
| roryhand | 1:aac37edee302 | 747 | } | 
| roryhand | 0:e89d7a0bfa3b | 748 | } | 
| roryhand | 1:aac37edee302 | 749 | |
| roryhand | 1:aac37edee302 | 750 | } | 
| roryhand | 1:aac37edee302 | 751 | slice = slice + 1; | 
| roryhand | 0:e89d7a0bfa3b | 752 | } | 
| roryhand | 0:e89d7a0bfa3b | 753 | } | 
| roryhand | 0:e89d7a0bfa3b | 754 | |
| roryhand | 0:e89d7a0bfa3b | 755 | |
| roryhand | 0:e89d7a0bfa3b | 756 | |
| roryhand | 0:e89d7a0bfa3b | 757 | |
| roryhand | 32:6ee488c97dcc | 758 | void Play_WaveFileDual(FILE * my_wav, WAV_FILE_STRUCT FileInfo) | 
| roryhand | 32:6ee488c97dcc | 759 | { | 
| roryhand | 32:6ee488c97dcc | 760 | while(slice<FileInfo.num_slices) { | 
| roryhand | 32:6ee488c97dcc | 761 | if(FileSwitchFlag == 1) { | 
| roryhand | 35:4469b508dda3 | 762 | |
| roryhand | 33:a75f0a30fbdc | 763 | if(temp == 1) { | 
| roryhand | 34:26118c8f2e48 | 764 | printf("Does it go to this point\n\r"); | 
| roryhand | 35:4469b508dda3 | 765 | N3Wav = fopen("/sd/mydir/SoundDecoder_second/03.wav","rb"); | 
| roryhand | 33:a75f0a30fbdc | 766 | if(N3Wav == NULL) { | 
| roryhand | 33:a75f0a30fbdc | 767 | printf("Cannot Open testwav\n\r"); | 
| roryhand | 33:a75f0a30fbdc | 768 | } | 
| roryhand | 33:a75f0a30fbdc | 769 | fclose(StartupWav); | 
| roryhand | 33:a75f0a30fbdc | 770 | temp = 0; | 
| roryhand | 33:a75f0a30fbdc | 771 | } | 
| roryhand | 35:4469b508dda3 | 772 | fread(WavInfo_N3.slice_buf,WavInfo_N3.FileFormat.block_align,1,N3Wav); | 
| roryhand | 35:4469b508dda3 | 773 | data_sptr=(short*)WavInfo_N3.slice_buf; | 
| roryhand | 32:6ee488c97dcc | 774 | } else { | 
| roryhand | 32:6ee488c97dcc | 775 | fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,my_wav); | 
| roryhand | 32:6ee488c97dcc | 776 | data_sptr=(short *)FileInfo.slice_buf; // 16 bit samples | 
| roryhand | 32:6ee488c97dcc | 777 | } | 
| roryhand | 32:6ee488c97dcc | 778 | for (channel=0; channel<FileInfo.FileFormat.num_channels; channel++) { | 
| roryhand | 32:6ee488c97dcc | 779 | if(flag1 == 1) { | 
| roryhand | 32:6ee488c97dcc | 780 | Buffer1[place_hold1] = data_sptr[channel]; | 
| roryhand | 32:6ee488c97dcc | 781 | place_hold1 = place_hold1 + 1; | 
| roryhand | 32:6ee488c97dcc | 782 | if(place_hold1 >= BufferLen) { | 
| roryhand | 32:6ee488c97dcc | 783 | while(1) { | 
| roryhand | 32:6ee488c97dcc | 784 | if(flag1 == 0) { | 
| roryhand | 0:e89d7a0bfa3b | 785 | |
| roryhand | 32:6ee488c97dcc | 786 | break; | 
| roryhand | 32:6ee488c97dcc | 787 | } | 
| roryhand | 32:6ee488c97dcc | 788 | |
| roryhand | 32:6ee488c97dcc | 789 | } | 
| roryhand | 32:6ee488c97dcc | 790 | } | 
| roryhand | 32:6ee488c97dcc | 791 | |
| roryhand | 32:6ee488c97dcc | 792 | } else if(flag2 == 1) { | 
| roryhand | 32:6ee488c97dcc | 793 | Buffer2[place_hold2] = data_sptr[channel]; | 
| roryhand | 32:6ee488c97dcc | 794 | place_hold2 = place_hold2 + 1; | 
| roryhand | 32:6ee488c97dcc | 795 | if(place_hold2 >= BufferLen) { | 
| roryhand | 32:6ee488c97dcc | 796 | |
| roryhand | 32:6ee488c97dcc | 797 | while(1) { | 
| roryhand | 32:6ee488c97dcc | 798 | if(flag2 == 0) { | 
| roryhand | 32:6ee488c97dcc | 799 | |
| roryhand | 32:6ee488c97dcc | 800 | break; | 
| roryhand | 32:6ee488c97dcc | 801 | } | 
| roryhand | 32:6ee488c97dcc | 802 | } | 
| roryhand | 32:6ee488c97dcc | 803 | } | 
| roryhand | 32:6ee488c97dcc | 804 | } | 
| roryhand | 32:6ee488c97dcc | 805 | |
| roryhand | 32:6ee488c97dcc | 806 | } | 
| roryhand | 32:6ee488c97dcc | 807 | slice = slice + 1; | 
| roryhand | 32:6ee488c97dcc | 808 | } | 
| roryhand | 32:6ee488c97dcc | 809 | } | 
| roryhand | 0:e89d7a0bfa3b | 810 | |
| roryhand | 38:3b4c05af5f36 | 811 | //***************************************************************************// | 
| roryhand | 38:3b4c05af5f36 | 812 | /* | 
| roryhand | 38:3b4c05af5f36 | 813 | void Play_WaveFileNotchTest(FILE * my_wav, WAV_FILE_STRUCT FileInfo) | 
| roryhand | 38:3b4c05af5f36 | 814 | { | 
| roryhand | 38:3b4c05af5f36 | 815 | while(slice<FileInfo.num_slices) { | 
| roryhand | 38:3b4c05af5f36 | 816 | if(notch_flag == 1) { | 
| roryhand | 38:3b4c05af5f36 | 817 | |
| roryhand | 38:3b4c05af5f36 | 818 | if(temp == 1) { | 
| roryhand | 38:3b4c05af5f36 | 819 | //printf("Does it go to this point\n\r"); | 
| roryhand | 38:3b4c05af5f36 | 820 | SoundFile[notch].FileInfo.WavFile = fopen(Sound[aaa].file_location,"rb"); | 
| roryhand | 38:3b4c05af5f36 | 821 | if(SoundFile[notch].FileInfo.WavFile == NULL) { | 
| roryhand | 38:3b4c05af5f36 | 822 | printf("Cannot Open testwav\n\r"); | 
| roryhand | 38:3b4c05af5f36 | 823 | } | 
| roryhand | 38:3b4c05af5f36 | 824 | fclose(StartupWav); | 
| roryhand | 38:3b4c05af5f36 | 825 | temp = 0; | 
| roryhand | 38:3b4c05af5f36 | 826 | } | 
| roryhand | 38:3b4c05af5f36 | 827 | fread(WavInfo_N3.slice_buf,WavInfo_N3.FileFormat.block_align,1,N3Wav); | 
| roryhand | 38:3b4c05af5f36 | 828 | data_sptr=(short*)WavInfo_N3.slice_buf; | 
| roryhand | 38:3b4c05af5f36 | 829 | } else { | 
| roryhand | 38:3b4c05af5f36 | 830 | fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,my_wav); | 
| roryhand | 38:3b4c05af5f36 | 831 | data_sptr=(short *)FileInfo.slice_buf; // 16 bit samples | 
| roryhand | 38:3b4c05af5f36 | 832 | } | 
| roryhand | 38:3b4c05af5f36 | 833 | for (channel=0; channel<FileInfo.FileFormat.num_channels; channel++) { | 
| roryhand | 38:3b4c05af5f36 | 834 | if(flag1 == 1) { | 
| roryhand | 38:3b4c05af5f36 | 835 | Buffer1[place_hold1] = data_sptr[channel]; | 
| roryhand | 38:3b4c05af5f36 | 836 | place_hold1 = place_hold1 + 1; | 
| roryhand | 38:3b4c05af5f36 | 837 | if(place_hold1 >= BufferLen) { | 
| roryhand | 38:3b4c05af5f36 | 838 | while(1) { | 
| roryhand | 38:3b4c05af5f36 | 839 | if(flag1 == 0) { | 
| roryhand | 38:3b4c05af5f36 | 840 | |
| roryhand | 38:3b4c05af5f36 | 841 | break; | 
| roryhand | 38:3b4c05af5f36 | 842 | } | 
| roryhand | 38:3b4c05af5f36 | 843 | |
| roryhand | 38:3b4c05af5f36 | 844 | } | 
| roryhand | 38:3b4c05af5f36 | 845 | } | 
| roryhand | 38:3b4c05af5f36 | 846 | |
| roryhand | 38:3b4c05af5f36 | 847 | } else if(flag2 == 1) { | 
| roryhand | 38:3b4c05af5f36 | 848 | Buffer2[place_hold2] = data_sptr[channel]; | 
| roryhand | 38:3b4c05af5f36 | 849 | place_hold2 = place_hold2 + 1; | 
| roryhand | 38:3b4c05af5f36 | 850 | if(place_hold2 >= BufferLen) { | 
| roryhand | 38:3b4c05af5f36 | 851 | |
| roryhand | 38:3b4c05af5f36 | 852 | while(1) { | 
| roryhand | 38:3b4c05af5f36 | 853 | if(flag2 == 0) { | 
| roryhand | 38:3b4c05af5f36 | 854 | |
| roryhand | 38:3b4c05af5f36 | 855 | break; | 
| roryhand | 38:3b4c05af5f36 | 856 | } | 
| roryhand | 38:3b4c05af5f36 | 857 | } | 
| roryhand | 38:3b4c05af5f36 | 858 | } | 
| roryhand | 38:3b4c05af5f36 | 859 | } | 
| roryhand | 38:3b4c05af5f36 | 860 | |
| roryhand | 38:3b4c05af5f36 | 861 | } | 
| roryhand | 38:3b4c05af5f36 | 862 | slice = slice + 1; | 
| roryhand | 38:3b4c05af5f36 | 863 | } | 
| roryhand | 38:3b4c05af5f36 | 864 | } | 
| roryhand | 38:3b4c05af5f36 | 865 | */ | 
| roryhand | 38:3b4c05af5f36 | 866 | //**************************************************************************// | 
| roryhand | 38:3b4c05af5f36 | 867 | |
| roryhand | 38:3b4c05af5f36 | 868 | |
| roryhand | 38:3b4c05af5f36 | 869 | |
| roryhand | 38:3b4c05af5f36 | 870 | |
| roryhand | 38:3b4c05af5f36 | 871 | |
| roryhand | 2:957d3b2afff4 | 872 | //void Play_WaveFileLoop(FILE * my_wav, WAV_FILE_STRUCT FileInfo)//(classSoundFile Sounds) | 
| roryhand | 9:dd9cae06b202 | 873 | |
| roryhand | 9:dd9cae06b202 | 874 | void Play_WaveFileLoop(classSoundFile Sounds[], Notch_STRUCT NotchingSet) | 
| roryhand | 0:e89d7a0bfa3b | 875 | { | 
| roryhand | 1:aac37edee302 | 876 | while(1) { //might have to change this to a while(1) loop? | 
| roryhand | 1:aac37edee302 | 877 | //New format!! This should be (roughly) the way that this is done, with the new structures and classes | 
| roryhand | 1:aac37edee302 | 878 | ////fread(Sound[Notch].FileData.slice_buf,Sound[Notch].FileFormat.block_align,1,Sound[notch].WavFile); | 
| roryhand | 1:aac37edee302 | 879 | //data_sptr=(short *)Sound[Notch].FileInfo.slice_buf; | 
| roryhand | 1:aac37edee302 | 880 | |
| roryhand | 0:e89d7a0bfa3b | 881 | |
| roryhand | 2:957d3b2afff4 | 882 | if( slice == (Sounds[NotchingSet.Notch].FileInfo.num_slices-1) ) { | 
| roryhand | 1:aac37edee302 | 883 | slice = 0; | 
| roryhand | 2:957d3b2afff4 | 884 | fseek(Sounds[NotchingSet.Notch].FileInfo.WavFile,44,SEEK_SET); | 
| roryhand | 1:aac37edee302 | 885 | } | 
| roryhand | 1:aac37edee302 | 886 | |
| roryhand | 2:957d3b2afff4 | 887 | //fread(FileInfo.slice_buf,FileInfo.FileFormat.block_align,1,my_wav); | 
| roryhand | 2:957d3b2afff4 | 888 | data_sptr=(short *)Sounds[NotchingSet.Notch].FileInfo.slice_buf; // 16 bit samples | 
| roryhand | 2:957d3b2afff4 | 889 | //make sure we are reading in the correct "notch" here | 
| roryhand | 2:957d3b2afff4 | 890 | |
| roryhand | 2:957d3b2afff4 | 891 | if(FadeFlag) { | 
| roryhand | 2:957d3b2afff4 | 892 | if(feof(Sounds[NotchingSet.Notch].FileInfo.WavFile)) { | 
| roryhand | 2:957d3b2afff4 | 893 | fseek(Sounds[NotchingSet.Notch].FileInfo.WavFile,44,SEEK_SET); | 
| roryhand | 2:957d3b2afff4 | 894 | } | 
| roryhand | 3:6169aeeaeeb4 | 895 | |
| roryhand | 2:957d3b2afff4 | 896 | //Read in data for current (i.e. now the previous notch, according to the index!!) | 
| roryhand | 2:957d3b2afff4 | 897 | //We might not need this code here...as its probably done somewhere else?? | 
| roryhand | 2:957d3b2afff4 | 898 | fread(Sounds[NotchingSet.Notch-1].FileInfo.slice_buf,Sounds[NotchingSet.Notch-1].FileInfo.FileFormat.block_align,1,Sounds[NotchingSet.Notch-1].FileInfo.WavFile); | 
| roryhand | 2:957d3b2afff4 | 899 | Sounds[NotchingSet.Notch-1].data_sptr = (short *)Sounds[NotchingSet.Notch-1].FileInfo.slice_buf; | 
| roryhand | 3:6169aeeaeeb4 | 900 | |
| roryhand | 2:957d3b2afff4 | 901 | NotchFadeOut.FadeCoeff = NotchFadeOut.FadeOut();//compute new FadeOut Coeff value | 
| roryhand | 2:957d3b2afff4 | 902 | |
| roryhand | 2:957d3b2afff4 | 903 | //Read in the notch transition file for transitioning up | 
| roryhand | 2:957d3b2afff4 | 904 | fread(Sounds[NotchingSet.NotchTransUp].FileInfo.slice_buf,Sounds[NotchingSet.NotchTransUp].FileInfo.FileFormat.block_align,1,Sounds[NotchingSet.NotchTransUp].FileInfo.WavFile); | 
| roryhand | 2:957d3b2afff4 | 905 | Sounds[NotchingSet.NotchTransUp].data_sptr = (short*)Sounds[NotchingSet.NotchTransUp].FileInfo.slice_buf; | 
| roryhand | 3:6169aeeaeeb4 | 906 | |
| roryhand | 2:957d3b2afff4 | 907 | if( ((Sounds[NotchingSet.NotchTransUp].FileInfo.FileData.subchunk2_size) - NotchFadeIn.Length - 2*11025) <= (ftell(Sounds[NotchingSet.NotchTransUp].FileInfo.WavFile) + 44)) | 
| roryhand | 2:957d3b2afff4 | 908 | //if( (WavInfo_IdleN2.FileData.subchunk2_size)/8 <=ftell(IdleN2Wav) ) | 
| roryhand | 2:957d3b2afff4 | 909 | { | 
| roryhand | 2:957d3b2afff4 | 910 | |
| roryhand | 2:957d3b2afff4 | 911 | NotchFadeIn.FadeCoeff = NotchFadeIn.FadeIn(); | 
| roryhand | 3:6169aeeaeeb4 | 912 | |
| roryhand | 2:957d3b2afff4 | 913 | //Read In the next Notch | 
| roryhand | 2:957d3b2afff4 | 914 | fread(Sounds[NotchingSet.Notch].FileInfo.slice_buf,Sounds[NotchingSet.Notch].FileInfo.FileFormat.block_align,1,Sounds[NotchingSet.Notch].FileInfo.WavFile); | 
| roryhand | 2:957d3b2afff4 | 915 | Sounds[NotchingSet.Notch].data_sptr = (short *)Sounds[NotchingSet.Notch].FileInfo.slice_buf; | 
| roryhand | 2:957d3b2afff4 | 916 | |
| roryhand | 2:957d3b2afff4 | 917 | if( (ftell(Sounds[NotchingSet.NotchTransUp].FileInfo.WavFile) + 44) >= Sounds[NotchingSet.NotchTransUp].FileInfo.FileData.subchunk2_size ) { | 
| roryhand | 3:6169aeeaeeb4 | 918 | |
| roryhand | 2:957d3b2afff4 | 919 | //need to explicitly test if this notation/syntax works for pointers.... | 
| roryhand | 2:957d3b2afff4 | 920 | *Sounds[NotchingSet.Notch].data_sptr = *Sounds[NotchingSet.Notch].data_sptr*NotchFadeIn.FadeCoeff; | 
| roryhand | 2:957d3b2afff4 | 921 | } else { | 
| roryhand | 2:957d3b2afff4 | 922 | *Sounds[NotchingSet.Notch-1].data_sptr = *Sounds[NotchingSet.Notch - 1].data_sptr*NotchFadeOut.FadeCoeff + *Sounds[NotchingSet.NotchTransUp].data_sptr + *Sounds[NotchingSet.Notch].data_sptr*NotchFadeIn.FadeCoeff;// + *data_sptr_N2; | 
| roryhand | 2:957d3b2afff4 | 923 | } | 
| roryhand | 2:957d3b2afff4 | 924 | |
| roryhand | 2:957d3b2afff4 | 925 | } else { | 
| roryhand | 2:957d3b2afff4 | 926 | *Sounds[NotchingSet.Notch-1].data_sptr = *Sounds[NotchingSet.Notch-1].data_sptr*NotchFadeOut.FadeCoeff + *Sounds[NotchingSet.NotchTransUp].data_sptr; | 
| roryhand | 2:957d3b2afff4 | 927 | } | 
| roryhand | 2:957d3b2afff4 | 928 | |
| roryhand | 1:aac37edee302 | 929 | } | 
| roryhand | 1:aac37edee302 | 930 | |
| roryhand | 1:aac37edee302 | 931 | |
| roryhand | 3:6169aeeaeeb4 | 932 | /********************END OF DATA ASSIGNMENT SECTION*************************************************/ | 
| roryhand | 9:dd9cae06b202 | 933 | |
| roryhand | 2:957d3b2afff4 | 934 | for (channel=0; channel<Sounds[NotchingSet.Notch].FileInfo.FileFormat.num_channels; channel++) { | 
| roryhand | 2:957d3b2afff4 | 935 | switch (Sounds[NotchingSet.Notch].FileInfo.FileFormat.sig_bps) { | 
| roryhand | 0:e89d7a0bfa3b | 936 | case 16: | 
| roryhand | 1:aac37edee302 | 937 | if(flag1 == 1) { | 
| roryhand | 2:957d3b2afff4 | 938 | Buffer1[place_hold1] = Sounds[NotchingSet.Notch].data_sptr[channel]; | 
| roryhand | 1:aac37edee302 | 939 | place_hold1 = place_hold1 + 1; | 
| roryhand | 1:aac37edee302 | 940 | if(place_hold1 >= BufferLen) { | 
| roryhand | 1:aac37edee302 | 941 | while(1) { | 
| roryhand | 1:aac37edee302 | 942 | if(flag1 == 0) { | 
| roryhand | 1:aac37edee302 | 943 | break; | 
| roryhand | 1:aac37edee302 | 944 | }//if(flag1 == 0) | 
| roryhand | 1:aac37edee302 | 945 | |
| roryhand | 1:aac37edee302 | 946 | |
| roryhand | 1:aac37edee302 | 947 | }//while(1) | 
| roryhand | 1:aac37edee302 | 948 | }//if(place_hold1 > = BufferLen) | 
| roryhand | 0:e89d7a0bfa3b | 949 | |
| roryhand | 1:aac37edee302 | 950 | } else if(flag2 == 1) { | 
| roryhand | 2:957d3b2afff4 | 951 | Buffer2[place_hold2] = Sounds[NotchingSet.Notch].data_sptr[channel]; | 
| roryhand | 1:aac37edee302 | 952 | place_hold2 = place_hold2 + 1; | 
| roryhand | 1:aac37edee302 | 953 | if(place_hold2 >= BufferLen) { | 
| roryhand | 1:aac37edee302 | 954 | while(1) { | 
| roryhand | 1:aac37edee302 | 955 | |
| roryhand | 1:aac37edee302 | 956 | if(flag2 == 0) { | 
| roryhand | 1:aac37edee302 | 957 | break; | 
| roryhand | 1:aac37edee302 | 958 | } | 
| roryhand | 1:aac37edee302 | 959 | } | 
| roryhand | 0:e89d7a0bfa3b | 960 | } | 
| roryhand | 1:aac37edee302 | 961 | |
| roryhand | 1:aac37edee302 | 962 | } | 
| roryhand | 0:e89d7a0bfa3b | 963 | } | 
| roryhand | 0:e89d7a0bfa3b | 964 | } | 
| roryhand | 0:e89d7a0bfa3b | 965 | slice = slice + 1; | 
| roryhand | 0:e89d7a0bfa3b | 966 | } | 
| roryhand | 0:e89d7a0bfa3b | 967 | } | 
| roryhand | 0:e89d7a0bfa3b | 968 | |
| roryhand | 0:e89d7a0bfa3b | 969 | |
| roryhand | 0:e89d7a0bfa3b | 970 | |
| roryhand | 0:e89d7a0bfa3b | 971 | |
| roryhand | 0:e89d7a0bfa3b | 972 | |
| roryhand | 0:e89d7a0bfa3b | 973 | |
| roryhand | 0:e89d7a0bfa3b | 974 | |
| roryhand | 9:dd9cae06b202 | 975 |