如下,这是一个模拟退火的模板。
inline void sa(){
double t=3000;
while(t>1e-15){
int v=value(), d=v-ans;
if(d<0) ans=v;
else if(exp(d/t)*RAND_MAX>rand())
t*=down;
}
}
但是对于 if(exp(d/t)*RAND_MAX>rand()),这里的 d,有些时候是 -d。
现在请教一下各位神仙,什么时候需要用 d,什么时候需要 -d。
或者给一下经验。
谢谢。