当前位置: 首页 > news >正文

【课程作业】提取图中苹果的面积、周长和最小外接矩形的python、matlab和c++代码

提取图中苹果的面积、周长和最小外接矩形

在图像处理中,提取对象的关键属性是常见的任务之一。本文将演示如何使用三种流行的编程语言——Python、Matlab和C++,利用相应的图像处理库(OpenCV或Matlab内置函数)来提取图像中苹果的面积、周长和最小外接矩形。

问题描述

我们有一张包含苹果的图片,我们想要从这张图片中提取苹果的关键信息,包括:

  • 苹果的面积(以像素为单位)。
  • 苹果的周长(以像素为单位)。
  • 苹果的最小外接矩形的位置和大小。

Python代码

import cv2# 读取图片
image = cv2.imread('apple_image.jpg')# 转换为灰度图像
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 使用阈值分割图像
_, binary = cv2.threshold(gray, 120, 255, cv2.THRESH_BINARY_INV)# 查找轮廓
contours, _ = cv2.findContours(binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)# 假设最大的轮廓为苹果
apple_contour = max(contours, key=cv2.contourArea)# 计算面积和周长
area = cv2.contourArea(apple_contour)
perimeter = cv2.arcLength(apple_contour, True)# 找到最小外接矩形
x, y, w, h = cv2.boundingRect(apple_contour)# 显示结果
print("Area:", area)
print("Perimeter:", perimeter)
print("Bounding Box:", (x, y, w, h))

MATLAB代码

% 读取图片
image = imread('apple_image.jpg');% 转换为灰度图像
grayImage = rgb2gray(image);% 使用阈值分割图像
bwImage = imbinarize(grayImage);% 查找轮廓
contours = bwboundaries(bwImage);% 假设最大的轮廓为苹果
maxArea = 0;
for i = 1:length(contours)area = polyarea(contours{i}(:,2), contours{i}(:,1));if area > maxAreamaxArea = area;appleContour = contours{i};end
end% 计算面积和周长
appleArea = maxArea;
applePerimeter = sum(sqrt(sum(diff(appleContour).^2,2)));% 找到最小外接矩形
rect = regionprops(bwImage,'BoundingBox');
appleRect = rect.BoundingBox;% 显示结果
disp("Area:" + appleArea);
disp("Perimeter:" + applePerimeter);
disp("Bounding Box:" + appleRect);

c++代码

#include <opencv2/opencv.hpp>int main() {// 读取图片cv::Mat image = cv::imread("apple_image.jpg");// 转换为灰度图像cv::Mat gray;cv::cvtColor(image, gray, cv::COLOR_BGR2GRAY);// 使用阈值分割图像cv::Mat thresh;cv::threshold(gray, thresh, 120, 255, cv::THRESH_BINARY_INV);// 查找轮廓std::vector<std::vector<cv::Point>> contours;cv::findContours(thresh, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_SIMPLE);// 假设最大的轮廓为苹果double maxArea = 0;std::vector<cv::Point> appleContour;for (const auto& contour : contours) {double area = cv::contourArea(contour);if (area > maxArea) {maxArea = area;appleContour = contour;}}// 计算面积和周长double appleArea = maxArea;double applePerimeter = cv::arcLength(appleContour, true);// 找到最小外接矩形cv::Rect appleRect = cv::boundingRect(appleContour);// 显示结果std::cout << "Area: " << appleArea << std::endl;std::cout << "Perimeter: " << applePerimeter << std::endl;std::cout << "Bounding Box: " << appleRect << std::endl;return 0;
}
http://www.lryc.cn/news/305635.html

相关文章:

  • 解决easyExcel模板填充时转义字符\{xxx\}失效
  • 在项目中使用CancelToken选择性取消Axios请求
  • [c++] 记录一次引用使用不当导致的 bug
  • 能不能节约百分之九十的算力来训练模型
  • LeetCode206: 反转链表.
  • 高级统计方法 第1次作业
  • spinalhdl,vivado,fpga
  • Tomcat线程池原理(下篇:工作原理)
  • 【服务器数据恢复】通过reed-solomon算法恢复raid6数据的案例
  • LeetCode 2583.二叉树中的第 K 大层和:层序遍历 + 排序
  • element ui 安装 简易过程 已解决
  • websoket
  • 案例:微服务从Java/SpringBoot迁移到Golan
  • 小波变换模拟
  • cv::Mat图像操作
  • 【机器学习基础】一元线性回归(适合初学者的保姆级文章)
  • 2024年软件测试岗位-面试
  • 【坑】Spring Boot整合MyBatis,一级缓存失效
  • J7 - 对于ResNeXt-50算法的思考
  • R3F(React Three Fiber)基础篇
  • torch\tensorflow在大语言模型LLM中的作用
  • 设计模式-创建型模式-单例模式
  • 备战蓝桥杯—— 双指针技巧巧答链表1
  • 微信小程序返回上一级页面并自动刷新数据
  • Spring⼯⼚创建复杂对象
  • Top-N 泛型工具类
  • Java 后端面试指南
  • 142.环形链表 ||
  • Nacos、Eureka、Zookeeper注册中心的区别
  • CSS重点知识整理1