/openscale_app

Build, deploy and monitor a machine learning model and related application with IBM Cloud, Watson Machine Learning, and Watson OpenScale.

Primary LanguageJupyter Notebook

Build, monitor and infuse AI with IBM Cloud, Watson Machine Learning, and Watson OpenScale

Welcome! The instructions below have been provided as part of an IBM Developer webcast series. By following along, you will provision IBM Cloud services, train and deploy a machine learning model, monitor that model, and finally deploy an IBM Cloud app that incorporates the model and the monitoring information. The webcast replay can be found here.

Prerequisites

In this step, you will provision and install the services and software you need for the hands-on lab.

  1. Sign up for a free IBM Cloud account.
  2. Sign up for a free Watson Studio account.
  3. Provision a free lite instance of Watson Machine Learning. Choose either the Dallas or Frankfurt region.
  4. Provision a free lite instance of Watson OpenScale. Choose the same region (Dallas or Frankfurt) you selected for Watson Machine Learning. You just need to provision the service for now. DO NOT RUN THE AUTO-SETUP DURING THE WEBCAST. It will take too much time to complete and you won't be able to follow along.
  5. Provision a free instance of Object Storage.
  6. Download and install the IBM Cloud command line tool. This is optional if you don't want to deploy the app in the final section to IBM Cloud.

0. Environment setup

In this step, you will create the service credentials and projjects you need for the hands-on lab.

Start by creating credentials for Watson Machine Learning. Navigate to your IBM Cloud Resources page. From the Resource list, expand the Services section and click on the instance of Watson Machine Learning you created in the previous section.

Resource list -> Services -> Watson Machine Learning

From the menu on the left, click on Service credentials.

Service credentials

Click blue the New credential button.

New credential

Give your credentials a name, and then click the Add button.

Add credential

Your new credentials will appear in the list. Click the copy button to copy them to your clipboard.

Copy to clipboard

Open your favorite text editor and paste the credentials into a new file. We will use them in a few different locations in later steps.

Next, you'll need a Cloud API key. Navigate to the Cloud user API key page and click the Create an IBM Cloud API key button.

Create an IBM Cloud API key

Give your key a name and click the Create button.

Confirm API key creation

Click the Copy button to copy the key to your clipboard.

Copy API key

Paste the API key into your text editor file for later use.

Finally, you will need to create a Watson Studio project for your Python notebooks and models. Navigate to the Watson Studio home page and click the New project button.

New project

Click the Create an empty project tile.

Empty project

Give your project a name. In the Define storage section, select the Object Storage instance you created in the previous section, and then click Create.

Project details

Click on the Settings tab at the top of the screen.

Project settings

Scroll down to the Associated services section. Click the Add service button and select Watson from the list.

Associate Watson services

Click the Add button on the Machine Learning tile.

Add Machine Learning

Select the instance of Watson Machine Learning you created in a previous step from the dropdown, and click the Select button.

Existing service instance

You are now ready to begin the lab.

1. Create and deploy the machine learning model

Navigate to this repo and clone or download the files to your machine.

Clone or download

Extract the downloaded files on your machine.

Navigate to your list of projects in Watson Studio, and click on the project you created in the previous section to open it.

Click on the Assets tab.

Assets tab

In the upper section of the screen, click the Add to project button.

Add to project

Select Notebook.

Notebook

Select the From file tab, and then click on the Drag and drop files here or upload link at the bottom.

Drag and drop file

Navigate to the folder where you extracted the github files, open the notebooks folder, select mortgage_default_cloud.ipynb, and then click Open.

mortgage_default_cloud.ipynb

Click the Create button to create the notebook in your Watson Studio project. When the notebook has loaded, scroll down to the first two code cells. You will want to replace the values for WML_CREDENTIALS and CLOUD_API_KEY in these two cells with the credentials and API key you created in a previous step. Ensure that the Watson Machine Learning credentials are enclosed in the curly braces, and that the Cloud API key is enclosed in quotation marks.

Edit code cells

You can now run the cells in the notebook. Click on the Cell menu and select Run All. You may also choose to run the cells one at a time.

Run all cells

The notebook will pull the training data from GitHub and use it to train a random forest classification model. It will then deploy that model as a web service to your Watson Machine Learning instance.

Next, it will use the Watson OpenScale Python client to configure explainability, drift, fairness, and accuracy monitoring for the model. Finally, it will submit enough random records from the training data to the model to engage the monitors.

