-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfusion_main.py
74 lines (57 loc) · 1.93 KB
/
fusion_main.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
import random
import cv2
import matplotlib.pyplot as plt
import numpy as np
import pywt
def channelTransform(ch1,ch2, shape):
cooef1 = pywt.dwt2(ch1, 'db5', mode = 'periodization')
cooef2 = pywt.dwt2(ch2, 'db5', mode = 'periodization')
cA1, (cH1, cV1, cD1) = cooef1
cA2, (cH2, cV2, cD2) = cooef2
cA = (cA1+cA2)/2
cH = (cH1 +cH2)/2
cV = (cV1+cV2)/2
cD = (cD1+cD2)/2
fincoC = cA, (cH,cV,cD)
outImageC = pywt.idwt2(fincoC, 'db5', mode = 'periodization')
outImageC = cv2.resize(outImageC,(shape[0],shape[1]))
return outImageC
def fusion(img1, img2, name_path):
# Params
FUSION_METHOD = 'max' # Can be 'min' || 'max || anything you choose according theory
# Read the two image
I1 = cv2.imread(img1)
I2 = cv2.imread(img2)
# Resizing image if both are in different shapes
I2 = cv2.resize(I2,(I1.shape[1],I1.shape[0]))
print (I1.shape)
print (I2.shape)
## Seperating channels
iR1 = I1.copy()
iR1[:,:,1] = iR1[:,:,2] = 0
iR2 = I2.copy()
iR2[:,:,1] = iR2[:,:,2] = 0
iG1 = I1.copy()
iG1[:,:,0] = iG1[:,:,2] = 0
iG2 = I2.copy()
iG2[:,:,0] = iG2[:,:,2] = 0
iB1 = I1.copy()
iB1[:,:,0] = iB1[:,:,1] = 0
iB2 = I2.copy()
iB2[:,:,0] = iB2[:,:,1] = 0
shape = (I1.shape[1], I1.shape[0])
# Wavelet transformation on red channel
outImageR = channelTransform(iR1, iR2, shape)
outImageG = channelTransform(iG1, iG2, shape)
outImageB = channelTransform(iB1, iB2, shape)
outImage = I1.copy()
outImage[:,:,0] = outImage[:,:,1] = outImage[:,:,2] = 0
outImage[:,:,0] = outImageR[:,:,0]
outImage[:,:,1] = outImageG[:,:,1]
outImage[:,:,2] = outImageB[:,:,2]
outImage = np.multiply(np.divide(outImage - np.min(outImage),(np.max(outImage) - np.min(outImage))),65535)
outImage = outImage.astype(np.uint16)
x = random.randint(1000, 2000)
loc = name_path
cv2.imwrite(loc,outImage)
return loc