Functional attempt at NRT threading:
* changes to NRT SC Wrapper makes it a UGen, using the RT thread for polling and delegating to SC NRT thread for launching * changes to FluidBufNMF: Now a UGen with kr (emitting progress updates); process() wraps .kr via Function.play. Sync at end managed through use of doneAction * TODO: cancelling, checking progress, all the other client (and then the help...)nix
parent
b0a05ce44d
commit
b3895c5be6
@ -1,27 +1,57 @@
|
|||||||
FluidBufNMF {
|
FluidBufNMF : UGen {
|
||||||
*process { arg server, source, startFrame = 0, numFrames = -1, startChan = 0, numChans = -1, destination, bases, basesMode = 0, activations, actMode = 0, components = 1, iterations = 100, windowSize = 1024, hopSize = -1, fftSize = -1, windowType = 0, randomSeed = -1, action;
|
|
||||||
|
|
||||||
|
*kr {|source, startFrame = 0, numFrames = -1, startChan = 0, numChans = -1, destination, bases, basesMode = 0, activations, actMode = 0, components = 1, iterations = 100, windowSize = 1024, hopSize = -1, fftSize = -1, windowType = 0, randomSeed = -1, doneAction = 0|
|
||||||
|
|
||||||
source = source.asUGenInput;
|
source = source.asUGenInput;
|
||||||
destination = destination.asUGenInput;
|
destination = destination.asUGenInput;
|
||||||
bases = bases.asUGenInput;
|
bases = bases.asUGenInput;
|
||||||
activations = activations.asUGenInput;
|
activations = activations.asUGenInput;
|
||||||
|
|
||||||
source.isNil.if {"FluidBufNMF: Invalid source buffer".throw};
|
source.isNil.if {"FluidBufNMF: Invalid source buffer".throw};
|
||||||
|
|
||||||
server = server ? Server.default;
|
destination = destination ? -1;
|
||||||
|
bases = bases ? -1;
|
||||||
|
activations = activations ? -1;
|
||||||
|
|
||||||
destination = destination ? -1;
|
^this.multiNew('control',source, startFrame, numFrames, startChan, numChans, destination, bases, basesMode, activations, actMode, components, iterations, windowSize, hopSize, fftSize, doneAction);
|
||||||
bases = bases ? -1;
|
|
||||||
activations = activations ? -1;
|
|
||||||
|
|
||||||
forkIfNeeded{
|
}
|
||||||
server.sendMsg(\cmd, \BufNMF, source, startFrame, numFrames, startChan, numChans, destination, bases, basesMode, activations, actMode, components, iterations, windowSize, hopSize, fftSize);
|
|
||||||
server.sync;
|
|
||||||
if (destination != -1) {destination = server.cachedBufferAt(destination); destination.updateInfo; server.sync;} {destination = nil};
|
*process { |server, source, startFrame = 0, numFrames = -1, startChan = 0, numChans = -1, destination, bases, basesMode = 0, activations, actMode = 0, components = 1, iterations = 100, windowSize = 1024, hopSize = -1, fftSize = -1, windowType = 0, randomSeed = -1, action|
|
||||||
if (bases != -1) {bases = server.cachedBufferAt(bases); bases.updateInfo; server.sync;} {bases = nil};
|
|
||||||
if (activations != -1) {activations = server.cachedBufferAt(activations); activations.updateInfo; server.sync;} {activations = nil};
|
var synth;
|
||||||
action.value(destination, bases, activations);
|
source = source.asUGenInput;
|
||||||
};
|
destination = destination.asUGenInput;
|
||||||
}
|
bases = bases.asUGenInput;
|
||||||
|
activations = activations.asUGenInput;
|
||||||
|
|
||||||
|
source.isNil.if {"FluidBufNMF: Invalid source buffer".throw};
|
||||||
|
|
||||||
|
destination = destination ? -1;
|
||||||
|
bases = bases ? -1;
|
||||||
|
activations = activations ? -1;
|
||||||
|
|
||||||
|
synth = {FluidBufNMF.kr(source, startFrame, numFrames, startChan, numChans, destination, bases, basesMode, activations, actMode, components, iterations, windowSize, hopSize, fftSize, doneAction: Done.freeSelf)}.play(server);
|
||||||
|
|
||||||
|
synth.waitForFree({ forkIfNeeded{
|
||||||
|
server.sync;
|
||||||
|
if (destination != -1) {
|
||||||
|
destination = server.cachedBufferAt(destination);
|
||||||
|
destination.updateInfo;
|
||||||
|
server.sync;
|
||||||
|
} {destination = nil};
|
||||||
|
if (bases != -1) {
|
||||||
|
bases = server.cachedBufferAt(bases);
|
||||||
|
bases.updateInfo;
|
||||||
|
server.sync;
|
||||||
|
} {bases = nil};
|
||||||
|
if (activations != -1) {
|
||||||
|
activations = server.cachedBufferAt(activations);
|
||||||
|
activations.updateInfo;
|
||||||
|
server.sync;
|
||||||
|
} {activations = nil};
|
||||||
|
action.value(destination, bases, activations);
|
||||||
|
}});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue