healing-soundscapes-light/hss.piecemaker.js
2024-08-01 17:11:37 +02:00

136 lines
4.1 KiB
JavaScript

inlets = 2
outlets = 3;
var presets = [];
var hsspiece = {};
var outdict = new Dict;
var points = [[0.5, 0.5], [1., 0.], [1., 1.], [0., 1.], [0., 0.]];
var net = new Dict;
var title;
var DJsterParams = {
"attenuation" : [0, 100, "linear"], //
"chordal_weight" : [1, 5, "linear"],//
"dynamics" : [0, 127, "linear"],//
"event_length" : [60, 600, "log"],//
"eventfulness" : [0, 100, "linear"],//
"harmoniclarity" : [0, 100, "linear"],//
"melodic_cohesion" : [-100, 100, "linear"],//
"melody_scope" : [0, 48, "linear"],//
"metriclarity" : [-100, 100, "linear"],//
"outset_pulses" : [1, 16, "linear"],//
"overlap" : [0, 1, "linear"],//
"pitch_center" : [12, 108, "linear"],//
"pitch_range" : [0, 48, "linear"],//
"scale" : [1, 5, "enum"],//
"sorted" : [0, 1, "linear"],//
"stream" : [0, 1, "linear"],//
"subdivision" : [1, 5, "enum"],//
"tempo" : [20, 200, "log"],//
"timesig_denominator" : [1, 5, "enum"],//
"timesig_numerator" : [1, 12, "linear"],//
"tonic_pitch" : [12, 108, "linear"],//
};
function dictionary(d)
{
net.name = d;
hsspiece[title]["networkData"] = JSON.parse(net.stringify());
outdict.parse(JSON.stringify(hsspiece));
outlet(0, "dictionary", outdict.name);
}
function writePiece()
{
var path = this.patcher.getnamed("machineLearning").subpatcher().getnamed("path").getvalueof();
net.export_json(path + "HSSPiece.json");
}
function anything()
{
var filenames = arrayfromargs(messagename, arguments);
for (var i = 0; i < filenames.length; i++)
{
presets[i] = new Dict;
presets[i].import_json(filenames[i]);
title = filenames[i].slice(filenames[i].lastIndexOf("/") + 1, filenames[i].lastIndexOf("."));
hsspiece[title] = {};
var slots = presets[i].get("pattrstorage::slots").getkeys();//number of slots here
post("slots", slots, "\n");
outlet(1, "clear");
for (var j = 0; j < slots.length; j++){
hsspiece[title][j + 1] = {};
var trainingData = [];
var data = JSON.parse(presets[i].get("pattrstorage::slots::" + (j + 1) + "::data").stringify());
for (var p = 0; p < 4; p++) {
delete data["Djster.µbus[" + p + "]::scales"];
delete data["Djster.µbus[" + p + "]::meters"];
for (var param in DJsterParams) {
var val = data["Djster.µbus[" + p + "]::" + param];
//post("params", hsspiece[title][j + 1]["Djster.µbus[" + p + "]::" + param], "\n");
switch (DJsterParams[param][2]) {
case "linear" :
trainingData.push(scale(val, DJsterParams[param][0], DJsterParams[param][1], 0., 1.));
break;
case "log" :
trainingData.push(scale(val, DJsterParams[param][0], DJsterParams[param][1], 0., 1.));
break;
case "enum" :
trainingData.push(0);
break;
}
}
var val = data["hub::instrument::instrument-" + (p + 1)];
trainingData.push(0);
}
//post("data", JSON.stringify(data), "\n");
hsspiece[title][j + 1] = data;
outlet(1, points[j].concat(trainingData));
outlet(1, "addPat");
}
outlet(1, "train", 10000);
}
}
function list()
{
var vector = arrayfromargs(arguments);
var keys = Object.keys(DJsterParams);
for (var i = 0; i < 4; i++) {
for (var j = 0; j < vector.length/4; j++) {
var k = j + i * vector.length/4;
switch (j) {
case 3 : //log
case 17 :
var val = scale(vector[k], 0, 1, DJsterParams[keys[j]][0], DJsterParams[keys[j]][1]);
outlet(2, "Djster.µbus[" + i + "]::" + keys[j], val);
break;
case 13 : //enum
val = "Major";
outlet(2, "Djster.µbus[" + i + "]::" + keys[j], val);
break;
case 16 :
val = "2 2 2";
outlet(2, "Djster.µbus[" + i + "]::" + keys[j], val);
break;
case 18 :
val = "4"
outlet(2, "Djster.µbus[" + i + "]::" + keys[j], val);
break;
case 21 :
val = "4"
outlet(2, "hub::instrument::instrument-" + (i + 1), val);
break;
default : //linear
var val = scale(vector[k], 0, 1, DJsterParams[keys[j]][0], DJsterParams[keys[j]][1]);
outlet(2, "Djster.µbus[" + i + "]::" + keys[j], val);
}
}
}
}
function scale(x, inputmin, inputmax, outputmin, outputmax)
{
return (x - inputmin) / (inputmax - inputmin) * (outputmax - outputmin) + outputmin;
}