📄 dettriangular.mata
字号:
*! version 1.0.1 19jan2005
version 9.0
mata:
numeric scalar dettriangular(numeric matrix A)
{
real scalar i, n
numeric vector v
numeric scalar zum
real scalar sum, z, sgn
if ((n=rows(A)) != cols(A)) _error(3205)
if (n==0) return(iscomplex(A) ? C(1) : 1)
v = diagonal(A)
if (missing(v)) return(iscomplex(A) ? C(.) : .)
if (anyof(v, 0)) return(iscomplex(A) ? 0i : 0)
if (iscomplex(A)) {
sum = 0i
for (i=1; i<=n; i++) sum = sum + ln(v[i])
return(exp(sum))
}
sum = 0
for(sgn=i=1; i<=n; i++) {
if ((z=v[i])<0) {
z = -z ;
sgn = -sgn ;
}
sum = sum + ln(z)
}
return(sgn*exp(sum))
}
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -