cubepoly

Capsim Block Documentation

Short Description

mplements a cubic polynomial nonlinearity of the form: output = a*x + b*x^2 + c*x^3, where x = input

Top
Input Connections
Port Type Name
0 float x
Top
Output Connections
Port Type Name
0 float y
Top
Parameters
Num Description Type Name Default Value
0 linear coefficient float a 1.0
1 quadratic coefficient float b 0.0
2 cubic coefficient float c 0.0
Top

Declarations


 

	float 	tmp,tmp2;



Top

Initialization Code



 





Top

Main Code



 


        while(IT_IN(0))
        {
            if(IT_OUT(0)) {
			KrnOverflow("cubepoly",0);
			return(99);
	    }
	    tmp = x(0);
	    tmp2=tmp*tmp;
            y(0) = a*tmp + b*tmp2 + c*tmp*tmp2;
        }
	return(0);





Top

Wrapup Code



 





Top

License



/*  Capsim (r) Text Mode Kernel (TMK) Star Library (Blocks)
    Copyright (C) 1989-2017  Silicon DSP Corporation

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License as published by the Free Software Foundation; either
    version 2.1 of the License, or (at your option) any later version.

    This library 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
    Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

    http://www.silicondsp.com
    Silicon DSP  Corporation
    Las Vegas, Nevada
*/


Top

Description



 

/* cubepoly.s */
/**********************************************************************
			cubepoly()
***********************************************************************
Implements a cubic polynomial nonlinearity of the form:
       output = a*x + b*x^2 + c*x^3,
         where x = input
       All signals and params are REAL.
      There are 3 parameters: a, b, c.

cubepoly


Implements a cubic polynomial nonlinearity of the form:
       output = a*x + b*x^2 + c*x^3,
         where x = input
       All signals and params are REAL.
      There are 3 parameters: a, b, c.


Programmer: R.A. Nobakht
Date:	    4/89

*/