File: GridAdaptBase.h

package info (click to toggle)
stopt 6.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 9,264 kB
  • sloc: cpp: 75,778; python: 6,012; makefile: 72; sh: 57
file content (50 lines) | stat: -rw-r--r-- 1,167 bytes parent folder | download
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
// Copyright (C) 2025 EDF
// All Rights Reserved
// This code is published under the GNU Lesser General Public License (GNU LGPL)
#ifndef GRIDADAPTBASE_H
#define GRIDADAPTBASE_H
#include <memory>
#include <vector>
#include <list>
#include <array>
#include <Eigen/Dense>

/** \file GridAdaptBase.h
 * \brief Defines an abstract grid with refinement possibility
 * \author  Pierre Gruet
 */

namespace StOpt
{
  class GridAdaptBase
  {
  public:

    // default constructor
    GridAdaptBase() : m_points()
    {}

    // constructor using points
    GridAdaptBase(const std::vector<Eigen::ArrayXd > & p_points) : m_points(p_points)
    {}

    virtual ~GridAdaptBase(){}

    /// get dimension of the grid
    virtual int getDim() const = 0;

    /// get back the number of points
    inline int getNbPoints() const { return m_points.size();}

    /// get back points
    inline  std::vector< Eigen::ArrayXd >   getPoints() const { return m_points;}

    /// get back an array with coordinates
    virtual Eigen::ArrayXd getCoord(const int & p_ipt) const = 0;

  protected:
    std::vector< Eigen::ArrayXd > m_points ; /// all points composing the grid

  };
}
#endif