Skip to content

CNTK Library Managed API

Zhou Wang edited this page Jan 16, 2017 · 34 revisions

The CNTK Library Managed Eval API is implemented in C#, and can be consumend by C# and other .NET languages. It contains the following classes and methods:

class Function

A Function denotes a symbolic computation with zero or more input arguments and one or more outputs. A Function may be primitive or composite (comprised of other Function instances whose inputs and outputs are wired together). A Function effectively is a computation graph composed of other primitive Functions (denoting computation) as nodes and Variable objects (denoting data) as the edges and leaves of the graph.

The Function class contains the following peroperties and methods that are relevant to evaluation:


public string Name { get; }

Name of this Function.


public List<Variable> Arguments { get; }

List of all input Variables of this Function that are not of type Parameter or Constant. These Variables are required inputs in order to to compute the outputs of the Function.


public Variable Output { get; }

The single output Variable of this Function, if there is only one. Otherwise a runtime exception is raised on access.


public List<Variable> Outputs { get; }

List of all output Variables of this Function.


public static Function LoadModel(string modelFile, DeviceDescriptor computeDevice)

Load a Function from a model file.

Parameters:

  • modelFile: the path to the model file.
  • computeDevice: the device on which the Function is loaded.

public void Evaluate(Dictionary<Variable, Value> arguments, Dictionary<Variable, Value> outputs, DeviceDescriptor computeDevice)

Evaluates the Function using the specified arguments as input. It uses provided Values corresponding to each input variable specified in the arguments dictionary to compute the outputs of the Function. The outputs are stored in the output Values corresponding to the output variables in the outputs dictionary.

Parameters:

  • arguments: the input variables and their values of the Function.
  • outputs: store the output values for each output variable. The caller may specify the Value object for storing the output or pass null in which case CNTK Library allocates the actual storage for the output value. In both cases, on return the Value object contains the result of the corresponding output of the Function.
  • computeDevice: the device on which the compuation is executued. It should be aligned with the device on which the model is loaded.

class Value

A Value is a multi-dimensional array with an optional mask and is the actual data fed into or produced from a computation.

Properties:


public DataType DataType { get; }

The data type of the data contained in this Value object.


public StroageFormat StorageFormat { get; }

The storage format of this Value.


public NDShape Shape { get; }

The shape of this Value.


public bool IsSparse { get; }

A boolean value indicating whether this Value contains data in sparse storage format.


public bool IsReadOnly { get; }

A boolean value indicating whether this Value is read-only


public void CopyFrom(Value Source)

Copies the contents of source to this Value. The shapes of the source's data and mask must be identical to this Value's data and mask.

Parameter:

  • Source: The source object from which this 'Value' is copied.

