-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathedgesFinalize.f90
102 lines (84 loc) · 3.27 KB
/
edgesFinalize.f90
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
!> @file edgesFinalize.f90
!!
!! Generation of final edge list.
!
! *****************************************************************************
!
! (c) J. Blazek, CFD Consulting & Analysis, www.cfd-ca.de
! Created February 25, 2014
! Last modification: May 22, 2014
!
! *****************************************************************************
!
! This program is free software; you can redistribute it and/or
! modify it under the terms of the GNU General Public License
! as published by the Free Software Foundation; either version 2
! of the License, or (at your option) any later version.
!
! This program is distributed in the hope that it will be useful,
! but WITHOUT ANY WARRANTY; without even the implied warranty of
! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
! GNU General Public License for more details.
!
! You should have received a copy of the GNU General Public License
! along with this program; if not, write to the Free Software
! Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
!
! *****************************************************************************
!> Generates final edge list (interior edges, edges to dummy nodes) using
!! the temporary lists "niedge" and "iedge".
!!
!! @param niedge pointer from a node to iedge()
!! @param iedge linked list of edge endpoints:
!! @li (1,*) = point j of edge (i,j)
!! @li (2,*) = next point j which is also connected to i;
!! if <0 - no further connections
!! @li (3,*) = pointer to edge() - used in InitMetrics to associate
!! face vector sij() with the correct edge
!!
subroutine EdgesFinalize( niedge,iedge )
use ModGeometry
use ModNumerics
use ModInterfaces, only : ErrorMessage
implicit none
! parameters
integer :: niedge(:), iedge(:,:)
! local variables
integer :: errFlag, i, ibn, ie, cedge
! *****************************************************************************
allocate( edge(2,nedges),stat=errFlag )
if (errFlag /= 0) call ErrorMessage( "cannot allocate memory for edge()" )
ie = 0 ! edge counter
do i=1,nndint
! - loop over all grid nodes
cedge = niedge(i)
if (cedge > 0) then
10 continue
! ----- loop over all edges adjacent to node "i"
ie = ie + 1
edge(1,ie) = i
edge(2,ie) = iedge(1,cedge)
iedge(3,cedge) = ie ! we need it in InitMetrics
cedge = iedge(2,cedge) ! next adjacent edge
if (cedge < 0) goto 20
goto 10
20 continue
endif
enddo
if (ie /= nedint) then
call ErrorMessage( "did not get the correct number of interior edges" )
endif
! add edges to dummy nodes;
! store 'dummy' edges in "bnode(3,*)"
do ibn=1,nbnodes
if (bnode(3,ibn) == -1) then ! dummy node here (see DummyNodes)
ie = ie + 1
edge(1,ie) = bnode(1,ibn) ! boundary node first
edge(2,ie) = bnode(2,ibn) ! dummy node second
bnode(3,ibn) = ie
endif
enddo
if (ie /= nedges) then
call ErrorMessage( "did not get the correct number of dummy edges" )
endif
end subroutine EdgesFinalize