|
from PIL import Image |
|
import matplotlib.pyplot as plt |
|
|
|
|
|
|
|
def log_image(x, opts): |
|
return tensor2im(x) |
|
|
|
|
|
def tensor2im(var): |
|
var = var.cpu().detach().transpose(0, 2).transpose(0, 1).numpy() |
|
var = ((var + 1) / 2) |
|
var[var < 0] = 0 |
|
var[var > 1] = 1 |
|
var = var * 255 |
|
return Image.fromarray(var.astype('uint8')) |
|
|
|
|
|
def vis_faces(log_hooks): |
|
display_count = len(log_hooks) |
|
fig = plt.figure(figsize=(12, 4 * display_count)) |
|
gs = fig.add_gridspec(display_count, 4) |
|
for i in range(display_count): |
|
hooks_dict = log_hooks[i] |
|
vis_faces_with_age(hooks_dict, fig, gs, i) |
|
plt.tight_layout() |
|
return fig |
|
|
|
|
|
def vis_faces_with_age(hooks_dict, fig, gs, i): |
|
fig.add_subplot(gs[i, 0]) |
|
plt.imshow(hooks_dict['input_face']) |
|
plt.title('Input\nOut Sim={:.2f}\nInput Age={:.2f}'.format(float(hooks_dict['diff_input_real']), |
|
float(hooks_dict['input_age_real']))) |
|
fig.add_subplot(gs[i, 1]) |
|
plt.imshow(hooks_dict['target_face']) |
|
plt.title('Target\nIn={:.2f},Out={:.2f}\nTarget Age={:.2f}'.format(float(hooks_dict['diff_views_real']), |
|
float(hooks_dict['diff_target_real']), |
|
float(hooks_dict['target_age_real']))) |
|
fig.add_subplot(gs[i, 2]) |
|
plt.imshow(hooks_dict['output_face']) |
|
plt.title('Output\nTarget Sim={:.2f}\nOuput Age={:.2f}'.format(float(hooks_dict['diff_target_real']), |
|
float(hooks_dict['output_age_real']))) |
|
fig.add_subplot(gs[i, 3]) |
|
plt.imshow(hooks_dict['recovered_face']) |
|
plt.title('Recovered\nTarget Sim={:.2f}\nOuput Age={:.2f}'.format(float(hooks_dict['diff_target_cycle']), |
|
float(hooks_dict['output_age_cycle']))) |
|
|