Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F88537354
test_multi_material_elastic.cc
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
Sat, Oct 19, 09:19
Size
2 KB
Mime Type
text/x-c
Expires
Mon, Oct 21, 09:19 (2 d)
Engine
blob
Format
Raw Data
Handle
21787907
Attached To
rAKA akantu
test_multi_material_elastic.cc
View Options
#include <solid_mechanics_model.hh>
#include "non_linear_solver.hh"
using
namespace
akantu
;
int
main
(
int
argc
,
char
*
argv
[])
{
initialize
(
"test_multi_material_elastic.dat"
,
argc
,
argv
);
UInt
spatial_dimension
=
2
;
Mesh
mesh
(
spatial_dimension
);
mesh
.
read
(
"test_multi_material_elastic.msh"
);
SolidMechanicsModel
model
(
mesh
);
auto
&&
mat_sel
=
std
::
make_shared
<
MeshDataMaterialSelector
<
std
::
string
>>
(
"physical_names"
,
model
);
model
.
setMaterialSelector
(
mat_sel
);
model
.
initFull
(
_analysis_method
=
_static
);
model
.
applyBC
(
BC
::
Dirichlet
::
FlagOnly
(
_y
),
"ground"
);
model
.
applyBC
(
BC
::
Dirichlet
::
FlagOnly
(
_x
),
"corner"
);
Vector
<
Real
>
trac
(
spatial_dimension
,
0.
);
trac
(
_y
)
=
1.
;
model
.
applyBC
(
BC
::
Neumann
::
FromTraction
(
trac
),
"air"
);
model
.
addDumpField
(
"external_force"
);
model
.
addDumpField
(
"internal_force"
);
model
.
addDumpField
(
"blocked_dofs"
);
model
.
addDumpField
(
"displacement"
);
model
.
addDumpField
(
"stress"
);
model
.
addDumpField
(
"grad_u"
);
//model.dump();
auto
&
solver
=
model
.
getNonLinearSolver
(
"static"
);
solver
.
set
(
"max_iterations"
,
1
);
solver
.
set
(
"threshold"
,
1e-8
);
solver
.
set
(
"convergence_type"
,
_scc_residual
);
model
.
solveStep
();
//model.dump();
std
::
map
<
std
::
string
,
Matrix
<
Real
>>
ref_strain
;
ref_strain
[
"strong"
]
=
Matrix
<
Real
>
(
spatial_dimension
,
spatial_dimension
,
0.
);
ref_strain
[
"strong"
](
_y
,
_y
)
=
.5
;
ref_strain
[
"weak"
]
=
Matrix
<
Real
>
(
spatial_dimension
,
spatial_dimension
,
0.
);
ref_strain
[
"weak"
](
_y
,
_y
)
=
1
;
Matrix
<
Real
>
ref_stress
(
spatial_dimension
,
spatial_dimension
,
0.
);
ref_stress
(
_y
,
_y
)
=
1.
;
std
::
vector
<
std
::
string
>
mats
=
{
"strong"
,
"weak"
};
typedef
Array
<
Real
>::
const_matrix_iterator
mat_it
;
auto
check
=
[](
mat_it
it
,
mat_it
end
,
const
Matrix
<
Real
>
&
ref
)
->
bool
{
for
(;
it
!=
end
;
++
it
)
{
Real
dist
=
(
*
it
-
ref
).
norm
<
L_2
>
();
//std::cout << *it << " " << dist << " " << (dist < 1e-10 ? "OK" : "Not OK") << std::endl;
if
(
dist
>
1e-10
)
return
false
;
}
return
true
;
};
auto
tit
=
mesh
.
firstType
(
spatial_dimension
);
auto
tend
=
mesh
.
lastType
(
spatial_dimension
);
for
(;
tit
!=
tend
;
++
tit
)
{
auto
&
type
=
*
tit
;
for
(
auto
mat_id
:
mats
)
{
auto
&
stress
=
model
.
getMaterial
(
mat_id
).
getStress
(
type
);
auto
&
grad_u
=
model
.
getMaterial
(
mat_id
).
getGradU
(
type
);
auto
sit
=
stress
.
begin
(
spatial_dimension
,
spatial_dimension
);
auto
send
=
stress
.
end
(
spatial_dimension
,
spatial_dimension
);
auto
git
=
grad_u
.
begin
(
spatial_dimension
,
spatial_dimension
);
auto
gend
=
grad_u
.
end
(
spatial_dimension
,
spatial_dimension
);
if
(
!
check
(
sit
,
send
,
ref_stress
))
AKANTU_ERROR
(
"The stresses are not correct"
);
if
(
!
check
(
git
,
gend
,
ref_strain
[
mat_id
]))
AKANTU_ERROR
(
"The grad_u are not correct"
);
}
}
finalize
();
return
0
;
}
Event Timeline
Log In to Comment