我有以下代码,比较值Cd
和Cdd
:
# use Python 3 print function and division
from __future__ import print_function
from __future__ import division
# libraries
import numpy as np
#--- INPUTS
rhog = 1.17 # density (kg/m^3)
ug = 1.85e-5 # dynamic viscosity (kg/ms)
g = 9.81 # gravity (m/s^2)
dp = 0.000207 # diameter of particle (m)
rhos = 2500 # density of particle (kg/m^3)
sp = 0.8 # sphericity of the particle, perfect sphere = 1.0
#--- OUTPUTS
# acceptable difference between Cd and Cdd
dn = 0.02
# determine ut when abs(Cd-Cdd) is a minimum
for ut in np.arange(0, 20, 0.001):
Re = (dp*rhog*ut)/ug
Cd = (24/Re)*(1+(8.1716*np.exp(-4.0655*sp))*Re**(0.0964+0.5565*sp)) + (73.69*np.exp(-5.0748*sp)*Re)/(Re+5.378*np.exp(6.2122*sp))
Cdd = (4*g*dp*(rhos-rhog))/(3*(ut**2)*rhog)
delta = abs(Cd-Cdd)
if delta < dn:
break
print('ut =', ut)
print('Re =', Re)
print('Cd =', Cd)
print('Cdd =', Cdd)
print('delta =', delta)
一切正常,除非代码运行的sp
值较低,例如sp=0.2
,导致delta < dn
的条件永远不会发生。
是否有更好的方法来比较Cd
和Cdd
条款?
答案 0 :(得分:1)
矢量化方法是计算所有值,然后寻找最小值:
ut = np.arange(0, 20, 0.001)
Re = (dp*rhog*ut)/ug
Cd = ((24/Re)*(1+(8.1716*np.exp(-4.0655*sp))*Re**(0.0964+0.5565*sp)) +
73.69*np.exp(-5.0748*sp)*Re)/(Re+5.378*np.exp(6.2122*sp)))
Cdd = (4*g*dp*(rhos-rhog))/(3*(ut**2)*rhog)
delta = np.abs(Cd-Cdd)
idx = np.argmin(delta)
print('ut =', ut[idx])
print('Re =', Re[idx])
print('Cd =', Cd[idx])
print('Cdd =', Cdd[idx])
print('delta =', delta[idx])
因为没有Python循环,它可能比当前代码运行得更快,即使它可能会做很多不必要的工作。
答案 1 :(得分:1)
这最初是一个评论,但我没有了房间。
测试收敛到min的常用方法是RMSD(均方根偏差)测试。要计算RMS偏差(也称为Standard Error
),请计算Cd
和Cdd
之间的平方差的平方根,即每个间隔math.sqrt((Cd-Cdd)**2)
。然后,除以您要比较的值的平方根(在这种情况下为2)。
这给了你:
rmsd = math.sqrt( ((Cd - Cdd)**2)/2 )
当两个值之间的差异收敛到最小值时,RMSD将变得越来越少。最终它只会改变一小部分,你可以说差异已经收敛。因此,跟踪迭代之间的rmsd,并将delta
应用于它:
if math.abs(rmsdPrior - rmsdCurrent) < delta:
break
答案 2 :(得分:0)
你确定它们实际上正在收敛sp>0.2
的值吗? ut
到达20
时,您确定循环没有退出吗?我做了一些测试,循环遍历ut
的值,从0.0001到20,增量为1,sp
从1
下降到01
并每次打印值通过环。它总是在ut==20
退出,Cd
永远不会接近Cdd
...
spr = range(10,1,-1)
for spv in spr:
sp = spv/10.0
# determine ut when abs(Cd-Cdd) is a minimum
# for ut in np.arange(0, 20, 0.001):
for ut in np.arange(0.0001, 20, 1):
Re = (dp*rhog*ut)/ug
Cd = (24/Re) * (1+(8.1716*np.exp(-4.0655*sp)) * Re**(0.0964+0.5565*sp)) + (73.69*np.exp(-5.0748*sp)*Re)/(Re+5.378*np.exp(6.2122*sp))
# Cd2 = (24/Re) * (1 + 0.14*Re**0.7) # for a sphere sp==1
Cdd = (4*g*dp*(rhos-rhog))/(3*(ut**2)*rhog)
delta = abs(Cd - Cdd)
if delta < dn:
continue
# print(sp,Cd,Cdd,Re,ut,delta)
print(sp,ut,Cd,Cdd)