1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
/***************************************************************************
* evalc.h is part of Math Graphic Library
* Copyright (C) 2007-2016 Alexey Balakin <mathgl.abalakin@gmail.ru> *
* *
* This program 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 3 of the *
* License, or (at your option) any later version. *
* *
* This program 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 more details. *
* *
* You should have received a copy of the GNU Lesser 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. *
***************************************************************************/
#ifndef _MGL_EVALC_H_
#define _MGL_EVALC_H_
//-----------------------------------------------------------------------------
#include "mgl2/eval.h"
class mglDataC;
//-----------------------------------------------------------------------------
/// Class for evaluating complex-valued formula specified by the string
class MGL_EXPORT mglFormulaC
{
public:
/// Evaluates the formula for 'x','r'=\a x, 'y','n'=\a y, 'z','t'=\a z, 'u'=\a u
dual Calc(dual x,dual y=0,dual z=0,dual u=0) const MGL_FUNC_PURE;
/// Evaluates the formula for 'x, y, z, u, v, w'
dual Calc(dual x,dual y,dual z,dual u,dual v,dual w) const MGL_FUNC_PURE;
/// Evaluates the formula for variables var
dual Calc(const dual var[MGL_VS]) const MGL_FUNC_PURE;
/// Evaluates the formula for variables var
void CalcV(HADT res, HCDT var[MGL_VS]) const;
/// Evaluates the formula for variables var (OpenMP-based)
void CalcVomp(HADT res, HCDT var[MGL_VS]) const;
/// Return error code
inline int GetError() const { return Error; }
/// Parse the formula str and create formula-tree
mglFormulaC(const char *str);
/// Set data for the spline interpolation
mglFormulaC(HCDT d, mreal x1=0, mreal x2=1, mreal y1=0, mreal y2=1, mreal z1=0, mreal z2=1) :
dat(d),dx1(x1),dx2(x2),dy1(y1),dy2(y2),dz1(z1),dz2(z2),tmp(NULL) {};
/// Clean up formula-tree
virtual ~mglFormulaC();
protected:
dual CalcIn(const dual *a1) const MGL_FUNC_PURE;
mglFormulaC *Left,*Right; // first and second argument of the function
int Kod; // the function ID
dual Res; // the number or the variable ID
HCDT dat; // data file for the interpolation
mreal dx1,dx2,dy1,dy2,dz1,dz2; // ranges of data files
static int Error;
private:
mglDataC *tmp;
};
//-----------------------------------------------------------------------------
#endif
|