Spaces:
Running
Running
Update app.py
Browse files
app.py
CHANGED
@@ -1,64 +1,91 @@
|
|
1 |
import gradio as gr
|
2 |
-
from
|
|
|
3 |
|
4 |
-
|
5 |
-
|
6 |
-
""
|
7 |
-
client = InferenceClient("HuggingFaceH4/zephyr-7b-beta")
|
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 |
if __name__ == "__main__":
|
64 |
-
demo.launch()
|
|
|
1 |
import gradio as gr
|
2 |
+
from simple_inference import predict_location
|
3 |
+
import os
|
4 |
|
5 |
+
# 设置默认模型和引擎
|
6 |
+
DEFAULT_MODEL = "Qwen/Qwen2.5-VL-7B-Instruct"
|
7 |
+
DEFAULT_ENGINE = "transformers"
|
|
|
8 |
|
9 |
+
def process_image(image, model_name, inference_engine):
|
10 |
+
"""
|
11 |
+
处理上传的图片并返回预测结果
|
12 |
+
"""
|
13 |
+
# 保存上传的图片到临时文件
|
14 |
+
temp_path = "temp_image.jpg"
|
15 |
+
image.save(temp_path)
|
16 |
+
|
17 |
+
try:
|
18 |
+
# 调用预测函数
|
19 |
+
result = predict_location(
|
20 |
+
image_path=temp_path,
|
21 |
+
model_name=model_name,
|
22 |
+
inference_engine=inference_engine
|
23 |
+
)
|
24 |
+
|
25 |
+
# 删除临时文件
|
26 |
+
os.remove(temp_path)
|
27 |
+
|
28 |
+
return result
|
29 |
+
except Exception as e:
|
30 |
+
# 删除临时文件
|
31 |
+
if os.path.exists(temp_path):
|
32 |
+
os.remove(temp_path)
|
33 |
+
return f"发生错误: {str(e)}"
|
34 |
|
35 |
+
# 创建Gradio界面
|
36 |
+
with gr.Blocks(title="位置识别系统") as demo:
|
37 |
+
gr.Markdown("# 🏞️ 图片位置识别系统")
|
38 |
+
gr.Markdown("上传一张图片,系统将识别图片拍摄的国家和地区。")
|
39 |
+
|
40 |
+
with gr.Row():
|
41 |
+
with gr.Column():
|
42 |
+
# 图片上传组件
|
43 |
+
image_input = gr.Image(type="pil", label="上传图片")
|
44 |
+
|
45 |
+
# 模型选择
|
46 |
+
model_name = gr.Textbox(
|
47 |
+
label="模型名称",
|
48 |
+
value=DEFAULT_MODEL,
|
49 |
+
info="输入Hugging Face模型ID或本地模型路径"
|
50 |
+
)
|
51 |
+
|
52 |
+
# 推理引擎选择
|
53 |
+
inference_engine = gr.Dropdown(
|
54 |
+
choices=["transformers", "vllm"],
|
55 |
+
value=DEFAULT_ENGINE,
|
56 |
+
label="推理引擎"
|
57 |
+
)
|
58 |
+
|
59 |
+
# 提交按钮
|
60 |
+
submit_btn = gr.Button("开始识别", variant="primary")
|
61 |
+
|
62 |
+
with gr.Column():
|
63 |
+
# 结果显示
|
64 |
+
output = gr.Textbox(
|
65 |
+
label="识别结果",
|
66 |
+
lines=10,
|
67 |
+
placeholder="识别结果将显示在这里..."
|
68 |
+
)
|
69 |
+
|
70 |
+
# 设置提交按钮的回调函数
|
71 |
+
submit_btn.click(
|
72 |
+
fn=process_image,
|
73 |
+
inputs=[image_input, model_name, inference_engine],
|
74 |
+
outputs=output
|
75 |
+
)
|
76 |
+
|
77 |
+
# 添加示例
|
78 |
+
gr.Examples(
|
79 |
+
examples=[
|
80 |
+
["examples/example1.jpg", DEFAULT_MODEL, DEFAULT_ENGINE],
|
81 |
+
["examples/example2.jpg", DEFAULT_MODEL, DEFAULT_ENGINE],
|
82 |
+
],
|
83 |
+
inputs=[image_input, model_name, inference_engine],
|
84 |
+
outputs=output,
|
85 |
+
fn=process_image,
|
86 |
+
cache_examples=True,
|
87 |
+
)
|
88 |
|
89 |
+
# 启动应用
|
90 |
if __name__ == "__main__":
|
91 |
+
demo.launch(share=True)
|