File: BTriMeshIP.h

package info (click to toggle)
esys-particle 2.3.4%2Bdfsg1-4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 13,036 kB
  • ctags: 10,805
  • sloc: cpp: 80,009; python: 5,872; makefile: 1,243; sh: 313; perl: 225
file content (87 lines) | stat: -rw-r--r-- 1,814 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/////////////////////////////////////////////////////////////
//                                                         //
// Copyright (c) 2003-2014 by The University of Queensland //
// Centre for Geoscience Computing                         //
// http://earth.uq.edu.au/centre-geoscience-computing      //
//                                                         //
// Primary Business: Brisbane, Queensland, Australia       //
// Licensed under the Open Software License version 3.0    //
// http://www.apache.org/licenses/LICENSE-2.0          //
//                                                         //
/////////////////////////////////////////////////////////////

#ifndef __BTRIMESHIP_H
#define __BTRIMESHIP_H

#include <string>

class BTriMeshIP
{
public:
  double k;
  double brk;

  BTriMeshIP();

  BTriMeshIP(
    const std::string &interactionName,
    const std::string &meshName,
    double normalK,
    double breakDistance
  );
  
  virtual ~BTriMeshIP();

  void setMeshName(const std::string &meshName);

  const std::string &getMeshName() const;

  void setName(const std::string &name);

  const std::string &getName() const;

  virtual std::string getTypeString() const;

private:
  std::string m_name;
  std::string m_meshName;
};

class MeshBuildPrms
{
public:
  MeshBuildPrms();

  virtual ~MeshBuildPrms();

  virtual std::string getTypeString() const = 0;

private:
};

class MeshTagBuildPrms : public MeshBuildPrms
{
public:
  int m_tag;
  int m_mask;

  MeshTagBuildPrms();

  MeshTagBuildPrms(int tag, int mask);

  virtual std::string getTypeString() const;
};

class MeshGapBuildPrms : public MeshBuildPrms
{
public:
  double m_maxGap;
  
  MeshGapBuildPrms();

  MeshGapBuildPrms(double maxGap);
  
  virtual std::string getTypeString() const;
};

#endif // __BTRIMESHIP_H