counter3

cyclic up/down counter with input for up or down
Author: Johannes Taelman
License: BSD
Github: phi/logic/counter3.axo

Inlets

bool32.rising increment trigger

bool32.rising decrement trigger

bool32.rising reset

Outlets

int32 output

bool32.pulse carry pulse

Parameters

int32 maximum

Declaration
int ntrig;
int rtrig;
int dtrig;
int count;
Init
count = 0;
ntrig = 0;
dtrig = 0;
rtrig = 0;
Control Rate
outlet_c = 0;
if ((((inlet_trig > 0) && (inlet_updown < 1))) && !ntrig) {
  count++;
  if (count >= param_maximum) {
    count = 0;
    outlet_c = 1;
  }
  ntrig = 1;
} else if (!(inlet_trig > 0))
  ntrig = 0;
if ((((inlet_updown > 0) && (inlet_trig))) && !dtrig) {
  count--;
  if (count < 0) {
    count = param_maximum - 1;
    outlet_c = 1;
  }
  dtrig = 1;
} else if (!((inlet_updown > 0) && (inlet_trig)))
  dtrig = 0;
if ((inlet_r > 0) && !rtrig) {
  count = 0;
  rtrig = 1;
} else if (!(inlet_r > 0))
  rtrig = 0;
outlet_o = count;

Privacy

© 2024 Zrna Research