Audacity 3.2.0
Public Member Functions | Static Public Member Functions | Static Public Attributes | Private Types | Private Member Functions | Private Attributes | Static Private Attributes | Friends | List of all members
EffectScienFilter Class Referencefinal

An Effect that applies 'classical' IIR filters. More...

#include <ScienFilter.h>

Inheritance diagram for EffectScienFilter:
[legend]
Collaboration diagram for EffectScienFilter:
[legend]

Public Member Functions

 EffectScienFilter ()
 
virtual ~EffectScienFilter ()
 
ComponentInterfaceSymbol GetSymbol () const override
 
TranslatableString GetDescription () const override
 
ManualPageID ManualPage () const override
 Name of a page in the Audacity alpha manual, default is empty. More...
 
EffectType GetType () const override
 Type determines how it behaves. More...
 
unsigned GetAudioInCount () const override
 How many input buffers to allocate at once. More...
 
unsigned GetAudioOutCount () const override
 How many output buffers to allocate at once. More...
 
bool ProcessInitialize (EffectSettings &settings, double sampleRate, ChannelNames chanMap) override
 
size_t ProcessBlock (EffectSettings &settings, const float *const *inBlock, float *const *outBlock, size_t blockLen) override
 Called for destructive effect computation. More...
 
bool Init () override
 
std::unique_ptr< EffectEditorPopulateOrExchange (ShuttleGui &S, EffectInstance &instance, EffectSettingsAccess &access, const EffectOutputs *pOutputs) override
 Add controls to effect panel; always succeeds. More...
 
bool TransferDataToWindow (const EffectSettings &settings) override
 
bool TransferDataFromWindow (EffectSettings &settings) override
 
- Public Member Functions inherited from StatefulPerTrackEffect
 ~StatefulPerTrackEffect () override
 
std::shared_ptr< EffectInstanceMakeInstance () const override
 Make an object maintaining short-term state of an Effect. More...
 
size_t SetBlockSize (size_t maxBlockSize) override
 
size_t GetBlockSize () const override
 
bool ProcessInitialize (EffectSettings &settings, double sampleRate, ChannelNames chanMap=nullptr) override
 
bool ProcessFinalize () noexcept override
 
virtual size_t ProcessBlock (EffectSettings &settings, const float *const *inBlock, float *const *outBlock, size_t blockLen)=0
 Called for destructive effect computation. More...
 
- Public Member Functions inherited from StatefulEffectBase
virtual bool Init ()
 
virtual bool Process (EffectInstance &instance, EffectSettings &settings)=0
 
virtual bool RealtimeInitialize (EffectSettings &settings, double sampleRate)
 
virtual bool RealtimeAddProcessor (EffectSettings &settings, EffectOutputs *pOutputs, unsigned numChannels, float sampleRate)
 
virtual bool RealtimeSuspend ()
 
virtual bool RealtimeResume ()
 
virtual bool RealtimeProcessStart (MessagePackage &package)
 settings are possibly changed, since last call, by an asynchronous dialog More...
 
virtual size_t RealtimeProcess (size_t group, EffectSettings &settings, const float *const *inBuf, float *const *outBuf, size_t numSamples)
 
virtual bool RealtimeProcessEnd (EffectSettings &settings) noexcept
 settings can be updated to let a dialog change appearance at idle More...
 
virtual bool RealtimeFinalize (EffectSettings &settings) noexcept
 
virtual size_t SetBlockSize (size_t maxBlockSize)
 
virtual size_t GetBlockSize () const
 
virtual unsigned GetAudioInCount () const
 How many input buffers to allocate at once. More...
 
virtual unsigned GetAudioOutCount () const
 How many output buffers to allocate at once. More...
 
virtual sampleCount GetLatency () const
 
virtual bool NeedsDither () const
 
virtual bool ProcessInitialize (EffectSettings &settings, double sampleRate, ChannelNames chanMap=nullptr)
 
virtual bool ProcessFinalize () noexcept
 
- Public Member Functions inherited from PerTrackEffect
 ~PerTrackEffect () override
 
- Public Member Functions inherited from Effect
 Effect ()
 
virtual ~Effect ()
 
PluginPath GetPath () const override
 
bool VisitSettings (SettingsVisitor &visitor, EffectSettings &settings) override
 
bool VisitSettings (ConstSettingsVisitor &visitor, const EffectSettings &settings) const override
 
ComponentInterfaceSymbol GetSymbol () const override
 
VendorSymbol GetVendor () const override
 
wxString GetVersion () const override
 
TranslatableString GetDescription () const override
 
EffectFamilySymbol GetFamily () const override
 Report identifier and user-visible name of the effect protocol. More...
 
bool IsInteractive () const override
 Whether the effect needs a dialog for entry of settings. More...
 
bool IsDefault () const override
 Whether the effect sorts "above the line" in the menus. More...
 
RealtimeSince RealtimeSupport () const override
 Since which version of Audacity has the effect supported realtime? More...
 
bool SupportsAutomation () const override
 Whether the effect has any automatable controls. More...
 
bool SaveSettings (const EffectSettings &settings, CommandParameters &parms) const override
 Store settings as keys and values. More...
 
bool LoadSettings (const CommandParameters &parms, EffectSettings &settings) const override
 Restore settings from keys and values. More...
 
OptionalMessage LoadUserPreset (const RegistryPath &name, EffectSettings &settings) const override
 
bool SaveUserPreset (const RegistryPath &name, const EffectSettings &settings) const override
 Save settings in the configuration file as a user-named preset. More...
 
RegistryPaths GetFactoryPresets () const override
 Report names of factory presets. More...
 
OptionalMessage LoadFactoryPreset (int id, EffectSettings &settings) const override
 
OptionalMessage LoadFactoryDefaults (EffectSettings &settings) const override
 
virtual const EffectParameterMethodsParameters () const
 
bool CanExportPresets () const override
 Whether the effect supports export of presets to files, and importing too. More...
 
bool HasOptions () const override
 
const EffectSettingsManagerGetDefinition () const override
 
virtual NumericFormatID GetSelectionFormat ()
 
bool SaveSettingsAsString (const EffectSettings &settings, wxString &parms) const override
 
OptionalMessage LoadSettingsFromString (const wxString &parms, EffectSettings &settings) const override
 
bool IsBatchProcessing () const override
 
void SetBatchProcessing () override
 
void UnsetBatchProcessing () override
 
unsigned TestUIFlags (unsigned mask)
 
bool Delegate (Effect &delegate, EffectSettings &settings, InstanceFinder finder={})
 Re-invoke DoEffect on another Effect object that implements the work. More...
 
- Public Member Functions inherited from EffectBase
 EffectBase ()
 
 ~EffectBase () override
 
bool IsLinearEffect () const
 
bool PreviewsFullSelection () const
 
void SetTracks (TrackList *pTracks)
 
virtual std::any BeginPreview (const EffectSettings &settings)
 Called when Preview() starts, to allow temporary effect state changes. More...
 
bool DoEffect (EffectSettings &settings, const InstanceFinder &finder, double projectRate, TrackList *list, WaveTrackFactory *factory, NotifyingSelectedRegion &selectedRegion, unsigned flags, const EffectSettingsAccessPtr &pAccess) override
 
virtual double CalcPreviewInputLength (const EffectSettings &settings, double previewLength) const =0
 
void CountWaveTracks ()
 
- Public Member Functions inherited from EffectPlugin
EffectPluginoperator= (EffectPlugin &)=delete
 
virtual ~EffectPlugin ()
 
virtual bool HasOptions () const =0
 
virtual bool CanExportPresets () const =0
 Whether the effect supports export of presets to files, and importing too. More...
 
virtual const EffectSettingsManagerGetDefinition () const =0
 
virtual bool SaveSettingsAsString (const EffectSettings &settings, wxString &parms) const =0
 
virtual OptionalMessage LoadSettingsFromString (const wxString &parms, EffectSettings &settings) const =0
 
virtual bool IsBatchProcessing () const =0
 
virtual void SetBatchProcessing ()=0
 
virtual void UnsetBatchProcessing ()=0
 
virtual bool DoEffect (EffectSettings &settings, const InstanceFinder &finder, double projectRate, TrackList *list, WaveTrackFactory *factory, NotifyingSelectedRegion &selectedRegion, unsigned flags, const EffectSettingsAccessPtr &pAccess=nullptr)=0
 
- Public Member Functions inherited from EffectInstanceFactory
virtual ~EffectInstanceFactory ()
 
virtual std::shared_ptr< EffectInstanceMakeInstance () const =0
 Make an object maintaining short-term state of an Effect. More...
 
- Public Member Functions inherited from EffectSettingsManager
virtual ~EffectSettingsManager ()
 
virtual bool VisitSettings (SettingsVisitor &visitor, EffectSettings &settings)
 
virtual bool VisitSettings (ConstSettingsVisitor &visitor, const EffectSettings &settings) const
 
virtual EffectSettings MakeSettings () const
 
virtual bool CopySettingsContents (const EffectSettings &src, EffectSettings &dst) const
 Update one settings object from another. More...
 
virtual std::unique_ptr< EffectOutputsMakeOutputs () const
 Produce an object to hold values to send to effect output meters. More...
 
- Public Member Functions inherited from EffectDefinitionInterface
virtual ~EffectDefinitionInterface ()
 
virtual EffectType GetType () const =0
 Type determines how it behaves. More...
 
virtual EffectType GetClassification () const
 Determines which menu it appears in; default same as GetType(). More...
 
virtual EffectFamilySymbol GetFamily () const =0
 Report identifier and user-visible name of the effect protocol. More...
 
virtual bool IsInteractive () const =0
 Whether the effect needs a dialog for entry of settings. More...
 
virtual bool IsDefault () const =0
 Whether the effect sorts "above the line" in the menus. More...
 
virtual RealtimeSince RealtimeSupport () const =0
 Since which version of Audacity has the effect supported realtime? More...
 
bool SupportsRealtime () const
 
virtual bool SupportsAutomation () const =0
 Whether the effect has any automatable controls. More...
 
virtual bool EnablesDebug () const
 Whether the effect dialog should have a Debug button; default, always false. More...
 
virtual ManualPageID ManualPage () const
 Name of a page in the Audacity alpha manual, default is empty. More...
 
virtual FilePath HelpPage () const
 Fully qualified local help file name, default is empty. More...
 
virtual bool IsHiddenFromMenus () const
 Default is false. More...
 
- Public Member Functions inherited from ComponentInterface
virtual ~ComponentInterface ()
 
virtual PluginPath GetPath () const =0
 
virtual ComponentInterfaceSymbol GetSymbol () const =0
 
virtual VendorSymbol GetVendor () const =0
 
virtual wxString GetVersion () const =0
 
virtual TranslatableString GetDescription () const =0
 
TranslatableString GetName () const
 
- Public Member Functions inherited from StatefulEffectUIServices
 ~StatefulEffectUIServices () override
 
std::unique_ptr< EffectEditorPopulateUI (const EffectPlugin &plugin, ShuttleGui &S, EffectInstance &instance, EffectSettingsAccess &access, const EffectOutputs *pOutputs) const override
 Allows PopulateOrExchange to return null. More...
 
virtual std::unique_ptr< EffectEditorPopulateOrExchange (ShuttleGui &S, EffectInstance &instance, EffectSettingsAccess &access, const EffectOutputs *pOutputs)
 Add controls to effect panel; always succeeds. More...
 
virtual bool TransferDataToWindow (const EffectSettings &settings)
 
virtual bool TransferDataFromWindow (EffectSettings &settings)
 
- Public Member Functions inherited from BasicEffectUIServices
int ShowClientInterface (const EffectPlugin &plugin, wxWindow &parent, wxDialog &dialog, EffectEditor *pEditor, bool forceModal) const override
 
void ExportPresets (const EffectPlugin &plugin, const EffectSettings &settings) const override
 
OptionalMessage ImportPresets (const EffectPlugin &plugin, EffectSettings &settings) const override
 
void ShowOptions (const EffectPlugin &plugin) const override
 
bool ValidateUI (const EffectPlugin &context, EffectSettings &) const override
 
bool CloseUI () const override
 
- Public Member Functions inherited from EffectUIServices
virtual ~EffectUIServices ()
 
virtual int ShowHostInterface (EffectBase &plugin, wxWindow &parent, const EffectDialogFactory &factory, std::shared_ptr< EffectInstance > &pInstance, EffectSettingsAccess &access, bool forceModal=false)
 
virtual int ShowClientInterface (const EffectPlugin &plugin, wxWindow &parent, wxDialog &dialog, EffectEditor *pEditor, bool forceModal=false) const =0
 
virtual std::unique_ptr< EffectEditorPopulateUI (const EffectPlugin &plugin, ShuttleGui &S, EffectInstance &instance, EffectSettingsAccess &access, const EffectOutputs *pOutputs) const =0
 Adds controls to a panel that is given as the parent window of S More...
 
virtual void ExportPresets (const EffectPlugin &plugin, const EffectSettings &settings) const =0
 
virtual OptionalMessage ImportPresets (const EffectPlugin &plugin, EffectSettings &settings) const =0
 
virtual void ShowOptions (const EffectPlugin &plugin) const =0
 
virtual bool ValidateUI (const EffectPlugin &context, EffectSettings &settings) const =0
 
virtual bool CloseUI () const =0
 

Static Public Member Functions

static EffectScienFilterFetchParameters (EffectScienFilter &e, EffectSettings &)
 
- Static Public Member Functions inherited from Effect
static EffectFetchParameters (Effect &e, EffectSettings &)
 
- Static Public Member Functions inherited from EffectBase
static std::optional< InstancePointerFindInstance (EffectPlugin &plugin)
 
static InstanceFinder DefaultInstanceFinder (EffectPlugin &plugin)
 
- Static Public Member Functions inherited from EffectDefinitionInterface
static Identifier GetSquashedName (const Identifier &ident)
 A utility that strips spaces and CamelCases a name. More...
 
- Static Public Member Functions inherited from EffectUIServices
static int DoMessageBox (const EffectPlugin &plugin, const TranslatableString &message, long style=DefaultMessageBoxStyle, const TranslatableString &titleStr={})
 

Static Public Attributes

static const ComponentInterfaceSymbol Symbol { XO("Classic Filters") }
 
- Static Public Attributes inherited from EffectPlugin
static const wxString kUserPresetIdent = wxT("User Preset:")
 
static const wxString kFactoryPresetIdent = wxT("Factory Preset:")
 
static const wxString kCurrentSettingsIdent = wxT("<Current Settings>")
 
static const wxString kFactoryDefaultsIdent = wxT("<Factory Defaults>")
 

Private Types

enum  kSubTypes { kLowPass = Biquad::kLowPass , kHighPass = Biquad::kHighPass , nSubTypes = Biquad::nSubTypes }
 
enum  kTypes { kButterworth , kChebyshevTypeI , kChebyshevTypeII , nTypes }
 

Private Member Functions

