rsc3/doc-schelp/HelpSource/Classes/Warp.schelp

36 lines
1.1 KiB
Text

class:: Warp
summary:: specification of a shape for a mapping of numerical input
related:: Classes/ControlSpec, Classes/Spec
categories:: Control, Spec
description::
The subclasses of Warp specify translations from input (a number) to an output (another number). This is an abstract class - already available shapes are emphasis::linear, exponential, sine, cosine, decibel, curve:: (this is similar to the curves in envelopes, see also link::Classes/Env::).
Warps are internally created by link::Classes/ControlSpec::. Usually they are created by the message strong::asWarp::, understood by symbols and numbers. A warp has a link::Classes/Spec:: to specify a certain range of input and output values.
code::
// create a new warp:
a = \exp.asWarp;
a = -4.asWarp; // a curve warp;
::
ClassMethods::
private::initClass
InstanceMethods::
method::map
Maps and constrains a strong::value:: between 0 and 1 to the output domain.
method::unmap
in the output domain to a value in the range between 0 and 1.
code::
g = -3.asWarp;
g.map(0.5);
g.unmap(0.9);
// fore and back translation should be identical:
g.unmap(g.map(0.5));
::