これは、1ページのグラムシュミットを実行するためのMATLABコードです http://web.mit.edu/18.06/www/Essays/gramschmidtmat.pdf
私はMATLABを持っていないので、Rでこれを実行するために何時間も何時間も試みていますこれが私のRです
f=function(x){
m=nrow(x);
n=ncol(x);
Q=matrix(0,m,n);
R=matrix(0,n,n);
for(j in 1:n){
v=x[,j,drop=FALSE];
for(i in 1:j-1){
R[i,j]=t(Q[,i,drop=FALSE])%*%x[,j,drop=FALSE];
v=v-R[i,j]%*%Q[,i,drop=FALSE]
}
R[j,j]=max(svd(v)$d);
Q[,j,,drop=FALSE]=v/R[j,j]}
return(list(Q,R))}
それはどちらかにエラーがあると言い続けます:
v=v-R[i,j]%*%Q[,i,drop=FALSE]
また
R[j,j]=max(svd(v)$d);
MATLABコードをRに間違って変換しているのは何ですか?