bool TransferGraphLimitsFromWindow ()
 
void CalcFilter ()
 
float FilterMagnAtFreq (float Freq)
 
void EnableDisableRippleCtl (int FilterType)
 
void OnSize (wxSizeEvent &evt)
 
void OnSlider (wxCommandEvent &evt)
 
void OnOrder (wxCommandEvent &evt)
 
void OnCutoff (wxCommandEvent &evt)
 
void OnRipple (wxCommandEvent &evt)
 
void OnStopbandRipple (wxCommandEvent &evt)
 
void OnFilterType (wxCommandEvent &evt)
 
void OnFilterSubtype (wxCommandEvent &evt)
 
void OnSliderDBMAX (wxCommandEvent &evt)
 
void OnSliderDBMIN (wxCommandEvent &evt)
 
const EffectParameterMethodsParameters () const override
 

Private Attributes

wxWeakRef< wxWindow > mUIParent {}
 
float mCutoff
 
float mRipple
 
float mStopbandRipple
 
int mFilterType
 
int mFilterSubtype
 
int mOrder
 
int mOrderIndex
 
ArrayOf< BiquadmpBiquad
 
double mdBMax
 
double mdBMin
 
bool mEditingBatchParams
 
double mLoFreq
 
double mNyquist
 
EffectScienFilterPanelmPanel
 
wxSlider * mdBMinSlider
 
wxSlider * mdBMaxSlider
 
wxStaticText * mRippleCtlP
 
wxTextCtrl * mRippleCtl
 
wxStaticText * mRippleCtlU
 
wxTextCtrl * mCutoffCtl
 
wxStaticText * mStopbandRippleCtlP
 
wxTextCtrl * mStopbandRippleCtl
 
wxStaticText * mStopbandRippleCtlU
 
wxChoice * mFilterTypeCtl
 
wxChoice * mFilterSubTypeCtl
 
wxChoice * mFilterOrderCtl
 
RulerPanelmdBRuler
 
RulerPanelmfreqRuler
 

Static Private Attributes

static const EnumValueSymbol kSubTypeStrings [nSubTypes]
 
static const EnumValueSymbol kTypeStrings [nTypes]
 
static constexpr EnumParameter Type
 
static constexpr EnumParameter Subtype
 
static constexpr EffectParameter Order
 
static constexpr EffectParameter Cutoff
 
static constexpr EffectParameter Passband
 
static constexpr EffectParameter Stopband
 

Friends

class EffectScienFilterPanel
 

Additional Inherited Members

- Public Types inherited from StatefulEffectBase
using MessagePackage = EffectInstance::MessagePackage
 
- Public Types inherited from EffectPlugin
using EffectSettingsAccessPtr = std::shared_ptr< EffectSettingsAccess >
 
using InstancePointer = std::shared_ptr< EffectInstanceEx >
 
using InstanceFinder = std::function< std::optional< InstancePointer >(EffectSettings &settings) >
 
- Public Types inherited from EffectDefinitionInterface
enum class  RealtimeSince : unsigned { Never , After_3_1 , Always }
 In which versions of Audacity was an effect realtime capable? More...
 
- Public Types inherited from EffectUIServices
enum  : long { DefaultMessageBoxStyle = wxOK | wxCENTRE }
 
- Public Attributes inherited from EffectBase
std::shared_ptr< TrackListmTracks {}
 
int mNumTracks {}
 
BasicUI::ProgressDialogmProgress {}
 
double mProjectRate {}
 
WaveTrackFactorymFactory {}
 
double mT0 {}
 
double mT1 {}
 
bool mIsPreview { false }
 
- Protected Member Functions inherited from PerTrackEffect
bool DoPass1 () const
 
bool DoPass2 () const
 
bool Process (EffectInstance &instance, EffectSettings &settings) const
 
std::shared_ptr< EffectOutputTracksMakeOutputTracks ()
 
void DestroyOutputTracks () const
 
- Protected Member Functions inherited from Effect
bool CheckWhetherSkipEffect (const EffectSettings &settings) const override
 Default implementation returns false. More...
 
double CalcPreviewInputLength (const EffectSettings &settings, double previewLength) const override
 Default implementation returns previewLength More...
 
bool TotalProgress (double frac, const TranslatableString &={}) const
 
bool TrackProgress (int whichTrack, double frac, const TranslatableString &={}) const
 
bool TrackGroupProgress (int whichGroup, double frac, const TranslatableString &={}) const
 
int GetNumWaveTracks () const
 
int GetNumWaveGroups () const
 
void GetBounds (const WaveTrack &track, sampleCount *start, sampleCount *len)
 
- Protected Member Functions inherited from EffectBase
virtual bool CheckWhetherSkipEffect (const EffectSettings &settings) const =0
 After Init(), tell whether Process() should be skipped. More...
 
void SetLinearEffectFlag (bool linearEffectFlag)
 
void SetPreviewFullSelectionFlag (bool previewDurationFlag)
 
bool IsPreviewing () const
 
const TrackListinputTracks () const
 
const AudacityProjectFindProject () const
 
- Protected Attributes inherited from PerTrackEffect
sampleCount mSampleCnt {}
 
- Protected Attributes inherited from EffectBase
double mF0 {}
 
double mF1 {}
 
wxArrayString mPresetNames
 
unsigned mUIFlags { 0 }
 

Detailed Description

An Effect that applies 'classical' IIR filters.

Performs IIR filtering that emulates analog filters, specifically Butterworth, Chebyshev Type I and Type II. Highpass and lowpass filters are supported, as are filter orders from 1 to 10.

The filter is applied using biquads

Definition at line 35 of file ScienFilter.h.

Member Enumeration Documentation

◆ kSubTypes

Enumerator
kLowPass 
kHighPass 
nSubTypes 

Definition at line 137 of file ScienFilter.h.

◆ kTypes

Enumerator
kButterworth 
kChebyshevTypeI 
kChebyshevTypeII 
nTypes 

Definition at line 145 of file ScienFilter.h.

Constructor & Destructor Documentation

◆ EffectScienFilter()

EffectScienFilter::EffectScienFilter ( )

Definition at line 144 of file ScienFilter.cpp.

145{
146 Parameters().Reset(*this);
148
149 mOrderIndex = mOrder - 1;
150
151 mdBMin = -30.0;
152 mdBMax = 30.0;
153
154 mLoFreq = 20; // Lowest frequency to display in response graph
155 mNyquist = 44100.0 / 2.0; // only used during initialization, updated when effect is used
156}
void SetLinearEffectFlag(bool linearEffectFlag)
Definition: EffectBase.cpp:210
virtual void Reset(Effect &effect) const =0
const EffectParameterMethods & Parameters() const override

Referenced by Parameters().

Here is the caller graph for this function:

◆ ~EffectScienFilter()

EffectScienFilter::~EffectScienFilter ( )
virtual

Definition at line 158 of file ScienFilter.cpp.

159{
160}

Member Function Documentation

◆ CalcFilter()

void EffectScienFilter::CalcFilter ( )
private

Definition at line 515 of file ScienFilter.cpp.

516{
517 switch (mFilterType)
518 {
519 case kButterworth:
521 break;
522 case kChebyshevTypeI:
524 break;
525 case kChebyshevTypeII:
527 break;
528 }
529}
ArrayOf< Biquad > mpBiquad
Definition: ScienFilter.h:102
static ArrayOf< Biquad > CalcButterworthFilter(int order, double fn, double fc, int type)
Definition: Biquad.cpp:64
static ArrayOf< Biquad > CalcChebyshevType2Filter(int order, double fn, double fc, double ripple, int type)
Definition: Biquad.cpp:228
static ArrayOf< Biquad > CalcChebyshevType1Filter(int order, double fn, double fc, double ripple, int type)
Definition: Biquad.cpp:146

