-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmake_figure3.py
112 lines (84 loc) · 4.2 KB
/
make_figure3.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
106
107
108
109
110
111
112
#!/usr/bin/env python
u"""
make_figure3.py
Plot Figure 3 of paper.
"""
import os
from PIL import Image
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.colors import LinearSegmentedColormap
from webcolors import rgb_to_name
batch = 10
#-- directory setup
#- current directory
current_dir = os.path.dirname(os.path.realpath(__file__))
main_dir = os.path.join(current_dir,'..','FrontLearning_data')
glacier_ddir = os.path.join(main_dir,'greenland_training.dir')
ddir = os.path.join(glacier_ddir, 'data','test')
prefix_list = ['LT05_L1TP_233013_19890629_20170202_01_T1_B2',\
'LE07_L1GT_233013_20010318_20170206_01_T2_B8',\
'LC08_L1TP_233013_20150707_20170407_01_T1_B8']
#fig, ax = plt.subplots(nrows=3, ncols=4, figsize=(9, 6.5),sharex=True, sharey=True)
fig, ax = plt.subplots(nrows=1, ncols=4, figsize=(8.5, 2.85),sharex=True, sharey=True)
#-- make custom colormap for final panel (comparison)
colors = [(1, 0, 0), (0, 1, 0), (0, 0, 1), (0,1,1), (1, 1, 1)] # red (0-2), green (2-4), blue (4-6), aqua (6-8), white (8-10)
my_cm = LinearSegmentedColormap.from_list('myColors', colors, N=5)
#norm = mpl.colors.Normalize(vmin=0.,vmax=1.)
#for i,prefix,j in zip([0,1,2],prefix_list,[5,7,8]):
prefix = prefix_list[0]
in_img_file = os.path.join(ddir,'images_equalize_autocontrast_smooth_edgeEnhance',\
'%s_Subset.png'%prefix)
in_img = np.array(Image.open(in_img_file).convert('L'))/255.
cnn_out_file = os.path.join(ddir,'output_%ibatches_60epochs_4layers_32init_241.15weight_w0.2drop_augment-x2_equalize_autocontrast_smooth_edgeEnhance_cropped_1px'%batch,\
'%s_nothreshold.png'%prefix)
cnn_out = np.array(Image.open(cnn_out_file).convert('L'))/255.
sobel_out_file = os.path.join(ddir,'output_sobel_equalize_autocontrast_smooth_edgeEnhance',\
'%s.png'%prefix)
sobel_out = np.array(Image.open(sobel_out_file).convert('L'))/255.
post_procss_dir = 'output_10batches_60epochs_4layers_32init_241.15weight_w0.2drop_augment-x2_equalize_autocontrast_smooth_edgeEnhance_cropped_1px'
cnn_p_file = os.path.join(main_dir,'Results','all_data2_test',post_procss_dir,post_procss_dir+' Post-Processed 50',\
'%s_Solution.png'%prefix)
cnn_p = np.array(Image.open(cnn_p_file).convert('L'))/255.
sobel_p_file = os.path.join(main_dir,'Results','all_data2_test','Sobel','Sobel Post-Processed 50','%s_Solution.png'%prefix)
sobel_p = np.array(Image.open(sobel_p_file).convert('L'))/255.
manual_p_file = os.path.join(main_dir,'Results','all_data2_test','output_handrawn','output_handrawn Post-Processed 50','%s_Solution.png'%prefix)
manual_p = np.array(Image.open(manual_p_file).convert('L'))/255.
front_file = os.path.join(ddir,'labels','%s_Front.png'%prefix)
front = np.array(Image.open(front_file).convert('L'))/255.
#-- combine the 4 output images into one image
out_image = np.ones(front.shape)*0.9
ind4 = np.where(front==0.)
out_image[ind4] = 0.7
ind3 = np.where(manual_p==0.)
out_image[ind3] = 0.1
ind2 = np.where(sobel_p==0.)
out_image[ind2] = 0.3
ind1 = np.where(cnn_p==0.)
out_image[ind1] = 0.5
ax[0].imshow(in_img, cmap=plt.cm.gray)
ax[0].axes.get_xaxis().set_ticks([])
ax[0].axes.get_yaxis().set_ticks([])
#ax[0].set_ylabel('Landsat %i'%j, fontsize=15)
ax[1].imshow(cnn_out, cmap=plt.cm.gray)
ax[1].axes.get_xaxis().set_ticks([])
ax[1].axes.get_yaxis().set_ticks([])
ax[2].imshow(sobel_out, cmap=plt.cm.gray)
ax[2].axes.get_xaxis().set_ticks([])
ax[2].axes.get_yaxis().set_ticks([])
ax[3].imshow(out_image, cmap=my_cm, vmin=0, vmax=1.0)
ax[3].axes.get_xaxis().set_ticks([])
ax[3].axes.get_yaxis().set_ticks([])
ax[0].set_title(r"$\bf{a)}$" + " Pre-processsed Input", fontsize=11)
ax[1].set_title(r"$\bf{b)}$" + " NN Output", fontsize=11)
ax[2].set_title(r"$\bf{c)}$" + " Sobel Output", fontsize=11)
ax[3].set_title(r"$\bf{d)}$" + " Processed Comparison", fontsize=11)
#-- make fake legend
ax[3].plot([],[],color=rgb_to_name((0, 0, 255)),label='NN')
ax[3].plot([],[],color=rgb_to_name((0, 255, 0)),label='Sobel')
ax[3].plot([],[],color=rgb_to_name((255, 0, 0)),label='Manual')
ax[3].plot([],[],color=rgb_to_name((0,255,255)),label='True Front')
ax[3].legend(loc='upper right', bbox_to_anchor=(0.97, 0.5),fontsize=11)
#fig.subplots_adjust(hspace=0)
fig.tight_layout()
plt.savefig(os.path.join(ddir,'Figure_3_v3_batch%i.pdf'%batch),format='pdf',dpi=300)