JuliaSetup <- function(add_cores = 1, remove_cores = FALSE, libraries = FALSE) {
if(!julia_exists("ref_dif_s")) {
if(libraries) {
withProgress(message = 'Loading analytical environment', detail = '', value = 0, min=0, max=9, {
julia <- JuliaCall::julia_setup(install=TRUE) #Set to false after deploying to shiny-server for startup speed
pkg = c("Pkg","Statistics", "Distributed","SharedArrays", "Optim", "Rmath", "GLM", "NearestNeighbors", "Dates", "DelimitedFiles", "LinearAlgebra", "MultivariateStats", "Printf", "StatsBase")
for(i in pkg) {
incProgress(amount = 1, message = paste("Loading ", i, " library", sep=""))
print(paste("Loading Julia package: ", i, sep=""))
julia_install_package_if_needed(i)
JuliaCall::julia_library(i)
}
incProgress(amount = 1, message = "Importing source code")
julia_source(system.file("jl", "cores.jl", package = "OsteoSort"))
julia_source(system.file("jl", "t_test_plot.jl", package = "OsteoSort"))
julia_source(system.file("jl", "t_test.jl", package = "OsteoSort"))
julia_source(system.file("jl", "yeojohnson.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression.jl", package = "OsteoSort"))
julia_source(system.file("jl", "antemortem.jl", package = "OsteoSort"))
julia_source(system.file("jl", "z_test.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression_plot.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression_helpers.jl", package = "OsteoSort"))
julia_source(system.file("jl", "radius_search.jl", package = "OsteoSort"))
julia_source(system.file("jl", "knn_ind_dst.jl", package = "OsteoSort"))
julia_source(system.file("jl", "point_to_plane.jl", package = "OsteoSort"))
julia_source(system.file("jl", "point_to_point.jl", package = "OsteoSort"))
julia_source(system.file("jl", "fragment_landmarks.jl", package = "OsteoSort"))
julia_source(system.file("jl", "alignment_landmarks.jl", package = "OsteoSort"))
julia_source(system.file("jl", "icp.jl", package = "OsteoSort"))
})
}
}
jcores <- julia_call("nprocs")
if(add_cores > jcores) {
sycores <- detectCores()
if(add_cores > jcores && add_cores <= sycores) {
julia_call("add_cores", add_cores - jcores)
}
if(add_cores < jcores) {
julia_call("clean_cores")
julia_call("add_cores", add_cores-1)
}
if(remove_cores) {
julia_call("clean_cores")
}
julia_source(system.file("jl", "library.jl", package = "OsteoSort"))
julia_source(system.file("jl", "t_test.jl", package = "OsteoSort"))
julia_source(system.file("jl", "t_test_plot.jl", package = "OsteoSort"))
julia_source(system.file("jl", "yeojohnson.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression.jl", package = "OsteoSort"))
julia_source(system.file("jl", "antemortem.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression_plot.jl", package = "OsteoSort"))
julia_source(system.file("jl", "regression_helpers.jl", package = "OsteoSort"))
julia_source(system.file("jl", "z_test.jl", package = "OsteoSort"))
julia_source(system.file("jl", "knn_ind_dst.jl", package = "OsteoSort"))
julia_source(system.file("jl", "point_to_plane.jl", package = "OsteoSort"))
julia_source(system.file("jl", "point_to_point.jl", package = "OsteoSort"))
julia_source(system.file("jl", "fragment_landmarks.jl", package = "OsteoSort"))
julia_source(system.file("jl", "alignment_landmarks.jl", package = "OsteoSort"))
julia_source(system.file("jl", "icp.jl", package = "OsteoSort"))
print(paste("Source code loaded on ", julia_call("nprocs"), " cores", sep=""))
}
JV <- JuliaCall:::julia_line(c("-e", "print(VERSION)"), stdout=TRUE)
return(JV)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.