References Biquad::CalcButterworthFilter(), Biquad::CalcChebyshevType1Filter(), Biquad::CalcChebyshevType2Filter(), kButterworth, kChebyshevTypeI, kChebyshevTypeII, mCutoff, mFilterSubtype, mFilterType, mNyquist, mOrder, mpBiquad, mRipple, and mStopbandRipple.

Referenced by TransferDataFromWindow().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ EnableDisableRippleCtl()

void EffectScienFilter::EnableDisableRippleCtl ( int  FilterType)
private

Definition at line 672 of file ScienFilter.cpp.

673{
674 bool ripple;
675 bool stop;
676
677 if (FilterType == kButterworth) // Butterworth
678 {
679 ripple = false;
680 stop = false;
681 }
682 else if (FilterType == kChebyshevTypeI) // Chebyshev Type1
683 {
684 ripple = true;
685 stop = false;
686 }
687 else // Chebyshev Type2
688 {
689 ripple = false;
690 stop = true;
691 }
692
693 mRippleCtlP->Enable(ripple);
694 mRippleCtl->Enable(ripple);
695 mRippleCtlU->Enable(ripple);
696 mStopbandRippleCtlP->Enable(stop);
697 mStopbandRippleCtl->Enable(stop);
698 mStopbandRippleCtlU->Enable(stop);
699}
wxStaticText * mRippleCtlU
Definition: ScienFilter.h:117
wxTextCtrl * mRippleCtl
Definition: ScienFilter.h:116
wxStaticText * mStopbandRippleCtlP
Definition: ScienFilter.h:121
wxTextCtrl * mStopbandRippleCtl
Definition: ScienFilter.h:122
wxStaticText * mRippleCtlP
Definition: ScienFilter.h:115
wxStaticText * mStopbandRippleCtlU
Definition: ScienFilter.h:123

References kButterworth, kChebyshevTypeI, mRippleCtl, mRippleCtlP, mRippleCtlU, mStopbandRippleCtl, mStopbandRippleCtlP, and mStopbandRippleCtlU.

Referenced by OnFilterType(), and TransferDataToWindow().

Here is the caller graph for this function:

◆ FetchParameters()

static EffectScienFilter * EffectScienFilter::FetchParameters ( EffectScienFilter e,
EffectSettings  
)
inlinestatic

Definition at line 39 of file ScienFilter.h.

39{ return &e; }

◆ FilterMagnAtFreq()

float EffectScienFilter::FilterMagnAtFreq ( float  Freq)
private

Definition at line 531 of file ScienFilter.cpp.

532{
533 float Magn;
534 if (Freq >= mNyquist)
535 Freq = mNyquist - 1; // prevent tan(PI/2)
536 float FreqWarped = tan (PI * Freq/(2*mNyquist));
537 if (mCutoff >= mNyquist)
538 mCutoff = mNyquist - 1;
539 float CutoffWarped = tan (PI * mCutoff/(2*mNyquist));
540 float fOverflowThresh = pow (10.0, 12.0 / (2*mOrder)); // once we exceed 10^12 there's not much to be gained and overflow could happen
541
542 switch (mFilterType)
543 {
544 case kButterworth: // Butterworth
545 default:
546 switch (mFilterSubtype)
547 {
548 case kLowPass: // lowpass
549 default:
550 if (FreqWarped/CutoffWarped > fOverflowThresh) // prevent pow() overflow
551 Magn = 0;
552 else
553 Magn = sqrt (1 / (1 + pow (FreqWarped/CutoffWarped, 2*mOrder)));
554 break;
555 case kHighPass: // highpass
556 if (FreqWarped/CutoffWarped > fOverflowThresh)
557 Magn = 1;
558 else
559 Magn = sqrt (pow (FreqWarped/CutoffWarped, 2*mOrder) / (1 + pow (FreqWarped/CutoffWarped, 2*mOrder)));
560 break;
561 }
562 break;
563
564 case kChebyshevTypeI: // Chebyshev Type 1
565 double eps; eps = sqrt(pow (10.0, wxMax(0.001, mRipple)/10.0) - 1);
566 double chebyPolyVal;
567 switch (mFilterSubtype)
568 {
569 case 0: // lowpass
570 default:
571 chebyPolyVal = Biquad::ChebyPoly(mOrder, FreqWarped/CutoffWarped);
572 Magn = sqrt (1 / (1 + square(eps) * square(chebyPolyVal)));
573 break;
574 case 1:
575 chebyPolyVal = Biquad::ChebyPoly(mOrder, CutoffWarped/FreqWarped);
576 Magn = sqrt (1 / (1 + square(eps) * square(chebyPolyVal)));
577 break;
578 }
579 break;
580
581 case kChebyshevTypeII: // Chebyshev Type 2
582 eps = 1 / sqrt(pow (10.0, wxMax(0.001, mStopbandRipple)/10.0) - 1);
583 switch (mFilterSubtype)
584 {
585 case kLowPass: // lowpass
586 default:
587 chebyPolyVal = Biquad::ChebyPoly(mOrder, CutoffWarped/FreqWarped);
588 Magn = sqrt (1 / (1 + 1 / (square(eps) * square(chebyPolyVal))));
589 break;
590 case kHighPass:
591 chebyPolyVal = Biquad::ChebyPoly(mOrder, FreqWarped/CutoffWarped);
592 Magn = sqrt (1 / (1 + 1 / (square(eps) * square(chebyPolyVal))));
593 break;
594 }
595 break;
596 }
597
598 return Magn;
599}
#define square(a)
Definition: ScienFilter.cpp:72
#define PI
Definition: ScienFilter.cpp:68
__finl float_x4 __vecc sqrt(const float_x4 &a)
static double ChebyPoly(int Order, double NormFreq)
Definition: Biquad.cpp:329

References Biquad::ChebyPoly(), kButterworth, kChebyshevTypeI, kChebyshevTypeII, kHighPass, kLowPass, mCutoff, mFilterSubtype, mFilterType, mNyquist, mOrder, mRipple, mStopbandRipple, PI, staffpad::audio::simd::sqrt(), and square.

Referenced by EffectScienFilterPanel::OnPaint().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetAudioInCount()

unsigned EffectScienFilter::GetAudioInCount ( ) const
overridevirtual

How many input buffers to allocate at once.

If the instance processes channels independently, this can return 1 The result is not necessarily well defined before RealtimeInitialize Default implementation returns 0

Reimplemented from StatefulEffectBase.

Definition at line 188 of file ScienFilter.cpp.

189{
190 return 1;
191}

◆ GetAudioOutCount()

unsigned EffectScienFilter::GetAudioOutCount ( ) const
overridevirtual

How many output buffers to allocate at once.

The result is not necessarily well defined before RealtimeInitialize Default implementation returns 0

Reimplemented from StatefulEffectBase.

Definition at line 193 of file ScienFilter.cpp.

194{
195 return 1;
196}

◆ GetDescription()

TranslatableString EffectScienFilter::GetDescription ( ) const
overridevirtual

Implements ComponentInterface.

Definition at line 169 of file ScienFilter.cpp.

170{
171 /* i18n-hint: "infinite impulse response" */
172 return XO("Performs IIR filtering that emulates analog filters");
173}
XO("Cut/Copy/Paste")

References XO().

Here is the call graph for this function:

◆ GetSymbol()

