激光条纹中心提取——极值法python

激光条纹中心提取——极值法python

极值法

极值法首先需要获取光条纹横截面的灰度分布函数,并对其进行梯度运算。梯度值等于零处的像素点就是光条纹中横截面灰度极大值点,并将该点作为光条纹中心点。极值法要求激光条纹截面的灰度分布近似成理想高斯分布,由于受到环境噪声的影响,列车轮对表面的激光条纹灰度分布并不是理想的高斯分布,如果在这种情况下使用极值法提取光条纹中心线,得到的光条纹中心点有可能是局部的极值点,造成提取结果出现较大的误差。如图1-5左图所示,当光条的灰度分布成理想的高斯分布式,极值法可以快速的提取出激光光条的中心。在受到噪声干扰时,如图1-5右图所示,最大值已经不再原来的位置,而是到了噪声的地方,因此和真实的光条中心会存在Δo的误差。在信噪比较低的列车轮对的检测环境下,该方法难以适用于动态环境下列车轮对激光条纹中心线的提取。
在这里插入图片描述

python代码

# Maximum value method
import cv2
import numpy as np
import time

def Extreme(img, thresh):
    row,col,chanel = img.shape
    gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
    points= []
    newimage 
  • 1
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以使用Python实现Steger算提取激光条纹中心线。以下是一个简单的示例代码: ```python import cv2 import numpy as np def steger_algorithm(image): # 转换为灰度图像 gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 计算梯度 grad_x = cv2.Sobel(gray, cv2.CV_64F, 1, 0, ksize=3) grad_y = cv2.Sobel(gray, cv2.CV_64F, 0, 1, ksize=3) # 计算梯度幅值和方向 mag, ang = cv2.cartToPolar(grad_x, grad_y) # 进行非最大抑制 mag_max = cv2.dilate(mag, None, iterations=3) mag_mask = np.zeros_like(mag) mag_mask[mag >= mag_max] = 255 # 应用阈值 _, thresholded = cv2.threshold(mag_mask, 50, 255, cv2.THRESH_BINARY) # 进行霍夫直线检测 lines = cv2.HoughLines(thresholded, 1, np.pi/180, 100) # 计算中心线的坐标 center_lines = [] for line in lines: rho, theta = line[0] if theta < np.pi/4 or theta > 3*np.pi/4: x1 = int(rho / np.cos(theta)) y1 = 0 x2 = int((rho - gray.shape[0]*np.sin(theta)) / np.cos(theta)) y2 = gray.shape[0] else: x1 = 0 y1 = int(rho / np.sin(theta)) x2 = gray.shape[1] y2 = int((rho - gray.shape[1]*np.cos(theta)) / np.sin(theta)) center_lines.append((x1, y1, x2, y2)) return center_lines # 读取图像 image = cv2.imread('image.jpg') # 提取中心线 center_lines = steger_algorithm(image) # 绘制中心线 for line in center_lines: x1, y1, x2, y2 = line cv2.line(image, (x1, y1), (x2, y2), (0, 255, 0), 2) # 显示图像 cv2.imshow('Center Lines', image) cv2.waitKey(0) cv2.destroyAllWindows() ``` 请注意,这只是一个简单的示例代码,你可能需要根据你的具体需求进行适当的调整和优化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值