-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMLBP_templates.py
105 lines (93 loc) · 4.99 KB
/
MLBP_templates.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import numpy as np
from PIL import Image
import os
import copy
# Given radius, number of neighbors, and the pixel, returns the neighbor pixels
def lbp_descriptor(radius, neighbors, center_pixel):
x, y = center_pixel
if radius == 1 and neighbors == 8:
pixel_list = [(x+1,y), (x+1,y+1), (x,y+1), (x-1,y+1), (x-1,y), (x-1,y-1), (x,y-1), (x+1,y-1)]
return pixel_list
elif radius == 2 and neighbors == 8:
pixel_list = [(x+2,y), (x+2,y+2), (x,y+2), (x-2,y+1), (x-2,y), (x-2,y-2), (x,y-2), (x+2,y-2)]
return pixel_list
elif radius == 3 and neighbors == 8:
pixel_list = [(x+3,y), (x+3,y+3), (x,y+3), (x-3,y+3), (x-3,y), (x-3,y-3), (x,y-3), (x+3,y-3)]
return pixel_list
elif radius == 4 and neighbors == 8:
pixel_list = [(x+4,y), (x+4,y+4), (x,y+4), (x-4,y+4), (x-4,y), (x-4,y-4), (x,y-4), (x+4,y-4)]
return pixel_list
elif radius == 5 and neighbors == 8:
pixel_list = [(x+5,y), (x+5,y+5), (x,y+5), (x-5,y+5), (x-5,y), (x-5,y-5), (x,y-5), (x+5,y-5)]
return pixel_list
elif radius == 7 and neighbors == 16:
pixel_list = [(x+radius, y), (x, y+radius), (x-radius, y), (x, y-radius),
(x+radius, y+2), (x+radius, y+3), (x+radius-1, y+2), (x+radius-1, y+3),
(x+radius-2, y+4), (x+radius-2, y+5), (x+radius-3, y+4), (x+radius-3, y+5),
(x+radius-4, y+6), (x+radius-4, y+7), (x+radius-5, y+6), (x+radius-5, y+7),
(x-2, y+radius), (x-2, y+radius-1), (x-3, y+radius), (x-4, y+radius-1),
(x-5, y+radius-2), (x-5, y+radius-3), (x-6, y+radius-2), (x-6, y+radius-3),
(x-7, y+radius-4), (x-7, y+radius-5), (x-8, y+radius-4), (x-8, y+radius-5),
(x-radius, y-2), (x-radius, y-3), (x-radius+1, y-2), (x-radius+1, y-3),
(x-radius+2, y-4), (x-radius+2, y-5), (x-radius+3, y-4), (x-radius+3, y-5),
(x-radius+4, y-6), (x-radius+4, y-7), (x-radius+5, y-6), (x-radius+5, y-7),
(x+2, y-radius), (x+2, y-radius+1), (x+3, y-radius), (x+3, y-radius+1),
(x+4, y-radius+2), (x+4, y-radius+3), (x+5, y-radius+2), (x+5, y-radius+3),
(x+6, y-radius+4), (x+6, y-radius+5), (x+7, y-radius+4), (x+7, y-radius+5)]
return pixel_list
else:
raise ValueError("Invalid radius or number of neighbors")
# Write another list for the half circle and the quarter circle use existing lists
def initialization(img_array, mslbp_matrix):
# mslbp_matrix = np.full_like(img_array, 0.1, dtype=np.float32)
# Define a list of radius values
radius_list = [1, 2, 3, 4, 5, 7]
neighbors = 8 # 8 or 16 neighbors
# Get image dimensions
height, width = img_array.shape
#iterate over the image array
index = radius_list[3]
for i in range(index, height - index):
for j in range(index, width - index):
# Get the pixel value
pixel = (i, j)
# Get the neighborhood pixels
neighborhood_pixels = lbp_descriptor(index, neighbors, pixel) # adjust the radius and number of neighbors
for k in range(0, len(neighborhood_pixels)-1):
if img_array[i, j] <= img_array[neighborhood_pixels[k]]:
mslbp_matrix[i, j] = mslbp_matrix[i, j] + 2**k
else:
mslbp_matrix[i, j] = mslbp_matrix[i, j] + 0
return mslbp_matrix
def main():
# Directory containing the image
image_directory = r'C:\Users\ozgul\Documents\GitHub\Palm_Veins_Identity\images'
image_filename = 'camera128.bmp'
# Full path to the image
image_path = os.path.join(image_directory, image_filename)
# Read the image
img = Image.open(image_path)
# Convert to grayscale if it's not already
if img.mode != 'L':
img = img.convert('L')
# Convert image to numpy array as type float
img_array = np.array(img, dtype=np.float32)
# Initialize mslbp_matrix
mslbp_matrix = np.full_like(img_array, 0.0, dtype=np.float32)
# Create, Initialize and populate from the image
mslbp_matrix_copy = copy.deepcopy(mslbp_matrix)
mslbp_matrix = initialization(img_array,mslbp_matrix_copy)
# Normalize the mslbp_matrix to the range [0, 255]
mslbp_matrix_normalized = (255 * (mslbp_matrix - np.min(mslbp_matrix)) / (np.max(mslbp_matrix) - np.min(mslbp_matrix))).astype(np.uint8)
# Convert the normalized matrix to an image
mslbp_image = Image.fromarray(mslbp_matrix_normalized)
# Save the image
output_image_path = os.path.join(image_directory, 'mslbp_image.png')
mslbp_image.save(output_image_path)
print(f"Multi-scale local binary pattern image saved to {output_image_path}")
# Write the mslbp_matrix to a file
output_path = os.path.join(image_directory, 'mslbp.npy')
np.save(output_path, mslbp_matrix)
print(f"Multi-scale local binary pattern matrix saved to {output_path}")
if __name__ == "__main__":
main()