ComponentInterfaceSymbol EffectScienFilter::GetSymbol ( ) const
overridevirtual

Implements ComponentInterface.

Definition at line 164 of file ScienFilter.cpp.

165{
166 return Symbol;
167}
static const ComponentInterfaceSymbol Symbol
Definition: ScienFilter.h:40

References Symbol.

◆ GetType()

EffectType EffectScienFilter::GetType ( ) const
overridevirtual

Type determines how it behaves.

Implements EffectDefinitionInterface.

Definition at line 183 of file ScienFilter.cpp.

184{
185 return EffectTypeProcess;
186}
@ EffectTypeProcess

References EffectTypeProcess.

◆ Init()

bool EffectScienFilter::Init ( )
overridevirtual

Default implementation does nothing, returns true

Reimplemented from StatefulEffectBase.

Definition at line 221 of file ScienFilter.cpp.

222{
223 int selcount = 0;
224 double rate = 0.0;
225
226 auto trackRange = inputTracks()->Selected<const WaveTrack>();
227
228 {
229 auto t = *trackRange.begin();
230 mNyquist =
231 (t
232 ? t->GetRate()
233 : mProjectRate)
234 / 2.0;
235 }
236
237 for (auto t : trackRange) {
238 if (selcount == 0)
239 rate = t->GetRate();
240 else {
241 if (t->GetRate() != rate) {
243 XO(
244"To apply a filter, all selected tracks must have the same sample rate.") );
245 return false;
246 }
247 }
248 ++selcount;
249 }
250
251 return true;
252}
const TrackList * inputTracks() const
Definition: EffectBase.h:91
double mProjectRate
Definition: EffectBase.h:110
static int DoMessageBox(const EffectPlugin &plugin, const TranslatableString &message, long style=DefaultMessageBoxStyle, const TranslatableString &titleStr={})
auto Selected() -> TrackIterRange< TrackType >
Definition: Track.h:967
A Track that contains audio waveform data.
Definition: WaveTrack.h:203

References EffectUIServices::DoMessageBox(), EffectBase::inputTracks(), mNyquist, EffectBase::mProjectRate, TrackList::Selected(), and XO().

Here is the call graph for this function:

◆ ManualPage()

ManualPageID EffectScienFilter::ManualPage ( ) const
overridevirtual

Name of a page in the Audacity alpha manual, default is empty.

Reimplemented from EffectDefinitionInterface.

Definition at line 175 of file ScienFilter.cpp.

176{
177 return L"Classic_Filters";
178}

◆ OnCutoff()

void EffectScienFilter::OnCutoff ( wxCommandEvent &  evt)
private

Definition at line 621 of file ScienFilter.cpp.

622{
624 mUIParent, mUIParent->TransferDataFromWindow()))
625 {
626 return;
627 }
628
629 mPanel->Refresh(false);
630}
static bool EnableApply(wxWindow *parent, bool enable=true)
Enable or disable the Apply button of the dialog that contains parent.
EffectScienFilterPanel * mPanel
Definition: ScienFilter.h:111
wxWeakRef< wxWindow > mUIParent
Definition: ScienFilter.h:93

References EffectEditor::EnableApply(), mPanel, and mUIParent.

Here is the call graph for this function:

◆ OnFilterSubtype()

void EffectScienFilter::OnFilterSubtype ( wxCommandEvent &  evt)
private

Definition at line 615 of file ScienFilter.cpp.

616{
617 mFilterSubtype = mFilterSubTypeCtl->GetSelection();
618 mPanel->Refresh(false);
619}
wxChoice * mFilterSubTypeCtl
Definition: ScienFilter.h:126

References mFilterSubtype, mFilterSubTypeCtl, and mPanel.

◆ OnFilterType()

void EffectScienFilter::OnFilterType ( wxCommandEvent &  evt)
private

Definition at line 608 of file ScienFilter.cpp.

609{
610 mFilterType = mFilterTypeCtl->GetSelection();
612 mPanel->Refresh(false);
613}
void EnableDisableRippleCtl(int FilterType)
wxChoice * mFilterTypeCtl
Definition: ScienFilter.h:125

References EnableDisableRippleCtl(), mFilterType, mFilterTypeCtl, and mPanel.

Here is the call graph for this function:

◆ OnOrder()

void EffectScienFilter::OnOrder ( wxCommandEvent &  evt)
private

Definition at line 601 of file ScienFilter.cpp.

602{
603 mOrderIndex = mFilterOrderCtl->GetSelection();
604 mOrder = mOrderIndex + 1; // 0..n-1 -> 1..n
605 mPanel->Refresh(false);
606}
wxChoice * mFilterOrderCtl
Definition: ScienFilter.h:127

References mFilterOrderCtl, mOrder, mOrderIndex, and mPanel.

◆ OnRipple()

void EffectScienFilter::OnRipple ( wxCommandEvent &  evt)
private

Definition at line 632 of file ScienFilter.cpp.

633{
635 mUIParent, mUIParent->TransferDataFromWindow()))
636 {
637 return;
638 }
639
640 mPanel->Refresh(false);
641}

References EffectEditor::EnableApply(), mPanel, and mUIParent.

Here is the call graph for this function:

◆ OnSize()

void EffectScienFilter::OnSize ( wxSizeEvent &  evt)
private

Definition at line 664 of file ScienFilter.cpp.

665{
666 // On Windows the Passband and Stopband boxes do not refresh properly
667 // on a resize...no idea why.
668 mUIParent->Refresh();
669 evt.Skip();
670}

References mUIParent.

◆ OnSlider()

void EffectScienFilter::OnSlider ( wxCommandEvent &  evt)
private

◆ OnSliderDBMAX()

void EffectScienFilter::OnSliderDBMAX ( wxCommandEvent &  evt)
private

Definition at line 659 of file ScienFilter.cpp.

660{
662}
bool TransferGraphLimitsFromWindow()

References TransferGraphLimitsFromWindow().

Here is the call graph for this function:

◆ OnSliderDBMIN()

void EffectScienFilter::OnSliderDBMIN ( wxCommandEvent &  evt)
private

Definition at line 654 of file ScienFilter.cpp.

References TransferGraphLimitsFromWindow().

Here is the call graph for this function:

◆ OnStopbandRipple()

void EffectScienFilter::OnStopbandRipple ( wxCommandEvent &  evt)
private

Definition at line 643 of file ScienFilter.cpp.

644{
646 mUIParent, mUIParent->TransferDataFromWindow()))
647 {
648 return;
649 }
650
651 mPanel->Refresh(false);
652}

References EffectEditor::EnableApply(), mPanel, and mUIParent.

Here is the call graph for this function:

◆ Parameters()

const EffectParameterMethods & EffectScienFilter::Parameters ( ) const
overrideprivatevirtual

Reimplemented from Effect.

Definition at line 104 of file ScienFilter.cpp.

105{
108 > parameters{
110 bool updating){
111 if (updating) {
112 e.mOrderIndex = e.mOrder - 1;
113 e.CalcFilter();
114 }
115 return true;
116 },
117 };
118 return parameters;
119}
Generates EffectParameterMethods overrides from variadic template arguments.
An Effect that applies 'classical' IIR filters.
Definition: ScienFilter.h:36
static constexpr EffectParameter Stopband
Definition: ScienFilter.h:166
static constexpr EffectParameter Cutoff
Definition: ScienFilter.h:162
static constexpr EnumParameter Subtype
Definition: ScienFilter.h:158
static constexpr EnumParameter Type
Definition: ScienFilter.h:156
static constexpr EffectParameter Passband
Definition: ScienFilter.h:164
static constexpr EffectParameter Order
Definition: ScienFilter.h:160
Externalized state of a plug-in.