public static Value CreateBatch<T>(NDShape shape, List<T> batch, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a batch of samples. The number of samples in the batch is the number of elements in batch divided by the size of shape (A runtime error occurs if the remainder is not zero). The created Value object contains a copy of the specified data in batch.

Parameters:

  • shape: the tensor shape of the Value object.
  • batch: the data to be contained in the Value object.
  • device: on which device the Value object should be created.
  • readOnly: the Value object is read-only if this flag is true.

public static Value CreateSequence<T>(NDShape shape, List<T> sequence, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a sequence of samples. The created Value object contains a copy of the specified data in sequence. The sequence length is the number of elements in sequence divided by the size of shape (A runtime error occurs if the remainder is not zero).

Parameters:

  • shape: the tensor shape of the Value.
  • sequence: the data to be contained in the Value.
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateSequence<T>(NDShape shape, List<T> sequence, bool seqStartFlag, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a sequence of samples. The created Value object contains a copy of the specified sequence data. The seqStartFlag specifies wehther this sequence is a new sequence or continuation of a previous sequence at the same index in the sequences list from a previous call to this method. The sequence length is the number of elements in sequence divided by the size of shape (A runtime error occurs if the remainder is not zero).

Parameters:

  • shape: the tensor shape of the Value.
  • sequence: the data to be contained in the Value.
  • seqStartFlag: true indicates that it is a new sequence. false means a continuation of a previous sequence.
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateBatchOfSequences<T>(NDShape shape, List<List<T>> batchOfSequences, List<bool> seqStartFlags, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a batch of variable length sequences. The created Value object contains a copy of the specified data in batchOfSequences. The number of sequences in the batch is the size of batchOfSequences. The length of each sequence is the number of elements in the corresponding sequence of batchOfSequences divided by the size of shape (A runtime error occurs if the remainder is not zero).

Parameters:

  • shape: the tensor shape of the Value.
  • batchOfSequences: the data to be stored in the Value. The outer List represents a collection of sequences with variable length, and the inner List represents each individual sequence.
  • seqStartFlags: A collection of boolean value. Each element represent whether the correspoinding sequence in batchOfSequences is a new sequence (in case of true) or a continuation of a previous sequence (in case of false).
  • device: on which device the Value should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateBatch<T>(uint dimension, List<uint> batch, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a batch of samples. Each sample is represented by an index value that points to the non-zero value in the one-hot vector of dimension elements. The number of samples in the batch is the number of elements in batch.

Parameters:

  • T: data type of the created Value object. Currently, float and double are supported.
  • dimension: the size of dimension of the one-hot vector.
  • batch: the collection of indexes representing the batch of samples.
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateSequence<T>(uint dimension, List<uint> sequence, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a sequence of samples. Each sample is represented by an index value that points to the non-zero value in the one-hot vector of dimension elements. The sequence length is the number of elements in sequence.

Parameters:

  • T: data type of the created Value object. Currently, float and double are supported.
  • dimension: the size of dimension of the one-hot vector.
  • sequence: the collection of indexes representing the sequence of samples.
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateSequence<T>(uint dimension, List<uint> sequence, bool seqStartFlag, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a sequence of samples. Each sample is represented by an index value that points to the non-zero value in the one-hot vector of dimension elements. The seqStartFlag specifies wehther this sequence is a new sequence or continuation of a previous sequence at the same index in the sequences list from a previous call to this method. The sequence length is the number of elements in sequence.

Parameters:

  • T: data type of the created Value object. Currently, float and double are supported.
  • dimension: the size of dimension of the one-hot vector.
  • sequence: the collection of indexes representing the sequence of samples.
  • seqStartFlag: true indicates that it is a new sequence. false means a continuation of a previous sequence.
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public static Value CreateBatchOfSequences<T>(uint dimension, List<List<uint>> batchOfSequences, List<bool> seqStartFlags, DeviceDescriptor device, bool readOnly = false)

Creates a new Value object containing a batch of variable length sequences. Each sample is represented by an index value that points to the non-zero value in the one-hot vector of dimension elements. The number of sequences is the number of elements in the outer list of batchOfSequences. The length of each sequence is the number of elements of the corresponding sequence in the inner list of batchOfSequences.

Parameters:

  • T: data type of the created Value object. Currently, float and double are supported.
  • dimension: the size of dimension of the one-hot vector.
  • batchOfSequences: the collection of indexes representing sequences of samples. The outer List represents a collection of sequences with variable length, and the inner List represents each individual sequence.
  • seqStartFlags: A collection of boolean value. Each element represent whether the correspoinding sequence in batchOfSequences is a new sequence (in case of true) or a continuation of a previous sequence (in case of false).
  • device: on which device the Value object should be created.
  • readOnly: the Value is read-only if this flag is true.

public void CopyVariableValueTo<T>(Variable sampleVariable, List<List<T>> sequences)

Copies the data stored in the Value into the buffer provided by sequences. The sequences is a list of sequences with variable length. The number of items contained in the outer list of sequences is the number of sequences in the Value. Each element of the outer list represents a sequence. Each sequence,represented by List<T>, contains a variable number of samples. Each sample consits of a fixed number of elements with type of T. The number of elements of a sample is determined by the shape of sampleVariable. The shape of the variable should match the shape of the Value.

Parameters:

  • sampleVariable: denotes the shape and dynamic axes when copying data from this Value to the sequences.
  • sequences: the output buffer used to store the data copied from the Value.

public static void CopyVariableValueTo(this Value value, Variable sampleVariable, List<List<uint>> sequences

Copies the data stored in the Value object into the buffer provided by sequences. The sequences is a list of sequences with variable length. The number of items contained in the outer list of sequences is the number of sequences in the Value. Each element of the outer list represents a sequence. Each sequence, represented by List, contains a variable number of samples. Each sample is represented by an index pointing to the non-zero value in the one-hot vector. The dimension size of the one-hot vector should match that defined in the sampleVariable.

Parameters:

  • sampleVariable: denotes the shape and dynamic axes when copying data from this Value to the sequences.
  • sequences: the output buffer used to store the data copied from the Value.

class Variable

Denotes a symbolic entity corresponding to the inputs and outputs of a Function.

The properties of Variable that are often used in evaluation include:


public string Name { get; }

Name of this Variable.


public NDShape Shape { get; }

Shape of this Variable.

class NDShape

Denotes a multi-dimensional rectangualar shape.

The following properties are available.


public uint Rank { get; }

The rank of this NDShape.


public List<uint> Dimensions { get; }

The dimensions of this NDShape.


public uint TotalSize { get; }

The total size of the rectangular shape that this Shape denotes.


public uint this[int key] { get; }

Returns the dimension size of the specified axis.

public enum VariableKind

Enumeration type denoting the kind of a symbolic Variable object


{
Input = 0,
Output = 1,
Parameter = 2,
Constant = 3,
Placeholder = 4
}

public enum DataType

Enumeration type denoting data type of symbolic data entities or actual data.


{
Unknown = 0,
Float = 1,
Double = 2
}

class Axis

Denotes an Axis of a Variable. Besides the static axes corresponding to each of the axes of the Variable's shape, Variables of kind 'Input' and any 'Output' Variables dependent on an 'Input' Variable also have 2 additional dynamic axes whose dimensions are known only when the Variable is bound to actual data during compute (viz. sequence axis and batch axis denoting the axis along which multiple sequences are batched)

The following properties are defined in the class Axis


public string Name { get; }

Name of this Axis.


public bool IsStatic { get; }

Returns a boolean value indicating whether this Axis corresponds to a static axis.


public bool IsDynamic { get; }

Returns a boolean value indicating whether this Axis corresponds to a dynamic axis.

class DeviceDescriptor

Denotes a computation device instance.

The class DeviceDescriptor contains the following properties and methods:


public uint Id { get; }

The Id of this device.


public DeviceKind Type { get; }

The DeviceKind of this device.


public static DeviceDescriptor CPUDevice { get; }

The DeviceDescriptor representing the CPU device on the local system.


public static DeviceDescriptor GPUDevice(uint deviceId)

Gets the DeviceDescriptor of the GPU device on the local system with the specified CUDA device ID.

Parameter:

  • deviceId: the CUDA device ID.

public enum DeviceKind

Enumeration type denoting the type of a computation device.


{
CPU, // A CPU device.
GPU // A GPU device.
}

Clone this wiki locally