1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
|
#ifndef INCLUDE_FREQUENCYREFERENCE_H
#define INCLUDE_FREQUENCYREFERENCE_H
/*
* This is the Loris C++ Class Library, implementing analysis,
* manipulation, and synthesis of digitized sounds using the Reassigned
* Bandwidth-Enhanced Additive Sound Model.
*
* Loris is Copyright (c) 1999-2010 by Kelly Fitz and Lippold Haken
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*
* FrequencyReference.h
*
* Definition of class FrequencyReference.
*
* Kelly Fitz, 3 Dec 2001
* loris@cerlsoundgroup.org
*
* http://www.cerlsoundgroup.org/Loris/
*
*/
#include "Envelope.h"
#include "PartialList.h"
#include <memory>
// begin namespace
namespace Loris {
class LinearEnvelope;
// ---------------------------------------------------------------------------
// class FrequencyReference
//
//! Class FrequencyReference represents a reference frequency envelope
//! derived from an estimate of the fundamental frequency of a given range
//! of Partials within in a specified frequency range. This reference envelope
//! can be used for channelizing the Partials in preparation for morphing
//! (see Channelizer.h).
//!
//! FrequencyReference implements the Envelope interface (see
//! Envelope.h).
//
class FrequencyReference : public Envelope
{
// -- instance variables --
std::auto_ptr< LinearEnvelope > _env;
// -- public interface --
public:
// -- construction --
//! Construct a new fundamental FrequencyReference derived from the
//! specified half-open (STL-style) range of Partials that lies
//! within the speficied average frequency range. Construct the
//! reference envelope with approximately numSamps points.
//!
//! \param begin The beginning of a range of Partials from which to
//! construct a frequency refence envelope.
//! \param end The end of a range of Partials from which to
//! construct a frequency refence envelope.
//! \param minFreq The minimum expected fundamental frequency.
//! \param maxFreq The maximum expected fundamental frequency.
//! \param numSamps The approximate number of estimate of the
//! fundamental frequency from which to construct the
//! frequency reference envelope.
FrequencyReference( PartialList::const_iterator begin,
PartialList::const_iterator end,
double minFreq, double maxFreq, long numSamps );
//! Construct a new fundamental FrequencyReference derived from the
//! specified half-open (STL-style) range of Partials that lies
//! within the speficied average frequency range. Construct the
//! reference envelope from fundamental estimates taken every
//! five milliseconds.
//!
//! \param begin The beginning of a range of Partials from which to
//! construct a frequency refence envelope.
//! \param end The end of a range of Partials from which to
//! construct a frequency refence envelope.
//! \param minFreq The minimum expected fundamental frequency.
//! \param maxFreq The maximum expected fundamental frequency.
FrequencyReference( PartialList::const_iterator begin,
PartialList::const_iterator end,
double minFreq, double maxFreq );
//! Construct a new FrequencyReference that is an exact copy of the
//! specified FrequencyReference.
FrequencyReference( const FrequencyReference & other );
//! Assignment operator: make this FrequencyReference an exact copy
//! of the specified FrequencyReference.
FrequencyReference & operator= ( const FrequencyReference & other );
//! Destroy this FrequencyReference.
~FrequencyReference();
// -- conversion to LinearEnvelope --
//! Return a LinearEnvelope that evaluates indentically to this
//! FrequencyReference at all time.
LinearEnvelope envelope( void ) const;
// -- Envelope interface --
//! Return an exact copy of this FrequencyReference (following the
//! Prototype pattern).
virtual FrequencyReference * clone( void ) const;
//! Return the frequency value (in Hz) of this FrequencyReference at the
//! specified time.
virtual double valueAt( double x ) const;
}; // end of class FrequencyReference
} // end of namespace Loris
#endif // ndef INCLUDE_FREQUENCYREFERENCE_H
|