mirror of
https://github.com/thestk/stk
synced 2026-01-13 04:51:53 +00:00
Version 4.4.3
This commit is contained in:
committed by
Stephen Sinclair
parent
baca57040b
commit
0aec39260a
@@ -6,7 +6,7 @@
|
||||
provided for creating a resonance in the frequency response while
|
||||
maintaining a nearly constant filter gain.
|
||||
|
||||
by Perry R. Cook and Gary P. Scavone, 1995 - 2010.
|
||||
by Perry R. Cook and Gary P. Scavone, 1995-2011.
|
||||
*/
|
||||
/***************************************************/
|
||||
|
||||
@@ -35,13 +35,24 @@ TwoPole :: ~TwoPole()
|
||||
void TwoPole :: sampleRateChanged( StkFloat newRate, StkFloat oldRate )
|
||||
{
|
||||
if ( !ignoreSampleRateChange_ ) {
|
||||
errorString_ << "TwoPole::sampleRateChanged: you may need to recompute filter coefficients!";
|
||||
oStream_ << "TwoPole::sampleRateChanged: you may need to recompute filter coefficients!";
|
||||
handleError( StkError::WARNING );
|
||||
}
|
||||
}
|
||||
|
||||
void TwoPole :: setResonance( StkFloat frequency, StkFloat radius, bool normalize )
|
||||
{
|
||||
#if defined(_STK_DEBUG_)
|
||||
if ( frequency < 0.0 || frequency > 0.5 * Stk::sampleRate() ) {
|
||||
oStream_ << "TwoPole::setResonance: frequency argument (" << frequency << ") is out of range!";
|
||||
handleError( StkError::WARNING ); return;
|
||||
}
|
||||
if ( radius < 0.0 || radius >= 1.0 ) {
|
||||
oStream_ << "TwoPole::setResonance: radius argument (" << radius << ") is out of range!";
|
||||
handleError( StkError::WARNING ); return;
|
||||
}
|
||||
#endif
|
||||
|
||||
a_[2] = radius * radius;
|
||||
a_[1] = (StkFloat) -2.0 * radius * cos(TWO_PI * frequency / Stk::sampleRate());
|
||||
|
||||
|
||||
Reference in New Issue
Block a user