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