Predict Categorical Fields Experiment Assistant workflow
The Predict Categorical Fields Assistant uses classification algorithms to learn the tendency for data to belong to one category or another based on related data.
The following classification table shows the actual state of the field versus predicted state of the field. The yellow bar highlights an incorrect prediction.
        
      
Available algorithms
The Predict Categorical Fields assistant uses the following classification algorithms:
Create an Experiment to predict a categorical field
Experiments bring all aspects of a monitored machine learning pipeline into one interface with automated model versioning and lineage built in. After the Experiment Assistant computes the model, use these peripheral values to make a prediction on the metric result.
Before you begin
- The Predict Categorical Fields Assistant offers the option to preprocess your data. For more information on Assistant-based preprocessing algorithms, see Preprocessing machine data using Assistants.
- MLTK default selects the Logistic Regression algorithm. Use this default if you aren't sure which algorithm is best for you. For further details on any algorithm, see Algorithms in the Machine Learning Toolkit.
Assistant workflow
Follow these steps to create a Predict Categorical Fields Experiment.
-  From the MLTK navigation bar, click Experiments. 
- If this is the first experiment in MLTK, you will land on a display screen of all six Assistants. Select the Predict Categorical Fields block.
- If you have at least one experiment in MLTK, you will land on a list view of experiments. Click the Create New Experiment button.
 
- Fill in an Experiment Title, and (optionally) add a description. Both the name and description can be edited later if needed.
- Click Create.
- Run a search and be sure to select a date range.
- (Optional) Click + Add a step to add preprocessing steps.
-  Select an algorithm from the Algorithmdrop-down menu. LogisticRegression is selected by default. Another algorithm option may better fit your Experiment.
-  Select a target field from the drop-down menu Field to Predict. When you select theField to predict, theFields to use for predictingdrop-down menu populates with available fields to include in your model.
-  Select a combination of fields from the drop-down menu Fields to use for predicting.
- Use the slider bar to split your data into training and testing data. The default split is 50/50, and the data is divided randomly into two groups.
-  (Optional) Add notes to this Experiment. Use this free form block of text to track the selections made in the Experiment parameter fields.  Refer back to notes to review which parameter combinations yield the best results.
Note: The algorithm you select determines the fields available to build your model. Hover over any field name to get more information about that field.
- Click Fit Model. The experiment is now in a Draft state. 
Draft versions allow you to alter settings without committing or overwriting a saved Experiment. An Experiment is not stored to Splunk until it is saved. 
The following table explains the differences between a draft and a saved Experiment. 
Action Draft Experiment Saved Experiment Create new record in Experiment history Yes No Run Experiment search jobs Yes No (As applicable) Save and update Experiment model No Yes (As applicable) Update all Experiment alerts No Yes (As applicable) Update Experiment scheduled trainings No Yes 
Interpret and validate results
After you fit the model, review the prediction results and visualizations to see how well the model predicted the categorical field. Results are based on your testing data. In this analysis, metrics are related to mis-classifying the field, and are based on false positives and negatives, and true positives and negatives.
This Assistant uses sklearn.metrics.precision_recall_fscore_support to calculate Precision, Recall, and F1 score. To learn more see, Precision-Recall-F1-Support. This Assistant also uses sklearn.metrics.accuracy_score to calculate Accuracy. To learn more see, Accuracy scoring.
average=weighted To learn more about these calculations, see Scoring metrics in the Machine Learning Toolkit.You can use the following methods to evaluate your predictions:
| Charts and Results | Applications | 
|---|---|
| Precision | This statistic is the percentage of the time a predicted class is the correct class. | 
| Recall | This statistic is the percentage of time that the correct class is predicted. | 
| Accuracy | This statistic is the overall percentage of correct predictions. | 
| F1 | This statistic is the the weighted average of precision and recall, based on a scale from zero to one. The closer the statistic is to one, the better the fit of the model. | 
| Classification Results (Confusion Matrix) | This table charts the number of actual results against predicted results, also known as a Confusion Matrix. The shaded diagonal numbers should be high (closer to 100%), while the other numbers should be closer to 0. | 
Refine the Experiment
After you validate your results, refine the Experimentl and run the fit command again. Optionally choose to track your changes in the Notes text field.
Consider the following options to better refine your Experiment:
-  Reduce the number of fields selected in the Fields to use for predictingdrop-down menu. Having too many fields can generate a distraction.
- Bring in new data sources to enrich your modeling space.
- Build features on raw data, model on behaviors of the data instead of raw data points, using SPL, Streamstats, or eventstats.
- Check your fields to ensure you are using categorical values correctly. For example are you using DayOfWeek as a number (0 to 6) instead of as "Monday", "Tuesday", and so forth? Make sure you have the right type of value for categorical fields.
- Bring in context via lookups - holidays, external anomalies, etc.
- Increase the number of fields (from additional data,  feature building as above, etc) selected in the Fields to use for predictingdrop-down menu.
Use the Experiment History tab to review settings and changes made as you refine the model.
Save the Experiment
Once you are getting valuable results from your Experiment, save it. Saving your Experiment results in the following actions:
- Assistant settings saved as an Experiment knowledge object.
- The Draft version saves to the Experiment Listings page.
- Any affiliated scheduled trainings and alerts update to synchronize with the search SPL and trigger conditions.
You can load a saved Experiment by clicking the Experiment name.
Deploy the Experiment
Saved predict categorical fields Experiments include options to manage and publish.
Within the Experiment framework
From within the framework, you can both manage and publish your Experiments. To manage your Experiment, perform the following steps:
- From the MLTK navigation bar, choose Experiments. A list of your saved experiments populates.
- Click the Manage button available under the Actions column.
          
        
The toolkit supports the following Experiment management options:
- Create and manage Experiment-level alerts. Choose from both Splunk platform standard trigger conditions, as well as from Machine Learning Conditions related to the Experiment.
- Edit the title and description of the Experiment.
- Schedule a training job for an Experiment.
- Delete an Experiment.
You can publish your Experiment through the following steps:
- From the MLTK navigation bar, choose Experiments. A list of saved Experiments populates.
- Click the Publish button available under the Actions column. 
Publishing an experiment model means the main model and any associated preprocessing models will be copied as lookup files in the user's namespace within a selected destination app. Published models can be used to create alerts or schedule model trainings.
Note: The Publish link will only show if you have created the experiment, and fit the model.
- Give the model a title. It must start with letter or underscore, and only have letters, numbers, and underscores in the name.
- Select the destination app.
- Click Save.
- A message will let you know whether the model has been published, or why the action was not completed.
Outside the Experiment framework
- Click Open in Search to generate a New Search tab for this same dataset. This new search opens in a new browser tab, away from the Assistant. This search query uses all data, not just the training set. You can adjust the SPL directly and see the results immediately. You can also save the query as a Report, Dashboard Panel or Alert.
- Click Show SPL to generate a new modal window/ overlay showing the search query you used to fit the model. Copy the SPL to use in other aspects of your Splunk instance.
Learn more
To learn about implementing analytics and data science projects using Splunk's statistics, machine learning, and built-in custom visualization capabilities, see the Splunk Education course Splunk 8.0 for Analytics and Data Science.