blur_mean = cv2.blur(img, (5, 5)) blur_box = cv2.boxFilter(img, -1, (5, 5)) blur_gaussian = cv2.GaussianBlur(img, (5, 5), 0) blur_median = cv2.medianBlur(img, 5) cv2.imshow('Mean Filter', blur_mean) cv2.imshow('Box Filter', blur_box) cv2.imshow('Gaussian Filter', blur_gaussian) cv2.imshow('Median Filter', blur_median) cv2.waitKey(0)

时间: 2024-02-16 19:01:39 浏览: 175
这是一段使用OpenCV库对图片进行平滑处理的Python代码。具体来说,它通过cv2.imread()函数读取了一张图片,然后分别使用cv2.blur()函数、cv2.boxFilter()函数、cv2.GaussianBlur()函数和cv2.medianBlur()函数对图片进行了平滑处理,生成了四个处理后的图片。这四个函数分别代表了均值滤波、方框滤波、高斯滤波和中值滤波四种平滑处理方法。最后,使用cv2.imshow()函数将这四张处理后的图片显示出来,通过cv2.waitKey(0)函数等待用户输入后关闭窗口。
相关问题

opencv python 图像处理 使用高斯滤波+cv2.adaptiveThreshold+canny算法 进行轮廓提取得到contours 在contours提取出面积不小于一定阈值threshold_area且两边接近平行于x轴、两边接近平行于y轴的矩形轮廓contour_rec 同时进行霍夫变化cv2.HoughLinesP得到直线lines 遍历lines 得到x1, y1, x2, y2 ,然后计算直线的斜率:slope = abs((y2 - y1) / (x2 - x1 + 0.001)) # 防止分母为0 通过直线的斜率筛选出相对水平与相对垂直的线:if slope > 5.5 or slope<0.17: # 如果斜率大于5.5,则认为是垂直线段 用筛选出相对水平与相对垂直的线去与对比矩形轮廓 若直线大部分与轮廓贴合 则画出该轮廓 能帮我用代码示例嘛

