/* TA-LIB Copyright (c) 1999-2007, Mario Fortier * All rights reserved. * * Redistribution and use in source and binary forms, with or * without modification, are permitted provided that the following * conditions are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * - Neither name of author nor the names of its contributors * may be used to endorse or promote products derived from this * software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /********************************************************************* * This file contains only TA functions starting with the letter 'L' * *********************************************************************/ #include #include "ta_abstract.h" #include "ta_def_ui.h" /* Follow the 3 steps defined below for adding a new TA Function to this * file. */ /**************************************************************************** * Step 1 - Define here the interface to your TA functions with * the macro DEF_FUNCTION. * ****************************************************************************/ /* LINEARREG BEGIN */ static const TA_InputParameterInfo *TA_LINEARREG_Inputs[] = { &TA_DEF_UI_Input_Real, NULL }; static const TA_OutputParameterInfo *TA_LINEARREG_Outputs[] = { &TA_DEF_UI_Output_Real, NULL }; static const TA_OptInputParameterInfo *TA_LINEARREG_OptInputs[] = { &TA_DEF_UI_TimePeriod_14_MINIMUM2, NULL }; DEF_FUNCTION( LINEARREG, /* name */ TA_GroupId_Statistic,/* groupId */ "Linear Regression", /* hint */ "LinearReg", /* CamelCase name */ TA_FUNC_FLG_OVERLAP /* flags */ ); /* LINEARREG END */ /* LINEARREG_SLOPE BEGIN */ static const TA_InputParameterInfo *TA_LINEARREG_SLOPE_Inputs[] = { &TA_DEF_UI_Input_Real, NULL }; static const TA_OutputParameterInfo *TA_LINEARREG_SLOPE_Outputs[] = { &TA_DEF_UI_Output_Real, NULL }; static const TA_OptInputParameterInfo *TA_LINEARREG_SLOPE_OptInputs[] = { &TA_DEF_UI_TimePeriod_14_MINIMUM2, NULL }; DEF_FUNCTION( LINEARREG_SLOPE, /* name */ TA_GroupId_Statistic,/* groupId */ "Linear Regression Slope", /* hint */ "LinearRegSlope", /* CamelCase name */ 0 /* flags */ ); /* LINEARREG_SLOPE END */ /* LINEARREG_ANGLE BEGIN */ static const TA_InputParameterInfo *TA_LINEARREG_ANGLE_Inputs[] = { &TA_DEF_UI_Input_Real, NULL }; static const TA_OutputParameterInfo *TA_LINEARREG_ANGLE_Outputs[] = { &TA_DEF_UI_Output_Real, NULL }; static const TA_OptInputParameterInfo *TA_LINEARREG_ANGLE_OptInputs[] = { &TA_DEF_UI_TimePeriod_14_MINIMUM2, NULL }; DEF_FUNCTION( LINEARREG_ANGLE, /* name */ TA_GroupId_Statistic,/* groupId */ "Linear Regression Angle", /* hint */ "LinearRegAngle", /* CamelCase name */ 0 /* flags */ ); /* LINEARREG_ANGLE END */ /* LINEARREG_INTERCEPT BEGIN */ static const TA_InputParameterInfo *TA_LINEARREG_INTERCEPT_Inputs[] = { &TA_DEF_UI_Input_Real, NULL }; static const TA_OutputParameterInfo *TA_LINEARREG_INTERCEPT_Outputs[] = { &TA_DEF_UI_Output_Real, NULL }; static const TA_OptInputParameterInfo *TA_LINEARREG_INTERCEPT_OptInputs[] = { &TA_DEF_UI_TimePeriod_14_MINIMUM2, NULL }; DEF_FUNCTION( LINEARREG_INTERCEPT, /* name */ TA_GroupId_Statistic,/* groupId */ "Linear Regression Intercept", /* hint */ "LinearRegIntercept", /* CamelCase name */ TA_FUNC_FLG_OVERLAP /* flags */ ); /* LINEARREG_INTERCEPT END */ /* LN BEGIN */ DEF_MATH_UNARY_OPERATOR( LN, "Vector Log Natural", "Ln" ) /* LN END */ /* LOG10 BEGIN */ DEF_MATH_UNARY_OPERATOR( LOG10, "Vector Log10", "Log10" ) /* LOG10 END */ /**************************************************************************** * Step 2 - Add your TA function to the table. * Keep in alphabetical order. Must be NULL terminated. ****************************************************************************/ const TA_FuncDef *TA_DEF_TableL[] = { ADD_TO_TABLE(LINEARREG), ADD_TO_TABLE(LINEARREG_ANGLE), ADD_TO_TABLE(LINEARREG_INTERCEPT), ADD_TO_TABLE(LINEARREG_SLOPE), ADD_TO_TABLE(LN), ADD_TO_TABLE(LOG10), NULL }; /* Do not modify the following line. */ const unsigned int TA_DEF_TableLSize = ((sizeof(TA_DEF_TableL)/sizeof(TA_FuncDef *))-1); /**************************************************************************** * Step 3 - Make sure "gen_code" is executed for generating all other * source files derived from this one. * You can then re-compile the library as usual and you are done! ****************************************************************************/