1. Introduction
install.packages("explainer")#install.packages("devtools")devtools::install_github("PERSIMUNE/explainer")
library(explainer)library(mlr3verse)library(dplyr)
df <- read.csv("boston.csv")
tk <- as_task_regr(df,target="medv") # Set tasksp <- partition(tk) # Data splittingmod <- lrn("regr.lightgbm") # Set modelsmod$train(tk,sp$train) # Model trainingmod$predict(tk,sp$test) # Prediction
SHAP_output <- eSHAP_plot_reg( task = tk, trained_model = mod, splits = sp, seed = 1)
SHAP_output[[1]] # Interactive Shapley summary
data:image/s3,"s3://crabby-images/c0cf1/c0cf12ebebbf5fa4b9b97d397940fcf782c8dfaf" alt="Understanding Machine Learning Model Explanations with R"
regressmdl_eval_results <- regressmdl_eval( task = tk, trained_model = mod, splits = sp)
# Resultsregressmdl_eval_results
MSE RMSE MAE R_squared1 13.56915 3.683633 2.396991 0.8222139
data("BreastCancer", package = "mlbench")BC <- BreastCancer[, -1] %>% na.omit()
tk_class <- as_task_classif(BC,target="Class")sp_class <- partition(tk_class)mod_class <- lrn("classif.catboost",predict_type="prob")mod_class$train(tk_class,sp_class$train)mod_class$predict(tk_class,sp_class$test)
confusionmatrix_plot <- eCM_plot( task = tk_class, trained_model = mod_class, splits = sp_class)
confusionmatrix_plot$train_set
data:image/s3,"s3://crabby-images/8a843/8a8433f6f89dd45241105077085bfd1695538177" alt="Understanding Machine Learning Model Explanations with R"
confusionmatrix_plot$test_set
data:image/s3,"s3://crabby-images/8fbca/8fbca3c4b239cb74b91bc1950b0f733e9844518a" alt="Understanding Machine Learning Model Explanations with R"
eDecisionCurve( task = tk_class, trained_model = mod_class, splits = sp_class, seed = 1)
data:image/s3,"s3://crabby-images/c3f65/c3f657968dfc7334a475c977df5c621470eaa77a" alt="Understanding Machine Learning Model Explanations with R"
eROC_plot( task = tk_class, trained_model = mod_class, splits = sp_class)
data:image/s3,"s3://crabby-images/518fb/518fb8c458bb4d0df3bd64a9cec5d622387fea65" alt="Understanding Machine Learning Model Explanations with R"
ePerformance( task = tk_class, trained_model = mod_class, splits = sp_class)
data:image/s3,"s3://crabby-images/b2c33/b2c332cbfe52717cadc59042d727e7b313865293" alt="Understanding Machine Learning Model Explanations with R"
SHAP_output <- eSHAP_plot( task = tk_class, trained_model = mod_class, splits = sp_class, sample.size = 30, seed = 1, subset = .8)
SHAP_output[[1]]
data:image/s3,"s3://crabby-images/3dd27/3dd2703ed6902463a82d665a936d75a936355f16" alt="Understanding Machine Learning Model Explanations with R"
shap_Mean_wide <- SHAP_output[[2]]shap_Mean_long <- SHAP_output[[3]]shap <- SHAP_output[[4]]
ShapFeaturePlot(shap_Mean_long)
data:image/s3,"s3://crabby-images/95d45/95d4568dd97ecb0814baf47405afef83fe69687b" alt="Understanding Machine Learning Model Explanations with R"
ShapPartialPlot(shap_Mean_long = shap_Mean_long)
data:image/s3,"s3://crabby-images/e88e7/e88e716c79cb2a06ccbb9355d97b701075c97d34" alt="Understanding Machine Learning Model Explanations with R"
SHAP_plot_clusters <- SHAPclust( task = tk_class, trained_model = mod_class, splits = sp_class, shap_Mean_wide = shap_Mean_wide, shap_Mean_long = shap_Mean_long, num_of_clusters = 4, seed = 1, subset = .8)
SHAP_plot_clusters[[1]]
data:image/s3,"s3://crabby-images/7be68/7be684be6ca4702f02c424019dbb0ea42e415d10" alt="Understanding Machine Learning Model Explanations with R"