mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
added laplacian_filter file (#9783)
* added laplacian_filter file * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian_py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * required changes to laplacian file * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * changed laplacian_filter.py * changed laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * changed laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * changed laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updated laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * update laplacian_filter.py * update laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * update laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * changed laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * changed laplacian_filter.py * changed laplacian_filter.py * changed laplacian_filter.py * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Update laplacian_filter.py * Add a test --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Christian Clauss <cclauss@me.com>
This commit is contained in:
parent
9200c64464
commit
19fc788197
81
digital_image_processing/filters/laplacian_filter.py
Normal file
81
digital_image_processing/filters/laplacian_filter.py
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
# @Author : ojas-wani
|
||||||
|
# @File : laplacian_filter.py
|
||||||
|
# @Date : 10/04/2023
|
||||||
|
|
||||||
|
import numpy as np
|
||||||
|
from cv2 import (
|
||||||
|
BORDER_DEFAULT,
|
||||||
|
COLOR_BGR2GRAY,
|
||||||
|
CV_64F,
|
||||||
|
cvtColor,
|
||||||
|
filter2D,
|
||||||
|
imread,
|
||||||
|
imshow,
|
||||||
|
waitKey,
|
||||||
|
)
|
||||||
|
|
||||||
|
from digital_image_processing.filters.gaussian_filter import gaussian_filter
|
||||||
|
|
||||||
|
|
||||||
|
def my_laplacian(src: np.ndarray, ksize: int) -> np.ndarray:
|
||||||
|
"""
|
||||||
|
:param src: the source image, which should be a grayscale or color image.
|
||||||
|
:param ksize: the size of the kernel used to compute the Laplacian filter,
|
||||||
|
which can be 1, 3, 5, or 7.
|
||||||
|
|
||||||
|
>>> my_laplacian(src=np.array([]), ksize=0)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
...
|
||||||
|
ValueError: ksize must be in (1, 3, 5, 7)
|
||||||
|
"""
|
||||||
|
kernels = {
|
||||||
|
1: np.array([[0, -1, 0], [-1, 4, -1], [0, -1, 0]]),
|
||||||
|
3: np.array([[0, 1, 0], [1, -4, 1], [0, 1, 0]]),
|
||||||
|
5: np.array(
|
||||||
|
[
|
||||||
|
[0, 0, -1, 0, 0],
|
||||||
|
[0, -1, -2, -1, 0],
|
||||||
|
[-1, -2, 16, -2, -1],
|
||||||
|
[0, -1, -2, -1, 0],
|
||||||
|
[0, 0, -1, 0, 0],
|
||||||
|
]
|
||||||
|
),
|
||||||
|
7: np.array(
|
||||||
|
[
|
||||||
|
[0, 0, 0, -1, 0, 0, 0],
|
||||||
|
[0, 0, -2, -3, -2, 0, 0],
|
||||||
|
[0, -2, -7, -10, -7, -2, 0],
|
||||||
|
[-1, -3, -10, 68, -10, -3, -1],
|
||||||
|
[0, -2, -7, -10, -7, -2, 0],
|
||||||
|
[0, 0, -2, -3, -2, 0, 0],
|
||||||
|
[0, 0, 0, -1, 0, 0, 0],
|
||||||
|
]
|
||||||
|
),
|
||||||
|
}
|
||||||
|
if ksize not in kernels:
|
||||||
|
msg = f"ksize must be in {tuple(kernels)}"
|
||||||
|
raise ValueError(msg)
|
||||||
|
|
||||||
|
# Apply the Laplacian kernel using convolution
|
||||||
|
return filter2D(
|
||||||
|
src, CV_64F, kernels[ksize], 0, borderType=BORDER_DEFAULT, anchor=(0, 0)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
# read original image
|
||||||
|
img = imread(r"../image_data/lena.jpg")
|
||||||
|
|
||||||
|
# turn image in gray scale value
|
||||||
|
gray = cvtColor(img, COLOR_BGR2GRAY)
|
||||||
|
|
||||||
|
# Applying gaussian filter
|
||||||
|
blur_image = gaussian_filter(gray, 3, sigma=1)
|
||||||
|
|
||||||
|
# Apply multiple Kernel to detect edges
|
||||||
|
laplacian_image = my_laplacian(ksize=3, src=blur_image)
|
||||||
|
|
||||||
|
imshow("Original image", img)
|
||||||
|
imshow("Detected edges using laplacian filter", laplacian_image)
|
||||||
|
|
||||||
|
waitKey(0)
|
Loading…
Reference in New Issue
Block a user