de.sciss.synth.ugen.IOUGens.scala Maven / Gradle / Ivy
/*
* IOUGens.scala
* (ScalaCollider-UGens)
*
* This is a synthetically generated file.
* ScalaCollider-UGens version: 1.0.1
*/
package de.sciss.synth
package ugen
import collection.immutable.{IndexedSeq => IIdxSeq}
object OffsetOut {
def ar(bus: GE, in: GE) = apply(bus, in)
}
final case class OffsetOut(bus: GE, in: GE) extends UGenSource.ZeroOut("OffsetOut") with AudioRated with WritesBus {
protected def makeUGens: Unit = unwrap(IIdxSeq(bus.expand).++(in.expand.outputs))
protected def makeUGen(_args: IIdxSeq[UGenIn]): Unit = new UGen.ZeroOut(name, audio, _args, true)
}
object LocalIn {
def kr: LocalIn = kr()
def kr(numChannels: Int = 1) = apply(control, numChannels)
def ar: LocalIn = ar()
def ar(numChannels: Int = 1) = apply(audio, numChannels)
}
final case class LocalIn(rate: Rate, numChannels: Int) extends UGenSource.MultiOut("LocalIn") {
protected def makeUGens: UGenInLike = makeUGen(IIdxSeq.empty)
protected def makeUGen(_args: IIdxSeq[UGenIn]): UGenInLike = new UGen.MultiOut(name, rate, IIdxSeq.fill(numChannels)(rate), _args)
}
/**
* '''Warning''': The argument order is different from its sclang counterpart.
*/
object XOut {
def ar(bus: GE, in: GE, xfade: GE) = apply(audio, bus, in, xfade)
def kr(bus: GE, in: GE, xfade: GE) = apply(control, bus, in, xfade)
}
/**
* '''Warning''': The argument order is different from its sclang counterpart.
*/
final case class XOut(rate: Rate, bus: GE, in: GE, xfade: GE) extends UGenSource.ZeroOut("XOut") with WritesBus {
protected def makeUGens: Unit = unwrap(IIdxSeq(bus.expand, xfade.expand).++(in.expand.outputs))
protected def makeUGen(_args: IIdxSeq[UGenIn]): Unit = new UGen.ZeroOut(name, rate, _args, true)
}
object ReplaceOut {
def ar(bus: GE, in: GE) = apply(bus, in)
}
final case class ReplaceOut(bus: GE, in: GE) extends UGenSource.ZeroOut("ReplaceOut") with AudioRated with WritesBus {
protected def makeUGens: Unit = unwrap(IIdxSeq(bus.expand).++(in.expand.outputs))
protected def makeUGen(_args: IIdxSeq[UGenIn]): Unit = new UGen.ZeroOut(name, audio, _args, true)
}
object Out {
def ar(bus: GE, in: GE) = apply(audio, bus, in)
def kr(bus: GE, in: GE) = apply(control, bus, in)
def ir(bus: GE, in: GE) = apply(scalar, bus, in)
}
final case class Out(rate: Rate, bus: GE, in: GE) extends UGenSource.ZeroOut("Out") with WritesBus {
protected def makeUGens: Unit = unwrap(IIdxSeq(bus.expand).++(in.expand.outputs))
protected def makeUGen(_args: IIdxSeq[UGenIn]): Unit = new UGen.ZeroOut(name, rate, _args, true)
}
object LocalOut {
def kr(in: GE) = apply(control, in)
def ar(in: GE) = apply(audio, in)
}
final case class LocalOut(rate: Rate, in: GE) extends UGenSource.ZeroOut("LocalOut") {
protected def makeUGens: Unit = unwrap(in.expand.outputs)
protected def makeUGen(_args: IIdxSeq[UGenIn]): Unit = new UGen.ZeroOut(name, rate, _args)
}
object In {
def ir(bus: GE, numChannels: Int = 1) = apply(scalar, bus, numChannels)
def kr(bus: GE, numChannels: Int = 1) = apply(control, bus, numChannels)
def ar(bus: GE, numChannels: Int = 1) = apply(audio, bus, numChannels)
}
final case class In(rate: Rate, bus: GE, numChannels: Int) extends UGenSource.MultiOut("In") {
protected def makeUGens: UGenInLike = unwrap(IIdxSeq(bus.expand))
protected def makeUGen(_args: IIdxSeq[UGenIn]): UGenInLike = new UGen.MultiOut(name, rate, IIdxSeq.fill(numChannels)(rate), _args)
}
object LagIn {
def kr(bus: GE, numChannels: Int = 1, lag: GE = 0.1f) = apply(control, bus, numChannels, lag)
}
final case class LagIn(rate: Rate, bus: GE, numChannels: Int, lag: GE) extends UGenSource.MultiOut("LagIn") {
protected def makeUGens: UGenInLike = unwrap(IIdxSeq(bus.expand, lag.expand))
protected def makeUGen(_args: IIdxSeq[UGenIn]): UGenInLike = new UGen.MultiOut(name, rate, IIdxSeq.fill(numChannels)(rate), _args)
}
/**
* A UGen which reads a signal from an audio bus with a current or one cycle old timestamp
*
* Audio buses adhere to the concept of a cycle timestamp, which increases for each audio block
* calculated. When the various output ugens (`Out`, `OffsetOut`, `XOut`) write data to a bus,
* they mix it with any data from the current cycle, but overwrite any data from the previous cycle.
* (`ReplaceOut` overwrites all data regardless.) Thus depending on node order and what synths are
* writing to the bus, the data on a given bus may be from the current cycle or be one cycle old at
* the time of reading.
*
* `In.ar` checks the timestamp of any data it reads in and zeros any data from the previous
* cycle (for use within that node; the data remains on the bus). This is fine for audio data,
* as it avoids feedback, but for control data it is useful to be able to read data from any place
* in the node order. For this reason `In.kr` also reads data that is older than the current cycle.
*
* In some cases one might also want to read audio from a node later in the current node order.
* This can be achieved with `InFeedback`. It reads from the previous cycle, and hence introduces
* a '''delay''' of one block size, which by default is 64 sample frames (equal to about 1.45 ms
* at 44.1 kHz sample rate).
*
* '''Note''' that no delay occurs when the bus contains a signal which has been written already
* in the current cycle. The delay is only introduced when no present signal exists.
*
* @see [[de.sciss.synth.ugen.In]]
* @see [[de.sciss.synth.ugen.LocalIn]]
* @see [[de.sciss.synth.ugen.ControlDur]]
*/
object InFeedback {
/**
* @param bus the index of the audio bus to read in from.
* @param numChannels the number of channels (i.e. adjacent buses) to read in. Since
* this is a constant, a change in number of channels of the underlying bus must
* be reflected by creating different SynthDefs.
*/
def ar(bus: GE, numChannels: Int = 1) = apply(bus, numChannels)
}
/**
* A UGen which reads a signal from an audio bus with a current or one cycle old timestamp
*
* Audio buses adhere to the concept of a cycle timestamp, which increases for each audio block
* calculated. When the various output ugens (`Out`, `OffsetOut`, `XOut`) write data to a bus,
* they mix it with any data from the current cycle, but overwrite any data from the previous cycle.
* (`ReplaceOut` overwrites all data regardless.) Thus depending on node order and what synths are
* writing to the bus, the data on a given bus may be from the current cycle or be one cycle old at
* the time of reading.
*
* `In.ar` checks the timestamp of any data it reads in and zeros any data from the previous
* cycle (for use within that node; the data remains on the bus). This is fine for audio data,
* as it avoids feedback, but for control data it is useful to be able to read data from any place
* in the node order. For this reason `In.kr` also reads data that is older than the current cycle.
*
* In some cases one might also want to read audio from a node later in the current node order.
* This can be achieved with `InFeedback`. It reads from the previous cycle, and hence introduces
* a '''delay''' of one block size, which by default is 64 sample frames (equal to about 1.45 ms
* at 44.1 kHz sample rate).
*
* '''Note''' that no delay occurs when the bus contains a signal which has been written already
* in the current cycle. The delay is only introduced when no present signal exists.
*
* @param bus the index of the audio bus to read in from.
* @param numChannels the number of channels (i.e. adjacent buses) to read in. Since
* this is a constant, a change in number of channels of the underlying bus must
* be reflected by creating different SynthDefs.
*
* @see [[de.sciss.synth.ugen.In]]
* @see [[de.sciss.synth.ugen.LocalIn]]
* @see [[de.sciss.synth.ugen.ControlDur]]
*/
final case class InFeedback(bus: GE, numChannels: Int) extends UGenSource.MultiOut("InFeedback") with AudioRated {
protected def makeUGens: UGenInLike = unwrap(IIdxSeq(bus.expand))
protected def makeUGen(_args: IIdxSeq[UGenIn]): UGenInLike = new UGen.MultiOut(name, audio, IIdxSeq.fill(numChannels)(audio), _args)
}
/**
* A UGen which generates a trigger anytime a control bus is set.
*
* Any time the bus is "touched" i.e. has its value set (using `"/c_set"` etc.), a single
* impulse trigger will be generated. Its amplitude is the value that the bus was set to.
* Note that if a signal is continuously written to that bus, for instance using
* `Out.kr`, only one initial trigger is generated once that ugen starts writing, but
* no successive triggers are generated.
*
* @see [[de.sciss.synth.ugen.In]]
*/
object InTrig {
/**
* @param bus the index of the control bus to read in from.
* @param numChannels the number of channels (i.e. adjacent buses) to read in. Since
* this is a constant, a change in number of channels of the underlying bus must
* be reflected by creating different SynthDefs.
*/
def kr(bus: GE, numChannels: Int = 1) = apply(bus, numChannels)
}
/**
* A UGen which generates a trigger anytime a control bus is set.
*
* Any time the bus is "touched" i.e. has its value set (using `"/c_set"` etc.), a single
* impulse trigger will be generated. Its amplitude is the value that the bus was set to.
* Note that if a signal is continuously written to that bus, for instance using
* `Out.kr`, only one initial trigger is generated once that ugen starts writing, but
* no successive triggers are generated.
*
* @param bus the index of the control bus to read in from.
* @param numChannels the number of channels (i.e. adjacent buses) to read in. Since
* this is a constant, a change in number of channels of the underlying bus must
* be reflected by creating different SynthDefs.
*
* @see [[de.sciss.synth.ugen.In]]
*/
final case class InTrig(bus: GE, numChannels: Int) extends UGenSource.MultiOut("InTrig") with ControlRated {
protected def makeUGens: UGenInLike = unwrap(IIdxSeq(bus.expand))
protected def makeUGen(_args: IIdxSeq[UGenIn]): UGenInLike = new UGen.MultiOut(name, control, IIdxSeq.fill(numChannels)(control), _args)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy