/* * Copyright (C) 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef DPBASE_H_ #define DPBASE_H_ #include <stdint.h> #include <cmath> #include <vector> #include <android/log.h> namespace dp_fx { #define DP_DEFAULT_BAND_ENABLED false #define DP_DEFAULT_BAND_CUTOFF_FREQUENCY_HZ 1000 #define DP_DEFAULT_ATTACK_TIME_MS 50 #define DP_DEFAULT_RELEASE_TIME_MS 120 #define DP_DEFAULT_RATIO 2 #define DP_DEFAULT_THRESHOLD_DB -30 #define DP_DEFAULT_KNEE_WIDTH_DB 0 #define DP_DEFAULT_NOISE_GATE_THRESHOLD_DB -90 #define DP_DEFAULT_EXPANDER_RATIO 1 #define DP_DEFAULT_GAIN_DB 0 #define DP_DEFAULT_STAGE_INUSE false #define DP_DEFAULT_STAGE_ENABLED false #define DP_DEFAULT_LINK_GROUP 0 class DPStage { public: DPStage(); ~DPStage() = default; void init(bool inUse, bool enabled); bool isInUse() const { return mInUse; } bool isEnabled() const { return mEnabled; } void setEnabled(bool enabled) { mEnabled = enabled; } private: bool mInUse; bool mEnabled; }; class DPBandStage : public DPStage { public: DPBandStage(); ~DPBandStage() = default; void init(bool inUse, bool enabled, int bandCount); uint32_t getBandCount() const { return mBandCount; } void setBandCount(uint32_t bandCount) { mBandCount = bandCount; } private: uint32_t mBandCount; }; class DPBandBase { public: DPBandBase(); ~DPBandBase() = default; void init(bool enabled, float cutoffFrequency); bool isEnabled() const { return mEnabled; } void setEnabled(bool enabled) { mEnabled = enabled; } float getCutoffFrequency() const { return mCutoofFrequencyHz; } void setCutoffFrequency(float cutoffFrequency) { mCutoofFrequencyHz = cutoffFrequency; } private: bool mEnabled; float mCutoofFrequencyHz; }; class DPEqBand : public DPBandBase { public: DPEqBand(); ~DPEqBand() = default; void init(bool enabled, float cutoffFrequency, float gain); float getGain() const; void setGain(float gain); private: float mGainDb; }; class DPMbcBand : public DPBandBase { public: DPMbcBand(); ~DPMbcBand() = default; void init(bool enabled, float cutoffFrequency, float attackTime, float releaseTime, float ratio, float threshold, float kneeWidth, float noiseGateThreshold, float expanderRatio, float preGain, float postGain); float getAttackTime() const { return mAttackTimeMs; } void setAttackTime(float attackTime) { mAttackTimeMs = attackTime; } float getReleaseTime() const { return mReleaseTimeMs; } void setReleaseTime(float releaseTime) { mReleaseTimeMs = releaseTime; } float getRatio() const { return mRatio; } void setRatio(float ratio) { mRatio = ratio; } float getThreshold() const { return mThresholdDb; } void setThreshold(float threshold) { mThresholdDb = threshold; } float getKneeWidth() const { return mKneeWidthDb; } void setKneeWidth(float kneeWidth) { mKneeWidthDb = kneeWidth; } float getNoiseGateThreshold() const { return mNoiseGateThresholdDb; } void setNoiseGateThreshold(float noiseGateThreshold) { mNoiseGateThresholdDb = noiseGateThreshold; } float getExpanderRatio() const { return mExpanderRatio; } void setExpanderRatio(float expanderRatio) { mExpanderRatio = expanderRatio; } float getPreGain() const { return mPreGainDb; } void setPreGain(float preGain) { mPreGainDb = preGain; } float getPostGain() const { return mPostGainDb; } void setPostGain(float postGain) { mPostGainDb = postGain; } private: float mAttackTimeMs; float mReleaseTimeMs; float mRatio; float mThresholdDb; float mKneeWidthDb; float mNoiseGateThresholdDb; float mExpanderRatio; float mPreGainDb; float mPostGainDb; }; class DPEq : public DPBandStage { public: DPEq(); ~DPEq() = default; void init(bool inUse, bool enabled, uint32_t bandCount); DPEqBand * getBand(uint32_t band); void setBand(uint32_t band, DPEqBand &src); private: std::vector<DPEqBand> mBands; }; class DPMbc : public DPBandStage { public: DPMbc(); ~DPMbc() = default; void init(bool inUse, bool enabled, uint32_t bandCount); DPMbcBand * getBand(uint32_t band); void setBand(uint32_t band, DPMbcBand &src); private: std::vector<DPMbcBand> mBands; }; class DPLimiter : public DPStage { public: DPLimiter(); ~DPLimiter() = default; void init(bool inUse, bool enabled, uint32_t linkGroup, float attackTime, float releaseTime, float ratio, float threshold, float postGain); uint32_t getLinkGroup() const { return mLinkGroup; } void setLinkGroup(uint32_t linkGroup) { mLinkGroup = linkGroup; } float getAttackTime() const { return mAttackTimeMs; } void setAttackTime(float attackTime) { mAttackTimeMs = attackTime; } float getReleaseTime() const { return mReleaseTimeMs; } void setReleaseTime(float releaseTime) { mReleaseTimeMs = releaseTime; } float getRatio() const { return mRatio; } void setRatio(float ratio) { mRatio = ratio; } float getThreshold() const { return mThresholdDb; } void setThreshold(float threshold) { mThresholdDb = threshold; } float getPostGain() const { return mPostGainDb; } void setPostGain(float postGain) { mPostGainDb = postGain; } private: uint32_t mLinkGroup; float mAttackTimeMs; float mReleaseTimeMs; float mRatio; float mThresholdDb; float mPostGainDb; }; class DPChannel { public: DPChannel(); ~DPChannel() = default; void init(float inputGain, bool preEqInUse, uint32_t preEqBandCount, bool mbcInUse, uint32_t mbcBandCount, bool postEqInUse, uint32_t postEqBandCount, bool limiterInUse); float getInputGain() const { if (!mInitialized) { return 0; } return mInputGainDb; } void setInputGain(float gain) { mInputGainDb = gain; } float getOutputGain() const { if (!mInitialized) { return 0; } return mOutputGainDb; } void setOutputGain(float gain) { mOutputGainDb = gain; } DPEq* getPreEq(); DPMbc* getMbc(); DPEq* getPostEq(); DPLimiter *getLimiter(); void setLimiter(DPLimiter &limiter); private: bool mInitialized; float mInputGainDb; float mOutputGainDb; DPEq mPreEq; DPMbc mMbc; DPEq mPostEq; DPLimiter mLimiter; bool mPreEqInUse; bool mMbcInUse; bool mPostEqInUse; bool mLimiterInUse; }; class DPBase { public: DPBase(); virtual ~DPBase() = default; void init(uint32_t channelCount, bool preEqInUse, uint32_t preEqBandCount, bool mbcInUse, uint32_t mbcBandCount, bool postEqInUse, uint32_t postEqBandCount, bool limiterInUse); virtual size_t processSamples(const float *in, float *out, size_t samples) = 0; virtual void reset() = 0; DPChannel* getChannel(uint32_t channelIndex); uint32_t getChannelCount() const { return mChannelCount; } uint32_t getPreEqBandCount() const { return mPreEqBandCount; } uint32_t getMbcBandCount() const { return mMbcBandCount; } uint32_t getPostEqBandCount() const { return mPostEqBandCount; } bool isPreEQInUse() const { return mPreEqInUse; } bool isMbcInUse() const { return mMbcInUse; } bool isPostEqInUse() const { return mPostEqInUse; } bool isLimiterInUse() const { return mLimiterInUse; } private: bool mInitialized; //general uint32_t mChannelCount; bool mPreEqInUse; uint32_t mPreEqBandCount; bool mMbcInUse; uint32_t mMbcBandCount; bool mPostEqInUse; uint32_t mPostEqBandCount; bool mLimiterInUse; std::vector<DPChannel> mChannel; }; } //namespace dp_fx #endif // DPBASE_H_