3

可以使用以下几行的 hdf5 数据层在 pycaffe 中编写 caffe prototxt:

import caffe
from caffe import layers as L

def logreg(hdf5, batch_size):
    n = caffe.NetSpec()
    n.data, n.label = L.HDF5Data(batch_size = batch_size, source = hdf5, ntop = 2)
    n.ip1 = L.InnerProduct(n.data, num_output = 2, weight_filler = dict(type='xavier'))
    n.accuracy = L.Accuracy(n.ip1, n.label)
    n.loss = L.SoftmaxWithLoss(n.ip1, n.label)
    return n.to_proto()

with open('models/logreg_auto_train.prototxt', 'w') as f:
    f.write(str(logreg('data/train.txt', chunck_size)))

是否可以使用类似的方法来编写具有内存数据层的 prototxt?

4

1 回答 1

3

尝试这样的事情:

import caffe
from caffe import layers as L

def logreg(height, width, channels, batch_size):
    n = caffe.NetSpec()
    n.data = L.MemoryData(batch_size = batch_size, height = height, width = width, channels = channels)
    n.ip1 = L.InnerProduct(n.data, num_output = 2, weight_filler = dict(type='xavier'))
    return n.to_proto()

with open('models/logreg_memdata.prototxt', 'w') as f:
    f.write(str(logreg(128,128,3, chunck_size)))
于 2016-02-13T05:22:30.503 回答