File size: 1,676 Bytes
33baf83
 
 
97677c5
33baf83
97677c5
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
41e6120
97677c5
 
 
 
 
 
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
import torch
from diffusers import ShapEPipeline
from diffusers.utils import export_to_gif
import PIL.Image

def generate_3d_model(prompt, output_path="assistant_3d.gif"):
    """
    Generate a 3D model using ShapE optimized for CPU usage
    """
    try:
        # Force CPU and reduced precision
        pipe = ShapEPipeline.from_pretrained(
            "openai/shap-e",
            torch_dtype=torch.float32,
            low_cpu_mem_usage=True
        ).to("cpu")
        
        # Minimal generation settings to reduce memory usage
        outputs = pipe(
            prompt,
            num_inference_steps=32,  # Reduced from default
            frame_size=32,  # Smaller frame size
            guidance_scale=10.0,  # Reduced guidance scale
            num_frames=30  # Reduced number of frames
        )
        
        # Ensure we have PIL images
        if not isinstance(outputs.images[0], PIL.Image.Image):
            images = [PIL.Image.fromarray(img) for img in outputs.images]
        else:
            images = outputs.images
            
        # Save as GIF
        gif_path = export_to_gif(images, output_path)
        print(f"Successfully created GIF at: {gif_path}")
        return gif_path
        
    except Exception as e:
        print(f"Error during generation: {e}")
        print(f"Error type: {type(e)}")
        print(f"Full error details: {str(e)}")
        raise

if __name__ == "__main__":
    prompt = "A gentle AI voice assistant constructed from a circle ring and 3 lines that fly alongside the circle"  # Simplified prompt
    try:
        generate_3d_model(prompt)
    except Exception as e:
        print(f"Generation failed: {e}")