forked from jaolive/SiStER
-
Notifications
You must be signed in to change notification settings - Fork 0
/
SiStER_patch_marker_holes.m
162 lines (127 loc) · 5.36 KB
/
SiStER_patch_marker_holes.m
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
function [xm, ym, im, Ifix, mp, ep, idm, Tm, sxxm, sxym, epNH, epsIIm]=SiStER_patch_marker_holes(icn,jcn,quad,Nx,Ny,Mquad,Mquad_crit,xm,ym,x,y,dx,dy,im,ep,idm,Tm,sxxm,sxym,epNH,epsIIm)
% function [xm, ym, im, Ifix, mp, ep, idm, Tm, sxxm, sxym, epNH, epsIIm]=SiStER_patch_marker_holes(icn,jcn,quad,Nx,Ny,Mquad,Mquad_crit,xm,ym,x,y,dx,dy,im,ep,idm,Tm,sxxm,sxym,epNH,epsIIm)
%
% seeds new markers in all quadrants where marker density has fallen below
% the threshold
% AND THEN assigns those new markers a marker index, a marker phase and a plastic
% strain based on the properties of the markers surrounding them
% (these particular properties are never passed on the grid, e.g. plastic strain...)
%
% J.-A. Olive, and B.Z. Klein, 2012-2014
M=length(xm);
md_crit=Mquad_crit;
mark_per_quad=Mquad;
mdx=min(dx)/2;
mdy=min(dy)/2;
%%%%%%%%%%%%%%% LOOK FOR EMPTY (no more markers) QUADRANTS
mp = accumarray({icn, jcn, quad}, 1, [Ny-1, Nx-1, 4]);
empty = find(mp==0);
display_message_if_empty=0;
if display_message_if_empty==1
if(~isempty(empty))
[iEmpty,jEmpty,kEmpty] = ind2sub(size(mp), empty);
for n = 1:min(length(iEmpty), 100)
disp(['WARNING ! Empty quadrant number ' num2str(kEmpty(n)) ' in cell i = ' num2str(iEmpty(n)) ', j = ' num2str(jEmpty(n))])
end
end
end
%%%%% LOCATE QUADRANTS WHERE MARKER DENSITY IS BELOW THRESHOLD
mpCrInd = find(mp<md_crit);
[iicr, jjcr, qqcr] = ind2sub(size(mp), mpCrInd);
iicr = iicr';
jjcr = jjcr';
qqcr = qqcr';
% NEED TO SEED NEW MARKERS IN THOSE QUADRANTS
% SO THAT WE ARE BACK TO THE INITIAL MARKER DENSITY IN THOSE QUADRANTS
xrsd=[];
yrsd=[];
im_fix=[]; % marker phase
ep_fix=[]; % plastic strain
epNH_fix=[]; % non-healed plastic strain
te_fix=[]; % temperature
sxx_fix=[]; % stress
sxy_fix=[]; % stress
sr_fix=[]; % strain rate
if ~isempty(iicr) % if there are critical quadrants
for c=1:length(iicr) % go through all critical quadrants
% the upper-left node of the corresponding cell is
icell=iicr(c);
jcell=jjcr(c);
qcell=qqcr(c);
% the quadrant area in that cell is
qsize=0.25*dx(jcell)*dy(icell);
% if the smallest quadrant in the domain (area mdx*mdy) has
% mark_per_quad markers, then this critical quadrant needs
Nfix=ceil(qsize/(mdx*mdy))*mark_per_quad;
Nfix=max(Nfix-mp(iicr(c),jjcr(c),qqcr(c)),1);
% find the coordinates of the upper-left corner of the quadrant
if qcell==1 || qcell==4
xcorn=x(jcell);
else
xcorn=x(jcell)+dx(jcell)/2;
end
if qcell==1 || qcell==2
ycorn=y(icell);
else
ycorn=y(icell)+dy(icell)/2;
end
% draw random marker location
[xmrr, ymrr]=SiStER_seed_markers_uniformly(xcorn,ycorn,dx(jcell)/2,dy(icell)/2,Nfix);
xrsd=[xrsd xmrr];
yrsd=[yrsd ymrr];
%%%% NOW THAT THE NEW MARKERS ARE SEEDED,
%%%%% ASSIGN PARAMETERS THAT ARE NEVER STORED ON THE EULERIAN GRID
% the value is assigned based on the average, or max. value of the
% markers that remain in the corresponding CELL (since there's no grid value to interpolate from)
% CAREFUL THIS CANNOT WORK IF WE END UP WITH AN EMPTY CELL
% if that was to happen, let's just draw "im" randomly
if isempty((ep(icn==icell & jcn==jcell)))==1
disp('WARNING ! - EMPTY CELL - SOMETHING IS VERY WRONG...')
im_fix=1+floor(rand(1,Nfix)*max(im)); % random phase number
ep_fix=zeros(1,Nfix);
epNH_fix=zeros(1,Nfix);
te_fix=zeros(1,Nfix);
sxx_fix=zeros(1,Nfix);
sxy_fix=zeros(1,Nfix);
sr_fix=zeros(1,Nfix);
else
% assign the average phase of the markers that are left in the cell
phase_fix=round(mode((im(icn==icell & jcn==jcell))));
% assign the greatest plastic strain of the markers that are left in the cell
strain_fix=max((ep(icn==icell & jcn==jcell)));
strainNH_fix=max((epNH(icn==icell & jcn==jcell)));
% assign the average temperature of the markers that are left in
% the cell
temp_fix=mean((Tm(icn==icell & jcn==jcell)));
% reassign mean stress / strain rate of markers left in cell
stress_xx_fix=mean((sxxm(icn==icell & jcn==jcell)));
stress_xy_fix=mean((sxym(icn==icell & jcn==jcell)));
strainrate_fix=mean((epsIIm(icn==icell & jcn==jcell)));
end
im_fix=[im_fix phase_fix*ones(1,Nfix)];
ep_fix=[ep_fix strain_fix*ones(1,Nfix)];
epNH_fix=[epNH_fix strainNH_fix*ones(1,Nfix)];
te_fix=[te_fix temp_fix*ones(1,Nfix)];
sxx_fix=[sxx_fix stress_xx_fix*ones(1,Nfix)];
sxy_fix=[sxy_fix stress_xy_fix*ones(1,Nfix)];
sr_fix=[sr_fix strainrate_fix*ones(1,Nfix)];
end
% NOW ASSIGN PROPERTIES TO THOSE MARKERS
Npatch=length(xrsd);
index_fix=max(idm)+1:max(idm)+Npatch;
Ifix=M+1:1:M+Npatch; % total number of markers added to fix holes in critical quadrants
xm(Ifix)=xrsd;
ym(Ifix)=yrsd;
im(Ifix)=im_fix;
ep(Ifix)=ep_fix;
epNH(Ifix)=epNH_fix;
idm(Ifix)=index_fix;
Tm(Ifix)=te_fix;
sxxm(Ifix)=sxx_fix;
sxym(Ifix)=sxy_fix;
epsIIm(Ifix)=sr_fix;
% uncomment to display number of added markers
%fprintf('\n%d%s%d%s\n', length(Ifix), ' markers added in ', length(iicr), ' cell quadrants.')
else
Ifix=0;
end