代码拉取完成,页面将自动刷新
同步操作将从 mynameisi/hed_autocanny 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
# 该函数使用预训练的 HED (Holistically-Nested Edge Detection) 模型来检测图像中的边缘。
# 通过使用 OpenCV 库加载模型并传递输入图像,该函数生成并返回二值化的边缘检测结果。
# 参数:
# img_rgb (numpy.ndarray): 输入的 RGB 图像,图像尺寸应为 (height, width, 3)。
# blur_window (int, 可选): 用于对输入图像和边缘检测结果进行高斯模糊的窗口大小。默认值为 5。
# scalefactor (float, 可选): 输入图像在创建 blob 时的缩放系数。默认值为 1.0。
# 返回:
# hed (numpy.ndarray): 二值化的边缘检测结果,图像尺寸与输入图像相同。
# 示例:
# >>> img = cv2.imread("example.jpg")
# >>> hed = get_hed(img)
# >>> plt.imshow(hed)
import cv2
import numpy as np
from tqdm import tqdm
import time
def get_hed(img_rgb, blur_window=5, scalefactor=1.0):
# 加载预训练的 HED 模型
net = cv2.dnn.readNetFromCaffe("model/deploy.prototxt", "model/hed_pretrained_bsds.caffemodel")
# 将图像转换为 blob
blob = cv2.dnn.blobFromImage(img_rgb, scalefactor=scalefactor, size=(500, 500), mean=(104.00698793, 116.66876762, 122.67891434))
# 设置 blob 为网络的输入
net.setInput(blob)
# 使用 tqdm 显示前向传播的进度
start = 0 # 起始值
end = 10 # 结束值
num_elements = 100 # 元素个数
linspace_list = np.linspace(start, end, num_elements) # 生成列表
for element in tqdm(linspace_list, desc="提示词: ", unit="每秒的单位"):
#for _ in tqdm(range(1), desc="Processing", unit="image"):
# 进行前向传播,得到预测结果
hed = net.forward()
time.sleep(0.1)
# 将预测结果转换为二值化的边缘检测结果
hed = cv2.resize(hed[0, 0], (img_rgb.shape[1], img_rgb.shape[0]))
hed = cv2.blur(hed, (blur_window, blur_window))
hed = cv2.convertScaleAbs(hed) # 将数据类型转换为CV_8UC1
_, hed = cv2.threshold(hed, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
return hed
# 该函数通过比较输入的灰度图像与 HED 边缘检测结果之间的均方误差 (MSE),自动选择最佳的 Canny 边缘检测阈值参数。使用最佳阈值参数计算最终的边缘检测结果。
# 参数:
# img_gray (numpy.ndarray): 输入的灰度图像,图像尺寸应为 (height, width)。
# hed (numpy.ndarray): 使用 HED 模型生成的边缘检测结果,图像尺寸应与输入灰度图像相同。
# 返回:
# edge_img (numpy.ndarray): 使用最佳阈值参数生成的 Canny 边缘检测结果。
# best_params (tuple): 包含最佳阈值参数的元组,格式为 (best_sigma, min_mse, lower, upper)。
# best_sigma: 为具有最低MSE的sigma值
# min_mse: 最低的mse值
# lower, upper: 用best_sigma进行canny时的上下限
# plot_data (tuple): 包含用于绘制 MSE 与 sigma 值关系图的数据,格式为 (sigma_values, mse_values)。
# sigma_values: 所有测试过的sigma_value,建议范围从0.001到1.0实验100个值
# mse_values: 对于每一个sigma的mse值
# 示例:
# >>> img_gray = cv2.cvtColor(cv2.imread("example.jpg"), cv2.COLOR_BGR2GRAY)
# >>> hed = get_hed(cv2.imread("example.jpg"))
# >>> edge_img, best_params, plot_data = auto_canny(img_gray, hed)
# >>> plt.imshow(edge_img)
def auto_canny(img_gray, hed):
# 将输入图像转换为 8 位无符号整数
img_gray = cv2.convertScaleAbs(img_gray)
hed = cv2.convertScaleAbs(hed)
# 使用Otsu's阈值法对HED进行二值化
_, hed = cv2.threshold(hed, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
best_sigma = None
min_mse = float('inf')
lower = None
upper = None
# 初始化sigma值的范围
sigma_values = np.linspace(0.001, 1.0, 100)
mse_values = []
# 遍历sigma值,找到最佳的sigma
for sigma in sigma_values:
v = np.median(img_gray)
lower = int(max(0, (1.0 - sigma) * v))
upper = int(min(255, (1.0 + sigma) * v))
# 应用Canny边缘检测
edge_img = cv2.Canny(img_gray, lower, upper)
# 计算当前sigma下Canny边缘检测图像与HED图像之间的均方误差(MSE)
mse = np.mean((edge_img - hed) ** 2)
mse_values.append(mse)
if mse < min_mse:
min_mse = mse
best_sigma = sigma
# 使用最佳的 sigma 值进行 Canny 边缘检测
v = np.median(img_gray)
lower = int(max(0, (1.0 - best_sigma) * v))
upper = int(min(255, (1.0 + best_sigma) * v))
edge_img = cv2.Canny(img_gray, lower, upper)
return edge_img, (best_sigma, min_mse, lower, upper), (sigma_values, mse_values)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。