Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.9 KiB

2 years ago
C Copyright(C) 1999-2020 National Technology & Engineering Solutions
C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
C NTESS, the U.S. Government retains certain rights in this software.
C
C See packages/seacas/LICENSE for details
C=======================================================================
SUBROUTINE FNDDIS (NAMECO, NAMENV,
& DEFOK, NDIM, NVARNP, IXDEF, IYDEF, IZDEF)
C=======================================================================
C --*** FNDDIS *** (MESH) Find displacement variables
C -- Written by Amy Gilkey - revised 01/25/88
C --
C --FNDDIS finds the displacement variables. The first two/three nodal
C --variables are displacement variables if and only if they begin with
C --'D' and end with the last character of the corresponding coordinate
C --name.
C --
C --Parameters:
C -- NAMECO - IN - the coordinate names
C -- NAMENV - IN - the nodal variable names
C -- DEFOK - OUT - true iff the displacement variables were found
C -- NDIM - IN - number of dimensions
C -- NVARNP - IN - number of nodal variables
C -- IXDEF, IYDEF, IZDEF - OUT - the indices of the displacement variables
C --
LOGICAL IS3DIM
include 'exodusII.inc'
CHARACTER*(MXSTLN) NAMECO(NDIM)
CHARACTER*(MXSTLN) NAMENV(NVARNP)
LOGICAL DEFOK
C ... Size of this string must be large enough to hold 3 names plus other info
C See print near bottom.
CHARACTER*400 STRING
IS3DIM = (NDIM .EQ. 3)
IF (NVARNP .GE. NDIM) THEN
C --Locate displacement variables
DEFOK = .TRUE.
NDEF0 = 0
LN = MAX (LENSTR (NAMENV(1)), 2)
DO 100 I = 1, NDIM
LC = LENSTR (NAMECO(I))
IF ((NAMENV(I)(1:1) .NE. 'D')
& .OR. (NAMENV(I)(1:LN-1) .NE. NAMENV(1)(1:LN-1))
& .OR. (NAMENV(I)(LN:LN) .NE. NAMECO(I)(LC:LC)))
& DEFOK = .FALSE.
100 CONTINUE
IF (DEFOK) THEN
ixdef = ndef0 + 1
iydef = ndef0 + 2
izdef = ndef0 + 3
END IF
ELSE
C --If not at least NDIM vars, no displacement variables
DEFOK = .FALSE.
END IF
IF (.NOT. DEFOK) THEN
WRITE (*, 10000)
10000 FORMAT (/,
& ' A valid set of displacement functions cannot be found.', /
& ' Your mesh plots will not be deformed.')
IXDEF = 0
IYDEF = 0
IZDEF = 0
ELSE
WRITE (*, *)
IF (.NOT. IS3DIM) THEN
WRITE (STRING, '(10A)') 'Displacement variables are ',
& NAMENV(IXDEF), ' ', NAMENV(IYDEF)
ELSE
WRITE (STRING, '(10A)') 'Displacement variables are ',
& NAMENV(IXDEF), ' ', NAMENV(IYDEF), ' ', NAMENV(IZDEF)
END IF
CALL SQZSTR (STRING, LSTR)
WRITE (*, 10010) STRING(:LSTR)
10010 FORMAT (1X, 5A)
END IF
RETURN
END