from ipfml import processing, metrics, utils from modules.utils.config import * from PIL import Image from skimage import color 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': block_file_path = '/tmp/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': 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/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))) if data_type == 'sub_blocks_stats': block = np.asarray(block) width, height, _= block.shape sub_width, sub_height = int(width / 4), int(height / 4) sub_blocks = processing.divide_in_blocks(block, (sub_width, sub_height)) data = [] for sub_b in sub_blocks: # by default use the whole lab L canal l_svd_data = np.array(processing.get_LAB_L_SVD_s(sub_b)) # get information we want from svd data.append(np.mean(l_svd_data)) data.append(np.median(l_svd_data)) data.append(np.percentile(l_svd_data, 25)) data.append(np.percentile(l_svd_data, 75)) data.append(np.var(l_svd_data)) area_under_curve = utils.integral_area_trapz(l_svd_data, dx=100) data.append(area_under_curve) # convert into numpy array after computing all stats data = np.asarray(data) 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]