Mercurial > hg > beaglert
view examples/basic_FFT_phase_vocoder/main.cpp @ 300:dbeed520b014 prerelease
Renamed projects to examples
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Fri, 27 May 2016 13:58:20 +0100 |
parents | projects/basic_FFT_phase_vocoder/main.cpp@aec268b5d1b4 |
children | e4392164b458 |
line wrap: on
line source
/* * main.cpp * * Created on: Oct 24, 2014 * Author: parallels */ #include <iostream> #include <cstdlib> #include <cstdio> #include <libgen.h> #include <signal.h> #include <getopt.h> #include <unistd.h> #include <sys/time.h> #include <sndfile.h> // to load audio files #include "SampleData.h" #include <BeagleRT.h> using namespace std; // Global variables used by getCurrentTime() unsigned long long gFirstSeconds, gFirstMicroseconds; // Load samples from file int initFile(string file, SampleData *smp)//float *& smp) { SNDFILE *sndfile ; SF_INFO sfinfo ; if (!(sndfile = sf_open (file.c_str(), SFM_READ, &sfinfo))) { cout << "Couldn't open file " << file << endl; return 1; } int numChan = sfinfo.channels; if(numChan != 1) { cout << "Error: " << file << " is not a mono file" << endl; return 1; } smp->sampleLen = sfinfo.frames * numChan; smp->samples = new float[smp->sampleLen]; if(smp == NULL){ cout << "Could not allocate buffer" << endl; return 1; } int subformat = sfinfo.format & SF_FORMAT_SUBMASK; int readcount = sf_read_float(sndfile, smp->samples, smp->sampleLen); // Pad with zeros in case we couldn't read whole file for(int k = readcount; k <smp->sampleLen; k++) smp->samples[k] = 0; if (subformat == SF_FORMAT_FLOAT || subformat == SF_FORMAT_DOUBLE) { double scale ; int m ; sf_command (sndfile, SFC_CALC_SIGNAL_MAX, &scale, sizeof (scale)) ; if (scale < 1e-10) scale = 1.0 ; else scale = 32700.0 / scale ; cout << "File samples scale = " << scale << endl; for (m = 0; m < smp->sampleLen; m++) smp->samples[m] *= scale; } sf_close(sndfile); return 0; } // Handle Ctrl-C by requesting that the audio rendering stop void interrupt_handler(int var) { gShouldStop = true; } // Print usage information void usage(const char * processName) { cerr << "Usage: " << processName << " [options]" << endl; BeagleRT_usage(); cerr << " --help [-h]: Print this menu\n"; } /* Function which returns the time since start of the program * in (fractional) seconds. */ double getCurrentTime(void) { unsigned long long result; struct timeval tv; gettimeofday(&tv, NULL); result = (tv.tv_sec - gFirstSeconds) * 1000000ULL + (tv.tv_usec - gFirstMicroseconds); return (double)result / 1000000.0; } extern SampleData gSampleData; int main(int argc, char *argv[]) { BeagleRTInitSettings settings; // Standard audio settings struct timeval tv; string fileName; // Name of the sample to load struct option customOptions[] = { {"help", 0, NULL, 'h'}, {"file", 1, NULL, 'f'}, {NULL, 0, NULL, 0} }; gSampleData.samples = 0; gSampleData.sampleLen = -1; // Set default settings BeagleRT_defaultSettings(&settings); settings.periodSize = 32; // Larger period size by default, for testing // Parse command-line arguments while (1) { int c; if ((c = BeagleRT_getopt_long(argc, argv, "hf:", customOptions, &settings)) < 0) break; switch (c) { case 'h': usage(basename(argv[0])); exit(0); case 'f': fileName = string((char *)optarg); break; case '?': default: usage(basename(argv[0])); exit(1); } } if(fileName.empty()){ fileName = "sample.wav"; } // Load file if(initFile(fileName, &gSampleData) != 0) { cout << "Error: unable to load samples " << endl; return -1; } if(settings.verbose) cout << "File contains " << gSampleData.sampleLen << " samples" << endl; // Initialise the PRU audio device if(BeagleRT_initAudio(&settings, &gSampleData) != 0) { cout << "Error: unable to initialise audio" << endl; return -1; } // Initialise time gettimeofday(&tv, NULL); gFirstSeconds = tv.tv_sec; gFirstMicroseconds = tv.tv_usec; // Start the audio device running if(BeagleRT_startAudio()) { cout << "Error: unable to start real-time audio" << endl; return -1; } // Set up interrupt handler to catch Control-C signal(SIGINT, interrupt_handler); signal(SIGTERM, interrupt_handler); // Run until told to stop while(!gShouldStop) { usleep(100000); } // Stop the audio device BeagleRT_stopAudio(); // Clean up any resources allocated for audio BeagleRT_cleanupAudio(); // All done! return 0; }