OpenCV 4.11.0
开源计算机视觉
加载中…
搜索中…
无匹配项
cv::dnn::ClassificationModel 类参考

此类表示分类模型的高级 API。更多…

#include <opencv2/dnn/dnn.hpp>

cv::dnn::ClassificationModel 的协作图

公共成员函数

 ClassificationModel ()
 
 ClassificationModel (const Net &network)
 从深度学习网络创建模型。
 
 ClassificationModel (CV_WRAP_FILE_PATH const String &model, CV_WRAP_FILE_PATH const String &config="")
 从以一种受支持的格式表示的网络创建分类模型。modelconfig 参数的顺序无关紧要。
 
std::pair< int, float > classify (InputArray frame)
 给定input帧,创建输入 blob,运行网络并返回 top-1 预测。
 
void classify (InputArray frame, int &classId, float &conf)
 
bool getEnableSoftmaxPostProcessing () const
 获取启用/禁用 softmax 后处理选项。
 
ClassificationModelsetEnableSoftmaxPostProcessing (bool enable)
 设置启用/禁用 softmax 后处理选项。
 
- 从 cv::dnn::Model 继承的公共成员函数
 Model ()
 
 Model (const Model &)=default
 
 Model (const Net &network)
 从深度学习网络创建模型。
 
 Model (CV_WRAP_FILE_PATH const String &model, CV_WRAP_FILE_PATH const String &config="")
 从以一种受支持的格式表示的深度学习网络创建模型。modelconfig 参数的顺序无关紧要。
 
 Model (Model &&)=default
 
ModelenableWinograd (bool useWinograd)
 
Impl * getImpl () const
 
Impl & getImplRef () const
 
NetgetNetwork_ ()
 
NetgetNetwork_ () const
 
 operator Net & () const
 
Modeloperator= (const Model &)=default
 
Modeloperator= (Model &&)=default
 
void predict (InputArray frame, OutputArrayOfArrays outs) const
 给定input帧,创建输入 blob,运行网络并返回输出blobs
 
ModelsetInputCrop (bool crop)
 设置帧的裁剪标志。
 
ModelsetInputMean (const Scalar &mean)
 设置帧的均值。
 
void setInputParams (double scale=1.0, const Size &size=Size(), const Scalar &mean=Scalar(), bool swapRB=false, bool crop=false)
 设置帧的预处理参数。
 
ModelsetInputScale (const Scalar &scale)
 设置帧的比例因子。
 
ModelsetInputSize (const Size &size)
 设置帧的输入大小。
 
ModelsetInputSize (int width, int height)
 
ModelsetInputSwapRB (bool swapRB)
 设置帧的 swapRB 标志。
 
ModelsetOutputNames (const std::vector< String > &outNames)
 设置帧的输出名称。
 
ModelsetPreferableBackend (dnn::Backend backendId)
 
ModelsetPreferableTarget (dnn::Target targetId)
 

其他继承成员

- 从 cv::dnn::Model 继承的受保护属性
Ptr< Impl > impl
 

详细描述

此类表示分类模型的高级 API。

ClassificationModel 允许设置预处理输入图像的参数。ClassificationModel 从包含训练权重和配置的文件中创建网络,设置输入预处理,运行前向传递并返回 top-1 预测。

构造函数和析构函数文档

◆ ClassificationModel() [1/3]

cv::dnn::ClassificationModel::ClassificationModel ( )
Python
cv.dnn.ClassificationModel(model[, config]) -> <dnn_ClassificationModel 对象>
cv.dnn.ClassificationModel(network) -> <dnn_ClassificationModel 对象>

◆ ClassificationModel() [2/3]

cv::dnn::ClassificationModel::ClassificationModel ( CV_WRAP_FILE_PATH const String & model,
CV_WRAP_FILE_PATH const String & config = "" )
Python
cv.dnn.ClassificationModel(model[, config]) -> <dnn_ClassificationModel 对象>
cv.dnn.ClassificationModel(network) -> <dnn_ClassificationModel 对象>

从以一种受支持的格式表示的网络创建分类模型。modelconfig 参数的顺序无关紧要。

参数
[输入]model包含已训练权重的二进制文件。
[输入]config包含网络配置的文本文件。

◆ ClassificationModel() [3/3]

cv::dnn::ClassificationModel::ClassificationModel ( const Net & network)
Python
cv.dnn.ClassificationModel(model[, config]) -> <dnn_ClassificationModel 对象>
cv.dnn.ClassificationModel(network) -> <dnn_ClassificationModel 对象>

从深度学习网络创建模型。

参数
[输入]networkNet 对象。

成员函数文档

◆ classify() [1/2]

std::pair< int, float > cv::dnn::ClassificationModel::classify ( 输入数组 frame)
Python
cv.dnn.ClassificationModel.classify(frame) -> classId, conf

给定input帧,创建输入 blob,运行网络并返回 top-1 预测。

参数
[输入]frame输入图像。

◆ classify() [2/2]

void cv::dnn::ClassificationModel::classify ( 输入数组 frame,
int & classId,
float & conf )
Python
cv.dnn.ClassificationModel.classify(frame) -> classId, conf

这是一个重载的成员函数,为了方便提供。它与上面的函数的区别仅在于它接受的参数。

◆ getEnableSoftmaxPostProcessing()

bool cv::dnn::ClassificationModel::getEnableSoftmaxPostProcessing ( ) const
Python
cv.dnn.ClassificationModel.getEnableSoftmaxPostProcessing() -> retval

获取启用/禁用 softmax 后处理选项。

此选项默认为 false,在 classify() 函数中不应用 softmax 后处理。

◆ setEnableSoftmaxPostProcessing()

ClassificationModel & cv::dnn::ClassificationModel::setEnableSoftmaxPostProcessing ( bool enable)
Python
cv.dnn.ClassificationModel.setEnableSoftmaxPostProcessing(enable) -> retval

设置启用/禁用 softmax 后处理选项。

如果此选项为 true,则在 classify() 函数中的前向推理后应用 softmax,将置信度范围转换为 [0.0-1.0]。此函数允许您切换此行为。如果模型中不包含 softmax 层,请将其设置为 true。

参数
[输入]enable设置 classify() 函数中的 softmax 后处理启用状态。

此类的文档是从以下文件生成的