У меня 2 изображения,
1- Белый круг с черным штрихом
2- Черный круг с черным штрихом
Я хочу сравнить оба изображения и определить, что оба имеют одинаковый круг, но с разным заполнением
Я должен использовать только питон и подушку
Я уже пробовал несколько методов, таких как Edge Detection, но всякий раз, когда я пытаюсь изменить изображение для обнаружения края, новое изображение отображается как пустое
from PIL import Image, ImageDraw
import numpy as np
from math import sqrt
# Load image:
input_image = Image.open("input.png")
input_pixels = input_image.load()
width, height = input_image.width, input_image.height
# Create output image
output_image = Image.new("RGB", input_image.size)
draw = ImageDraw.Draw(output_image)
# Convert to grayscale
intensity = np.zeros((width, height))
for x in range(width):
for y in range(height):
intensity[x, y] = sum(input_pixels[x, y]) / 3
# Compute convolution between intensity and kernels
for x in range(1, input_image.width - 1):
for y in range(1, input_image.height - 1):
magx = intensity[x + 1, y] - intensity[x - 1, y]
magy = intensity[x, y + 1] - intensity[x, y - 1]
# Draw in black and white the magnitude
color = int(sqrt(magx**2 + magy**2))
draw.point((x, y), (color, color, color))
output_image.save("edge.png")
ожидаемый результат, что оба изображения будут окрашены в серый цвет только с кружочками, отмеченными белым
фактический результат пустое черное изображение (как будто оно не может видеть края)