Merge remote-tracking branch 'origin/MiscImprovements' into development
This commit is contained in:
commit
b72b6b660e
|
@ -1,8 +1,5 @@
|
||||||
*.pyc
|
*.pyc
|
||||||
*.mod
|
|
||||||
*.o
|
|
||||||
*.hdf5
|
*.hdf5
|
||||||
*.exe
|
|
||||||
*.bak
|
*.bak
|
||||||
*~
|
*~
|
||||||
bin
|
bin
|
||||||
|
|
317
CMakeLists.txt
317
CMakeLists.txt
|
@ -105,12 +105,13 @@ set (CMAKE_C_COMPILER "${PETSC_MPICC}")
|
||||||
# Now start to care about DAMASK
|
# Now start to care about DAMASK
|
||||||
|
|
||||||
# DAMASK solver defines project to build
|
# DAMASK solver defines project to build
|
||||||
if (DAMASK_SOLVER STREQUAL "GRID")
|
string(TOLOWER ${DAMASK_SOLVER} DAMASK_SOLVER)
|
||||||
project (DAMASK_grid Fortran C)
|
if (DAMASK_SOLVER STREQUAL "grid")
|
||||||
|
project (damask-grid Fortran C)
|
||||||
add_definitions (-DGrid)
|
add_definitions (-DGrid)
|
||||||
message ("Building Grid Solver\n")
|
message ("Building Grid Solver\n")
|
||||||
elseif (DAMASK_SOLVER STREQUAL "FEM")
|
elseif (DAMASK_SOLVER STREQUAL "fem" OR DAMASK_SOLVER STREQUAL "mesh")
|
||||||
project (DAMASK_FEM Fortran C)
|
project (damask-mesh Fortran C)
|
||||||
add_definitions (-DFEM)
|
add_definitions (-DFEM)
|
||||||
message ("Building FEM Solver\n")
|
message ("Building FEM Solver\n")
|
||||||
else ()
|
else ()
|
||||||
|
@ -156,22 +157,6 @@ if (CMAKE_BUILD_TYPE STREQUAL "SYNTAXONLY")
|
||||||
set (BUILDCMD_POST "${BUILDCMD_POST} -fsyntax-only")
|
set (BUILDCMD_POST "${BUILDCMD_POST} -fsyntax-only")
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
# Parse DAMASK_BIN from CONFIG file
|
|
||||||
file (READ "CONFIG" CONFIGFILE)
|
|
||||||
string (REGEX REPLACE ";" "\\\\;" CONFIGFILE "${CONFIGFILE}")
|
|
||||||
string (REGEX REPLACE "\n" ";" CONFIGFILE "${CONFIGFILE}")
|
|
||||||
foreach (item ${CONFIGFILE})
|
|
||||||
string (REGEX MATCH ".+DAMASK_BIN.+" item ${item})
|
|
||||||
if (item)
|
|
||||||
string (REGEX REPLACE "set" "" item "${item}")
|
|
||||||
string (REGEX REPLACE "=" " " item "${item}")
|
|
||||||
string (REGEX REPLACE "\\\${DAMASK_ROOT}" "${PROJECT_SOURCE_DIR}" item "${item}")
|
|
||||||
string (REPLACE "DAMASK_BIN" ";" STRING_LIST ${item})
|
|
||||||
list (GET STRING_LIST 1 item)
|
|
||||||
string (STRIP "${item}" CMAKE_INSTALL_PREFIX)
|
|
||||||
endif ()
|
|
||||||
endforeach(item ${CONFIGFILE})
|
|
||||||
|
|
||||||
# Parse DAMASK version from VERSION file
|
# Parse DAMASK version from VERSION file
|
||||||
find_program (CAT_EXECUTABLE NAMES cat)
|
find_program (CAT_EXECUTABLE NAMES cat)
|
||||||
execute_process (COMMAND ${CAT_EXECUTABLE} ${PROJECT_SOURCE_DIR}/VERSION
|
execute_process (COMMAND ${CAT_EXECUTABLE} ${PROJECT_SOURCE_DIR}/VERSION
|
||||||
|
@ -184,283 +169,14 @@ add_definitions (-DDAMASKVERSION="${DAMASK_V}")
|
||||||
add_definitions (-DPETSc)
|
add_definitions (-DPETSc)
|
||||||
|
|
||||||
set (DAMASK_INCLUDE_FLAGS "${DAMASK_INCLUDE_FLAGS} ${PETSC_INCLUDES}")
|
set (DAMASK_INCLUDE_FLAGS "${DAMASK_INCLUDE_FLAGS} ${PETSC_INCLUDES}")
|
||||||
|
list(APPEND CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake)
|
||||||
|
|
||||||
###################################################################################################
|
|
||||||
# Intel Compiler
|
|
||||||
###################################################################################################
|
|
||||||
if (CMAKE_Fortran_COMPILER_ID STREQUAL "Intel")
|
if (CMAKE_Fortran_COMPILER_ID STREQUAL "Intel")
|
||||||
|
include(Compiler-Intel)
|
||||||
if (OPENMP)
|
|
||||||
set (OPENMP_FLAGS "-qopenmp -parallel")
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
if (OPTIMIZATION STREQUAL "OFF")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O0 -no-ip")
|
|
||||||
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O2")
|
|
||||||
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-ipo -O3 -no-prec-div -fp-model fast=2 -xHost")
|
|
||||||
# -fast = -ipo, -O3, -no-prec-div, -static, -fp-model fast=2, and -xHost"
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
# -assume std_mod_proc_name (included in -standard-semantics) causes problems if other modules
|
|
||||||
# (PETSc, HDF5) are not compiled with this option (https://software.intel.com/en-us/forums/intel-fortran-compiler-for-linux-and-mac-os-x/topic/62172)
|
|
||||||
set (STANDARD_CHECK "-stand f15 -standard-semantics -assume nostd_mod_proc_name")
|
|
||||||
set (LINKER_FLAGS "${LINKER_FLAGS} -shared-intel")
|
|
||||||
# Link against shared Intel libraries instead of static ones
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Fine tuning compilation options
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -fpp")
|
|
||||||
# preprocessor
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ftz")
|
|
||||||
# flush underflow to zero, automatically set if -O[1,2,3]
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -diag-disable")
|
|
||||||
# disables warnings ...
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} 5268")
|
|
||||||
# ... the text exceeds right hand column allowed on the line (we have only comments there)
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -warn")
|
|
||||||
# enables warnings ...
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} declarations")
|
|
||||||
# ... any undeclared names (alternative name: -implicitnone)
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},general")
|
|
||||||
# ... warning messages and informational messages are issued by the compiler
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},usage")
|
|
||||||
# ... questionable programming practices
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},interfaces")
|
|
||||||
# ... checks the interfaces of all SUBROUTINEs called and FUNCTIONs invoked in your compilation against an external set of interface blocks
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},ignore_loc")
|
|
||||||
# ... %LOC is stripped from an actual argument
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},alignments")
|
|
||||||
# ... data that is not naturally aligned
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS},unused")
|
|
||||||
# ... declared variables that are never used
|
|
||||||
|
|
||||||
# Additional options
|
|
||||||
# -warn: enables warnings, where
|
|
||||||
# truncated_source: Determines whether warnings occur when source exceeds the maximum column width in fixed-format files.
|
|
||||||
# (too many warnings because we have comments beyond character 132)
|
|
||||||
# uncalled: Determines whether warnings occur when a statement function is never called
|
|
||||||
# all:
|
|
||||||
# -name as_is: case sensitive Fortran!
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Runtime debugging
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
|
||||||
# Generate symbolic debugging information in the object file
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -traceback")
|
|
||||||
# Generate extra information in the object file to provide source file traceback information when a severe error occurs at run time
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -gen-interfaces")
|
|
||||||
# Generate an interface block for each routine. http://software.intel.com/en-us/blogs/2012/01/05/doctor-fortran-gets-explicit-again/
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fp-stack-check")
|
|
||||||
# Generate extra code after every function call to ensure that the floating-point (FP) stack is in the expected state
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fp-model strict")
|
|
||||||
# Trap uninitalized variables
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -check" )
|
|
||||||
# Checks at runtime ...
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} bounds")
|
|
||||||
# ... if an array index is too small (<1) or too large!
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS},format")
|
|
||||||
# ... for the data type of an item being formatted for output.
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS},output_conversion")
|
|
||||||
# ... for the fit of data items within a designated format descriptor field.
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS},pointers")
|
|
||||||
# ... for certain disassociated or uninitialized pointers or unallocated allocatable objects.
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS},uninit")
|
|
||||||
# ... for uninitialized variables.
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -ftrapuv")
|
|
||||||
# ... initializes stack local variables to an unusual value to aid error detection
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fpe-all=0")
|
|
||||||
# ... capture all floating-point exceptions, sets -ftz automatically
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -warn")
|
|
||||||
# enables warnings ...
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} errors")
|
|
||||||
# ... warnings are changed to errors
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS},stderrors")
|
|
||||||
# ... warnings about Fortran standard violations are changed to errors
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -debug-parameters all")
|
|
||||||
# generate debug information for parameters
|
|
||||||
|
|
||||||
# Additional options
|
|
||||||
# -heap-arrays: Should not be done for OpenMP, but set "ulimit -s unlimited" on shell. Probably it helps also to unlimit other limits
|
|
||||||
# -check: Checks at runtime, where
|
|
||||||
# arg_temp_created: will cause a lot of warnings because we create a bunch of temporary arrays (performance?)
|
|
||||||
# stack:
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# precision settings
|
|
||||||
set (PRECISION_FLAGS "${PRECISION_FLAGS} -real-size 64")
|
|
||||||
# set precision for standard real to 32 | 64 | 128 (= 4 | 8 | 16 bytes, type pReal is always 8 bytes)
|
|
||||||
|
|
||||||
|
|
||||||
###################################################################################################
|
|
||||||
# GNU Compiler
|
|
||||||
###################################################################################################
|
|
||||||
elseif(CMAKE_Fortran_COMPILER_ID STREQUAL "GNU")
|
elseif(CMAKE_Fortran_COMPILER_ID STREQUAL "GNU")
|
||||||
|
include(Compiler-GNU)
|
||||||
if (OPENMP)
|
|
||||||
set (OPENMP_FLAGS "-fopenmp")
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
if (OPTIMIZATION STREQUAL "OFF")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O0" )
|
|
||||||
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O2")
|
|
||||||
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O3 -ffast-math -funroll-loops -ftree-vectorize")
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
set (STANDARD_CHECK "-std=f2008ts -pedantic-errors" )
|
|
||||||
set (LINKER_FLAGS "${LINKER_FLAGS} -Wl")
|
|
||||||
# options parsed directly to the linker
|
|
||||||
set (LINKER_FLAGS "${LINKER_FLAGS},-undefined,dynamic_lookup" )
|
|
||||||
# ensure to link against dynamic libraries
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Fine tuning compilation options
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -xf95-cpp-input")
|
|
||||||
# preprocessor
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ffree-line-length-132")
|
|
||||||
# restrict line length to the standard 132 characters (lattice.f90 require more characters)
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -fimplicit-none")
|
|
||||||
# assume "implicit none" even if not present in source
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wall")
|
|
||||||
# sets the following Fortran options:
|
|
||||||
# -Waliasing: warn about possible aliasing of dummy arguments. Specifically, it warns if the same actual argument is associated with a dummy argument with "INTENT(IN)" and a dummy argument with "INTENT(OUT)" in a call with an explicit interface.
|
|
||||||
# -Wampersand: checks if a character expression is continued proberly by an ampersand at the end of the line and at the beginning of the new line
|
|
||||||
# -Warray-bounds: checks if array reference is out of bounds at compile time. use -fcheck-bounds to also check during runtime
|
|
||||||
# -Wconversion: warn about implicit conversions between different type
|
|
||||||
# -Wsurprising: warn when "suspicious" code constructs are encountered. While technically legal these usually indicate that an error has been made.
|
|
||||||
# -Wc-binding-type:
|
|
||||||
# -Wintrinsics-std: only standard intrisics are available, e.g. "call flush(6)" will cause an error
|
|
||||||
# -Wno-tabs: do not allow tabs in source
|
|
||||||
# -Wintrinsic-shadow: warn if a user-defined procedure or module procedure has the same name as an intrinsic
|
|
||||||
# -Wline-truncation:
|
|
||||||
# -Wtarget-lifetime:
|
|
||||||
# -Wreal-q-constant: warn about real-literal-constants with 'q' exponent-letter
|
|
||||||
# -Wunused: a number of unused-xxx warnings
|
|
||||||
# and sets the general (non-Fortran options) options:
|
|
||||||
# -Waddress
|
|
||||||
# -Warray-bounds (only with -O2)
|
|
||||||
# -Wc++11-compat
|
|
||||||
# -Wchar-subscripts
|
|
||||||
# -Wcomment
|
|
||||||
# -Wformat
|
|
||||||
# -Wmaybe-uninitialized
|
|
||||||
# -Wnonnull
|
|
||||||
# -Wparentheses
|
|
||||||
# -Wpointer-sign
|
|
||||||
# -Wreorder
|
|
||||||
# -Wreturn-type
|
|
||||||
# -Wsequence-point
|
|
||||||
# -Wstrict-aliasing
|
|
||||||
# -Wstrict-overflow=1
|
|
||||||
# -Wswitch
|
|
||||||
# -Wtrigraphs
|
|
||||||
# -Wuninitialized
|
|
||||||
# -Wunknown-pragmas
|
|
||||||
# -Wunused-function
|
|
||||||
# -Wunused-label
|
|
||||||
# -Wunused-value
|
|
||||||
# -Wunused-variable
|
|
||||||
# -Wvolatile-register-var
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wextra")
|
|
||||||
# sets the following Fortran options:
|
|
||||||
# -Wunuses-parameter:
|
|
||||||
# -Wcompare-reals:
|
|
||||||
# and sets the general (non-Fortran options) options:
|
|
||||||
# -Wclobbered
|
|
||||||
# -Wempty-body
|
|
||||||
# -Wignored-qualifiers
|
|
||||||
# -Wmissing-field-initializers
|
|
||||||
# -Woverride-init
|
|
||||||
# -Wsign-compare
|
|
||||||
# -Wtype-limits
|
|
||||||
# -Wuninitialized
|
|
||||||
# -Wunused-but-set-parameter (only with -Wunused or -Wall)
|
|
||||||
# -Wno-globals
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wcharacter-truncation")
|
|
||||||
# warn if character expressions (strings) are truncated
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wunderflow")
|
|
||||||
# produce a warning when numerical constant expressions are encountered, which yield an UNDERFLOW during compilation
|
|
||||||
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wsuggest-attribute=pure")
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wsuggest-attribute=noreturn")
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wconversion-extra")
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wimplicit-procedure")
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wno-unused-parameter")
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ffpe-summary=all")
|
|
||||||
# print summary of floating point exeptions (invalid,zero,overflow,underflow,inexact,denormal)
|
|
||||||
|
|
||||||
# Additional options
|
|
||||||
# -Warray-temporarieswarnings: because we have many temporary arrays (performance issue?):
|
|
||||||
# -Wimplicit-interface: no interfaces for lapack/MPI routines
|
|
||||||
# -Wunsafe-loop-optimizations: warn if the loop cannot be optimized due to nontrivial assumptions.
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Runtime debugging
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -ffpe-trap=invalid,zero,overflow")
|
|
||||||
# stop execution if floating point exception is detected (NaN is silent)
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
|
||||||
# Generate symbolic debugging information in the object file
|
|
||||||
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fbacktrace")
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fdump-core")
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fcheck=all")
|
|
||||||
# checks for (array-temps,bounds,do,mem,pointer,recursion)
|
|
||||||
|
|
||||||
# Additional options
|
|
||||||
# -ffpe-trap=precision,denormal,underflow
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# precision settings
|
|
||||||
set (PRECISION_FLAGS "${PRECISION_FLAGS} -fdefault-real-8")
|
|
||||||
# set precision to 8 bytes for standard real (=8 for pReal). Will set size of double to 16 bytes as long as -fdefault-double-8 is not set
|
|
||||||
set (PRECISION_FLAGS "${PRECISION_FLAGS} -fdefault-double-8")
|
|
||||||
# set precision to 8 bytes for double real, would be 16 bytes if -fdefault-real-8 is used
|
|
||||||
|
|
||||||
|
|
||||||
###################################################################################################
|
|
||||||
# PGI Compiler
|
|
||||||
###################################################################################################
|
|
||||||
elseif(CMAKE_Fortran_COMPILER_ID STREQUAL "PGI")
|
elseif(CMAKE_Fortran_COMPILER_ID STREQUAL "PGI")
|
||||||
|
include(Compiler-PGI)
|
||||||
if (OPTIMIZATION STREQUAL "OFF")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O0" )
|
|
||||||
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O2")
|
|
||||||
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
|
||||||
set (OPTIMIZATION_FLAGS "-O3")
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Fine tuning compilation options
|
|
||||||
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Mpreprocess")
|
|
||||||
# preprocessor
|
|
||||||
|
|
||||||
set (STANDARD_CHECK "-Mallocatable=03")
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------------------------
|
|
||||||
# Runtime debugging
|
|
||||||
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
|
||||||
# Includes debugging information in the object module; sets the optimization level to zero unless a -O option is present on the command line
|
|
||||||
else ()
|
else ()
|
||||||
message (FATAL_ERROR "Compiler type (CMAKE_Fortran_COMPILER_ID) not recognized")
|
message (FATAL_ERROR "Compiler type (CMAKE_Fortran_COMPILER_ID) not recognized")
|
||||||
endif ()
|
endif ()
|
||||||
|
@ -483,18 +199,3 @@ message ("Fortran Linker Command:\n${CMAKE_Fortran_LINK_EXECUTABLE}\n")
|
||||||
|
|
||||||
# location of code
|
# location of code
|
||||||
add_subdirectory (src)
|
add_subdirectory (src)
|
||||||
|
|
||||||
# INSTALL BUILT BINARIES
|
|
||||||
if (CMAKE_BUILD_TYPE STREQUAL "SYNTAXONLY")
|
|
||||||
exec_program (mktemp OUTPUT_VARIABLE nothing)
|
|
||||||
exec_program (mktemp ARGS -d OUTPUT_VARIABLE black_hole)
|
|
||||||
install (PROGRAMS ${nothing} DESTINATION ${black_hole})
|
|
||||||
else ()
|
|
||||||
if (PROJECT_NAME STREQUAL "DAMASK_grid")
|
|
||||||
install (PROGRAMS ${PROJECT_BINARY_DIR}/src/DAMASK_spectral
|
|
||||||
DESTINATION ${CMAKE_INSTALL_PREFIX})
|
|
||||||
elseif (PROJECT_NAME STREQUAL "DAMASK_FEM")
|
|
||||||
install (PROGRAMS ${PROJECT_BINARY_DIR}/src/DAMASK_FEM
|
|
||||||
DESTINATION ${CMAKE_INSTALL_PREFIX})
|
|
||||||
endif ()
|
|
||||||
endif ()
|
|
||||||
|
|
2
CONFIG
2
CONFIG
|
@ -1,8 +1,6 @@
|
||||||
# "set"-syntax needed only for tcsh (but works with bash and zsh)
|
# "set"-syntax needed only for tcsh (but works with bash and zsh)
|
||||||
# DAMASK_ROOT will be expanded
|
# DAMASK_ROOT will be expanded
|
||||||
|
|
||||||
set DAMASK_BIN = ${DAMASK_ROOT}/bin
|
|
||||||
|
|
||||||
set DAMASK_NUM_THREADS = 4
|
set DAMASK_NUM_THREADS = 4
|
||||||
|
|
||||||
set MSC_ROOT = /opt/msc
|
set MSC_ROOT = /opt/msc
|
||||||
|
|
25
Makefile
25
Makefile
|
@ -2,30 +2,31 @@ SHELL = /bin/sh
|
||||||
########################################################################################
|
########################################################################################
|
||||||
# Makefile for the installation of DAMASK
|
# Makefile for the installation of DAMASK
|
||||||
########################################################################################
|
########################################################################################
|
||||||
|
DAMASK_ROOT = $(shell python -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser('$(pwd)'))))")
|
||||||
.PHONY: all
|
.PHONY: all
|
||||||
all: grid FEM processing
|
all: grid mesh processing
|
||||||
|
|
||||||
.PHONY: grid
|
.PHONY: grid
|
||||||
grid: build/grid
|
grid: build/grid
|
||||||
@(cd build/grid;make -j4 --no-print-directory -ws all install;)
|
@(cd build/grid;make -j4 all install;)
|
||||||
|
|
||||||
.PHONY: spectral
|
.PHONY: spectral
|
||||||
spectral: build/grid
|
spectral: grid
|
||||||
@(cd build/grid;make -j4 --no-print-directory -ws all install;)
|
|
||||||
|
|
||||||
|
.PHONY: mesh
|
||||||
|
mesh: build/mesh
|
||||||
|
@(cd build/mesh; make -j4 all install;)
|
||||||
.PHONY: FEM
|
.PHONY: FEM
|
||||||
FEM: build/FEM
|
FEM: mesh
|
||||||
@(cd build/FEM; make -j4 --no-print-directory -ws all install;)
|
|
||||||
|
|
||||||
.PHONY: build/grid
|
.PHONY: build/grid
|
||||||
build/grid:
|
build/grid:
|
||||||
@mkdir -p build/grid
|
@mkdir -p build/grid
|
||||||
@(cd build/grid; cmake -Wno-dev -DDAMASK_SOLVER=GRID -DCMAKE_BUILD_TYPE=${BUILD_TYPE} -DBUILDCMD_POST=${BUILDCMD_POST} -DBUILDCMD_PRE=${BUILDCMD_PRE} -DOPTIMIZATION=${OPTIMIZATION} -DOPENMP=${OPENMP} ../../;)
|
@(cd build/grid; cmake -Wno-dev -DDAMASK_SOLVER=GRID -DCMAKE_INSTALL_PREFIX=${DAMASK_ROOT} -DCMAKE_BUILD_TYPE=${BUILD_TYPE} -DBUILDCMD_POST=${BUILDCMD_POST} -DBUILDCMD_PRE=${BUILDCMD_PRE} -DOPTIMIZATION=${OPTIMIZATION} -DOPENMP=${OPENMP} ../../;)
|
||||||
|
|
||||||
.PHONY: build/FEM
|
.PHONY: build/mesh
|
||||||
build/FEM:
|
build/mesh:
|
||||||
@mkdir -p build/FEM
|
@mkdir -p build/mesh
|
||||||
@(cd build/FEM; cmake -Wno-dev -DDAMASK_SOLVER=FEM -DCMAKE_BUILD_TYPE=${BUILD_TYPE} -DBUILDCMD_POST=${BUILDCMD_POST} -DBUILDCMD_PRE=${BUILDCMD_PRE} -DOPTIMIZATION=${OPTIMIZATION} -DOPENMP=${OPENMP} ../../;)
|
@(cd build/mesh; cmake -Wno-dev -DDAMASK_SOLVER=FEM -DCMAKE_INSTALL_PREFIX=${DAMASK_ROOT} -DCMAKE_BUILD_TYPE=${BUILD_TYPE} -DBUILDCMD_POST=${BUILDCMD_POST} -DBUILDCMD_PRE=${BUILDCMD_PRE} -DOPTIMIZATION=${OPTIMIZATION} -DOPENMP=${OPENMP} ../../;)
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
|
|
2
PRIVATE
2
PRIVATE
|
@ -1 +1 @@
|
||||||
Subproject commit f342bc7dabddf5a9c7786d14115145ef4b0f330b
|
Subproject commit 212ac3b326f3a15926d71109fec0173d95931b6b
|
|
@ -0,0 +1,130 @@
|
||||||
|
###################################################################################################
|
||||||
|
# GNU Compiler
|
||||||
|
###################################################################################################
|
||||||
|
|
||||||
|
if (OPENMP)
|
||||||
|
set (OPENMP_FLAGS "-fopenmp")
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
if (OPTIMIZATION STREQUAL "OFF")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O0" )
|
||||||
|
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O2")
|
||||||
|
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O3 -ffast-math -funroll-loops -ftree-vectorize")
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
set (STANDARD_CHECK "-std=f2008ts -pedantic-errors" )
|
||||||
|
set (LINKER_FLAGS "${LINKER_FLAGS} -Wl")
|
||||||
|
# options parsed directly to the linker
|
||||||
|
set (LINKER_FLAGS "${LINKER_FLAGS},-undefined,dynamic_lookup" )
|
||||||
|
# ensure to link against dynamic libraries
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Fine tuning compilation options
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -xf95-cpp-input")
|
||||||
|
# preprocessor
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ffree-line-length-132")
|
||||||
|
# restrict line length to the standard 132 characters (lattice.f90 require more characters)
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -fimplicit-none")
|
||||||
|
# assume "implicit none" even if not present in source
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wall")
|
||||||
|
# sets the following Fortran options:
|
||||||
|
# -Waliasing: warn about possible aliasing of dummy arguments. Specifically, it warns if the same actual argument is associated with a dummy argument with "INTENT(IN)" and a dummy argument with "INTENT(OUT)" in a call with an explicit interface.
|
||||||
|
# -Wampersand: checks if a character expression is continued proberly by an ampersand at the end of the line and at the beginning of the new line
|
||||||
|
# -Warray-bounds: checks if array reference is out of bounds at compile time. use -fcheck-bounds to also check during runtime
|
||||||
|
# -Wconversion: warn about implicit conversions between different type
|
||||||
|
# -Wsurprising: warn when "suspicious" code constructs are encountered. While technically legal these usually indicate that an error has been made.
|
||||||
|
# -Wc-binding-type:
|
||||||
|
# -Wintrinsics-std: only standard intrisics are available, e.g. "call flush(6)" will cause an error
|
||||||
|
# -Wno-tabs: do not allow tabs in source
|
||||||
|
# -Wintrinsic-shadow: warn if a user-defined procedure or module procedure has the same name as an intrinsic
|
||||||
|
# -Wline-truncation:
|
||||||
|
# -Wtarget-lifetime:
|
||||||
|
# -Wreal-q-constant: warn about real-literal-constants with 'q' exponent-letter
|
||||||
|
# -Wunused: a number of unused-xxx warnings
|
||||||
|
# and sets the general (non-Fortran options) options:
|
||||||
|
# -Waddress
|
||||||
|
# -Warray-bounds (only with -O2)
|
||||||
|
# -Wc++11-compat
|
||||||
|
# -Wchar-subscripts
|
||||||
|
# -Wcomment
|
||||||
|
# -Wformat
|
||||||
|
# -Wmaybe-uninitialized
|
||||||
|
# -Wnonnull
|
||||||
|
# -Wparentheses
|
||||||
|
# -Wpointer-sign
|
||||||
|
# -Wreorder
|
||||||
|
# -Wreturn-type
|
||||||
|
# -Wsequence-point
|
||||||
|
# -Wstrict-aliasing
|
||||||
|
# -Wstrict-overflow=1
|
||||||
|
# -Wswitch
|
||||||
|
# -Wtrigraphs
|
||||||
|
# -Wuninitialized
|
||||||
|
# -Wunknown-pragmas
|
||||||
|
# -Wunused-function
|
||||||
|
# -Wunused-label
|
||||||
|
# -Wunused-value
|
||||||
|
# -Wunused-variable
|
||||||
|
# -Wvolatile-register-var
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wextra")
|
||||||
|
# sets the following Fortran options:
|
||||||
|
# -Wunuses-parameter:
|
||||||
|
# -Wcompare-reals:
|
||||||
|
# and sets the general (non-Fortran options) options:
|
||||||
|
# -Wclobbered
|
||||||
|
# -Wempty-body
|
||||||
|
# -Wignored-qualifiers
|
||||||
|
# -Wmissing-field-initializers
|
||||||
|
# -Woverride-init
|
||||||
|
# -Wsign-compare
|
||||||
|
# -Wtype-limits
|
||||||
|
# -Wuninitialized
|
||||||
|
# -Wunused-but-set-parameter (only with -Wunused or -Wall)
|
||||||
|
# -Wno-globals
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wcharacter-truncation")
|
||||||
|
# warn if character expressions (strings) are truncated
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wunderflow")
|
||||||
|
# produce a warning when numerical constant expressions are encountered, which yield an UNDERFLOW during compilation
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wsuggest-attribute=pure")
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wsuggest-attribute=noreturn")
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wconversion-extra")
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wimplicit-procedure")
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Wno-unused-parameter")
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ffpe-summary=all")
|
||||||
|
# print summary of floating point exeptions (invalid,zero,overflow,underflow,inexact,denormal)
|
||||||
|
|
||||||
|
# Additional options
|
||||||
|
# -Warray-temporarieswarnings: because we have many temporary arrays (performance issue?):
|
||||||
|
# -Wimplicit-interface: no interfaces for lapack/MPI routines
|
||||||
|
# -Wunsafe-loop-optimizations: warn if the loop cannot be optimized due to nontrivial assumptions.
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Runtime debugging
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -ffpe-trap=invalid,zero,overflow")
|
||||||
|
# stop execution if floating point exception is detected (NaN is silent)
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
||||||
|
# Generate symbolic debugging information in the object file
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fbacktrace")
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fdump-core")
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fcheck=all")
|
||||||
|
# checks for (array-temps,bounds,do,mem,pointer,recursion)
|
||||||
|
|
||||||
|
# Additional options
|
||||||
|
# -ffpe-trap=precision,denormal,underflow
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# precision settings
|
||||||
|
set (PRECISION_FLAGS "${PRECISION_FLAGS} -fdefault-real-8")
|
||||||
|
# set precision to 8 bytes for standard real (=8 for pReal). Will set size of double to 16 bytes as long as -fdefault-double-8 is not set
|
||||||
|
set (PRECISION_FLAGS "${PRECISION_FLAGS} -fdefault-double-8")
|
||||||
|
# set precision to 8 bytes for double real, would be 16 bytes if -fdefault-real-8 is used
|
|
@ -0,0 +1,114 @@
|
||||||
|
###################################################################################################
|
||||||
|
# Intel Compiler
|
||||||
|
###################################################################################################
|
||||||
|
if (OPENMP)
|
||||||
|
set (OPENMP_FLAGS "-qopenmp -parallel")
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
if (OPTIMIZATION STREQUAL "OFF")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O0 -no-ip")
|
||||||
|
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O2")
|
||||||
|
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-ipo -O3 -no-prec-div -fp-model fast=2 -xHost")
|
||||||
|
# -fast = -ipo, -O3, -no-prec-div, -static, -fp-model fast=2, and -xHost"
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
# -assume std_mod_proc_name (included in -standard-semantics) causes problems if other modules
|
||||||
|
# (PETSc, HDF5) are not compiled with this option (https://software.intel.com/en-us/forums/intel-fortran-compiler-for-linux-and-mac-os-x/topic/62172)
|
||||||
|
set (STANDARD_CHECK "-stand f15 -standard-semantics -assume nostd_mod_proc_name")
|
||||||
|
set (LINKER_FLAGS "${LINKER_FLAGS} -shared-intel")
|
||||||
|
# Link against shared Intel libraries instead of static ones
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Fine tuning compilation options
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -fpp")
|
||||||
|
# preprocessor
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -ftz")
|
||||||
|
# flush underflow to zero, automatically set if -O[1,2,3]
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -diag-disable")
|
||||||
|
# disables warnings ...
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} 5268")
|
||||||
|
# ... the text exceeds right hand column allowed on the line (we have only comments there)
|
||||||
|
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -warn")
|
||||||
|
# enables warnings ...
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} declarations")
|
||||||
|
# ... any undeclared names (alternative name: -implicitnone)
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},general")
|
||||||
|
# ... warning messages and informational messages are issued by the compiler
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},usage")
|
||||||
|
# ... questionable programming practices
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},interfaces")
|
||||||
|
# ... checks the interfaces of all SUBROUTINEs called and FUNCTIONs invoked in your compilation against an external set of interface blocks
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},ignore_loc")
|
||||||
|
# ... %LOC is stripped from an actual argument
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},alignments")
|
||||||
|
# ... data that is not naturally aligned
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS},unused")
|
||||||
|
# ... declared variables that are never used
|
||||||
|
|
||||||
|
# Additional options
|
||||||
|
# -warn: enables warnings, where
|
||||||
|
# truncated_source: Determines whether warnings occur when source exceeds the maximum column width in fixed-format files.
|
||||||
|
# (too many warnings because we have comments beyond character 132)
|
||||||
|
# uncalled: Determines whether warnings occur when a statement function is never called
|
||||||
|
# all:
|
||||||
|
# -name as_is: case sensitive Fortran!
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Runtime debugging
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
||||||
|
# Generate symbolic debugging information in the object file
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -traceback")
|
||||||
|
# Generate extra information in the object file to provide source file traceback information when a severe error occurs at run time
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -gen-interfaces")
|
||||||
|
# Generate an interface block for each routine. http://software.intel.com/en-us/blogs/2012/01/05/doctor-fortran-gets-explicit-again/
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fp-stack-check")
|
||||||
|
# Generate extra code after every function call to ensure that the floating-point (FP) stack is in the expected state
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fp-model strict")
|
||||||
|
# Trap uninitalized variables
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -check" )
|
||||||
|
# Checks at runtime ...
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} bounds")
|
||||||
|
# ... if an array index is too small (<1) or too large!
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS},format")
|
||||||
|
# ... for the data type of an item being formatted for output.
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS},output_conversion")
|
||||||
|
# ... for the fit of data items within a designated format descriptor field.
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS},pointers")
|
||||||
|
# ... for certain disassociated or uninitialized pointers or unallocated allocatable objects.
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS},uninit")
|
||||||
|
# ... for uninitialized variables.
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -ftrapuv")
|
||||||
|
# ... initializes stack local variables to an unusual value to aid error detection
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -fpe-all=0")
|
||||||
|
# ... capture all floating-point exceptions, sets -ftz automatically
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -warn")
|
||||||
|
# enables warnings ...
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} errors")
|
||||||
|
# ... warnings are changed to errors
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS},stderrors")
|
||||||
|
# ... warnings about Fortran standard violations are changed to errors
|
||||||
|
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -debug-parameters all")
|
||||||
|
# generate debug information for parameters
|
||||||
|
|
||||||
|
# Additional options
|
||||||
|
# -heap-arrays: Should not be done for OpenMP, but set "ulimit -s unlimited" on shell. Probably it helps also to unlimit other limits
|
||||||
|
# -check: Checks at runtime, where
|
||||||
|
# arg_temp_created: will cause a lot of warnings because we create a bunch of temporary arrays (performance?)
|
||||||
|
# stack:
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# precision settings
|
||||||
|
set (PRECISION_FLAGS "${PRECISION_FLAGS} -real-size 64")
|
||||||
|
# set precision for standard real to 32 | 64 | 128 (= 4 | 8 | 16 bytes, type pReal is always 8 bytes)
|
|
@ -0,0 +1,25 @@
|
||||||
|
###################################################################################################
|
||||||
|
# PGI Compiler
|
||||||
|
###################################################################################################
|
||||||
|
elseif(CMAKE_Fortran_COMPILER_ID STREQUAL "PGI")
|
||||||
|
|
||||||
|
if (OPTIMIZATION STREQUAL "OFF")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O0" )
|
||||||
|
elseif (OPTIMIZATION STREQUAL "DEFENSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O2")
|
||||||
|
elseif (OPTIMIZATION STREQUAL "AGGRESSIVE")
|
||||||
|
set (OPTIMIZATION_FLAGS "-O3")
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Fine tuning compilation options
|
||||||
|
set (COMPILE_FLAGS "${COMPILE_FLAGS} -Mpreprocess")
|
||||||
|
# preprocessor
|
||||||
|
|
||||||
|
set (STANDARD_CHECK "-Mallocatable=03")
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------------------------
|
||||||
|
# Runtime debugging
|
||||||
|
set (DEBUG_FLAGS "${DEBUG_FLAGS} -g")
|
||||||
|
# Includes debugging information in the object module; sets the optimization level to zero unless a -O option is present on the command line
|
|
@ -13,9 +13,7 @@ set BRANCH = `git branch 2>/dev/null| grep -E '^\* ')`
|
||||||
cd - >/dev/null
|
cd - >/dev/null
|
||||||
|
|
||||||
# if DAMASK_BIN is present
|
# if DAMASK_BIN is present
|
||||||
if ( $?DAMASK_BIN) then
|
set path = ($DAMASK_ROOT/bin $path)
|
||||||
set path = ($DAMASK_BIN $path)
|
|
||||||
endif
|
|
||||||
|
|
||||||
set SOLVER=`which DAMASK_spectral`
|
set SOLVER=`which DAMASK_spectral`
|
||||||
set PROCESSING=`which postResults`
|
set PROCESSING=`which postResults`
|
||||||
|
|
|
@ -33,8 +33,7 @@ unset -f set
|
||||||
# add BRANCH if DAMASK_ROOT is a git repository
|
# add BRANCH if DAMASK_ROOT is a git repository
|
||||||
cd $DAMASK_ROOT >/dev/null; BRANCH=$(git branch 2>/dev/null| grep -E '^\* '); cd - >/dev/null
|
cd $DAMASK_ROOT >/dev/null; BRANCH=$(git branch 2>/dev/null| grep -E '^\* '); cd - >/dev/null
|
||||||
|
|
||||||
# add DAMASK_BIN if present
|
PATH=${DAMASK_ROOT}/bin:$PATH
|
||||||
[ "x$DAMASK_BIN" != "x" ] && PATH=$DAMASK_BIN:$PATH
|
|
||||||
|
|
||||||
SOLVER=$(type -p DAMASK_spectral || true 2>/dev/null)
|
SOLVER=$(type -p DAMASK_spectral || true 2>/dev/null)
|
||||||
[ "x$SOLVER" == "x" ] && SOLVER=$(blink 'Not found!')
|
[ "x$SOLVER" == "x" ] && SOLVER=$(blink 'Not found!')
|
||||||
|
|
|
@ -25,7 +25,7 @@ unset -f set
|
||||||
cd $DAMASK_ROOT >/dev/null; BRANCH=$(git branch 2>/dev/null| grep -E '^\* '); cd - >/dev/null
|
cd $DAMASK_ROOT >/dev/null; BRANCH=$(git branch 2>/dev/null| grep -E '^\* '); cd - >/dev/null
|
||||||
|
|
||||||
# add DAMASK_BIN if present
|
# add DAMASK_BIN if present
|
||||||
[[ "x$DAMASK_BIN" != "x" ]] && PATH=$DAMASK_BIN:$PATH
|
PATH=${DAMASK_ROOT}/bin:$PATH
|
||||||
|
|
||||||
SOLVER=$(which DAMASK_spectral || true 2>/dev/null)
|
SOLVER=$(which DAMASK_spectral || true 2>/dev/null)
|
||||||
[[ "x$SOLVER" == "x" ]] && SOLVER=$(blink 'Not found!')
|
[[ "x$SOLVER" == "x" ]] && SOLVER=$(blink 'Not found!')
|
||||||
|
|
|
@ -7,7 +7,7 @@ import damask
|
||||||
|
|
||||||
damaskEnv = damask.Environment()
|
damaskEnv = damask.Environment()
|
||||||
baseDir = damaskEnv.relPath('processing/')
|
baseDir = damaskEnv.relPath('processing/')
|
||||||
binDir = damaskEnv.options['DAMASK_BIN']
|
binDir = damaskEnv.relPath('bin/')
|
||||||
|
|
||||||
if not os.path.isdir(binDir):
|
if not os.path.isdir(binDir):
|
||||||
os.mkdir(binDir)
|
os.mkdir(binDir)
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
dist
|
||||||
|
damask.egg-info
|
|
@ -0,0 +1 @@
|
||||||
|
include damask/VERSION
|
|
@ -1,3 +0,0 @@
|
||||||
core.so
|
|
||||||
corientation.so
|
|
||||||
*.pyx
|
|
|
@ -0,0 +1 @@
|
||||||
|
../../LICENSE
|
|
@ -0,0 +1 @@
|
||||||
|
../../README
|
|
@ -0,0 +1 @@
|
||||||
|
../../VERSION
|
|
@ -3,8 +3,8 @@
|
||||||
"""Main aggregator"""
|
"""Main aggregator"""
|
||||||
import os
|
import os
|
||||||
|
|
||||||
with open(os.path.join(os.path.dirname(__file__),'../../VERSION')) as f:
|
with open(os.path.join(os.path.dirname(__file__),'VERSION')) as f:
|
||||||
version = f.readline()[:-1]
|
version = f.readline()[1:-1]
|
||||||
|
|
||||||
name = 'damask'
|
name = 'damask'
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# -*- coding: UTF-8 no BOM -*-
|
# -*- coding: UTF-8 no BOM -*-
|
||||||
|
|
||||||
import os,subprocess,shlex,re
|
import os,re
|
||||||
|
|
||||||
class Environment():
|
class Environment():
|
||||||
__slots__ = [ \
|
__slots__ = [ \
|
||||||
|
@ -26,24 +26,3 @@ class Environment():
|
||||||
if len(items) == 2:
|
if len(items) == 2:
|
||||||
self.options[items[0].upper()] = \
|
self.options[items[0].upper()] = \
|
||||||
re.sub('\$\{*DAMASK_ROOT\}*',self.rootDir(),os.path.expandvars(items[1])) # expand all shell variables and DAMASK_ROOT
|
re.sub('\$\{*DAMASK_ROOT\}*',self.rootDir(),os.path.expandvars(items[1])) # expand all shell variables and DAMASK_ROOT
|
||||||
|
|
||||||
def isAvailable(self,software,Nneeded =-1):
|
|
||||||
licensesNeeded = {'abaqus' :5,
|
|
||||||
'standard':5
|
|
||||||
}
|
|
||||||
if Nneeded == -1: Nneeded = licensesNeeded[software]
|
|
||||||
try:
|
|
||||||
cmd = """ ssh mulicense2 "/lm-status | grep 'Users of %s: ' | cut -d' ' -f7,13" """%software
|
|
||||||
process = subprocess.Popen(shlex.split(cmd),stdout = subprocess.PIPE,stderr = subprocess.PIPE)
|
|
||||||
licenses = list(map(int, process.stdout.readline().split()))
|
|
||||||
try:
|
|
||||||
if licenses[0]-licenses[1] >= Nneeded:
|
|
||||||
return 0
|
|
||||||
else:
|
|
||||||
print('%s missing licenses for %s'%(licenses[1] + Nneeded - licenses[0],software))
|
|
||||||
return licenses[1] + Nneeded - licenses[0]
|
|
||||||
except IndexError:
|
|
||||||
print('Could not retrieve license information for %s'%software)
|
|
||||||
return 127
|
|
||||||
except:
|
|
||||||
return 126
|
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
import setuptools
|
||||||
|
import os
|
||||||
|
|
||||||
|
with open(os.path.join(os.path.dirname(__file__),'damask/VERSION')) as f:
|
||||||
|
version = f.readline()[1:-1]
|
||||||
|
|
||||||
|
setuptools.setup(
|
||||||
|
name="damask",
|
||||||
|
version=version,
|
||||||
|
author="The DAMASK team",
|
||||||
|
author_email="damask@mpie.de",
|
||||||
|
description="DAMASK library",
|
||||||
|
long_description="Python library for pre and post processing of DAMASK simulations",
|
||||||
|
url="https://damask.mpie.de",
|
||||||
|
packages=setuptools.find_packages(),
|
||||||
|
include_package_data=True,
|
||||||
|
install_requires = [
|
||||||
|
"scipy",
|
||||||
|
"h5py",
|
||||||
|
"vtk"
|
||||||
|
],
|
||||||
|
license = 'GPL3',
|
||||||
|
classifiers = [
|
||||||
|
"Programming Language :: Python :: 3",
|
||||||
|
"License :: OSI Approved :: GPL3",
|
||||||
|
"Operating System :: OS Independent",
|
||||||
|
],
|
||||||
|
)
|
|
@ -4,43 +4,37 @@ if (CMAKE_Fortran_COMPILER_ID STREQUAL "GNU")
|
||||||
SET_SOURCE_FILES_PROPERTIES("lattice.f90" PROPERTIES COMPILE_FLAGS "-ffree-line-length-240")
|
SET_SOURCE_FILES_PROPERTIES("lattice.f90" PROPERTIES COMPILE_FLAGS "-ffree-line-length-240")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
file(GLOB_RECURSE sources *.f90 *.c)
|
file(GLOB damask-sources *.f90 *.c)
|
||||||
|
|
||||||
# probably we should have subfolders for abaqus and MSC.Marc
|
# probably we should have subfolders for abaqus and MSC.Marc
|
||||||
list(FILTER sources EXCLUDE REGEX ".*CPFEM\\.f90")
|
list(FILTER damask-sources EXCLUDE REGEX ".*CPFEM.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*DAMASK_marc.*\\.f90")
|
list(FILTER damask-sources EXCLUDE REGEX ".*DAMASK_marc.*.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*mesh_marc.*\\.f90")
|
list(FILTER damask-sources EXCLUDE REGEX ".*mesh_marc.*.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*mesh_abaqus.*\\.f90")
|
list(FILTER damask-sources EXCLUDE REGEX ".*mesh_abaqus.*.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*commercialFEM_fileList.*\\.f90")
|
list(FILTER damask-sources EXCLUDE REGEX ".*commercialFEM_fileList.*.f90")
|
||||||
|
|
||||||
|
|
||||||
if (PROJECT_NAME STREQUAL "DAMASK_grid")
|
if (PROJECT_NAME STREQUAL "damask-grid")
|
||||||
|
|
||||||
# probably we should have subfolders for FEM and spectral
|
list(FILTER damask-sources EXCLUDE REGEX ".*mesh_FEM.*.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*DAMASK_FEM.*\\.f90")
|
file(GLOB grid-sources grid/*.f90)
|
||||||
list(FILTER sources EXCLUDE REGEX ".*FEM_utilities.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*FEM_zoo.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*mesh_FEM.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*FEM_mech.*\\.f90")
|
|
||||||
|
|
||||||
if(NOT CMAKE_BUILD_TYPE STREQUAL "SYNTAXONLY")
|
if(NOT CMAKE_BUILD_TYPE STREQUAL "SYNTAXONLY")
|
||||||
add_executable(DAMASK_spectral ${sources})
|
add_executable(DAMASK_spectral ${damask-sources} ${grid-sources})
|
||||||
|
install (TARGETS DAMASK_spectral RUNTIME DESTINATION bin)
|
||||||
else()
|
else()
|
||||||
add_library(DAMASK_spectral OBJECT ${sources})
|
add_library(DAMASK_spectral OBJECT ${damask-sources} ${grid-sources})
|
||||||
|
exec_program (mktemp OUTPUT_VARIABLE nothing)
|
||||||
|
exec_program (mktemp ARGS -d OUTPUT_VARIABLE black_hole)
|
||||||
|
install (PROGRAMS ${nothing} DESTINATION ${black_hole})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
elseif (PROJECT_NAME STREQUAL "DAMASK_FEM")
|
elseif (PROJECT_NAME STREQUAL "damask-mesh")
|
||||||
|
|
||||||
# probably we should have subfolders for FEM and spectral
|
list(FILTER damask-sources EXCLUDE REGEX ".*mesh_grid.*.f90")
|
||||||
list(FILTER sources EXCLUDE REGEX ".*DAMASK_grid.*\\.f90")
|
file(GLOB mesh-sources mesh/*.f90)
|
||||||
list(FILTER sources EXCLUDE REGEX ".*grid_mech_FEM.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*grid_mech_spectral_basic.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*grid_mech_spectral_polarisation.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*grid_damage_spectral.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*grid_thermal_spectral.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*spectral_utilities.*\\.f90")
|
|
||||||
list(FILTER sources EXCLUDE REGEX ".*mesh_grid.*\\.f90")
|
|
||||||
|
|
||||||
add_executable(DAMASK_FEM ${sources})
|
add_executable(DAMASK_FEM ${damask-sources} ${mesh-sources})
|
||||||
|
install (TARGETS DAMASK_FEM RUNTIME DESTINATION bin)
|
||||||
|
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -1,417 +0,0 @@
|
||||||
! common block definition file taken from respective MSC.Marc release and reformated to free format
|
|
||||||
!***********************************************************************
|
|
||||||
!
|
|
||||||
! File: concom.cmn
|
|
||||||
!
|
|
||||||
! MSC.Marc include file
|
|
||||||
!
|
|
||||||
integer(pInt) &
|
|
||||||
iacous, iasmbl, iautth, ibear, icompl, iconj, icreep, ideva, idyn, idynt,&
|
|
||||||
ielas, ielcma, ielect, iform, ifour, iharm, ihcps, iheat, iheatt, ihresp,&
|
|
||||||
ijoule, ilem, ilnmom, iloren, inc, incext, incsub, ipass, iplres, ipois,&
|
|
||||||
ipoist, irpflo, ismall, ismalt, isoil, ispect, ispnow, istore, iswep, ithcrp,&
|
|
||||||
itherm, iupblg, iupdat, jacflg, jel, jparks, largst, lfond, loadup, loaduq,&
|
|
||||||
lodcor, lovl, lsub, magnet, ncycle, newtnt, newton, noshr, linear, ivscpl,&
|
|
||||||
icrpim, iradrt, ipshft, itshr, iangin, iupmdr, iconjf, jincfl, jpermg, jhour,&
|
|
||||||
isolvr, jritz, jtable, jshell, jdoubl, jform, jcentr, imini, kautth, iautof,&
|
|
||||||
ibukty, iassum, icnstd, icnstt, kmakmas, imethvp, iradrte, iradrtp, iupdate, iupdatp,&
|
|
||||||
ncycnt, marmen , idynme, ihavca, ispf, kmini, imixex, largtt, kdoela, iautofg,&
|
|
||||||
ipshftp, idntrc, ipore, jtablm, jtablc, isnecma, itrnspo, imsdif, jtrnspo, mcnear,&
|
|
||||||
imech, imecht, ielcmat, ielectt, magnett, imsdift, noplas, jtabls, jactch, jtablth,&
|
|
||||||
kgmsto , jpzo, ifricsh, iremkin, iremfor, ishearp, jspf, machining, jlshell, icompsol,&
|
|
||||||
iupblgfo, jcondir, nstcrp, nactive, ipassref, nstspnt, ibeart, icheckmpc, noline, icuring,&
|
|
||||||
ishrink, ioffsflg, isetoff, ioffsetm,iharmt, inc_incdat, iautspc, ibrake, icbush, istream_input,&
|
|
||||||
iprsinp, ivlsinp, ifirst_time,ipin_m, jgnstr_glb, imarc_return,iqvcinp, nqvceid, istpnx, imicro1,&
|
|
||||||
iaxisymm, jbreakglue,iglstif, jfastasm,iwear, iwearcf, imixmeth, ielcmadyn, idinout, igena_meth,&
|
|
||||||
magf_meth, non_assumed, iredoboudry, ioffsz0,icomplt, mesh_dual, iactrp, mgnewton, iusedens,igsigd0,&
|
|
||||||
iaem, icosim, inodels, nlharm, iampini, iphasetr
|
|
||||||
dimension :: ideva(60)
|
|
||||||
integer(pInt) num_concom
|
|
||||||
parameter(num_concom=245)
|
|
||||||
common/marc_concom/&
|
|
||||||
iacous, iasmbl, iautth, ibear, icompl, iconj, icreep, ideva, idyn, idynt,&
|
|
||||||
ielas, ielcma, ielect, iform, ifour, iharm, ihcps, iheat, iheatt, ihresp,&
|
|
||||||
ijoule, ilem, ilnmom, iloren, inc, incext, incsub, ipass, iplres, ipois,&
|
|
||||||
ipoist, irpflo, ismall, ismalt, isoil, ispect, ispnow, istore, iswep, ithcrp,&
|
|
||||||
itherm, iupblg, iupdat, jacflg, jel, jparks, largst, lfond, loadup, loaduq,&
|
|
||||||
lodcor, lovl, lsub, magnet, ncycle, newtnt, newton, noshr, linear, ivscpl,&
|
|
||||||
icrpim, iradrt, ipshft, itshr, iangin, iupmdr, iconjf, jincfl, jpermg, jhour,&
|
|
||||||
isolvr, jritz, jtable, jshell, jdoubl, jform, jcentr, imini, kautth, iautof,&
|
|
||||||
ibukty, iassum, icnstd, icnstt, kmakmas, imethvp, iradrte, iradrtp, iupdate, iupdatp,&
|
|
||||||
ncycnt, marmen, idynme, ihavca, ispf, kmini, imixex, largtt, kdoela, iautofg,&
|
|
||||||
ipshftp, idntrc, ipore, jtablm, jtablc, isnecma, itrnspo, imsdif, jtrnspo, mcnear,&
|
|
||||||
imech, imecht, ielcmat, ielectt, magnett, imsdift, noplas, jtabls, jactch, jtablth,&
|
|
||||||
kgmsto , jpzo, ifricsh, iremkin, iremfor, ishearp, jspf, machining, jlshell, icompsol,&
|
|
||||||
iupblgfo, jcondir, nstcrp, nactive, ipassref, nstspnt, ibeart, icheckmpc, noline, icuring,&
|
|
||||||
ishrink, ioffsflg, isetoff, ioffsetm,iharmt, inc_incdat, iautspc, ibrake, icbush , istream_input,&
|
|
||||||
iprsinp, ivlsinp, ifirst_time,ipin_m, jgnstr_glb, imarc_return,iqvcinp, nqvceid, istpnx, imicro1,&
|
|
||||||
iaxisymm, jbreakglue,iglstif, jfastasm,iwear, iwearcf, imixmeth, ielcmadyn, idinout,igena_meth,&
|
|
||||||
magf_meth, non_assumed, iredoboudry, ioffsz0,icomplt, mesh_dual, iactrp, mgnewton, iusedens,igsigd0,&
|
|
||||||
iaem, icosim, inodels, nlharm, iampini, iphasetr
|
|
||||||
!
|
|
||||||
! comments of variables:
|
|
||||||
!
|
|
||||||
! iacous Control flag for acoustic analysis. Input data.
|
|
||||||
! iacous=1 modal acoustic analysis.
|
|
||||||
! iacous=2 harmonic acoustic-structural analysis.
|
|
||||||
! iasmbl Control flag to indicate that operator matrix should be
|
|
||||||
! recalculated.
|
|
||||||
! iautth Control flag for AUTO THERM option.
|
|
||||||
! ibear Control flag for bearing analysis. Input data.
|
|
||||||
! icompl Control variable to indicate that a complex analysis is
|
|
||||||
! being performed. Either a Harmonic analysis with damping,
|
|
||||||
! or a harmonic electro-magnetic analysis. Input data.
|
|
||||||
! iconj Flag for EBE conjugate gradient solver (=solver 1, retired)
|
|
||||||
! Also used for VKI iterative solver.
|
|
||||||
! icreep Control flag for creep analysis. Input data.
|
|
||||||
! ideva(60) - debug print out flag
|
|
||||||
! 1 print element stiffness matrices, mass matrix
|
|
||||||
! 2 output matrices used in tying
|
|
||||||
! 3 force the solution of a nonpositive definite matrix
|
|
||||||
! 4 print info of connections to each node
|
|
||||||
! 5 info of gap convergence, internal heat generated, contact
|
|
||||||
! touching and separation
|
|
||||||
! 6 nodal value array during rezoning
|
|
||||||
! 7 tying info in CONRAD GAP option, fluid element numbers in
|
|
||||||
! CHANNEL option
|
|
||||||
! 8 output incremental displacements in local coord. system
|
|
||||||
! 9 latent heat output
|
|
||||||
! 10 stress-strain in local coord. system
|
|
||||||
! 11 additional info on interlaminar stress
|
|
||||||
! 12 output right hand side and solution vector
|
|
||||||
! 13 info of CPU resources used and memory available on NT
|
|
||||||
! 14 info of mesh adaption process, 2D outline information
|
|
||||||
! info of penetration checking for remeshing
|
|
||||||
! save .fem files after afmesh3d meshing
|
|
||||||
! 15 surface energy balance flag
|
|
||||||
! 16 print info regarding pyrolysis
|
|
||||||
! 17 print info of "streamline topology"
|
|
||||||
! 18 print mesh data changes after remeshing
|
|
||||||
! 19 print material flow stress data read in from *.mat file
|
|
||||||
! if unit flag is on, print out flow stress after conversion
|
|
||||||
! 20 print information on table input
|
|
||||||
! 21 print out information regarding kinematic boundary conditions
|
|
||||||
! 22 print out information regarding dist loads, point loads, film
|
|
||||||
! and foundations
|
|
||||||
! 23 print out information about automatic domain decomposition
|
|
||||||
! 24 print out iteration information in SuperForm status report file
|
|
||||||
! 25 print out information for ablation
|
|
||||||
! 26 print out information for films - Table input
|
|
||||||
! 27 print out the tying forces
|
|
||||||
! 28 print out for CASI solver, convection,
|
|
||||||
! 29 DDM single file debug printout
|
|
||||||
! 30 print out cavity debug info
|
|
||||||
! 31 print out welding related info
|
|
||||||
! 32 prints categorized DDM memory usage
|
|
||||||
! 33 print out the cutting info regarding machining feature
|
|
||||||
! 34 print out the list of quantities which can be defined via a table
|
|
||||||
! and for each quantity the supported independent variables
|
|
||||||
! 35 print out detailed coupling region info
|
|
||||||
! 36 print out solver debug info level 1 (Least Detailed)
|
|
||||||
! 37 print out solver debug info level 1 (Medium Detailed)
|
|
||||||
! 38 print out solver debug info level 1 (Very Detailed)
|
|
||||||
! 39 print detailed memory allocation info
|
|
||||||
! 40 print out marc-adams debug info
|
|
||||||
! 41 output rezone mapping post file for debugging
|
|
||||||
! 42 output post file after calling oprofos() for debugging
|
|
||||||
! 43 debug printout for vcct
|
|
||||||
! 44 debug printout for progressive failure
|
|
||||||
! 45 print out automatically generated midside node coordinates (arecrd)
|
|
||||||
! 46 print out message about routine and location, where the ibort is raised (ibort_inc)
|
|
||||||
! 47 print out summary message of element variables on a
|
|
||||||
! group-basis after all the automatic changes have been
|
|
||||||
! made (em_ellibp)
|
|
||||||
! 48 Automatically generate check results based on max and min vals.
|
|
||||||
! These vals are stored in the checkr file, which is inserted
|
|
||||||
! into the *dat file by the generate_check_results script from /marc/tools
|
|
||||||
! 49 Automatically generate check results based on the real calculated values
|
|
||||||
! at the sppecified check result locations.
|
|
||||||
! These vals are stored in the checkr file, which is inserted
|
|
||||||
! into the *dat file by the update_check_results script from /marc/tools
|
|
||||||
! 50 generate a file containing the resistance or capacity matrix;
|
|
||||||
! this file can be used to compare results with a reference file
|
|
||||||
! 51 print out detailed information for segment-to-segment contact
|
|
||||||
! 52 print out detailed relative displacement information
|
|
||||||
! for uniaxial sliding contact
|
|
||||||
! 53 print out detailed sliding direction information for
|
|
||||||
! uniaxial sliding contact
|
|
||||||
! 54 print out detailed information for edges attached to a curve
|
|
||||||
! 55 print information related to viscoelasticity calculations
|
|
||||||
! 56 print out detailed information for element coloring for multithreading
|
|
||||||
! 57 print out extra overheads due to multi-threading.
|
|
||||||
! These overhead includes (i) time and (ii) memory.
|
|
||||||
! The memory report will be summed over all the children.
|
|
||||||
!
|
|
||||||
!
|
|
||||||
! 58 debug output for ELSTO usage
|
|
||||||
!
|
|
||||||
! idyn Control flag for dynamics. Input data.
|
|
||||||
! 1 = eigenvalue extraction and / or modal superposition
|
|
||||||
! 2 = Newmark Beta and Single Step Houbolt (ssh with idynme=1)
|
|
||||||
! 3 = Houbolt
|
|
||||||
! 4 = Central difference
|
|
||||||
! 5 = Newer central difference
|
|
||||||
! idynt Copy of idyn at begining of increment
|
|
||||||
! ielas Control flag for ELASTIC analysis. Input data.
|
|
||||||
! Set by user or automatically turned on by Fourier option.
|
|
||||||
! Implies that each load case is treated separately.
|
|
||||||
! In Adaptive meshing analysis , forces re-analysis until
|
|
||||||
! convergence obtained.
|
|
||||||
! Also seriously misused to indicate no convergence.
|
|
||||||
! = 1 elastic option with fourier analysis
|
|
||||||
! = 2 elastic option without fourier analysis
|
|
||||||
! =-1 no convergence in recycles or max # increments reached
|
|
||||||
! Set to 1 if ELASTIC or SUBSTRUC parameter cards are used,
|
|
||||||
! or if fourier option is used.
|
|
||||||
! Then set to 2 if not fourier analysis.
|
|
||||||
! ielcma Control flag for electromagnetic analysis. Input data.
|
|
||||||
! ielcma = 1 Harmonic formulation
|
|
||||||
! ielcma = 2 Transient formulation
|
|
||||||
! ielect Control flag for electrostatic option. Input data.
|
|
||||||
! iform Control flag indicating that contact will be performed.
|
|
||||||
! ifour Control flag for Fourier analysis.
|
|
||||||
! 0 = Odd and even terms.
|
|
||||||
! 1 = symmetric (cosine) terms
|
|
||||||
! 2 = antisymmetric (sine) terms.
|
|
||||||
! iharm Control flag to indicate that a harmonic analysis will
|
|
||||||
! be performed. May change between passes.
|
|
||||||
! ihcps Control flag for coupled thermal - stress analysis.
|
|
||||||
! iheat Control flag for heat transfer analysis. Input data.
|
|
||||||
! iheatt Permanent control flag for heat transfer analysis.
|
|
||||||
! Note in coupled analysis iheatt will remain as one,
|
|
||||||
! but iheat will be zero in stress pass.
|
|
||||||
! ihresp Control flag to indicate to perform a harmonic subincrement.
|
|
||||||
! ijoule Control flag for Joule heating.
|
|
||||||
! ilem Control flag to determin which vector is to be transformed.
|
|
||||||
! Control flag to see where one is:
|
|
||||||
! ilem = 1 - elem.f
|
|
||||||
! ilem = 2 - initst.f
|
|
||||||
! ilem = 3 - pressr.f
|
|
||||||
! ilem = 3 - fstif.f
|
|
||||||
! ilem = 4 - jflux.f
|
|
||||||
! ilem = 4 - strass.f
|
|
||||||
! ilem = 5 - mass.f
|
|
||||||
! ilem = 5 - osolty.f
|
|
||||||
! ilnmom Control flag for soil - pore pressure calculation. Input data.
|
|
||||||
! ilnmom = 0 - perform only pore pressure calculation.
|
|
||||||
! = 1 - couples pore pressure - displacement analysis
|
|
||||||
! iloren Control flag for DeLorenzi J-Integral evaluation. Input data.
|
|
||||||
! inc Increment number.
|
|
||||||
! incext Control flag indicating that currently working on a
|
|
||||||
! subincrement.
|
|
||||||
! Could be due to harmonics , damping component (bearing),
|
|
||||||
! stiffness component (bearing), auto therm creep or
|
|
||||||
! old viscoplaticity
|
|
||||||
! incsub Sub-increment number.
|
|
||||||
! ipass Control flag for which part of coupled analysis.
|
|
||||||
! ipass = -1 - reset to base values
|
|
||||||
! ipass = 0 - do nothing
|
|
||||||
! ipass = 1 - stress part
|
|
||||||
! ipass = 2 - heat transfer part
|
|
||||||
! iplres Flag indicating that either second matrix is stored.
|
|
||||||
! dynamic analysis - mass matrix
|
|
||||||
! heat transfer - specific heat matrix
|
|
||||||
! buckle - initial stress stiffness
|
|
||||||
! ipois Control flag indicating Poisson type analysis
|
|
||||||
! ipois = 1 for heat transfer
|
|
||||||
! = 1 for heat transfer part of coupled
|
|
||||||
! = 1 for bearing
|
|
||||||
! = 1 for electrostatic
|
|
||||||
! = 1 for magnetostatic
|
|
||||||
! ipoist Permanent copy of ipois. In coupled analysis , ipois = 0
|
|
||||||
! in stress portion, yet ipoist will still =1.
|
|
||||||
! irpflo global flag for rigid plastic flow analysis
|
|
||||||
! = 1 eularian formulation
|
|
||||||
! = 2 regular formulation; rigid material present in the analysis
|
|
||||||
|
|
||||||
! ismall control flag to indicate small displacement analysis. input data.
|
|
||||||
! ismall = 0 - large disp included.
|
|
||||||
! ismall = 1 - small displacement.
|
|
||||||
! the flag is changing between passes.
|
|
||||||
! ismalt permanent copy of ismall . in heat transfer portion of
|
|
||||||
! coupled analysis ismall =0 , but ismalt remains the same.
|
|
||||||
! isoil control flag indicating that soil / pore pressure
|
|
||||||
! calculation . input data.
|
|
||||||
! ispect control flag for response spectrum calculation. input data.
|
|
||||||
! ispnow control flag to indicate to perform a spectrum response
|
|
||||||
! calculation now.
|
|
||||||
! istore store stresses flag.
|
|
||||||
! istore = 0 in elem.f and if first pass of creep
|
|
||||||
! convergence checking in ogetst.f
|
|
||||||
! or harmonic analysis or thruc.f if not
|
|
||||||
! converged.
|
|
||||||
! iswep control flag for eigenvalue analysis.
|
|
||||||
! iswep=1 - go do extraction process
|
|
||||||
! ithcrp control flag for auto therm creep option. input data.
|
|
||||||
! itherm control flag for either temperature dependent material
|
|
||||||
! properties and/or thermal loads.
|
|
||||||
! iupblg control flag for follower force option. input data.
|
|
||||||
! iupdat control flag for update lagrange option for current element.
|
|
||||||
! jacflg control flag for lanczos iteration method. input data.
|
|
||||||
! jel control flag indicating that total load applied in
|
|
||||||
! increment, ignore previous solution.
|
|
||||||
! jel = 1 in increment 0
|
|
||||||
! = 1 if elastic or fourier
|
|
||||||
! = 1 in subincrements with elastic and adaptive
|
|
||||||
! jparks control flag for j integral by parks method. input data.
|
|
||||||
! largst control flag for finite strain plasticity. input data.
|
|
||||||
! lfond control variable that indicates if doing elastic
|
|
||||||
! foundation or film calculation. influences whether
|
|
||||||
! this is volumetric or surface integration.
|
|
||||||
! loadup control flag that indicates that nonlinearity occurred
|
|
||||||
! during previous increment.
|
|
||||||
! loaduq control flag that indicates that nonlinearity occurred.
|
|
||||||
! lodcor control flag for switching on the residual load correction.
|
|
||||||
! notice in input stage lodcor=0 means no loadcor,
|
|
||||||
! after omarc lodcor=1 means no loadcor
|
|
||||||
! lovl control flag for determining which "overlay" is to
|
|
||||||
! be called from ellib.
|
|
||||||
! lovl = 1 omarc
|
|
||||||
! = 2 oaread
|
|
||||||
! = 3 opress
|
|
||||||
! = 4 oasemb
|
|
||||||
! = 5 osolty
|
|
||||||
! = 6 ogetst
|
|
||||||
! = 7 oscinc
|
|
||||||
! = 8 odynam
|
|
||||||
! = 9 opmesh
|
|
||||||
! = 10 omesh2
|
|
||||||
! = 11 osetz
|
|
||||||
! = 12 oass
|
|
||||||
! = 13 oincdt
|
|
||||||
! = 14 oasmas
|
|
||||||
! = 15 ofluas
|
|
||||||
! = 16 ofluso
|
|
||||||
! = 17 oshtra
|
|
||||||
! = 18 ocass
|
|
||||||
! = 19 osoltc
|
|
||||||
! = 20 orezon
|
|
||||||
! = 21 otest
|
|
||||||
! = 22 oeigen
|
|
||||||
! lsub control variable to determine which part of element
|
|
||||||
! assembly function is being done.
|
|
||||||
! lsub = 1 - no longer used
|
|
||||||
! = 2 - beta*
|
|
||||||
! = 3 - cons*
|
|
||||||
! = 4 - ldef*
|
|
||||||
! = 5 - posw*
|
|
||||||
! = 6 - theta*
|
|
||||||
! = 7 - tmarx*
|
|
||||||
! = 8 - geom*
|
|
||||||
! magnet control flag for magnetostatic analysis. input data.
|
|
||||||
! ncycle cycle number. accumulated in osolty.f
|
|
||||||
! note first time through oasemb.f , ncycle = 0.
|
|
||||||
! newtnt control flag for permanent copy of newton.
|
|
||||||
! newton iteration type. input data.
|
|
||||||
! newton : = 1 full newton raphson
|
|
||||||
! 2 modified newton raphson
|
|
||||||
! 3 newton raphson with strain correct.
|
|
||||||
! 4 direct substitution
|
|
||||||
! 5 direct substitution followed by n.r.
|
|
||||||
! 6 direct substitution with line search
|
|
||||||
! 7 full newton raphson with secant initial stress
|
|
||||||
! 8 secant method
|
|
||||||
! 9 full newton raphson with line search
|
|
||||||
! noshr control flag for calculation interlaminar shears for
|
|
||||||
! elements 22,45, and 75. input data.
|
|
||||||
!ees
|
|
||||||
!
|
|
||||||
! jactch = 1 or 2 if elements are activated or deactivated
|
|
||||||
! = 3 if elements are adaptively remeshed or rezoned
|
|
||||||
! = 0 normally / reset to 0 when assembly is done
|
|
||||||
! ifricsh = 0 call to fricsh in otest not needed
|
|
||||||
! = 1 call to fricsh (nodal friction) in otest needed
|
|
||||||
! iremkin = 0 remove deactivated kinematic boundary conditions
|
|
||||||
! immediately - only in new input format (this is default)
|
|
||||||
! = 1 remove deactivated kinematic boundary conditions
|
|
||||||
! gradually - only in new input format
|
|
||||||
! iremfor = 0 remove force boundary conditions immediately -
|
|
||||||
! only in new input format (this is default)
|
|
||||||
! = 1 remove force boundary conditions gradually -
|
|
||||||
! only in new input format (this is default)
|
|
||||||
! ishearp set to 1 if shear panel elements are present in the model
|
|
||||||
!
|
|
||||||
! jspf = 0 not in spf loadcase
|
|
||||||
! > 0 in spf loadcase (jspf=1 during first increment)
|
|
||||||
! machining = 1 if the metal cutting feature is used, for memory allocation purpose
|
|
||||||
! = 0 (default) if no metal cutting feature required
|
|
||||||
!
|
|
||||||
! jlshell = 1 if there is a shell element in the mesh
|
|
||||||
! icompsol = 1 if there is a composite solid element in the mesh
|
|
||||||
! iupblgfo = 1 if follower force for point loads
|
|
||||||
! jcondir = 1 if contact priority option is used
|
|
||||||
! nstcrp = 0 (default) steady state creep flag (undocumented feature.
|
|
||||||
! if not 0, turns off special ncycle = 0 code in radial.f)
|
|
||||||
! nactive = number of active passes, if =1 then it's not a coupled analysis
|
|
||||||
! ipassref = reference ipass, if not in a multiphysics pass ipass=ipassref
|
|
||||||
! icheckmpc = value of mpc-check parameter option
|
|
||||||
! noline = set to 1 in osolty if no line seacrh should be done in ogetst
|
|
||||||
! icuring = set to 1 if the curing is included for the heat transfer analysis.
|
|
||||||
! ishrink = set to 1 if shrinkage strain is included for mechancial analysis.
|
|
||||||
! ioffsflg = 1 for small displacement beam/shell offsets
|
|
||||||
! = 2 for large displacement beam/shell offsets
|
|
||||||
! isetoff = 0 - do not apply beam/shell offsets
|
|
||||||
! = 1 - apply beam/shell offsets
|
|
||||||
! ioffsetm = min. value of offset flag
|
|
||||||
! iharmt = 1 global flag if a coupled analysis contains an harmonic pass
|
|
||||||
! inc_incdat = flag to record increment number of a new loadcase in incdat.f
|
|
||||||
! iautspc = flag for AutoSPC option
|
|
||||||
! ibrake = brake squeal in this increment
|
|
||||||
! icbush = set to 1 if cbush elements present in model
|
|
||||||
! istream_input = set to 1 for streaming input calling Marc as library
|
|
||||||
! iprsinp = set to 1 if pressure input, introduced so other variables
|
|
||||||
! such as h could be a function of pressure
|
|
||||||
! ivlsinp = set to 1 if velocity input, introduced so other variables
|
|
||||||
! such as h could be a function of velocity
|
|
||||||
! ipin_m = # of beam element with PIN flag
|
|
||||||
! jgnstr_glb = global control over pre or fast integrated composite shells
|
|
||||||
! imarc_return = Marc return flag for streaming input control
|
|
||||||
! iqvcimp = if non-zero, then the number of QVECT boundary conditions
|
|
||||||
! nqvceid = number of QVECT boundary conditions, where emisivity/absorbtion id entered
|
|
||||||
! istpnx = 1 if to stop at end of increment
|
|
||||||
! imicro1 = 1 if micro1 interface is used
|
|
||||||
! iaxisymm = set to 1 if axisymmetric analysis
|
|
||||||
! jbreakglue = set to 1 if breaking glued option is used
|
|
||||||
! iglstif = 1 if ddm and global stiffness matrix formed (sgi solver 6 or solver9)
|
|
||||||
! jfastasm = 1 do fast assembly using SuperForm code
|
|
||||||
! iwear = set to 1 if wear model, set to 2 if wear model and coordinates updated
|
|
||||||
! iwearcf = set to 1 to store nodal coefficient of friction for wear calculation
|
|
||||||
! imixmeth = set=1 then use nonlinear mixture material - allocate memory
|
|
||||||
! ielcmadyn = flag for magnetodynamics
|
|
||||||
! 0 - electromagnetics using newmark beta
|
|
||||||
! 1 - transient magnetics using backward euler
|
|
||||||
! idinout = flag to control if inside out elements should be deactivated
|
|
||||||
! igena_meth = 0 - generalized alpha parameters depend on whether or not contact
|
|
||||||
! is flagged (dynamic,7)
|
|
||||||
! 10 - generalized alpha parameters are optimized for a contact
|
|
||||||
! analysis (dynamic,8)
|
|
||||||
! 11 - generalized alpha parameters are optimized for an analysis
|
|
||||||
! without contact (dynamic,8)
|
|
||||||
! magf_meth = - Method to compute force in magnetostatic - structural
|
|
||||||
! = 1 - Virtual work method based on finite difference for the force computation
|
|
||||||
! = 2 - Maxwell stress tensor
|
|
||||||
! = 3 - Virtual work method based on local derivative for the force computation
|
|
||||||
! non_assumed = 1 no assumed strain formulation (forced)
|
|
||||||
! iredoboudry set to 1 if contact boundary needs to be recalculated
|
|
||||||
! ioffsz0 = 1 if composite are used with reference position.ne.0
|
|
||||||
! icomplt = 1 global flag if a coupled analysis contains an complex pass
|
|
||||||
! mesh_dual = 1 two independent meshes are used in magnetodynamic/thermal/structural
|
|
||||||
! one for magnetodynamic and the other for the remaining passes
|
|
||||||
! iactrp = 1 in an analysis with global remeshing, include inactive
|
|
||||||
! rigid bodies on post file
|
|
||||||
! mgnewton = 1 Use full Newton Raphson iteration for magnetostatic pass
|
|
||||||
!
|
|
||||||
! iusedens > 0 if mass density is used in the analysis (dynamics, mass dependent loading)
|
|
||||||
! igsigd0 = 1 set varselem(igsigd) to zero in next oasemb
|
|
||||||
! iaem = 1 if marc is called from aem (0 - off - default)
|
|
||||||
! icosim = 1 if marc is used in co-simulation software (ADAMS-MARC)
|
|
||||||
! inodels = 1 nodal integration elements 239/240/241 present
|
|
||||||
! nlharm = 0 harmonic subincrements are linear
|
|
||||||
! = 1 harmonic subincrements are nonlinear
|
|
||||||
! iampini = 0 amplitude of previous harmonic subinc is initial estimate (default)
|
|
||||||
! = 1 zero amplitude is initial estimate
|
|
||||||
! iphasetr = 1 phase transformation material model is used
|
|
||||||
!
|
|
||||||
!***********************************************************************
|
|
||||||
!$omp threadprivate(/marc_concom/)
|
|
||||||
!!
|
|
|
@ -1,424 +0,0 @@
|
||||||
! common block definition file taken from respective MSC.Marc release and reformated to free format
|
|
||||||
!***********************************************************************
|
|
||||||
!
|
|
||||||
! File: concom.cmn
|
|
||||||
!
|
|
||||||
! MSC.Marc include file
|
|
||||||
!
|
|
||||||
integer(pInt) &
|
|
||||||
iacous, iasmbl, iautth, ibear, icompl, iconj, icreep, ideva, idyn, idynt,&
|
|
||||||
ielas, ielcma, ielect, iform, ifour, iharm, ihcps, iheat, iheatt, ihresp,&
|
|
||||||
ijoule, ilem, ilnmom, iloren, inc, incext, incsub, ipass, iplres, ipois,&
|
|
||||||
ipoist, irpflo, ismall, ismalt, isoil, ispect, ispnow, istore, iswep, ithcrp,&
|
|
||||||
itherm, iupblg, iupdat, jacflg, jel, jparks, largst, lfond, loadup, loaduq,&
|
|
||||||
lodcor, lovl, lsub, magnet, ncycle, newtnt, newton, noshr, linear, ivscpl,&
|
|
||||||
icrpim, iradrt, ipshft, itshr, iangin, iupmdr, iconjf, jincfl, jpermg, jhour,&
|
|
||||||
isolvr, jritz, jtable, jshell, jdoubl, jform, jcentr, imini, kautth, iautof,&
|
|
||||||
ibukty, iassum, icnstd, icnstt, kmakmas, imethvp, iradrte, iradrtp, iupdate, iupdatp,&
|
|
||||||
ncycnt, marmen , idynme, ihavca, ispf, kmini, imixex, largtt, kdoela, iautofg,&
|
|
||||||
ipshftp, idntrc, ipore, jtablm, jtablc, isnecma, itrnspo, imsdif, jtrnspo, mcnear,&
|
|
||||||
imech, imecht, ielcmat, ielectt, magnett, imsdift, noplas, jtabls, jactch, jtablth,&
|
|
||||||
kgmsto , jpzo, ifricsh, iremkin, iremfor, ishearp, jspf, machining, jlshell, icompsol,&
|
|
||||||
iupblgfo, jcondir, nstcrp, nactive, ipassref, nstspnt, ibeart, icheckmpc, noline, icuring,&
|
|
||||||
ishrink, ioffsflg, isetoff, ioffsetm,iharmt, inc_incdat, iautspc, ibrake, icbush, istream_input,&
|
|
||||||
iprsinp, ivlsinp, ifirst_time,ipin_m, jgnstr_glb, imarc_return,iqvcinp, nqvceid, istpnx, imicro1,&
|
|
||||||
iaxisymm, jbreakglue,iglstif, jfastasm,iwear, iwearcf, imixmeth, ielcmadyn, idinout, igena_meth,&
|
|
||||||
magf_meth, non_assumed, iredoboudry, ioffsz0,icomplt, mesh_dual, iactrp, mgnewton, iusedens,igsigd0,&
|
|
||||||
iaem, icosim, inodels, nlharm, iampini, iphasetr, inonlcl, inonlct, iforminp,ispecerror
|
|
||||||
dimension :: ideva(60)
|
|
||||||
integer(pInt) num_concom
|
|
||||||
parameter(num_concom=249)
|
|
||||||
common/marc_concom/&
|
|
||||||
iacous, iasmbl, iautth, ibear, icompl, iconj, icreep, ideva, idyn, idynt,&
|
|
||||||
ielas, ielcma, ielect, iform, ifour, iharm, ihcps, iheat, iheatt, ihresp,&
|
|
||||||
ijoule, ilem, ilnmom, iloren, inc, incext, incsub, ipass, iplres, ipois,&
|
|
||||||
ipoist, irpflo, ismall, ismalt, isoil, ispect, ispnow, istore, iswep, ithcrp,&
|
|
||||||
itherm, iupblg, iupdat, jacflg, jel, jparks, largst, lfond, loadup, loaduq,&
|
|
||||||
lodcor, lovl, lsub, magnet, ncycle, newtnt, newton, noshr, linear, ivscpl,&
|
|
||||||
icrpim, iradrt, ipshft, itshr, iangin, iupmdr, iconjf, jincfl, jpermg, jhour,&
|
|
||||||
isolvr, jritz, jtable, jshell, jdoubl, jform, jcentr, imini, kautth, iautof,&
|
|
||||||
ibukty, iassum, icnstd, icnstt, kmakmas, imethvp, iradrte, iradrtp, iupdate, iupdatp,&
|
|
||||||
ncycnt, marmen, idynme, ihavca, ispf, kmini, imixex, largtt, kdoela, iautofg,&
|
|
||||||
ipshftp, idntrc, ipore, jtablm, jtablc, isnecma, itrnspo, imsdif, jtrnspo, mcnear,&
|
|
||||||
imech, imecht, ielcmat, ielectt, magnett, imsdift, noplas, jtabls, jactch, jtablth,&
|
|
||||||
kgmsto , jpzo, ifricsh, iremkin, iremfor, ishearp, jspf, machining, jlshell, icompsol,&
|
|
||||||
iupblgfo, jcondir, nstcrp, nactive, ipassref, nstspnt, ibeart, icheckmpc, noline, icuring,&
|
|
||||||
ishrink, ioffsflg, isetoff, ioffsetm,iharmt, inc_incdat, iautspc, ibrake, icbush, istream_input,&
|
|
||||||
iprsinp, ivlsinp, ifirst_time,ipin_m, jgnstr_glb, imarc_return,iqvcinp, nqvceid, istpnx, imicro1,&
|
|
||||||
iaxisymm, jbreakglue,iglstif, jfastasm,iwear, iwearcf, imixmeth, ielcmadyn, idinout, igena_meth,&
|
|
||||||
magf_meth, non_assumed, iredoboudry, ioffsz0,icomplt, mesh_dual, iactrp, mgnewton, iusedens,igsigd0,&
|
|
||||||
iaem, icosim, inodels, nlharm, iampini, iphasetr, inonlcl, inonlct, iforminp,ispecerror
|
|
||||||
!
|
|
||||||
! comments of variables:
|
|
||||||
!
|
|
||||||
! iacous Control flag for acoustic analysis. Input data.
|
|
||||||
! iacous=1 modal acoustic analysis.
|
|
||||||
! iacous=2 harmonic acoustic-structural analysis.
|
|
||||||
! iasmbl Control flag to indicate that operator matrix should be
|
|
||||||
! recalculated.
|
|
||||||
! iautth Control flag for AUTO THERM option.
|
|
||||||
! ibear Control flag for bearing analysis. Input data.
|
|
||||||
! icompl Control variable to indicate that a complex analysis is
|
|
||||||
! being performed. Either a Harmonic analysis with damping,
|
|
||||||
! or a harmonic electro-magnetic analysis. Input data.
|
|
||||||
! iconj Flag for EBE conjugate gradient solver (=solver 1, retired)
|
|
||||||
! Also used for VKI iterative solver.
|
|
||||||
! icreep Control flag for creep analysis. Input data.
|
|
||||||
! ideva(60) - debug print out flag
|
|
||||||
! 1 print element stiffness matrices, mass matrix
|
|
||||||
! 2 output matrices used in tying
|
|
||||||
! 3 force the solution of a nonpositive definite matrix
|
|
||||||
! 4 print info of connections to each node
|
|
||||||
! 5 info of gap convergence, internal heat generated, contact
|
|
||||||
! touching and separation
|
|
||||||
! 6 nodal value array during rezoning
|
|
||||||
! 7 tying info in CONRAD GAP option, fluid element numbers in
|
|
||||||
! CHANNEL option
|
|
||||||
! 8 output incremental displacements in local coord. system
|
|
||||||
! 9 latent heat output
|
|
||||||
! 10 stress-strain in local coord. system
|
|
||||||
! 11 additional info on interlaminar stress
|
|
||||||
! 12 output right hand side and solution vector
|
|
||||||
! 13 info of CPU resources used and memory available on NT
|
|
||||||
! 14 info of mesh adaption process, 2D outline information
|
|
||||||
! info of penetration checking for remeshing
|
|
||||||
! save .fem files after afmesh3d meshing
|
|
||||||
! 15 surface energy balance flag
|
|
||||||
! 16 print info regarding pyrolysis
|
|
||||||
! 17 print info of "streamline topology"
|
|
||||||
! 18 print mesh data changes after remeshing
|
|
||||||
! 19 print material flow stress data read in from *.mat file
|
|
||||||
! if unit flag is on, print out flow stress after conversion
|
|
||||||
! 20 print information on table input
|
|
||||||
! 21 print out information regarding kinematic boundary conditions
|
|
||||||
! 22 print out information regarding dist loads, point loads, film
|
|
||||||
! and foundations
|
|
||||||
! 23 print out information about automatic domain decomposition
|
|
||||||
! 24 print out iteration information in SuperForm status report file
|
|
||||||
! 25 print out information for ablation
|
|
||||||
! 26 print out information for films - Table input
|
|
||||||
! 27 print out the tying forces
|
|
||||||
! 28 print out for CASI solver, convection,
|
|
||||||
! 29 DDM single file debug printout
|
|
||||||
! 30 print out cavity debug info
|
|
||||||
! 31 print out welding related info
|
|
||||||
! 32 prints categorized DDM memory usage
|
|
||||||
! 33 print out the cutting info regarding machining feature
|
|
||||||
! 34 print out the list of quantities which can be defined via a table
|
|
||||||
! and for each quantity the supported independent variables
|
|
||||||
! 35 print out detailed coupling region info
|
|
||||||
! 36 print out solver debug info level 1 (Least Detailed)
|
|
||||||
! 37 print out solver debug info level 1 (Medium Detailed)
|
|
||||||
! 38 print out solver debug info level 1 (Very Detailed)
|
|
||||||
! 39 print detailed memory allocation info
|
|
||||||
! 40 print out marc-adams debug info
|
|
||||||
! 41 output rezone mapping post file for debugging
|
|
||||||
! 42 output post file after calling oprofos() for debugging
|
|
||||||
! 43 debug printout for vcct
|
|
||||||
! 44 debug printout for progressive failure
|
|
||||||
! 45 print out automatically generated midside node coordinates (arecrd)
|
|
||||||
! 46 print out message about routine and location, where the ibort is raised (ibort_inc)
|
|
||||||
! 47 print out summary message of element variables on a
|
|
||||||
! group-basis after all the automatic changes have been
|
|
||||||
! made (em_ellibp)
|
|
||||||
! 48 Automatically generate check results based on max and min vals.
|
|
||||||
! These vals are stored in the checkr file, which is inserted
|
|
||||||
! into the *dat file by the generate_check_results script from /marc/tools
|
|
||||||
! 49 Automatically generate check results based on the real calculated values
|
|
||||||
! at the sppecified check result locations.
|
|
||||||
! These vals are stored in the checkr file, which is inserted
|
|
||||||
! into the *dat file by the update_check_results script from /marc/tools
|
|
||||||
! 50 generate a file containing the resistance or capacity matrix;
|
|
||||||
! this file can be used to compare results with a reference file
|
|
||||||
! 51 print out detailed information for segment-to-segment contact
|
|
||||||
! 52 print out detailed relative displacement information
|
|
||||||
! for uniaxial sliding contact
|
|
||||||
! 53 print out detailed sliding direction information for
|
|
||||||
! uniaxial sliding contact
|
|
||||||
! 54 print out detailed information for edges attached to a curve
|
|
||||||
! 55 print information related to viscoelasticity calculations
|
|
||||||
! 56 print out detailed information for element coloring for multithreading
|
|
||||||
! 57 print out extra overheads due to multi-threading.
|
|
||||||
! These overhead includes (i) time and (ii) memory.
|
|
||||||
! The memory report will be summed over all the children.
|
|
||||||
!
|
|
||||||
!
|
|
||||||
! 58 debug output for ELSTO usage
|
|
||||||
!
|
|
||||||
! idyn Control flag for dynamics. Input data.
|
|
||||||
! 1 = eigenvalue extraction and / or modal superposition
|
|
||||||
! 2 = Newmark Beta and Single Step Houbolt (ssh with idynme=1)
|
|
||||||
! 3 = Houbolt
|
|
||||||
! 4 = Central difference
|
|
||||||
! 5 = Newer central difference
|
|
||||||
! idynt Copy of idyn at begining of increment
|
|
||||||
! ielas Control flag for ELASTIC analysis. Input data.
|
|
||||||
! Set by user or automatically turned on by Fourier option.
|
|
||||||
! Implies that each load case is treated separately.
|
|
||||||
! In Adaptive meshing analysis , forces re-analysis until
|
|
||||||
! convergence obtained.
|
|
||||||
! Also seriously misused to indicate no convergence.
|
|
||||||
! = 1 elastic option with fourier analysis
|
|
||||||
! = 2 elastic option without fourier analysis
|
|
||||||
! =-1 no convergence in recycles or max # increments reached
|
|
||||||
! Set to 1 if ELASTIC or SUBSTRUC parameter cards are used,
|
|
||||||
! or if fourier option is used.
|
|
||||||
! Then set to 2 if not fourier analysis.
|
|
||||||
! ielcma Control flag for electromagnetic analysis. Input data.
|
|
||||||
! ielcma = 1 Harmonic formulation
|
|
||||||
! ielcma = 2 Transient formulation
|
|
||||||
! ielect Control flag for electrostatic option. Input data.
|
|
||||||
! iform Control flag indicating that contact will be performed.
|
|
||||||
! ifour Control flag for Fourier analysis.
|
|
||||||
! 0 = Odd and even terms.
|
|
||||||
! 1 = symmetric (cosine) terms
|
|
||||||
! 2 = antisymmetric (sine) terms.
|
|
||||||
! iharm Control flag to indicate that a harmonic analysis will
|
|
||||||
! be performed. May change between passes.
|
|
||||||
! ihcps Control flag for coupled thermal - stress analysis.
|
|
||||||
! iheat Control flag for heat transfer analysis. Input data.
|
|
||||||
! iheatt Permanent control flag for heat transfer analysis.
|
|
||||||
! Note in coupled analysis iheatt will remain as one,
|
|
||||||
! but iheat will be zero in stress pass.
|
|
||||||
! ihresp Control flag to indicate to perform a harmonic subincrement.
|
|
||||||
! ijoule Control flag for Joule heating.
|
|
||||||
! ilem Control flag to determin which vector is to be transformed.
|
|
||||||
! Control flag to see where one is:
|
|
||||||
! ilem = 1 - elem.f
|
|
||||||
! ilem = 2 - initst.f
|
|
||||||
! ilem = 3 - pressr.f
|
|
||||||
! ilem = 3 - fstif.f
|
|
||||||
! ilem = 4 - jflux.f
|
|
||||||
! ilem = 4 - strass.f
|
|
||||||
! ilem = 5 - mass.f
|
|
||||||
! ilem = 5 - osolty.f
|
|
||||||
! ilnmom Control flag for soil - pore pressure calculation. Input data.
|
|
||||||
! ilnmom = 0 - perform only pore pressure calculation.
|
|
||||||
! = 1 - couples pore pressure - displacement analysis
|
|
||||||
! iloren Control flag for DeLorenzi J-Integral evaluation. Input data.
|
|
||||||
! inc Increment number.
|
|
||||||
! incext Control flag indicating that currently working on a
|
|
||||||
! subincrement.
|
|
||||||
! Could be due to harmonics , damping component (bearing),
|
|
||||||
! stiffness component (bearing), auto therm creep or
|
|
||||||
! old viscoplaticity
|
|
||||||
! incsub Sub-increment number.
|
|
||||||
! ipass Control flag for which part of coupled analysis.
|
|
||||||
! ipass = -1 - reset to base values
|
|
||||||
! ipass = 0 - do nothing
|
|
||||||
! ipass = 1 - stress part
|
|
||||||
! ipass = 2 - heat transfer part
|
|
||||||
! iplres Flag indicating that either second matrix is stored.
|
|
||||||
! dynamic analysis - mass matrix
|
|
||||||
! heat transfer - specific heat matrix
|
|
||||||
! buckle - initial stress stiffness
|
|
||||||
! ipois Control flag indicating Poisson type analysis
|
|
||||||
! ipois = 1 for heat transfer
|
|
||||||
! = 1 for heat transfer part of coupled
|
|
||||||
! = 1 for bearing
|
|
||||||
! = 1 for electrostatic
|
|
||||||
! = 1 for magnetostatic
|
|
||||||
! ipoist Permanent copy of ipois. In coupled analysis , ipois = 0
|
|
||||||
! in stress portion, yet ipoist will still =1.
|
|
||||||
! irpflo global flag for rigid plastic flow analysis
|
|
||||||
! = 1 eularian formulation
|
|
||||||
! = 2 regular formulation; rigid material present in the analysis
|
|
||||||
|
|
||||||
! ismall control flag to indicate small displacement analysis. input data.
|
|
||||||
! ismall = 0 - large disp included.
|
|
||||||
! ismall = 1 - small displacement.
|
|
||||||
! the flag is changing between passes.
|
|
||||||
! ismalt permanent copy of ismall . in heat transfer portion of
|
|
||||||
! coupled analysis ismall =0 , but ismalt remains the same.
|
|
||||||
! isoil control flag indicating that soil / pore pressure
|
|
||||||
! calculation . input data.
|
|
||||||
! ispect control flag for response spectrum calculation. input data.
|
|
||||||
! ispnow control flag to indicate to perform a spectrum response
|
|
||||||
! calculation now.
|
|
||||||
! istore store stresses flag.
|
|
||||||
! istore = 0 in elem.f and if first pass of creep
|
|
||||||
! convergence checking in ogetst.f
|
|
||||||
! or harmonic analysis or thruc.f if not
|
|
||||||
! converged.
|
|
||||||
! iswep control flag for eigenvalue analysis.
|
|
||||||
! iswep=1 - go do extraction process
|
|
||||||
! ithcrp control flag for auto therm creep option. input data.
|
|
||||||
! itherm control flag for either temperature dependent material
|
|
||||||
! properties and/or thermal loads.
|
|
||||||
! iupblg control flag for follower force option. input data.
|
|
||||||
! iupdat control flag for update lagrange option for current element.
|
|
||||||
! jacflg control flag for lanczos iteration method. input data.
|
|
||||||
! jel control flag indicating that total load applied in
|
|
||||||
! increment, ignore previous solution.
|
|
||||||
! jel = 1 in increment 0
|
|
||||||
! = 1 if elastic or fourier
|
|
||||||
! = 1 in subincrements with elastic and adaptive
|
|
||||||
! jparks control flag for j integral by parks method. input data.
|
|
||||||
! largst control flag for finite strain plasticity. input data.
|
|
||||||
! lfond control variable that indicates if doing elastic
|
|
||||||
! foundation or film calculation. influences whether
|
|
||||||
! this is volumetric or surface integration.
|
|
||||||
! loadup control flag that indicates that nonlinearity occurred
|
|
||||||
! during previous increment.
|
|
||||||
! loaduq control flag that indicates that nonlinearity occurred.
|
|
||||||
! lodcor control flag for switching on the residual load correction.
|
|
||||||
! notice in input stage lodcor=0 means no loadcor,
|
|
||||||
! after omarc lodcor=1 means no loadcor
|
|
||||||
! lovl control flag for determining which "overlay" is to
|
|
||||||
! be called from ellib.
|
|
||||||
! lovl = 1 omarc
|
|
||||||
! = 2 oaread
|
|
||||||
! = 3 opress
|
|
||||||
! = 4 oasemb
|
|
||||||
! = 5 osolty
|
|
||||||
! = 6 ogetst
|
|
||||||
! = 7 oscinc
|
|
||||||
! = 8 odynam
|
|
||||||
! = 9 opmesh
|
|
||||||
! = 10 omesh2
|
|
||||||
! = 11 osetz
|
|
||||||
! = 12 oass
|
|
||||||
! = 13 oincdt
|
|
||||||
! = 14 oasmas
|
|
||||||
! = 15 ofluas
|
|
||||||
! = 16 ofluso
|
|
||||||
! = 17 oshtra
|
|
||||||
! = 18 ocass
|
|
||||||
! = 19 osoltc
|
|
||||||
! = 20 orezon
|
|
||||||
! = 21 otest
|
|
||||||
! = 22 oeigen
|
|
||||||
! lsub control variable to determine which part of element
|
|
||||||
! assembly function is being done.
|
|
||||||
! lsub = 1 - no longer used
|
|
||||||
! = 2 - beta*
|
|
||||||
! = 3 - cons*
|
|
||||||
! = 4 - ldef*
|
|
||||||
! = 5 - posw*
|
|
||||||
! = 6 - theta*
|
|
||||||
! = 7 - tmarx*
|
|
||||||
! = 8 - geom*
|
|
||||||
! magnet control flag for magnetostatic analysis. input data.
|
|
||||||
! ncycle cycle number. accumulated in osolty.f
|
|
||||||
! note first time through oasemb.f , ncycle = 0.
|
|
||||||
! newtnt control flag for permanent copy of newton.
|
|
||||||
! newton iteration type. input data.
|
|
||||||
! newton : = 1 full newton raphson
|
|
||||||
! 2 modified newton raphson
|
|
||||||
! 3 newton raphson with strain correct.
|
|
||||||
! 4 direct substitution
|
|
||||||
! 5 direct substitution followed by n.r.
|
|
||||||
! 6 direct substitution with line search
|
|
||||||
! 7 full newton raphson with secant initial stress
|
|
||||||
! 8 secant method
|
|
||||||
! 9 full newton raphson with line search
|
|
||||||
! noshr control flag for calculation interlaminar shears for
|
|
||||||
! elements 22,45, and 75. input data.
|
|
||||||
!ees
|
|
||||||
!
|
|
||||||
! jactch = 1 or 2 if elements are activated or deactivated
|
|
||||||
! = 3 if elements are adaptively remeshed or rezoned
|
|
||||||
! = 0 normally / reset to 0 when assembly is done
|
|
||||||
! ifricsh = 0 call to fricsh in otest not needed
|
|
||||||
! = 1 call to fricsh (nodal friction) in otest needed
|
|
||||||
! iremkin = 0 remove deactivated kinematic boundary conditions
|
|
||||||
! immediately - only in new input format (this is default)
|
|
||||||
! = 1 remove deactivated kinematic boundary conditions
|
|
||||||
! gradually - only in new input format
|
|
||||||
! iremfor = 0 remove force boundary conditions immediately -
|
|
||||||
! only in new input format (this is default)
|
|
||||||
! = 1 remove force boundary conditions gradually -
|
|
||||||
! only in new input format (this is default)
|
|
||||||
! ishearp set to 1 if shear panel elements are present in the model
|
|
||||||
!
|
|
||||||
! jspf = 0 not in spf loadcase
|
|
||||||
! > 0 in spf loadcase (jspf=1 during first increment)
|
|
||||||
! machining = 1 if the metal cutting feature is used, for memory allocation purpose
|
|
||||||
! = 0 (default) if no metal cutting feature required
|
|
||||||
!
|
|
||||||
! jlshell = 1 if there is a shell element in the mesh
|
|
||||||
! icompsol = 1 if there is a composite solid element in the mesh
|
|
||||||
! iupblgfo = 1 if follower force for point loads
|
|
||||||
! jcondir = 1 if contact priority option is used
|
|
||||||
! nstcrp = 0 (default) steady state creep flag (undocumented feature.
|
|
||||||
! if not 0, turns off special ncycle = 0 code in radial.f)
|
|
||||||
! nactive = number of active passes, if =1 then it's not a coupled analysis
|
|
||||||
! ipassref = reference ipass, if not in a multiphysics pass ipass=ipassref
|
|
||||||
! icheckmpc = value of mpc-check parameter option
|
|
||||||
! noline = set to 1 in osolty if no line seacrh should be done in ogetst
|
|
||||||
! icuring = set to 1 if the curing is included for the heat transfer analysis.
|
|
||||||
! ishrink = set to 1 if shrinkage strain is included for mechancial analysis.
|
|
||||||
! ioffsflg = 1 for small displacement beam/shell offsets
|
|
||||||
! = 2 for large displacement beam/shell offsets
|
|
||||||
! isetoff = 0 - do not apply beam/shell offsets
|
|
||||||
! = 1 - apply beam/shell offsets
|
|
||||||
! ioffsetm = min. value of offset flag
|
|
||||||
! iharmt = 1 global flag if a coupled analysis contains an harmonic pass
|
|
||||||
! inc_incdat = flag to record increment number of a new loadcase in incdat.f
|
|
||||||
! iautspc = flag for AutoSPC option
|
|
||||||
! ibrake = brake squeal in this increment
|
|
||||||
! icbush = set to 1 if cbush elements present in model
|
|
||||||
! istream_input = set to 1 for streaming input calling Marc as library
|
|
||||||
! iprsinp = set to 1 if pressure input, introduced so other variables
|
|
||||||
! such as h could be a function of pressure
|
|
||||||
! ivlsinp = set to 1 if velocity input, introduced so other variables
|
|
||||||
! such as h could be a function of velocity
|
|
||||||
! ipin_m = # of beam element with PIN flag
|
|
||||||
! jgnstr_glb = global control over pre or fast integrated composite shells
|
|
||||||
! imarc_return = Marc return flag for streaming input control
|
|
||||||
! iqvcimp = if non-zero, then the number of QVECT boundary conditions
|
|
||||||
! nqvceid = number of QVECT boundary conditions, where emisivity/absorbtion id entered
|
|
||||||
! istpnx = 1 if to stop at end of increment
|
|
||||||
! imicro1 = 1 if micro1 interface is used
|
|
||||||
! iaxisymm = set to 1 if axisymmetric analysis
|
|
||||||
! jbreakglue = set to 1 if breaking glued option is used
|
|
||||||
! iglstif = 1 if ddm and global stiffness matrix formed (sgi solver 6 or solver9)
|
|
||||||
! jfastasm = 1 do fast assembly using SuperForm code
|
|
||||||
! iwear = set to 1 if wear model, set to 2 if wear model and coordinates updated
|
|
||||||
! iwearcf = set to 1 to store nodal coefficient of friction for wear calculation
|
|
||||||
! imixmeth = set=1 then use nonlinear mixture material - allocate memory
|
|
||||||
! ielcmadyn = flag for magnetodynamics
|
|
||||||
! 0 - electromagnetics using newmark beta
|
|
||||||
! 1 - transient magnetics using backward euler
|
|
||||||
! idinout = flag to control if inside out elements should be deactivated
|
|
||||||
! igena_meth = 0 - generalized alpha parameters depend on whether or not contact
|
|
||||||
! is flagged (dynamic,7)
|
|
||||||
! 10 - generalized alpha parameters are optimized for a contact
|
|
||||||
! analysis (dynamic,8)
|
|
||||||
! 11 - generalized alpha parameters are optimized for an analysis
|
|
||||||
! without contact (dynamic,8)
|
|
||||||
! magf_meth = - Method to compute force in magnetostatic - structural
|
|
||||||
! = 1 - Virtual work method based on finite difference for the force computation
|
|
||||||
! = 2 - Maxwell stress tensor
|
|
||||||
! = 3 - Virtual work method based on local derivative for the force computation
|
|
||||||
! non_assumed = 1 no assumed strain formulation (forced)
|
|
||||||
! iredoboudry set to 1 if contact boundary needs to be recalculated
|
|
||||||
! ioffsz0 = 1 if composite are used with reference position.ne.0
|
|
||||||
! icomplt = 1 global flag if a coupled analysis contains an complex pass
|
|
||||||
! mesh_dual = 1 two independent meshes are used in magnetodynamic/thermal/structural
|
|
||||||
! one for magnetodynamic and the other for the remaining passes
|
|
||||||
! iactrp = 1 in an analysis with global remeshing, include inactive
|
|
||||||
! rigid bodies on post file
|
|
||||||
! mgnewton = 1 Use full Newton Raphson iteration for magnetostatic pass
|
|
||||||
!
|
|
||||||
! iusedens > 0 if mass density is used in the analysis (dynamics, mass dependent loading)
|
|
||||||
! igsigd0 = 1 set varselem(igsigd) to zero in next oasemb
|
|
||||||
! iaem = 1 if marc is called from aem (0 - off - default)
|
|
||||||
! icosim = 1 if marc is used in co-simulation software (ADAMS-MARC)
|
|
||||||
! inodels = 1 nodal integration elements 239/240/241 present
|
|
||||||
! nlharm = 0 harmonic subincrements are linear
|
|
||||||
! = 1 harmonic subincrements are nonlinear
|
|
||||||
! iampini = 0 amplitude of previous harmonic subinc is initial estimate (default)
|
|
||||||
! = 1 zero amplitude is initial estimate
|
|
||||||
! iphasetr = 1 phase transformation material model is used
|
|
||||||
! iforminp flag indicating that contact is switched on via the CONTACT
|
|
||||||
! option in the input file (as opposed to the case that contact
|
|
||||||
! is switched on internally due to cyclic symmetry or model
|
|
||||||
! section creation)
|
|
||||||
! ispecerror = a+10*b (only for spectrum response analysis with missing mass option)
|
|
||||||
! a=0 or a=1 (modal shape with non-zero shift)
|
|
||||||
! b=0 or b=1 (recover with new assembly of stiffness matrix)
|
|
||||||
!
|
|
||||||
!***********************************************************************
|
|
||||||
!$omp threadprivate(/marc_concom/)
|
|
||||||
!!
|
|
|
@ -1,66 +0,0 @@
|
||||||
! common block definition file taken from respective MSC.Marc release and reformated to free format
|
|
||||||
!***********************************************************************
|
|
||||||
!
|
|
||||||
! File: creeps.cmn
|
|
||||||
!
|
|
||||||
! MSC.Marc include file
|
|
||||||
!
|
|
||||||
real(pReal) cptim,timinc,timinc_p,timinc_s,timincm,timinc_a,timinc_b
|
|
||||||
integer(pInt) icfte,icfst,icfeq,icftm,icetem,mcreep,jcreep,icpa,icftmp,icfstr,&
|
|
||||||
icfqcp,icfcpm,icrppr,icrcha,icpb,iicpmt,iicpa
|
|
||||||
real(pReal) time_beg_lcase,time_beg_inc,fractol,time_beg_pst
|
|
||||||
real(pReal) fraction_donn,timinc_ol2
|
|
||||||
!
|
|
||||||
integer(pInt) num_creepsr,num_creepsi,num_creeps2r
|
|
||||||
parameter(num_creepsr=7)
|
|
||||||
parameter(num_creepsi=17)
|
|
||||||
parameter(num_creeps2r=6)
|
|
||||||
common/marc_creeps/cptim,timinc,timinc_p,timinc_s,timincm,timinc_a,timinc_b,icfte,icfst,&
|
|
||||||
icfeq,icftm,icetem,mcreep,jcreep,icpa,icftmp,icfstr,icfqcp,icfcpm,icrppr,icrcha,icpb,iicpmt,iicpa
|
|
||||||
common/marc_creeps2/time_beg_lcase,time_beg_inc,fractol,time_beg_pst,fraction_donn,timinc_ol2
|
|
||||||
!
|
|
||||||
! cptim Total time at begining of increment.
|
|
||||||
! timinc Incremental time for this step.
|
|
||||||
! icfte Local copy number of slopes of creep strain rate function
|
|
||||||
! versus temperature. Is -1 if exponent law used.
|
|
||||||
! icfst Local copy number of slopes of creep strain rate function
|
|
||||||
! versus equivalent stress. Is -1 if exponent law used.
|
|
||||||
! icfeq Local copy number of slopes of creep strain rate function
|
|
||||||
! versus equivalent strain. Is -1 if exponent law used.
|
|
||||||
! icftm Local copy number of slopes of creep strain rate function
|
|
||||||
! versus time. Is -1 if exponent law used.
|
|
||||||
! icetem Element number that needs to be checked for creep convergence
|
|
||||||
! or, if negative, the number of elements that need to
|
|
||||||
! be checked. In the latter case the elements to check
|
|
||||||
! are stored in ielcp.
|
|
||||||
! mcreep Maximum nuber of iterations for explicit creep.
|
|
||||||
! jcreep Counter of number of iterations for explicit creep
|
|
||||||
! procedure. jcreep must be .le. mcreep
|
|
||||||
! icpa Pointer to constant in creep strain rate expression.
|
|
||||||
! icftmp Pointer to temperature dependent creep strain rate data.
|
|
||||||
! icfstr Pointer to equivalent stress dependent creep strain rate data.
|
|
||||||
! icfqcp Pointer to equivalent creep strain dependent creep strain
|
|
||||||
! rate data.
|
|
||||||
! icfcpm Pointer to equivalent creep strain rate dependent
|
|
||||||
! creep strain rate data.
|
|
||||||
! icrppr Permanent copy of icreep
|
|
||||||
! icrcha Control flag for creep convergence checking , if set to
|
|
||||||
! 1 then testing on absolute change in stress and creep
|
|
||||||
! strain, not relative testing. Input data.
|
|
||||||
! icpb Pointer to storage of material id cross reference numbers.
|
|
||||||
! iicpmt
|
|
||||||
! iicpa Pointer to constant in creep strain rate expression
|
|
||||||
!
|
|
||||||
! time_beg_lcase time at the beginning of the current load case
|
|
||||||
! time_beg_inc time at the beginning of the current increment
|
|
||||||
! fractol fraction of loadcase or increment time when we
|
|
||||||
! consider it to be finished
|
|
||||||
! time_beg_pst time corresponding to first increment to be
|
|
||||||
! read in from thermal post file for auto step
|
|
||||||
!
|
|
||||||
! timinc_old Time step of the previous increment
|
|
||||||
!
|
|
||||||
!***********************************************************************
|
|
||||||
!!$omp threadprivate(/marc_creeps/)
|
|
||||||
!!$omp threadprivate(/marc_creeps2/)
|
|
||||||
!!
|
|
|
@ -1,66 +0,0 @@
|
||||||
! common block definition file taken from respective MSC.Marc release and reformated to free format
|
|
||||||
!***********************************************************************
|
|
||||||
!
|
|
||||||
! File: creeps.cmn
|
|
||||||
!
|
|
||||||
! MSC.Marc include file
|
|
||||||
!
|
|
||||||
real(pReal) cptim,timinc,timinc_p,timinc_s,timincm,timinc_a,timinc_b
|
|
||||||
integer(pInt) icfte,icfst,icfeq,icftm,icetem,mcreep,jcreep,icpa,icftmp,icfstr,&
|
|
||||||
icfqcp,icfcpm,icrppr,icrcha,icpb,iicpmt,iicpa
|
|
||||||
real(pReal) time_beg_lcase,time_beg_inc,fractol,time_beg_pst
|
|
||||||
real(pReal) fraction_donn,timinc_ol2
|
|
||||||
!
|
|
||||||
integer(pInt) num_creepsr,num_creepsi,num_creeps2r
|
|
||||||
parameter(num_creepsr=7)
|
|
||||||
parameter(num_creepsi=17)
|
|
||||||
parameter(num_creeps2r=6)
|
|
||||||
common/marc_creeps/cptim,timinc,timinc_p,timinc_s,timincm,timinc_a,timinc_b,icfte,icfst,&
|
|
||||||
icfeq,icftm,icetem,mcreep,jcreep,icpa,icftmp,icfstr,icfqcp,icfcpm,icrppr,icrcha,icpb,iicpmt,iicpa
|
|
||||||
common/marc_creeps2/time_beg_lcase,time_beg_inc,fractol,time_beg_pst,fraction_donn,timinc_ol2
|
|
||||||
!
|
|
||||||
! cptim Total time at begining of increment.
|
|
||||||
! timinc Incremental time for this step.
|
|
||||||
! icfte Local copy number of slopes of creep strain rate function
|
|
||||||
! versus temperature. Is -1 if exponent law used.
|
|
||||||
! icfst Local copy number of slopes of creep strain rate function
|
|
||||||
! versus equivalent stress. Is -1 if exponent law used.
|
|
||||||
! icfeq Local copy number of slopes of creep strain rate function
|
|
||||||
! versus equivalent strain. Is -1 if exponent law used.
|
|
||||||
! icftm Local copy number of slopes of creep strain rate function
|
|
||||||
! versus time. Is -1 if exponent law used.
|
|
||||||
! icetem Element number that needs to be checked for creep convergence
|
|
||||||
! or, if negative, the number of elements that need to
|
|
||||||
! be checked. In the latter case the elements to check
|
|
||||||
! are stored in ielcp.
|
|
||||||
! mcreep Maximum nuber of iterations for explicit creep.
|
|
||||||
! jcreep Counter of number of iterations for explicit creep
|
|
||||||
! procedure. jcreep must be .le. mcreep
|
|
||||||
! icpa Pointer to constant in creep strain rate expression.
|
|
||||||
! icftmp Pointer to temperature dependent creep strain rate data.
|
|
||||||
! icfstr Pointer to equivalent stress dependent creep strain rate data.
|
|
||||||
! icfqcp Pointer to equivalent creep strain dependent creep strain
|
|
||||||
! rate data.
|
|
||||||
! icfcpm Pointer to equivalent creep strain rate dependent
|
|
||||||
! creep strain rate data.
|
|
||||||
! icrppr Permanent copy of icreep
|
|
||||||
! icrcha Control flag for creep convergence checking , if set to
|
|
||||||
! 1 then testing on absolute change in stress and creep
|
|
||||||
! strain, not relative testing. Input data.
|
|
||||||
! icpb Pointer to storage of material id cross reference numbers.
|
|
||||||
! iicpmt
|
|
||||||
! iicpa Pointer to constant in creep strain rate expression
|
|
||||||
!
|
|
||||||
! time_beg_lcase time at the beginning of the current load case
|
|
||||||
! time_beg_inc time at the beginning of the current increment
|
|
||||||
! fractol fraction of loadcase or increment time when we
|
|
||||||
! consider it to be finished
|
|
||||||
! time_beg_pst time corresponding to first increment to be
|
|
||||||
! read in from thermal post file for auto step
|
|
||||||
!
|
|
||||||
! timinc_old Time step of the previous increment
|
|
||||||
!
|
|
||||||
!***********************************************************************
|
|
||||||
!!$omp threadprivate(/marc_creeps/)
|
|
||||||
!!$omp threadprivate(/marc_creeps2/)
|
|
||||||
!!
|
|
Loading…
Reference in New Issue