📄 wmlintptrilinear3.h
字号:
// Magic Software, Inc.
// http://www.magic-software.com
// http://www.wild-magic.com
// Copyright (c) 2003. All Rights Reserved
//
// The Wild Magic Library (WML) source code is supplied under the terms of
// the license agreement http://www.magic-software.com/License/WildMagic.pdf
// and may not be copied or disclosed except in accordance with the terms of
// that agreement.
#ifndef WMLINTPTRILINEAR3_H
#define WMLINTPTRILINEAR3_H
#include "WmlSystem.h"
namespace Wml
{
template <class Real>
class WML_ITEM IntpTrilinear3
{
public:
// Construction and destruction. IntpTrilinear3 does not accept
// responsibility for deleting the input array. The application must do
// so. The interpolator is for uniformly spaced (x,y,z)-values. The
// function values are assumed to be organized as f(x,y,z) = F[z][y][x].
IntpTrilinear3 (int iXBound, int iYBound, int iZBound, Real fXMin,
Real fXSpacing, Real fYMin, Real fYSpacing, Real fZMin,
Real fZSpacing, Real*** aaafF);
int GetXBound () const;
int GetYBound () const;
int GetZBound () const;
int GetQuantity () const;
Real*** GetF () const;
Real GetXMin () const;
Real GetXMax () const;
Real GetXSpacing () const;
Real GetYMin () const;
Real GetYMax () const;
Real GetYSpacing () const;
Real GetZMin () const;
Real GetZMax () const;
Real GetZSpacing () const;
// Evaluate the function and its derivatives. The application is
// responsible for ensuring that xmin <= x <= xmax, ymin <= y <= ymax,
// and zmin <= z <= zmax. If (x,y,z) is outside the extremes, the
// function returns MAXREAL. The first operator is for function
// evaluation. The second operator is for function or derivative
// evaluations. The uiXOrder argument is the order of the x-derivative,
// the uiYOrder argument is the order of the y-derivative, and the
// uiZOrder argument is the order of the z-derivative. All orders are
// zero to get the function value itself.
Real operator() (Real fX, Real fY, Real fZ) const;
Real operator() (int iXOrder, int iYOrder, int iZOrder, Real fX,
Real fY, Real fZ) const;
protected:
int m_iXBound, m_iYBound, m_iZBound, m_iQuantity;
Real m_fXMin, m_fXMax, m_fXSpacing, m_fInvXSpacing;
Real m_fYMin, m_fYMax, m_fYSpacing, m_fInvYSpacing;
Real m_fZMin, m_fZMax, m_fZSpacing, m_fInvZSpacing;
Real*** m_aaafF;
static const Real ms_aafBlend[2][2];
};
typedef IntpTrilinear3<float> IntpTrilinear3f;
typedef IntpTrilinear3<double> IntpTrilinear3d;
}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -