qroot.h

来自「经典numerical receip 配套代码」· C头文件 代码 · 共 30 行

H
30
字号
void qroot(VecDoub_I &p, Doub &b, Doub &c, const Doub eps)
{
	const Int ITMAX=20;
	const Doub TINY=1.0e-14;
	Doub sc,sb,s,rc,rb,r,dv,delc,delb;
	Int n=p.size()-1;
	VecDoub d(3),q(n+1),qq(n+1),rem(n+1);
	d[2]=1.0;
	for (Int iter=0;iter<ITMAX;iter++) {
		d[1]=b;
		d[0]=c;
		poldiv(p,d,q,rem);
		s=rem[0];
		r=rem[1];
		poldiv(q,d,qq,rem);
		sb = -c*(rc = -rem[1]);
		rb = -b*rc+(sc = -rem[0]);
		dv=1.0/(sb*rc-sc*rb);
		delb=(r*sc-s*rc)*dv;
		delc=(-r*sb+s*rb)*dv;
		b += (delb=(r*sc-s*rc)*dv);
		c += (delc=(-r*sb+s*rb)*dv);
		if ((abs(delb) <= eps*abs(b) || abs(b) < TINY)
			&& (abs(delc) <= eps*abs(c) || abs(c) < TINY)) {
			return;
		}
	}
	throw("Too many iterations in routine qroot");
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?