我写了一个简单的Python代码来解决某个水力公式(Manning's equation):
import math
def mannings(units,A,P,S,n):
if units=='SI':
k=1.0
elif units=='US':
k=1.49
R=A/P
V=(k/n)*(math.pow(R,(2/3)))*(math.sqrt(S))
Q=A*V
return R,V,Q
在上面的代码中,速度V
是根据k
,n
,R
和S
计算得出的。然后使用速度通过乘以区域Q
来计算放电A
。用户输入单位约定,A
,P
,S
和n
。 k
是根据单位惯例决定的。
当我使用mannings('US',1.0618,2.7916,0.02,0.015)
运行该功能时,我得到(0.38035535176959456, 14.047854719572745, 14.916012141242343)
。 R
值与电子表格中计算的R
相匹配,但V
和Q
之间的距离很远。实际的V
应为7.374638178
Q
应为7.830634155
。
如果有人能告诉我这里出了什么问题,那就太好了。这是一个非常简单的公式,我猜它应该很容易。
答案 0 :(得分:14)
您的问题是2/3
是整数除法,因此评估为0
。您希望2.0/3
强制进行浮点除法。或者在文件顶部包含from __future__ import division
以使用Python 2.x中的Python 3样式除法。
假设您没有使用__future__
解决方案,您还需要将R = A / P
写为例如R = float(A) / P
。 A
因为否则,如果P
和R
都是整数,{{1}}也将是整数。