Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Diffusion tasks #827

Merged
merged 12 commits into from
Jul 18, 2024
6 changes: 5 additions & 1 deletion optimum/commands/export/openvino.py
Original file line number Diff line number Diff line change
Expand Up @@ -227,7 +227,11 @@ def _get_default_int4_config(model_id_or_path, library_name):

return _DEFAULT_4BIT_CONFIG

library_name = TasksManager.infer_library_from_model(self.args.model, library_name=self.args.library)
# TODO: add revision, subfolder and token to args
library_name = TasksManager._infer_library_from_model_name_or_path(
model_name_or_path=self.args.model, cache_dir=self.args.cache_dir
)

if library_name == "sentence_transformers" and self.args.library is None:
logger.warning(
"Library name is not specified. There are multiple possible variants: `sentence_transformers`, `transformers`."
Expand Down
25 changes: 13 additions & 12 deletions optimum/exporters/openvino/__main__.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,11 @@
logger = logging.getLogger(__name__)


def infer_task(task, model_name_or_path):
def infer_task(task, model_name_or_path, **kwargs):
IlyasMoutawwakil marked this conversation as resolved.
Show resolved Hide resolved
task = TasksManager.map_from_synonym(task)
if task == "auto":
try:
task = TasksManager.infer_task_from_model(model_name_or_path)
task = TasksManager._infer_task_from_model_name_or_path(model_name_or_path=model_name_or_path, **kwargs)
except KeyError as e:
raise KeyError(
f"The task could not be automatically inferred. Please provide the argument --task with the relevant task from {', '.join(TasksManager.get_all_tasks())}. Detailed error: {e}"
Expand Down Expand Up @@ -193,14 +193,17 @@ def main_export(
ov_config = OVConfig(quantization_config=q_config)

original_task = task
task = infer_task(task, model_name_or_path)
framework = TasksManager.determine_framework(model_name_or_path, subfolder=subfolder, framework=framework)
library_name_is_not_provided = library_name is None
library_name = TasksManager.infer_library_from_model(
model_name_or_path, subfolder=subfolder, library_name=library_name
task = infer_task(
task, model_name_or_path, subfolder=subfolder, revision=revision, cache_dir=cache_dir, token=token
)

if library_name == "sentence_transformers" and library_name_is_not_provided:
framework = TasksManager.determine_framework(
model_name_or_path, subfolder=subfolder, revision=revision, cache_dir=cache_dir, token=token
)
original_library_name = library_name
library_name = TasksManager._infer_library_from_model_name_or_path(
model_name_or_path=model_name_or_path, subfolder=subfolder, revision=revision, cache_dir=cache_dir, token=token
)
if library_name == "sentence_transformers" and original_library_name is None:
logger.warning(
"Library name is not specified. There are multiple possible variants: `sentence_tenasformers`, `transformers`."
"`transformers` will be selected. If you want to load your model with the `sentence-transformers` library instead, please set --library sentence_transformers"
Expand Down Expand Up @@ -317,9 +320,7 @@ class StoreAttr(object):
)
model.config.pad_token_id = pad_token_id

if "stable-diffusion" in task:
IlyasMoutawwakil marked this conversation as resolved.
Show resolved Hide resolved
model_type = "stable-diffusion"
elif hasattr(model.config, "export_model_type"):
if hasattr(model.config, "export_model_type"):
model_type = model.config.export_model_type.replace("_", "-")
else:
model_type = model.config.model_type.replace("_", "-")
Expand Down
21 changes: 11 additions & 10 deletions optimum/exporters/openvino/convert.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@
from transformers.modeling_utils import PreTrainedModel

if is_diffusers_available():
from diffusers import ModelMixin
from diffusers import DiffusionPipeline, ModelMixin

if is_tf_available():
from transformers.modeling_tf_utils import TFPreTrainedModel
Expand All @@ -90,13 +90,13 @@ def _save_model(model, path: str, ov_config: Optional["OVConfig"] = None):

compress_to_fp16 = ov_config.dtype == "fp16"

library_name = TasksManager.infer_library_from_model(Path(path).parent)
library_name = TasksManager._infer_library_from_model_name_or_path(model_name_or_path=Path(path).parent)
model = _add_version_info_to_model(model, library_name)
save_model(model, path, compress_to_fp16)


def export(
model: Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin"],
model: Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin", "DiffusionPipeline"],
config: OnnxConfig,
output: Path,
opset: Optional[int] = None,
Expand Down Expand Up @@ -139,7 +139,7 @@ def export(
)

if "diffusers" in str(model.__class__) and not is_diffusers_available():
raise ImportError("The pip package `diffusers` is required to export stable diffusion models to ONNX.")
raise ImportError("The package `diffusers` is required to export diffusion models to OpenVINO.")

if stateful:
# This will be checked anyway after the model conversion, but checking it earlier will save time for a user if not suitable version is used
Expand Down Expand Up @@ -422,7 +422,7 @@ def ts_patched_forward(*args, **kwargs):

def export_models(
models_and_export_configs: Dict[
str, Tuple[Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin"], "OnnxConfig"]
str, Tuple[Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin", "DiffusionPipeline"], "OnnxConfig"]
],
output_dir: Path,
opset: Optional[int] = None,
Expand Down Expand Up @@ -491,7 +491,7 @@ def export_models(


def export_from_model(
model: Union["PreTrainedModel", "TFPreTrainedModel"],
model: Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin", "DiffusionPipeline"],
output: Union[str, Path],
task: Optional[str] = None,
ov_config: Optional["OVConfig"] = None,
Expand All @@ -505,14 +505,15 @@ def export_from_model(
trust_remote_code: bool = False,
**kwargs_shapes,
):
model_kwargs = model_kwargs or {}

if ov_config is not None and ov_config.quantization_config and not is_nncf_available():
raise ImportError(
f"Compression of the weights to {ov_config.quantization_config} requires nncf, please install it with `pip install nncf`"
)

model_kwargs = model_kwargs or {}
library_name = TasksManager._infer_library_from_model(model)
TasksManager.standardize_model_attributes(model, library_name)
library_name = TasksManager._infer_library_from_model_or_model_class(model=model)
TasksManager.standardize_model_attributes(model)

if hasattr(model.config, "export_model_type"):
model_type = model.config.export_model_type.replace("_", "-")
Expand All @@ -521,7 +522,7 @@ def export_from_model(

custom_architecture = library_name == "transformers" and model_type not in TasksManager._SUPPORTED_MODEL_TYPE

if task is not None:
if task is not None and task != "auto":
task = TasksManager.map_from_synonym(task)
else:
try:
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
INSTALL_REQUIRE = [
"torch>=1.11",
"transformers>=4.36.0,<4.43.0",
"optimum>=1.21.2,<1.22.0",
"optimum@git+https://github.com/huggingface/optimum.git",
"datasets>=1.4.0",
"sentencepiece",
"setuptools",
Expand Down
Loading