0
我是一名Python初學者,我試圖使用相同的Excel求解器邏輯來儘量減少此功能,但我無法做到這一點。你能幫我麼?Python優化最小化如何?
我希望儘量減少功能如下:
from datetime import date
import numpy as np
def nelsonsiegel(Beta0,Beta1,Beta2,Beta3,Lambda1,Lambda2):
SettleDate = date(2017,07,14)
Bond1MaturityDate = date(2018,7,13)
Bond3MaturityDate = date(2020,2,17)
Bond5MaturityDate = date(2022,7,21)
Bond10MaturityDate = date(2027,1,20)
Bond15MaturityDate = date(2031,9,16)
Bond20MaturityDate = date(2037,3,17)
Yearfraction = [float((Bond1MaturityDate-SettleDate).days)/365,float((Bond3MaturityDate-SettleDate).days)/365, float((Bond5MaturityDate-SettleDate).days)/365, float((Bond10MaturityDate-SettleDate).days)/365, float((Bond15MaturityDate-SettleDate).days)/365, float((Bond20MaturityDate-SettleDate).days)/365]
CouponRate = [0,0.0290,0.0321,0.0494,0.0585,0.0624]
BondPrices = [0.97863,0.99745,0.9968, 0.99922,0.98724,0.96679 ]
NS = []
df = []
rst = []
NSS = []
NegM = []
for i in range(len(Yearfraction)):
NelsonSiegel = Beta0 + (Beta1 * ((1-np.exp(-Yearfraction[i]/Lambda1)/Yearfraction[i]*Lambda1))) + (Beta2 * ((((1-np.exp(-Yearfraction[i]/Lambda1))/(Yearfraction[i]*Lambda1))) - (np.exp(-Yearfraction[i]/Lambda1)))) + (Beta3 * ((((1-np.exp(-Yearfraction[i]/Lambda2))/(Yearfraction[i]*Lambda2))) - (np.exp(-Yearfraction[i]/Lambda2))))
NS.append(NelsonSiegel)
discountfactor = np.exp(-Yearfraction[i]*NS[i])
df.append(discountfactor)
if i < 6:
result = (1 + CouponRate[i])* df[i]
m = Yearfraction[i] - 1
if m < 0:
rst.append(result)
while m > 0:
NelsonSiegelCpnRe = Beta0 + (Beta1 * ((1-np.exp(-m/Lambda1)/m*Lambda1))) + (Beta2 * ((((1-np.exp(-m/Lambda1))/(m*Lambda1))) - (np.exp(-m/Lambda1)))) + (Beta3 * ((((1-np.exp(-m/Lambda2))/(m*Lambda2))) - (np.exp(-m/Lambda2))))
result = result + (CouponRate[i] * np.exp(-m*NelsonSiegelCpnRe))
NSS.append(NelsonSiegelCpnRe)
m = m -1
if m <0:
rst.append(result)
a = np.array(rst)
Spread = (BondPrices - a)**2
#SpreadtoMinimize = sum(Spread)
return sum(Spread)
通常它返回一個總和。這個總和應該通過在Beta0,Beta1,Beta2,BEta3,Lambda1,Lambda2上進行最小化。 Beta0直到Beta3的限制應該是這些變量可以在-1和1之間振盪.Lambda1和Lambda2沒有限制。
你知道如何編寫代碼來執行該任務嗎? 謝謝 SB
PS:我執行與這些參數的函數:nelsonsiegel(0.01,0.01,0.01,0.01,1,1)
非常感謝胡安,我會努力解答你給了。 – Sitingbull