add the output of standard deviation errors;

fix Hill 48 and anisotropic Barlat 1991
This commit is contained in:
Haiming Zhang 2015-02-04 13:04:34 +00:00
parent 43ed6028bc
commit 2d568b49f2
1 changed files with 15 additions and 6 deletions

View File

@ -122,9 +122,9 @@ def Hill1948(sigmas, F,G,H,L,M,N):
r = F*(sigmas[4]-sigmas[8])**2.0\ r = F*(sigmas[4]-sigmas[8])**2.0\
+ G*(sigmas[8]-sigmas[0])**2.0\ + G*(sigmas[8]-sigmas[0])**2.0\
+ H*(sigmas[0]-sigmas[4])**2.0\ + H*(sigmas[0]-sigmas[4])**2.0\
+ 2.0*L* sigmas[1]**2.0\ + 2.0*L* sigmas[5]**2.0\
+ 2.0*M* sigmas[2]**2.0\ + 2.0*M* sigmas[2]**2.0\
+ 2.0*N* sigmas[5]**2.0\ + 2.0*N* sigmas[1]**2.0\
- 1.0 - 1.0
return r.ravel()/2.0 return r.ravel()/2.0
@ -274,33 +274,41 @@ class Criterion(object):
if self.name.lower() == 'tresca': if self.name.lower() == 'tresca':
funResidum = Tresca funResidum = Tresca
text = '\nCoefficient of Tresca criterion:\nsigma0: '+formatOutput(1) text = '\nCoefficient of Tresca criterion:\nsigma0: '+formatOutput(1)
error='The standard deviation error is: '+formatOutput(1,'%-14.8f')+'\n'
elif self.name.lower() == 'vonmises': elif self.name.lower() == 'vonmises':
funResidum = vonMises funResidum = vonMises
text = '\nCoefficient of Huber-Mises-Hencky criterion:\nsigma0: '+formatOutput(1) text = '\nCoefficient of Huber-Mises-Hencky criterion:\nsigma0: '+formatOutput(1)
error='The standard deviation error is: '+formatOutput(1,'%-14.8f')+'\n'
elif self.name.lower() == 'drucker': elif self.name.lower() == 'drucker':
funResidum = Drucker funResidum = Drucker
text = '\nCoefficient of Drucker criterion:\nsigma0, C_D: '+formatOutput(2) text = '\nCoefficient of Drucker criterion:\nsigma0, C_D: '+formatOutput(2)
error='The standard deviation errors are: '+formatOutput(2,'%-14.8f')+'\n'
elif self.name.lower() == 'hill48': elif self.name.lower() == 'hill48':
funResidum = Hill1948 funResidum = Hill1948
text = '\nCoefficient of Hill1948 criterion:\n[F, G, H, L, M, N]:\n'+formatOutput(6) text = '\nCoefficient of Hill1948 criterion:\n[F, G, H, L, M, N]:\n'+formatOutput(6)
error='The standard deviation errors are: '+formatOutput(6,'%-14.8f')+'\n'
elif self.name.lower() == 'barlat91iso': elif self.name.lower() == 'barlat91iso':
funResidum = Barlat1991iso funResidum = Barlat1991iso
text = '\nCoefficient of isotropic Barlat 1991 criterion:\nsigma0, m:\n'+formatOutput(2) text = '\nCoefficient of isotropic Barlat 1991 criterion:\nsigma0, m:\n'+formatOutput(2)
error='The standard deviation errors are: '+formatOutput(2,'%-14.8f')+'\n'
elif self.name.lower() == 'barlat91aniso': elif self.name.lower() == 'barlat91aniso':
funResidum = Barlat1991iso funResidum = Barlat1991aniso
text = '\nCoefficient of anisotropic Barlat 1991 criterion:\nsigma0, \m, a, b, c, f, g, h:\n' \ text = '\nCoefficient of anisotropic Barlat 1991 criterion:\nsigma0, \m, a, b, c, f, g, h:\n' \
+formatOutput(8) +formatOutput(8)
if fitResults == []: error='The standard deviation errors are: '+formatOutput(8,'%-14.8f')
if fitResults == []:
initialguess = fittingCriteria[funResidum.__name__]['fit'] initialguess = fittingCriteria[funResidum.__name__]['fit']
else: else:
initialguess = np.array(fitResults[-1]) initialguess = np.array(fitResults[-1])
weight = get_weight(np.shape(stress)[1]) weight = get_weight(np.shape(stress)[1])
try: try:
popt, pcov = \ popt, pcov = \
curve_fit(funResidum, stress, np.zeros(np.shape(stress)[1]), curve_fit(funResidum, stress, np.zeros(np.shape(stress)[1]),
initialguess, weight) initialguess, weight)
print (text%popt) perr = np.sqrt(np.diag(pcov))
fitResults.append(popt.tolist()) fitResults.append(popt.tolist())
print (text%popt)
print (error%perr)
except Exception as detail: except Exception as detail:
print detail print detail
pass pass
@ -358,6 +366,7 @@ def doSim(delay,thread):
else: s.release() else: s.release()
s.acquire() s.acquire()
print('-'*10)
print('reading values for sim %i from %s'%(me,thread)) print('reading values for sim %i from %s'%(me,thread))
s.release() s.release()