-
Notifications
You must be signed in to change notification settings - Fork 391
Expand file tree
/
Copy pathtaylorseer_text2image.py
More file actions
92 lines (72 loc) · 3.2 KB
/
taylorseer_text2image.py
File metadata and controls
92 lines (72 loc) · 3.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#!/usr/bin/env python3
# Copyright (C) 2026 Intel Corporation
# SPDX-License-Identifier: Apache-2.0
import argparse
import time
import openvino_genai
from PIL import Image
def main():
parser = argparse.ArgumentParser(description="Text-to-image generation with TaylorSeer caching optimization")
parser.add_argument("model_dir", help="Path to the converted OpenVINO model directory")
parser.add_argument("prompt", help="Text prompt for image generation")
args = parser.parse_args()
device = "CPU" # GPU can be used as well
pipe = openvino_genai.Text2ImagePipeline(args.model_dir, device)
# TaylorSeer configuration
cache_interval = 3
disable_before = 6
disable_after = -2
num_inference_steps = 28
def callback(step, num_steps, latent):
print(f"Step {step + 1}/{num_steps}")
return False
generate_kwargs = {
"width": 512,
"height": 512,
"num_inference_steps": num_inference_steps,
"rng_seed": 42,
"num_images_per_prompt": 1,
"callback": callback,
}
# Generate baseline for comparison
print(f"\nGenerating baseline image without caching...")
baseline_config = pipe.get_generation_config()
baseline_config.taylorseer_config = None # explicitly disable caching
pipe.set_generation_config(baseline_config)
start_time = time.time()
baseline_tensor = pipe.generate(args.prompt, **generate_kwargs)
baseline_time = time.time() - start_time
print(f"Baseline generation completed in {baseline_time:.2f}s")
baseline_filename = "taylorseer_baseline.bmp"
baseline_image = Image.fromarray(baseline_tensor.data[0])
baseline_image.save(baseline_filename)
print(f"Baseline image saved to {baseline_filename}")
# Configure TaylorSeer caching
print(f"\nGenerating image with TaylorSeer caching...")
taylorseer_config = openvino_genai.TaylorSeerCacheConfig()
taylorseer_config.cache_interval = cache_interval
taylorseer_config.disable_cache_before_step = disable_before
taylorseer_config.disable_cache_after_step = disable_after
print(taylorseer_config)
generation_config = pipe.get_generation_config()
generation_config.taylorseer_config = taylorseer_config
pipe.set_generation_config(generation_config)
start_time = time.time()
image_tensor = pipe.generate(args.prompt, **generate_kwargs)
taylorseer_time = time.time() - start_time
print(f"TaylorSeer generation completed in {taylorseer_time:.2f}s")
image_filename = "taylorseer.bmp"
image = Image.fromarray(image_tensor.data[0])
image.save(image_filename)
print(f"Image saved to {image_filename}")
# Performance comparison
speedup = baseline_time / taylorseer_time if taylorseer_time > 0 else 0.0
time_saved = baseline_time - taylorseer_time if baseline_time > 0 else 0.0
percentage = (baseline_time - taylorseer_time) / baseline_time * 100 if baseline_time > 0 else 0.0
print(f"\nPerformance Comparison:")
print(f" Baseline time: {baseline_time:.2f}s")
print(f" TaylorSeer time: {taylorseer_time:.2f}s")
print(f" Speedup: {speedup:.2f}x")
print(f" Time saved: {time_saved:.2f}s ({percentage:.1f}%)")
if __name__ == "__main__":
main()