-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathPolycrystals.h
211 lines (170 loc) · 7.19 KB
/
Polycrystals.h
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
#ifndef POLYCRYSTALS_H
#define POLYCRYSTALS_H
#include <omp.h>
#include <iostream>
#include <fstream>
#include <iomanip>
#include <string>
#include <nlohmann/json.hpp>
#include <vector>
using namespace std;
using json = nlohmann::json;
#include "EVPSC.h"
#include "Toolbox.h"
namespace Polycs{
//const int max_grain_n = 3000;
class polycrystal
{
private:
double GZ = 30; //grain size (um)
Gausspoint* Gpsets = NULL;
string crysym; //crystal symmetry
MatrixXd Trans_Miller;// the conversion matrix of Miller indices
int Miller_n = 3;// the number of the Miller indices (3 or 4(hcp))
Matrix3d Mabc;
Vector3d Cdim; //lattice constant
Vector3d Cang; //lattice constant
Vector6d therm; //Thermal expansion coefficients [K^(-1)]
//the shape of ellipsoid
//Vector3d ell_axis_o;
Vector3d ell_axis; //axial length of ellipsoid/grain (_o means the original value)
Matrix3d ell_axisb;
double ell_crit_shape = 25;
Vector3d ellip_ang; //the rotate angle of the ellipsoid
bool Iflat = 0; //flag of stretch the ellipsoid (0: yes; 1: no)
bool Ishape = 0; //flag of individual ellipsoid for grain (1: yes; 0: no)
///////
double Cijkl[3][3][3][3]; //elastic constants 3X3X3X3
Matrix6d Cij6; //elastic constants 6X6 of crystal
//ESC
Matrix6d CSC; //The elastic consistent stiffness
Matrix6d CUB;
Matrix6d COLD;//The initial guessed elastic consistent stiffness
Matrix6d SSC; //CSC^-1
Matrix3d therm_expansion_ave; //The average thermal expansion tensor
Matrix3d therm_expans_ave_old; //The average thermal expansion tensor in last increment
//VPSC
Matrix5d C_VP_SC; //The visco-plastic stiffness
Matrix5d C_VP_SC_old;
/* Matrix5d M_VP_SC; //The visco-plastic compliance C_VP_SC^-1 */
Vector6d D0; //the macro back-extrapolated term (follow Equ[5-41b])
/* Vector5d DVP_AV; */
Matrix3d Fij_m; //the macro deformation tensor in grain
Matrix3d UDWdot_m; //the BC velocity gradient;
Matrix3d Udot_m; // L matrix
Matrix3i IUdot; //the flag of known (control by Udot_m) and unknown (calculated by EVPSC) velocity components
Vector6i IDdot; //the flag of known and unknown strain rate components
Vector6i ISdot; //the flag of known and unknown stress componets
/* Matrix3d Dij_m; //the macro strain rate tensor */
Matrix3d Wij_m; //the macro rotation rate tensor
Matrix3d Udot_AV;
// Udot_m = Dij_m + Wij_m
Matrix3d Dij_AV; //the average strain rate tensor of all garins
Matrix3d Dije_AV; //the elastic part
Matrix3d Dijp_AV; //the vp part
Matrix3d Eps_m; //macro strain
Matrix3d Sig_m; //macro stress
Matrix3d Sig_AV; //the average stress tensor of all garins
Matrix3d Sig_m_old; //macro stress in last increment
//some parameters for error control and iteration control
double SC_err_m = 0.01; //the error limit of Self-consistent compliance or stiffness
int SC_iter_m = 30; //the max iteration number of SC
double errD_m = 0.01; //error limit between the input macro strain rate and output at each iteration
double errS_m = 0.01; //error limit of the macro stress
double err_g_AV = 0.01; //error limit of the average grain stress
Matrix3d Sig_in;
Matrix3d Dij_in;
Matrix3d sig_in_AV;
Matrix6d Msup;
// Matrices for restoration
Matrix3d Wij_m_old, Dij_m_old, Dije_AV_old, Dijp_AV_old;
public:
polycrystal();
grain* g = NULL;
int grains_num = 0;
int family_count = 0;
vector<int> modes_count_by_family;
vector<double> density_by_family, acc_strain_by_family, crss_by_family;
double error_SC = 0., twin_threshold = 1., temperature_poly = 0., temp_poly_old = 0.;
Matrix3d Dij_m; //the macro strain rate tensor
Matrix3d thermal_strain_m;//the macro thermal strain tensor
Matrix3d ther_strain_m_old;//the macro thermal strain tensor in last increment
Vector5d DVP_AV;
Matrix5d M_VP_SC; //The visco-plastic compliance C_VP_SC^-1
void ini_from_json(json &j);
void ini_Udot_m(Matrix3d);
void ini_Sig_m(Matrix3d);
void set_IUdot(Matrix3i);
void set_ISdot(Vector6i);
void set_BC_const(Matrix3d, Matrix3d, Matrix3i, Vector6i);
//input the number of grains
int grains_n(int);
int check_grains_n();
int add_grain(Vector4d, int tp_id, int mode_id);
//input the euler angles and weights
//needs loop over grains
void ini_euler(Vector4d, int);
void Norm_weight();
int ini_cry(string, VectorXd);
int ini_cry(json &j);
//input the crystal constant
void check_cry();
int get_Millern();
//output the need number of Miller indice
void ini_Cij6(MatrixXd);
//input the elastic constant in 6X6 tensor
int check_Cij6();
int ini_therm(Vector6d);
//input the thermal expansion coefficients [K^(-1)]
int check_therm();
int ini_gmode(int n);
int ini_gmode(json &j);
//input the deformation modes
//needs loop over grains
int check_gmode();
//input the normal and Burgers vector of deformation system in a mode
//input parameters:
//(MatrixXd) sn, (int) flag of twin or slip, (int) number of systems,(int) mode label
//needs loop over grains
int ini_sn(MatrixXd, int, int, int);
int check_sn();
int ini_GZ(double);
//input the grain size;
int ini_hardening(double, VectorXd, VectorXd, int, int);
//input the hardening parameters
//input parameters:
//double nrsx_in; VectorXd CRSS_p_in; VectorXd hst_in; int modei
int check_hardening();
int Update_Fij(double);
int Update_shape();
Vector3d get_ell_axis();
Vector3d get_ellip_ang();
//the singular step according to a certain process
int EVPSC(int, double);
//calculate the macro&grain elastic compliance
int Selfconsistent_E(int, double, int);
//calculate the macro&grain VP compliance
int Selfconsistent_P(int, double, int);
// status management
void save_status();
void restore_status(bool reset);
void update_status(double time_incre);
void update_twin_control();
// calculate the Sig_m and Dij_m
void Cal_Sig_m(double);
// calculate the Sig_g and Dij_g including the elastic and vp part
double Cal_Sig_g(double);
void Update_AV(); //update the volume average value
//output
Vector6d get_Sig_m();
Vector6d get_Sig_ave();
Vector6d get_Eps_m();
void get_euler(fstream &);
void update_info_by_family();
// Set the temperature in polyX and all grains to the given value
void set_temperature(double);
// Update the temperature in polyX and all grains by the given increment
void update_temperature(double time_incre);
};
}
#endif