pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
plink_UnaryOpProcess.h
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
 All Classes Functions Typedefs Enumerations Enumerator Properties