cannam@95
|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
cannam@95
|
2
|
cannam@95
|
3 /*
|
cannam@95
|
4 Rubber Band Library
|
cannam@95
|
5 An audio time-stretching and pitch-shifting library.
|
cannam@95
|
6 Copyright 2007-2012 Particular Programs Ltd.
|
cannam@95
|
7
|
cannam@95
|
8 This program is free software; you can redistribute it and/or
|
cannam@95
|
9 modify it under the terms of the GNU General Public License as
|
cannam@95
|
10 published by the Free Software Foundation; either version 2 of the
|
cannam@95
|
11 License, or (at your option) any later version. See the file
|
cannam@95
|
12 COPYING included with this distribution for more information.
|
cannam@95
|
13
|
cannam@95
|
14 Alternatively, if you have a valid commercial licence for the
|
cannam@95
|
15 Rubber Band Library obtained by agreement with the copyright
|
cannam@95
|
16 holders, you may redistribute and/or modify it under the terms
|
cannam@95
|
17 described in that licence.
|
cannam@95
|
18
|
cannam@95
|
19 If you wish to distribute code using the Rubber Band Library
|
cannam@95
|
20 under terms other than those of the GNU General Public License,
|
cannam@95
|
21 you must obtain a valid commercial licence before doing so.
|
cannam@95
|
22 */
|
cannam@95
|
23
|
cannam@95
|
24 #ifndef _RUBBERBAND_PITCH_SHIFTER_H_
|
cannam@95
|
25 #define _RUBBERBAND_PITCH_SHIFTER_H_
|
cannam@95
|
26
|
cannam@95
|
27 #include <ladspa.h>
|
cannam@95
|
28
|
cannam@95
|
29 #include "base/RingBuffer.h"
|
cannam@95
|
30
|
cannam@95
|
31 namespace RubberBand {
|
cannam@95
|
32 class RubberBandStretcher;
|
cannam@95
|
33 }
|
cannam@95
|
34
|
cannam@95
|
35 class RubberBandPitchShifter
|
cannam@95
|
36 {
|
cannam@95
|
37 public:
|
cannam@95
|
38 static const LADSPA_Descriptor *getDescriptor(unsigned long index);
|
cannam@95
|
39
|
cannam@95
|
40 protected:
|
cannam@95
|
41 RubberBandPitchShifter(int sampleRate, size_t channels);
|
cannam@95
|
42 ~RubberBandPitchShifter();
|
cannam@95
|
43
|
cannam@95
|
44 enum {
|
cannam@95
|
45 LatencyPort = 0,
|
cannam@95
|
46 OctavesPort = 1,
|
cannam@95
|
47 SemitonesPort = 2,
|
cannam@95
|
48 CentsPort = 3,
|
cannam@95
|
49 CrispnessPort = 4,
|
cannam@95
|
50 FormantPort = 5,
|
cannam@95
|
51 FastPort = 6,
|
cannam@95
|
52 InputPort1 = 7,
|
cannam@95
|
53 OutputPort1 = 8,
|
cannam@95
|
54 PortCountMono = OutputPort1 + 1,
|
cannam@95
|
55 InputPort2 = 9,
|
cannam@95
|
56 OutputPort2 = 10,
|
cannam@95
|
57 PortCountStereo = OutputPort2 + 1
|
cannam@95
|
58 };
|
cannam@95
|
59
|
cannam@95
|
60 static const char *const portNamesMono[PortCountMono];
|
cannam@95
|
61 static const LADSPA_PortDescriptor portsMono[PortCountMono];
|
cannam@95
|
62 static const LADSPA_PortRangeHint hintsMono[PortCountMono];
|
cannam@95
|
63
|
cannam@95
|
64 static const char *const portNamesStereo[PortCountStereo];
|
cannam@95
|
65 static const LADSPA_PortDescriptor portsStereo[PortCountStereo];
|
cannam@95
|
66 static const LADSPA_PortRangeHint hintsStereo[PortCountStereo];
|
cannam@95
|
67
|
cannam@95
|
68 static const LADSPA_Properties properties;
|
cannam@95
|
69
|
cannam@95
|
70 static const LADSPA_Descriptor ladspaDescriptorMono;
|
cannam@95
|
71 static const LADSPA_Descriptor ladspaDescriptorStereo;
|
cannam@95
|
72
|
cannam@95
|
73 static LADSPA_Handle instantiate(const LADSPA_Descriptor *, unsigned long);
|
cannam@95
|
74 static void connectPort(LADSPA_Handle, unsigned long, LADSPA_Data *);
|
cannam@95
|
75 static void activate(LADSPA_Handle);
|
cannam@95
|
76 static void run(LADSPA_Handle, unsigned long);
|
cannam@95
|
77 static void deactivate(LADSPA_Handle);
|
cannam@95
|
78 static void cleanup(LADSPA_Handle);
|
cannam@95
|
79
|
cannam@95
|
80 void activateImpl();
|
cannam@95
|
81 void runImpl(unsigned long);
|
cannam@95
|
82 void runImpl(unsigned long, unsigned long offset);
|
cannam@95
|
83 void updateRatio();
|
cannam@95
|
84 void updateCrispness();
|
cannam@95
|
85 void updateFormant();
|
cannam@95
|
86 void updateFast();
|
cannam@95
|
87
|
cannam@95
|
88 float *m_input[2];
|
cannam@95
|
89 float *m_output[2];
|
cannam@95
|
90 float *m_latency;
|
cannam@95
|
91 float *m_cents;
|
cannam@95
|
92 float *m_semitones;
|
cannam@95
|
93 float *m_octaves;
|
cannam@95
|
94 float *m_crispness;
|
cannam@95
|
95 float *m_formant;
|
cannam@95
|
96 float *m_fast;
|
cannam@95
|
97 double m_ratio;
|
cannam@95
|
98 double m_prevRatio;
|
cannam@95
|
99 int m_currentCrispness;
|
cannam@95
|
100 bool m_currentFormant;
|
cannam@95
|
101 bool m_currentFast;
|
cannam@95
|
102
|
cannam@95
|
103 size_t m_blockSize;
|
cannam@95
|
104 size_t m_reserve;
|
cannam@95
|
105 size_t m_minfill;
|
cannam@95
|
106
|
cannam@95
|
107 RubberBand::RubberBandStretcher *m_stretcher;
|
cannam@95
|
108 RubberBand::RingBuffer<float> *m_outputBuffer[2];
|
cannam@95
|
109 float *m_scratch[2];
|
cannam@95
|
110
|
cannam@95
|
111 int m_sampleRate;
|
cannam@95
|
112 size_t m_channels;
|
cannam@95
|
113 };
|
cannam@95
|
114
|
cannam@95
|
115
|
cannam@95
|
116 #endif
|