CNTK LSTM评估

时间:2017-10-26 17:05:16

标签: c# lstm cntk

我无法弄清楚如何在c#.net中为我创建的LSTM网络做评估..任何帮助都会很棒:)

def create_model(x,num_classes,LSTM_dim):
with default_options(initial_state=0.1):
    m =  C.layers.Sequential([
         C.layers.Recurrence(C.layers.LSTM(LSTM_dim), go_backwards=False),
         C.sequence.last,
         C.layers.Dense(num_classes)
    ])
    return m(x);

数据看起来像这样

0 |features 0.23 0.24 0 0.245 0.9723383 -0.1125 |labels -8.88333333333333
0 |features -0.01 0.02 0.23 0.075 0.2361691 -0.1725 
0 |features 0 0.02 -0.01 0.04 0.1574461 -0.1916667 
0 |features 0.02 0.05 0.03 0.15 0.2942928 -0.208125 
0 |features -0.02 0.05 -0.01 0.115 0.09446766 -0.215 
0 |features 0.04 0.09 0.03 0.165 0.2193967 -0.2204167 

我的c#代码...我在c#中的数据是浮点数列表,我尝试在每个6处拼接,但是我在第二个序列上得到以下错误! ......我似乎无法弄清楚我做错了什么:(

  

System.ApplicationException:' GetColumnIndex:尝试访问a   正在访问非序列的一部分的时间步   包含在当前的迷你邮箱中。

public CntkDnn(String FileName)
            {
                device = DeviceDescriptor.GPUDevice(0);
                Function modelFunc2 = Function.Load(FileName, device);
                // var z = CNTK.CNTKLib.Softmax(modelFunc2);
                var z = modelFunc2;
                inputVar = z.Arguments.FirstOrDefault();



                outputVar = z.Output;

                inputShape = inputVar.Shape;

                dataCount = inputShape[0];

                nn = z;
            }
  public List<float> EvalSeq(List<float> input,int SplitBy)
            {
                //if (dataCount != input.Count) return null;
                var output = new List<float>();
                var starting = true;
                for (int jindex = 0; jindex < input.Count; jindex += 6)
                {

                    var thisInput = input.Skip(jindex).Take(6).ToList();
                    var inputDataMap = new Dictionary<Variable, Value>();
                    var inputValue = Value.CreateSequence<float>(inputShape, thisInput, starting, device);

                    inputDataMap.Add(inputVar, inputValue);

                    var outputDataMap = new Dictionary<Variable, Value>();

                    outputDataMap.Add(outputVar, null);

                    nn.Evaluate(inputDataMap, outputDataMap, device);


                    var outputVal = outputDataMap[outputVar];
                    var outputData = outputVal.GetDenseData<float>(outputVar)[0];

                    output.AddRange(outputData.ToList());
                    starting = false;
                }
                return output;
            }

1 个答案:

答案 0 :(得分:0)

带有CNTK的C#的支持非常差。

一个代码示例:

public static Function Model { get; set; }


public Function Load(string modelFilePath, DeviceDescriptor device)
{

    return Function.Load(modelFilePath, device);
}

然后:

public void Evaluate(string word, function model, DeviceDescriptor device)
{

// Create Input Dictionary Pair:
Dictionary<Variable, Value> ModelInput = new Dictionary<Variable, Value>
{
    { model.Arguments.Single(), Value.CreateBatch<float>(XDim, new int[] { 7 }, DeviceDescriptor.GPUDevice(0), true) }
};

// Vector the Model's Output Variable.
Variable OutputVariable = model.Output;

// Create Output Dictionary Pair:
Dictionary<Variable, Value> ModelOutput = new Dictionary<Variable, Value>
{
    { OutputVariable, null }
};

// Evaluate the Model using the Device:
model.Evaluate(ModelInput, ModelOutput, device);

// Vector evaluate result as dense output
IList<IList<float>> OutputValue = ModelOutput[OutputVariable].GetDenseData<float>(OutputVariable);

IList<float> t = OutputValue[0];
int index = t.IndexOf(t.Max());

// Do what you need with your index...

}

注意:

Value.CreateBatch<float>(XDim, new int[] { 7 }

其中7作为单个稀疏变量在输入类长度之内。您会注意到,有更好的方法可以做到这一点,这只是一个非常基本的示例。

我已经建立了一个网站:9.4.,以期在C#和CNTK上取得成功。

我希望这会有所帮助!