-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBase.wl
90 lines (75 loc) · 2.65 KB
/
Base.wl
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
88
89
90
(* ::Package:: *)
BeginPackage["RockMatica`Base`"]
rpRock::usage = "rpRock[RockName, DryBulkModulus, \
ShearModulus, MineralModulus, Porosity, MineralDensity]\
defines a rock object called by rpRock[RockName]. \
For an isotropically viscoelastic rock the option \
MicrocrackParameters->{CrackDensity, AspectRatio, ReferenceFrequency}\
can be given, whereas for an anisotropically viscoelastic rock\
FractureParameters->{FractureDensity, FractureFrequencyRatio}\
must also be provided
"
rpFluid::usage = "rpFluid[FluidName, FluidModulus, FluidViscosity, \
FluidDensity] defines a fluid object called by rpFluid[FluidName]"
Begin["Private`"]
Options[rpRock]={MicrocrackParameters->{None, 10^-5, None}, FractureParameters->{None, None, None, None}};
rpRock[name_String, drymod_, shearmod_, mineralmod_, porosity_, mineraldens_ , OptionsPattern[]]:=
Module[{crackDensity, aspectRatio, referenceFrequency, fractureDensity, fractureRefFreq, lambda, mu},
{crackDensity, aspectRatio, referenceFrequency}=Evaluate@OptionValue[MicrocrackParameters];
{fractureDensity, fractureRefFreq, lambda, mu}=Evaluate@OptionValue[FractureParameters];
rpRock[name]=<|
"RockName"->name,
"DryModulus"->drymod,
"ShearModulus"->shearmod,
"MineralModulus"->mineralmod,
"Porosity"->porosity,
"MineralDensity"->mineraldens,
"MicrocrackParameters"-><|
"CrackDensity"->crackDensity,
"AspectRatio"->aspectRatio,
"ReferenceFrequency"->referenceFrequency
|>,
"FractureParameters"-><|
"FractureDensity"->fractureDensity,
"FractureFrequencyRatio"->fractureRefFreq,
"EffectiveMediumLambda"->lambda,
"EffectiveMediumMu"->mu
|>
|>//N
];
rpRock[name_String, c11_, c12_, c13_, c33_, c44_, mineralmod_, porosity_, mineraldens_ , OptionsPattern[]]:=
Module[{crackDensity, aspectRatio, referenceFrequency, fractureDensity, fractureRefFreq, lambda, mu},
{crackDensity, aspectRatio, referenceFrequency}=Evaluate@OptionValue[MicrocrackParameters];
{fractureDensity, fractureRefFreq, lambda, mu}=Evaluate@OptionValue[FractureParameters];
rpRock[name]=<|
"RockName"->name,
"C11"->c11,
"C12"->c12,
"C13"->c13,
"C33"->c33,
"C44"->c44,
"MineralModulus"->mineralmod,
"Porosity"->porosity,
"MineralDensity"->mineraldens,
"MicrocrackParameters"-><|
"CrackDensity"->crackDensity,
"AspectRatio"->aspectRatio,
"ReferenceFrequency"->referenceFrequency
|>,
"FractureParameters"-><|
"FractureDensity"->fractureDensity,
"FractureFrequencyRatio"->fractureRefFreq,
"EffectiveMediumLambda"->lambda,
"EffectiveMediumMu"->mu
|>
|>//N
];
rpFluid[name_String,fluidMod_, fluidVisc_, fluidDens_]:=
rpFluid[name]=<|
"FluidName"->name,
"FluidModulus"->fluidMod,
"FluidViscosity"->fluidVisc,
"FluidDensity"->fluidDens
|>//N;
End[]
EndPackage[]