123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- from ipfml import processing, metrics
- from modules.utils.config import *
- from PIL import Image
- from skimage import color
- import random
- import numpy as np
- _scenes_names_prefix = '_scenes_names'
- _scenes_indices_prefix = '_scenes_indices'
- # store all variables from current module context
- context_vars = vars()
- def get_svd_data(data_type, block):
- """
- Method which returns the data type expected
- """
- if data_type == 'lab':
- nb = random.randint(0, 10)
- block_file_path = '/tmp/' + str(nb) + '_lab_img.png'
- block.save(block_file_path)
- data = processing.get_LAB_L_SVD_s(Image.open(block_file_path))
- if data_type == 'mscn_revisited':
- nb = random.randint(0, 10)
- img_mscn_revisited = processing.rgb_to_mscn(block)
- # save tmp as img
- img_output = Image.fromarray(img_mscn_revisited.astype('uint8'), 'L')
- mscn_revisited_file_path = '/tmp/' + str(nb) + '_mscn_revisited_img.png'
- img_output.save(mscn_revisited_file_path)
- img_block = Image.open(mscn_revisited_file_path)
- # extract from temp image
- data = metrics.get_SVD_s(img_block)
- if data_type == 'mscn':
- img_gray = np.array(color.rgb2gray(np.asarray(block))*255, 'uint8')
- img_mscn = processing.calculate_mscn_coefficients(img_gray, 7)
- img_mscn_norm = processing.normalize_2D_arr(img_mscn)
- img_mscn_gray = np.array(img_mscn_norm*255, 'uint8')
- data = metrics.get_SVD_s(img_mscn_gray)
- if data_type == 'low_bits_6':
- low_bits_6 = processing.rgb_to_LAB_L_low_bits(block, 6)
- data = metrics.get_SVD_s(low_bits_6)
- if data_type == 'low_bits_5':
- low_bits_5 = processing.rgb_to_LAB_L_low_bits(block, 5)
- data = metrics.get_SVD_s(low_bits_5)
- if data_type == 'low_bits_4':
- low_bits_4 = processing.rgb_to_LAB_L_low_bits(block, 4)
- data = metrics.get_SVD_s(low_bits_4)
- if data_type == 'low_bits_3':
- low_bits_3 = processing.rgb_to_LAB_L_low_bits(block, 3)
- data = metrics.get_SVD_s(low_bits_3)
- if data_type == 'low_bits_2':
- low_bits_2 = processing.rgb_to_LAB_L_low_bits(block, 2)
- data = metrics.get_SVD_s(low_bits_2)
- if data_type == 'low_bits_4_shifted_2':
- data = metrics.get_SVD_s(processing.rgb_to_LAB_L_bits(block, (3, 6)))
- return data
- def get_renderer_scenes_indices(renderer_name):
- if renderer_name not in renderer_choices:
- raise ValueError("Unknown renderer name")
- if renderer_name == 'all':
- return scenes_indices
- else:
- return context_vars[renderer_name + _scenes_indices_prefix]
- def get_renderer_scenes_names(renderer_name):
- if renderer_name not in renderer_choices:
- raise ValueError("Unknown renderer name")
- if renderer_name == 'all':
- return scenes_names
- else:
- return context_vars[renderer_name + _scenes_names_prefix]
|