我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【Python图像线条坐标提取】

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【Python图像线条坐标提取】

问题描述:

在进行图像处理时,有时需要对图像上的坐标点进行提取,然后进行曲线拟合,如下图,但是提取的xy坐标会有许多重复的值,影响曲线拟合效果。这里提供三种方法,其它的方法大家可以自行补充。

warn:函数传入的图像是二值化之后的图像,像素只有0和255,如何二值化自行百度。

在这里插入图片描述

1:直接提取黑色的所有点坐标,该方法显而易见,会存在很多重复的x坐标,直接上代码:

def extract_line_position(image):       # 提取坐标,存在bug,会重复提取x的值    list_y = []    list_x = []    # 存储值为0的行号和列号        for i in range(len(image)):        for j in range(len(image[i])):            if image[i][j] == 0:                list_x.append(j)                list_y.append(len(image) - i)    return list_x, list_y

可以看见重复坐标太多,曲线拟合效果并不好

2 直接提取曲线的上边缘坐标,该方法,在曲线较粗或垂直向下时会失真,但是适用于现在的场景,代码如下:

def get_line_position(image):    list_x = []    list_y = []    # y_len = len(image)    # print(y_len)    for i in range(len(image[0])):    #  遍历列数        for j in range(len(image)):   # 遍历行数            if image[j][i] == 0:                list_x.append(i)                list_y.append(len(image)-j)                break    return list_x,list_y

效果还不错

3: 提取曲线上边缘与下边缘的中值来获取位置坐标,代码:

def get_lineMedium_position(image):    image = np.delete(image, 0, axis=0)  # 删除第一行    image = np.delete(image, 0, axis=1)  # 删除第一列    list_x = []    list_y = []    start_index = 0    end_index = 0    for i in range(len(image[0])):  # 遍历列数        for j in range(len(image)-1):  # 遍历行数            if image[j][i] == 255 and image[j+1][i] == 0:                start_index = j                continue            if image[j][i] == 0 and image[j+1][i] == 255:                end_index = j                y_position = (start_index + end_index)/2                list_x.append(i)                list_y.append(len(image) - y_position)                start_index = 0                end_index = 0                break    return list_x, list_y

这里就不上图了,效果挺不错的,不用对曲线进行细化,节省时间,但是要根据实际情况使用。

最后整理了一个类,供大家使用:

import numpy as npimport matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']  # 显示中文plt.rcParams['axes.unicode_minus'] = False  # 正常显示负号"""December 16, 2022,LuoNicus获取曲线分割后的图像点坐标类用不同的方法获取坐标只可提取像素 0 or 255,提取其它自行修改正常提取,上边缘提取,中值提取,各有优缺,根据实际情况使用""""""   图像像素示意    [[255,255, 255, 0,   0]     [0,   0,  255, 0,   0]     [0,   0,  255, 0,   0]     [0,   0,  255, 255,255]]     """class Get_Line_Positon:    def __init__(self, image):        self.image = image        self.list_x = []        self.list_y = []        print("已获取图像信息,准备提取二值图像位置坐标")    def by_allline_point(self):  # 提取坐标,存在bug,会重复提取x的值        # 细化算法存在bug,第一行和第一列为0黑色,不合理,因此首先去掉        print("warn:常规算法提取,容易出现多个x为相同值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        for i in range(len(self.image)):            for j in range(len(self.image[i])):                if self.image[i][j] == 0:                    # print(mask[i][j],j,i)                    self.list_x.append(j)                    self.list_y.append(len(self.image) - i)        return self.list_x, self.list_y    def by_upline_point(self):  # 提取直线坐标,提取曲线的边缘坐标,避免出现x的重复值        print("提取曲线上边缘的值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        # y_len = len(self.image)        # print(y_len)        for i in range(len(self.image[0])):  # 遍历列数            for j in range(len(self.image)):  # 遍历行数                if self.image[j][i] == 0:                    self.list_x.append(i)                    self.list_y.append(len(self.image) - j)                    break        return self.list_x, self.list_y    def by_lineMedium_point(self):  # 提取像素上下值的中位数坐标,该方法不用对函数进行细化        print("提取曲线的中值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        start_index = 0        end_index = 0        for i in range(len(self.image[0])):  # 遍历列数            for j in range(len(self.image) - 1):  # 遍历行数                if self.image[j][i] == 255 and self.image[j + 1][i] == 0:                    start_index = j                    continue                if self.image[j][i] == 0 and self.image[j + 1][i] == 255:                    end_index = j                    y_position = (start_index + end_index) / 2                    self.list_x.append(i)                    self.list_y.append(len(self.image) - y_position)                    start_index = 0                    end_index = 0                    break        return self.list_x, self.list_y

欢迎补充!!

来源地址:https://blog.csdn.net/weixin_49594201/article/details/128343729

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【Python图像线条坐标提取】

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python如何获取图像中像素点坐标

这篇“Python如何获取图像中像素点坐标”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python如何获取图像中像素点坐标
2023-06-30

matlab如何精确提取图像点的坐标

在MATLAB中,可以使用以下方法精确提取图像点的坐标:1. 使用`ginput`函数:该函数允许用户从图像中选择点,并返回所选点的坐标。使用以下代码可以实现:```matlabimshow(image); % 显示图像[x, y] = g
2023-09-14

matlab怎么获取图像坐标

要获取图像的坐标,可以使用MATLAB中的impoint函数。impoint函数创建一个交互式点的对象,可以在图像上点击鼠标获取点的坐标。使用该函数需要提供一个图像作为参数。下面是一个简单的示例代码,演示如何使用impoint函数获取图像坐
2023-08-31

Python图像处理之如何实现目标物体轮廓提取

这篇文章将为大家详细讲解有关Python图像处理之如何实现目标物体轮廓提取,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1 引言目标物体的边缘对图像识别和计算机分析十分有用。边缘可以勾画出目标物体,使观察
2023-06-20

python使用skimage包提取图像的方法

这篇文章主要介绍python使用skimage包提取图像的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、说明skimage.feature.hog()用于提取图像的hog特征。返回特征及特征图像。hog:方向
2023-06-15

python中的opencv图像分割与提取的方法

这篇文章主要介绍了python中的opencv图像分割与提取的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python中的opencv图像分割与提取的方法文章都会有所收获,下面我们一起来看看吧。图像分割与
2023-06-30

Python中人脸图像特征提取方法(HOG、Dlib、CNN)简述

目录人脸图像特征提取方法(一)HOG特征提取(二)Dlib库(三)卷积神经网络特征提取(CNN)人脸图像特征提取方法 (一)HOG特征提取 1、HOG简介 Histogram of Oriented Gridients,缩写为HOG,是目前
2022-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录