Skip to content

Latest commit

 

History

History
61 lines (36 loc) · 4.75 KB

README.md

File metadata and controls

61 lines (36 loc) · 4.75 KB

Build Status

mlrPlayground

Quickstart:

Use this link: https://sebastian-gruber.shinyapps.io/mlrPlayground/

Or:

Install the package in R with devtools::install_github("SebGruber1996/mlrPlayground") and execute mlrPlayground::start().

Introduction

The mlrPlayground is an interactive web application allowing the user to explore different kinds of machine learning datasets on predefined, but miscellaneous and customizable toy datasets in the domain of classification and regression. Information about the performance of each learner is given reactively in the form of prediction planes/lines, an high amount of different measures, a learning curve and an ROC plot. Additionally the hyperparameters of each learner can be changed to observe the change learner behaviour. In general the app is designed to work fully in real time, meaning every button acts as a trigger for an action. This improves the user experience hugely in most cases, but only if the dataset size is chosen appropriately based on the running machines performance. Plotting probabilities instead of classes also has a negative effect on the latter.

Select predefined (but tunable) tasks:

Select learner and its hyperparameters to view prediction plane:

Screenshot

Compare different learners:

Screenshot

View learning curve and ROC plot:

Screenshot

About the learner.config file (only for advanced users):

The file is located in inst/mlrPlayground and offers highy adaptability for the learners and its hyperparameters. Stuff you can define in there:

  • learners selectable in the UI (or remove already selectable learners; but don't forget to adjust unit tests in this case)
  • hyperparameter names
  • hyperparameter default min/max values for the sliders
  • hyperparameter default values
  • your own tooltips for the hyperparameters
  • removing specific hyperparameters from the UI Examples and an indepth description of how to do all this is located in the first section in learner.config.

About the R6 class system (only for developers):

Every learning process is considered as a class. Currently there are 6 classes. The base class is called "LearningProcess" and is meant as a base scheme with all required methods listed for all the other classes. The currently working classes are "ClassifLearningProcess" and "RegrLearningProcess". Besides these "Classif3dLearningProcess", "Regr3dLearningProcess" are not fully implemented and "ClusterLearningProcess" is implemented, but not working right now. All the plots should now be defined in each class, so tasks/datasets in the same class have the SAME predictions and plots. This hopefully makes everything a lot clearer and more uniform. The methods for these plots are already named and called everywhere ("getDataPlot" and "getPredPlot"), so no further methods should be introduced. Every plot should be defined in one of these methods in each class respectively. So whenever a plot is changed, only adapt the class, not any code anywhere else. To make the method "getPredPlot" work, one also has to implement the method "calculateResample", which basically calculates the model, the measures on the test set and the predictions of a bounded set of equidistant (and predefined) points. When defining methods, ALWAYS use isolate on reactive values. Otherwise calling the method elsewhere may lead to highly unintended behaviour, like infinite update loops or triggered observers in some totally different place - basically stuff making debugging feel totally like hell.

About unit tests (only for developers):

Because all the app files have to be placed in the inst/mlrPlayground folder, unit tests can't be written for functions (and especially the R6 classes) defined there. Also the package shinytest meant for "interactive UI" testing seems to not work - every new execution of the same test suddenly changes some value in the overall state, thus throwing a test error. Fortunately a different way was found to still do some potent testing. shinytest allows to start the app, set input values and catch output values in a script without visiting the app. The current unit tests simply set the input to all different kinds of tasks and learners and checks if the dataset/prediction plot json data changed compared to the last input (this way we can make sure the plots are actually updated with the input instead of guessing that "not NULL" as a output condition for the plot may actually be enough).