![]() |
pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
|
00001 /* 00002 ------------------------------------------------------------------------------- 00003 This file is part of the Plink, Plonk, Plank libraries 00004 by Martin Robinson 00005 00006 http://code.google.com/p/pl-nk/ 00007 00008 Copyright University of the West of England, Bristol 2011-14 00009 All rights reserved. 00010 00011 Redistribution and use in source and binary forms, with or without 00012 modification, are permitted provided that the following conditions are met: 00013 00014 * Redistributions of source code must retain the above copyright 00015 notice, this list of conditions and the following disclaimer. 00016 * Redistributions in binary form must reproduce the above copyright 00017 notice, this list of conditions and the following disclaimer in the 00018 documentation and/or other materials provided with the distribution. 00019 * Neither the name of University of the West of England, Bristol nor 00020 the names of its contributors may be used to endorse or promote products 00021 derived from this software without specific prior written permission. 00022 00023 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 00024 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 00025 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00026 DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF THE WEST OF ENGLAND, BRISTOL BE 00027 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00028 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 00029 GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 00030 HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00031 LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 00032 OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00033 00034 This software makes use of third party libraries. For more information see: 00035 doc/license.txt included in the distribution. 00036 ------------------------------------------------------------------------------- 00037 */ 00038 00039 #ifndef PLINK_UNARYOPPROCESS_H 00040 #define PLINK_UNARYOPPROCESS_H 00041 00042 #include "../plink_Process.h" 00043 00044 00052 #define PLINK_UNARYOPPROCESS_DEFINE_NN(OPNAME, TYPECODE)\ 00053 void plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _NN (void* ppv, UnaryState* state) {\ 00054 PlinkProcess##TYPECODE* pp; PlankUL N; Plank##TYPECODE* output; const Plank##TYPECODE* input;\ 00055 (void)state;\ 00056 pp = (PlinkProcess##TYPECODE*)ppv;\ 00057 N = pp->buffers[0].bufferSize;\ 00058 output = pp->buffers[0].buffer;\ 00059 input = pp->buffers[1].buffer;\ 00060 PLANK_VECTORUNARYOP_NAME(OPNAME,TYPECODE) (output, input, N);\ 00061 } 00062 00063 #define PLINK_UNARYOPPROCESS_DEFINE_N1(OPNAME, TYPECODE)\ 00064 void plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _N1 (void* ppv, UnaryState* state) {\ 00065 PlinkProcess##TYPECODE* pp; PlankUL N; Plank##TYPECODE* output; Plank##TYPECODE value;\ 00066 (void)state;\ 00067 pp = (PlinkProcess##TYPECODE*)ppv;\ 00068 N = pp->buffers[0].bufferSize;\ 00069 output = pp->buffers[0].buffer;\ 00070 value = pl_##OPNAME##TYPECODE (pp->buffers[1].buffer[0]);\ 00071 PLANK_VECTORFILL_NAME(TYPECODE) (output, value, N);\ 00072 } 00073 00074 #define PLINK_UNARYOPPROCESS_DEFINE_Nn(OPNAME, TYPECODE)\ 00075 void plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _Nn (void* ppv, UnaryState* state) {\ 00076 PlinkProcess##TYPECODE* pp; PlankUL N, i; Plank##TYPECODE* output; const Plank##TYPECODE* input;\ 00077 double inputPos, inputInc;\ 00078 (void)state;\ 00079 pp = (PlinkProcess##TYPECODE*)ppv;\ 00080 N = pp->buffers[0].bufferSize;\ 00081 output = pp->buffers[0].buffer;\ 00082 input = pp->buffers[1].buffer;\ 00083 inputPos = 0.0;\ 00084 inputInc = (double)pp->buffers[1].bufferSize / (double)N;\ 00085 for (i = 0; i < N; ++i) {\ 00086 output[i] = pl_##OPNAME##TYPECODE (input[(int)inputPos]);\ 00087 inputPos += inputInc;\ 00088 }\ 00089 } 00090 00091 #define PLINK_UNARYOPPROCESS_DEFINE_SELECT(OPNAME, TYPECODE)\ 00092 void plink_UnaryOpProcess ## OPNAME ## TYPECODE (void* ppv, UnaryState* state) {\ 00093 PlinkProcess##TYPECODE* pp; PlankUL N, n;\ 00094 (void)state;\ 00095 pp = (PlinkProcess##TYPECODE*)ppv;\ 00096 N = pp->buffers[0].bufferSize;\ 00097 n = pp->buffers[1].bufferSize;\ 00098 if (n == N) plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _NN (ppv, 0);\ 00099 else if (n == 1) plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _N1 (ppv, 0);\ 00100 else plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _Nn (ppv, 0);\ 00101 } 00102 00103 00104 #define PLINK_UNARYOPPROCESS_DECLARE(OPNAME, TYPECODE)\ 00105 void PLINK_API plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _NN (void* pp, UnaryState* state);\ 00106 void PLINK_API plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _N1 (void* pp, UnaryState* state);\ 00107 void PLINK_API plink_UnaryOpProcess ## OPNAME ## TYPECODE ## _Nn (void* pp, UnaryState* state);\ 00108 void PLINK_API plink_UnaryOpProcess ## OPNAME ## TYPECODE (void* pp, UnaryState* state); 00109 00110 #define PLINK_UNARYOPPROCESS_DEFINE(OPNAME, TYPECODE)\ 00111 PLINK_UNARYOPPROCESS_DEFINE_NN(OPNAME, TYPECODE)\ 00112 PLINK_UNARYOPPROCESS_DEFINE_N1(OPNAME, TYPECODE)\ 00113 PLINK_UNARYOPPROCESS_DEFINE_Nn(OPNAME, TYPECODE)\ 00114 PLINK_UNARYOPPROCESS_DEFINE_SELECT(OPNAME, TYPECODE) 00115 00117 00118 00119 PLINK_BEGIN_C_LINKAGE 00120 00128 typedef PlinkState UnaryState; 00129 00130 PLINK_UNARYOPPROCESS_DECLARE(Move, F) 00131 PLINK_UNARYOPPROCESS_DECLARE(Inc, F) 00132 PLINK_UNARYOPPROCESS_DECLARE(Neg, F) 00133 PLINK_UNARYOPPROCESS_DECLARE(Abs, F) 00134 PLINK_UNARYOPPROCESS_DECLARE(Log2, F) 00135 PLINK_UNARYOPPROCESS_DECLARE(Reciprocal, F) 00136 PLINK_UNARYOPPROCESS_DECLARE(Sin, F) 00137 PLINK_UNARYOPPROCESS_DECLARE(Cos, F) 00138 PLINK_UNARYOPPROCESS_DECLARE(Tan, F) 00139 PLINK_UNARYOPPROCESS_DECLARE(Asin, F) 00140 PLINK_UNARYOPPROCESS_DECLARE(Acos, F) 00141 PLINK_UNARYOPPROCESS_DECLARE(Atan, F) 00142 PLINK_UNARYOPPROCESS_DECLARE(Sinh, F) 00143 PLINK_UNARYOPPROCESS_DECLARE(Cosh, F) 00144 PLINK_UNARYOPPROCESS_DECLARE(Tanh, F) 00145 PLINK_UNARYOPPROCESS_DECLARE(Sqrt, F) 00146 PLINK_UNARYOPPROCESS_DECLARE(Log, F) 00147 PLINK_UNARYOPPROCESS_DECLARE(Log10, F) 00148 PLINK_UNARYOPPROCESS_DECLARE(Exp, F) 00149 PLINK_UNARYOPPROCESS_DECLARE(Squared, F) 00150 PLINK_UNARYOPPROCESS_DECLARE(Cubed, F) 00151 PLINK_UNARYOPPROCESS_DECLARE(Ceil, F) 00152 PLINK_UNARYOPPROCESS_DECLARE(Floor, F) 00153 PLINK_UNARYOPPROCESS_DECLARE(Frac, F) 00154 PLINK_UNARYOPPROCESS_DECLARE(Sign, F) 00155 PLINK_UNARYOPPROCESS_DECLARE(M2F, F) 00156 PLINK_UNARYOPPROCESS_DECLARE(F2M, F) 00157 PLINK_UNARYOPPROCESS_DECLARE(A2dB, F) 00158 PLINK_UNARYOPPROCESS_DECLARE(dB2A, F) 00159 PLINK_UNARYOPPROCESS_DECLARE(D2R, F) 00160 PLINK_UNARYOPPROCESS_DECLARE(R2D, F) 00161 PLINK_UNARYOPPROCESS_DECLARE(Distort, F) 00162 PLINK_UNARYOPPROCESS_DECLARE(Zap, F) 00163 00165 00166 PLINK_END_C_LINKAGE 00167 00168 #endif // PLINK_UNARYOPPROCESS_H