forked from microsoft/semantic-kernel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimage_gen_prompt.py
49 lines (39 loc) · 1.41 KB
/
image_gen_prompt.py
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
# Copyright (c) Microsoft. All rights reserved.
import asyncio
from urllib.request import urlopen
try:
from PIL import Image
pil_available = True
except ImportError:
pil_available = False
from semantic_kernel import Kernel
from semantic_kernel.connectors.ai import PromptExecutionSettings
from semantic_kernel.connectors.ai.open_ai import OpenAITextToImage
from semantic_kernel.functions import KernelArguments
"""
This sample demonstrates how to use the OpenAI text-to-image service to generate an image from a prompt.
It uses the OpenAITextToImage class to create an image based on the provided prompt and settings.
The generated image is then displayed using the PIL library if available.
"""
async def main():
kernel = Kernel()
kernel.add_service(OpenAITextToImage(service_id="dalle3"))
result = await kernel.invoke_prompt(
prompt="Generate a image of {{$topic}} in the style of a {{$style}}",
arguments=KernelArguments(
topic="a flower vase",
style="painting",
settings=PromptExecutionSettings(
service_id="dalle3",
width=1024,
height=1024,
quality="hd",
style="vivid",
),
),
)
if result and pil_available:
img = Image.open(urlopen(str(result.value[0].uri))) # nosec
img.show()
if __name__ == "__main__":
asyncio.run(main())