ardour
utils.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 1999 Paul Davis
3 
4  This program is free software; you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or
7  (at your option) any later version.
8 
9  This program is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with this program; if not, write to the Free Software
16  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 
18 */
19 
20 #ifndef __ardour_utils_h__
21 #define __ardour_utils_h__
22 
23 #ifdef WAF_BUILD
24 #include "libardour-config.h"
25 #endif
26 
27 #include <iostream>
28 #include <string>
29 #include <cmath>
30 
31 #if __APPLE__
32 #include <CoreFoundation/CoreFoundation.h>
33 #endif /* __APPLE__ */
34 
36 #include "ardour/ardour.h"
37 #include "ardour/data_type.h"
38 #include "ardour/dB.h"
39 
40 class XMLNode;
41 
42 namespace ARDOUR {
43 
44 LIBARDOUR_API std::string legalize_for_path (const std::string& str);
45 LIBARDOUR_API std::string legalize_for_universal_path (const std::string& str);
46 LIBARDOUR_API std::string legalize_for_uri (const std::string& str);
47 LIBARDOUR_API std::string legalize_for_path_2X (const std::string& str);
48 LIBARDOUR_API XMLNode* find_named_node (const XMLNode& node, std::string name);
49 LIBARDOUR_API std::string bool_as_string (bool);
50 
51 static inline float f_max(float x, float a) {
52  x -= a;
53  x += fabsf (x);
54  x *= 0.5f;
55  x += a;
56 
57  return (x);
58 }
59 
60 LIBARDOUR_API std::string bump_name_once(const std::string& s, char delimiter);
61 LIBARDOUR_API std::string bump_name_number(const std::string& s);
62 
63 LIBARDOUR_API int cmp_nocase (const std::string& s, const std::string& s2);
64 LIBARDOUR_API int cmp_nocase_utf8 (const std::string& s1, const std::string& s2);
65 
66 LIBARDOUR_API int touch_file(std::string path);
67 
68 LIBARDOUR_API std::string region_name_from_path (std::string path, bool strip_channels, bool add_channel_suffix = false, uint32_t total = 0, uint32_t this_one = 0);
69 LIBARDOUR_API bool path_is_paired (std::string path, std::string& pair_base);
70 
71 LIBARDOUR_API void compute_equal_power_fades (ARDOUR::framecnt_t nframes, float* in, float* out);
72 
73 LIBARDOUR_API const char* sync_source_to_string (ARDOUR::SyncSource src, bool sh = false);
75 
78 
79 #undef OLD_GAIN_MATH
80 #define OLD_GAIN_MATH
81 
82 static inline double
84 {
85  if (g == 0) return 0;
86 
87 #ifndef OLD_GAIN_MATH
88  /* Power Law With Exponential Cutoff 2D, fit to data from TC Spectra
89  console (image of fader gradations
90 
91  y = C * x(-T) * exp(-x/K)
92 
93  C = 8.2857630370864188E-01
94  T = -5.1526743785019269E-01
95  K = 7.8990885960495589E+00
96 
97  */
98 
99  return 8.2857630370864188E-01 * pow(g,5.1526743785019269E-01) * exp (-g/7.8990885960495589E+00);
100 #else
101  return pow((6.0*log(g)/log(2.0)+192.0)/198.0, 8.0);
102 #endif
103 }
104 
105 static inline ARDOUR::gain_t
107 {
108  if (pos == 0.0) {
109  return 0.0;
110  }
111 
112 #ifndef OLD_GAIN_MATH
113  /* 5th order polynomial function fit to data from a TC Spectra console
114  fader (image of fader gradations).
115 
116  y = a + bx1 + cx2 + dx3 + fx4 + gx5
117 
118  a = -1.1945480381045521E-02
119  b = 1.5809476525537265E+00
120  c = -1.5850710838966151E+01
121  d = 6.1643128605961991E+01
122  f = -8.5525246160607693E+01
123  g = 4.1312725896188283E+01
124 
125  */
126 
127  double p = pos;
128  double g = -1.1945480381045521E-02;
129 
130  g += 1.5809476525537265E+00 * pos;
131  pos *= p;
132  g += -1.5850710838966151E+01 * pos;
133  pos *= p;
134  g += 6.1643128605961991E+01 * pos;
135  pos *= p;
136  g += -8.5525246160607693E+01 * pos;
137  pos *= p;
138  g += 4.1312725896188283E+01 * pos;
139 
140  return g;
141 #else
142  /* XXX Marcus writes: this doesn't seem right to me. but i don't have a better answer ... */
143  if (pos == 0.0) return 0;
144  return pow (2.0,(sqrt(sqrt(sqrt(pos)))*198.0-192.0)/6.0);
145 #endif
146 }
147 #undef OLD_GAIN_MATH
148 
149 LIBARDOUR_API double gain_to_slider_position_with_max (double g, double max_gain = 2.0);
150 LIBARDOUR_API double slider_position_to_gain_with_max (double g, double max_gain = 2.0);
151 
152 /* I don't really like hard-coding these falloff rates here
153  * Probably should use a map of some kind that could be configured
154  * These rates are db/sec.
155 */
156 
157 #define METER_FALLOFF_OFF 0.0f
158 #define METER_FALLOFF_SLOWEST 6.6f // BBC standard
159 #define METER_FALLOFF_SLOW 8.6f // BBC standard, EBU 24dB / 2.8sec
160 #define METER_FALLOFF_SLOWISH 12.0f // DIN 20dB / 1.7 sec
161 #define METER_FALLOFF_MODERATE 13.3f // EBU-PPM, IRT PPM- 20dB / 1.5 sec
162 #define METER_FALLOFF_MEDIUM 20.0f
163 #define METER_FALLOFF_FAST 32.0f
164 #define METER_FALLOFF_FASTER 46.0f
165 #define METER_FALLOFF_FASTEST 70.0f
166 
170 
172 LIBARDOUR_API bool matching_unsuffixed_filename_exists_in (const std::string& dir, const std::string& name);
173 
175 
176 #if __APPLE__
177 LIBARDOUR_API std::string CFStringRefToStdString(CFStringRef stringRef);
178 #endif // __APPLE__
179 
180 } //namespave
181 
182 #endif /* __ardour_utils_h__ */
183 
LIBARDOUR_API ARDOUR::MeterFalloff meter_falloff_from_float(float)
Definition: utils.cc:535
HeaderFormat
Definition: types.h:475
static double gain_to_slider_position(ARDOUR::gain_t g)
Definition: utils.h:83
LIBARDOUR_API bool path_is_paired(std::string path, std::string &pair_base)
SyncSource
Definition: types.h:498
LIBARDOUR_API void compute_equal_power_fades(ARDOUR::framecnt_t nframes, float *in, float *out)
Definition: utils.cc:394
LIBARDOUR_API std::string legalize_for_uri(const std::string &str)
LIBARDOUR_API std::string legalize_for_path(const std::string &str)
LIBARDOUR_API double slider_position_to_gain_with_max(double g, double max_gain=2.0)
Definition: utils.cc:762
LIBARDOUR_API const char * sync_source_to_string(ARDOUR::SyncSource src, bool sh=false)
Definition: utils.cc:477
LIBARDOUR_API float meter_falloff_to_db_per_sec(float)
float gain_t
Definition: types.h:58
LIBARDOUR_API uint32_t how_many_dsp_threads()
Definition: utils.cc:722
LIBARDOUR_API int touch_file(std::string path)
LIBARDOUR_API bool matching_unsuffixed_filename_exists_in(const std::string &dir, const std::string &name)
LIBARDOUR_API ARDOUR::EditMode string_to_edit_mode(std::string)
int64_t framecnt_t
Definition: types.h:76
LIBARDOUR_API std::string legalize_for_path_2X(const std::string &str)
Definition: amp.h:29
LIBARDOUR_API ARDOUR::SyncSource string_to_sync_source(std::string str)
LIBARDOUR_API int cmp_nocase_utf8(const std::string &s1, const std::string &s2)
EditMode
Definition: types.h:351
LIBARDOUR_API XMLNode * find_named_node(const XMLNode &node, std::string name)
LIBARDOUR_API int cmp_nocase(const std::string &s, const std::string &s2)
LIBARDOUR_API std::string bump_name_number(const std::string &s)
Definition: utils.cc:200
#define LIBARDOUR_API
LIBARDOUR_API std::string bump_name_once(const std::string &s, char delimiter)
Definition: utils.cc:158
LIBARDOUR_API double gain_to_slider_position_with_max(double g, double max_gain=2.0)
Definition: utils.cc:756
const char * name
LIBARDOUR_API std::string legalize_for_universal_path(const std::string &str)
Definition: xml++.h:95
LIBARDOUR_API const char * edit_mode_to_string(ARDOUR::EditMode)
Definition: utils.cc:437
LIBARDOUR_API std::string bool_as_string(bool)
Definition: utils.cc:642
LIBARDOUR_API float meter_falloff_to_float(ARDOUR::MeterFalloff)
Definition: utils.cc:508
static float f_max(float x, float a)
Definition: utils.h:51
LIBARDOUR_API std::string region_name_from_path(std::string path, bool strip_channels, bool add_channel_suffix=false, uint32_t total=0, uint32_t this_one=0)
MeterFalloff
Definition: types.h:332
static ARDOUR::gain_t slider_position_to_gain(double pos)
Definition: utils.h:106
LIBARDOUR_API const char * native_header_format_extension(ARDOUR::HeaderFormat, const ARDOUR::DataType &type)
Definition: utils.cc:648