2024-05-03 18:31:14 +00:00
|
|
|
import { WaveShaper, WaveShaperMappingFn } from "./WaveShaper.js";
|
|
|
|
import { optionsFromArguments } from "../core/util/Defaults.js";
|
|
|
|
import { SignalOperator } from "./SignalOperator.js";
|
|
|
|
import { ToneAudioNodeOptions } from "../core/context/ToneAudioNode.js";
|
2019-09-20 00:49:02 +00:00
|
|
|
|
|
|
|
export interface PowOptions extends ToneAudioNodeOptions {
|
|
|
|
value: number;
|
|
|
|
}
|
2019-09-16 22:18:03 +00:00
|
|
|
|
|
|
|
/**
|
2019-09-20 21:55:36 +00:00
|
|
|
* Pow applies an exponent to the incoming signal. The incoming signal must be AudioRange [-1, 1]
|
2019-09-16 22:18:03 +00:00
|
|
|
*
|
2019-09-20 21:55:36 +00:00
|
|
|
* @example
|
2020-04-17 02:24:18 +00:00
|
|
|
* const pow = new Tone.Pow(2);
|
|
|
|
* const sig = new Tone.Signal(0.5).connect(pow);
|
2024-05-03 18:31:14 +00:00
|
|
|
* // output of pow is 0.25.
|
2019-09-20 22:51:45 +00:00
|
|
|
* @category Signal
|
2019-09-16 22:18:03 +00:00
|
|
|
*/
|
2019-09-20 00:49:02 +00:00
|
|
|
export class Pow extends SignalOperator<PowOptions> {
|
2019-09-16 22:18:03 +00:00
|
|
|
readonly name: string = "Pow";
|
2020-04-17 02:24:18 +00:00
|
|
|
|
2019-10-29 21:49:40 +00:00
|
|
|
private _exponent: number;
|
2019-09-16 22:18:03 +00:00
|
|
|
|
2019-09-20 00:49:02 +00:00
|
|
|
private _exponentScaler: WaveShaper;
|
2019-09-16 22:18:03 +00:00
|
|
|
|
2019-09-20 00:49:02 +00:00
|
|
|
input: WaveShaper;
|
2019-09-16 22:18:03 +00:00
|
|
|
|
2019-09-20 00:49:02 +00:00
|
|
|
output: WaveShaper;
|
2020-04-17 02:24:18 +00:00
|
|
|
|
2019-09-16 22:18:03 +00:00
|
|
|
/**
|
|
|
|
* @param value Constant exponent value to use
|
|
|
|
*/
|
|
|
|
constructor(value?: number);
|
2019-09-20 00:49:02 +00:00
|
|
|
constructor(options?: Partial<PowOptions>);
|
2019-09-16 22:18:03 +00:00
|
|
|
constructor() {
|
2024-05-03 18:31:14 +00:00
|
|
|
super(
|
|
|
|
Object.assign(
|
|
|
|
optionsFromArguments(Pow.getDefaults(), arguments, ["value"])
|
|
|
|
)
|
|
|
|
);
|
|
|
|
const options = optionsFromArguments(Pow.getDefaults(), arguments, [
|
|
|
|
"value",
|
|
|
|
]);
|
2019-09-20 00:49:02 +00:00
|
|
|
|
2024-05-03 18:31:14 +00:00
|
|
|
this._exponentScaler =
|
|
|
|
this.input =
|
|
|
|
this.output =
|
|
|
|
new WaveShaper({
|
|
|
|
context: this.context,
|
|
|
|
mapping: this._expFunc(options.value),
|
|
|
|
length: 8192,
|
|
|
|
});
|
2019-09-16 22:18:03 +00:00
|
|
|
|
2019-10-29 21:49:40 +00:00
|
|
|
this._exponent = options.value;
|
2019-09-16 22:18:03 +00:00
|
|
|
}
|
|
|
|
|
2019-09-20 00:49:02 +00:00
|
|
|
static getDefaults(): PowOptions {
|
|
|
|
return Object.assign(SignalOperator.getDefaults(), {
|
2019-09-16 22:18:03 +00:00
|
|
|
value: 1,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* the function which maps the waveshaper
|
2019-09-20 00:49:02 +00:00
|
|
|
* @param exponent exponent value
|
2019-09-16 22:18:03 +00:00
|
|
|
*/
|
2019-09-20 00:49:02 +00:00
|
|
|
private _expFunc(exponent: number): WaveShaperMappingFn {
|
2019-09-16 22:18:03 +00:00
|
|
|
return (val: number) => {
|
2019-09-20 00:49:02 +00:00
|
|
|
return Math.pow(Math.abs(val), exponent);
|
2019-09-16 22:18:03 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-09-20 21:55:36 +00:00
|
|
|
/**
|
2019-10-23 03:04:52 +00:00
|
|
|
* The value of the exponent.
|
|
|
|
*/
|
2019-09-20 00:49:02 +00:00
|
|
|
get value(): number {
|
2019-09-16 22:18:03 +00:00
|
|
|
return this._exponent;
|
|
|
|
}
|
2019-09-20 00:49:02 +00:00
|
|
|
set value(exponent: number) {
|
|
|
|
this._exponent = exponent;
|
2019-09-16 22:18:03 +00:00
|
|
|
this._exponentScaler.setMap(this._expFunc(this._exponent));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up.
|
|
|
|
*/
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._exponentScaler.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
2019-09-20 21:55:36 +00:00
|
|
|
}
|