Skip to content

Commit

Permalink
test version with file input
Browse files Browse the repository at this point in the history
  • Loading branch information
JvanKatwijk committed Aug 2, 2017
1 parent dfb3059 commit dc62680
Show file tree
Hide file tree
Showing 6 changed files with 255 additions and 3 deletions.
2 changes: 2 additions & 0 deletions device-handler.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@

#include <stdint.h>
#include <complex>
#include <thread>
using namespace std;

class deviceHandler {
Expand All @@ -53,6 +54,7 @@ virtual void set_autogain (bool);
int32_t lastFrequency;
int32_t vfoOffset;
int theGain;
virtual void run (void);
};
#endif

2 changes: 2 additions & 0 deletions devices/device-handler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ bool deviceHandler::restartReader (void) {
void deviceHandler::stopReader (void) {
}

void deviceHandler::run (void) {
}

int32_t deviceHandler::getSamples (std::complex<float> *v,
int32_t amount) {
Expand Down
150 changes: 150 additions & 0 deletions devices/wavfiles/wavfiles.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,150 @@
#
/*
* Copyright (C) 2013 .. 2017
* Jan van Katwijk (J.vanKatwijk@gmail.com)
* Lazy Chair Programming
*
* This file is part of the DAB library
* DAB library is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* DAB library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with DAB library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/time.h>
#include <time.h>
#include <cstring>
#include "wavfiles.h"

static inline
int64_t getMyTime (void) {
struct timeval tv;

gettimeofday (&tv, NULL);
return ((int64_t)tv. tv_sec * 1000000 + (int64_t)tv. tv_usec);
}

#define __BUFFERSIZE 8 * 32768

wavFiles::wavFiles (std::string f) {
SF_INFO *sf_info;

fileName = f;
_I_Buffer = new RingBuffer<std::complex<float>>(__BUFFERSIZE);

sf_info = (SF_INFO *)alloca (sizeof (SF_INFO));
sf_info -> format = 0;
filePointer = sf_open (f. c_str (), SFM_READ, sf_info);
if (filePointer == NULL) {
fprintf (stderr, "file %s no legitimate sound file\n",
f. c_str ());
throw (24);
}
if ((sf_info -> samplerate != 2048000) ||
(sf_info -> channels != 2)) {
fprintf (stderr, "This is not a recorded dab file, sorry\n");
sf_close (filePointer);
throw (25);
}
currPos = 0;
}

wavFiles::~wavFiles (void) {
if (running)
workerHandle. join ();
running = false;
sf_close (filePointer);
delete _I_Buffer;
}

bool wavFiles::restartReader (void) {
workerHandle = std::thread (wavFiles::run, this);
running = true;
return true;
}

void wavFiles::stopReader (void) {
if (running)
workerHandle. join ();
running = false;
}
//
// size is in I/Q pairs
int32_t wavFiles::getSamples (std::complex<float> *V, int32_t size) {
int32_t amount;
if (filePointer == NULL)
return 0;

while (_I_Buffer -> GetRingBufferReadAvailable () < (uint32_t)size)
usleep (100);

amount = _I_Buffer -> getDataFromBuffer (V, size);
return amount;
}

int32_t wavFiles::Samples (void) {
return _I_Buffer -> GetRingBufferReadAvailable ();
}

void wavFiles::run (wavFiles *p) {
int32_t t, i;
std::complex<float> *bi;
int32_t bufferSize = 32768;
int64_t period;
int64_t nextStop;

p -> running = true;
period = (32768 * 1000) / 2048; // full IQś read
fprintf (stderr, "Period = %ld\n", period);
bi = new std::complex<float> [bufferSize];
nextStop = getMyTime ();
while (p -> running) {
while (p -> _I_Buffer -> WriteSpace () < bufferSize) {
if (!p -> running)
break;
usleep (100);
}

nextStop += period;
t = p -> readBuffer (bi, bufferSize);
if (t < bufferSize) {
for (i = t; i < bufferSize; i ++)
bi [i] = 0;
t = bufferSize;
}
p -> _I_Buffer -> putDataIntoBuffer (bi, bufferSize);
if (nextStop - getMyTime () > 0)
usleep (nextStop - getMyTime ());
}
fprintf (stderr, "taak voor replay eindigt hier\n");
delete [] bi;
}
/*
* length is number of uints that we read.
*/
int32_t wavFiles::readBuffer (std::complex<float> *data, int32_t length) {
int32_t i, n;
float temp [2 * length];

n = sf_readf_float (filePointer, temp, length);
if (n < length) {
sf_seek (filePointer, 0, SEEK_SET);
fprintf (stderr, "End of file, restarting\n");
}
for (i = 0; i < n; i ++)
data [i] = std::complex<float> (temp [2 * i], temp [2 * i + 1]);
return n & ~01;
}

53 changes: 53 additions & 0 deletions devices/wavfiles/wavfiles.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
#
/*
* Copyright (C) 2013 .. 2017
* Jan van Katwijk (J.vanKatwijk@gmail.com)
* Lazy Chair Computing
*
* This file is part of the Qt-DAB program
* Qt-DAB is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* Qt-DAB is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Qt-DAB; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef __WAV_FILES__
#define __WAV_FILES__

#include <sndfile.h>
#include "ringbuffer.h"
#include "device-handler.h"
#include <thread>

class wavFiles: public deviceHandler {
public:
wavFiles (std::string);
~wavFiles (void);
int32_t getSamples (std::complex<float> *, int32_t);
uint8_t myIdentity (void);
int32_t Samples (void);
bool restartReader (void);
void stopReader (void);

private:
std::string fileName;
static void run (wavFiles *);
int32_t readBuffer (std::complex<float> *, int32_t);
RingBuffer<std::complex<float>> *_I_Buffer;
std::thread workerHandle;
int32_t bufferSize;
SNDFILE *filePointer;
bool running;
int64_t currPos;
};

#endif

28 changes: 28 additions & 0 deletions example-2/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,11 @@ if(DEFINED RTLSDR)
set(objectName dab-rtlsdr-2)
endif ()

if(DEFINED WAVFILES)
set(WAVFILES true)
set(objectName dab-files)
endif ()

#
#########################################################################
find_package (PkgConfig)
Expand Down Expand Up @@ -161,6 +166,29 @@ endif ()

add_definitions (-DHAVE_RTLSDR)
endif()

if (WAVFILES)
include_directories (
../devices/wavfiles/
)

set (${objectName}_HDRS
${${objectName}_HDRS}
../devices/wavfiles/wavfiles.h
)

set (${objectName}_SRCS
${${objectName}_SRCS}
../devices/wavfiles/wavfiles.cpp
)
find_package(LibSndFile)
if (NOT LIBSNDFILE_FOUND)
message(FATAL_ERROR "please install libsndfile")
endif ()
list(APPEND extraLibs ${LIBSNDFILE_LIBRARY})

add_definitions (-DHAVE_WAVFILES)
endif()
#######################################################################
#
# Here we really start
Expand Down
23 changes: 20 additions & 3 deletions example-2/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@
#include "airspy-handler.h"
#elif HAVE_RTLSDR
#include "rtlsdr-handler.h"
#elif HAVE_WAVFILES
#include "wavfiles.h"
#endif
#include <atomic>

Expand Down Expand Up @@ -160,14 +162,21 @@ int opt;
struct sigaction sigact;
bandHandler dabBand;
deviceHandler *theDevice;
#ifdef HAVE_WAVFILES
std::string fileName;
#endif

fprintf (stderr, "dab_cmdline,\n \
Copyright 2017 J van Katwijk, Lazy Chair Computing\n");
timeSynced. store (false);
timesyncSet. store (false);
run. store (false);

#ifndef HAVE_WAVFILES
while ((opt = getopt (argc, argv, "M:B:C:P:G:A:L:S:Q")) != -1) {
#else
while ((opt = getopt (argc, argv, "M:B:P:A:L:S:F:")) != -1) {
#endif
fprintf (stderr, "opt = %c\n", opt);
switch (opt) {

Expand All @@ -182,9 +191,6 @@ deviceHandler *theDevice;
L_BAND : BAND_III;
break;

case 'C':
theChannel = std::string (optarg);
break;

case 'P':
programName = optarg;
Expand All @@ -193,6 +199,10 @@ deviceHandler *theDevice;
case 'p':
ppmCorrection = atoi (optarg);
break;
#ifndef HAVE_WAVFILES
case 'C':
theChannel = std::string (optarg);
break;

case 'G':
theGain = atoi (optarg);
Expand All @@ -201,6 +211,11 @@ deviceHandler *theDevice;
case 'Q':
autogain = true;
break;
#else
case 'F':
fileName = std::string (optarg);
break;
#endif

case 'A':
soundChannel = optarg;
Expand Down Expand Up @@ -248,6 +263,8 @@ deviceHandler *theDevice;
ppmCorrection,
theGain,
autogain);
#elif HAVE_WAVFILES
theDevice = new wavFiles (fileName);
#endif
}
catch (int e) {
Expand Down

0 comments on commit dc62680

Please sign in to comment.