我试图在 python2.7 中计算比特币的指数移动平均值,但我的结果总是相同的值,我不知道为什么。
def calcSMA(data,counter,timeframe):
closesum = 0
for i in range(timeframe):
closesum = float(closesum) + float(data[counter-i])
return float(closesum / timeframe)
def calcEMA(price,timeframe,prevema):
multiplier = float(2/(timeframe+1))
ema = ((float(price) - float(prevema))*multiplier) + float(prevema)
return float(ema)
counter = 0
closeprice = [7242.4,7240,7242.8,7253.8,7250.6,7255.7,7254.9,7251.4,7234.3,7237.4
,7240.7,7232,7230.2,7232.2,7236.1,7230.5,7230.5,7230.4,7236.4]
while counter < len(closeprice):
if counter == 3:
movingaverage = calcSMA(closeprice,counter,3)
print movingaverage
if counter > 3:
movingaverage = calcEMA(closeprice[counter],3,movingaverage)
print movingaverage
counter +=1
这是计算 EMA 的方法:{Close - EMA(previous day)} x multiplier + EMA(previous day) 你用一个简单的移动平均线作为公式的种子。
在 Excel 中执行此操作是否可行,因此可能是我使用了变量?
如果有人能告诉我我做错了什么,我真的很高兴,因为我在这个简单的问题上失败了几个小时并且无法弄清楚我已经尝试将我以前的 ema 存储在一个单独的变量中,我什至存储了所有它们在一个列表中,但我总是在每个时间步得到相同的值。
该表达式2/(timeframe+1)
始终为零,因为组件都是整数,因此 Python 2 使用整数除法。将结果包装在float()
没有好处;你只是得到0.0
而不是0
.
试试吧2.0/(timeframe+1)
。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句