fixed missing structure type in material.config, small changes in the other code
This commit is contained in:
parent
1d7794978d
commit
37aa559bd4
|
@ -1276,9 +1276,6 @@ subroutine lattice_init
|
||||||
if (LATTICE_bct_Nslip /= sum(lattice_bct_NslipSystem)) &
|
if (LATTICE_bct_Nslip /= sum(lattice_bct_NslipSystem)) &
|
||||||
call IO_error(0_pInt,ext_msg = 'LATTICE_bct_Nslip')
|
call IO_error(0_pInt,ext_msg = 'LATTICE_bct_Nslip')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (LATTICE_fcc_Ntwin /= sum(lattice_fcc_NtwinSystem)) &
|
if (LATTICE_fcc_Ntwin /= sum(lattice_fcc_NtwinSystem)) &
|
||||||
call IO_error(0_pInt,ext_msg = 'LATTICE_fcc_Ntwin')
|
call IO_error(0_pInt,ext_msg = 'LATTICE_fcc_Ntwin')
|
||||||
if (LATTICE_bcc_Ntwin /= sum(lattice_bcc_NtwinSystem)) &
|
if (LATTICE_bcc_Ntwin /= sum(lattice_bcc_NtwinSystem)) &
|
||||||
|
@ -1288,8 +1285,6 @@ subroutine lattice_init
|
||||||
if (LATTICE_bct_Ntwin /= sum(lattice_bct_NtwinSystem)) &
|
if (LATTICE_bct_Ntwin /= sum(lattice_bct_NtwinSystem)) &
|
||||||
call IO_error(0_pInt,ext_msg = 'LATTICE_bct_Ntwin')
|
call IO_error(0_pInt,ext_msg = 'LATTICE_bct_Ntwin')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (LATTICE_fcc_Ntrans /= sum(lattice_fcc_NtransSystem)) &
|
if (LATTICE_fcc_Ntrans /= sum(lattice_fcc_NtransSystem)) &
|
||||||
call IO_error(0_pInt,ext_msg = 'LATTICE_fcc_Ntrans')
|
call IO_error(0_pInt,ext_msg = 'LATTICE_fcc_Ntrans')
|
||||||
if (LATTICE_bcc_Ntrans /= sum(lattice_bcc_NtransSystem)) &
|
if (LATTICE_bcc_Ntrans /= sum(lattice_bcc_NtransSystem)) &
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
! $Id: plastic_phenopowerlaw.f90 4457 2015-09-08 19:44:32Z MPIE\m.diehl $
|
! $Id$
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Franz Roters, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
!> @author Philip Eisenlohr, Max-Planck-Institut für Eisenforschung GmbH
|
||||||
|
@ -170,7 +170,7 @@ subroutine plastic_phenoplus_init(fileUnit)
|
||||||
|
|
||||||
mainProcess: if (worldrank == 0) then
|
mainProcess: if (worldrank == 0) then
|
||||||
write(6,'(/,a)') ' <<<+- constitutive_'//PLASTICITY_PHENOPLUS_label//' init -+>>>'
|
write(6,'(/,a)') ' <<<+- constitutive_'//PLASTICITY_PHENOPLUS_label//' init -+>>>'
|
||||||
write(6,'(a)') ' $Id: plastic_phenoplus.f90 4457 2015-09-08 19:44:32Z MPIE\m.diehl $'
|
write(6,'(a)') ' $Id$'
|
||||||
write(6,'(a15,a)') ' Current time: ',IO_timeStamp()
|
write(6,'(a15,a)') ' Current time: ',IO_timeStamp()
|
||||||
#include "compilation_info.f90"
|
#include "compilation_info.f90"
|
||||||
endif mainProcess
|
endif mainProcess
|
||||||
|
|
|
@ -347,7 +347,7 @@ end function vacancyflux_cahnhilliard_getDiffusion33
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief returns homogenized vacancy formation energy
|
!> @brief returns homogenized vacancy formation energy
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
function vacancyflux_cahnhilliard_getFormationEnergy(ip,el)
|
real(pReal) function vacancyflux_cahnhilliard_getFormationEnergy(ip,el)
|
||||||
use lattice, only: &
|
use lattice, only: &
|
||||||
lattice_vacancyFormationEnergy, &
|
lattice_vacancyFormationEnergy, &
|
||||||
lattice_vacancyVol, &
|
lattice_vacancyVol, &
|
||||||
|
@ -362,8 +362,6 @@ function vacancyflux_cahnhilliard_getFormationEnergy(ip,el)
|
||||||
integer(pInt), intent(in) :: &
|
integer(pInt), intent(in) :: &
|
||||||
ip, & !< integration point number
|
ip, & !< integration point number
|
||||||
el !< element number
|
el !< element number
|
||||||
real(pReal) :: &
|
|
||||||
vacancyflux_cahnhilliard_getFormationEnergy
|
|
||||||
integer(pInt) :: &
|
integer(pInt) :: &
|
||||||
grain
|
grain
|
||||||
|
|
||||||
|
@ -384,7 +382,7 @@ end function vacancyflux_cahnhilliard_getFormationEnergy
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
!> @brief returns homogenized vacancy entropy coefficient
|
!> @brief returns homogenized vacancy entropy coefficient
|
||||||
!--------------------------------------------------------------------------------------------------
|
!--------------------------------------------------------------------------------------------------
|
||||||
function vacancyflux_cahnhilliard_getEntropicCoeff(ip,el)
|
real(pReal) function vacancyflux_cahnhilliard_getEntropicCoeff(ip,el)
|
||||||
use lattice, only: &
|
use lattice, only: &
|
||||||
lattice_vacancyVol, &
|
lattice_vacancyVol, &
|
||||||
lattice_vacancySurfaceEnergy
|
lattice_vacancySurfaceEnergy
|
||||||
|
@ -399,8 +397,6 @@ function vacancyflux_cahnhilliard_getEntropicCoeff(ip,el)
|
||||||
integer(pInt), intent(in) :: &
|
integer(pInt), intent(in) :: &
|
||||||
ip, & !< integration point number
|
ip, & !< integration point number
|
||||||
el !< element number
|
el !< element number
|
||||||
real(pReal) :: &
|
|
||||||
vacancyflux_cahnhilliard_getEntropicCoeff
|
|
||||||
integer(pInt) :: &
|
integer(pInt) :: &
|
||||||
grain
|
grain
|
||||||
|
|
||||||
|
|
|
@ -42,11 +42,30 @@ class Test():
|
||||||
description = test_description+' (using class: $Id$)',
|
description = test_description+' (using class: $Id$)',
|
||||||
usage='./test.py [options]')
|
usage='./test.py [options]')
|
||||||
self.updateRequested = False
|
self.updateRequested = False
|
||||||
|
self.parser.add_option("-d", "--debug", action="store_true",\
|
||||||
|
dest="debug",\
|
||||||
|
help="debug run, don't calculate but use existing results")
|
||||||
|
self.parser.add_option("-p", "--pass", action="store_true",\
|
||||||
|
dest="accept",\
|
||||||
|
help="calculate results but always consider test as successfull")
|
||||||
|
self.parser.set_defaults(debug=False,
|
||||||
|
accept=False)
|
||||||
|
|
||||||
def execute(self):
|
def execute(self):
|
||||||
'''
|
'''
|
||||||
Run all variants and report first failure.
|
Run all variants and report first failure.
|
||||||
'''
|
'''
|
||||||
|
if self.options.debug:
|
||||||
|
for variant in xrange(len(self.variants)):
|
||||||
|
try:
|
||||||
|
self.postprocess(variant)
|
||||||
|
if not self.compare(variant):
|
||||||
|
return variant+1 # return culprit
|
||||||
|
except Exception as e :
|
||||||
|
logging.critical('\nWARNING:\n %s\n'%e)
|
||||||
|
return variant+1 # return culprit
|
||||||
|
return 0
|
||||||
|
else:
|
||||||
if not self.testPossible(): return -1
|
if not self.testPossible(): return -1
|
||||||
self.clean()
|
self.clean()
|
||||||
self.prepareAll()
|
self.prepareAll()
|
||||||
|
@ -57,7 +76,7 @@ class Test():
|
||||||
self.postprocess(variant)
|
self.postprocess(variant)
|
||||||
if self.updateRequested: # update requested
|
if self.updateRequested: # update requested
|
||||||
self.update(variant)
|
self.update(variant)
|
||||||
elif not self.compare(variant): # no update, do comparison
|
elif not (self.options.accept or self.compare(variant)): # no update, do comparison
|
||||||
return variant+1 # return culprit
|
return variant+1 # return culprit
|
||||||
except Exception as e :
|
except Exception as e :
|
||||||
logging.critical('\nWARNING:\n %s\n'%e)
|
logging.critical('\nWARNING:\n %s\n'%e)
|
||||||
|
@ -406,6 +425,64 @@ class Test():
|
||||||
return maxError
|
return maxError
|
||||||
|
|
||||||
|
|
||||||
|
def compare_TablesStatistically(self,
|
||||||
|
files = [None,None], # list of file names
|
||||||
|
columns = [None], # list of list of column labels (per file)
|
||||||
|
meanTol = 1.0e-4,
|
||||||
|
stdTol = 1.0e-6,
|
||||||
|
preFilter = 1.0e-9):
|
||||||
|
|
||||||
|
'''
|
||||||
|
calculate statistics of tables
|
||||||
|
threshold can be used to ignore small values (a negative number disables this feature)
|
||||||
|
'''
|
||||||
|
|
||||||
|
import numpy as np
|
||||||
|
from collections import Iterable
|
||||||
|
|
||||||
|
if not (isinstance(files, Iterable) and not isinstance(files, str)): # check whether list of files is requested
|
||||||
|
files = [str(files)]
|
||||||
|
|
||||||
|
tables = [damask.ASCIItable(name = filename,readonly = True) for filename in files]
|
||||||
|
for table in tables:
|
||||||
|
table.head_read()
|
||||||
|
|
||||||
|
columns += [columns[0]]*(len(files)-len(columns)) # extend to same length as files
|
||||||
|
columns = columns[:len(files)] # truncate to same length as files
|
||||||
|
|
||||||
|
for i,column in enumerate(columns):
|
||||||
|
if column is None: columns[i] = tables[i].labels # if no column is given, read all
|
||||||
|
|
||||||
|
logging.info('comparing ASCIItables statistically')
|
||||||
|
for i in xrange(len(columns)):
|
||||||
|
columns[i] = columns[0] if not columns[i] else \
|
||||||
|
([columns[i]] if not (isinstance(columns[i], Iterable) and not isinstance(columns[i], str)) else \
|
||||||
|
columns[i]
|
||||||
|
)
|
||||||
|
logging.info(files[i]+':'+','.join(columns[i]))
|
||||||
|
|
||||||
|
if len(files) < 2: return True # single table is always close to itself...
|
||||||
|
|
||||||
|
data = []
|
||||||
|
for table,labels in zip(tables,columns):
|
||||||
|
table.data_readArray(labels)
|
||||||
|
data.append(table.data)
|
||||||
|
table.close()
|
||||||
|
|
||||||
|
|
||||||
|
for i in xrange(1,len(data)):
|
||||||
|
delta = data[i]-data[i-1]
|
||||||
|
normBy = (np.abs(data[i]) + np.abs(data[i-1]))*0.5
|
||||||
|
normedDelta = np.where(normBy>preFilter,delta/normBy,0.0)
|
||||||
|
mean = np.amax(np.abs(np.mean(normedDelta,0)))
|
||||||
|
std = np.amax(np.std(normedDelta,0))
|
||||||
|
logging.info('mean: %f'%mean)
|
||||||
|
logging.info('std: %f'%std)
|
||||||
|
|
||||||
|
return (mean<meanTol) & (std < stdTol)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def compare_Tables(self,
|
def compare_Tables(self,
|
||||||
files = [None,None], # list of file names
|
files = [None,None], # list of file names
|
||||||
columns = [None], # list of list of column labels (per file)
|
columns = [None], # list of list of column labels (per file)
|
||||||
|
@ -471,7 +548,7 @@ class Test():
|
||||||
t0 = np.where(mask,0.0,data[i-1])
|
t0 = np.where(mask,0.0,data[i-1])
|
||||||
t1 = np.where(mask,0.0,data[i ])
|
t1 = np.where(mask,0.0,data[i ])
|
||||||
j = np.argmin(np.abs(t1)*rtol+atol-np.abs(t0-t1))
|
j = np.argmin(np.abs(t1)*rtol+atol-np.abs(t0-t1))
|
||||||
print np.amin(np.abs(t1)*rtol+atol-np.abs(t0-t1))
|
logging.info('%f'%np.amax(np.abs(t0-t1)/(np.abs(t1)*rtol+atol)))
|
||||||
logging.info('%f %f'%((t0*maximum).flatten()[j],(t1*maximum).flatten()[j]))
|
logging.info('%f %f'%((t0*maximum).flatten()[j],(t1*maximum).flatten()[j]))
|
||||||
allclose &= np.allclose(np.where(mask,0.0,data[i-1]),
|
allclose &= np.allclose(np.where(mask,0.0,data[i-1]),
|
||||||
np.where(mask,0.0,data[i ]),rtol,atol) # accumulate "pessimism"
|
np.where(mask,0.0,data[i ]),rtol,atol) # accumulate "pessimism"
|
||||||
|
|
Loading…
Reference in New Issue