Building Our Adversarial Playground
In Chapter 1, we introduced core concepts of artificial intelligence (AI) and machine learning (ML) to help lay the foundations for working with adversarial AI. In this chapter, we will provide a hands-on walkthrough of ML development, demonstrating how to create and manage your development environment, utilize the algorithms, and navigate the life cycle we described. We will build models and deploy a neural network (NN) model as a REST prediction service. This will be our adversarial playground, the target of our adversarial AI attacks.
By the end of the chapter, you will have learned how to do the following:
- Install Python and create a Python virtual environment to manage your dependencies and work.
- Install Python packages required for data analysis and ML.
- Register our virtual environment as a Jupyter Notebook kernel.
- Use a Jupyter notebook to explore baseline ML algorithms and a simple Keras NN for classifying wine samples. We will demonstrate basic techniques for exploring and preprocessing data and training, testing, and evaluating models.
- Utilize Keras to construct a convolutional NN (CNN) for classifying images and deploy it as an inference REST service for predictions. This will be the initial target of our adversarial attacks.
- Understand options for ML at scale for demanding workloads, including Google’s Colaboratory (Colab), Lambda Labs Cloud, Amazon’s Amazon Web Service (AWS), and Microsoft’s Azure.
The chapter covers the following topics:
- Setting up your development environment
- Hands-on basic baseline ML
- Developing our target AI service with CNNs
- ML development at scale