Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -1,31 +1,38 @@
|
|
|
|
1 |
import gradio as gr
|
2 |
-
from transformers import pipeline
|
|
|
3 |
|
4 |
-
#
|
5 |
-
|
|
|
|
|
|
|
6 |
generator = pipeline(
|
7 |
-
"text-generation",
|
8 |
-
model=
|
9 |
-
|
|
|
|
|
|
|
10 |
)
|
11 |
|
12 |
-
#
|
|
|
13 |
def generate_text(prompt):
|
14 |
-
#
|
15 |
-
result = generator(prompt, max_new_tokens=
|
16 |
-
|
|
|
17 |
|
18 |
-
#
|
19 |
-
# テキストボックスを入力と出力に設定し、generate_text関数を呼び出すシンプルなUIを構築
|
20 |
demo = gr.Interface(
|
21 |
-
fn=generate_text,
|
22 |
-
inputs=gr.
|
23 |
-
outputs=gr.
|
24 |
-
title="
|
25 |
-
description="
|
26 |
)
|
27 |
|
28 |
-
#
|
29 |
-
|
30 |
-
demo.launch()
|
31 |
-
|
|
|
1 |
+
import spaces
|
2 |
import gradio as gr
|
3 |
+
from transformers import AutoTokenizer, pipeline
|
4 |
+
import torch
|
5 |
|
6 |
+
# 使用するモデル名(Falcon-7B-Instructを例に使用)
|
7 |
+
model_name = "tiiuae/falcon-7b-instruct"
|
8 |
+
|
9 |
+
# トークナイザとテキスト生成パイプラインの準備
|
10 |
+
tokenizer = AutoTokenizer.from_pretrained(model_name)
|
11 |
generator = pipeline(
|
12 |
+
"text-generation",
|
13 |
+
model=model_name,
|
14 |
+
tokenizer=tokenizer,
|
15 |
+
torch_dtype=torch.bfloat16, # モデルをbfloat16精度でロード(メモリ節約)
|
16 |
+
trust_remote_code=True, # モデルのリポジトリ内の追加コードを信頼して読み込む
|
17 |
+
device_map="auto" # 利用可能なGPUに自動割り当て(ZeroGPU環境ではA100を使用)
|
18 |
)
|
19 |
|
20 |
+
# GPUを利用する推論関数を定義(ZeroGPUのためデコレータを使用)
|
21 |
+
@spaces.GPU
|
22 |
def generate_text(prompt):
|
23 |
+
# プロンプトからテキストを生成し、結果文字列を返す
|
24 |
+
result = generator(prompt, max_new_tokens=100, do_sample=True)
|
25 |
+
generated = result[0]["generated_text"]
|
26 |
+
return generated
|
27 |
|
28 |
+
# Gradioインタフェースの構築(テキスト入力→テキスト出力)
|
|
|
29 |
demo = gr.Interface(
|
30 |
+
fn=generate_text,
|
31 |
+
inputs=gr.Textbox(lines=3, label="入力プロンプト"),
|
32 |
+
outputs=gr.Textbox(label="生成されたテキスト"),
|
33 |
+
title="Falcon-7B-Instruct テキスト生成デモ",
|
34 |
+
description="プロンプトを入力すると、大規模言語モデルが続きのテキストを生成します。"
|
35 |
)
|
36 |
|
37 |
+
# アプリの起動(Spaces上ではこれによりサービスが公開される)
|
38 |
+
demo.launch()
|
|
|
|