Skip to content

Setup Windows Binary Script

Mark Hillebrand edited this page Feb 1, 2017 · 61 revisions

CNTK binary installation with scripts on Windows

This page will walk you through the process of installing the Microsoft Cognitive Toolkit (CNTK) based on a binary distribution we have prepared and you can download from our website. It is an easy way to get you up-and-running quickly.

If you are looking for any other kind of support in setting up a CNTK build environment or installing CNTK on your system, you should go here instead.

These instructions apply to release 2.0.beta10.0.

We will install the CNTK binaries, the CNTK prerequisites, and by default create a new Python 3.5 environment on your computer. The here described script also supports options to create a Python 2.7 or Python 3.4 environment as well as various other additional options. A detailed overview of the supported options is here.

The changes are as much localized as possible to not impact any other installed software. We have tested the Microsoft Cognitive Toolkit on Windows 8.1, Windows 10 and Windows Server 2012 R2 (and later).

Once you have download and unpacked the precompiled package, you can run an install script that will perform the following steps:

  • If required the VS2015 Runtime will be installed
  • If required MSMPI will be installed
  • Anaconda3 will be installed into the folder C:\local\Anaconda3-4.1.1-Windows-x86_64
  • A CNTK-PY34 environment will be created or updated in C:\local\Anaconda3-4.1.1-Windows-x86_64\envs
  • The CNTK Python module will be installed or updated in the created CNTK-PY35 environment

In the following we assume you are running the script using the default options. If you changed the options as described here, please adjust the following instructions accordingly.

Step 1: Download and prepare the Microsoft Cognitive Toolkit

Download the appropriate binary package from CNTK Releases page. The installation described on this page only works with the binary package. The source code package, which is also available from the CNTK Release page, is NOT required.

Once you downloaded the package, for security reasons Windows might try to block execution of any scripts contained in this package. It is easy to mark all the scripts contained in this package as secure:

  • Right-click on the downloaded .zip file, choose Properties, and, if near the bottom you see the message "This file came from another computer and might be blocked to help protect this computer", click the checkbox "Unblock" and press "OK".

im1

After you followed the step above, you can now unpack the zip file into a local folder of your choice. We recommend you name the folder according to the version. For example, if you are installing version 2.0Beta10 GPU version, then create a folder, say in c:\local, called c:\local\CNTK-2-0-beta10-0-Windows-64bit-GPU and then unpack into that folder. If you are upgrading, create a new folder with the new name (based on the new version) right along side the folder you created for the older version.

Get the path to your CNTK installation (for example: c:\local\CNTK-2-0-beta10-0-Windows-64bit-GPU) and create an environment variable named MYCNTKPATH.

setx MYCNTKPATH <thePathToCNTKDescribedAbove>

In the following text we will assume you unpacked the package into %MYCNTKPATH%.

Note: If you have a previous version of CNTK installed on your system, please make sure that you unzip the downloaded package into an empty folder on your machine. Between package versions we might have moved files in the package or even removed files from the package. Unzipping in an empty folder will avoid a mix of files from different CNTK versions.

Step 2 Prepare to run PowerShell scripts

The prepared installation script is written for the Powershell environment.

  • Start Powershell allowing script execution

    By default Powershell doesn't allow the execution of any scripts. To allow execution of the installation script start Powershell from a standard Windows command shell by:

    start powershell -executionpolicy remotesigned
    

Step 3 Run the Powershell installation script

Change your current directory into the location of the install script and test the installation script from inside the above opened Powershell environment:

# $env:MYCNTKPATH is your install location
cd $env:MYCNTKPATH\cntk\Scripts\install\windows
# This will launch the install script in test/demo mode:
.\install.ps1

Note: If you now receive an errormessage stating that running scripts is disabled on your system, please make sure you followed Step 1 and Step 2 correctly. These two steps are enabling script execution in your created Powershell environment.

The script will inspect your system and determine the pre-requisites which are missing. You will be notified about the proposed installation steps. At this point you are running in a demo mode - NO changes to your system are being performed.

If you are satisfied with the proposed changes, you can proceed to the actual installation. The installation script supports several command line options. get-help .\install.ps1 will give you a list over the available option. At this point it is recommended to start the installation by adding the -Execute parameter (and any additional parameters you might require):

.\install.ps1 -execute

The script will download needed components from the web, therefore a connection to the Internet is required. It will execute these components, and according to the setting of UAC (User Account Control) on your system, you will be asked to acknowledge the execution and installtion of these components.

Depending on the speed of your system, your Internet connection and the required components to install, the whole process can take up to 20 minutes. Especially the Anaconda3 install is very time consuming without any progress indication, please be patient.

By the end of the successful setup the script will inform you about the location of the CNTK Python environment batch file and of the location of CNTK Python examples.

You can now close the PowerShell window. All other installation steps or your work with the Microsoft Cognitive Toolkit should be performed from a standard Windows command prompt.

Step 4 Update your GPU Driver

If you have an NVidia graphics card on your system, the card can be used to accelerate the operation of the Microsoft Cognitive Toolkit. Please ensure that you have the latest NVIDIA driver installed. In addition utilization of an NVidia graphics card requires a binary Cognitive Toolkit package supporting GPU or GPU with 1bit-SGD.

Step 5 Verify the setup from Python

