changeset 121:d1a99d44812b

Trim down examples, tidy
author Chris Cannam <c.cannam@qmul.ac.uk>
date Thu, 10 Nov 2016 12:07:51 +0000
parents 975719b38bdb
children 6d651bfc93b9
files Makefile.example.em Makefile.inc Makefile.qm-vamp-plugins.em Makefile.silvet.em Makefile.testplugin.em examples/Makefile.vamp-example-plugins examples/Makefile.vamp-test-plugin examples/qm-vamp-plugins.cpp examples/silvet.cpp
diffstat 9 files changed, 36 insertions(+), 344 deletions(-) [+]
line wrap: on
line diff
--- a/Makefile.example.em	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,16 +0,0 @@
-
-MODULE_NAME	:= VampExamplePlugins
-
-EXAMPLE_DIR	:= ../vamp-plugin-sdk/examples
-
-PLUGIN_SOURCES	:= \
-		$(EXAMPLE_DIR)/ZeroCrossing.cpp \
-		$(EXAMPLE_DIR)/SpectralCentroid.cpp \
-		$(EXAMPLE_DIR)/PercussionOnsetDetector.cpp \
-		$(EXAMPLE_DIR)/FixedTempoEstimator.cpp \
-		$(EXAMPLE_DIR)/AmplitudeFollower.cpp \
-		$(EXAMPLE_DIR)/PowerSpectrum.cpp
-
-MODULE_SOURCE	:= examples/vamp-example-plugins.cpp
-
-include Makefile.inc
--- a/Makefile.inc	Thu Nov 10 11:34:04 2016 +0000
+++ b/Makefile.inc	Thu Nov 10 12:07:51 2016 +0000
@@ -15,9 +15,11 @@
 		@echo "Note: when switching from one target to another, make clean first"
 		@echo
 
-SRC_DIR		:= src
-SDK_DIR		:= ../vamp-plugin-sdk
-PIPERCPP_DIR    := ../piper-cpp
+MY_DIR		:= $(realpath $(dir $(lastword $(MAKEFILE_LIST))))
+
+SRC_DIR		:= $(MY_DIR)/src
+SDK_DIR		:= $(MY_DIR)/../vamp-plugin-sdk
+PIPERCPP_DIR    := $(MY_DIR)/../piper-cpp
 
 ADAPTER_HEADERS	:= \
 		$(SRC_DIR)/PiperAdapter.h \
@@ -59,7 +61,7 @@
 		$(EMFLAGS)
 
 CXX_SOURCES	:= $(MODULE_SOURCE) $(ADAPTER_SOURCES) $(PLUGIN_SOURCES) $(SDK_SOURCES) $(OTHER_SOURCES)
-C_SOURCES	:= $(PLUGIN_C_SOURCES)
+C_SOURCES	:= $(PLUGIN_C_SOURCES) $(C_SOURCES)
 
 #OPTFLAGS	:= -g3
 OPTFLAGS	:= -O3 -ffast-math
@@ -96,7 +98,7 @@
 		$(CC) -c $(INCPATH) $(CFLAGS) -o $@ $<
 
 $(EM_MODULE):	$(OBJECTS)
-		$(CXX) $(OPTFLAGS) $(EMFLAGS) -o $@ $^ $(LDFLAGS) && \
+		$(CXX) $(OPTFLAGS) -o $@ $^ $(LDFLAGS) && \
 		( echo "if (typeof process === 'object') module.exports=$(MODULE_SYMBOL);" >> $(EM_MODULE) )
 
 $(SO_MODULE):	$(OBJECTS)