References Cutoff, EffectScienFilter(), Order, Passband, Stopband, Subtype, and Type.

Here is the call graph for this function:

◆ PopulateOrExchange()

std::unique_ptr< EffectEditor > EffectScienFilter::PopulateOrExchange ( ShuttleGui S,
EffectInstance instance,
EffectSettingsAccess access,
const EffectOutputs pOutputs 
)
overridevirtual

Add controls to effect panel; always succeeds.

Returns
if not null, then return it from PopulateUI instead of a DefaultEffectEditor; default implementation returns null

Reimplemented from StatefulEffectUIServices.

Definition at line 254 of file ScienFilter.cpp.

257{
258 mUIParent = S.GetParent();
259 S.AddSpace(5);
260 S.SetSizerProportion(1);
261 S.StartMultiColumn(3, wxEXPAND);
262 {
263 S.SetStretchyCol(1);
264 S.SetStretchyRow(0);
265
266 // -------------------------------------------------------------------
267 // ROW 1: Freq response panel and sliders for vertical scale
268 // -------------------------------------------------------------------
269
270 S.StartVerticalLay();
271 {
273 S.GetParent(), wxID_ANY, wxVERTICAL,
274 wxSize{ 100, 100 }, // Ruler can't handle small sizes
275 RulerPanel::Range{ 30.0, -120.0 },
277 XO("dB"),
279 .LabelEdges(true)
280 );
281
282 S.SetBorder(1);
283 S.AddSpace(1, 1);
284 S.Prop(1)
285 .Position(wxALIGN_RIGHT | wxTOP)
286 .AddWindow(mdBRuler);
287 S.AddSpace(1, 1);
288 }
289 S.EndVerticalLay();
290
292 S.GetParent(), wxID_ANY,
293 this, mLoFreq, mNyquist
294 );
295
296 S.SetBorder(5);
297 S.Prop(1)
298 .Position(wxEXPAND | wxRIGHT)
299 .MinSize( { -1, -1 } )
300 .AddWindow(mPanel);
301
302 S.StartVerticalLay();
303 {
304 S.AddVariableText(XO("+ dB"), false, wxCENTER);
306 .Name(XO("Max dB"))
307 .Style(wxSL_VERTICAL | wxSL_INVERSE)
308 .AddSlider( {}, 10, 20, 0);
309#if wxUSE_ACCESSIBILITY
310 mdBMaxSlider->SetAccessible(safenew SliderAx(mdBMaxSlider, XO("%d dB")));
311#endif
313 .Name(XO("Min dB"))
314 .Style(wxSL_VERTICAL | wxSL_INVERSE)
315 .AddSlider( {}, -10, -10, -120);
316#if wxUSE_ACCESSIBILITY
317 mdBMinSlider->SetAccessible(safenew SliderAx(mdBMinSlider, XO("%d dB")));
318#endif
319
320 S.AddVariableText(XO("- dB"), false, wxCENTER);
321 }
322 S.EndVerticalLay();
323
324 // -------------------------------------------------------------------
325 // ROW 2: Frequency ruler
326 // -------------------------------------------------------------------
327
328 S.AddSpace(1, 1);
329
331 S.GetParent(), wxID_ANY, wxHORIZONTAL,
332 wxSize{ 100, 100 }, // Ruler can't handle small sizes
333 RulerPanel::Range{ mLoFreq, mNyquist },
335 {},
337 .Log(true)
338 .Flip(true)
339 .LabelEdges(true)
340 );
341
342 S.Prop(1)
343 .Position(wxEXPAND | wxALIGN_LEFT | wxRIGHT)
344 .AddWindow(mfreqRuler);
345
346 S.AddSpace(1, 1);
347
348 // -------------------------------------------------------------------
349 // ROW 3 and 4: Type, Order, Ripple, Subtype, Cutoff
350 // -------------------------------------------------------------------
351
352 S.AddSpace(1, 1);
353 S.SetSizerProportion(0);
354 S.StartMultiColumn(8, wxALIGN_CENTER);
355 {
356 wxASSERT(nTypes == WXSIZEOF(kTypeStrings));
357
359 .Focus()
360 .Validator<wxGenericValidator>(&mFilterType)
361 .MinSize( { -1, -1 } )
362 .AddChoice(XXO("&Filter Type:"),
364 );
365
367 .Validator<wxGenericValidator>(&mOrderIndex)
368 .MinSize( { -1, -1 } )
369 /*i18n-hint: 'Order' means the complexity of the filter, and is a number between 1 and 10.*/
370 .AddChoice(XXO("O&rder:"),
371 []{
372 TranslatableStrings orders;
373 for (int i = 1; i <= 10; i++)
374 orders.emplace_back( Verbatim("%d").Format( i ) );
375 return orders;
376 }()
377 );
378 S.AddSpace(1, 1);
379
380 mRippleCtlP = S.AddVariableText( XO("&Passband Ripple:"),
381 false, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);
383 .Name(XO("Passband Ripple (dB)"))
384 .Validator<FloatingPointValidator<float>>(
385 1, &mRipple, NumValidatorStyle::DEFAULT,
387 .AddTextBox( {}, L"", 10);
388 mRippleCtlU = S.AddVariableText(XO("dB"),
389 false, wxALL | wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);
390
392 .Validator<wxGenericValidator>(&mFilterSubtype)
393 .MinSize( { -1, -1 } )
394 .AddChoice(XXO("&Subtype:"),
396 );
397
399 .Name(XO("Cutoff (Hz)"))
400 .Validator<FloatingPointValidator<float>>(
401 1, &mCutoff, NumValidatorStyle::DEFAULT,
402 Cutoff.min, mNyquist - 1)
403 .AddTextBox(XXO("C&utoff:"), L"", 10);
404 S.AddUnits(XO("Hz"));
405
407 S.AddVariableText(XO("Minimum S&topband Attenuation:"),
408 false, wxALL | wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);
410 .Name(XO("Minimum S&topband Attenuation (dB)"))
411 .Validator<FloatingPointValidator<float>>(
412 1, &mStopbandRipple, NumValidatorStyle::DEFAULT,
414 .AddTextBox( {}, L"", 10);
416 S.AddVariableText(XO("dB"),
417 false, wxALL | wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);
418 }
419 S.EndMultiColumn();
420 S.AddSpace(1, 1);
421 }
422 S.EndMultiColumn();
423
424 return nullptr;
425}
XXO("&Cut/Copy/Paste Toolbar")
#define safenew
Definition: MemoryX.h:9
@ ID_Cutoff
Definition: ScienFilter.cpp:83
@ ID_SubType
Definition: ScienFilter.cpp:80
@ ID_dBMax
Definition: ScienFilter.cpp:77
@ ID_Ripple
Definition: ScienFilter.cpp:82
@ ID_StopbandRipple
Definition: ScienFilter.cpp:84
@ ID_Order
Definition: ScienFilter.cpp:81
@ ID_Type
Definition: ScienFilter.cpp:79
@ ID_dBMin
Definition: ScienFilter.cpp:78
TranslatableStrings Msgids(const EnumValueSymbol strings[], size_t nStrings)
Convenience function often useful when adding choice controls.
#define S(N)
Definition: ToChars.cpp:64
TranslatableString Verbatim(wxString str)
Require calls to the one-argument constructor to go through this distinct global function name.
std::vector< TranslatableString > TranslatableStrings
static const EnumValueSymbol kSubTypeStrings[nSubTypes]
Definition: ScienFilter.h:143
friend class EffectScienFilterPanel
Definition: ScienFilter.h:135
static const EnumValueSymbol kTypeStrings[nTypes]
Definition: ScienFilter.h:152
wxTextCtrl * mCutoffCtl
Definition: ScienFilter.h:119
wxSlider * mdBMaxSlider
Definition: ScienFilter.h:113
RulerPanel * mdBRuler
Definition: ScienFilter.h:129
RulerPanel * mfreqRuler
Definition: ScienFilter.h:130
wxSlider * mdBMinSlider
Definition: ScienFilter.h:112
static const IntFormat & Instance()
Definition: IntFormat.cpp:14
static const LinearDBFormat & Instance()
RulerPanel class allows you to work with a Ruler like any other wxWindow.
Definition: RulerPanel.h:19
std::pair< double, double > Range
Definition: RulerPanel.h:23
TranslatableString & Format(Args &&...args) &
Capture variadic format arguments (by copy) when there is no plural.
A Validator is an object which checks whether a wxVariant satisfies a certain criterion....
Definition: Validators.h:54
const Type min
Minimum value.
const Type max
Maximum value.
Options & LabelEdges(bool l)
Definition: RulerPanel.h:41
Options & Flip(bool f)
Definition: RulerPanel.h:38
Options & Log(bool l)
Definition: RulerPanel.h:35

