var x = a2 || a1;

再看看实际的应用:
 
function test(a1,a2){
var x = a2 || a1;
//var x = a2===undefined ? a1 : a2;
alert(x);
}
test("abc");
test("abc","def");
第一次执行 test 时只传了一个参数,因此在 test 内部获取的 a2 恒等于 undefined,即类型属于false,或运算将继续执行双 竖线右边的表达式 a1 ,a1的值为字符串"abc",不是false,因此或运算表达式返回 "abc" 并赋值给 x。

对于此类型的表达方法 a2 || a1 可以这样理解:优先取 a2, a1 排后。按这样的理解,看看下面的:
function test(a1,a2,a3,a4,a5){
  var x = a5 || a4 || a3 || a2 || a1;
  alert(x);
}
test("abc","def","ghi");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
解释 int nSize = pdPoints.size(); if (nSize < 3) { return; } vector<double>vdX; vector<double>vdY; double dMeanX = 0, dMeanY = 0; for (Point2d p : pdPoints) { vdX.push_back(p.x); vdY.push_back(p.y); dMeanX += p.x; dMeanY += p.y; } dMeanX /= (nSize * 1.); dMeanY /= (nSize * 1.); double Xi = 0, Yi = 0, Zi = 0; double Mz = 0, Mxy = 0, Mxx = 0, Myy = 0, Mxz = 0, Myz = 0, Mzz = 0, Cov_xy = 0, Var_z=0; double A0 = 0, A1 = 0, A2 = 0, A22 = 0; double Dy = 0, xnew = 0, x = 0, ynew = 0, y = 0; double DET = 0, Xcenter = 0, Ycenter = 0; for (int i = 0; i < nSize; i++) { Xi = vdX[i] - dMeanX; // centered x-coordinates Yi = vdY[i] - dMeanY; // centered y-coordinates Zi = Xi * Xi + Yi * Yi; Mxy += Xi * Yi; Mxx += Xi * Xi; Myy += Yi * Yi; Mxz += Xi * Zi; Myz += Yi * Zi; Mzz += Zi * Zi; } Mxx /= (nSize * 1.); Myy /= (nSize * 1.); Mxy /= (nSize * 1.); Mxz /= (nSize * 1.); Myz /= (nSize * 1.); Mzz /= (nSize * 1.); Mz = Mxx + Myy; Cov_xy = Mxx * Myy - Mxy * Mxy; Var_z = Mzz - Mz * Mz; A2 = 4.0 * Cov_xy - 3.0 * Mz * Mz - Mzz; A1 = Var_z * Mz + 4.0 * Cov_xy * Mz - Mxz * Mxz - Myz * Myz; A0 = Mxz * (Mxz * Myy - Myz * Mxy) + Myz * (Myz * Mxx - Mxz * Mxy) - Var_z * Cov_xy; A22 = A2 + A2; // finding the root of the characteristic polynomial // using Newton's method starting at x=0 // (it is guaranteed to converge to the right root) x = 0., y = A0; for (int i = 0; i < 99; i++) // usually, 4-6 iterations are enough { Dy = A1 + x * (A22 + 16. * x * x); xnew = x - y / Dy; if ((xnew == x) || (!isfinite(xnew))) { break; } ynew = A0 + xnew * (A1 + xnew * (A2 + 4.0 * xnew * xnew)); if (abs(ynew) >= abs(y)) { break; } x = xnew; y = ynew; } DET = x * x - x * Mz + Cov_xy; Xcenter = (Mxz * (Myy - x) - Myz * Mxy) / DET / 2.0; Ycenter = (Myz * (Mxx - x) - Mxz * Mxy) / DET / 2.0; dRadius = sqrt(Xcenter * Xcenter + Ycenter * Ycenter + Mz - x - x); pdCenter = Point2d(Xcenter + dMeanX, Ycenter + dMeanY);
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值