The notebook is heavily commented to help you understand what each cell is doing. You may read through it for more detailed information.

When the notebook has finished running, scroll to the very bottom of the screen. You will need to copy the output of the final cell and paste it into your text file for use in the application.

Copy the OpenScale GUID

2. Explore Watson OpenScale

Watson OpenScale monitors production machine learning models for quality, fairness, and drift. It also provides detailed explanations of model predictions.

Navigate to Watson OpenScale. Once you have signed in, you will see the Insights Dashboard, which provides an overview of the models you are monitoring. Click on the tile for the Mortgage Default model.

Mortgage Default

The notebook you ran in the previous step configured the monitors for our model, and provided enough data for the monitors to run. If you are interested in learning more about the monitors OpenScale provides, click here.

The first monitor shown is the Fairness monitor. It ensures that our model is not unfairly biased against a particular group. For this use case, we wanted to make sure that our model was treating online applications fairly. For more information, click the Fairness monitor section.

Fairness monitor

This screen shows fairness data computed hourly for the past week. Because we just built and fed data to our model, there won't be much data here yet.

On the left, you can explore the different monitors OpenScale provides. The Quality monitor requires scored feedback data, and calculates nine different quality metrics.

The Drift monitor compares the data that has been submitted to the model to the training data, and attempts to identify potential quality issues that may result if the submission data begins to vary too much from the training data.

When you are finished exploring, return to the Fairness graph screen and click on the left-most point on the graph.

Fairness graph

Here we can see the breakdown for predictions made during a specific time period. Click the View Transactions button.

View transactions

This screen provides a table with all the predictions made by the model during the selected time period. Find one you'd like to get more information about, and click the Explain link.

Explain link

OpenScale's explanation service can take up to a minute to fully complete. When it finishes, it provides detailed information on which features from the submitted application influenced the model prediction. It can also tell you what changes need to be made to the request to result in a different prediction, and how much the request could change without altering the prediction.

In the next section, we'll take a look at how these tools might work in a real-world application.

3. Build an application to use the model and explanations

Note: If you are having trouble with the ibmcloud command line tool in this section, you may wish to use the Cloud Foundry command line tool instead. In that case, login with cf login, omit the ibmcloud portion from each command below, and skip the ibmcloud cf install and ibmcloud target --cf steps. You can also run the app from your local machine using node.js.

It's time to use the credentials you've been pasting in your text editor. Navigate to the directory where you extracted the files from the repo, and edit the auth_example.js file. Paste your Cloud API key, Watson Machine Learning service credentials, and the Watson OpenScale information from the notebook into the correct locations in the JavaScript file.

When you are finished, save the file and then rename it to auth.js.

Next, open up a terminal window and run the following command to install the Cloud Foundry tools: ibmcloud cf install

Next, login to your IBM Cloud account: ibmcloud login

IBM employees will login with: ibmcloud login --sso

Follow any prompts from the tool to select your default accounts or workspaces.

Enter the following command to target Cloud Foundry: ibmcloud target --cf

The command line tool may prompt you to select an account or workspace.

Within the terminal, navigate to the directory where you extracted the GitHub repo files. The directory file listing should look like this: Directory listing

Ensure that you've renamed the edited auth_example.js to auth.js to avoid breaking the app.

Enter the following command, replacing your-app-name with a unique application name: ibmcloud cf push your-app-name -m 256m

When the command successfully completes, you can navigate to https://your-app-name.mybluemix.net to use the running app. You can change the details of the mortgage application to see how it affects the model's prediction, and then use the OpenScale explainability service to see exactly what is influencing each decision.

Note that the Lite version of OpenScale does limit the number of explanations you can generate each month.

4. Next steps

Tune in May 15 for an AutoAI presentation from Jacques Roy! And subscribe to his excellent YouTube channel, Byte Size Data Science.

The model and application can be improved in several ways:

  • More tuning could be done to the model to improve its accuracy.
  • Continually feeding data into the model would provide more information for the monitors. This notebook will allow you to schedule hourly requests. Before setting this up, take into account the limits of the free plans for Watson Machine Learning and Watson OpenScale.
  • The app could certainly use a visual upgrade.
  • As discussed in the app source code, it would be a good idea to render the model result and explanation result pages immediately with progress bars, then update the page when the results are available.
  • OpenScale's explanation service provides both LIME and contrastive information. Currently, the app only requests and displays the LIME information. It could be updated to provide both, which would allow the user to see what changes to the record would lead to a different prediction.