diff --git a/Source/cudaSDR.pri b/Source/cudaSDR.pri index 860c8d4..b2d304d 100644 --- a/Source/cudaSDR.pri +++ b/Source/cudaSDR.pri @@ -1,3 +1,4 @@ +win32 { HEADERS += \ ./src/Util/cusdr_buttons.h \ ./src/Util/cusdr_colorTriangle.h \ @@ -71,10 +72,85 @@ HEADERS += \ ./src/cusdr_transmitTabWidget.h \ ./src/cusdr_transmitOptionsWidget.h \ ./src/cusdr_transmitPAWidget.h \ +} +unix { +HEADERS += \ + ./src/Util/cusdr_buttons.h \ + ./src/Util/cusdr_colorTriangle.h \ + ./src/Util/cusdr_highResTimer.h \ + ./src/Util/cusdr_image.h \ + ./src/Util/cusdr_imageblur.h \ + ./src/Util/cusdr_led.h \ + ./src/Util/cusdr_painter.h \ + ./src/Util/cusdr_queue.h \ + ./src/Util/cusdr_splash.h \ + ./src/Util/cusdr_styles.h \ + ./src/Util/cusdr_cpuUsage.h \ + ./src/Util/qcircularbuffer.h \ + ./src/AudioEngine/cusdr_audio_engine.h \ + ./src/AudioEngine/cusdr_audio_settingsdialog.h \ + ./src/AudioEngine/cusdr_audio_spectrum.h \ + ./src/AudioEngine/cusdr_audio_spectrumanalyser.h \ + ./src/AudioEngine/cusdr_audio_utils.h \ + ./src/AudioEngine/cusdr_audio_waveform.h \ + ./src/AudioEngine/cusdr_audio_wavfile.h \ + ./src/AudioEngine/cusdr_fspectrum.h \ + ./src/DataEngine/cusdr_audioReceiver.h \ + ./src/DataEngine/cusdr_chirpProcessor.h \ + ./src/DataEngine/cusdr_dataEngine.h \ + ./src/DataEngine/cusdr_dataIO.h \ + ./src/DataEngine/cusdr_discoverer.h \ + ./src/DataEngine/cusdr_receiver.h \ + ./src/DataEngine/soundout.h \ + ./src/DataEngine/fractresampler.h \ + ./src/DataEngine/datatypes.h \ + ./src/QtDSP/fftw3.h \ + ./src/QtDSP/qtdsp_demodulation.h \ + ./src/QtDSP/qtdsp_dspEngine.h \ + ./src/QtDSP/qtdsp_dualModeAverager.h \ + ./src/QtDSP/qtdsp_fft.h \ + ./src/QtDSP/qtdsp_filter.h \ + ./src/QtDSP/qtdsp_powerSpectrum.h \ + ./src/QtDSP/qtdsp_invsinc_coeff.h \ + ./src/QtDSP/qtdsp_qComplex.h \ + ./src/QtDSP/qtdsp_signalMeter.h \ + ./src/QtDSP/qtdsp_wpagc.h \ + ./src/GL/cusdr_oglDisplayPanel.h \ + ./src/GL/cusdr_oglDistancePanel.h \ + ./src/GL/cusdr_oglInfo.h \ + ./src/GL/cusdr_oglReceiverPanel.h \ + ./src/GL/cusdr_oglText.h \ + ./src/GL/cusdr_oglUtils.h \ + ./src/GL/cusdr_oglWidebandPanel.h \ + ./src/cusdr_alexAntennaWidget.h \ + ./src/cusdr_alexFilterWidget.h \ + ./src/cusdr_alexTabWidget.h \ + ./src/cusdr_chirpWidget.h \ + ./src/cusdr_displayWidget.h \ + ./src/cusdr_colorsWidget.h \ + ./src/cusdr_hamDatabase.h \ + ./src/cusdr_hpsdrTabWidget.h \ + ./src/cusdr_hpsdrWidget.h \ + ./src/cusdr_networkWidget.h \ + ./src/cusdr_mainWidget.h \ + ./src/cusdr_extCtrlWidget.h \ + ./src/cusdr_radioTabWidget.h \ + ./src/cusdr_radioWidget.h \ + ./src/cusdr_agcWidget.h \ + ./src/cusdr_displayTabWidget.h \ + ./src/cusdr_radioPopupWidget.h \ + ./src/cusdr_receiverWidget.h \ + #./src/cusdr_server.h \ + ./src/cusdr_serverWidget.h \ + ./src/cusdr_settings.h \ + ./src/cusdr_fonts.h \ + ./src/cusdr_transmitTabWidget.h \ + ./src/cusdr_transmitOptionsWidget.h \ + ./src/cusdr_transmitPAWidget.h \ ./src/Util/cusdr_cpuUsage_unix.h - -#win32:HEADERS += ./src/Util/cusdr_cpuUsage.h \ +} +win32 { SOURCES += \ ./src/Util/cusdr_buttons.cpp \ ./src/Util/cusdr_colorTriangle.cpp \ @@ -140,6 +216,73 @@ SOURCES += \ ./src/cusdr_transmitOptionsWidget.cpp \ ./src/cusdr_transmitPAWidget.cpp \ ./src/main.cpp \ - ./src/Util/cusdr_cpuUsage_unix.cpp +} -#win32:SOURCES += ./src/Util/cusdr_cpuUsage.cpp \ +unix { +SOURCES += \ + ./src/Util/cusdr_buttons.cpp \ + ./src/Util/cusdr_colorTriangle.cpp \ + ./src/Util/cusdr_highResTimer.cpp \ + ./src/Util/cusdr_image.cpp \ + ./src/Util/cusdr_imageblur.cpp \ + ./src/Util/cusdr_led.cpp \ + ./src/Util/cusdr_painter.cpp \ + ./src/Util/cusdr_splash.cpp \ + ./src/Util/cusdr_cpuUsage.cpp \ + ./src/AudioEngine/cusdr_audio_engine.cpp \ + ./src/AudioEngine/cusdr_audio_settingsdialog.cpp \ + ./src/AudioEngine/cusdr_audio_spectrumanalyser.cpp \ + ./src/AudioEngine/cusdr_audio_utils.cpp \ + ./src/AudioEngine/cusdr_audio_waveform.cpp \ + ./src/AudioEngine/cusdr_audio_wavfile.cpp \ + ./src/AudioEngine/cusdr_fspectrum.cpp \ + ./src/DataEngine/cusdr_audioReceiver.cpp \ + ./src/DataEngine/cusdr_chirpProcessor.cpp \ + ./src/DataEngine/cusdr_dataEngine.cpp \ + ./src/DataEngine/cusdr_dataIO.cpp \ + ./src/DataEngine/cusdr_discoverer.cpp \ + ./src/DataEngine/cusdr_receiver.cpp \ + ./src/DataEngine/soundout.cpp \ + ./src/DataEngine/fractresampler.cpp \ + ./src/QtDSP/qtdsp_demodulation.cpp \ + ./src/QtDSP/qtdsp_dspEngine.cpp \ + ./src/QtDSP/qtdsp_dualModeAverager.cpp \ + ./src/QtDSP/qtdsp_fft.cpp \ + ./src/QtDSP/qtdsp_filter.cpp \ + ./src/QtDSP/qtdsp_powerSpectrum.cpp \ + ./src/QtDSP/qtdsp_signalMeter.cpp \ + ./src/QtDSP/qtdsp_wpagc.cpp \ + ./src/GL/cusdr_oglDisplayPanel.cpp \ + ./src/GL/cusdr_oglDistancePanel.cpp \ + ./src/GL/cusdr_oglInfo.cpp \ + ./src/GL/cusdr_oglReceiverPanel.cpp \ + ./src/GL/cusdr_oglText.cpp \ + ./src/GL/cusdr_oglWidebandPanel.cpp \ + ./src/cusdr_alexAntennaWidget.cpp \ + ./src/cusdr_alexFilterWidget.cpp \ + ./src/cusdr_alexTabWidget.cpp \ + ./src/cusdr_chirpWidget.cpp \ + ./src/cusdr_displayWidget.cpp \ + ./src/cusdr_colorsWidget.cpp \ + ./src/cusdr_hamDatabase.cpp \ + ./src/cusdr_hpsdrTabWidget.cpp \ + ./src/cusdr_hpsdrWidget.cpp \ + ./src/cusdr_networkWidget.cpp \ + ./src/cusdr_mainWidget.cpp \ + ./src/cusdr_extCtrlWidget.cpp \ + ./src/cusdr_radioTabWidget.cpp \ + ./src/cusdr_radioWidget.cpp \ + ./src/cusdr_agcWidget.cpp \ + ./src/cusdr_displayTabWidget.cpp \ + ./src/cusdr_radioPopupWidget.cpp \ + ./src/cusdr_receiverWidget.cpp \ + #./src/cusdr_server.cpp \ + ./src/cusdr_serverWidget.cpp \ + ./src/cusdr_settings.cpp \ + ./src/cusdr_fonts.cpp \ + ./src/cusdr_transmitTabWidget.cpp \ + ./src/cusdr_transmitOptionsWidget.cpp \ + ./src/cusdr_transmitPAWidget.cpp \ + ./src/main.cpp \ + ./src/Util/cusdr_cpuUsage_unix.cpp +} diff --git a/Source/cudaSDR.pro b/Source/cudaSDR.pro index bed548e..d2afea8 100644 --- a/Source/cudaSDR.pro +++ b/Source/cudaSDR.pro @@ -72,16 +72,18 @@ win32 { LIBS += \ -L"$$(CUDA_PATH_V6_5)/lib/x64" \ - -L"./lib" \ + -L"./lib" \ -lwsock32 \ -lVersion \ -lPsapi \ - -lQtOpenCL \ + # -lQtOpenCL \ -lopengl32 \ - -llibfftw3f-3 \ + # -llibfftw3f-3 \ -lgdi32 \ -luser32 \ -lKernel32 + INCLUDEPATH +=$$PWD/lib + LIBS += $$PWD/lib/libfftw3f-3.a } OBJECTS_DIR = ./bld/o @@ -89,3 +91,4 @@ MOC_DIR = ./bld/moc #UI_DIR = ./bld/ui RCC_DIR = ./bld/rcc DESTDIR = ./bin + diff --git a/Source/cudaSDR.pro.user b/Source/cudaSDR.pro.user index cde8d39..6ad35ac 100644 --- a/Source/cudaSDR.pro.user +++ b/Source/cudaSDR.pro.user @@ -1,10 +1,10 @@ - + EnvironmentId - {15ea231e-b5c8-48e7-80f9-aa26c31ff3fa} + {e51181fc-176a-40ca-a8e0-59157399e831} ProjectExplorer.Project.ActiveTarget @@ -55,7 +55,9 @@ ProjectExplorer.Project.PluginSettings - + + -fno-delayed-template-parsing + true Builtin.Questionable @@ -72,17 +74,17 @@ ProjectExplorer.Project.Target.0 - Desktop - Desktop - {b99b464b-bcca-4177-862b-cd51b625c7d4} + Desktop Qt 5.9.9 MinGW 32bit + Desktop Qt 5.9.9 MinGW 32bit + qt.qt5.599.win32_mingw53_kit 0 0 0 - false - 2 - /home/vladimir/repository/cudaSDR/Source - /home/vladimir/repository/cudaSDR/Source + true + 0 + C:\Users\karpe\Desktop\cudaSDR\build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Debug + C:/Users/karpe/Desktop/cudaSDR/build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Debug true @@ -101,8 +103,8 @@ false 2 - Build - Build + Сборка + Сборка ProjectExplorer.BuildSteps.Build @@ -116,25 +118,127 @@ false 1 - Clean - Clean + Очистка + Очистка ProjectExplorer.BuildSteps.Clean 2 false - Release + Отладка + Qt4ProjectManager.Qt4BuildConfiguration + 2 + 2 + 2 + + + true + 2 + C:\Users\karpe\Desktop\cudaSDR\build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Release + C:/Users/karpe/Desktop/cudaSDR/build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Release + + + true + QtProjectManager.QMakeBuildStep + + false + + + + true + Qt4ProjectManager.MakeStep + + false + + + false + + 2 + Сборка + Сборка + ProjectExplorer.BuildSteps.Build + + + + true + Qt4ProjectManager.MakeStep + + true + clean + + false + + 1 + Очистка + Очистка + ProjectExplorer.BuildSteps.Clean + + 2 + false + + Выпуск Qt4ProjectManager.Qt4BuildConfiguration 0 2 2 - 1 + + true + 0 + C:\Users\karpe\Desktop\cudaSDR\build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Profile + C:/Users/karpe/Desktop/cudaSDR/build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Profile + + + true + QtProjectManager.QMakeBuildStep + + false + + + + true + Qt4ProjectManager.MakeStep + + false + + + false + + 2 + Сборка + Сборка + ProjectExplorer.BuildSteps.Build + + + + true + Qt4ProjectManager.MakeStep + + true + clean + + false + + 1 + Очистка + Очистка + ProjectExplorer.BuildSteps.Clean + + 2 + false + + Профилирование + Qt4ProjectManager.Qt4BuildConfiguration + 0 + 2 + 0 + + 3 0 - Deploy - Deploy + Развёртывание + Развёртывание ProjectExplorer.BuildSteps.Deploy 1 @@ -204,8 +308,8 @@ 2 - Qt4ProjectManager.Qt4RunConfiguration:/home/vladimir/repository/cudaSDR/Source/cudaSDR.pro - /home/vladimir/repository/cudaSDR/Source/cudaSDR.pro + Qt4ProjectManager.Qt4RunConfiguration:C:/Users/karpe/Desktop/cudaSDR/Source/cudaSDR.pro + C:/Users/karpe/Desktop/cudaSDR/Source/cudaSDR.pro false @@ -216,7 +320,7 @@ false true - /home/vladimir/repository/cudaSDR/Source/bin + C:/Users/karpe/Desktop/cudaSDR/build-cudaSDR-Desktop_Qt_5_9_9_MinGW_32bit-Debug/bin 1 diff --git a/Source/lib/fftw3.h b/Source/lib/fftw3.h new file mode 100644 index 0000000..4326eae --- /dev/null +++ b/Source/lib/fftw3.h @@ -0,0 +1,414 @@ +/* + * Copyright (c) 2003, 2007-14 Matteo Frigo + * Copyright (c) 2003, 2007-14 Massachusetts Institute of Technology + * + * The following statement of license applies *only* to this header file, + * and *not* to the other files distributed with FFTW or derived therefrom: + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE + * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +/***************************** NOTE TO USERS ********************************* + * + * THIS IS A HEADER FILE, NOT A MANUAL + * + * If you want to know how to use FFTW, please read the manual, + * online at http://www.fftw.org/doc/ and also included with FFTW. + * For a quick start, see the manual's tutorial section. + * + * (Reading header files to learn how to use a library is a habit + * stemming from code lacking a proper manual. Arguably, it's a + * *bad* habit in most cases, because header files can contain + * interfaces that are not part of the public, stable API.) + * + ****************************************************************************/ + +#ifndef FFTW3_H +#define FFTW3_H + +#include + +#ifdef __cplusplus +extern "C" +{ +#endif /* __cplusplus */ + +/* If is included, use the C99 complex type. Otherwise + define a type bit-compatible with C99 complex */ +#if !defined(FFTW_NO_Complex) && defined(_Complex_I) && defined(complex) && defined(I) +# define FFTW_DEFINE_COMPLEX(R, C) typedef R _Complex C +#else +# define FFTW_DEFINE_COMPLEX(R, C) typedef R C[2] +#endif + +#define FFTW_CONCAT(prefix, name) prefix ## name +#define FFTW_MANGLE_DOUBLE(name) FFTW_CONCAT(fftw_, name) +#define FFTW_MANGLE_FLOAT(name) FFTW_CONCAT(fftwf_, name) +#define FFTW_MANGLE_LONG_DOUBLE(name) FFTW_CONCAT(fftwl_, name) +#define FFTW_MANGLE_QUAD(name) FFTW_CONCAT(fftwq_, name) + +/* IMPORTANT: for Windows compilers, you should add a line +*/ +#define FFTW_DLL +/* + here and in kernel/ifftw.h if you are compiling/using FFTW as a + DLL, in order to do the proper importing/exporting, or + alternatively compile with -DFFTW_DLL or the equivalent + command-line flag. This is not necessary under MinGW/Cygwin, where + libtool does the imports/exports automatically. */ +#if defined(FFTW_DLL) && (defined(_WIN32) || defined(__WIN32__)) + /* annoying Windows syntax for shared-library declarations */ +# if defined(COMPILING_FFTW) /* defined in api.h when compiling FFTW */ +# define FFTW_EXTERN extern __declspec(dllexport) +# else /* user is calling FFTW; import symbol */ +# define FFTW_EXTERN extern __declspec(dllimport) +# endif +#else +# define FFTW_EXTERN extern +#endif + +enum fftw_r2r_kind_do_not_use_me { + FFTW_R2HC=0, FFTW_HC2R=1, FFTW_DHT=2, + FFTW_REDFT00=3, FFTW_REDFT01=4, FFTW_REDFT10=5, FFTW_REDFT11=6, + FFTW_RODFT00=7, FFTW_RODFT01=8, FFTW_RODFT10=9, FFTW_RODFT11=10 +}; + +struct fftw_iodim_do_not_use_me { + int n; /* dimension size */ + int is; /* input stride */ + int os; /* output stride */ +}; + +#include /* for ptrdiff_t */ +struct fftw_iodim64_do_not_use_me { + ptrdiff_t n; /* dimension size */ + ptrdiff_t is; /* input stride */ + ptrdiff_t os; /* output stride */ +}; + +typedef void (*fftw_write_char_func_do_not_use_me)(char c, void *); +typedef int (*fftw_read_char_func_do_not_use_me)(void *); + +/* + huge second-order macro that defines prototypes for all API + functions. We expand this macro for each supported precision + + X: name-mangling macro + R: real data type + C: complex data type +*/ + +#define FFTW_DEFINE_API(X, R, C) \ + \ +FFTW_DEFINE_COMPLEX(R, C); \ + \ +typedef struct X(plan_s) *X(plan); \ + \ +typedef struct fftw_iodim_do_not_use_me X(iodim); \ +typedef struct fftw_iodim64_do_not_use_me X(iodim64); \ + \ +typedef enum fftw_r2r_kind_do_not_use_me X(r2r_kind); \ + \ +typedef fftw_write_char_func_do_not_use_me X(write_char_func); \ +typedef fftw_read_char_func_do_not_use_me X(read_char_func); \ + \ +FFTW_EXTERN void X(execute)(const X(plan) p); \ + \ +FFTW_EXTERN X(plan) X(plan_dft)(int rank, const int *n, \ + C *in, C *out, int sign, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_dft_1d)(int n, C *in, C *out, int sign, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_2d)(int n0, int n1, \ + C *in, C *out, int sign, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_3d)(int n0, int n1, int n2, \ + C *in, C *out, int sign, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_many_dft)(int rank, const int *n, \ + int howmany, \ + C *in, const int *inembed, \ + int istride, int idist, \ + C *out, const int *onembed, \ + int ostride, int odist, \ + int sign, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru_dft)(int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + C *in, C *out, \ + int sign, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru_split_dft)(int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + R *ri, R *ii, R *ro, R *io, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru64_dft)(int rank, \ + const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + C *in, C *out, \ + int sign, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru64_split_dft)(int rank, \ + const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + R *ri, R *ii, R *ro, R *io, \ + unsigned flags); \ + \ +FFTW_EXTERN void X(execute_dft)(const X(plan) p, C *in, C *out); \ +FFTW_EXTERN void X(execute_split_dft)(const X(plan) p, R *ri, R *ii, \ + R *ro, R *io); \ + \ +FFTW_EXTERN X(plan) X(plan_many_dft_r2c)(int rank, const int *n, \ + int howmany, \ + R *in, const int *inembed, \ + int istride, int idist, \ + C *out, const int *onembed, \ + int ostride, int odist, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_dft_r2c)(int rank, const int *n, \ + R *in, C *out, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_dft_r2c_1d)(int n,R *in,C *out,unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_r2c_2d)(int n0, int n1, \ + R *in, C *out, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_r2c_3d)(int n0, int n1, \ + int n2, \ + R *in, C *out, unsigned flags); \ + \ + \ +FFTW_EXTERN X(plan) X(plan_many_dft_c2r)(int rank, const int *n, \ + int howmany, \ + C *in, const int *inembed, \ + int istride, int idist, \ + R *out, const int *onembed, \ + int ostride, int odist, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_dft_c2r)(int rank, const int *n, \ + C *in, R *out, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_dft_c2r_1d)(int n,C *in,R *out,unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_c2r_2d)(int n0, int n1, \ + C *in, R *out, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_dft_c2r_3d)(int n0, int n1, \ + int n2, \ + C *in, R *out, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru_dft_r2c)(int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + R *in, C *out, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru_dft_c2r)(int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + C *in, R *out, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru_split_dft_r2c)( \ + int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + R *in, R *ro, R *io, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru_split_dft_c2r)( \ + int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + R *ri, R *ii, R *out, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru64_dft_r2c)(int rank, \ + const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + R *in, C *out, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru64_dft_c2r)(int rank, \ + const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + C *in, R *out, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru64_split_dft_r2c)( \ + int rank, const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + R *in, R *ro, R *io, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_guru64_split_dft_c2r)( \ + int rank, const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + R *ri, R *ii, R *out, \ + unsigned flags); \ + \ +FFTW_EXTERN void X(execute_dft_r2c)(const X(plan) p, R *in, C *out); \ +FFTW_EXTERN void X(execute_dft_c2r)(const X(plan) p, C *in, R *out); \ + \ +FFTW_EXTERN void X(execute_split_dft_r2c)(const X(plan) p, \ + R *in, R *ro, R *io); \ +FFTW_EXTERN void X(execute_split_dft_c2r)(const X(plan) p, \ + R *ri, R *ii, R *out); \ + \ +FFTW_EXTERN X(plan) X(plan_many_r2r)(int rank, const int *n, \ + int howmany, \ + R *in, const int *inembed, \ + int istride, int idist, \ + R *out, const int *onembed, \ + int ostride, int odist, \ + const X(r2r_kind) *kind, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_r2r)(int rank, const int *n, R *in, R *out, \ + const X(r2r_kind) *kind, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_r2r_1d)(int n, R *in, R *out, \ + X(r2r_kind) kind, unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_r2r_2d)(int n0, int n1, R *in, R *out, \ + X(r2r_kind) kind0, X(r2r_kind) kind1, \ + unsigned flags); \ +FFTW_EXTERN X(plan) X(plan_r2r_3d)(int n0, int n1, int n2, \ + R *in, R *out, X(r2r_kind) kind0, \ + X(r2r_kind) kind1, X(r2r_kind) kind2, \ + unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru_r2r)(int rank, const X(iodim) *dims, \ + int howmany_rank, \ + const X(iodim) *howmany_dims, \ + R *in, R *out, \ + const X(r2r_kind) *kind, unsigned flags); \ + \ +FFTW_EXTERN X(plan) X(plan_guru64_r2r)(int rank, const X(iodim64) *dims, \ + int howmany_rank, \ + const X(iodim64) *howmany_dims, \ + R *in, R *out, \ + const X(r2r_kind) *kind, unsigned flags); \ + \ +FFTW_EXTERN void X(execute_r2r)(const X(plan) p, R *in, R *out); \ + \ +FFTW_EXTERN void X(destroy_plan)(X(plan) p); \ +FFTW_EXTERN void X(forget_wisdom)(void); \ +FFTW_EXTERN void X(cleanup)(void); \ + \ +FFTW_EXTERN void X(set_timelimit)(double t); \ + \ +FFTW_EXTERN void X(plan_with_nthreads)(int nthreads); \ +FFTW_EXTERN int X(init_threads)(void); \ +FFTW_EXTERN void X(cleanup_threads)(void); \ + \ +FFTW_EXTERN int X(export_wisdom_to_filename)(const char *filename); \ +FFTW_EXTERN void X(export_wisdom_to_file)(FILE *output_file); \ +FFTW_EXTERN char *X(export_wisdom_to_string)(void); \ +FFTW_EXTERN void X(export_wisdom)(X(write_char_func) write_char, \ + void *data); \ +FFTW_EXTERN int X(import_system_wisdom)(void); \ +FFTW_EXTERN int X(import_wisdom_from_filename)(const char *filename); \ +FFTW_EXTERN int X(import_wisdom_from_file)(FILE *input_file); \ +FFTW_EXTERN int X(import_wisdom_from_string)(const char *input_string); \ +FFTW_EXTERN int X(import_wisdom)(X(read_char_func) read_char, void *data); \ + \ +FFTW_EXTERN void X(fprint_plan)(const X(plan) p, FILE *output_file); \ +FFTW_EXTERN void X(print_plan)(const X(plan) p); \ +FFTW_EXTERN char *X(sprint_plan)(const X(plan) p); \ + \ +FFTW_EXTERN void *X(malloc)(size_t n); \ +FFTW_EXTERN R *X(alloc_real)(size_t n); \ +FFTW_EXTERN C *X(alloc_complex)(size_t n); \ +FFTW_EXTERN void X(free)(void *p); \ + \ +FFTW_EXTERN void X(flops)(const X(plan) p, \ + double *add, double *mul, double *fmas); \ +FFTW_EXTERN double X(estimate_cost)(const X(plan) p); \ +FFTW_EXTERN double X(cost)(const X(plan) p); \ + \ +FFTW_EXTERN int X(alignment_of)(R *p); \ +FFTW_EXTERN const char X(version)[]; \ +FFTW_EXTERN const char X(cc)[]; \ +FFTW_EXTERN const char X(codelet_optim)[]; + + +/* end of FFTW_DEFINE_API macro */ + +FFTW_DEFINE_API(FFTW_MANGLE_DOUBLE, double, fftw_complex) +FFTW_DEFINE_API(FFTW_MANGLE_FLOAT, float, fftwf_complex) +FFTW_DEFINE_API(FFTW_MANGLE_LONG_DOUBLE, long double, fftwl_complex) + +/* __float128 (quad precision) is a gcc extension on i386, x86_64, and ia64 + for gcc >= 4.6 (compiled in FFTW with --enable-quad-precision) */ +#if (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) \ + && !(defined(__ICC) || defined(__INTEL_COMPILER)) \ + && (defined(__i386__) || defined(__x86_64__) || defined(__ia64__)) +# if !defined(FFTW_NO_Complex) && defined(_Complex_I) && defined(complex) && defined(I) +/* note: __float128 is a typedef, which is not supported with the _Complex + keyword in gcc, so instead we use this ugly __attribute__ version. + However, we can't simply pass the __attribute__ version to + FFTW_DEFINE_API because the __attribute__ confuses gcc in pointer + types. Hence redefining FFTW_DEFINE_COMPLEX. Ugh. */ +# undef FFTW_DEFINE_COMPLEX +# define FFTW_DEFINE_COMPLEX(R, C) typedef _Complex float __attribute__((mode(TC))) C +# endif +FFTW_DEFINE_API(FFTW_MANGLE_QUAD, __float128, fftwq_complex) +#endif + +#define FFTW_FORWARD (-1) +#define FFTW_BACKWARD (+1) + +#define FFTW_NO_TIMELIMIT (-1.0) + +/* documented flags */ +#define FFTW_MEASURE (0U) +#define FFTW_DESTROY_INPUT (1U << 0) +#define FFTW_UNALIGNED (1U << 1) +#define FFTW_CONSERVE_MEMORY (1U << 2) +#define FFTW_EXHAUSTIVE (1U << 3) /* NO_EXHAUSTIVE is default */ +#define FFTW_PRESERVE_INPUT (1U << 4) /* cancels FFTW_DESTROY_INPUT */ +#define FFTW_PATIENT (1U << 5) /* IMPATIENT is default */ +#define FFTW_ESTIMATE (1U << 6) +#define FFTW_WISDOM_ONLY (1U << 21) + +/* undocumented beyond-guru flags */ +#define FFTW_ESTIMATE_PATIENT (1U << 7) +#define FFTW_BELIEVE_PCOST (1U << 8) +#define FFTW_NO_DFT_R2HC (1U << 9) +#define FFTW_NO_NONTHREADED (1U << 10) +#define FFTW_NO_BUFFERING (1U << 11) +#define FFTW_NO_INDIRECT_OP (1U << 12) +#define FFTW_ALLOW_LARGE_GENERIC (1U << 13) /* NO_LARGE_GENERIC is default */ +#define FFTW_NO_RANK_SPLITS (1U << 14) +#define FFTW_NO_VRANK_SPLITS (1U << 15) +#define FFTW_NO_VRECURSE (1U << 16) +#define FFTW_NO_SIMD (1U << 17) +#define FFTW_NO_SLOW (1U << 18) +#define FFTW_NO_FIXED_RADIX_LARGE_N (1U << 19) +#define FFTW_ALLOW_PRUNING (1U << 20) + +#ifdef __cplusplus +} /* extern "C" */ +#endif /* __cplusplus */ + +#endif /* FFTW3_H */ diff --git a/Source/src/DataEngine/cusdr_dataIO.h b/Source/src/DataEngine/cusdr_dataIO.h index fe1a14d..3043799 100644 --- a/Source/src/DataEngine/cusdr_dataIO.h +++ b/Source/src/DataEngine/cusdr_dataIO.h @@ -59,7 +59,7 @@ public slots: void initDataReceiverSocket(); void readData(); void writeData(); - void sendAudio(u_char *buf); + void sendAudio(uint8_t *buf); void sendInitFramesToNetworkDevice(int rx); void networkDeviceStartStop(char value); //void setWidebandBuffers(int value);