当然可以,以下是代码示例: ``` import cv2 import numpy as np # 读取图像 img = cv2.imread('test.jpg') # 灰度化 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 高斯滤波 blur = cv2.GaussianBlur(gray, (5, 5), 0) # 自适应阈值化 th = cv2.adaptiveThreshold(blur, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY_INV, 11, 2) # Canny边缘检测 edges = cv2.Canny(th, 30, 150) # 轮廓提取 contours, hierarchy = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # 遍历轮廓 for contour in contours: # 计算轮廓面积 area = cv2.contourArea(contour) # 过滤面积小于阈值的轮廓 if area < threshold_area: continue # 计算轮廓外接矩形 rect = cv2.minAreaRect(contour) box = cv2.boxPoints(rect) box = np.int0(box) # 计算外接矩形的长宽 width = rect[1][0] height = rect[1][1] # 过滤长宽比例不合适的矩形 if width / height > 5 or height / width > 5: continue # 霍夫变换检测直线 lines = cv2.HoughLinesP(edges, 1, np.pi / 180, 50, minLineLength=50, maxLineGap=10) # 遍历直线 for line in lines: x1, y1, x2, y2 = line[0] # 计算直线斜率 slope = abs((y2 - y1) / (x2 - x1 + 0.001)) # 过滤斜率不合适的直线 if slope > 5.5 or slope < 0.17: continue # 判断直线是否与矩形贴合 if abs(y2 - y1) > abs(x2 - x1): # 直线接近水平,判断是否与矩形上下两条边贴合 if abs(y1 - box[0][1]) < 10 or abs(y1 - box[1][1]) < 10: # 绘制矩形 cv2.drawContours(img, [box], 0, (0, 0, 255), 2) break else: # 直线接近垂直,判断是否与矩形左右两条边贴合 if abs(x1 - box[0][0]) < 10 or abs(x1 - box[1][0]) < 10: # 绘制矩形 cv2.drawContours(img, [box], 0, (0, 0, 255), 2) break # 显示结果 cv2.imshow('result', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这段代码中需要自己定义阈值`threshold_area`,表示过滤掉面积小于该值的轮廓。

帮我解释下面的代码import cv2 img=cv2.imread('C:/Users/Administrator/Desktop/1.jfif') img_mean = cv2.blur(img, (5, 5)) img_box = cv2.boxFilter(img, -1, (5, 5)) img_median = cv2.medianBlur(img, 5) img_gussian = cv2.GaussianBlur(img, (5, 5), 0) cv2.imshow('gs',img_gaussin) cv2.imshow('jz',img_mean) cv2.imshow('fk',img_box) cv2.imshow('zz',img_median) cv2.waitKey(0)

这段代码使用了OpenCV库对一张名为1.jfif的图像进行了四种不同类型的滤波处理,并将处理后的图像显示在窗口中。具体来说,它首先使用cv2.imread函数读取了这张图像,并将其存储为一个numpy数组img。然后,它分别使用cv2.blur、cv2.boxFilter、cv2.medianBlur和cv2.GaussianBlur四个函数对img进行了不同类型的滤波处理,生成了四个新的图像img_mean、img_box、img_median和img_gaussian。这四个函数分别对应了均值滤波、方框滤波、中值滤波和高斯滤波四种不同类型的滤波器。 最后,它使用cv2.imshow函数将这四张图像显示在不同的窗口中,并使用cv2.waitKey函数等待用户按下一个按键才关闭窗口。
阅读全文

相关推荐

import cv2 import numpy as np # 初始化摄像头 cap = cv2.VideoCapture(0) if not cap.isOpened(): print("无法打开摄像头") exit() def process_frame(frame): """ 主处理函数: 输入一帧画面 -> 输出带标注的画面 """ # 转灰度图 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) # 应用高斯模糊降噪 blurred = cv2.GaussianBlur(gray, (9, 9), 0) # 边缘检测(Canny Edge Detection) edges = cv2.Canny(blurred, threshold1=50, threshold2=150) # 寻找所有轮廓 contours, _ = cv2.findContours(edges.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) boxes = [] for contour in contours: # 过滤小尺寸噪声 if cv2.contourArea(contour) < 100: continue # 最小面积矩形拟合 rect = cv2.minAreaRect(contour) # 获取四个角点 box = np.intp(cv2.boxPoints(rect)) boxes.append(box) return frame, boxes # 平滑缓冲区设定 last_boxes = None while True: ret, frame = cap.read() if not ret: break original_frame = frame.copy() # 保留原图用于显示 processed_frame, detected_boxes = process_frame(original_frame) # 如果有新盒子,则更新缓冲区 if len(detected_boxes) > 0 and last_boxes is not None: # 检测是否变化过大,若未变则沿用之前的结果避免频繁闪烁 diff = abs(len(last_boxes) - len(detected_boxes)) <= 1 if diff: detected_boxes = last_boxes # 更新缓存 last_boxes = detected_boxes # 绘制结果 for i, box in enumerate(detected_boxes): color = (np.random.randint(0, 256), np.random.randint(0, 256), np.random.randint(0, 256)) cv2.drawContours(processed_frame, [box], -1, color, thickness=2) x_avg = int(np.mean([point[0] for point in box])) y_avg = int(np.mean([point[1] for point in box])) cv2.putText(processed_frame, f"Box-{i+1}", (x_avg, y_avg), cv2.FONT_HERSHEY_SIMPLEX, 0.7, color, 2) # 展示效果 cv2.imshow("Long Cube Detector", processed_frame) key = cv2.waitKey(1) if key == ord('q'): # 按 Q 键退出程序 break # 清理资源 cap.release() cv2.destroyAllWindows()提高识别稳定性

王乐予已于 2024-01-06 18:11:11 修改阅读量1w 收藏 265点赞数 33分类专栏: 图像处理 文章标签: 计算机视觉 python opencv 图像处理版权华为开发者空间该内容已被华为云开发者联盟社区收录加入社区图像处理专栏收录该内容30 篇文章订阅专栏✨博客主页:王乐予🎈✨年轻人要:Living for the moment(活在当下)!💪🏆推荐专栏:【图像处理】【千锤百炼Python】【深度学习】【排序算法】目录😺一、引言🐶1.1 图像用例🐶1.2 评价指标🐶1.3 定义图像质量评价函数😺二、均值滤波🐶2.1 滤波原理🐶2.2 实验过程🦄2.2.1 程序设计🦄2.2.2 实验结果🦄2.2.3 指标参数😺三、中值滤波🐶3.1 滤波原理🐶3.2 实验过程🦄3.2.1 程序设计🦄3.2.2 实验结果🦄3.2.3 指标参数😺四、方框滤波🐶4.1 滤波原理🐶4.2 实验过程🦄4.2.1 程序设计🦄4.2.2 实验结果🦄4.2.3 指标参数😺五、双边滤波🐶5.1 滤波原理🐶5.2 实验过程🦄5.2.1 程序设计🦄5.2.2 实验结果🦄5.2.3 指标参数😺六、高斯滤波🐶6.1 滤波原理🐶6.2 实验过程🦄6.2.1 程序设计🦄6.2.2 实验结果🦄6.2.3 指标参数😺七、全部代码本节将对经过噪声污染的图像进行去噪,去噪方法包含均值滤波、中值滤波、方框滤波、双边滤波和高斯滤波。😺一、引言🐶1.1 图像用例实验所用的图像为【OpenCV-Python】:对图像添加高斯噪声与椒盐噪声中得到的均值为0,方差为0.01的高斯噪声污染图像和噪声密度为0.05的椒盐噪声污染图像,如图所示:🐶1.2 评价指标为了评判去噪质量的好坏,我们将选取PSNR、SSIM和MSE作为评价指标!评价指标见:【OpenCV-Python】:图像PSNR、SSIM、MSE计算🐶1.3 定义图像质量评价函数def compare(ori, gaussian_denosing, sp_denosing): # ori为原图(未被噪声污染的图),gaussian_denosing为经过高斯噪声污染的图通过去噪算法去噪后的图;sp_denosing为经过椒盐噪声污染的图通过去噪算法去噪后的图 gaussian_psnr = compare_psnr(ori, gaussian_denosing) sp_psnr = compare_psnr(ori, sp_denosing) gaussian_ssim = compare_ssim(ori, gaussian_denosing, multichannel=True) sp_ssim = compare_ssim(ori, sp_denosing, multichannel=True) gaussian_mse = compare_mse(ori, gaussian_denosing) sp_mse = compare_mse(ori, sp_denosing) return gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse12345678910111213😺二、均值滤波🐶2.1 滤波原理均值滤波也称线性滤波,它是指使用一个模板在原图上进行均值计算并替换原图的值。均值滤波器的模板有标准像素平均和加权平均之分,一个3 × 3 3×33×3大小的模板如下图所示:🐶2.2 实验过程使用函数:cv2.blur()🦄2.2.1 程序设计"""均值滤波"""gaussian_blur = cv2.blur(gaussian_img, (3, 3))sp_blur = cv2.blur(sp_img, (3, 3))h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imshow('out', v)cv2.waitKey()12345678910🦄2.2.2 实验结果第一幅图为被高斯噪声污染的图像;第二幅图为使用均值滤波对第一幅图去噪后的图像;第三幅图为被椒盐噪声污染的图像;第四幅图为使用均值滤波对第三幅图去噪后的图像。🦄2.2.3 指标参数gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('均值滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('均值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))123结果为:均值滤波对高斯噪声污染图像去噪后的指标为:PSNR:27.51495578617511,SSIM:0.7044879580272968,MSE:115.23509979248047均值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:25.66665449076371,SSIM:0.5821969899711158,MSE:176.3660189310709512从指标结果可以看出,均值滤波对高斯噪声的去除能力更强!😺三、中值滤波🐶3.1 滤波原理中值滤波是把图像中的一点用该点的一个邻域中的各值的中值代替。🐶3.2 实验过程使用函数:cv2.medianBlur()🦄3.2.1 程序设计gaussian_blur = cv2.medianBlur(gaussian_img, (3, 3))sp_blur = cv2.medianBlur(sp_img, (3, 3))h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\median_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()12345678🦄3.2.2 实验结果第一幅图为被高斯噪声污染的图像;第二幅图为使用中值滤波对第一幅图去噪后的图像;第三幅图为被椒盐噪声污染的图像;第四幅图为使用中值滤波对第三幅图去噪后的图像。🦄3.2.3 指标参数gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('中值滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('中值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))123结果为:中值滤波对高斯噪声污染图像去噪后的指标为:PSNR:26.882078435438537,SSIM:0.6406334892144118,MSE:133.31300481160483中值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:28.5392567826037,SSIM:0.7218574470291008,MSE:91.023741404215512从指标结果可以看出,中值滤波对椒盐噪声的去除能力更强!😺四、方框滤波🐶4.1 滤波原理方框滤波又称盒子滤波,方框滤波中可以自由选择是否对均值滤波的结果进行归一化,即可以自由选择滤波结果是邻域像素值之和的平均值(均值滤波),还是邻域像素值之和。也就是说均值滤波是方框滤波的特殊情况。方框滤波卷积核可以表示为:K = 1 α [ 1 1 1 ⋯ 1 1 1 1 1 ⋯ 1 1 ⋯ ⋯ ⋯ ⋯ ⋯ ⋯ 1 1 1 ⋯ 1 1 1 1 1 ⋯ 1 1 1 1 1 ⋯ 1 1 ] K=\frac{1}{\alpha }⎡⎣⎢⎢⎢⎢⎢⎢⎢⎢11⋯11111⋯11111⋯111⋯⋯⋯⋯⋯⋯11⋯11111⋯111⎤⎦⎥⎥⎥⎥⎥⎥⎥⎥[111⋯11111⋯11⋯⋯⋯⋯⋯⋯111⋯11111⋯11111⋯11]K= α1​ ​ 11⋯111​ 11⋯111​ 11⋯111​ ⋯⋯⋯⋯⋯⋯​ 11⋯111​ 11⋯111​ ​ 上式的对应关系为:α = { 1 w i d t h × h e i g h t n o r m a l i z e = 1 1 n o r m a l i z e = 0 \alpha =\left\{1width×height1normalize=1normalize=01𝑤𝑖𝑑𝑡ℎ×ℎ𝑒𝑖𝑔ℎ𝑡𝑛𝑜𝑟𝑚𝑎𝑙𝑖𝑧𝑒=11𝑛𝑜𝑟𝑚𝑎𝑙𝑖𝑧𝑒=0\right.α={ width×height1​ 1​ normalize=1normalize=0​ 🐶4.2 实验过程使用函数:cv2.boxFilter(src, ddepth, ksize, anchor, normalize, borderType)参数说明:src:输入图像;ddepth:图像深度,-1表示用原图深度;ksize:内核大小;anchor:锚点,默认为(-1,-1),表示当前计算均值的点位于核的中心点位置;normalize:表示是否进行归一化处理,值为1,进行归一化处理;值为0,不进行归一化处理;borderType:表示以何种方式处理边界,默认即可。🦄4.2.1 程序设计"""方框滤波"""gaussian_blur = cv2.boxFilter(gaussian_img, -1, (3, 3), normalize=0)sp_blur = cv2.boxFilter(sp_img, -1, (3, 3), normalize=0)h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\box_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()1234567891011🦄4.2.2 实验结果第一幅图为被高斯噪声污染的图像;第二幅图为使用方框滤波对第一幅图去噪后的图像;第三幅图为被椒盐噪声污染的图像;第四幅图为使用方框滤波对第三幅图去噪后的图像。由图可知,不经过归一化的方框滤波很容易出现大面积的白色。🦄4.2.3 指标参数gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('方框滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('方框滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))123结果为:方框滤波对高斯噪声污染图像去噪后的指标为:PSNR:5.251255346836561,SSIM:0.415694536225471,MSE:19406.84003829956方框滤波对椒盐噪声污染图像去噪后的指标为:PSNR:5.328992238651672,SSIM:0.41684132817868463,MSE:19062.55619684855312😺五、双边滤波🐶5.1 滤波原理双边滤波是一种非线性的滤波方法,其同时考虑空间几何距离与灰度相似性。🐶5.2 实验过程使用函数:cv2.bilateralFilter(src, d, sigmaColor, sigmaSpace[, dst[, borderType]])参数说明:src:输入图像;d:滤波期间使用的每个像素邻域的直径,如果其值为非正数,则从sigmaSpace计算;sigmaColor:在颜色空间中过滤sigma,较大的参数意味着像素邻域内较远的颜色将相互影响;sigmaSpace:在几何空间中过滤sigma,较大的参数意味着更远的像素将相互影响;🦄5.2.1 程序设计"""双边滤波"""gaussian_blur = cv2.bilateralFilter(gaussian_img, 25, 100, 100)sp_blur = cv2.bilateralFilter(sp_img, 25, 100, 100)h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\bilateral_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()1234567891011🦄5.2.2 实验结果第一幅图为被高斯噪声污染的图像;第二幅图为使用双边滤波对第一幅图去噪后的图像;第三幅图为被椒盐噪声污染的图像;第四幅图为使用双边滤波对第三幅图去噪后的图像。🦄5.2.3 指标参数gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('双边滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('双边滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))123结果为:双边滤波对高斯噪声污染图像去噪后的指标为:PSNR:25.992916512934414,SSIM:0.6635250024737996,MSE:163.60203806559244双边滤波对椒盐噪声污染图像去噪后的指标为:PSNR:21.06964250996061,SSIM:0.3879879230675302,MSE:508.295318603515612从指标结果可以看出,双边滤波对高斯噪声的去除能力更强!😺六、高斯滤波🐶6.1 滤波原理在实际滤波中,将当前像素作为核中心,利用卷积核对周围邻域像素作加权平均,其值作为当前像素的新值。高斯滤波步骤:移动相关核的中心元素,使它位于输入图像待处理像素的正上方;将输入图像的像素值作为权重,乘以相关核;将上面各步得到的结果相加做为输出。简单来说就是根据高斯分布得到高斯模板然后做卷积相加的一个过程。https://www.cnblogs.com/kensporger/p/11628050.htmlhttps://www.jianshu.com/p/73e6ccbd8f3f🐶6.2 实验过程使用函数:cv2.GaussianBlur(src, ksize, sigmaX [ , dst [ , sigmaY [ , borderType ] ] ] )参数说明:src:输入图像;ksize:高斯核大小,必须是正数和奇数;sigmaX:X方向的高斯核标准差;sigmaY:Y方向的高斯核标准差;如果该值为0,则默认为与sigma相等。borderType:边界处理方式。🦄6.2.1 程序设计"""高斯滤波"""gaussian_blur = cv2.GaussianBlur(gaussian_img, (5, 5), 0, 0)sp_blur = cv2.GaussianBlur(sp_img, (5, 5), 0, 0)h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\gaussian_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()1234567891011🦄6.2.2 实验结果第一幅图为被高斯噪声污染的图像;第二幅图为使用高斯滤波对第一幅图去噪后的图像;第三幅图为被椒盐噪声污染的图像;第四幅图为使用高斯滤波对第三幅图去噪后的图像。🦄6.2.3 指标参数gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('高斯滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('高斯滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))123结果为:高斯滤波对高斯噪声污染图像去噪后的指标为:PSNR:27.80345326784865,SSIM:0.7496298168722767,MSE:107.82886505126953高斯滤波对椒盐噪声污染图像去噪后的指标为:PSNR:26.360239863855103,SSIM:0.6420068535144939,MSE:150.3337097167968812从指标结果可以看出,高斯滤波对高斯噪声的去除能力更强!😺七、全部代码import numpy as npimport cv2from skimage.measure import compare_ssim, compare_psnr, compare_mseoriginal = cv2.imread(r"C:\Users\Lenovo\Desktop\DIP\lena1.jpg")gaussian_img = cv2.imread(r"C:\Users\Lenovo\Desktop\DIP\gaussian.jpg")sp_img = cv2.imread(r"C:\Users\Lenovo\Desktop\DIP\sp.jpg")def compare(ori, gaussian_denosing, sp_denosing): # ori为原图(未被噪声污染的图),gaussian_denosing为经过高斯噪声污染的图通过去噪算法去噪后的图;sp_denosing为经过椒盐噪声污染的图通过去噪算法去噪后的图 gaussian_psnr = compare_psnr(ori, gaussian_denosing) sp_psnr = compare_psnr(ori, sp_denosing) gaussian_ssim = compare_ssim(ori, gaussian_denosing, multichannel=True) sp_ssim = compare_ssim(ori, sp_denosing, multichannel=True) gaussian_mse = compare_mse(ori, gaussian_denosing) sp_mse = compare_mse(ori, sp_denosing) return gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse"""均值滤波"""gaussian_blur = cv2.blur(gaussian_img, (3, 3))sp_blur = cv2.blur(sp_img, (3, 3))h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\mean_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('均值滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('均值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))"""中值滤波"""gaussian_blur = cv2.medianBlur(gaussian_img, 3)sp_blur = cv2.medianBlur(sp_img, 3)h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desktop\DIP\median_filter.jpg", v)cv2.imshow('out', v)cv2.waitKey()gaussian_psnr, sp_psnr, gaussian_ssim, sp_ssim, gaussian_mse, sp_mse = compare(original, gaussian_blur, sp_blur)print('中值滤波对高斯噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(gaussian_psnr, gaussian_ssim, gaussian_mse))print('中值滤波对椒盐噪声污染图像去噪后的指标为:PSNR:{},SSIM:{},MSE:{}'.format(sp_psnr, sp_ssim, sp_mse))"""方框滤波"""gaussian_blur = cv2.boxFilter(gaussian_img, -1, (3, 3), normalize=0)sp_blur = cv2.boxFilter(sp_img, -1, (3, 3), normalize=0)h1 = np.hstack([gaussian_img, gaussian_blur])h2 = np.hstack([sp_img, sp_blur])v = np.vstack([h1, h2])cv2.imwrite(r"C:\Users\Lenovo\Desk

最新推荐

recommend-type

(完整版)基因工程药物干扰素的制备.ppt

(完整版)基因工程药物干扰素的制备.ppt
recommend-type

Web2.0新特征图解解析

Web2.0是互联网发展的一个阶段,相对于早期的Web1.0时代,Web2.0具有以下显著特征和知识点: ### Web2.0的定义与特点 1. **用户参与内容生产**: - Web2.0的一个核心特征是用户不再是被动接收信息的消费者,而是成为了内容的生产者。这标志着“读写网络”的开始,用户可以在网络上发布信息、评论、博客、视频等内容。 2. **信息个性化定制**: - Web2.0时代,用户可以根据自己的喜好对信息进行个性化定制,例如通过RSS阅读器订阅感兴趣的新闻源,或者通过社交网络筛选自己感兴趣的话题和内容。 3. **网页技术的革新**: - 随着技术的发展,如Ajax、XML、JSON等技术的出现和应用,使得网页可以更加动态地与用户交互,无需重新加载整个页面即可更新数据,提高了用户体验。 4. **长尾效应**: - 在Web2.0时代,即使是小型或专业化的内容提供者也有机会通过互联网获得关注,这体现了长尾理论,即在网络环境下,非主流的小众产品也有机会与主流产品并存。 5. **社交网络的兴起**: - Web2.0推动了社交网络的发展,如Facebook、Twitter、微博等平台兴起,促进了信息的快速传播和人际交流方式的变革。 6. **开放性和互操作性**: - Web2.0时代倡导开放API(应用程序编程接口),允许不同的网络服务和应用间能够相互通信和共享数据,提高了网络的互操作性。 ### Web2.0的关键技术和应用 1. **博客(Blog)**: - 博客是Web2.0的代表之一,它支持用户以日记形式定期更新内容,并允许其他用户进行评论。 2. **维基(Wiki)**: - 维基是另一种形式的集体协作项目,如维基百科,任何用户都可以编辑网页内容,共同构建一个百科全书。 3. **社交网络服务(Social Networking Services)**: - 社交网络服务如Facebook、Twitter、LinkedIn等,促进了个人和组织之间的社交关系构建和信息分享。 4. **内容聚合器(RSS feeds)**: - RSS技术让用户可以通过阅读器软件快速浏览多个网站更新的内容摘要。 5. **标签(Tags)**: - 用户可以为自己的内容添加标签,便于其他用户搜索和组织信息。 6. **视频分享(Video Sharing)**: - 视频分享网站如YouTube,用户可以上传、分享和评论视频内容。 ### Web2.0与网络营销 1. **内容营销**: - Web2.0为内容营销提供了良好的平台,企业可以通过撰写博客文章、发布视频等内容吸引和维护用户。 2. **社交媒体营销**: - 社交网络的广泛使用,使得企业可以通过社交媒体进行品牌传播、产品推广和客户服务。 3. **口碑营销**: - 用户生成内容、评论和分享在Web2.0时代更易扩散,为口碑营销提供了土壤。 4. **搜索引擎优化(SEO)**: - 随着内容的多样化和个性化,SEO策略也必须适应Web2.0特点,注重社交信号和用户体验。 ### 总结 Web2.0是对互联网发展的一次深刻变革,它不仅仅是一个技术变革,更是人们使用互联网的习惯和方式的变革。Web2.0的时代特征与Web1.0相比,更加注重用户体验、社交互动和信息的个性化定制。这些变化为网络营销提供了新的思路和平台,也对企业的市场策略提出了新的要求。通过理解Web2.0的特点和应用,企业可以更好地适应互联网的发展趋势,实现与用户的深度互动和品牌的有效传播。
recommend-type

【C++编程新手必看】:一步步带你制作出风靡全球的“别踩白块儿”游戏

# 摘要 本文全面介绍C++编程在游戏开发中的应用,涵盖了从基础概念到具体实现的多个方面。首先,文章提供了游戏开发环境的搭建指南,包括编译器配置和开发工具的选择。随后,重点介绍了游戏主循环和基本框架的构建,强调了事件处理和渲染技术。在游戏逻辑和交互设计方面,本文阐述了界面布局、事件响应和游戏状态管理的核心实现。为了提升游戏体验,本文还探讨了添加音效和背景音乐以及开发高级游戏特性的方法。最后,文章介绍了性能优化和跨平台发布的过程,包括游戏的打包和针对不同平台的发布策略。本文旨在为C++游戏开发者提供一个实用的开发指南,帮助他们从零开始构建出性能优化、跨平台兼容的游戏。 # 关键字 C++编程;
recommend-type

使用scikit-learn训练模型来预测鸢尾花种类

<think>我们使用scikit-learn库来训练一个分类模型预测鸢尾花种类。鸢尾花数据集是scikit-learn内置的经典数据集,包含三种鸢尾花的四个特征(花萼长度、花萼宽度、花瓣长度、花瓣宽度)和对应的类别标签。步骤:1.导入必要的库和数据集2.数据探索(可选,但建议了解数据)3.数据预处理(如划分训练集和测试集、标准化等)4.选择模型(例如KNN、随机森林等)5.训练模型6.模型评估7.使用模型进行预测下面以KNN(K近邻)算法为例,展示完整流程。</think>### 使用 scikit-learn 训练鸢尾花分类模型 以下是基于 scikit-learn 训练鸢尾花分类模型的
recommend-type

WWF工作流设计器C#源码解析及演示

### WWF工作流设计器控件C#源码知识点 #### 1. WWF(Windows Workflow Foundation)概述 WWF是微软公司推出的一个工作流框架,作为.NET Framework的一部分。它提供了一套丰富的API,用于设计、执行和管理工作流。工作流可以用于各种应用程序,包括Web应用、服务和桌面应用,使得开发者能够将复杂的业务逻辑以工作流的形式表现出来,简化业务流程自动化和管理。 #### 2. 工作流设计器控件(Workflow Designer Control) 工作流设计器控件是WWF中的一个组件,主要用于提供可视化设计工作流的能力。它允许用户通过拖放的方式在界面上添加、配置和连接工作流活动,从而构建出复杂的工作流应用。控件的使用大大降低了工作流设计的难度,并使得设计工作流变得直观和用户友好。 #### 3. C#源码分析 在提供的文件描述中提到了两个工程项目,它们均使用C#编写。下面分别对这两个工程进行介绍: - **WorkflowDesignerControl** - 该工程是工作流设计器控件的核心实现。它封装了设计工作流所需的用户界面和逻辑代码。开发者可以在自己的应用程序中嵌入这个控件,为最终用户提供一个设计工作流的界面。 - 重点分析:控件如何加载和显示不同的工作流活动、控件如何响应用户的交互、控件状态的保存和加载机制等。 - **WorkflowDesignerExample** - 这个工程是演示如何使用WorkflowDesignerControl的示例项目。它不仅展示了如何在用户界面中嵌入工作流设计器控件,还展示了如何处理用户的交互事件,比如如何在设计完工作流后进行保存、加载或执行等。 - 重点分析:实例程序如何响应工作流设计师的用户操作、示例程序中可能包含的事件处理逻辑、以及工作流的实例化和运行等。 #### 4. 使用Visual Studio 2008编译 文件描述中提到使用Visual Studio 2008进行编译通过。Visual Studio 2008是微软在2008年发布的集成开发环境,它支持.NET Framework 3.5,而WWF正是作为.NET 3.5的一部分。开发者需要使用Visual Studio 2008(或更新版本)来加载和编译这些代码,确保所有必要的项目引用、依赖和.NET 3.5的特性均得到支持。 #### 5. 关键技术点 - **工作流活动(Workflow Activities)**:WWF中的工作流由一系列的活动组成,每个活动代表了一个可以执行的工作单元。在工作流设计器控件中,需要能够显示和操作这些活动。 - **活动编辑(Activity Editing)**:能够编辑活动的属性是工作流设计器控件的重要功能,这对于构建复杂的工作流逻辑至关重要。 - **状态管理(State Management)**:工作流设计过程中可能涉及保存和加载状态,例如保存当前的工作流设计、加载已保存的工作流设计等。 - **事件处理(Event Handling)**:处理用户交互事件,例如拖放活动到设计面板、双击活动编辑属性等。 #### 6. 文件名称列表解释 - **WorkflowDesignerControl.sln**:解决方案文件,包含了WorkflowDesignerControl和WorkflowDesignerExample两个项目。 - **WorkflowDesignerControl.suo**:Visual Studio解决方案用户选项文件,该文件包含了开发者特有的个性化设置,比如窗口布局、断点位置等。 - **Thumbs.db**:缩略图缓存文件,由Windows自动生成,用于存储文件夹中的图片缩略图,与WWF工作流设计器控件功能无关。 - **WorkflowDesignerExample**:可能是一个文件夹,包含了示例工程相关的所有文件,或者是示例工程的可执行文件。 - **EULA.txt**:最终用户许可协议文本文件,通常说明了软件的版权和使用许可条件。 综上所述,该文件集包含了WWF工作流设计器控件的完整C#源码以及相应的Visual Studio项目文件,开发者可以利用这些资源深入理解WWF工作流设计器控件的工作机制,并将其应用于实际的项目开发中,实现工作流的设计和管理功能。
recommend-type

CAD数据在ANSA中:完美修复几何数据的策略与方法

# 摘要 CAD数据的准确性和几何完整性对于产品设计和工程分析至关重要。本文首先强调了CAD数据和几何修复的重要性,随后介绍了ANSA软件在处理CAD数据中的角色。通过详细的分析,本文探讨了几何数据的常见问题,以及有效的手动和自动修复技术。文中还提供了几何修复在实际应用中的案例分析,并讨论了行业未来对几何修复技术的需求和新兴技术趋势。文章旨在为CAD数据几何修复提供全面的理论知识、诊断方法和修复策略,并
recommend-type

编写verilog代码实现以上的规格化功能

<think>我们有一个16位的二进制数,其格式如下:-a15:尾数符号位(1位)-a14-a5:尾数数值位(10位)-a4:指数符号位(1位)-a3-a0:指数数值位(4位)规格化的目标:确保尾数数值位的最高位a14为1(即尾数的绝对值在[0.5,1)范围内)。步骤:1.提取输入信号的各个部分:尾数符号位、尾数数值位、指数符号位、指数数值位。2.将尾数数值位(10位)视为无符号整数M(范围0到1023),我们需要通过左移操作使得M的最高位为1(即M>=512)。同时记录左移的位数(shift_count)。3.调整指数:新的指数=原指数-shift_count(因为尾数左移相当于乘以2^sh
recommend-type

探索ARM9 2410开发板与wince5.0系统的高级实验

标题中的“周立功ARM (magicarm2410) 高级实验”指明了文档内容涉及周立功品牌下的ARM9 2410开发板的高级使用实验。ARM9 2410是基于ARM920T内核的处理器,广泛应用于嵌入式系统开发。周立功是一家在电子与嵌入式系统领域内具有影响力的公司,提供嵌入式教学和开发解决方案。MagicARM2410是该公司的某型号开发板,可能专为教学和实验设计,携带了特定的实验内容,例如本例中的“eva例程”。 描述提供了额外的背景信息,说明周立功ARM9 2410开发板上预装有Windows CE 5.0操作系统,以及该开发板附带的EVA例程。EVA可能是用于实验教学的示例程序或演示程序。文档中还提到,虽然书店出售的《周立功 ARM9开发实践》书籍中没有包含EVA的源码,但该源码实际上是随开发板提供的。这意味着,EVA例程的源码并不在书籍中公开,而是需要直接从开发板上获取。这对于那些希望深入研究和修改EVA例程的学生和开发者来说十分重要。 标签中的“magicarm2410”和“周立功ARM”是对文档和开发板的分类标识。这些标签有助于在文档管理系统或资料库中对相关文件进行整理和检索。 至于“压缩包子文件的文件名称列表:新建文件夹”,这表明相关文件已经被打包压缩,但具体的文件内容和名称没有在描述中列出。我们仅知道压缩包内至少存在一个“新建文件夹”,这可能意味着用户需要进一步操作来查看或解压出文件夹中的内容。 综合以上信息,知识点主要包括: 1. ARM9 2410开发板:一款基于ARM920T内核的处理器的嵌入式开发板,适用于教学和项目实验。 2. Windows CE 5.0系统:这是微软推出的专为嵌入式应用设计的操作系统,提供了一个可定制、可伸缩的、实时的操作环境。 3. EVA例程:一个嵌入式系统开发的教学或实验示例程序。它可能被设计用于演示特定功能或技术,如显示、控制或通信。 4. 开发实践书籍与源码提供:《周立功 ARM9开发实践》一书可能详细介绍了ARM9 2410开发板的使用方法,但书中的内容不包含EVA例程的源码,源码需要通过其他途径获得。 5. 文件打包压缩:文档可能以压缩包的形式存在,包含了需要的内容,但具体内容未知,需要解压缩之后才能查看。 了解这些知识点后,对于从事嵌入式系统开发的工程师或者学生来说,可以更好地利用周立功 ARM9 2410开发板进行学习和实验,尤其是可以进行更深入的研究和实验设计,通过EVA例程的源码来理解嵌入式系统的运行机制和程序结构。同时,也能够使用Windows CE 5.0系统环境来开发相应的应用程序。
recommend-type

【ANSA网格生成手册】:创建高效高质量网格的6个技巧

# 摘要 ANSA软件作为一款强大的前处理工具,在工程仿真领域扮演着重要角色。本文首先概述了ANSA软件的基本功能以及网格生成技术的基础知识。接着深入探讨了不同网格类型的选择及其优缺点,同时强调了网格密度与质量控制的重要性。文中详细介绍了高级网格生成技巧,包括自适应网格技术和多重网格以及混合网格技术的应用。此外,本文还提供了网格生成在实际应用中的前处理
recommend-type

能否简单一点

<think>我们简化问题:统计从列表第一个字典开始,连续多少个字典的money字段为正数。注意:我们只关心从第一个开始的连续正数,一旦遇到非正数(包括0和负数)或者缺失money字段,就停止计数。简单实现思路:1.遍历列表中的每个字典(从第一个开始)2.对于每个字典,检查是否有'money'键,且其值大于0。3.如果满足条件,计数器加1;否则立即停止遍历并返回当前计数。代码实现:</think>### 简化版:统计连续正数 `money` 字段 #### 解决方案代码 ```python def count_positive_money(dict_list): count = 0