我无法弄清楚如何在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;
}
答案 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上取得成功。
我希望这会有所帮助!