Welcome to the Splunk Machine Learning Toolkit
The Splunk Machine Learning Toolkit (MLTK) is an app available for both Splunk Enterprise and Splunk Cloud Platform users through Splunkbase. The Splunk Machine Learning Toolkit acts like an extension to the Splunk platform and includes machine learning Search Processing Language (SPL) search commands, macros, and visualizations.
On top of the platform extensions meant for machine learning, MLTK has guided modeling dashboards called Assistants. Assistants walk you through the process of performing particular analytics.
The Splunk Machine Learning Toolkit is not a default solution, but a way to create custom machine learning. You must have have domain knowledge, SPL knowledge, Splunk platform experience, and data science skills or experience to be successful using MLTK.
Types of machine learning
Machine learning is a process for generalizing from examples. You can use these generalizations, typically called models, to perform a variety of tasks, such as predicting the value of a field, forecasting future values, identifying patterns in data, and detecting anomalies from new data. Without data and correct examples, it is difficult for machine learning to work at all.
The machine learning process starts with a question. You might ask one of these questions:
- Am I being hacked?
- How hot are the servers?
- How many visits to my site do I expect in the next hour?
- What is the price range of houses in a particular neighborhood?
There are different types of machine learning, including:
Regression modeling predicts a number from a variety of contributing factors. Regression is a predictive analytic. For example, you might have utilization metrics on a machine, such as CPU percentage and amount of disk reads and writes. You can use regression modeling to predict the amount of power that that machine is likely to draw both now and in the future.
... | fit DecisionTreeRegressor temperature from date_month date_hour into temperature_model
Classification modeling predicts a category or a class from a number of contributing factors. Classification is a predictive analytic. For example, you might have data on user behavior on a website or within a software product. You can use classification modeling to predict whether that customer is going to churn.
... | fit RandomForestClassifier SLA_violation from * into sla_model
Forecasting is a predictive analytic that predicts the future of a single value moving through time. Forecasting looks at past measurements for a single value, like profit per day or CPU usage per minute, to predict future values. For example, you might have sales results by quarter for the past 5 years. Use forecast modeling to predict sales for the upcoming quarter.
... | fit ARIMA Voltage order=4-0-1 holdback=10 forecast_k=10
Clustering groups similar points of data together. For example, you might want to group customers together based on their buying behaviors, such as how much they tend to spend or how many items they buy at one time. Use cluster modeling to group together the features you specify.
... | fit XMeans * | stats count by cluster
Anomaly detection finds outliers in your data by computing an expectation based on one of the machine learning types, comparing it with reality, and triggering an alert when the discrepancies between the two values is large.
... | fit OneClassSVM * kernel="poly" nu=0.5 coef0=0.5 gamma=0.5 tol=1 degree=3 shrinking=f into Model_Name
How MLTK fits into the Splunk platform
Different machine learning options exist in the Splunk platform.
- Core Platform Search: The Splunk platform has machine learning capabilities integrated in the SPL.
- Packaged Premium Solutions: Solutions including IT Service Intelligence (ITSI), Splunk Enterprise Security, and Splunk User Behavior Analytics offer managed machine learning options.
- Splunk Machine Learning Toolkit: The Splunk Machine Learning Toolkit is an app in the Splunkbase ecosystem that allows you to build custom machine learning solutions for any use case.
The machine learning process
Machine learning is a process for generalizing from examples. Ideally, the machine learning process follows a series of steps, beginning collecting data and ending with deploying your machine learning model.
- Collect available data like CPU percentages, memory utilization, server temperatures, disk space, or sales values.
- Clean and transform that data. All machine learning expects a matrix of numbers as input. If you're collecting data that is missing values, then you need to clean and transform that data until it's in the form machine learning requires.
- Explore and visualize the data to make sure it is encoding what you expect it to encode.
- Build a model on training data.
- Evaluate the model test data.
- Deploy the model on un-seen data.
The machine learning process follows those steps in theory, but in practice it's rarely linear:
You might evaluate your model, discover the performance is not generating the results your expect, and go back to further clean and transform the data. Maybe the data has too many missing values, lacks completeness, is improperly weighted, or has unit disagreement. Iterate around the machine learning process until the model is providing desired machine learning outcomes.
The machine learning process is potentially time consuming and could mean a need for different tools, different team members, and context switching. But with the Splunk Machine Learning Toolkit, this entire process, from ingesting the data to building reports, can all occur inside the Splunk platform.
Layers that make up the Splunk Machine Learning Toolkit
The Splunk Machine Learning Toolkit is comprised of several layers, each of which aid in the process of building a generalization from your data.
Python for Scientific Computing Library
Access to over 300 open source algorithms.
MLTK is built on top of the Python for Scientific Computing Library. This ecosystem includes the most popular machine learning library called sci-kit learn, as well as other supporting libraries like NumPy and Statsmodels.
Extensibility to easily support any algorithm, whether proprietary or open source.
MLTK includes access to an extensibility API that not only allows you to expose the 300+ algorithms from the Python app, but also custom algorithms you can write yourself. You can share and reuse your own custom algorithms in the Splunk Community for MLTK on GitHub.
New SPL commands to fit, test, score, and operationalize models.
MLTK uses the PSC app to expose new SPL commands that let you do machine learning. These are SPL commands for building (fit), testing (apply), and validating (score) models and more.
Over 30 standard algorithms to accommodate both supervised and unsupervised learning.
The SPL commands expose different algorithms. There are more than 30 standard algorithms, which are the most commonly used machine learning algorithms.
Interactive examples for typical IT, security, business, and IoT use cases.
MLTK includes many interactive examples from different domains like IoT and business analytics. This is called the Showcase. The Showcase is the initial page you land on when you open MLTK, where you see different examples from end-to-end.
Experiments and Assistants
Guided model building, model testing, and deployment for common objectives.
On top of the tools included for machine learning are guided modeling dashboards called Assistants. Built on an Experiment Management Framework (EMF), Assistants offer a walk-through interface of the process for performing particular analytics with your own data. Smart Assistants and Experiment Assistants bring all aspects of a monitored machine learning pipeline into one interface, with automated model versioning and lineage.
What is included in MLTK
MLTK includes several platform extensions. This includes a set of macros that allow you to compute validation statistics as well as a set of custom visualizations. The Machine Learning Toolkit provides the key commands of
fitbuilds the generalization or model
applylets you use that generalization later
- splitby (1-5)
- 3D Scatterplot
- Boxplot Chart
- Distribution Plot
- Downsampled Line Chart
- Forecast Chart
- Heatmap Plot
- Histogram Chart
- Outliers Chart
- Scatter Line Chart
- Scatterplot Matrix
Other commands, including
deletemodel, manage or inspect the models you've created. MLTK also offers the
sample command that lets you take random partitions of your data. The
score command is available to run statistical tests to validate model outcomes.
To learn more about the
apply commands, see Understanding the fit and apply commands.
To learn more about the
score command see, Using the score command.
To learn more about the available visualizations, see Custom visualizations in the Machine Learning Toolkit.
Introduction to the Assistants
The Assistants guide you through the process of performing an analytic in MLTK. Assistants use all tools and extensions, including both SPL and ML-SPL. You can click the button labeled SPL in any Smart Assistant, or the button labeled Show SPL in any Experiment Assistant to see the underlying SPL.
The underlying SPL can also be viewed in a new window using the pop-out button.
The Assistants walk you through the entire machine learning process including:
- Preparing your data
- Building the model
- Validating the model
- Deploying the model
Each type of machine learning has an accompanying Assistant:
|Type of machine learning||Assistant|
|Regression||Predict Numeric Fields Experiment Assistant
Smart Prediction Assistant
|Classification||Predict Categorical Fields Experiment Assistant
Smart Prediction Assistant
|Anomaly detection||Detect Numeric Outliers Experiment Assistant
Detect Categorical Outliers Experiment Assistant
|Forecasting||Forecast Time Series Experiment Assistant
Smart Forecasting Assistant
|Clustering||Cluster Numeric Events Experiment Assistant
Smart Clustering Assistant
To learn more about the variety of Assistants within the Splunk Machine Learning Toolkit, see MLTK guided workflows.
Continue learning about MLTK by working through this user guide or through the following links:
- To learn about companion apps, cheat-sheets, videos, and courses see Learn more about the Splunk Machine Learning Toolkit.
- To learn about installing MLTK, see Install the Splunk Machine Learning Toolkit.
- To see the Assistants in action using pre-populated use cases, see the Showcase examples.
- To learn about further support for MLTK, see the Support for the Splunk Machine Learning Toolkit.
About the Splunk Machine Learning Toolkit
What is the MLTK process?
This documentation applies to the following versions of Splunk® Machine Learning Toolkit: 5.3.3, 5.4.0, 5.4.1