References Cutoff, EffectScienFilterPanel, RulerPanel::Options::Flip(), TranslatableString::Format(), ID_Cutoff, ID_dBMax, ID_dBMin, ID_Order, ID_Ripple, ID_StopbandRipple, ID_SubType, ID_Type, IntFormat::Instance(), LinearDBFormat::Instance(), kSubTypeStrings, kTypeStrings, RulerPanel::Options::LabelEdges(), RulerPanel::Options::Log(), EffectParameter< Structure, Member, Type, Value >::max, mCutoff, mCutoffCtl, mdBMaxSlider, mdBMinSlider, mdBRuler, mFilterOrderCtl, mFilterSubtype, mFilterSubTypeCtl, mFilterType, mFilterTypeCtl, mfreqRuler, EffectParameter< Structure, Member, Type, Value >::min, mLoFreq, mNyquist, mOrderIndex, mPanel, mRipple, mRippleCtl, mRippleCtlP, mRippleCtlU, Msgids(), mStopbandRipple, mStopbandRippleCtl, mStopbandRippleCtlP, mStopbandRippleCtlU, mUIParent, nSubTypes, nTypes, Passband, S, safenew, Stopband, Verbatim(), XO(), and XXO().

Here is the call graph for this function:

◆ ProcessBlock()

size_t EffectScienFilter::ProcessBlock ( EffectSettings settings,
const float *const *  inBlock,
float *const *  outBlock,
size_t  blockLen 
)
overridevirtual

Called for destructive effect computation.

Implements StatefulPerTrackEffect.

Definition at line 206 of file ScienFilter.cpp.

208{
209 const float *ibuf = inBlock[0];
210 for (int iPair = 0; iPair < (mOrder + 1) / 2; iPair++)
211 {
212 mpBiquad[iPair].Process(ibuf, outBlock[0], blockLen);
213 ibuf = outBlock[0];
214 }
215
216 return blockLen;
217}

References mOrder, and mpBiquad.

◆ ProcessInitialize()

bool EffectScienFilter::ProcessInitialize ( EffectSettings settings,
double  sampleRate,
ChannelNames  chanMap 
)
overridevirtual

Called at start of destructive processing, for each (mono/stereo) track Default implementation does nothing, returns true

Parameters
chanMapnull or array terminated with ChannelNameEOL. Do not retain the pointer
Postcondition
GetAudioInCount() and GetAudioOutCount() are well defined

Reimplemented from StatefulEffectBase.

Definition at line 198 of file ScienFilter.cpp.

200{
201 for (int iPair = 0; iPair < (mOrder + 1) / 2; iPair++)
202 mpBiquad[iPair].Reset();
203 return true;
204}

References mOrder, and mpBiquad.

◆ TransferDataFromWindow()

bool EffectScienFilter::TransferDataFromWindow ( EffectSettings settings)
overridevirtual

Update the given settings from controls; default does nothing, returns true

Reimplemented from StatefulEffectUIServices.

Definition at line 450 of file ScienFilter.cpp.

451{
452 if (!mUIParent->Validate() || !mUIParent->TransferDataFromWindow())
453 {
454 return false;
455 }
456
457 mOrder = mOrderIndex + 1;
458
459 CalcFilter();
460
461 return true;
462}

References CalcFilter(), mOrder, mOrderIndex, and mUIParent.

Here is the call graph for this function:

◆ TransferDataToWindow()

bool EffectScienFilter::TransferDataToWindow ( const EffectSettings settings)
overridevirtual

Update controls for the settings; default does nothing, returns true

Reimplemented from StatefulEffectUIServices.

Definition at line 430 of file ScienFilter.cpp.

431{
432 mOrderIndex = mOrder - 1;
433
434 if (!mUIParent->TransferDataToWindow())
435 {
436 return false;
437 }
438
439 mdBMinSlider->SetValue((int) mdBMin);
440 mdBMin = 0.0; // force refresh in TransferGraphLimitsFromWindow()
441
442 mdBMaxSlider->SetValue((int) mdBMax);
443 mdBMax = 0.0; // force refresh in TransferGraphLimitsFromWindow()
444
446
448}

References EnableDisableRippleCtl(), mdBMax, mdBMaxSlider, mdBMin, mdBMinSlider, mFilterType, mOrder, mOrderIndex, mUIParent, and TransferGraphLimitsFromWindow().

Here is the call graph for this function:

◆ TransferGraphLimitsFromWindow()

bool EffectScienFilter::TransferGraphLimitsFromWindow ( )
private

Definition at line 469 of file ScienFilter.cpp.

470{
471 // Read the sliders and send to the panel
472 wxString tip;
473
474 bool rr = false;
475 int dB = mdBMinSlider->GetValue();
476 if (dB != mdBMin) {
477 rr = true;
478 mdBMin = dB;
479 tip.Printf(_("%d dB"), (int)mdBMin);
480 mdBMinSlider->SetToolTip(tip);
481 }
482
483 dB = mdBMaxSlider->GetValue();
484 if (dB != mdBMax) {
485 rr = true;
486 mdBMax = dB;
487 tip.Printf(_("%d dB"),(int)mdBMax);
488 mdBMaxSlider->SetToolTip(tip);
489 }
490
491 if (rr) {
493 }
494
495 // Refresh ruler if values have changed
496 if (rr) {
497 int w1, w2, h;
498 mdBRuler->ruler.GetMaxSize(&w1, &h);
500 mdBRuler->ruler.GetMaxSize(&w2, &h);
501 if( w1 != w2 ) // Reduces flicker
502 {
503 mdBRuler->SetSize(wxSize(w2,h));
504 mUIParent->Layout();
505 mfreqRuler->Refresh(false);
506 }
507 mdBRuler->Refresh(false);
508 }
509
510 mPanel->Refresh(false);
511
512 return true;
513}
#define _(s)
Definition: Internat.h:73
void SetDbRange(double min, double max)
void GetMaxSize(wxCoord *width, wxCoord *height)
Definition: Ruler.cpp:612
void SetRange(double min, double max)
Definition: Ruler.cpp:152
Ruler ruler
Definition: RulerPanel.h:79