--- a/Makefile.qm-vamp-plugins.em	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,115 +0,0 @@
-
-MODULE_NAME	:= QMVampPlugins
-
-QMV	:= ../qm-vamp-plugins
-DSP	:= $(QMV)/qm-dsp
-EXT	:= $(DSP)/ext
-
-INCPATH	:= -I$(QMV) -I$(DSP) -I$(EXT)/kissfft -I$(EXT)/kissfft/tools
-DEFINES := -DNO_BLAS_WRAP -DADD_ -Dkiss_fft_scalar=double -I$(EXT)/clapack/include -I$(EXT)/cblas/include
-
-CLAPACK_SOURCES := \
-  	$(EXT)/clapack/src/dgetrf.c \
-	$(EXT)/clapack/src/dgetri.c \
-	$(EXT)/clapack/src/dgetf2.c \
-	$(EXT)/clapack/src/xerbla.c \
-	$(EXT)/clapack/src/dlaswp.c \
-	$(EXT)/clapack/src/dtrtri.c \
-	$(EXT)/clapack/src/ilaenv.c \
-	$(EXT)/clapack/src/iparmq.c \
-	$(EXT)/clapack/src/s_cat.c \
-	$(EXT)/clapack/src/s_copy.c \
-	$(EXT)/clapack/src/s_cmp.c \
-	$(EXT)/clapack/src/pow_di.c \
-	$(EXT)/clapack/src/ieeeck.c \
-	$(EXT)/clapack/src/i_nint.c \
-	$(EXT)/clapack/src/dtrti2.c \
-	$(EXT)/clapack/src/f77_aloc.c \
-	$(EXT)/clapack/src/exit_.c 
-
-CBLAS_SOURCES := \
-	$(EXT)/cblas/src/dgemm.c \
-	$(EXT)/cblas/src/ddot.c \
-	$(EXT)/cblas/src/dgemv.c \
-	$(EXT)/cblas/src/dswap.c \
-	$(EXT)/cblas/src/dtrsm.c \
-	$(EXT)/cblas/src/dger.c \
-	$(EXT)/cblas/src/idamax.c \
-	$(EXT)/cblas/src/dscal.c \
-	$(EXT)/cblas/src/dtrmm.c \
-	$(EXT)/cblas/src/lsame.c \
-	$(EXT)/cblas/src/dlamch.c \
-	$(EXT)/cblas/src/dtrmv.c \
-	$(EXT)/cblas/src/cblas_globals.c \
-	$(EXT)/cblas/src/cblas_dgemm.c \
-	$(EXT)/cblas/src/cblas_ddot.c \
-	$(EXT)/cblas/src/cblas_xerbla.c
-
-DSP_SOURCES := \
-	$(DSP)/base/Pitch.cpp \
-	$(DSP)/base/KaiserWindow.cpp \
-	$(DSP)/base/SincWindow.cpp \
-	$(DSP)/dsp/chromagram/Chromagram.cpp \
-	$(DSP)/dsp/chromagram/ConstantQ.cpp \
-	$(DSP)/dsp/keydetection/GetKeyMode.cpp \
-	$(DSP)/dsp/mfcc/MFCC.cpp \
-	$(DSP)/dsp/onsets/DetectionFunction.cpp \
-	$(DSP)/dsp/onsets/PeakPicking.cpp \
-	$(DSP)/dsp/phasevocoder/PhaseVocoder.cpp \
-	$(DSP)/dsp/rateconversion/Decimator.cpp \
-	$(DSP)/dsp/rateconversion/DecimatorB.cpp \
-	$(DSP)/dsp/rateconversion/Resampler.cpp \
-	$(DSP)/dsp/rhythm/BeatSpectrum.cpp \
-	$(DSP)/dsp/segmentation/ClusterMeltSegmenter.cpp \
-	$(DSP)/dsp/segmentation/Segmenter.cpp \
-	$(DSP)/dsp/signalconditioning/DFProcess.cpp \
-	$(DSP)/dsp/signalconditioning/Filter.cpp \
-	$(DSP)/dsp/signalconditioning/FiltFilt.cpp \
-	$(DSP)/dsp/signalconditioning/Framer.cpp \
-	$(DSP)/dsp/tempotracking/DownBeat.cpp \
-	$(DSP)/dsp/tempotracking/TempoTrack.cpp \
-	$(DSP)/dsp/tempotracking/TempoTrackV2.cpp \
-	$(DSP)/dsp/tonal/ChangeDetectionFunction.cpp \
-	$(DSP)/dsp/tonal/TCSgram.cpp \
-	$(DSP)/dsp/tonal/TonalEstimator.cpp \
-	$(DSP)/dsp/transforms/DCT.cpp \
-	$(DSP)/dsp/transforms/FFT.cpp \
-	$(DSP)/dsp/wavelet/Wavelet.cpp \
-	$(DSP)/maths/Correlation.cpp \
-	$(DSP)/maths/CosineDistance.cpp \
-	$(DSP)/maths/KLDivergence.cpp \
-	$(DSP)/maths/MathUtilities.cpp
-
-#	$(DSP)/thread/Thread.cpp \
-
-#	$(QMV)/plugins/AdaptiveSpectrogram.cpp \
-
-PLUGIN_SOURCES := \
-	$(QMV)/plugins/BarBeatTrack.cpp \
-	$(QMV)/plugins/BeatTrack.cpp \
-	$(QMV)/plugins/DWT.cpp \
-	$(QMV)/plugins/OnsetDetect.cpp \
-	$(QMV)/plugins/ChromagramPlugin.cpp \
-	$(QMV)/plugins/ConstantQSpectrogram.cpp \
-	$(QMV)/plugins/KeyDetect.cpp \
-	$(QMV)/plugins/MFCCPlugin.cpp \
-	$(QMV)/plugins/SegmenterPlugin.cpp \
-	$(QMV)/plugins/SimilarityPlugin.cpp \
-	$(QMV)/plugins/TonalChangeDetect.cpp \
-	$(QMV)/plugins/Transcription.cpp \
-	$(DSP_SOURCES)
-
-C_SOURCES	:= \
-	$(QMV)/g2cstubs.c \
-	$(DSP)/dsp/segmentation/cluster_segmenter.c \
-	$(DSP)/dsp/segmentation/cluster_melt.c \
-	$(DSP)/hmm/hmm.c \
-	$(DSP)/maths/pca/pca.c \
-	$(DSP)/ext/kissfft/kiss_fft.c \
-	$(DSP)/ext/kissfft/tools/kiss_fftr.c \
-	$(CLAPACK_SOURCES) \
-	$(CBLAS_SOURCES)
-
-MODULE_SOURCE	:= qm-vamp-plugins.cpp
-
-include Makefile.inc.em
--- a/Makefile.silvet.em	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,54 +0,0 @@
-
-MODULE_NAME	:= Silvet
-
-SILVET_DIR	:= ../silvet
-
-SRC_DIR		:= $(SILVET_DIR)/src
-CQ_DIR	     	:= $(SILVET_DIR)/constant-q-cpp
-CQSRC_DIR     	:= $(SILVET_DIR)/constant-q-cpp/src
-KFFT_DIR  	:= $(SILVET_DIR)/constant-q-cpp/src/ext/kissfft
-BQVEC_DIR     	:= $(SILVET_DIR)/bqvec
-FD_DIR	     	:= $(SILVET_DIR)/flattendynamics
-
-INCPATH		:= -I$(SRC_DIR) -I$(CQ_DIR) -I$(CQ_DIR)/cq -I$(KFFT_DIR) -I$(KFFT_DIR)/tools -I$(SILVET_DIR) -I$(FD_DIR) -I$(BQVEC_DIR)
-
-EMFLAGS		:= -s TOTAL_MEMORY=100000000
-
-DEFINES		:= -Dkiss_fft_scalar=double
- 
-PLUGIN_SOURCES 	:= \
-		$(SRC_DIR)/Silvet.cpp \
-		$(SRC_DIR)/EM.cpp \
-		$(SRC_DIR)/Instruments.cpp \
-		$(SRC_DIR)/LiveInstruments.cpp
-
-BQVEC_SOURCES	:= \
-		$(BQVEC_DIR)/src/Allocators.cpp
-
-FD_SOURCES	:= \
-		$(FD_DIR)/flattendynamics-ladspa.cpp
-
-CQ_SOURCES	:= \
-		$(CQSRC_DIR)/CQKernel.cpp \
-		$(CQSRC_DIR)/ConstantQ.cpp \
-		$(CQSRC_DIR)/CQSpectrogram.cpp \
-		$(CQSRC_DIR)/CQInverse.cpp \
-		$(CQSRC_DIR)/Chromagram.cpp \
-		$(CQSRC_DIR)/Pitch.cpp \
-		$(CQSRC_DIR)/dsp/FFT.cpp \
-		$(CQSRC_DIR)/dsp/KaiserWindow.cpp \
-		$(CQSRC_DIR)/dsp/MathUtilities.cpp \
-		$(CQSRC_DIR)/dsp/Resampler.cpp \
-		$(CQSRC_DIR)/dsp/SincWindow.cpp
-
-KFFT_SOURCES    := \
-		$(KFFT_DIR)/kiss_fft.c \
-		$(KFFT_DIR)/tools/kiss_fftr.c
-
-PLUGIN_SOURCES	:= $(PLUGIN_SOURCES) $(BQVEC_SOURCES) $(FD_SOURCES) $(CQ_SOURCES)
-
-PLUGIN_C_SOURCES   := $(KFFT_SOURCES)
-
-MODULE_SOURCE	:= silvet.cpp
-
-include Makefile.inc.em
--- a/Makefile.testplugin.em	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,13 +0,0 @@
-
-MODULE_NAME	:= VampTestPlugin
-
-TESTPLUGIN_DIR	:= ../vamp-test-plugin
-
-INCPATH		:= -I$(TESTPLUGIN_DIR)
-
-PLUGIN_SOURCES	:= \
-		$(TESTPLUGIN_DIR)/VampTestPlugin.cpp
-
-MODULE_SOURCE	:= vamp-test-plugin.cpp
-
-include Makefile.inc.em
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/examples/Makefile.vamp-example-plugins	Thu Nov 10 12:07:51 2016 +0000
@@ -0,0 +1,16 @@
+
+MODULE_NAME	:= VampExamplePlugins
+
+EXAMPLE_DIR	:= ../../vamp-plugin-sdk/examples
+
+PLUGIN_SOURCES	:= \
+		$(EXAMPLE_DIR)/ZeroCrossing.cpp \
+		$(EXAMPLE_DIR)/SpectralCentroid.cpp \
+		$(EXAMPLE_DIR)/PercussionOnsetDetector.cpp \
+		$(EXAMPLE_DIR)/FixedTempoEstimator.cpp \
+		$(EXAMPLE_DIR)/AmplitudeFollower.cpp \
+		$(EXAMPLE_DIR)/PowerSpectrum.cpp
+
+MODULE_SOURCE	:= vamp-example-plugins.cpp
+
+include ../Makefile.inc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/examples/Makefile.vamp-test-plugin	Thu Nov 10 12:07:51 2016 +0000
@@ -0,0 +1,13 @@
+
+MODULE_NAME	:= VampTestPlugin
+
+TESTPLUGIN_DIR	:= ../../vamp-test-plugin
+
+INCPATH		:= -I$(TESTPLUGIN_DIR)
+
+PLUGIN_SOURCES	:= \
+		$(TESTPLUGIN_DIR)/VampTestPlugin.cpp
+
+MODULE_SOURCE	:= vamp-test-plugin.cpp
+
+include ../Makefile.inc
--- a/examples/qm-vamp-plugins.cpp	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,105 +0,0 @@
-/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */
-
-/*
-    Piper
-
-    Centre for Digital Music, Queen Mary, University of London.
-    Copyright 2015-2016 QMUL.
-  
-    Permission is hereby granted, free of charge, to any person
-    obtaining a copy of this software and associated documentation
-    files (the "Software"), to deal in the Software without
-    restriction, including without limitation the rights to use, copy,
-    modify, merge, publish, distribute, sublicense, and/or sell copies
-    of the Software, and to permit persons to whom the Software is
-    furnished to do so, subject to the following conditions:
-
-    The above copyright notice and this permission notice shall be
-    included in all copies or substantial portions of the Software.
-
-    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-    NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
-    ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
-    CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
-    WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-    Except as contained in this notice, the names of the Centre for
-    Digital Music; Queen Mary, University of London; and Chris Cannam
-    shall not be used in advertising or otherwise to promote the sale,
-    use or other dealings in this Software without prior written
-    authorization.
-*/
-
-#include "PiperAdapter.h"
-#include "PiperPluginLibrary.h"
-
-#include "plugins/BeatTrack.h"
-#include "plugins/OnsetDetect.h"
-#include "plugins/ChromagramPlugin.h"
-#include "plugins/ConstantQSpectrogram.h"
-#include "plugins/TonalChangeDetect.h"
-#include "plugins/KeyDetect.h"
-#include "plugins/MFCCPlugin.h"
-#include "plugins/SegmenterPlugin.h"
-#include "plugins/SimilarityPlugin.h"
-#include "plugins/BarBeatTrack.h"
-//!!!#include "plugins/AdaptiveSpectrogram.h"
-#include "plugins/DWT.h"
-#include "plugins/Transcription.h"
-
-using piper::PiperAdapter;
-using piper::PiperPluginLibrary;
-
-static std::string soname("qm-vamp-plugins");
-
-static PiperAdapter<BeatTracker> beatTrackerAdapter(soname);
-static PiperAdapter<OnsetDetector> onsetDetectorAdapter(soname);
-static PiperAdapter<ChromagramPlugin> chromagramPluginAdapter(soname);
-static PiperAdapter<ConstantQSpectrogram> constantQAdapter(soname);
-static PiperAdapter<TonalChangeDetect> tonalChangeDetectorAdapter(soname);
-static PiperAdapter<KeyDetector> keyDetectorAdapter(soname);
-static PiperAdapter<MFCCPlugin> mfccPluginAdapter(soname);
-static PiperAdapter<SegmenterPlugin> segmenterPluginAdapter(soname);
-static PiperAdapter<SimilarityPlugin> similarityPluginAdapter(soname);
-static PiperAdapter<BarBeatTracker> barBeatTrackPluginAdapter(soname);
-//!!!static PiperAdapter<AdaptiveSpectrogram> adaptiveSpectrogramAdapter(soname);
-static PiperAdapter<DWT> dwtAdapter(soname);
-static PiperAdapter<Transcription> transcriptionAdapter(soname);
-
-static PiperPluginLibrary library({
-	&beatTrackerAdapter,
-	    &onsetDetectorAdapter,
-	    &chromagramPluginAdapter,
-	    &constantQAdapter,
-	    &tonalChangeDetectorAdapter,
-	    &keyDetectorAdapter,
-	    &mfccPluginAdapter,
-	    &segmenterPluginAdapter,
-	    &similarityPluginAdapter,
-	    &barBeatTrackPluginAdapter,
-//!!!	    &adaptiveSpectrogramAdapter,
-	    &dwtAdapter,
-	    &transcriptionAdapter
-	    });
-
-extern "C" {
-
-const char *piperRequestJson(const char *request) {
-    return library.requestJson(request);
-}
-
-const char *piperProcessRaw(int handle,
-                              const float *const *inputBuffers,
-                              int sec,
-                              int nsec) {
-    return library.processRaw(handle, inputBuffers, sec, nsec);
-}
-    
-void piperFreeJson(const char *json) {
-    return library.freeJson(json);
-}
-
-}
-
--- a/examples/silvet.cpp	Thu Nov 10 11:34:04 2016 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,36 +0,0 @@
-
-#include "PiperAdapter.h"
-#include "PiperPluginLibrary.h"
-
-#include "Silvet.h"
-
-using piper::PiperAdapter;
-using piper::PiperPluginLibrary;
-
-static std::string soname("silvet");
-
-static PiperAdapter<Silvet> silvetAdapter(soname);
-
-static PiperPluginLibrary library({
-    &silvetAdapter
-});
-
-extern "C" {
-
-const char *piperRequestJson(const char *request) {
-    return library.requestJson(request);
-}
-
-const char *piperProcessRaw(int handle,
-                              const float *const *inputBuffers,
-                              int sec,
-                              int nsec) {
-    return library.processRaw(handle, inputBuffers, sec, nsec);
-}
-    
-void piperFreeJson(const char *json) {
-    return library.freeJson(json);
-}
-
-}
-