During this step we describe the basic steps to verify a successful installation by using the Cognitive Toolkit Python API.

First you need to activate the CNTK environment by opening a standard Windows command prompt (not a Powershell prompt) and running the batch file created by the installation script (see Step 3).

Note: you will need to do this every time you plan to use the CNTK Python environment

In the default case:

%MYCNTKPATH%\cntk\scripts\cntkpy35.bat

This script will also add your CNTK installation to your current PATH environment

  • Run an example

    Change into the Tutorials\NumpyInterop directory and run the FeedForward example:

cd %MYCNTKPATH%\cntk\Tutorials\NumpyInterop
python FeedForwardNet.py

You will see the following output on the console:

Minibatch[   1- 128]: loss = 0.564038 * 3200
Minibatch[ 129- 256]: loss = 0.308571 * 3200
Minibatch[ 257- 384]: loss = 0.295577 * 3200
Minibatch[ 385- 512]: loss = 0.270765 * 3200
Minibatch[ 513- 640]: loss = 0.252143 * 3200
Minibatch[ 641- 768]: loss = 0.234520 * 3200
Minibatch[ 769- 896]: loss = 0.231275 * 3200
Minibatch[ 897-1024]: loss = 0.215522 * 3200
Finished Epoch [1]: loss = 0.296552 * 25600
error rate on an unseen minibatch 0.040000
  • Run Jupyter notebooks

The Toolkit contains several tutorials based on Jupyter notebooks. To use them, execute the following commands:

cd c:\local\CNTK-2-0-beta10-0-Windows-64bit-GPU\cntk\Tutorials
jupyter notebook

This will start a browser with the available notebooks.

  • If you want to use Python Tools, CNTK, and Visual Studio Code, see this blog.
  • If you want to use Python Tools, CNTK, and Visual Studio:
  • First determine your path to Visual studio. For VS2013 it would be something like: "c:\Program Files (x86)\Microsoft Visual Studio 12.0". For VS2015, it would be something like: "c:\Program Files (x86)\Microsoft Visual Studio 14.0". Take that path and create an environment variable named MYVSPATH. set MYVSPATH=thePathToVSDescribedAbove.
  • Next Setup your environment with %MYVSPATH%\vc\vcvarsall.bat" amd64.
  • Next update your PATH environment with set PATH=%MYCNTKPATH%\cntk\cntk;%PATH%.
  • Then open Visual Studio with %MYVSPATH%\Common7\IDE\devenv.exe
  • In VS, go to Tools -> Python Tools -> Python Environments and create a new environment.
  • Select Configure from the dropdown menu and set the prefix path to C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\cntk-py35\.
  • Afterwards, click Auto Detect and the rest of the entries will be filled out automatically.

Step 6: Verify the setup for BrainScript

Perform the following command in the CNTK environment command prompt (see previous step):

cd %MYCNTKPATH%\cntk\Tutorials\HelloWorld-LogisticRegression
cntk configFile=lr_bs.cntk makeMode=false command=Train

The last lines of the CNTK output on the console should look similar to this:

Finished Epoch[42 of 50]: [Training] lr = 0.04287672 * 1000; err = 0.01152817 * 1000; totalSamplesSeen = 42000; learningRatePerSample = 0.039999999; epochTime=0.050296s
Finished Epoch[43 of 50]: [Training] lr = 0.04388479 * 1000; err = 0.01206375 * 1000; totalSamplesSeen = 43000; learningRatePerSample = 0.039999999; epochTime=0.052143s
Finished Epoch[44 of 50]: [Training] lr = 0.04223433 * 1000; err = 0.01105073 * 1000; totalSamplesSeen = 44000; learningRatePerSample = 0.039999999; epochTime=0.057235s
Finished Epoch[45 of 50]: [Training] lr = 0.04208072 * 1000; err = 0.01140516 * 1000; totalSamplesSeen = 45000; learningRatePerSample = 0.039999999; epochTime=0.051414s
Finished Epoch[46 of 50]: [Training] lr = 0.04261674 * 1000; err = 0.01158323 * 1000; totalSamplesSeen = 46000; learningRatePerSample = 0.039999999; epochTime=0.051115s
Finished Epoch[47 of 50]: [Training] lr = 0.04326523 * 1000; err = 0.01164283 * 1000; totalSamplesSeen = 47000; learningRatePerSample = 0.039999999; epochTime=0.051611s
Finished Epoch[48 of 50]: [Training] lr = 0.04225255 * 1000; err = 0.01148774 * 1000; totalSamplesSeen = 48000; learningRatePerSample = 0.039999999; epochTime=0.0509s
Finished Epoch[49 of 50]: [Training] lr = 0.04173276 * 1000; err = 0.01124948 * 1000; totalSamplesSeen = 49000; learningRatePerSample = 0.039999999; epochTime=0.049659s
Finished Epoch[50 of 50]: [Training] lr = 0.04399402 * 1000; err = 0.01202178 * 1000; totalSamplesSeen = 50000; learningRatePerSample = 0.039999999; epochTime=0.052725s

COMPLETED.

If you have an NVidia GPU and installed a GPU build, you can also try this command:

cntk configFile=lr_bs.cntk makeMode=false command=Train deviceId=auto

To validate that the GPU was being used, look for the following line in your output:

Model has 9 nodes. Using GPU 0.

Next:

Clone this wiki locally