آزمایشگاه ۲ - اجرای Prompt flow با Phi-3-mini در AIPC
February 1, 2026 · View on GitHub
Prompt flow چیست
Prompt flow مجموعهای از ابزارهای توسعه است که برای سادهسازی چرخه کامل توسعه برنامههای هوش مصنوعی مبتنی بر LLM طراحی شده است، از ایدهپردازی، نمونهسازی، تست، ارزیابی تا استقرار در تولید و نظارت. این ابزار مهندسی پرامپت را بسیار آسانتر میکند و به شما امکان میدهد برنامههای LLM با کیفیت تولید بسازید.
با استفاده از prompt flow، شما قادر خواهید بود:
-
جریانهایی بسازید که LLMها، پرامپتها، کد پایتون و سایر ابزارها را در یک روند اجرایی به هم متصل کنند.
-
جریانهای خود را بهویژه تعامل با LLMها به راحتی اشکالزدایی و تکرار کنید.
-
جریانهای خود را ارزیابی کنید، کیفیت و معیارهای عملکرد را با دادههای بزرگتر محاسبه کنید.
-
تست و ارزیابی را در سیستم CI/CD خود ادغام کنید تا کیفیت جریان خود را تضمین کنید.
-
جریانهای خود را به پلتفرم سرویسدهی دلخواه خود مستقر کنید یا به راحتی در کد برنامه خود ادغام کنید.
-
(اختیاری اما بسیار توصیه شده) با استفاده از نسخه ابری Prompt flow در Azure AI با تیم خود همکاری کنید.
ساخت جریانهای تولید کد روی Apple Silicon
توجه: اگر نصب محیط را کامل نکردهاید، لطفاً به آزمایشگاه ۰ - نصبها مراجعه کنید.
- افزونه Prompt flow را در Visual Studio Code باز کنید و یک پروژه جریان خالی ایجاد کنید

- پارامترهای ورودی و خروجی را اضافه کنید و کد پایتون را به عنوان جریان جدید اضافه کنید

میتوانید از این ساختار (flow.dag.yaml) برای ساخت جریان خود استفاده کنید
inputs:
prompt:
type: string
default: Write python code for Fibonacci serie. Please use markdown as output
outputs:
result:
type: string
reference: ${gen_code_by_phi3.output}
nodes:
- name: gen_code_by_phi3
type: python
source:
type: code
path: gen_code_by_phi3.py
inputs:
prompt: ${inputs.prompt}
- کمّیسازی phi-3-mini
امیدواریم بتوانیم SLM را بهتر روی دستگاههای محلی اجرا کنیم. به طور کلی، مدل را کمّیسازی میکنیم (INT4، FP16، FP32)
python -m mlx_lm.convert --hf-path microsoft/Phi-3-mini-4k-instruct
توجه: پوشه پیشفرض mlx_model است
- کد را در Chat_With_Phi3.py اضافه کنید
from promptflow import tool
from mlx_lm import load, generate
# The inputs section will change based on the arguments of the tool function, after you save the code
# Adding type to arguments and return value will help the system show the types properly
# Please update the function name/signature per need
@tool
def my_python_tool(prompt: str) -> str:
model_id = './mlx_model_phi3_mini'
model, tokenizer = load(model_id)
# <|user|>\nWrite python code for Fibonacci serie. Please use markdown as output<|end|>\n<|assistant|>
response = generate(model, tokenizer, prompt="<|user|>\n" + prompt + "<|end|>\n<|assistant|>", max_tokens=2048, verbose=True)
return response
- میتوانید جریان را از طریق Debug یا Run تست کنید تا مطمئن شوید کد تولید به درستی کار میکند

- اجرای جریان به عنوان API توسعه در ترمینال
pf flow serve --source ./ --port 8080 --host localhost
میتوانید آن را در Postman / Thunder Client تست کنید
توجه
-
اجرای اول زمان زیادی میبرد. توصیه میشود مدل phi-3 را از طریق Hugging face CLI دانلود کنید.
-
با توجه به محدودیت قدرت محاسباتی Intel NPU، توصیه میشود از Phi-3-mini-4k-instruct استفاده کنید.
-
ما از شتابدهنده Intel NPU برای کمّیسازی تبدیل INT4 استفاده میکنیم، اما اگر سرویس را دوباره اجرا کنید، باید پوشههای cache و nc_workshop را حذف کنید.
منابع
-
یادگیری Promptflow https://microsoft.github.io/promptflow/
-
یادگیری شتابدهنده Intel NPU https://github.com/intel/intel-npu-acceleration-library
-
کد نمونه، دانلود کد نمونه Local NPU Agent
سلب مسئولیت:
این سند با استفاده از سرویس ترجمه هوش مصنوعی Co-op Translator ترجمه شده است. در حالی که ما در تلاش برای دقت هستیم، لطفاً توجه داشته باشید که ترجمههای خودکار ممکن است حاوی خطاها یا نواقصی باشند. سند اصلی به زبان بومی خود باید به عنوان منبع معتبر در نظر گرفته شود. برای اطلاعات حیاتی، ترجمه حرفهای انسانی توصیه میشود. ما مسئول هیچ گونه سوءتفاهم یا تفسیر نادرستی که از استفاده این ترجمه ناشی شود، نیستیم.