⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lagrange.h

📁 利用C
💻 H
字号:
// Copyright (C) 2003-2005 Anders Logg.// Licensed under the GNU LGPL Version 2.1.//// First added:  2003-06-12// Last changed: 2005-12-09#ifndef __LAGRANGE_H#define __LAGRANGE_H#include <dolfin/log/dolfin_log.h>#include <dolfin/common/types.h>namespace dolfin{  /// Lagrange polynomial (basis) with given degree q determined by n = q + 1 nodal points.  ///  /// Example: q = 1 (n = 2)  ///  ///   Lagrange p(1);  ///   p.set(0, 0.0);  ///   p.set(1, 1.0);  ///  /// This creates a Lagrange polynomial (actually two Lagrange polynomials):  ///  ///   p(0,x) = 1 - x   (one at x = 0, zero at x = 1)  ///   p(1,x) = x       (zero at x = 0, one at x = 1)  class Lagrange  {  public:     /// Constructor    Lagrange(unsigned int q);        /// Copy constructor    Lagrange(const Lagrange& p);        /// Destructor    ~Lagrange();        /// Specify point    void set(unsigned int i, real x);    /// Return number of points    unsigned int size() const;        /// Return degree    unsigned int degree() const;        /// Return point    real point(unsigned int i) const;        /// Return value of polynomial i at given point x    real operator() (unsigned int i, real x);        /// Return value of polynomial i at given point x    real eval(unsigned int i, real x);    /// Return derivate of polynomial i at given point x    real ddx(unsigned int i, real x);    /// Return derivative q (a constant) of polynomial    real dqdx(unsigned int i);    /// Output    friend LogStream& operator<<(LogStream& stream, const Lagrange& p);    void disp() const;      private:    void init();        unsigned int q;    unsigned int n;    real* points;     real* constants;  };  LogStream& operator<<(LogStream& stream, const Lagrange& p);}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -