Skip to content

Setup Windows Binary Manual

Wolfgang Manousek edited this page Nov 11, 2016 · 35 revisions

Windows manual installation from binary download

This page will walk you through the process of manual installing the Microsoft Cognitive Toolkit (CNTK) based on a binary distribution we have prepared and you can download from our website. This is intended for those users who want to have a customized installation. We have tested the Microsoft Cognitive Toolkit on Windows 8.1, Windows 10 and Windows Server 2012 R2.

Note: You can find an overview about all the available installation options for CNTK on [this page] (./Setup-CNTK-on-your-machine).

If you previously installed an earlier version of the CNTK Python package, you can jump to step 3 to update existing CNTK package installation from your Python 3.4 environment

Step 1: Install pre-requisites

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.

After you followed the step above, you can now unpack the zip file into a local folder of your choice, although in the following text we will assume you unpacked the package into c:\local. If you installed the zip into a different directory, please adjust the commands given below accordingly.

CNTK on Windows requires the following prerequisites to be installed on your system. Please install them from the links below:

  • The Visual C++ Redistributable Package for Visual Studio 2013 can be installed from c:\local\cntk\prerequisites\VS2013\vcredist_x64.exe

  • The Visual C++ Redistributable Package for Visual Studio 2012 can be installed from c:\local\cntk\prerequisites\VS2012\vcredist_x64.exe

  • Microsoft MPI Version 7 (7.0.12437.6) can be installed from c:\local\cntk\prerequisites\MsMPiSetup.exe. At this point we suggest this version of MSMPI (7.0.12437.6), as this is the version which is currently tested by us in connection with the Microsoft Cognitive Toolkit.

  • For GPU systems ensure that you have the latest NVIDIA driver

Step 2: Python setup

  • If you do not have an Anaconda installation: install Anaconda Python for Windows. You can follow the standard configuraion given in the install program (InstallationType=JustMe; AddToPath=No; RegisterPython=No). In the following we assume you installed Python into C:\local\Anaconda3-4.1.1-Windows-x86_64. If you installed Python in a different directory, please adjust the commands given below accordingly.

  • In your Anaconda installation, create a conda environment (called cntk-py34 here) and activate it by running the following commands from the Windows command shell:

cd C:\local\Anaconda3-4.1.1-Windows-x86_64\scripts
conda env create --file c:\local\cntk\scripts\windows\conda-windows-cntk-py34-environment.yml
activate C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\cntk-py34

Step 3: Install CNTK Python Environment

  • From an activated conda environment (see step 3) run: pip install c:\local\cntk\cntk\python\cntk-2.0.beta2.0-cp34-cp34m-win_amd64.whl

Brainscript (optional)

  • From Windows cmd prompt run: setx PATH=c:\local\cntk\cntk;%PATH%

Step 4: Download the examples and tutorials

  • Install GIT

  • Clone the CNTK repository into the folder c:\repos. If you cloned it in different directory, please adjust the commands given below accordingly.

cd c:\repos
git clone --recursive https://github.com/Microsoft/CNTK/
cd c:\repos\cntk 
git checkout v2.0.beta1.0
setx PYTHONPATH=c:\repos\cntk\bindings\python\examples;%PYTHONPATH%

This will also include the Python examples and tutorials in the environment variable PYTHONPATH

Step 5 Verify the setup from Python

During this step we describe the basic steps to verify a succesful 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

cd C:\local\Anaconda3-4.1.1-Windows-x86_64\scripts
activate C:\local\Anaconda3-4.1.1-Windows-x86_64\envs\cntk-py34

Note: you will need to do this every time you plan to run CNTK in Python.

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

  • Run the examples

    Change into the Python example directory inside the cloned CNTK github repository and run the FeedForward example:

cd c:\repos\CNTK\bindings\python\examples
python NumpyInterop/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 the tutorials

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

cd c:\repos\CNTK\bindings\python\tutorials
jupyter notebook

This will start a browser with the available notebooks.

Step 6 Verify the setup (BrainScript)

Start a normal Windows command shell, and make sure the CNTK binaries are included in your PATH

set PATH=c:\local\cntk\cntk;%PATH%

Then you can test your installation by:

cd c:\repos\CNTK\Examples\Other\Simple2d\Data
cntk configFile=../Config/Simple.cntk makeMode=false command=Simple_Demo_Train

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

Epoch[10 of 10]-Minibatch[ 361- 370, 92.50%]: CrossEntropyWithSoftmax = 0.15039844 * 250; EvalClassificationError = 0.06800000 * 250; time = 0.0123s; samplesPerSecond = 20374.9
Epoch[10 of 10]-Minibatch[ 371- 380, 95.00%]: CrossEntropyWithSoftmax = 0.13989600 * 250; EvalClassificationError = 0.06800000 * 250; time = 0.0119s; samplesPerSecond = 21082.8
Epoch[10 of 10]-Minibatch[ 381- 390, 97.50%]: CrossEntropyWithSoftmax = 0.16218604 * 250; EvalClassificationError = 0.08400000 * 250; time = 0.0126s; samplesPerSecond = 19887.0
Epoch[10 of 10]-Minibatch[ 391- 400, 100.00%]: CrossEntropyWithSoftmax = 0.13712695 * 250; EvalClassificationError = 0.08400000 * 250; time = 0.0123s; samplesPerSecond = 20353.3
Finished Epoch[10 of 10]: [Training] CrossEntropyWithSoftmax = 0.15792653 * 10000; EvalClassificationError = 0.07570000 * 10000; totalSamplesSeen = 100000; learningRatePerSample = 0.0080000004; epochTime=0.540674s
SGD: Saving checkpoint model '../Output/Models/simple.dnn'

Action "train" complete.

COMPLETED.

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

cntk configFile=../Config/Simple.cntk makeMode=false command=Simple_Demo_Train deviceId=0

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

Model has 25 nodes. Using GPU 0.
Clone this wiki locally