Visual Studio Code Tensorflow



  1. Tensorflow In Visual Studio

I would describe TensorFlow as an open source machine learning framework developed by Google which can be used to build neural networks and perform a variety of machine learning tasks. it works on data flow graph where nodes are the mathematical operations and the edges are the data in the form of tensor, hence the name Tensor-Flow.

TensorFlow.NET uses the.NET Standard 2.0 standard, so your new project Target Framework can be.NET Framework or.NET Core/.NET 5. All the examples in this book are using.NET Core 3.1 and Microsoft Visual Studio Community 2019. To start building TensorFlow program you just need to download and install the.NET SDK (Software Development Kit). Build an AI-powered Pet Detector with Python, TensorFlow, and Visual Studio Code Let’s build a pet detector to recognize them in pictures! We will walk through the training, optimizing, and deploying of a deep learning model using Azure Notebooks and the Azure Machine Learning service.

Let’s run a classic HelloWorld program first and see if TensorFlow is running on .NET. I can’t think of a simpler way to be a HelloWorld.

Install the TensorFlow.NET SDK¶

TensorFlow.NET uses the .NET Standard 2.0 standard, so your new project Target Framework can be .NET Framework or .NET Core/ .NET 5. All the examples in this book are using .NET Core 3.1 and Microsoft Visual Studio Community 2019. To start building TensorFlow program you just need to download and install the .NET SDK (Software Development Kit). You have to download the latest .NET Core SDK from offical website: https://dotnet.microsoft.com/download.

  • Visual Studio Code is a code editor redefined and optimized for building and debugging modern web and cloud applications. Visual Studio Code is free and available on your favorite platform.
  • I work on the python code in VS Code for image processing and i need to use tensorflow. When I want to import tensorflow i get this error: import tensorflow as tf E0401:Unable to import 'tensorflow' I have read ImportError: No module named tensorflow for Visual Studio Code but it is used for working with GPU but I only want to work with CPU.
  • 00:15 Installation von TensorFlow03:15 Installation von Keras03:25 Installation von Visual Studio CodeHast Du Bock auf Machine Learning und Artificial Intell.
  1. New a project

    New Project

  2. Choose Console App (.NET Core)

    Console App

Start coding Hello World¶

After installing the TensorFlow.NET package, you can use the usingstaticTensorflow.Binding to introduce the TensorFlow .NET library.

TensorFlow 2.x enabled EagerMode by default. About what eager mode is, I will introduce it in detail in the following chapters.

Runtime

After CTRL + F5 run, you will get the output.

This sample code can be found at here.

-->

Learn how to train and deploy an image classification model to recognize hand-written numbers using TensorFlow and the Azure Machine Learning Visual Studio Code Extension.

In this tutorial, you learn the following tasks:

  • Understand the code
  • Create a workspace
  • Create an experiment
  • Configure Computer Targets
  • Run a configuration file
  • Train a model
  • Register a model
  • Deploy a model

Prerequisites

Visual studio code python tutorial
  • Azure subscription. If you don't have one, sign up to try the free or paid version of Azure Machine Learning.
  • Install Visual Studio Code, a lightweight, cross-platform code editor.
  • Azure Machine Learning Studio Visual Studio Code extension. For install instructions see the Setup Azure Machine Learning Visual Studio Code extension tutorial

Understand the code

The code for this tutorial uses TensorFlow to train an image classification machine learning model that categorizes handwritten digits from 0-9. It does so by creating a neural network that takes the pixel values of 28 px x 28 px image as input and outputs a list of 10 probabilities, one for each of the digits being classified. Below is a sample of what the data looks like.

Get the code for this tutorial by downloading and unzipping the VS Code Tools for AI repository anywhere on your computer.

Create a workspace

The first thing you have to do to build an application in Azure Machine Learning is to create a workspace. A workspace contains the resources to train models as well as the trained models themselves. For more information, see what is a workspace.

  1. On the Visual Studio Code activity bar, select the Azure icon to open the Azure Machine Learning view.

  2. Right-click your Azure subscription and select Create Workspace.

  3. By default a name is generated containing the date and time of creation. In the text input box, change the name to 'TeamWorkspace' and press Enter.

  4. Select Create a new resource group.

  5. Name your resource group 'TeamWorkspace-rg' and press Enter.

  6. Choose a location for your workspace. It's recommended to choose a location that is closest to the location you plan to deploy your model. For example, 'West US 2'.

  7. When prompted to select the type of workspace, choose basic.

At this point, a request to Azure is made to create a new workspace in your account. After a few minutes, the new workspace appears in your subscription node.

Create an experiment

One or more experiments can be created in your workspace to track and analyze individual model training runs. Runs can be done in the Azure cloud or on your local machine.

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace node.

  4. Right-click the Experiments node.

  5. Select Create Experiment from the context menu.

  6. Name your experiment 'Tutorial-VSCode-MNIST' and press Enter to create the new experiment.

Like workspaces, a request is sent to Azure to create an experiment with the provided configurations. After a few minutes, the new experiment appears in the Experiments node of your workspace.

Configure Compute Targets

A compute target is the computing resource or environment where you run scripts and deploy trained models. For more information, see the Azure Machine Learning compute targets documentation.