References _, Ruler::GetMaxSize(), mdBMax, mdBMaxSlider, mdBMin, mdBMinSlider, mdBRuler, mfreqRuler, mPanel, mUIParent, RulerPanel::ruler, EffectScienFilterPanel::SetDbRange(), and Ruler::SetRange().

Referenced by OnSliderDBMAX(), OnSliderDBMIN(), and TransferDataToWindow().

Here is the call graph for this function:
Here is the caller graph for this function:

Friends And Related Function Documentation

◆ EffectScienFilterPanel

friend class EffectScienFilterPanel
friend

Definition at line 135 of file ScienFilter.h.

Referenced by PopulateOrExchange().

Member Data Documentation

◆ Cutoff

constexpr EffectParameter EffectScienFilter::Cutoff
staticconstexprprivate
Initial value:
L"Cutoff", 1000.0f, 1.0, FLT_MAX, 1 }

Definition at line 162 of file ScienFilter.h.

Referenced by Parameters(), and PopulateOrExchange().

◆ kSubTypeStrings

const EnumValueSymbol EffectScienFilter::kSubTypeStrings
staticprivate
Initial value:
=
{
{ XO("Lowpass") },
{ XO("Highpass") }
}

Definition at line 143 of file ScienFilter.h.

Referenced by PopulateOrExchange().

◆ kTypeStrings

const EnumValueSymbol EffectScienFilter::kTypeStrings
staticprivate
Initial value:
=
{
{ XO("Butterworth") },
{ XO("Chebyshev Type I") },
{ XO("Chebyshev Type II") }
}

Definition at line 152 of file ScienFilter.h.

Referenced by PopulateOrExchange().

◆ mCutoff

float EffectScienFilter::mCutoff
private

Definition at line 95 of file ScienFilter.h.

Referenced by CalcFilter(), FilterMagnAtFreq(), and PopulateOrExchange().

◆ mCutoffCtl

wxTextCtrl* EffectScienFilter::mCutoffCtl
private

Definition at line 119 of file ScienFilter.h.

Referenced by PopulateOrExchange().

◆ mdBMax

double EffectScienFilter::mdBMax
private

Definition at line 104 of file ScienFilter.h.

Referenced by TransferDataToWindow(), and TransferGraphLimitsFromWindow().

◆ mdBMaxSlider

wxSlider* EffectScienFilter::mdBMaxSlider
private

◆ mdBMin

double EffectScienFilter::mdBMin
private

Definition at line 105 of file ScienFilter.h.

Referenced by TransferDataToWindow(), and TransferGraphLimitsFromWindow().

◆ mdBMinSlider

wxSlider* EffectScienFilter::mdBMinSlider
private

◆ mdBRuler

RulerPanel* EffectScienFilter::mdBRuler
private

◆ mEditingBatchParams

bool EffectScienFilter::mEditingBatchParams
private

Definition at line 106 of file ScienFilter.h.

◆ mFilterOrderCtl

wxChoice* EffectScienFilter::mFilterOrderCtl
private

Definition at line 127 of file ScienFilter.h.

Referenced by OnOrder(), and PopulateOrExchange().

◆ mFilterSubtype

int EffectScienFilter::mFilterSubtype
private

Definition at line 99 of file ScienFilter.h.

Referenced by CalcFilter(), FilterMagnAtFreq(), OnFilterSubtype(), and PopulateOrExchange().

◆ mFilterSubTypeCtl

wxChoice* EffectScienFilter::mFilterSubTypeCtl
private

Definition at line 126 of file ScienFilter.h.

Referenced by OnFilterSubtype(), and PopulateOrExchange().

◆ mFilterType

int EffectScienFilter::mFilterType
private

◆ mFilterTypeCtl

wxChoice* EffectScienFilter::mFilterTypeCtl
private

Definition at line 125 of file ScienFilter.h.

Referenced by OnFilterType(), and PopulateOrExchange().

◆ mfreqRuler

RulerPanel* EffectScienFilter::mfreqRuler
private

◆ mLoFreq

double EffectScienFilter::mLoFreq
private

Definition at line 108 of file ScienFilter.h.

Referenced by PopulateOrExchange().

◆ mNyquist

double EffectScienFilter::mNyquist
private

Definition at line 109 of file ScienFilter.h.

Referenced by CalcFilter(), FilterMagnAtFreq(), Init(), and PopulateOrExchange().

◆ mOrder

int EffectScienFilter::mOrder
private

◆ mOrderIndex

int EffectScienFilter::mOrderIndex
private

◆ mPanel

EffectScienFilterPanel* EffectScienFilter::mPanel
private

◆ mpBiquad

ArrayOf<Biquad> EffectScienFilter::mpBiquad
private

Definition at line 102 of file ScienFilter.h.

Referenced by CalcFilter(), ProcessBlock(), and ProcessInitialize().

◆ mRipple

float EffectScienFilter::mRipple
private

Definition at line 96 of file ScienFilter.h.

Referenced by CalcFilter(), FilterMagnAtFreq(), and PopulateOrExchange().

◆ mRippleCtl

wxTextCtrl* EffectScienFilter::mRippleCtl
private

Definition at line 116 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mRippleCtlP

wxStaticText* EffectScienFilter::mRippleCtlP
private

Definition at line 115 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mRippleCtlU

wxStaticText* EffectScienFilter::mRippleCtlU
private

Definition at line 117 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mStopbandRipple

float EffectScienFilter::mStopbandRipple
private

Definition at line 97 of file ScienFilter.h.

Referenced by CalcFilter(), FilterMagnAtFreq(), and PopulateOrExchange().

◆ mStopbandRippleCtl

wxTextCtrl* EffectScienFilter::mStopbandRippleCtl
private

Definition at line 122 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mStopbandRippleCtlP

wxStaticText* EffectScienFilter::mStopbandRippleCtlP
private

Definition at line 121 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mStopbandRippleCtlU

wxStaticText* EffectScienFilter::mStopbandRippleCtlU
private

Definition at line 123 of file ScienFilter.h.

Referenced by EnableDisableRippleCtl(), and PopulateOrExchange().

◆ mUIParent

wxWeakRef<wxWindow> EffectScienFilter::mUIParent {}
private

◆ Order

constexpr EffectParameter EffectScienFilter::Order
staticconstexprprivate
Initial value:
L"Order", 1, 1, 10, 1 }

Definition at line 160 of file ScienFilter.h.

Referenced by Parameters().

◆ Passband

constexpr EffectParameter EffectScienFilter::Passband
staticconstexprprivate
Initial value:
L"PassbandRipple", 1.0f, 0.0, 100.0, 1 }

Definition at line 164 of file ScienFilter.h.

Referenced by Parameters(), and PopulateOrExchange().

◆ Stopband

constexpr EffectParameter EffectScienFilter::Stopband
staticconstexprprivate
Initial value:
L"StopbandRipple", 30.0f, 0.0, 100.0, 1 }

Definition at line 166 of file ScienFilter.h.

Referenced by Parameters(), and PopulateOrExchange().

◆ Subtype

constexpr EnumParameter EffectScienFilter::Subtype
staticconstexprprivate
Initial value:

Definition at line 158 of file ScienFilter.h.

Referenced by Parameters().

◆ Symbol

const ComponentInterfaceSymbol EffectScienFilter::Symbol { XO("Classic Filters") }
static

Definition at line 40 of file ScienFilter.h.

Referenced by GetSymbol().

◆ Type

constexpr EnumParameter EffectScienFilter::Type
staticconstexprprivate
Initial value:

Definition at line 156 of file ScienFilter.h.

Referenced by Parameters().


The documentation for this class was generated from the following files: