Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
在現有軟體服務中整合 Copilot 功能:Context 與 UI 的新挑戰
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kewang
December 27, 2024
Programming
82
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
在現有軟體服務中整合 Copilot 功能:Context 與 UI 的新挑戰
Kewang
December 27, 2024
More Decks by Kewang
See All by Kewang
從裝潢設計圖到 Home Assistant:打造智慧家庭的實戰與踩坑筆記
kewang
0
1.7k
自 LLM 誕生的新 UX 模式,如何在現有軟體服務整合 copilot
kewang
0
82
如何在有限資源下實現十年的後端服務演進
kewang
1
2.8k
Other Decks in Programming
See All in Programming
Performance Engineering for Everyone
elenatanasoiu
0
200
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
290
エンジニア向け会社紹介/Findy Company Profile
findyinc
6
350k
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
370
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
3
730
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
600
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
180
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
290
エンジニアと一緒にテストコードの設計と実装を改善した話
mototakatsu
0
210
依存関係から依存物へ―Dependencyという言葉の歴史をひも解く
j_lee
0
130
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
150
The NotImplementedError Problem in Ruby
koic
1
900
Featured
See All Featured
The agentic SEO stack - context over prompts
schlessera
0
820
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
56k
Chasing Engaging Ingredients in Design
codingconduct
0
220
Rails Girls Zürich Keynote
gr2m
96
14k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
340
Product Roadmaps are Hard
iamctodd
PRO
55
12k
Making Projects Easy
brettharned
120
6.7k
HDC tutorial
michielstock
2
720
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
260
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
Transcript
在現有軟體服務中整合 Copilot 功能: Context 與 UI 的新挑戰 Kewang, Funliday
Kewang • 王慕羣 Kewang • JavaScript / Java • PostgreSQL
/ MongoDB / Elasticsearch / HBase • Git / DevOps • 熱愛開源 Linkedin Linkedin kewangtw kewangtw SlideShare SlideShare kewang kewang Gmail Gmail cpckewang cpckewang Facebook Facebook Kewang 的資訊進化論 Kewang 的資訊進化論 devopsday taipei devopsday taipei '17 '17 hadoopcon hadoopcon '14 '15 '14 '15 jcconf jcconf '16 '17 '18 '16 '17 '18 GitHub GitHub kewang kewang Funliday Funliday kewang kewang modernweb modernweb '18 '19 '20 '21 '18 '19 '20 '21 coscup coscup '20 '21 '20 '21 webconf webconf '23 '23 mopcon mopcon '14 '20 '22 '24 '14 '20 '22 '24
3 主題開始
4 大家都愛用 GitHub Copilot
5 大家都愛用 GitHub Copilot 或是 Cursor
6 但今天不講 GitHub Copilot
7 今天內容
8 今天內容 • 跟 GitHub Copilot 完全無關 • 如何整合 Copilot
到你開發的軟體 • 如何設計 context
9 先介紹一下 Funliday
10 先介紹一下 Funliday 沒有要業配
None
12 DEMO 無 copilot
13 使用者遇到的問題
14 使用者遇到的問題 • 不知道怎麼改停留時間
15 使用者遇到的問題 • 不知道怎麼改停留時間 • 不知道怎麼改交通方式
16 使用者遇到的問題 • 不知道怎麼改停留時間 • 不知道怎麼改交通方式 • 不知道怎麼移動景點
17 使用者遇到的問題 • 不知道怎麼改停留時間 • 不知道怎麼改交通方式 • 不知道怎麼移動景點 • 不知道
... 等
18 使用者遇到的問題 • 不知道怎麼改停留時間 • 不知道怎麼改交通方式 • 不知道怎麼移動景點 • 不知道
... 等 使用者一般不看 coachmark
19 Funliday Copilot
20 Copilot
21 Copilot • 幫助使用者更有效率地完成任務
22 Copilot • 幫助使用者更有效率地完成任務 • 運用 AI 來分析使用者的行為、需求和上下文, 提供即時建議或自動化部分任務
23 Copilot • 幫助使用者更有效率地完成任務 • 運用 AI 來分析使用者的行為、需求和上下文, 提供即時建議或自動化部分任務 •
為了簡化流程或減少使用者的工作負擔
24 Funliday Copilot 更改出發時間
25 Funliday Copilot 更改停留時間
26 DEMO 有 copilot
27 最高原則
28 最高原則 • 在目前畫面上的所有功能都要可以做到
29 最高原則 • 在目前畫面上的所有功能都要可以做到 • 如果沒辦法做到,要能回饋給使用者
30 發現新功能
31 發現新功能 • 功能開發時,很自然就想到的拖拉天數功能
32 發現新功能 • 功能開發時,很自然就想到的拖拉天數功能
33 發現新功能 • 功能開發時,很自然就想到的拖拉天數功能 • 與 Copilot 對話過程中,發現天數交換很重要, 就新增了天數交換
34 發現新功能
35 發現新功能 • 幫我把第三天移到第五天後面
36 發現新功能 • 幫我把第三天移到第五天後面 • 幫我把第三天跟第五天交換
37 技術實作
38 先來看張圖
39
40 使用者利用各種方式告訴 client 要做什麼事
41 client 將內容送到 server 開始解析
42 用 LLM 解析會花很長時間,所以丟到 MQ
43 把內容丟到 MQ 後,就趕快回傳 client 成功
44 MQ 會把問句、 context 、 function call 這三者組合好之後丟去問 LLM
45 LLM 會將解析完的結果回傳到 MQ 結果會有兩種, function call 或一般回應
46 MQ 有原本 Client 相同 SocketIO 房間的 client 稱為 Copilot
,並將 LLM 的回應交給 Copilot
47 如果回應是 function call 的話 Copilot 就會執行這個動作 ( 如新增景點 ...
等 )
48 執行完 function 之後會透過 SocketIO 將結果送到同房間的其他 client
49 如果 Client 跟原始發出請求的 Client 相同 就顯示 Copilot 動畫
50 如果 Client 跟原始發出請求的 Client 不同 就不顯示動畫
51
52 如何整合目前的操作
53
54 定義 function
55 定義回傳參數與原功能的參數介面
56 原功能的業務邏輯
57 分享一些實作要注意的地方
58 要注意喔
59 要注意喔 • LLM
60 要注意喔 • LLM – Function call
61 要注意喔 • LLM – Function call – Shift system
prompt
62 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context
63 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check
64 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check • Socket.IO
65 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check • Socket.IO – client 要能分辨 copilot
66 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check • Socket.IO – client 要能分辨 copilot – emit 要分開發送
67 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check • Socket.IO – client 要能分辨 copilot – emit 要分開發送 • 支援多動作
68 要注意喔 • LLM – Function call – Shift system
prompt – 自定義 context – 刪除動作必須 double check • Socket.IO – client 要能分辨 copilot – emit 要分開發送 • 支援多動作
69 Function call
70 Function call 取得特定地點的溫度
71 Function call 幫景點加上別名
72 Shift system prompt
73 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 角色扮演
74 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 把目前畫面的所有資訊加上去
75 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 使用者輸入要執行的指令
76 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 LLM 用指令與 context 取出結構化資料
77 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 將結構化資料執行之後,回傳結果給 LLM
78 Shift system prompt no. role prompt 1 system (base)
你是行程規劃 copilot, blahblah 2 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰豐 "}, {"id":456,"name":" 晴空塔 "}]}} 3 user 幫我把鼎泰豐標示為午餐 4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 LLM 將執行結果轉換為文字回傳
79 Shift system prompt no. role prompt 3 user 幫我把鼎泰豐標示為午餐
4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 7 system (base) 你是行程規劃 copilot, blahblah 8 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰 豐 ","alias":" 午餐 "},{"id":456,"name":" 晴空塔 "}]}} 9 user 幫我把晴空塔刪掉 接續的指令將角色扮演移到 prompt 最下方 強調最新資訊
80 Shift system prompt no. role prompt 3 user 幫我把鼎泰豐標示為午餐
4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 7 system (base) 你是行程規劃 copilot, blahblah 8 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰 豐 ","alias":" 午餐 "},{"id":456,"name":" 晴空塔 "}]}} 9 user 幫我把晴空塔刪掉 加上目前的最新畫面,包括稍早的鼎泰豐午餐
81 Shift system prompt no. role prompt 3 user 幫我把鼎泰豐標示為午餐
4 assistant {"id":"call_id_test","arguments": {"id":123,"name":" 鼎泰豐 ","alias":" 午餐 "}} 5 tool*n {"id":"call_id_test","content":"{\"success\":true}"} 6 assistant 已成功為您把鼎泰豐標示為午餐 7 system (base) 你是行程規劃 copilot, blahblah 8 system (context) {"context":{"pois":[{"id":123,"name":" 鼎泰 豐 ","alias":" 午餐 "},{"id":456,"name":" 晴空塔 "}]}} 9 user 幫我把晴空塔刪掉 下一次使用者要輸入的指令
82 自定義 context
83 自定義 context • 畫面上的所有內容都要做為 context
84 自定義 context • 畫面上的所有內容都要做為 context • API 回傳的內容 !=
畫面上的內容
85 自定義 context - API 資料 不知所云的欄位
86 自定義 context - 翻譯後 名稱及內容讓 LLM 看的懂
87 Context useless
88 Context useless • 2024/10/22 : claude 公佈 computer use
89 Context useless • 2024/10/22 : claude 公佈 computer use
• 不久的將來連自行定義 context 都不用了
90 支援多動作
91 支援多動作 • 使用 Function call 可一次萃取多個任務
92 支援多動作 • 使用 Function call 可一次萃取多個任務 • 後端同時回傳多個任務給前端
93 支援多動作 • 使用 Function call 可一次萃取多個任務 • 後端同時回傳多個任務給前端 •
後端難度:同時支援新舊版的前端,同時回傳一 個或多個任務
94 支援多動作 • 使用 Function call 可一次萃取多個任務 • 後端同時回傳多個任務給前端 •
後端難度:同時支援新舊版的前端,同時回傳一 個或多個任務 • 前端難度:從原本 1 個任務,變成 n 個任 務, UIUX 的挑戰變高
95 結論
96 結論
97 結論 • Copilot 的整合帶來新行為與複合操作,豐富使 用者體驗
98 結論 • Copilot 的整合帶來新行為與複合操作,豐富使 用者體驗 • 前端工程師需設計直觀介面,以提升操作效率並 避免使用者困惑
99 結論 • Copilot 的整合帶來新行為與複合操作,豐富使 用者體驗 • 前端工程師需設計直觀介面,以提升操作效率並 避免使用者困惑 •
後端工程師需優化情境管理,確保 Copilot 即時 精確回應多任務需求
100