write_aligned_files <-
function(ds, ga, input_dir, output_dir, scale){
#rotate the individual raw files. Use the rotation matrices from global alignment.
for (kk in 1: ds$n){
mesh_fn = file.path(input_dir, ds$ids[kk])
mesh_fn_type = substring(tolower(mesh_fn), nchar(mesh_fn)-3, nchar(mesh_fn))
if(mesh_fn_type == ".off"){
VF = read_off(mesh_fn)
}else if(mesh_fn_type == ".ply"){
VF = read_ply(mesh_fn)
}else{
stop("Error. Unrecognized mesh file type.")
}
#VF = read_off(file.path(input_dir,ds$ids[kk]))
V = VF[[1]]
FF = VF[[2]]
#Scale according to highest resolution point cloud
V = V - repmat(ds$shape[[kk]]$center,1,dim(V)[2])
if(scale){
V = V / (ds$shape[[kk]]$scale / sqrt(ds$N[ds$K]) )
}
#Rotate according to ga
if (det(ga$R[[kk]]) <0){ FF = FF[c(2,1,3),]}
V = ga$R[[kk]]%*%V
write_off_path = file.path(output_dir,paste(substr(ds$ids[kk], 1, nchar(ds$ids[kk])-4),".off",sep=""))
write_off(write_off_path,V,FF,FALSE)
}
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.