我有一个非常详细的while循环,并已真正抵制不得不再次寻求帮助,但我很茫然!对于这个while循环代码,我真的很抱歉,有很多事情要做,但我不想留下任何东西,以防万一观众需要看到这一切。我在Swift中的while循环不会终止,我错过了什么?
func retRhoCurrent() -> Double {
while abs(pTarget - pCalc) > 1 {
//
// SET rhoCurrent
//
if (pTarget > pCalc) {
rhoLow = rhoCurrent
if(rhoCurrent >= rhoHigh) {
rhoCurrent += RHO_C
rhoHigh = rhoCurrent
} else {
rhoCurrent += ((rhoHigh - rhoCurrent)/2)
}
} else {
rhoHigh = rhoCurrent
rhoCurrent += ((rhoLow - rhoCurrent)/2)
}
//
// SET rhoR
//
rhoR = rhoCurrent/RHO_C
//
// SET DIFFERENTIAL
//
diffAggregate = 0
for var kIndex = 0; kIndex < NK_VALUES.count; ++kIndex {
diffSegment = NK_VALUES[kIndex]
diffSegment *= pow(rhoR, IK_VALUES[kIndex])
diffSegment *= pow(tempR, JK_VALUES[kIndex])
iFactor = 0
if LK_VALUES[kIndex] > 0 {
diffSegment *= exp(-1 * pow(rhoR, LK_VALUES[kIndex]))
iFactor = LK_VALUES[kIndex] * pow(rhoR, LK_VALUES[kIndex])
}
if PK_VALUES[kIndex] > 0 {
diffSegment *= exp(-1 * PK_VALUES[kIndex] * pow(rhoR, 2) - BK_VALUES[kIndex] * pow(tempR - UK_VALUES[kIndex], 2))
iFactor = 2 * rhoR * PK_VALUES[kIndex] * (rhoR - 1)
}
diffAggregate += (diffSegment * (IK_VALUES[kIndex] - iFactor))
}
//
// SET pCalc
//
zDiff + 1 + diffAggregate
pCalc = zDiff * R_CONST * 1000 * tempK * rhoCurrent
}
return rhoCurrent
}
我想另一个问题,我也就是主要价值我想出来这个while循环的是rhoCurrent(我会用这最后#计算别的东西)。做“返回rhoCurrent”将工作,更正?
非常感谢!
几个快速评论:1)你在哪里设置pTarget值? 2)似乎这比编程问题更关于算法。也许输出值会帮助你看看它是否如你所期望的那样收敛,或者你有一个合乎逻辑的问题... – Rusty30 2015-02-24 18:35:15
你预期会发生什么,以及你观察到了什么? “pTarget”的典型值是什么?当循环迭代时,'pCalc'接近该值吗? – Caleb 2015-02-24 18:51:58