完成高斯滤波、反谐波均值滤波、自适应中值滤波
This commit is contained in:
		
						commit
						9acae91953
					
				
							
								
								
									
										41
									
								
								adaptive_median_filter.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								adaptive_median_filter.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | |||||||
|  | import numpy as np | ||||||
|  | 
 | ||||||
|  | # 自适应中值滤波 | ||||||
|  | def adaptive_median_filter(image, max_window_size=7): | ||||||
|  |     padded_image = np.pad(image, max_window_size // 2, mode='edge') | ||||||
|  |     filtered_image = image.copy() | ||||||
|  |     height, width = image.shape | ||||||
|  | 
 | ||||||
|  |     for i in range(height): | ||||||
|  |         for j in range(width): | ||||||
|  |             window_size = 3 | ||||||
|  |             while True: | ||||||
|  |                 half = window_size // 2 | ||||||
|  |                 i1, i2 = i + max_window_size//2 - half, i + max_window_size//2 + half + 1 | ||||||
|  |                 j1, j2 = j + max_window_size//2 - half, j + max_window_size//2 + half + 1 | ||||||
|  |                 window = padded_image[i1:i2, j1:j2].flatten() | ||||||
|  |                 window = np.sort(window) | ||||||
|  | 
 | ||||||
|  |                 Z_min = window[0] | ||||||
|  |                 Z_max = window[-1] | ||||||
|  |                 Z_med = window[len(window) // 2] | ||||||
|  |                 Z_xy = padded_image[i + max_window_size//2, j + max_window_size//2] | ||||||
|  | 
 | ||||||
|  |                 A1 = Z_med - Z_min | ||||||
|  |                 A2 = Z_med - Z_max | ||||||
|  | 
 | ||||||
|  |                 if A1 > 0 and A2 < 0:  # Level A | ||||||
|  |                     B1 = Z_xy - Z_min | ||||||
|  |                     B2 = Z_xy - Z_max | ||||||
|  |                     if B1 > 0 and B2 < 0: | ||||||
|  |                         filtered_image[i, j] = Z_xy | ||||||
|  |                     else: | ||||||
|  |                         filtered_image[i, j] = Z_med | ||||||
|  |                     break | ||||||
|  |                 else: | ||||||
|  |                     window_size += 2 | ||||||
|  |                     if window_size > max_window_size: | ||||||
|  |                         filtered_image[i, j] = Z_med | ||||||
|  |                         break | ||||||
|  | 
 | ||||||
|  |     return filtered_image | ||||||
							
								
								
									
										22
									
								
								contraharmonic_mean_filter.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								contraharmonic_mean_filter.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | import numpy as np | ||||||
|  | 
 | ||||||
|  | #反谐波均值滤波 | ||||||
|  | def contraharmonic_mean_filter(img, kernel_size=3, Q=1.5): | ||||||
|  |     img = img.astype(np.float64) | ||||||
|  |     filtered_img = np.zeros_like(img) | ||||||
|  | 
 | ||||||
|  |     k = kernel_size // 2 | ||||||
|  |     height, width = img.shape | ||||||
|  | 
 | ||||||
|  |     for i in range(k, height - k): | ||||||
|  |         for j in range(k, width - k): | ||||||
|  |             window = img[i - k:i + k + 1, j - k:j + k + 1] | ||||||
|  |             numerator = np.power(window, Q + 1).sum() | ||||||
|  |             denominator = np.power(window, Q).sum() | ||||||
|  | 
 | ||||||
|  |             if denominator != 0: | ||||||
|  |                 filtered_img[i, j] = numerator / denominator | ||||||
|  |             else: | ||||||
|  |                 filtered_img[i, j] = img[i, j] | ||||||
|  | 
 | ||||||
|  |     return np.clip(filtered_img, 0, 255).astype(np.uint8) | ||||||
							
								
								
									
										
											BIN
										
									
								
								file/circuitboard-gaussian.tif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								file/circuitboard-gaussian.tif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								file/circuitboard-pepper.tif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								file/circuitboard-pepper.tif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								file/circuitboard-salt.tif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								file/circuitboard-salt.tif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								file/circuitboard-saltandpep.tif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								file/circuitboard-saltandpep.tif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										25
									
								
								gaussian.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								gaussian.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | import cv2 | ||||||
|  | import matplotlib.pyplot as plt | ||||||
|  | plt.rcParams['font.sans-serif'] = ['simHei'] | ||||||
|  | plt.rcParams['axes.unicode_minus'] = False | ||||||
|  | 
 | ||||||
|  | #读取照片 | ||||||
|  | image_gaussian = cv2.imread("file/circuitboard-gaussian.tif") | ||||||
|  | 
 | ||||||
|  | #高斯滤波 | ||||||
|  | kernel_size_gaussian = (5,5)    #核的大小 | ||||||
|  | sigmax = 0    #标准差 | ||||||
|  | image_gaussian2 = cv2.GaussianBlur(image_gaussian,kernel_size_gaussian,sigmax) | ||||||
|  | 
 | ||||||
|  | plt.subplot(1,2,1) | ||||||
|  | plt.imshow(image_gaussian, cmap='gray') | ||||||
|  | plt.title('1.高斯噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.subplot(1,2,2) | ||||||
|  | plt.imshow(image_gaussian2, cmap='gray') | ||||||
|  | plt.title('1.高斯滤波_高斯噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.tight_layout() | ||||||
|  | plt.show() | ||||||
							
								
								
									
										24
									
								
								pepper_and_salt.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								pepper_and_salt.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | |||||||
|  | import cv2 | ||||||
|  | import matplotlib.pyplot as plt | ||||||
|  | plt.rcParams['font.sans-serif'] = ['simHei'] | ||||||
|  | plt.rcParams['axes.unicode_minus'] = False | ||||||
|  | from adaptive_median_filter import adaptive_median_filter | ||||||
|  | 
 | ||||||
|  | #读取照片 | ||||||
|  | image_saltandpep = cv2.imread("file/circuitboard-saltandpep.tif", cv2.IMREAD_GRAYSCALE) | ||||||
|  | 
 | ||||||
|  | # 自适应中值滤波 | ||||||
|  | image_saltandpep2 = adaptive_median_filter(image_saltandpep) | ||||||
|  | 
 | ||||||
|  | plt.subplot(1,2,1) | ||||||
|  | plt.imshow(image_saltandpep, cmap='gray') | ||||||
|  | plt.title('3.胡椒噪声和盐噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.subplot(1,2,2) | ||||||
|  | plt.imshow(image_saltandpep2, cmap='gray') | ||||||
|  | plt.title('3.自适应中值滤波_胡椒噪声和盐噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.tight_layout() | ||||||
|  | plt.show() | ||||||
							
								
								
									
										42
									
								
								pepper_pep.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								pepper_pep.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,42 @@ | |||||||
|  | import cv2 | ||||||
|  | import matplotlib.pyplot as plt | ||||||
|  | plt.rcParams['font.sans-serif'] = ['simHei'] | ||||||
|  | plt.rcParams['axes.unicode_minus'] = False | ||||||
|  | from contraharmonic_mean_filter import contraharmonic_mean_filter | ||||||
|  | 
 | ||||||
|  | #读取照片 | ||||||
|  | image_pepper = cv2.imread("file/circuitboard-pepper.tif", cv2.IMREAD_GRAYSCALE) | ||||||
|  | image_salt = cv2.imread("file/circuitboard-salt.tif", cv2.IMREAD_GRAYSCALE) | ||||||
|  | 
 | ||||||
|  | #反谐波均值滤波_胡椒噪声 | ||||||
|  | kernel_size_pepper = 3    #核的大小 | ||||||
|  | Q_pepper = 1.5    #滤波器阶数 | ||||||
|  | image_pepper2 = contraharmonic_mean_filter(image_pepper,kernel_size_pepper,Q_pepper) | ||||||
|  | 
 | ||||||
|  | #反谐波均值滤波_盐噪声 | ||||||
|  | kernel_size_salt = 3    #核的大小 | ||||||
|  | Q_salt = -1.5    #滤波器阶数 | ||||||
|  | image_salt2 = contraharmonic_mean_filter(image_salt,kernel_size_salt,Q_salt) | ||||||
|  | 
 | ||||||
|  | plt.subplot(2,2,1) | ||||||
|  | plt.imshow(image_pepper, cmap='gray') | ||||||
|  | plt.title('2.胡椒噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.subplot(2,2,2) | ||||||
|  | plt.imshow(image_pepper2, cmap='gray') | ||||||
|  | plt.title('2.反谐波均值滤波_胡椒噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.subplot(2,2,3) | ||||||
|  | plt.imshow(image_salt, cmap='gray') | ||||||
|  | plt.title('2.盐噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.subplot(2,2,4) | ||||||
|  | plt.imshow(image_salt2, cmap='gray') | ||||||
|  | plt.title('2.反谐波均值滤波_盐噪声') | ||||||
|  | plt.axis('off') | ||||||
|  | 
 | ||||||
|  | plt.tight_layout() | ||||||
|  | plt.show() | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user