プレイグラウンドでこれを試みると:
func StockEvolution(S_0:Double, _ down:Double, _ up:Double, _ totalsteps:Int, _ upsteps:Int) -> Double // function being used in calcCall()
{
var S_t:Double = S_0 * pow(up, Double(upsteps)) * pow(down, Double(totalsteps - upsteps))
return S_t
}
func CallPayoff(S:Double, _ K:Double) -> Double // function being used in calcCall()
{
return max(S - K, 0.0)
}
func calcCall(S_0:Double, _ down:Double, _ up:Double, _ r:Double, _ steps:Int, _ K:Double) -> Double //calculate Call-Option
{
var prices = [Double]()
var q = 0.6 //risk-neutral probability factor
var i = 0
while i < steps
{
var payOff = CallPayoff(StockEvolution(S_0, down, up, steps, i), K)
prices.append(payOff)
i += 1
}
var n = steps - 1
while n >= 0
{
var j = 0
while j <= n
{
var value = (1 / r) * (prices[j + 1] * q + (1 - q) * prices[j])
prices.removeAtIndex(j)
prices.insert(value, atIndex: j)
j += 1
}
n -= 1
}
return prices[0]
}
これを行うことにより:
var checkPrice = calcCall(100, 0.6, 1.5, 1.05, 10, 200)
それは私にこのエラーを与えます:
実行が中断されました。理由: EXC_BAD_INSTRUCTION (コード=EXC_I386_INVOP、サブコード=0x0)
コードにバグが見つからないようです。さまざまな入力値で試しましたが、それでもエラーが発生します。
私のコードを見て、この問題を解決するのを手伝っていただければ幸いです。ご尽力いただきありがとうございます。