To create a compute target:

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace node.

  4. Under the workspace node, right-click the Compute clusters node and choose Create Compute.

  5. Select Azure Machine Learning Compute (AmlCompute). Azure Machine Learning Compute is a managed-compute infrastructure that allows the user to easily create a single or multi-node compute that can be used with other users in your workspace.

  6. Choose a VM size. Select Standard_F2s_v2 from the list of options. The size of your VM has an impact on the amount of time it takes to train your models. For more information on VM sizes, see sizes for Linux virtual machines in Azure.

  7. Name your compute 'TeamWkspc-com' and press Enter to create your compute.

    A file appears in VS Code with content similar to the one below:

  8. When satisfied with the configuration, open the command palette by selecting View > Command Palette.

  9. Enter the following command into the command palette to save your run configuration file.

After a few minutes, the new compute target appears in the Compute clusters node of your workspace.

Create a run configuration

When you submit a training run to a compute target, you also submit the configuration needed to run the training job. For example, the script that contains the training code and the Python dependencies needed to run it.

To create a run configuration:

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace > Compute clusters node.

  4. Under the compute node, right-click the TeamWkspc-com compute node and choose Create Run Configuration.

  5. Name your run configuration 'MNIST-rc' and press Enter to create your run configuration.

  6. Then, select Create new Azure ML Environment. Environments define the dependencies required to run your scripts.

  7. Name your environment 'MNIST-env' and press Enter.

  8. Select Conda dependencies file from the list.

  9. Press Enter to browse the Conda dependencies file. In this case, the dependencies file is the env.yml file inside the vscode-tools-for-ai/mnist-vscode-docs-sample directory.

    A file appears in VS Code with content similar to the one below:

  10. Once you're satisfied with your configuration, save it by opening the command palette and entering the following command:

  11. This sample does not use a dataset registered in Azure Machine Learning. Instead, it's loaded when train.py runs. When prompted to create a data reference for your training run, enter 'n' into the prompt and press Enter.

  12. Press Enter to browse the script file to run on the compute. In this case, the script to train the model is the train.py file inside the vscode-tools-for-ai/mnist-vscode-docs-sample directory.

    A file called MNIST-rc.runconfig appears in VS Code with content similar to the one below:

  13. Once you're satisfied with your configuration, save it by opening the command palette and entering the following command:

The MNIST-rc run configuration is added under the TeamWkspc-com compute node and the MNIST-env environment configuration is added under the Environments node.

Train the model

During the training process, a TensorFlow model is created by processing the training data and learning patterns embedded within it for each of the respective digits being classified.

To run an Azure Machine Learning experiment:

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace > Experiments node.

  4. Right-click the MNIST experiment.

  5. Select Run Experiment.

  6. From the list of compute target options, select the TeamWkspc-com compute target.

  7. Then, select the MNIST-rc run configuration.

  8. At this point, a request is sent to Azure to run your experiment on the selected compute target in your workspace. This process takes several minutes. The amount of time to run the training job is impacted by several factors like the compute type and training data size. To track the progress of your experiment, right-click the current run node and select View Run in Azure portal.

  9. When the dialog requesting to open an external website appears, select Open.

When the model is done training, the status label next to the run node updates to 'Completed'.

Register the model

Now that you've trained your model, you can register it in your workspace.

To register your model:

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace > Experiments > MNIST node.

  4. Get the model outputs generated from training the model. Right-click the Run 1 run node and select Download outputs.

  5. Choose the directory to save the downloaded outputs to. By default, the outputs are placed in the directory currently opened in Visual Studio Code.

  6. Right-click the Models node and choose Register Model.

  7. Name your model 'MNIST-TensorFlow-model' and press Enter.

  8. A TensorFlow model is made up of several files. Select Model folder as the model path format from the list of options.

  9. Select the azureml_outputs/Run_1/outputs/outputs/model directory.

    A file containing your model configurations appears in Visual Studio Code with similar content to the one below:

  10. Once you're satisfied with your configuration, save it by opening the command palette and entering the following command:

After a few minutes, the model appears under the Models node.

Deploy the model

In Visual Studio Code, you can deploy your model as a web service to:

  • Azure Container Instances (ACI).
  • Azure Kubernetes Service (AKS).

You don't need to create an ACI container to test in advance, because ACI containers are created as needed. However, you do need to configure AKS clusters in advance. For more information on deployment options, see deploy models with Azure Machine Learning .

To deploy a web service as an ACI :

  1. On the Visual Studio Code activity bar, select the Azure icon. The Azure Machine Learning view appears.

  2. Expand your subscription node.

  3. Expand the TeamWorkspace > Models node.

  4. Right-click the MNIST-TensorFlow-model and select Deploy Service from Registered Model.

  5. Select Azure Container Instances.

  6. Name your service 'mnist-tensorflow-svc' and press Enter.

  7. Choose the script to run in the container by pressing Enter in the input box and browsing for the score.py file in the mnist-vscode-docs-sample directory.

  8. Provide the dependencies needed to run the script by pressing Enter in the input box and browsing for the env.yml file in the mnist-vscode-docs-sample directory.

    A file containing your model configurations appears in Visual Studio Code with similar content to the one below:

  9. Once you're satisfied with your configuration, save it by opening the command palette and entering the following command:

At this point, a request is sent to Azure to deploy your web service. This process takes several minutes. Once deployed, the new service appears under the Endpoints node.

Next steps

Tensorflow In Visual Studio

  • For a walkthrough of how to train with Azure Machine Learning outside of Visual Studio Code, see Tutorial: Train models with Azure Machine Learning.
  • For a walkthrough of how to edit, run, and debug code locally, see the Python hello-world tutorial.