Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F65251068
GooseFEM.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sun, Jun 2, 06:06
Size
3 KB
Mime Type
text/x-c
Expires
Tue, Jun 4, 06:06 (2 d)
Engine
blob
Format
Raw Data
Handle
17892163
Attached To
rGOOSEFEM GooseFEM
GooseFEM.h
View Options
/* =================================================================================================
(c - GPLv3) T.W.J. de Geus (Tom) | tom@geus.me | www.geus.me | github.com/tdegeus/GooseFEM
================================================================================================= */
#ifndef GOOSEFEM_H
#define GOOSEFEM_H
// =================================================================================================
#define _USE_MATH_DEFINES
// to use "M_PI" from "math.h"
#include <assert.h>
#include <cstdlib>
#include <vector>
#include <string>
#include <memory>
#include <iostream>
#include <iomanip>
#include <numeric>
#include <limits>
#include <algorithm>
#include <math.h>
#include <Eigen/Eigen>
#include <cppmat/cppmat.h>
// =================================================================================================
#define GOOSEFEM_WORLD_VERSION 0
#define GOOSEFEM_MAJOR_VERSION 0
#define GOOSEFEM_MINOR_VERSION 11
#define GOOSEFEM_VERSION_AT_LEAST(x,y,z) \
(GOOSEFEM_WORLD_VERSION>x || (GOOSEFEM_WORLD_VERSION>=x && \
(GOOSEFEM_MAJOR_VERSION>y || (GOOSEFEM_MAJOR_VERSION>=y && \
GOOSEFEM_MINOR_VERSION>=z))))
#define GOOSEFEM_VERSION(x,y,z) \
(GOOSEFEM_WORLD_VERSION==x && \
GOOSEFEM_MAJOR_VERSION==y && \
GOOSEFEM_MINOR_VERSION==z)
// =================================================================================================
// dummy operation that can be use to suppress the "unused parameter" warnings
#define UNUSED(p) ( (void)(p) )
// =================================================================================================
// alias types
namespace
GooseFEM
{
// - alias Eigen dense matrices
typedef
Eigen
::
Matrix
<
double
,
Eigen
::
Dynamic
,
Eigen
::
Dynamic
,
Eigen
::
RowMajor
>
MatD
;
typedef
Eigen
::
Matrix
<
size_t
,
Eigen
::
Dynamic
,
Eigen
::
Dynamic
,
Eigen
::
RowMajor
>
MatS
;
typedef
Eigen
::
Matrix
<
double
,
Eigen
::
Dynamic
,
1
,
Eigen
::
ColMajor
>
ColD
;
typedef
Eigen
::
Matrix
<
size_t
,
Eigen
::
Dynamic
,
1
,
Eigen
::
ColMajor
>
ColS
;
typedef
Eigen
::
Matrix
<
int
,
Eigen
::
Dynamic
,
1
,
Eigen
::
ColMajor
>
ColI
;
// - alias Eigen sparse matrices
typedef
Eigen
::
SparseMatrix
<
double
,
Eigen
::
RowMajor
>
SpMatD
;
typedef
Eigen
::
SparseMatrix
<
size_t
,
Eigen
::
RowMajor
>
SpMatS
;
// - alias cppmat matrices
typedef
cppmat
::
array
<
double
>
ArrD
;
typedef
cppmat
::
array
<
size_t
>
ArrS
;
typedef
cppmat
::
array
<
int
>
ArrI
;
}
// =================================================================================================
#include "Mesh.h"
#include "MeshTri3.h"
#include "MeshQuad4.h"
#include "MeshHex8.h"
#include "Element.h"
#include "ElementQuad4.h"
#include "ElementHex8.h"
#include "Vector.h"
#include "MatrixDiagonal.h"
#include "Iterate.h"
#include "Dynamics.h"
#include "Mesh.hpp"
#include "MeshTri3.hpp"
#include "MeshQuad4.hpp"
#include "MeshHex8.hpp"
#include "Element.hpp"
#include "ElementQuad4.hpp"
#include "ElementHex8.hpp"
#include "Vector.hpp"
#include "MatrixDiagonal.hpp"
#include "Iterate.hpp"
#include "Dynamics.hpp"
// =================================================================================================
#endif
Event Timeline
Log In to Comment