mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-18 08:50:33 +05:00
48 lines
1.2 KiB
C++
48 lines
1.2 KiB
C++
#ifndef FILE_POLYNOMIAL
|
|
#define FILE_POLYNOMIAL
|
|
|
|
/* *************************************************************************/
|
|
/* File: polynomial.hh */
|
|
/* Author: Joachim Schoeberl */
|
|
/* Date: 25. Nov. 99 */
|
|
/* *************************************************************************/
|
|
|
|
namespace netgen
|
|
{
|
|
|
|
class QuadraticPolynomial1V
|
|
{
|
|
double c, cx, cxx;
|
|
public:
|
|
QuadraticPolynomial1V (double ac, double acx, double acxx);
|
|
double Value (double x);
|
|
double MaxUnitInterval ();
|
|
};
|
|
|
|
class LinearPolynomial2V
|
|
{
|
|
double c, cx, cy;
|
|
public:
|
|
LinearPolynomial2V (double ac, double acx, double acy);
|
|
friend class QuadraticPolynomial2V;
|
|
};
|
|
|
|
|
|
class QuadraticPolynomial2V
|
|
{
|
|
double c, cx, cy, cxx, cxy, cyy;
|
|
public:
|
|
QuadraticPolynomial2V ();
|
|
QuadraticPolynomial2V (double ac, double acx, double acy,
|
|
double acxx, double acxy, double acyy);
|
|
void Square (const LinearPolynomial2V & lp);
|
|
void Add (double lam, const QuadraticPolynomial2V & qp);
|
|
|
|
double Value (double x, double y);
|
|
// double MinUnitSquare ();
|
|
double MaxUnitSquare ();
|
|
double MaxUnitTriangle ();
|
|
};
|
|
} // namespace netgen
|
|
#endif
|