multi2

8 logic functions for 2 inputs 4th mode samples logic outcome at rising edge, but updates output after the rising edge->eg. for generative logic feedback networks
Author: Remco van der Most
License: BSD
Github: sss/logic/multi2.axo

Inlets

int32 logic mode: 0=AND,1=NAND,2=OR,3=NOR,4=XOR,5=XNOR,6=S&H,7=T&H

int32 update mode: 0=direct,1=when i1 changes,2=when i2 changes,3=when either one changes

bool32 input 1

bool32 input 2

bool32 trg

Outlets

bool32 output

Parameters

int32 logic mode: 0=AND,1=NAND,2=OR,3=NOR,4=XOR,5=XNOR,6=S&H,7=T&H. Selector works as an offset, outcome is wrapped within list size

int32 update mode: 0=direct,1=when i1 changes,2=when i2 changes,3=when either one changes. Selector works as an offset, outcome is wrapped within list size

Displays

bool32 o1

Declaration
int bt, bit, s, S, p1, p2, mode, trg;
Control Rate
int upd = inlet_update + param_update % 5;
switch (upd) {
case 0:
  mode = inlet_mode + param_mode;
  break; // direct update
case 1:
  if (!(p1 == inlet_i1)) // update when i1 changes
  {
    mode = inlet_mode + param_mode;
  }
  break;
case 2:
  if (!(p2 == inlet_i2)) // update when i2 changes
  {
    mode = inlet_mode + param_mode;
  }
  break;
case 3:
  if ((!(p1 == inlet_i1)) ||
      (!(p2 == inlet_i2))) // update when either i1 or i2 changes
  {
    mode = inlet_mode + param_mode;
  }
  break;
case 4:
  mode = inlet_mode + param_mode;
  break; // update triggered by trg input
}
p1 = inlet_i1;
p2 = inlet_i2;
int o;
switch (mode & 7) {
case 0:
  o = (inlet_i1) && (inlet_i2);
  break; // AND
case 1:
  o = !((inlet_i1) && (inlet_i2));
  break; // NAND
case 2:
  o = ((inlet_i1) || (inlet_i2));
  break; // OR
case 3:
  o = !((inlet_i1) || (inlet_i2));
  break; // NOR
case 4:
  o = !((inlet_i1) == (inlet_i2));
  break; // XOR
case 5:
  o = ((inlet_i1) == (inlet_i2));
  break; // XNOR
case 6:
  if (inlet_i2 && !bt) {
    bt = 1;
    bit = inlet_i1;
  } else if (bt && !inlet_i2) {
    bt = 0;
  }
  o = bit;
  break; // sample&hold bit
case 7:
  if (inlet_i2) {
    bit = inlet_i1;
  }
  o = bit;
  break; // track&hold bit
}

if (upd == 4) {
  S = s;
  if (inlet_trg && !trg) {
    trg = 1;
    s = o;
  } else if (trg && !inlet_trg) {
    trg = 0;
  }
} else {
  S = o;
}
outlet_o = S;

disp_o1 = S;

Privacy

© 2025 Zrna Research