view projects/heavy/samphold/ControlRandom.c @ 163:20b52283c7b4 heavy-updated

- added circular buffer pd/heavy example (works but process needs to be killed manually if launched via ssh?)
author chnrx <chris.heinrichs@gmail.com>
date Thu, 12 Nov 2015 15:55:30 +0000
parents 5bcf04234f80
children
line wrap: on
line source
/**
 * Copyright (c) 2014, 2015, Enzien Audio Ltd.
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
 * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
 * PERFORMANCE OF THIS SOFTWARE.
 */

#include "ControlRandom.h"
#include "HvBase.h"

// http://www.firstpr.com.au/dsp/rand31
// http://en.wikipedia.org/wiki/Lehmer_random_number_generator

hv_size_t cRandom_init(ControlRandom *o, int seed) {
  o->state = (seed != 0) ? seed : 1;
  return 0;
}

void cRandom_onMessage(HvBase *_c, ControlRandom *o, int inletIndex, const HvMessage *m,
    void (*sendMessage)(HvBase *, int, const HvMessage *)) {
  switch (inletIndex) {
    case 0: {
      HvMessage *n = HV_MESSAGE_ON_STACK(1);
      o->state = (int) ((((unsigned long long) o->state) * 279470273UL) % 4294967291UL);
      float f = ((float) (o->state >> 9)) * 0.00000011920929f;
      msg_initWithFloat(n, msg_getTimestamp(m), f);
      sendMessage(_c, 0, n);
      break;
    }
    case 1: {
      if (msg_isFloat(m,0)) {
        o->state = (int) msg_getFloat(m,0);
      }
      break;
    }
    default: break;
  }
}