lzyhha
clean
af44a4b
import cv2
import numpy as np
def oversharpen(img, severity=1):
"""
OverSharpening filter on a NumPy array.
severity = [1, 5] corresponding to amount = [2, 4, 6, 8, 10]
@param x: Input image as NumPy array, H x W x C, value range [0, 255]
@param severity: Severity of distortion, [1, 5]
@return: Degraded image as NumPy array, H x W x C, value range [0, 255]
"""
assert img.dtype == np.uint8, "Image array should have dtype of np.uint8"
assert severity in [1, 2, 3, 4, 5], 'Severity must be an integer between 1 and 5.'
amount = [2, 2.8, 4, 6, 8][severity - 1]
# Setting the kernel size and sigmaX value for Gaussian blur
# In OpenCV's Size(kernel_width, kernel_height), both kernel_width and kernel_height
# should be odd numbers; for example, we can use (2*radius+1, 2*radius+1)
blur_radius = 2 # The radius is the blur radius used to set the size of the Gaussian kernel
sigmaX = 0
# Create a blurred/smoothed version of the image
blurred = cv2.GaussianBlur(img, (2*blur_radius+1, 2*blur_radius+1), sigmaX)
# Compute the sharpened image with an enhancement factor of 'amount'
sharpened = cv2.addWeighted(img, 1 + amount, blurred, -amount, 0)
return sharpened