Name: Towards AI Legal Name: Towards AI, Inc. Description: Towards AI is the world's leading artificial intelligence (AI) and technology publication. Read by thought-leaders and decision-makers around the world. Phone Number: +1-650-246-9381 Email: [email protected]
228 Park Avenue South New York, NY 10003 United States
Website: Publisher: https://towardsai.net/#publisher Diversity Policy: https://towardsai.net/about Ethics Policy: https://towardsai.net/about Masthead: https://towardsai.net/about
Name: Towards AI Legal Name: Towards AI, Inc. Description: Towards AI is the world's leading artificial intelligence (AI) and technology publication. Founders: Roberto Iriondo, , Job Title: Co-founder and Advisor Works for: Towards AI, Inc. Follow Roberto: X, LinkedIn, GitHub, Google Scholar, Towards AI Profile, Medium, ML@CMU, FreeCodeCamp, Crunchbase, Bloomberg, Roberto Iriondo, Generative AI Lab, Generative AI Lab Denis Piffaretti, Job Title: Co-founder Works for: Towards AI, Inc. Louie Peters, Job Title: Co-founder Works for: Towards AI, Inc. Louis-François Bouchard, Job Title: Co-founder Works for: Towards AI, Inc. Cover:
Towards AI Cover
Logo:
Towards AI Logo
Areas Served: Worldwide Alternate Name: Towards AI, Inc. Alternate Name: Towards AI Co. Alternate Name: towards ai Alternate Name: towardsai Alternate Name: towards.ai Alternate Name: tai Alternate Name: toward ai Alternate Name: toward.ai Alternate Name: Towards AI, Inc. Alternate Name: towardsai.net Alternate Name: pub.towardsai.net
5 stars – based on 497 reviews

Frequently Used, Contextual References

TODO: Remember to copy unique IDs whenever it needs used. i.e., URL: 304b2e42315e

Resources

Take the GenAI Test: 25 Questions, 6 Topics. Free from Activeloop & Towards AI

Publication

Machine Learning in the Cloud using Azure ML Studio
Cloud Computing

Machine Learning in the Cloud using Azure ML Studio

Last Updated on December 7, 2020 by Editorial Team

Author(s): Ranganath Venkataraman

Cloud Computing

Model training and deployment for a new Nanodegree from Udacity and Microsoft

Photo by Marius Masalar onΒ Unsplash

After completing a Foundations course launched in July that enrolled~ 10,000 students worldwide, I was one of 300 selected in October for a scholarship to get a Nanodegree. After completing the capstone yesterday and graduating, I’m writing this article to document my experience with the mechanics of AzureML. Here’s the link to my project’s repo.

Context

As evident in my previous posts, my self-taught journey to date focused on building predictors and visualizations using machine learning algorithms with Python. My interface was the Jupyter notebook, and my work lived on my laptop. As I was getting ready to practice and learn deploying models, I started the Nanodegree thatβ€Šβ€”β€Šamong other conceptsβ€Šβ€”β€Šcovered the deployment of models inΒ Azure.

How this article is organized

Topics covered in this article about Nanodegree’s Capstone projectΒ are:

  • Purpose
  • Setting up for theΒ project.
  • Developmentβ€Šβ€”β€ŠHyperDrive andΒ AutoML
  • Deployment
  • Conclusions

Throughout this article, I’ll discuss points that were good learning opportunities for my fellow students andΒ me.

Purpose

The capstone project is the culmination of training on various concepts; therefore, it tested our abilityΒ to:

  • run a HyperDrive experiment to comb through the hyperparameter search space to find settings that maximize the performance of a pre-selected scikit-learn algorithm on a problem ofΒ choice
  • use AutoML to find the best algorithm that maximizes performance on the aforementioned problem
  • deploying the best performing model as an active endpoint that can be queried by anybodyβ€Šβ€”β€Šgetting the product out of my laptop so anybody can useΒ it

Setting up for the CapstoneΒ project

The first step was to select a problem and dataset: I chose the problem of predicting vehicle fuel efficiency with the Auto MPG dataset from the UCI repository. Since I was familiar with this dataset from a prior post, I could focus on the mechanics of Azure’s Machine Learning (ML)Β Studio.

Microsoft and Udacity provide a virtual machine for the capstone: Standard DS3V2 with 14 GB RAM that can provide up to 4 CPU nodes. After launching a workspace that uses this virtual machine, the next setting-up step is to upload and register the dataset, which currently is aΒ .csv file on myΒ desktop.

Once completed, AzureML provides the user with the necessary code to consume the registered dataset, as seen in Figure 1 below. The line declaring the Experiment is my own and not necessary to consume a registered dataset.

Figure 1: consuming registered dataset

With the dataset ready for use and a workspace launched on a running virtual machine β€˜compute,’ we are ready to develop theΒ project.

Developmentβ€Šβ€”β€ŠHyperDrive

Setting up the HyperDrive experiment for this problem in Azure ML Studio entails setting the search space for model hyperparametersβ€Šβ€”β€Šsimilar to GridSearchCVβ€Šβ€”β€Šand selecting an Early Stopping policy to halt the experiment’s runs upon achieving a certain performance factor. These two factors, along with a max number of trials, provide means of configuring the HyperDrive run, as observed in FigureΒ 2.

Figure 2: developing a HyperDrive experiment

