Files
openvino/model-optimizer/mo/utils/utils.py
2020-02-11 22:48:49 +03:00

122 lines
4.6 KiB
Python

"""
Copyright (C) 2018-2020 Intel Corporation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import functools
import os
import re
import warnings
import numpy as np
def refer_to_faq_msg(question_num: int):
return '\n For more information please refer to Model Optimizer FAQ' \
' (https://docs.openvinotoolkit.org/latest/_docs_MO_DG_prepare_model_Model_Optimizer_FAQ.html),' \
' question #{}. '.format(question_num)
class NamedAttrsClass:
def __init__(self, class_attrs: dict):
for key, val in class_attrs.items():
self.__setattr__(key, val)
def match_shapes(pattern: np.array, shape: np.array):
""" Check if shape matches shape pattern handling -1 and 0 in the pattern. """
# Elements with values -1 and 0 in pattern are just ignored.
# Other elements should match.
if pattern.size != shape.size:
return False
indices = [i for i, n in enumerate(pattern) if n not in [0, -1]]
return np.array_equal(pattern[indices], shape[indices])
def symm_match_shapes(shape1: np.array, shape2: np.array):
""" Check if shape matches shape pattern handling -1 and 0 in the pattern. """
# Elements with values -1 and 0 in both shapes are just ignored.
# Other elements should match. Undefined elements can be one side only.
return match_shapes(shape1, shape2) or match_shapes(shape2, shape1)
def deprecated_api(class_name=None, new_method_name=None):
def deprecated(func):
@functools.wraps(func)
def deprecation_message(*args, **kwargs):
warnings.simplefilter('always', DeprecationWarning) # turn on filter
dep_msg = "Call to deprecated function {}. ".format(func.__name__)
if class_name is not None:
dep_msg += "Please use {}.{} method" \
"".format(class_name.__name__ if not isinstance(class_name, str) else class_name,
func.__name__ if new_method_name is None else new_method_name)
warnings.warn(dep_msg, DeprecationWarning, stacklevel=2)
warnings.simplefilter('default', DeprecationWarning) # reset filter
return func(*args, **kwargs)
return deprecation_message
return deprecated
def array_to_str(node, attr):
if not node.has_valid(attr):
return None
else:
return ','.join(map(str, node[attr]))
def shrink_str_value(value: np.array, max_symbols=100):
value = str(value)
if len(value) > max_symbols:
value = value.strip('\n')[:max_symbols - 3] + '...'
return value
def files_by_pattern(dir: str, pattern: str, files_only=True, add_prefix=False):
"""
Return a list of files and directories (or only files if the files_only is set to True) in the directory dir that
match pattern string pattern.
:param dir: Directory to search for files
:param pattern: string defining pattern name
:param files_only: flag to include only files (not directories) to the result
:param add_prefix: flag to include the prefix string to the file names
:return: list of file and directory names
"""
pattern_compiled = re.compile(pattern)
matched_file_names = []
for file_name in os.listdir(dir):
if re.match(pattern_compiled, file_name) and (not files_only or os.path.isfile(os.path.join(dir, file_name))):
matched_file_names.append(os.path.join(dir, file_name) if add_prefix else file_name)
return matched_file_names
def get_mo_root_dir():
"""
Return the absolute path to the Model Optimizer root directory (where mo.py file is located)
:return: path to the MO root directory
"""
return os.path.normpath(os.path.join(os.path.dirname(os.path.abspath(os.path.realpath(__file__))), os.pardir,
os.pardir))
def convert_param_type(node, attr_name: str, type_v1x, type_v7):
if attr_name in node.attrs() and node[attr_name] is not None:
if node.graph.graph['ir_version'] < 10:
node[attr_name] = type_v7(node[attr_name])
else:
node[attr_name] = type_v1x(node[attr_name])
return node[attr_name]
else:
return None