-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathomax_realtime.h
86 lines (64 loc) · 2.87 KB
/
omax_realtime.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/** @file osc_realtime.h
Real-time support for signal processing
@author John MacCallum, Andy Schmeder
*/
/*
Copyright (c) 2009, 13. The Regents of the University of California (Regents).
All Rights Reserved.
Permission to use, copy, modify, and distribute this software and its
documentation for educational, research, and not-for-profit purposes, without
fee and without a signed licensing agreement, is hereby granted, provided that
the above copyright notice, this paragraph and the following two paragraphs
appear in all copies, modifications, and distributions. Contact The Office of
Technology Licensing, UC Berkeley, 2150 Shattuck Avenue, Suite 510, Berkeley,
CA 94720-1620, (510) 643-7201, for commercial licensing opportunities.
Written by John MacCallum, Andy Schmeder, The Center for New Music and
Audio Technologies, University of California, Berkeley.
IN NO EVENT SHALL REGENTS BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS,
ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
REGENTS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
REGENTS SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
FOR A PARTICULAR PURPOSE. THE SOFTWARE AND ACCOMPANYING
DOCUMENTATION, IF ANY, PROVIDED HEREUNDER IS PROVIDED "AS IS".
REGENTS HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES,
ENHANCEMENTS, OR MODIFICATIONS.
*/
#ifndef __OMAX_REALTIME_H__
#define __OMAX_REALTIME_H__
#include "osc_timetag.h"
typedef struct _omax_realtime_clock {
double dt0; // a priori expected time between ticks
double dt; // expected time between ticks
int n; // number of frame ticks
double fc; // filter cutoff (0.0-1.0), controls how aggressively clock filters jitter
double w; // w = 2 PI lp
double b; // sqrt(2) * w
double c; // w^2
double dt_error; // jitter of clock on last tick
//struct ntptime t0;
//struct ntptime t1;
t_osc_timetag t0, t1;
int running;
void* trigger;
} t_omax_realtime_clock;
t_omax_realtime_clock* omax_realtime_clock_get_master();
// initialize clock with a dt0
// this goes in an object's class creation function
void omax_realtime_clock_init();
// set the filter cutoff, not user-adjustable
void omax_realtime_clock_set_fc(double fc0);
// update the clock
// call this before calling now or next
void omax_realtime_clock_tick(void *x);
// when is now
void omax_realtime_clock_now(t_osc_timetag *t);
// when is next
void omax_realtime_clock_next(t_osc_timetag *t);
// how long until next in seconds
double omax_realtime_clock_dt();
// register interest in the clock
// this goes in an object's instance creation function
void omax_realtime_clock_register();
#endif