Other settings needed to configure the HyperDrive run include the primary metric name, our goal with the metric, i.e., maximize or minimize, and the estimator. The number of max_concurrent_runs must be less than or equal to the maximum number of nodes that can be provisioned by the available compute, in this case,Β 3<4.

Continuing with this article’s focus on the mechanics of AzureML, let’s discuss the estimator. As you see above, it’s declared using AzureML’s SKLearn class and uses an entry script as input. That entry script is the actual code that cleans the data, splits data into training and testing sets, trains the pre-selected scikit-learn algorithm, and evaluates performance on a test set. Let’s look at part of the entry script in Figure 3 below, with the whole code available in train_11_29_FINAL.py script, found in the projectΒ repo.

Figure 3: a portion of the entry script used in the HyperDrive experiment.

As observed above, I chose to vary tree depth and learning rate when searching for the bestΒ model.

I also used the default scorer used by GradientBoosting Regressor, which returns an R-square value. This score must be logged in the entry script with the same name as the name used as the primary_scoring_metric in the HyperDriveConfigβ€Šβ€”β€Šcompare Figures 2 andΒ 3.

Experiments are β€˜submitted’ to launch HyperDrive runs. When these runs fail, the main console returns messages that can be inadequate for diagnosis. The user opens a given link that has a list of HyperDrive runs, click on a failed run, and open that failed run’s output logs. Those logs point out the specific line with theΒ error.

The best-performing run can then be retrieved from the HyperDrive experiment as seen in Figure 4 below, with the corresponding hyperparameter settings specified in an instance of the algorithm and saved to the active directory as a model using joblib. Figure 5 shows the ID and performance of the bestΒ run.

Figure 4: retrieving best run from HyperDrive experiment and using corresponding hyperparameter values to save the bestΒ model
Figure 5: best run and run ID from HyperDrive experiment

A HyperDrive-optimized GradientBoosting Regressor has an R-squared value ofΒ 0.82

Developmentβ€Šβ€”β€ŠAutoML

AutoML in Azure ML Studio entails cleaning the dataset, specifying configuration settings through AutoMLConfig, and submitting an experiment with these settings. Figure 6 below goes through this processβ€Šβ€”β€Šbecause there is no training script submitted with AutoML, we have to sanitize the data before feeding it as training_data.

Figure 6: setting AutoML configuration and running the experiment

The entire output is in the linked repoβ€Šβ€”β€Šgetting the best model from the AutoML experiment reveals that it’s an XGBoost Regressor that produces an R-squared value of 0.87. This top-performing model is saved to the active directory using joblib.dump

Figure 7: identifying and saving the best-performing model fromΒ AutoML

Deployment

With the best performing, AutoML saved to the working directory, I then registered the model and created the necessary environment with the required packages to use in deploying the registered model as a web service. This web service is an active HTTP endpoint that can be queried with data to receive the model’s prediction.

Registering the model creates a β€˜container’ with the application and libraries/dependencies needed for execution. The registered model is also saved on the working directory for subsequent use in deployment.

The Model class’s deploy method, as used in this project, takes the following inputs: a workspace, the registered model, an inference configuration, and a deployment configuration. Let’s take each of these at aΒ time:

  • workspace = already definedΒ earlier
  • registered model = coveredΒ above
  • inference configuration = represents settings of the β€˜computer’ used for deployment. The InferenceConfig class is used, whichβ€Šβ€”β€Šfor our purposesβ€Šβ€”β€Štakes two inputs: an entry script and a curated environment. We’ll cover both of theseΒ short
  • deployment configurations = configures the web service that hosts the registered model and entry script. For our purposes, we’ll use the Azure Container Instance.

Now let’s discuss the inputs to the InferenceConfig class:

  • the entry script takes data from the user and passes it to the model. The resulting prediction from the model is β€˜returned’ as the output of the entry scriptβ€Šβ€”β€Šsee below for a snippet from the score.py entry script, which can be found at this project’s repo.
Figure 8: entry script score.py used to run the registered AutoMLΒ model
  • the curated environment is expected to support the algorithms used by the model. In my case, since the best AutoML model is an XGBoost Regressor, I chose the β€˜AzureML-AutoML’ package, which covers this algorithm.

Figure 9 below shows the creation of the environment, inference configuration, and deployment configuration. These creations are fed along with the registered model into the deploy method of the ModelΒ class.

Figure 9: model deployment

As seen below, deployment was successful with a healthy endpoint. Upon my asking, AzureML provides the scoring URI for use in querying theΒ model.

Figure 10: healthy endpoint and scoringΒ URI

Passing a request to this scoring URI runs the entry script, which launches the registered model from its saved home in the working directory in the init() command. The run() command is then executed to actually generate a prediction on data passed to the active endpoint.

Figure 11: passing the request to active scoring URI and getting a resulting prediction

Figure 11 demonstrates that any user who uses the files at the project repo can pass data on a car and get the predicted mileage. Key learning for the group was the importance of passing in a dataframe that can be dumped into a JSON file while being transferred to the score script, which then unpackages, i.e., dumps the JSON file and transfers it back into a dataframe.

Conclusions

I entered this Nanodegree with no experience in deploying models and have come out with experience in one medium. While challenging, this Nanodegree was enjoyable, and I’m looking forward to learning deployment with otherΒ tools.


Machine Learning in the Cloud using Azure ML Studio was originally published in Towards AI on Medium, where people are continuing the conversation by highlighting and responding to this story.

Published via Towards AI

Feedback ↓