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

📄 ffc_l2proj_05.h

📁 利用C
💻 H
📖 第 1 页 / 共 5 页
字号:
// This code conforms with the UFC specification version 1.0// and was automatically generated by FFC version 0.5.0.//// Warning: This code was generated with the option '-l dolfin'// and contains DOLFIN-specific wrappers that depend on DOLFIN.#ifndef __FFC_L2PROJ_05_H#define __FFC_L2PROJ_05_H#include <cmath>#include <stdexcept>#include <fstream>#include <ufc.h>/// This class defines the interface for a finite element.class UFC_ffc_L2proj_05BilinearForm_finite_element_0: public ufc::finite_element{public:  /// Constructor  UFC_ffc_L2proj_05BilinearForm_finite_element_0() : ufc::finite_element()  {    // Do nothing  }  /// Destructor  virtual ~UFC_ffc_L2proj_05BilinearForm_finite_element_0()  {    // Do nothing  }  /// Return a string identifying the finite element  virtual const char* signature() const  {    return "Lagrange finite element of degree 2 on a tetrahedron";  }  /// Return the cell shape  virtual ufc::shape cell_shape() const  {    return ufc::tetrahedron;  }  /// Return the dimension of the finite element function space  virtual unsigned int space_dimension() const  {    return 10;  }  /// Return the rank of the value space  virtual unsigned int value_rank() const  {    return 0;  }  /// Return the dimension of the value space for axis i  virtual unsigned int value_dimension(unsigned int i) const  {    return 1;  }  /// Evaluate basis function i at given point in cell  virtual void evaluate_basis(unsigned int i,                              double* values,                              const double* coordinates,                              const ufc::cell& c) const  {    throw std::runtime_error("// Function evaluate_basis not generated (compiled with -fno-evaluate_basis)");  }  /// Evaluate all basis functions at given point in cell  virtual void evaluate_basis_all(double* values,                                  const double* coordinates,                                  const ufc::cell& c) const  {    throw std::runtime_error("The vectorised version of evaluate_basis() is not yet implemented.");  }  /// Evaluate order n derivatives of basis function i at given point in cell  virtual void evaluate_basis_derivatives(unsigned int i,                                          unsigned int n,                                          double* values,                                          const double* coordinates,                                          const ufc::cell& c) const  {    throw std::runtime_error("// Function evaluate_basis_derivatives not generated (compiled with -fno-evaluate_basis_derivatives)");  }  /// Evaluate order n derivatives of all basis functions at given point in cell  virtual void evaluate_basis_derivatives_all(unsigned int n,                                              double* values,                                              const double* coordinates,                                              const ufc::cell& c) const  {    throw std::runtime_error("The vectorised version of evaluate_basis_derivatives() is not yet implemented.");  }  /// Evaluate linear functional for dof i on the function f  virtual double evaluate_dof(unsigned int i,                              const ufc::function& f,                              const ufc::cell& c) const  {    // The reference points, direction and weights:    const static double X[10][1][3] = {{{0, 0, 0}}, {{1, 0, 0}}, {{0, 1, 0}}, {{0, 0, 1}}, {{0, 0.5, 0.5}}, {{0.5, 0, 0.5}}, {{0.5, 0.5, 0}}, {{0, 0, 0.5}}, {{0, 0.5, 0}}, {{0.5, 0, 0}}};    const static double W[10][1] = {{1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}};    const static double D[10][1][1] = {{{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}};        const double * const * x = c.coordinates;    double result = 0.0;    // Iterate over the points:    // Evaluate basis functions for affine mapping    const double w0 = 1.0 - X[i][0][0] - X[i][0][1] - X[i][0][2];    const double w1 = X[i][0][0];    const double w2 = X[i][0][1];    const double w3 = X[i][0][2];        // Compute affine mapping y = F(X)    double y[3];    y[0] = w0*x[0][0] + w1*x[1][0] + w2*x[2][0] + w3*x[3][0];    y[1] = w0*x[0][1] + w1*x[1][1] + w2*x[2][1] + w3*x[3][1];    y[2] = w0*x[0][2] + w1*x[1][2] + w2*x[2][2] + w3*x[3][2];        // Evaluate function at physical points    double values[1];    f.evaluate(values, y, c);        // Map function values using appropriate mapping    // Affine map: Do nothing        // Note that we do not map the weights (yet).        // Take directional components    for(int k = 0; k < 1; k++)      result += values[k]*D[i][0][k];    // Multiply by weights     result *= W[i][0];        return result;  }  /// Evaluate linear functionals for all dofs on the function f  virtual void evaluate_dofs(double* values,                             const ufc::function& f,                             const ufc::cell& c) const  {    throw std::runtime_error("Not implemented (introduced in UFC v1.1).");  }  /// Interpolate vertex values from dof values  virtual void interpolate_vertex_values(double* vertex_values,                                         const double* dof_values,                                         const ufc::cell& c) const  {    // Evaluate at vertices and use affine mapping    vertex_values[0] = dof_values[0];    vertex_values[1] = dof_values[1];    vertex_values[2] = dof_values[2];    vertex_values[3] = dof_values[3];  }  /// Return the number of sub elements (for a mixed element)  virtual unsigned int num_sub_elements() const  {    return 1;  }  /// Create a new finite element for sub element i (for a mixed element)  virtual ufc::finite_element* create_sub_element(unsigned int i) const  {    return new UFC_ffc_L2proj_05BilinearForm_finite_element_0();  }};/// This class defines the interface for a finite element.class UFC_ffc_L2proj_05BilinearForm_finite_element_1: public ufc::finite_element{public:  /// Constructor  UFC_ffc_L2proj_05BilinearForm_finite_element_1() : ufc::finite_element()  {    // Do nothing  }  /// Destructor  virtual ~UFC_ffc_L2proj_05BilinearForm_finite_element_1()  {    // Do nothing  }  /// Return a string identifying the finite element  virtual const char* signature() const  {    return "Lagrange finite element of degree 2 on a tetrahedron";  }  /// Return the cell shape  virtual ufc::shape cell_shape() const  {    return ufc::tetrahedron;  }  /// Return the dimension of the finite element function space  virtual unsigned int space_dimension() const  {    return 10;  }  /// Return the rank of the value space  virtual unsigned int value_rank() const  {    return 0;  }  /// Return the dimension of the value space for axis i  virtual unsigned int value_dimension(unsigned int i) const  {    return 1;  }  /// Evaluate basis function i at given point in cell  virtual void evaluate_basis(unsigned int i,                              double* values,                              const double* coordinates,                              const ufc::cell& c) const  {    throw std::runtime_error("// Function evaluate_basis not generated (compiled with -fno-evaluate_basis)");  }  /// Evaluate all basis functions at given point in cell  virtual void evaluate_basis_all(double* values,                                  const double* coordinates,                                  const ufc::cell& c) const  {    throw std::runtime_error("The vectorised version of evaluate_basis() is not yet implemented.");  }  /// Evaluate order n derivatives of basis function i at given point in cell  virtual void evaluate_basis_derivatives(unsigned int i,                                          unsigned int n,                                          double* values,                                          const double* coordinates,                                          const ufc::cell& c) const  {    throw std::runtime_error("// Function evaluate_basis_derivatives not generated (compiled with -fno-evaluate_basis_derivatives)");  }  /// Evaluate order n derivatives of all basis functions at given point in cell  virtual void evaluate_basis_derivatives_all(unsigned int n,                                              double* values,                                              const double* coordinates,                                              const ufc::cell& c) const  {    throw std::runtime_error("The vectorised version of evaluate_basis_derivatives() is not yet implemented.");  }  /// Evaluate linear functional for dof i on the function f  virtual double evaluate_dof(unsigned int i,                              const ufc::function& f,                              const ufc::cell& c) const  {    // The reference points, direction and weights:    const static double X[10][1][3] = {{{0, 0, 0}}, {{1, 0, 0}}, {{0, 1, 0}}, {{0, 0, 1}}, {{0, 0.5, 0.5}}, {{0.5, 0, 0.5}}, {{0.5, 0.5, 0}}, {{0, 0, 0.5}}, {{0, 0.5, 0}}, {{0.5, 0, 0}}};    const static double W[10][1] = {{1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}, {1}};    const static double D[10][1][1] = {{{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}, {{1}}};        const double * const * x = c.coordinates;    double result = 0.0;    // Iterate over the points:    // Evaluate basis functions for affine mapping    const double w0 = 1.0 - X[i][0][0] - X[i][0][1] - X[i][0][2];    const double w1 = X[i][0][0];    const double w2 = X[i][0][1];    const double w3 = X[i][0][2];        // Compute affine mapping y = F(X)    double y[3];    y[0] = w0*x[0][0] + w1*x[1][0] + w2*x[2][0] + w3*x[3][0];    y[1] = w0*x[0][1] + w1*x[1][1] + w2*x[2][1] + w3*x[3][1];    y[2] = w0*x[0][2] + w1*x[1][2] + w2*x[2][2] + w3*x[3][2];        // Evaluate function at physical points    double values[1];    f.evaluate(values, y, c);        // Map function values using appropriate mapping    // Affine map: Do nothing        // Note that we do not map the weights (yet).        // Take directional components    for(int k = 0; k < 1; k++)      result += values[k]*D[i][0][k];    // Multiply by weights     result *= W[i][0];        return result;  }  /// Evaluate linear functionals for all dofs on the function f  virtual void evaluate_dofs(double* values,                             const ufc::function& f,                             const ufc::cell& c) const  {    throw std::runtime_error("Not implemented (introduced in UFC v1.1).");  }  /// Interpolate vertex values from dof values  virtual void interpolate_vertex_values(double* vertex_values,                                         const double* dof_values,                                         const ufc::cell& c) const  {    // Evaluate at vertices and use affine mapping    vertex_values[0] = dof_values[0];    vertex_values[1] = dof_values[1];    vertex_values[2] = dof_values[2];    vertex_values[3] = dof_values[3];  }  /// Return the number of sub elements (for a mixed element)  virtual unsigned int num_sub_elements() const  {    return 1;  }  /// Create a new finite element for sub element i (for a mixed element)  virtual ufc::finite_element* create_sub_element(unsigned int i) const  {    return new UFC_ffc_L2proj_05BilinearForm_finite_element_1();  }};/// This class defines the interface for a local-to-global mapping of/// degrees of freedom (dofs).class UFC_ffc_L2proj_05BilinearForm_dof_map_0: public ufc::dof_map{private:  unsigned int __global_dimension;public:  /// Constructor  UFC_ffc_L2proj_05BilinearForm_dof_map_0() : ufc::dof_map()  {    __global_dimension = 0;  }  /// Destructor  virtual ~UFC_ffc_L2proj_05BilinearForm_dof_map_0()  {    // Do nothing  }  /// Return a string identifying the dof map  virtual const char* signature() const  {    return "FFC dof map for Lagrange finite element of degree 2 on a tetrahedron";  }  /// Return true iff mesh entities of topological dimension d are needed  virtual bool needs_mesh_entities(unsigned int d) const  {    switch ( d )    {    case 0:      return true;      break;    case 1:      return true;      break;    case 2:      return false;      break;    case 3:      return false;      break;    }    return false;  }  /// Initialize dof map for mesh (return true iff init_cell() is needed)  virtual bool init_mesh(const ufc::mesh& m)  {    __global_dimension = m.num_entities[0] + m.num_entities[1];    return false;  }  /// Initialize dof map for given cell  virtual void init_cell(const ufc::mesh& m,                         const ufc::cell& c)  {    // Do nothing  }  /// Finish initialization of dof map for cells  virtual void init_cell_finalize()  {    // Do nothing  }  /// Return the dimension of the global finite element function space  virtual unsigned int global_dimension() const  {    return __global_dimension;  }  /// Return the dimension of the local finite element function space  virtual unsigned int local_dimension() const  {    return 10;  }

⌨️ 快捷键说明

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