با تغییر مدل قیمت‌گذاری GitHub Copilot، مدیریت توکن‌ها دیگر فقط دغدغه کاربران سازمانی یا تیم‌های بزرگ نیست. هر درخواستی که به Copilot ارسال می‌کنید، بخشی از سهمیه یا اعتبار مصرفی شما را کاهش می‌دهد و اگر از مدل‌های پیشرفته یا Agent Mode استفاده کنید، این مصرف می‌تواند به‌مراتب بیشتر باشد.

    ۱. Context را تا حد امکان کوچک، اما کامل نگه دارید۲. برای هر وظیفه گفت‌وگوی جدیدی شروع کنیدچالش Lost in the Middleسوگیری تازگی (Recency Bias)برای درگیر نشدن با این چالش‌ها چه کنیم؟۳. همیشه از Agent Mode استفاده نکنید۴. برای هر کار، مدل مناسب را انتخاب کنید۵. خروجی‌های کوتاه‌تر بخواهید و از استراتژی استفاده کنید۶. فایل دستورالعمل را مرتب نگه دارید۷. وظایف بزرگ را به چند مرحله تقسیم کنید۸. داده‌های غیرضروری را قبل از ارسال حذف کنیدبهینه‌سازی خروجی‌ها با ابزارهای تخصصی (مانند RTK)۹. از تکرار خطاها جلوگیری کنید

کاهش مصرف توکن فقط به‌معنی صرفه‌جویی در هزینه نیست؛ هرچه کانتکست دقیق‌تر و مختصرتر باشد، مدل نیز معمولاً پاسخ‌های دقیق‌تر و مرتبط‌تری تولید می‌کند. به‌همین دلیل، بسیاری از توسعه‌دهندگان حرفه‌ای به‌جای تمرکز صرف بر کاهش تعداد توکن‌ها، تلاش می‌کنند کیفیت کانتکست را بهبود دهند؛ رویکردی که هم هزینه را کاهش می‌دهد، هم عملکرد کوپایلت را بهبود می‌بخشد.

آموزشی که در ادامه می‌خوانید، براساس منابع رسمی GitHub و تجربه مهندسان این حوزه گردآوری شده‌ است و نشان می‌دهند چگونه با ارائه اطلاعات درست، در زمان درست و به اندازه کافی، می‌توان هم مصرف توکن را کاهش داد، هم پاسخ‌های دقیق‌تر و سریع‌تری از کوپایلت دریافت کرد.

۱. Context را تا حد امکان کوچک، اما کامل نگه دارید

مهم‌ترین عاملی که روی مصرف توکن تأثیر می‌گذارد، میزان کانتکست ارسال‌شده برای مدل است. گیت‌‌هاب کوپایلت تنها به پیام فعلی شما نگاه نمی‌کند؛ بلکه بسته به نوع درخواست، شاید فایل‌های باز، تاریخچه گفت‌وگو و اطلاعات دیگری از پروژه را نیز به مدل ارسال کند. قاعده‌ای که بسیاری از تیم‌های توسعه از آن استفاده می‌کنند این است که کانتکست را تا حد امکان کوچک نگه می‌دارند، اما نه آن‌قدر کوچک که اطلاعات ضروری برای انجام کار حذف شود.

توصیه می‌شود برای بهینه‌سازی حداکثری، بیش از ۵ تب مرتبط را باز نگه ندارید

به همین دلیل، بهتر است هنگام انجام هر وظیفه فقط فایل‌های مرتبط را باز نگه دارید و تب‌های اضافی، فایل‌های لاگ یا پروژه‌های قدیمی را ببندید.

اگر فقط قصد اصلاح چند خط کد را دارید، نیازی نیست کل فایل را در اختیار Copilot قرار دهید. استفاده از ارجاع به فایل یا انتخاب همان بخش موردنظر، معمولاً نتیجه مشابهی ایجاد می‌کند اما با مصرف توکن بسیار کمتر.

برای مثال، فرض کنید فقط می‌خواهید تابع ورود کاربران را اصلاح کنید. اگر کل فایل ۷۰۰ خطی یا حتی چندین فایل پروژه را در اختیار Copilot قرار دهید، تمام آن اطلاعات وارد کانتکست می‌شوند و توکن بیشتری مصرف می‌شود. در مقابل، اگر فقط همان تابع را انتخاب کنید یا مستقیماً به فایل و متد موردنظر اشاره کنید، معمولاً مدل با اطلاعات کمتر هم می‌تواند همان نتیجه را تولید کند.

کانتکست همیشه فقط متن چت نیست. فراموش نکنید که کانتکست بیش از حد و نامرتبط، فقط توکن مصرف نمی‌کند، بلکه باعث انحراف (Bias) مدل می‌شود؛ یعنی هوش مصنوعی نمی‌تواند داده‌های مهم را از نویز تشخیص دهد و پاسخ‌های غلط می‌دهد

۲. برای هر وظیفه گفت‌وگوی جدیدی شروع کنید

یکی از اشتباهات رایج این است که همه کارها در یک گفت‌وگوی طولانی انجام شوند. در چنین شرایطی، تاریخچه مکالمه به‌تدریج بزرگ‌تر می‌شود و مدل باید حجم بیشتری از اطلاعات را در هر درخواست پردازش کند؛ البته در کنار توکن‌سوزی بیشتر، جواب‌هایی که می‌گیرید دقیق نخواهند بود؛ بنابراین مجبور به ارسال درخواست‌های بیشتر خواهید شد.

برای جلوگیری از این موضوع باید با دو مفهوم Lost in the Middle و Recency Bias آشنا شوید تا از آن‌ها جلوگیری کنید.

چالش Lost in the Middle

حتی در گفت‌وگوهای نه چندان طولانی، مدل‌ها تمایل دارند به اطلاعات ابتدا (دستورات سیستمی و قوانین پروژه) و انتها (آخرین درخواست شما) توجه بیشتری کنند و بخش‌های میانی چت را نادیده بگیرند.

مدل‌ها تمایل دارند بخش‌های میانی چت را نادیده بگیرند

اگر در میان یک گفت‌وگوی طولانی، ناگهان موضوع را عوض کنید، تسک جدید شما در «میانه» کانتکست قرار می‌گیرد و احتمالاً کوپایلت در اجرای آن گیج می‌شود. به همین دلیل، برای هر وظیفه جدید، یک چت جدید شروع کنید تا تسک همیشه در نقطه طلایی یعنی پایان پنجره قرار بگیرد.

سوگیری تازگی (Recency Bias)

وقتی حجم توکن‌ها به ۶۰ تا ۷۰ درصد از ظرفیت پنجره کانتکست می‌رسد، مدل دچار «سوگیری تازگی» می‌شود. در این حالت، فشار اطلاعات آنقدر زیاد است که مدل حتی دستورات اولیه و حیاتی که در ابتدای چت نوشته بودید (مانند فایل copilot.instructions) را هم فراموش می‌کند و فقط براساس چند پیام آخر عمل می‌کند.

برای درگیر نشدن با این چالش‌ها چه کنیم؟

    برای جلوگیری از وقوعLost in the Middle، موضوع گفت‌وگو را وسط چت عوض نکنید (تمرکز بر کیفیت).برای جلوگیری ازRecency Bias، اجازه ندهید گفت‌وگو بیش از حد طولانی شود و تب‌های اضافی را ببندید تا کانتکست به مرز اشباع نرسد (تمرکز بر کمیت).

به‌محض اینکه احساس کردید پاسخ‌های کوپایلت از مسیر اصلی منحرف شده یا حجم گفت‌وگو زیاد شده است، سشن را پاک کنید (clear/) تا با صرف توکن کمتر، دقت مدل را به ۱۰۰درصد برگردانید.

۳. همیشه از Agent Mode استفاده نکنید

Agent Mode یکی از قدرتمندترین قابلیت‌های گیت‌هاب کوپایلت است، اما همیشه بهترین انتخاب نیست. در این حالت، کوپایلت علاوه‌بر تحلیل درخواست، ابزارهای مختلف را فراخوانی می‌کند، فایل‌های بیشتری را بررسی می‌کند و شاید چندین مرحله برای رسیدن به پاسخ طی کند. همه این مراحل مصرف توکن را افزایش می‌دهند.

Agent Mode را برای کارهای پیچیده‌تر استفاده کنید

اگر فقط قصد دارید درباره یک قطعه کد سؤال بپرسید، تابعی را بازنویسی کنید یا توضیح کوتاهی دریافت کنید، استفاده از حالت Ask معمولاً سریع‌تر، ارزان‌تر و کافی است.

ویژگی Auto Mode در VS Code به صورت هوشمند بین مدل‌ها سوییچ می‌کند و ۱۰درصد تخفیف در هزینه توکن به همراه دارد.

استفاده از ایجنت مود برای یک سؤال ساده که درحالت Ask قابل حل است، می‌تواند تا ۱۰برابر هزینه توکن بیشتری داشته باشد. بهتر است این حالت را برای کارهای پیچیده‌تر مانند ریفکتور کردن پروژه، پیاده‌سازی قابلیت‌های جدید یا بررسی ساختار کد کنار بگذارید.

۴. برای هر کار، مدل مناسب را انتخاب کنید

یکی از اشتباهات رایج این است که کاربران برای هر کاری سراغ قدرتمندترین مدل موجود می‌روند؛ درحالی‌که بسیاری از وظایف روزمره مانند تغییر نام متغیرها، نوشتن تست یا تکمیل توابع ساده با مدل‌های سبک‌تر نیز به همان کیفیت انجام می‌شوند و هزینه بسیار کمتری دارند. در مقابل، برای طراحی معماری، تحلیل پروژه‌های بزرگ یا رفع باگ‌های پیچیده، استفاده از مدل‌های قدرتمند منطقی‌تر است.

یرای هر کاری سراغ قدرتمندترین مدل موجود نروید

مدل‌های سنگین گاهی در اجرا و کارگیری بدتر عمل می‌کنند چون ممکن است در برنامه‌ریزی شما شک کرده و خودسرانه عمل کنند (Go Rogue)؛ بنابراین برای اجرا، مدل‌های سبک‌تر که دقیقاً طبق نقشه پیش می‌روند، گاهی باکیفیت‌تر هم هستند.

اگر از VS Code استفاده می‌کنید، فعال‌کردن حالت Auto نیز می‌تواند انتخاب مدل را به Copilot بسپارد تا متناسب با نوع درخواست، گزینه مناسب را انتخاب کند.

۵. خروجی‌های کوتاه‌تر بخواهید و از استراتژی استفاده کنید

بخش قابل توجهی از هزینه به خروجی مدل مربوط می‌شود؛ بنابراین اگر فقط به کد نیاز دارید، بهتر است همان را درخواست کنید.

به‌عنوان مثال، به‌جای اینکه از Copilot بخواهید کد را همراه با توضیح کامل تولید کند، می‌توانید از دستورهایی مانندCode onlyیاNo explanationاستفاده کنید؛ همچنین اگر صرفاً تغییرات یک فایل برایتان اهمیت دارد، درخواست نمایش اختلاف (Diff) به‌جای بازنویسی کامل فایل، توکن بسیار کمتری مصرف می‌کند.

پرامپت‌نویسی فشرده = ۳۰ تا ۵۰ درصد کاهش مصرف توکن‌های ورودی

ازطرفی بسیاری عادت دارند پرامپت‌های خود را رسمی، مؤدبانه و با جملات کامل بنویسند؛ اما مدل‌های هوش مصنوعی هیچ نیازی به تعارفات ندارند. در دنیای کوپایلت، استراتژی‌ Caveman Speak یا همان پرامپت‌نویسی فشرده می‌تواند ۳۰ تا ۵۰ درصد در مصرف توکن‌های ورودی صرفه‌جویی کند.

    پرامپت اشتباه (مؤدبانه):

"Hello Copilot, could you please rewrite this function for me so that it has better readability? I would be grateful if you could change the code in a way that it uses simpler variables. Thank you!"

    پرامپت درست (Caveman Speak):

"Refactor for readability. Use simple variables. Code only."

با حذف کلمات اضافی، نه تنها اعتبار مصرفی خود را مدیریت می‌کنید، بلکه احتمال انحراف مدل را کاهش خواهید داد و پاسخ‌های سریع‌تری دریافت خواهید کرد.

۶. فایل دستورالعمل را مرتب نگه دارید

اگر از فایل‌های دستورالعمل پروژه (instructions) استفاده می‌کنید، بهتر است آن‌ها را مرتب بازبینی کنید. به توصیه کارشناسان، فایل instructions باید زیر ۲۰ سطر بماند و اگر سنگین باشد، هر پیام ساده هم مبلغ زیادی بابت توکن‌های سیستمی پرداخت می‌کند. تیم‌های حرفه‌ای هر سه ماه یک‌بار این فایل را کاملاً پاک می‌کنند و از نو می‌نویسند تا دستورات قدیمی و بی‌استفاده حذف شوند.

هر قانونی که داخل فایل instructions قرار می‌گیرد، ممکن است در درخواست‌های بعدی نیز برای مدل ارسال شود؛ به‌همین دلیل، نگه‌داشتن فایل در حد قوانین ضروری، حذف دستورهای قدیمی و محدودکردن هر قانون به فایل‌های مرتبط، می‌تواند بدون تغییر در کیفیت پاسخ‌ها، مصرف توکن را کاهش دهد.

به توصیه کارشناسان بهتر است از هوش مصنوعی برای نوشتن فایل instructions استفاده نکنید، چون هوش مصنوعی متون را طولانی و غیردقیق می‌نویسد. بااین‌حال تصمیم با خودتان است می‌توانید فایل نهایی را براساس چیزی که می‌دانید بازنویسی کنید و دقت آن را در کوتاهترین فرم بالا ببرید.

۷. وظایف بزرگ را به چند مرحله تقسیم کنید

به‌جای اینکه از کوپایلت بخواهید کل پروژه را یک‌باره تحلیل یا بازنویسی کند، بهتر است کار را به چند مرحله کوچک‌تر تقسیم کنید.

برای مثال، ابتدا از مدل بخواهید ساختار پروژه را بررسی کند، سپس پیشنهادهایی برای بهبود ارائه دهد و در مرحله بعد، هر فایل را جداگانه اصلاح کند. این روش نه‌تنها مصرف توکن را کاهش می‌دهد، بلکه احتمال خطا و خروج مدل از مسیر اصلی را نیز کمتر می‌کند.

بین هر فاز از دستور clear/ استفاده کنید تا اطلاعات فاز قبلی؛ مثلاً جزئیات حجیم فاز تحقیق به فاز اجرا منتقل نشود و توکن بیهوده مصرف نکند

۸. داده‌های غیرضروری را قبل از ارسال حذف کنید

ارسال فایل‌های لاگ، پاسخ‌های طولانی API یا خروجی کامل ترمینال معمولاً فقط حجم زیادی از توکن‌ها را مصرف می‌کند؛ درحالی‌که بخش عمده آن اطلاعات هیچ تأثیری در پاسخ نهایی ندارد.

فقط بخش‌هایی را که به مشکل مربوط هستند در اختیار کوپایلت قرار دهید

پیش از ارسال چنین داده‌هایی، بهتر است آن‌ها را فیلتر یا خلاصه کنید و فقط قسمت‌هایی را که به مشکل مربوط هستند در اختیار کوپایلت قرار دهید؛ مثلاً به جای ارسال کل خروجی یک API حجیم، فقط فیلد‌های کلیدی (Relevant Fields) را جدا کنید و برای کوپایلت بفرستید.

بهینه‌سازی خروجی‌ها با ابزارهای تخصصی (مانند RTK)

یکی از چالش‌های بزرگ در کار با کوپایلت، ارسال خروجی‌های حجیم ترمینال یا API-های شلوغ به داخل چت است. از آنجایی که مدل‌های زبانی نمی‌توانند به‌خوبی داده‌های مرتبط را از نویز تشخیص دهند، ارسال یک خروجی لاگ چندصد سطری می‌تواند باعث گیج‌شدن مدل و هدررفت شدید توکن شود.

همیشه قبل از ارسال داده‌های خام، آن‌ها را با اسکریپت‌های ساده یا ابزارهایی مثل RTK فیلتر کنید

کاربران حرفه‌ای برای حل مشکل نویز در پرامپت‌ها از ابزارهای فیلترکننده استفاده می‌کنند. ابزاری مانندRTK (Runtime ToolKit)به‌طور اختصاصی برای همین کار طراحی شده است؛ این ابزار خروجی‌های ترمینال (Shell Output) را قبل از ارسال به کانتکست کوپایلت اسکن می‌کند و فقط اطلاعاتی را که برای ایجنت حیاتی است، باقی می‌گذارد.

به‌عنوان یک قاعده کلی، همیشه قبل از ارسال داده‌های خام؛ مانند پاسخ‌های JSON سنگین، آن‌ها را با اسکریپت‌های ساده یا ابزارهایی مثل RTK فیلتر کنید تا فقط فیلدهای کلیدی ارسال شوند. این کار مصداق بارز «مهندسی کانتکست» است: ارائه کمترین حجم داده، اما با بیشترین دقت ممکن.

۹. از تکرار خطاها جلوگیری کنید

مصرف زیاد توکن همیشه به طولانی‌بودن پرامپت یا حجم کانتکست مربوط نمی‌شود. گاهی کوپایلت برای رسیدن به پاسخ مناسب چند راهکار مختلف را امتحان می‌کند، پس‌از مواجهه با خطا درخواست‌های جدیدی ارسال می‌کند یا بخشی از کد را چندین بار بازنویسی می‌کند. هر بار تکرار این فرایند، توکن بیشتری مصرف خواهد کرد.

به‌همین دلیل، هرچه پروژه ساختار منظم‌تری داشته باشد و درخواست‌ها با جزئیات و شفافیت بیشتری مطرح شوند، احتمال اینکه Copilot از همان ابتدا مسیر درستی را انتخاب کند افزایش می‌یابد. در نتیجه، علاوه بر کاهش زمان توسعه، تعداد درخواست‌های اضافی و مصرف توکن نیز کمتر می‌شود.

    بهترین ابزار هوش مصنوعی برای برنامه‌ نویسی در سال ۲۰۲۵

وجود تست‌های خودکار و ابزارهایی مانند لینترها نیز در همین راستا مؤثر است. این ابزارها مانند یک مکانیزم بازخورد سریع عمل می‌کنند و به کوپایلت کمک می‌کنند زودتر متوجه اشتباه‌های خود شود. در نتیجه، ایجنت هوش مصنوعی برای رسیدن به پاسخ نهایی، دفعات کمتری به اصلاح یا تولید مجدد کد نیاز خواهد داشت.

اگر دقت مدل در هر مرحله ۹۹درصد باشد، بعد از ۵۰ مرحله دقت کل به ۶۱درصد سقوط می‌کند؛ اما یک تست ناموفق (Deterministic Control) مانند یک دکمه ریست عمل می‌کند و دقت را دوباره به ۱۰۰درثد برمی‌گرداند

مدیریت توکن در گیت‌‌هاب کوپایلت فقط به کاهش هزینه‌ها محدود نمی‌شود. هرچه کانتکست هدفمندتر باشد، مدل مناسب‌تری انتخاب کنید و وظایف را به بخش‌های کوچک‌تر تقسیم کنید، کوپایلت نیز پاسخ‌های دقیق‌تر و قابل‌اعتماد‌تری ارائه خواهد داد. درنهایت باید یاد بگیرید اطلاعات درست را در زمان درست و با حجم مناسب در اختیار کوپایلت قرار دهید.

آیا تاکنون متوجه افزایش غیرمنتظره مصرف توکن در GitHub Copilot شده‌اید؟ شما برای کاهش مصرف توکن یا افزایش دقت کوپایلت گیت‌هاب از چه ترفندهایی استفاده می‌کنید؟ اگر تجربه یا راهکاری دارید که در این مقاله به آن اشاره نشده است، آن را در بخش دیدگاه‌ها با دیگر کاربران زومیت به اشتراک بگذارید.

#GitHub