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

add ipex readme #595

Merged
merged 15 commits into from
Mar 22, 2024
28 changes: 28 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ where `extras` can be one or more of `ipex`, `neural-compressor`, `openvino`, `n

# Quick tour


echarlaix marked this conversation as resolved.
Show resolved Hide resolved
## Neural Compressor

Dynamic quantization can be used through the Optimum command-line interface:
Expand Down Expand Up @@ -202,6 +203,33 @@ Quantization aware training (QAT) is applied in order to simulate the effects of
You can find more examples in the [documentation](https://huggingface.co/docs/optimum/intel/index).


## IPEX
With `export=True`, IPEX model will replace torch linear to ipex linear which prepacks the weights. It will also apply linear fusioin and [IAKV](https://intel.github.io/intel-extension-for-pytorch/cpu/latest/tutorials/llm.html#indirect-access-kv-cache) for generation. Finally, jit.trace will be applied to change the model to graph mode.
echarlaix marked this conversation as resolved.
Show resolved Hide resolved
Here is the example of how to use IPEX optimized model to generate texts.
### generate
echarlaix marked this conversation as resolved.
Show resolved Hide resolved
```diff
import torch
from transformers import AutoTokenizer
echarlaix marked this conversation as resolved.
Show resolved Hide resolved
- from transformers import AutoModelForCausalLM
+ from optimum.intel.ipex import IPEXModelForCausalLM
echarlaix marked this conversation as resolved.
Show resolved Hide resolved


model_id = "gpt2"
- model = AutoModelForCausalLM.from_pretrained(model_id, torch_dtype=torch.bfloat16)
+ model = IPEXModelForCausalLM.from_pretrained(model_id, torch_dtype=torch.bfloat16, export=True)
tokenizer = AutoTokenizer.from_pretrained("gpt2")
input_sentence = ["Answer the following yes/no question by reasoning step-by-step please. Can you write a whole Haiku in a single tweet?"]
model_inputs = tokenizer(input_sentence, return_tensors="pt")
generation_kwargs = dict(max_new_tokens=32, do_sample=False, num_beams=4, num_beam_groups=1, no_repeat_ngram_size=2, use_cache=True)

generated_ids = model.generate(**model_inputs, **generation_kwargs)
output = tokenizer.batch_decode(generated_ids, skip_special_tokens=True)[0]
print(output)
echarlaix marked this conversation as resolved.
Show resolved Hide resolved
```

For more details, please refer to the [documentation](https://intel.github.io/intel-extension-for-pytorch/#introduction).


## Running the examples

Check out the [`examples`](https://github.com/huggingface/optimum-intel/tree/main/examples) directory to see how 🤗 Optimum Intel can be used to optimize models and accelerate inference.
Expand Down
Loading