Rocstar  1.0
Rocstar multiphysics simulation application
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
RFLU_ModGrid.F90
Go to the documentation of this file.
1 ! *********************************************************************
2 ! * Rocstar Simulation Suite *
3 ! * Copyright@2015, Illinois Rocstar LLC. All rights reserved. *
4 ! * *
5 ! * Illinois Rocstar LLC *
6 ! * Champaign, IL *
7 ! * www.illinoisrocstar.com *
8 ! * sales@illinoisrocstar.com *
9 ! * *
10 ! * License: See LICENSE file in top level of distribution package or *
11 ! * http://opensource.org/licenses/NCSA *
12 ! *********************************************************************
13 ! *********************************************************************
14 ! * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, *
15 ! * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES *
16 ! * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND *
17 ! * NONINFRINGEMENT. IN NO EVENT SHALL THE CONTRIBUTORS OR *
18 ! * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
19 ! * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
20 ! * Arising FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE *
21 ! * USE OR OTHER DEALINGS WITH THE SOFTWARE. *
22 ! *********************************************************************
23 ! ******************************************************************************
24 !
25 ! Purpose: Define the derived data types related to grids in ROCFLU.
26 !
27 ! Description: None
28 !
29 ! Notes: None
30 !
31 ! ******************************************************************************
32 !
33 ! $Id: RFLU_ModGrid.F90,v 1.15 2008/12/06 08:44:22 mtcampbe Exp $
34 !
35 ! Copyright: (c) 2001-2004 by the University of Illinois
36 !
37 ! ******************************************************************************
38 
40 
41  USE moddatatypes
42  USE modparameters
43 
44  IMPLICIT NONE
45 
46 ! ******************************************************************************
47 ! Boundary type
48 ! ******************************************************************************
49 
50  TYPE bound_t
51  INTEGER :: bType,nBTris,nBQuads
52  INTEGER, DIMENSION(:,:), POINTER :: bTri2v,bQuad2v
53  CHARACTER(CHRLEN) :: bName
54  END TYPE bound_t
55 
56  TYPE(bound_t), DIMENSION(:), ALLOCATABLE :: bound
57 
58 ! ******************************************************************************
59 ! Mapping from faces to vertices for ROCFLU grid definition
60 ! ******************************************************************************
61 
62  INTEGER, DIMENSION(4,4), PARAMETER :: f2vTet = &
63  RESHAPE((/1,2,3,VERT_NONE,2,4,3,VERT_NONE,1,3,4,VERT_NONE,1,4,2, &
64  VERT_NONE/), (/4,4/))
65  INTEGER, DIMENSION(4,6), PARAMETER :: f2vHex = &
66  RESHAPE((/1,4,3,2,1,2,6,5,2,3,7,6,3,4,8,7,1,5,8,4,5,6,7,8/), (/4,6/))
67  INTEGER, DIMENSION(4,5), PARAMETER :: f2vPri = &
68  RESHAPE((/1,3,2,VERT_NONE,1,2,5,4,2,3,6,5,1,4,6,3,4,5,6, &
69  VERT_NONE/), (/4,5/))
70  INTEGER, DIMENSION(4,5), PARAMETER :: f2vPyr = &
71  RESHAPE((/1,4,3,2,1,2,5,VERT_NONE,2,3,5,VERT_NONE,3,4,5,VERT_NONE,1,5,4, &
72  VERT_NONE/), (/4,5/))
73 
74 ! ******************************************************************************
75 ! Mapping from faces to opposite faces for ROCFLU grid definition
76 ! ******************************************************************************
77 
78  INTEGER, DIMENSION(6), PARAMETER :: f2fOppHex = (/6,4,5,2,3,1/)
79  INTEGER, DIMENSION(5), PARAMETER :: f2fOppPri = &
80  (/5,FACE_NONE,FACE_NONE,FACE_NONE,1/)
81 
82 ! ******************************************************************************
83 ! Mapping from cell edges to vertices for ROCFLU grid definition
84 ! ******************************************************************************
85 
86  INTEGER, DIMENSION(2,6), PARAMETER :: ce2vTet = &
87  RESHAPE((/1,2,2,3,1,3,1,4,2,4,3,4/), (/2,6/))
88  INTEGER, DIMENSION(2,12), PARAMETER :: ce2vHex = &
89  RESHAPE((/1,2,2,3,3,4,1,4,5,6,6,7,7,8,5,8,1,5,2,6,3,7,4,8/), (/2,12/))
90  INTEGER, DIMENSION(2,9), PARAMETER :: ce2vPri = &
91  RESHAPE((/1,2,2,3,1,3,1,4,2,5,3,6,4,5,5,6,4,6/), (/2,9/))
92  INTEGER, DIMENSION(2,8), PARAMETER :: ce2vPyr = &
93  RESHAPE((/1,2,2,3,3,4,1,4,1,5,2,5,3,5,4,5/), (/2,8/))
94 
95 END MODULE rflu_modgrid
96 
97 ! ******************************************************************************
98 !
99 ! RCS Revision history:
100 !
101 ! $Log: RFLU_ModGrid.F90,v $
102 ! Revision 1.15 2008/12/06 08:44:22 mtcampbe
103 ! Updated license.
104 !
105 ! Revision 1.14 2008/11/19 22:17:33 mtcampbe
106 ! Added Illinois Open Source License/Copyright
107 !
108 ! Revision 1.13 2004/09/27 01:39:26 haselbac
109 ! Added arrays for opposing faces
110 !
111 ! Revision 1.12 2004/07/06 15:14:41 haselbac
112 ! Removed data types for grid generators and patchDimens
113 !
114 ! Revision 1.11 2004/02/16 01:10:27 haselbac
115 ! Added PARAMETER qualifyer to avoid problems on Apple OS X
116 !
117 ! Revision 1.10 2003/08/19 22:49:07 haselbac
118 ! Added COBALT grid type
119 !
120 ! Revision 1.9 2003/03/19 16:47:09 haselbac
121 ! Added gridTETMESH type
122 !
123 ! Revision 1.8 2003/03/15 18:10:40 haselbac
124 ! Added VERT_NONE, *2vTEC, changed patchDimens
125 !
126 ! Revision 1.7 2003/01/28 16:32:05 haselbac
127 ! Added patchDimens and ModParameters
128 !
129 ! Revision 1.6 2002/10/27 19:07:39 haselbac
130 ! Added c2v arrays for edge list construction
131 !
132 ! Revision 1.5 2002/03/01 16:22:32 haselbac
133 ! Added face to vertex mapping arrays
134 !
135 ! Revision 1.4 2002/01/15 15:52:07 haselbac
136 ! Added grid types for grid generators
137 !
138 ! ******************************************************************************
139 
140 
141 
142 
143 
144