#include "HetrickCV.hpp" namespace rack_plugin_HetrickCV { struct Comparator : Module { enum ParamIds { AMOUNT_PARAM, SCALE_PARAM, NUM_PARAMS }; enum InputIds { MAIN_INPUT, AMOUNT_INPUT, NUM_INPUTS }; enum OutputIds { GT_GATE_OUTPUT, GT_TRIG_OUTPUT, LT_GATE_OUTPUT, LT_TRIG_OUTPUT, ZEROX_OUTPUT, NUM_OUTPUTS }; enum LightIds { GT_LIGHT, LT_LIGHT, ZEROX_LIGHT, NUM_LIGHTS }; Comparator() : Module(NUM_PARAMS, NUM_INPUTS, NUM_OUTPUTS, NUM_LIGHTS) { } TriggerGenWithSchmitt ltTrig, gtTrig; void step() override; // For more advanced Module features, read Rack's engine.hpp header file // - toJson, fromJson: serialization of internal data // - onSampleRateChange: event triggered by a change of sample rate // - reset, randomize: implements special behavior when user clicks these from the context menu }; void Comparator::step() { float input = inputs[MAIN_INPUT].value; float compare = params[AMOUNT_PARAM].value + (inputs[AMOUNT_INPUT].value * params[SCALE_PARAM].value); compare = clampf(compare, -5.0f, 5.0f); const bool greaterThan = (input > compare); const bool lessThan = (input < compare); outputs[GT_TRIG_OUTPUT].value = gtTrig.process(greaterThan) ? 5.0f : 0.0f; outputs[LT_TRIG_OUTPUT].value = ltTrig.process(lessThan) ? 5.0f : 0.0f; outputs[GT_GATE_OUTPUT].value = greaterThan ? 5.0f : 0.0f; outputs[LT_GATE_OUTPUT].value = lessThan ? 5.0f : 0.0f; float allTrigs = outputs[GT_TRIG_OUTPUT].value + outputs[LT_TRIG_OUTPUT].value; allTrigs = clampf(allTrigs, 0.0f, 5.0f); outputs[ZEROX_OUTPUT].value = allTrigs; lights[GT_LIGHT].setBrightnessSmooth(outputs[GT_GATE_OUTPUT].value); lights[LT_LIGHT].setBrightnessSmooth(outputs[LT_GATE_OUTPUT].value); lights[ZEROX_LIGHT].setBrightnessSmooth(allTrigs); } struct ComparatorWidget : ModuleWidget { ComparatorWidget(Comparator *module); }; ComparatorWidget::ComparatorWidget(Comparator* module) : ModuleWidget(module) { box.size = Vec(6 * RACK_GRID_WIDTH, RACK_GRID_HEIGHT); { auto *panel = new SVGPanel(); panel->box.size = box.size; panel->setBackground(SVG::load(assetPlugin(plugin, "res/Comparator.svg"))); addChild(panel); } addChild(Widget::create(Vec(15, 0))); addChild(Widget::create(Vec(box.size.x - 30, 0))); addChild(Widget::create(Vec(15, 365))); addChild(Widget::create(Vec(box.size.x - 30, 365))); //////PARAMS////// addParam(ParamWidget::create(Vec(27, 62), module, Comparator::AMOUNT_PARAM, -5.0, 5.0, 0.0)); addParam(ParamWidget::create(Vec(36, 112), module, Comparator::SCALE_PARAM, -1.0, 1.0, 1.0)); //////INPUTS////// addInput(Port::create(Vec(33, 195), Port::INPUT, module, Comparator::MAIN_INPUT)); addInput(Port::create(Vec(33, 145), Port::INPUT, module, Comparator::AMOUNT_INPUT)); //////OUTPUTS////// addOutput(Port::create(Vec(12, 285), Port::OUTPUT, module, Comparator::LT_GATE_OUTPUT)); addOutput(Port::create(Vec(53, 285), Port::OUTPUT, module, Comparator::GT_GATE_OUTPUT)); addOutput(Port::create(Vec(12, 315), Port::OUTPUT, module, Comparator::LT_TRIG_OUTPUT)); addOutput(Port::create(Vec(53, 315), Port::OUTPUT, module, Comparator::GT_TRIG_OUTPUT)); addOutput(Port::create(Vec(32.5, 245), Port::OUTPUT, module, Comparator::ZEROX_OUTPUT)); //////BLINKENLIGHTS////// addChild(ModuleLightWidget::create>(Vec(22, 275), module, Comparator::LT_LIGHT)); addChild(ModuleLightWidget::create>(Vec(62, 275), module, Comparator::GT_LIGHT)); addChild(ModuleLightWidget::create>(Vec(42, 275), module, Comparator::ZEROX_LIGHT)); } } // namespace rack_plugin_HetrickCV using namespace rack_plugin_HetrickCV; RACK_PLUGIN_MODEL_INIT(HetrickCV, Comparator) { Model *modelComparator = Model::create("HetrickCV", "Comparator", "Comparator", LOGIC_TAG); return modelComparator; }