批处理模式在Caffe
Batch processing mode in Caffe
我想使用Caffe库来提取图像特征,但我有性能问题。我只能使用CPU模式。我被告知Caffe支持批处理模式,在这种模式下处理一张图像所需的平均时间要慢得多。
我正在调用以下方法:
const vector<Blob<Dtype>*>&
Net::Forward(const vector<Blob<Dtype>* > & bottom, Dtype* loss = NULL);
,我放入一个大小为1的向量,包含以下维度的单个blob - (num: 10, channels: 3, width: 227, height: 227)。它以与官方python包装器相同的方式表示过采样的单个图像。
这可以工作并给出正确的结果。然而,它太慢了。
每当我尝试发送一个包含多个blob(相同维度)的向量时,我得到以下错误:
[p]尝试复制不同大小的blobs .
检查失败堆栈跟踪:
我如何使Caffe处理我的图像在批处理?
如果你想要喂养更大的批次,你需要bottom
中的第一个(也是唯一一个)blob来拥有num>10
。用num=20
喂一个斑点与用oversample=10
喂两个输入相同。当然,您必须根据您正在使用的oversampling
手动执行平均。
此外,您可能希望将deploy.prototxt
文件中的第一个输入维度从10更改为更大的值(取决于您的机器的内存容量)
相关文章:
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 为什么在保护模式下继承升级不起作用
- 如何在全屏模式下(在OpenGL中)使背景透明
- 为什么使用__LINE_的代码在发布模式下在MSVC下编译,而不是在调试模式下
- 派生类是否可以在抽象工厂设计模式中具有数据成员
- 此模式的C++RegEx
- avrogencpp能为模式中的每种类型生成单独的头文件吗
- 使用可变模板的Broadcaster/Listener模式
- c++方法参数只能在linux的发布模式下自行更改
- 资源管理设计模式
- 使用 mod_gsoap 部署服务时,如何在 Gsoap 中更改 soap 上下文的模式?
- C++ 无法在字符数组中使用 for 循环打印字母模式
- 小字符串优化(调试与发布模式)
- 可视化C++:发布模式的运行时库作为'Multi-threaded Debug DLL'
- 如何设计具有不同类型的通知和观察器的观察者模式?
- 在C++的一系列数字中查找重复模式
- 是否允许使用带有"w+"模式的 freopen 进行标准设置?
- C++ 使用存储在动态数组中的文本文件中的数据查找模式
- 批处理模式在Caffe -没有性能增益
- 批处理模式在Caffe