-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdiffuselongshoreY.m
63 lines (52 loc) · 1.97 KB
/
diffuselongshoreY.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
function F=diffuseVELOCITYX(A,F,alpha,dx,h);
D=h.*A*(alpha*3600*24)/(dx^2);
G=0*F;
p=find(A==1);%exclude the NOLAND CELLS (A==0)
NN=length(p);G(p)=[1:NN];rhs=F(p);[m,n]=size(G);i=[];j=[];s=[];
S=0*G;
[row col]=ind2sub(size(A),p);
for k = [-m m]
%avoid to the the cells out of the domain (risk to make it periodic...)
if k==m;aa=find(col+1<=n);end;if k==-m;aa=find(col-1>0);end;if k==-1;aa=find(row-1>0);end;if k==1;aa=find(row+1<=m);end;
q=p+k;%the translated cell
a=aa(A(q(aa))==1 );%only inclued the cells in whcih you can creep to
%value=min(D(p(a)),D(q(a)));%value=(D(p(a))+D(q(a)))/2.*facNL;
%value=max(D(p(a)),D(q(a)));
value=(D(p(a))+D(q(a)))/2;%.*facNL;
S(p(a))=S(p(a))+value; %exit from that cell
i=[i;G(q(a))]; j=[j;G(p(a))]; s=[s;-value]; %gain from the neigborh cell
end
%summary of the material that exits the cell
i=[i;G(p)]; j=[j;G(p)]; s=[s;1+S(p)];
ds2 = sparse(i,j,s);%solve the matrix inversion
P=ds2\rhs;F(G>0)=full(P(G(G>0)));
% D=h.*A*(alpha*3600*24)/(dx^2);
%
%
% G=0*F;
% p=find(A==1);%exclude the NOLAND CELLS (A==0)
% NN=length(p);G(p)=[1:NN];rhs=F(p);[m,n]=size(G);i=[];j=[];s=[];
%
% S=0*G;
% [row col]=ind2sub(size(A),p);
% for k = [m -1 1 -m]
% %avoid to the the cells out of the domain (risk to make it periodic...)
% if k==m;aa=find(col+1<=n);end;if k==-m;aa=find(col-1>0);end;if k==-1;aa=find(row-1>0);end;if k==1;aa=find(row+1<=m);end;
%
% q=p+k;%the translated cell
% a=aa(A(q(aa))==1 );%only inclued the cells in whcih you can creep to
%
% if k==1 | k==-1
% value=0.2*(D(p(a))+D(q(a)))/2;%value=(D(p(a))+D(q(a)))/2.*facNL;
% else
% value=(D(p(a))+D(q(a)))/2;%value=(D(p(a))+D(q(a)))/2.*facNL;
% end
%
% S(p(a))=S(p(a))+value; %exit from that cell
% i=[i;G(q(a))]; j=[j;G(p(a))]; s=[s;-value]; %gain from the neigborh cell
% end
%
% %summary of the material that exits the cell
% i=[i;G(p)]; j=[j;G(p)]; s=[s;1+S(p)];
% ds2 = sparse(i,j,s);%solve the matrix inversion
% P=ds2\rhs;F(G>0)=full(P(G(G>0)));