mirror of
https://github.com/airwindows/airwindows.git
synced 2026-05-21 06:46:21 -06:00
205 lines
8.4 KiB
C++
Executable file
205 lines
8.4 KiB
C++
Executable file
/*
|
||
* File: HighGlossDither.cpp
|
||
*
|
||
* Version: 1.0
|
||
*
|
||
* Created: 11/17/16
|
||
*
|
||
* Copyright: Copyright <20> 2016 Airwindows, Airwindows uses the MIT license
|
||
*
|
||
* Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple Computer, Inc. ("Apple") in
|
||
* consideration of your agreement to the following terms, and your use, installation, modification
|
||
* or redistribution of this Apple software constitutes acceptance of these terms. If you do
|
||
* not agree with these terms, please do not use, install, modify or redistribute this Apple
|
||
* software.
|
||
*
|
||
* In consideration of your agreement to abide by the following terms, and subject to these terms,
|
||
* Apple grants you a personal, non-exclusive license, under Apple's copyrights in this
|
||
* original Apple software (the "Apple Software"), to use, reproduce, modify and redistribute the
|
||
* Apple Software, with or without modifications, in source and/or binary forms; provided that if you
|
||
* redistribute the Apple Software in its entirety and without modifications, you must retain this
|
||
* notice and the following text and disclaimers in all such redistributions of the Apple Software.
|
||
* Neither the name, trademarks, service marks or logos of Apple Computer, Inc. may be used to
|
||
* endorse or promote products derived from the Apple Software without specific prior written
|
||
* permission from Apple. Except as expressly stated in this notice, no other rights or
|
||
* licenses, express or implied, are granted by Apple herein, including but not limited to any
|
||
* patent rights that may be infringed by your derivative works or by other works in which the
|
||
* Apple Software may be incorporated.
|
||
*
|
||
* The Apple Software is provided by Apple on an "AS IS" basis. APPLE MAKES NO WARRANTIES, EXPRESS OR
|
||
* IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY
|
||
* AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE
|
||
* OR IN COMBINATION WITH YOUR PRODUCTS.
|
||
*
|
||
* IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL
|
||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE,
|
||
* REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER
|
||
* UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN
|
||
* IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
*
|
||
*/
|
||
/*=============================================================================
|
||
HighGlossDither.cpp
|
||
|
||
=============================================================================*/
|
||
#include "HighGlossDither.h"
|
||
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
||
COMPONENT_ENTRY(HighGlossDither)
|
||
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::HighGlossDither
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
HighGlossDither::HighGlossDither(AudioUnit component)
|
||
: AUEffectBase(component)
|
||
{
|
||
CreateElements();
|
||
Globals()->UseIndexedParameters(kNumberOfParameters);
|
||
|
||
#if AU_DEBUG_DISPATCHER
|
||
mDebugDispatcher = new AUDebugDispatcher (this);
|
||
#endif
|
||
|
||
}
|
||
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::GetParameterValueStrings
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
ComponentResult HighGlossDither::GetParameterValueStrings(AudioUnitScope inScope,
|
||
AudioUnitParameterID inParameterID,
|
||
CFArrayRef * outStrings)
|
||
{
|
||
|
||
return kAudioUnitErr_InvalidProperty;
|
||
}
|
||
|
||
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::GetParameterInfo
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
ComponentResult HighGlossDither::GetParameterInfo(AudioUnitScope inScope,
|
||
AudioUnitParameterID inParameterID,
|
||
AudioUnitParameterInfo &outParameterInfo )
|
||
{
|
||
ComponentResult result = noErr;
|
||
|
||
outParameterInfo.flags = kAudioUnitParameterFlag_IsWritable
|
||
| kAudioUnitParameterFlag_IsReadable;
|
||
|
||
if (inScope == kAudioUnitScope_Global) {
|
||
switch(inParameterID)
|
||
{
|
||
default:
|
||
result = kAudioUnitErr_InvalidParameter;
|
||
break;
|
||
}
|
||
} else {
|
||
result = kAudioUnitErr_InvalidParameter;
|
||
}
|
||
|
||
|
||
|
||
return result;
|
||
}
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::GetPropertyInfo
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
ComponentResult HighGlossDither::GetPropertyInfo (AudioUnitPropertyID inID,
|
||
AudioUnitScope inScope,
|
||
AudioUnitElement inElement,
|
||
UInt32 & outDataSize,
|
||
Boolean & outWritable)
|
||
{
|
||
return AUEffectBase::GetPropertyInfo (inID, inScope, inElement, outDataSize, outWritable);
|
||
}
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::GetProperty
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
ComponentResult HighGlossDither::GetProperty( AudioUnitPropertyID inID,
|
||
AudioUnitScope inScope,
|
||
AudioUnitElement inElement,
|
||
void * outData )
|
||
{
|
||
return AUEffectBase::GetProperty (inID, inScope, inElement, outData);
|
||
}
|
||
|
||
// HighGlossDither::Initialize
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
ComponentResult HighGlossDither::Initialize()
|
||
{
|
||
ComponentResult result = AUEffectBase::Initialize();
|
||
if (result == noErr)
|
||
Reset(kAudioUnitScope_Global, 0);
|
||
return result;
|
||
}
|
||
|
||
#pragma mark ____HighGlossDitherEffectKernel
|
||
|
||
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::HighGlossDitherKernel::Reset()
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
void HighGlossDither::HighGlossDitherKernel::Reset()
|
||
{
|
||
Position = 99999999;
|
||
flip = false;
|
||
}
|
||
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
// HighGlossDither::HighGlossDitherKernel::Process
|
||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
void HighGlossDither::HighGlossDitherKernel::Process( const Float32 *inSourceP,
|
||
Float32 *inDestP,
|
||
UInt32 inFramesToProcess,
|
||
UInt32 inNumChannels,
|
||
bool &ioSilence )
|
||
{
|
||
UInt32 nSampleFrames = inFramesToProcess;
|
||
const Float32 *sourceP = inSourceP;
|
||
Float32 *destP = inDestP;
|
||
|
||
double inputSample;
|
||
int hotbinA;
|
||
|
||
while (nSampleFrames-- > 0) {
|
||
inputSample = *sourceP;
|
||
|
||
|
||
|
||
inputSample *= 8388608.0;
|
||
//0-1 is now one bit, now we dither
|
||
|
||
Position += 1;
|
||
//Note- uses integer overflow as a 'mod' operator
|
||
hotbinA = Position * Position;
|
||
hotbinA = hotbinA % 170003; //% is C++ mod operator
|
||
hotbinA *= hotbinA;
|
||
hotbinA = hotbinA % 17011; //% is C++ mod operator
|
||
hotbinA *= hotbinA;
|
||
hotbinA = hotbinA % 1709; //% is C++ mod operator
|
||
hotbinA *= hotbinA;
|
||
hotbinA = hotbinA % 173; //% is C++ mod operator
|
||
hotbinA *= hotbinA;
|
||
hotbinA = hotbinA % 17;
|
||
hotbinA *= 0.0635;
|
||
if (flip) hotbinA = -hotbinA;
|
||
inputSample += hotbinA;
|
||
inputSample = floor(inputSample);
|
||
//Quadratic dither
|
||
flip = !flip;
|
||
|
||
inputSample /= 8388608.0;
|
||
*destP = inputSample;
|
||
sourceP += inNumChannels; destP += inNumChannels;
|
||
}
|
||
}
|
||
|