From e1abec66df4f1c071c3d25caa768fe1a98781a13 Mon Sep 17 00:00:00 2001 From: Hans-Christoph Steiner Date: Tue, 22 Aug 2006 00:58:25 +0000 Subject: appended creb/system/envelope_util.c as a temporary fix to get things compiling, like I did before svn path=/trunk/externals/creb/; revision=5703 --- modules/ead~.c | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) (limited to 'modules/ead~.c') diff --git a/modules/ead~.c b/modules/ead~.c index e58b08a..3e8a997 100644 --- a/modules/ead~.c +++ b/modules/ead~.c @@ -157,3 +157,36 @@ void ead_tilde_setup(void) gensym("decay"), A_FLOAT, 0); } +/* + * Utility functions for exponential decay + * Copyright (c) 2000-2003 by Tom Schouten + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + + +#include "extlib_util.h" + +float milliseconds_2_one_minus_realpole(float time) +{ + float r; + + if (time < 0.0f) time = 0.0f; + r = -expm1(1000.0f * log(ENVELOPE_RANGE) / (sys_getsr() * time)); + if (!(r < 1.0f)) r = 1.0f; + + //post("%f",r); + return r; +} -- cgit v1.2.1