aboutsummaryrefslogtreecommitdiffstats
path: root/src/hz_voct_4200.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2006-06-09 14:34:20 +0000
committerDavid Robillard <d@drobilla.net>2006-06-09 14:34:20 +0000
commit1ad3c632e91211ae84bc738eebd8d4a8318707c9 (patch)
treeb060300cf35069b227851f62f0957edb9006e989 /src/hz_voct_4200.c
Added omins
git-svn-id: http://svn.drobilla.net/lad/omins@8 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/hz_voct_4200.c')
-rw-r--r--src/hz_voct_4200.c242
1 files changed, 242 insertions, 0 deletions
diff --git a/src/hz_voct_4200.c b/src/hz_voct_4200.c
new file mode 100644
index 0000000..977a405
--- /dev/null
+++ b/src/hz_voct_4200.c
@@ -0,0 +1,242 @@
+/* Hz to AMS style V/Oct plugin. Copyright (C) 2005 Dave Robillard.
+ *
+ * This plugin 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 plugin 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
+ * 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.,
+ * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#define _XOPEN_SOURCE 500 /* strdup */
+#include <stdlib.h>
+#include <string.h>
+#include <math.h>
+
+#include "ladspa.h"
+
+#define HZVOCT_BASE_ID 4200
+
+#define HZVOCT_NUM_PORTS 2
+
+/* Port Numbers */
+#define HZVOCT_INPUT 0
+#define HZVOCT_OUTPUT 1
+
+
+/* All state information for plugin */
+typedef struct
+{
+ /* Ports */
+ LADSPA_Data* input_buffer;
+ LADSPA_Data* output_buffer;
+} HzVoct;
+
+
+/* Construct a new plugin instance */
+LADSPA_Handle
+hzvoct_instantiate(const LADSPA_Descriptor* descriptor,
+ unsigned long srate)
+{
+ HzVoct* plugin = malloc(sizeof(HzVoct));
+ plugin->input_buffer = NULL;
+ plugin->output_buffer = NULL;
+ return (LADSPA_Handle)plugin;
+}
+
+
+/* Connect a port to a data location */
+void
+hzvoct_connect_port(LADSPA_Handle instance,
+ unsigned long port,
+ LADSPA_Data* location)
+{
+ HzVoct* plugin;
+
+ plugin = (HzVoct*)instance;
+ switch (port) {
+ case HZVOCT_INPUT:
+ plugin->input_buffer = location;
+ break;
+ case HZVOCT_OUTPUT:
+ plugin->output_buffer = location;
+ break;
+ }
+}
+
+
+void
+hzvoct_run_cr(LADSPA_Handle instance, unsigned long nframes)
+{
+ HzVoct* plugin;
+ float log2inv;
+ float eighth = 1.0f/8.0f;
+ const float offset = 2.0313842f; // + octave, ... -1, 0, 1 ...
+
+ plugin = (HzVoct*)instance;
+ log2inv = 1.0f/logf(2.0f);
+
+ *plugin->output_buffer = logf(*plugin->input_buffer * eighth) * log2inv - offset;
+}
+
+
+void
+hzvoct_run_ar(LADSPA_Handle instance, unsigned long nframes)
+{
+ LADSPA_Data* input;
+ LADSPA_Data* output;
+ HzVoct* plugin;
+ unsigned long i;
+ float log2inv;
+ float eighth = 1.0f/8.0f;
+ const float offset = 5.0313842; // + octave, ... -1, 0, 1 ...
+
+ plugin = (HzVoct*)instance;
+ log2inv = 1.0f/logf(2.0);
+
+ input = plugin->input_buffer;
+ output = plugin->output_buffer;
+
+ // Inverse of the formula used in AMS's converter module (except the 1/8 part)
+ for (i = 0; i < nframes; i++)
+ *output++ = logf((*input++) * eighth) * log2inv - offset;
+}
+
+
+void
+hzvoct_cleanup(LADSPA_Handle instance)
+{
+ free(instance);
+}
+
+
+LADSPA_Descriptor* hz_voct_cr_desc = NULL;
+LADSPA_Descriptor* hz_voct_ar_desc = NULL;
+
+
+/* Called automatically when the plugin library is first loaded. */
+void
+_init()
+{
+ char** port_names;
+ LADSPA_PortDescriptor* port_descriptors;
+ LADSPA_PortRangeHint* port_range_hints;
+
+ hz_voct_cr_desc = (LADSPA_Descriptor*)malloc(sizeof(LADSPA_Descriptor));
+ hz_voct_ar_desc = (LADSPA_Descriptor*)malloc(sizeof(LADSPA_Descriptor));
+
+ if (hz_voct_cr_desc) {
+
+ hz_voct_cr_desc->UniqueID = HZVOCT_BASE_ID;
+ hz_voct_cr_desc->Label = strdup("hz_voct_cr");
+ hz_voct_cr_desc->Properties = LADSPA_PROPERTY_HARD_RT_CAPABLE;
+ hz_voct_cr_desc->Name = strdup("Hz to V/Oct Converter (CR)");
+ hz_voct_cr_desc->Maker = strdup("Dave Robillard");
+ hz_voct_cr_desc->Copyright = strdup("GPL");
+ hz_voct_cr_desc->PortCount = HZVOCT_NUM_PORTS;
+ port_descriptors = (LADSPA_PortDescriptor*)calloc(HZVOCT_NUM_PORTS, sizeof(LADSPA_PortDescriptor));
+ hz_voct_cr_desc->PortDescriptors = (const LADSPA_PortDescriptor*)port_descriptors;
+ port_descriptors[HZVOCT_INPUT] = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL;
+ port_descriptors[HZVOCT_OUTPUT] = LADSPA_PORT_OUTPUT | LADSPA_PORT_CONTROL;
+ port_names = (char**)calloc(HZVOCT_NUM_PORTS, sizeof(char*));
+ hz_voct_cr_desc->PortNames = (const char**)port_names;
+ port_names[HZVOCT_INPUT] = strdup("Input");
+ port_names[HZVOCT_OUTPUT] = strdup("Output");
+ port_range_hints = ((LADSPA_PortRangeHint *)
+ calloc(HZVOCT_NUM_PORTS, sizeof(LADSPA_PortRangeHint)));
+ hz_voct_cr_desc->PortRangeHints = (const LADSPA_PortRangeHint*)port_range_hints;
+ port_range_hints[HZVOCT_INPUT].HintDescriptor = 0;
+ port_range_hints[HZVOCT_OUTPUT].HintDescriptor = 0;
+ hz_voct_cr_desc->instantiate = hzvoct_instantiate;
+ hz_voct_cr_desc->connect_port = hzvoct_connect_port;
+ hz_voct_cr_desc->activate = NULL;
+ hz_voct_cr_desc->run = hzvoct_run_cr;
+ hz_voct_cr_desc->run_adding = NULL;
+ hz_voct_cr_desc->set_run_adding_gain = NULL;
+ hz_voct_cr_desc->deactivate = NULL;
+ hz_voct_cr_desc->cleanup = hzvoct_cleanup;
+ }
+
+ if (hz_voct_ar_desc) {
+
+ hz_voct_ar_desc->UniqueID = HZVOCT_BASE_ID+1;
+ hz_voct_ar_desc->Label = strdup("hz_voct_ar");
+ hz_voct_ar_desc->Properties = LADSPA_PROPERTY_HARD_RT_CAPABLE;
+ hz_voct_ar_desc->Name = strdup("Hz to V/Oct Converter (AR)");
+ hz_voct_ar_desc->Maker = strdup("Dave Robillard");
+ hz_voct_ar_desc->Copyright = strdup("GPL");
+ hz_voct_ar_desc->PortCount = HZVOCT_NUM_PORTS;
+ port_descriptors = (LADSPA_PortDescriptor*)calloc(HZVOCT_NUM_PORTS, sizeof(LADSPA_PortDescriptor));
+ hz_voct_ar_desc->PortDescriptors = (const LADSPA_PortDescriptor*)port_descriptors;
+ port_descriptors[HZVOCT_INPUT] = LADSPA_PORT_INPUT | LADSPA_PORT_AUDIO;
+ port_descriptors[HZVOCT_OUTPUT] = LADSPA_PORT_OUTPUT | LADSPA_PORT_AUDIO;
+ port_names = (char**)calloc(HZVOCT_NUM_PORTS, sizeof(char*));
+ hz_voct_ar_desc->PortNames = (const char**)port_names;
+ port_names[HZVOCT_INPUT] = strdup("Input");
+ port_names[HZVOCT_OUTPUT] = strdup("Output");
+ port_range_hints = ((LADSPA_PortRangeHint *)
+ calloc(HZVOCT_NUM_PORTS, sizeof(LADSPA_PortRangeHint)));
+ hz_voct_ar_desc->PortRangeHints = (const LADSPA_PortRangeHint*)port_range_hints;
+ port_range_hints[HZVOCT_INPUT].HintDescriptor = 0;
+ port_range_hints[HZVOCT_OUTPUT].HintDescriptor = 0;
+ hz_voct_ar_desc->instantiate = hzvoct_instantiate;
+ hz_voct_ar_desc->connect_port = hzvoct_connect_port;
+ hz_voct_ar_desc->activate = NULL;
+ hz_voct_ar_desc->run = hzvoct_run_ar;
+ hz_voct_ar_desc->run_adding = NULL;
+ hz_voct_ar_desc->set_run_adding_gain = NULL;
+ hz_voct_ar_desc->deactivate = NULL;
+ hz_voct_ar_desc->cleanup = hzvoct_cleanup;
+ }
+}
+
+
+void
+hzvoct_delete_descriptor(LADSPA_Descriptor* psDescriptor)
+{
+ unsigned long lIndex;
+ if (psDescriptor) {
+ free((char*)psDescriptor->Label);
+ free((char*)psDescriptor->Name);
+ free((char*)psDescriptor->Maker);
+ free((char*)psDescriptor->Copyright);
+ free((LADSPA_PortDescriptor *)psDescriptor->PortDescriptors);
+ for (lIndex = 0; lIndex < psDescriptor->PortCount; lIndex++)
+ free((char*)(psDescriptor->PortNames[lIndex]));
+ free((char**)psDescriptor->PortNames);
+ free((LADSPA_PortRangeHint *)psDescriptor->PortRangeHints);
+ free(psDescriptor);
+ }
+}
+
+
+/* Called automatically when the library is unloaded. */
+void
+_fini()
+{
+ hzvoct_delete_descriptor(hz_voct_cr_desc);
+ hzvoct_delete_descriptor(hz_voct_ar_desc);
+}
+
+
+/* Return a descriptor of the requested plugin type. */
+const LADSPA_Descriptor*
+ladspa_descriptor(unsigned long Index)
+{
+ switch (Index) {
+ case 0:
+ return hz_voct_cr_desc;
+ case 1:
+ return hz_voct_ar_desc;
+ default:
+ return NULL;
+ }
+}
+