开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 246|回复: 2
收起左侧

[易语言] Opencv 图像裁剪

[复制链接]
结帖率:68% (15/22)
发表于 2025-3-4 08:21:15 | 显示全部楼层 |阅读模式   福建省厦门市
200精币
ONNX模型推理,图像显示,看图不知道是哪的问题
推理第一张图片没问题,到第二张就奔溃了,不知道哪的问题


这里插入完整代码,找问题,例子都是按官方示例写的
  
子程序名返回值类型公开备 注
测试_ONNX  
参数名类 型参考可空数组备 注
模型路劲文本型
图片路径文本型
类Txt文件文本型
模型输入形状Size
变量名类 型静态数组备 注
N整数型 
netNet 
modelInputMat 
class文本型0
classesVectorString 
col整数型 
row整数型 
max整数型 
resultMat 
blobMat 
outputsVectorMat 
classnamesVectorString 
rows整数型 
dimensions整数型 
size整数型0
i整数型 
yolov8逻辑型 
data整数型 
classes_scores整数型 
x_factor小数型 
y_factor小数型 
scoresMat 
dims整数型 
minLocPoint 
maxLocPoint 
maxClassScore双精度小数型 
x小数型 
y小数型 
w小数型 
h小数型 
left整数型 
top整数型 
width整数型 
height整数型 
class_idsVectorint 
confidencesVectorfloat 
boxesVectorRect 
nms_resultVectorint 
modelConfidenceThreshold小数型置信度阈值
modelScoreThreshold小数型分数阈值
modelNMSThreshold小数型NMS阈值
idx整数型 
class_id整数型 
colorScalar 
boxRect 
classString文本型 
textSizeSize 
frameMat 
net = readNetFromONNX (模型路劲)
如果真 (net.empty ())
调试输出 (“加载模型失败!”)
返回 ()
如果真 (是否为空 (类Txt文件))
class = { “person”, “bicycle”, “car”, “motorcycle”, “airplane”, “bus”, “train”, “truck”, “boat”, “traffic light”, “fire hydrant”, “stop sign”, “parking meter”, “bench”, “bird”, “cat”, “dog”, “horse”, “sheep”, “cow”, “elephant”, “bear”, “zebra”, “giraffe”, “backpack”, “umbrella”, “handbag”, “tie”, “suitcase”, “frisbee”, “skis”, “snowboard”, “sports ball”, “kite”, “baseball bat”, “baseball glove”, “skateboard”, “surfboard”, “tennis racket”, “bottle”, “wine glass”, “cup”, “fork”, “knife”, “spoon”, “bowl”, “banana”, “apple”, “sandwich”, “orange”, “broccoli”, “carrot”, “hot dog”, “pizza”, “donut”, “cake”, “chair”, “couch”, “potted plant”, “bed”, “dining table”, “toilet”, “tv”, “laptop”, “mouse”, “remote”, “keyboard”, “cell phone”, “microwave”, “oven”, “toaster”, “sink”, “refrigerator”, “book”, “clock”, “vase”, “scissors”, “teddy bear”, “hair drier”, “toothbrush” }
计次循环首 (取数组成员数 (class), i)
classes.push_back (class [i])
计次循环尾 ()
如果真 (是否为空 (模型输入形状))
模型输入形状.width = 640
模型输入形状.height = 640
net.setPreferableBackend ( #DNN_BACKEND_OPENCV )
net.setPreferableTarget ( #DNN_TARGET_CPU )
net.enableFusion ()  ' 禁用层融合
modelConfidenceThreshold = 0.25
modelScoreThreshold = 0.45
modelNMSThreshold = 0.5
计次循环首 (取数组成员数 (图片路径), N)
modelInput.指针 (imread (图片路径 [N]))
如果真 (modelInput.Empty ())
调试输出 (“读取图片失败!”, 图片路径 [N])
到循环尾 ()
如果真 (模型输入形状.width = 模型输入形状.height)
col = modelInput.Cols ()
row = modelInput.Rows ()
max = 到整数 (最大值 (col, row))
result.zeros (max, max, #CV_8UC3 )
调试输出 (“col: ”到文本 (result.Cols ()) + “ row: ”到文本 (result.Rows ()) + “ channels: ”到文本 (result.channels ()))
modelInput.copyTrect (result, Rect (0, 0, col, row))
调试输出 (“col: ”到文本 (result.Cols ()) + “ row: ”到文本 (result.Rows ()) + “ channels: ”到文本 (result.channels ()))
modelInput = result

blobFromImage2 (modelInput, blob, 1 ÷ 255, 模型输入形状, , 真, )
net.setInput (blob)
classnames = net.getUnconnectedOutLayersNames ()
计次循环首 (classnames.size (), i)
调试输出 (“classnames: ”, classnames.at (i - 1))
计次循环尾 ()
net.forward3 (outputs, classnames)
如果真 (outputs.size () ≤ 0 outputs.empty ())
到循环尾 ()

outputs.at (0).size (size)
rows = size [2]
dimensions = size [3]
调试输出 (“outputs: ”, size [1], rows, dimensions)
如果真 (dimensions > rows)  ' 检查 shape[2] 是否大于 shape[1](yolov8)(yolo11)
yolov8 = 真
rows = size [3]
dimensions = size [2]
' outputs.at (0, outputs.at (0).reshape (1, dimensions))
outputs.IndexReshape (0, 1, dimensions)
transpose (outputs.at (0), outputs.at (0))
data = outputs.at (0).dataToF ()
x_factor = modelInput.Cols () ÷ 模型输入形状.width
y_factor = modelInput.Rows () ÷ 模型输入形状.height
outputs.at (0).size (size)
' 调试输出 (“data : ”, size [1], size [2], 取数组成员数 (size), x_factor, y_factor)
变量循环首 (0, rows - 1, 1, i)
判断 (yolov8)
classes_scores = 指针_到地址_ASM (data, 4, 4)
' 调试输出 (“Mat Data: [ ” + 到文本 (i) + “ ] ” + 到文本 (data) + “ - ” + 到文本 (classes_scores))
scores.NewTData (1, classes.size (), #CV_32FC1, classes_scores)
minMaxLoc (scores, , maxClassScore, minLoc, maxLoc)
如果真 (maxClassScore > modelScoreThreshold)
confidences.push_back (maxClassScore)
class_ids.push_back (maxLoc.x)
x = array_float (data, 0)
y = array_float (data, 1)
w = array_float (data, 2)
h = array_float (data, 3)
left = 取整 ( (x - 0.5 × w) × x_factor)
top = 取整 ( (y - 0.5 × h) × y_factor)
width = 取整 (w × x_factor)
height = 取整 (h × y_factor)
调试输出 (“[ ”到文本 (i)“ ] ”到文本 (x)“ - ”到文本 (y)“ - ”到文本 (w)“ - ”到文本 (h)“ left:”到文本 (left)“ top:”到文本 (top)“ width:”到文本 (width)“ height:”到文本 (height))
boxes.push_back (Rect (left, top, width, height))


' yolov5 ?
data = 指针_到地址_ASM (data, dimensions, 4)
变量循环尾 ()
NMSBoxes (boxes, confidences, modelScoreThreshold, modelNMSThreshold, nms_result)
调试输出 (“完成推理图像 【 ”到文本 (N)“ 】 - ”到文本 (nms_result.size ()))
变量循环首 (0, nms_result.size () - 1, 1, i)
idx = nms_result.at (i)
class_id = class_ids.at (idx)
调试输出 (“idx: ”到文本 (idx)“ class_id : ”到文本 (class_id))
' 绘制物体矩形框
color = Scalar (取随机数 (0, 255), 取随机数 (0, 255), 取随机数 (0, 255), 255)
box = boxes.at (idx)
rectangle2 (result, box, color, 2)
' 计算字体尺寸
classString = classes.at (class_id)“ ”取文本左边 (到文本 (confidences.at (idx)), 4)
textSize = getTextSize (classString, #FONT_HERSHEY_DUPLEX, 1, 0)
' 填充字体背景与显示类别文字
rectangle2 (result, Rect (box.x, box.y - 40, textSize.width + 10, textSize.height + 20), color, #FILLED )
putText (result, classString, Point (box.x + 5, box.y - 10), #FONT_HERSHEY_DUPLEX, 1, Scalar (, , , 100), 2, 0)
变量循环尾 ()
resize (result, frame, Size (result.Cols () × 0.8, result.Rows () × 0.8), , )
imshow (“推理结果”, frame)
waitKey ()
destroyWindow (“推理结果”)
boxes.New ()
confidences.New ()
nms_result.New ()
outputs.New ()
计次循环尾 ()
destroyAllWindows ()
调试输出 (“================================= ok ====================================”)


i支持库列表   支持库注释   
spec特殊功能支持库



补充内容 (2025-3-4 08:25):
第一张检测完,检测第二张报错位置: result.zeros (max, max, #CV_8UC3)

补充内容 (2025-3-4 09:01):
自己找到问题了,是自己代码逻辑没写好,.版本 2

        result.copyTo (modelInput)
        ' modelInput = result
修改一下这句两问题都就解决了

大小没问题,黑色区域为什么还在?

大小没问题,黑色区域为什么还在?

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:68% (15/22)
 楼主| 发表于 2025-3-4 08:30:41 | 显示全部楼层   福建省厦门市
补充错误位置代码:
  
子程序名返回值类型公开备 注
zeros整数型 
参数名类 型参考可空数组备 注
rows整数型int
cols整数型int
type整数型int
Close ()
m_isPtr = 假
m_Mat = Mat_zeros (rows, cols, type)
OutputArray.提交数据 (m_Mat, #指针类型_Mat )
返回 (m_Mat)


DLL定义代码:

Mat _stdcall Mat_zeros(int rows, int cols, int type) {
        return new cv::Mat(cv::Mat::zeros(rows, cols, type));
}

回复

使用道具 举报

结帖率:68% (15/22)
 楼主| 发表于 2025-3-4 08:57:43 | 显示全部楼层   福建省厦门市
@管理员   自己找到问题了,请求删贴
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表