robot_lab 0.1.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (242) hide show
  1. checksums.yaml +4 -4
  2. data/.architecture/AGENTS.md +32 -0
  3. data/.architecture/config.yml +8 -0
  4. data/.architecture/members.yml +60 -0
  5. data/.architecture/reviews/feature-free-will.md +490 -0
  6. data/.architecture/reviews/overall-codebase.md +427 -0
  7. data/.claude/settings.local.json +57 -0
  8. data/.codex/config.toml +2 -0
  9. data/.irbrc +2 -2
  10. data/.rubocop.yml +172 -0
  11. data/CHANGELOG.md +72 -0
  12. data/CLAUDE.md +139 -0
  13. data/README.md +91 -95
  14. data/Rakefile +109 -3
  15. data/agent2agent_review.md +192 -0
  16. data/agentf_improvements.md +253 -0
  17. data/agents.md +14 -0
  18. data/docs/examples/index.md +37 -2
  19. data/docs/getting-started/configuration.md +20 -7
  20. data/docs/guides/index.md +16 -16
  21. data/docs/guides/knowledge.md +7 -1
  22. data/docs/guides/observability.md +132 -0
  23. data/docs/index.md +30 -3
  24. data/docs/superpowers/plans/2026-05-06-agentskills.md +1303 -0
  25. data/docs/superpowers/specs/2026-05-06-agentskills-design.md +247 -0
  26. data/examples/.envrc +1 -0
  27. data/examples/01_simple_robot.rb +5 -9
  28. data/examples/02_tools.rb +5 -9
  29. data/examples/03_network.rb +8 -9
  30. data/examples/04_mcp.rb +21 -29
  31. data/examples/05_streaming.rb +12 -18
  32. data/examples/06_prompt_templates.rb +11 -19
  33. data/examples/07_network_memory.rb +16 -31
  34. data/examples/08_llm_config.rb +10 -22
  35. data/examples/09_chaining.rb +16 -27
  36. data/examples/10_memory.rb +12 -28
  37. data/examples/11_network_introspection.rb +15 -29
  38. data/examples/12_message_bus.rb +5 -12
  39. data/examples/13_spawn.rb +5 -10
  40. data/examples/14_rusty_circuit/.envrc +1 -0
  41. data/examples/14_rusty_circuit/comic.rb +2 -0
  42. data/examples/14_rusty_circuit/heckler.rb +1 -1
  43. data/examples/14_rusty_circuit/open_mic.rb +1 -3
  44. data/examples/14_rusty_circuit/scout.rb +2 -0
  45. data/examples/15_memory_network_and_bus/.envrc +1 -0
  46. data/examples/15_memory_network_and_bus/editorial_pipeline.rb +6 -3
  47. data/examples/15_memory_network_and_bus/linux_writer.rb +1 -1
  48. data/examples/15_memory_network_and_bus/output/combined_article.md +6 -6
  49. data/examples/15_memory_network_and_bus/output/final_article.md +6 -8
  50. data/examples/15_memory_network_and_bus/output/linux_draft.md +4 -2
  51. data/examples/15_memory_network_and_bus/output/mac_draft.md +3 -3
  52. data/examples/15_memory_network_and_bus/output/memory.json +6 -6
  53. data/examples/15_memory_network_and_bus/output/revision_1.md +10 -11
  54. data/examples/15_memory_network_and_bus/output/revision_2.md +6 -8
  55. data/examples/15_memory_network_and_bus/output/windows_draft.md +3 -3
  56. data/examples/16_writers_room/.envrc +1 -0
  57. data/examples/16_writers_room/writers_room.rb +2 -4
  58. data/examples/17_skills.rb +8 -17
  59. data/examples/18_rails/Gemfile +1 -0
  60. data/examples/19_token_tracking.rb +9 -15
  61. data/examples/20_circuit_breaker.rb +10 -19
  62. data/examples/21_learning_loop.rb +11 -20
  63. data/examples/22_context_compression.rb +6 -13
  64. data/examples/23_convergence.rb +6 -17
  65. data/examples/24_structured_delegation.rb +11 -15
  66. data/examples/25_history_search.rb +5 -12
  67. data/examples/26_document_store.rb +6 -13
  68. data/examples/27_incident_response/incident_response.rb +4 -5
  69. data/examples/28_mcp_discovery.rb +8 -11
  70. data/examples/29_ractor_tools.rb +4 -9
  71. data/examples/30_ractor_network.rb +10 -19
  72. data/examples/31_launch_assessment.rb +10 -23
  73. data/examples/32_newsletter_reader.rb +188 -0
  74. data/examples/33_stock_generator.rb +80 -0
  75. data/examples/33_stock_predictor.rb +306 -0
  76. data/examples/34_agentskills.rb +72 -0
  77. data/examples/README.md +1 -1
  78. data/examples/common.rb +76 -0
  79. data/examples/ruboruby.md +423 -0
  80. data/examples/temp.md +51 -0
  81. data/lib/robot_lab/agent_skill.rb +63 -0
  82. data/lib/robot_lab/agent_skill_catalog.rb +74 -0
  83. data/lib/robot_lab/ask_user.rb +2 -2
  84. data/lib/robot_lab/bus_poller.rb +12 -5
  85. data/lib/robot_lab/config.rb +1 -12
  86. data/lib/robot_lab/delegation_future.rb +1 -1
  87. data/lib/robot_lab/doom_loop_detector.rb +98 -0
  88. data/lib/robot_lab/history_compressor.rb +4 -10
  89. data/lib/robot_lab/mcp/client.rb +1 -2
  90. data/lib/robot_lab/mcp/connection_poller.rb +3 -3
  91. data/lib/robot_lab/mcp/server.rb +1 -1
  92. data/lib/robot_lab/mcp/server_discovery.rb +0 -2
  93. data/lib/robot_lab/memory.rb +32 -27
  94. data/lib/robot_lab/memory_change.rb +2 -2
  95. data/lib/robot_lab/message.rb +4 -4
  96. data/lib/robot_lab/network.rb +11 -6
  97. data/lib/robot_lab/robot/agent_skill_matching.rb +99 -0
  98. data/lib/robot_lab/robot/bus_messaging.rb +9 -27
  99. data/lib/robot_lab/robot/history_search.rb +4 -1
  100. data/lib/robot_lab/robot/mcp_management.rb +5 -11
  101. data/lib/robot_lab/robot/template_rendering.rb +60 -40
  102. data/lib/robot_lab/robot.rb +323 -206
  103. data/lib/robot_lab/robot_result.rb +6 -5
  104. data/lib/robot_lab/run_config.rb +5 -11
  105. data/lib/robot_lab/script_tool.rb +76 -0
  106. data/lib/robot_lab/state_proxy.rb +7 -5
  107. data/lib/robot_lab/tool.rb +3 -3
  108. data/lib/robot_lab/tool_config.rb +1 -1
  109. data/lib/robot_lab/tool_manifest.rb +5 -7
  110. data/lib/robot_lab/user_message.rb +2 -2
  111. data/lib/robot_lab/version.rb +1 -1
  112. data/lib/robot_lab/waiter.rb +1 -1
  113. data/lib/robot_lab.rb +41 -52
  114. data/logfile +8 -0
  115. data/mkdocs.yml +2 -3
  116. data/robot_concurrency.md +38 -0
  117. data/simple_acp_review.md +298 -0
  118. data/site/404.html +2300 -0
  119. data/site/api/core/index.html +2706 -0
  120. data/site/api/core/memory/index.html +3793 -0
  121. data/site/api/core/network/index.html +3500 -0
  122. data/site/api/core/robot/index.html +4566 -0
  123. data/site/api/core/state/index.html +3390 -0
  124. data/site/api/core/tool/index.html +3843 -0
  125. data/site/api/index.html +2635 -0
  126. data/site/api/mcp/client/index.html +3435 -0
  127. data/site/api/mcp/index.html +2783 -0
  128. data/site/api/mcp/server/index.html +3252 -0
  129. data/site/api/mcp/transports/index.html +3352 -0
  130. data/site/api/messages/index.html +2641 -0
  131. data/site/api/messages/text-message/index.html +3087 -0
  132. data/site/api/messages/tool-call-message/index.html +3159 -0
  133. data/site/api/messages/tool-result-message/index.html +3252 -0
  134. data/site/api/messages/user-message/index.html +3212 -0
  135. data/site/api/streaming/context/index.html +3282 -0
  136. data/site/api/streaming/events/index.html +3347 -0
  137. data/site/api/streaming/index.html +2738 -0
  138. data/site/architecture/core-concepts/index.html +3757 -0
  139. data/site/architecture/index.html +2797 -0
  140. data/site/architecture/message-flow/index.html +3238 -0
  141. data/site/architecture/network-orchestration/index.html +3433 -0
  142. data/site/architecture/robot-execution/index.html +3140 -0
  143. data/site/architecture/state-management/index.html +3498 -0
  144. data/site/assets/css/custom.css +56 -0
  145. data/site/assets/images/favicon.png +0 -0
  146. data/site/assets/images/robot_lab.jpg +0 -0
  147. data/site/assets/javascripts/bundle.79ae519e.min.js +16 -0
  148. data/site/assets/javascripts/bundle.79ae519e.min.js.map +7 -0
  149. data/site/assets/javascripts/lunr/min/lunr.ar.min.js +1 -0
  150. data/site/assets/javascripts/lunr/min/lunr.da.min.js +18 -0
  151. data/site/assets/javascripts/lunr/min/lunr.de.min.js +18 -0
  152. data/site/assets/javascripts/lunr/min/lunr.du.min.js +18 -0
  153. data/site/assets/javascripts/lunr/min/lunr.el.min.js +1 -0
  154. data/site/assets/javascripts/lunr/min/lunr.es.min.js +18 -0
  155. data/site/assets/javascripts/lunr/min/lunr.fi.min.js +18 -0
  156. data/site/assets/javascripts/lunr/min/lunr.fr.min.js +18 -0
  157. data/site/assets/javascripts/lunr/min/lunr.he.min.js +1 -0
  158. data/site/assets/javascripts/lunr/min/lunr.hi.min.js +1 -0
  159. data/site/assets/javascripts/lunr/min/lunr.hu.min.js +18 -0
  160. data/site/assets/javascripts/lunr/min/lunr.hy.min.js +1 -0
  161. data/site/assets/javascripts/lunr/min/lunr.it.min.js +18 -0
  162. data/site/assets/javascripts/lunr/min/lunr.ja.min.js +1 -0
  163. data/site/assets/javascripts/lunr/min/lunr.jp.min.js +1 -0
  164. data/site/assets/javascripts/lunr/min/lunr.kn.min.js +1 -0
  165. data/site/assets/javascripts/lunr/min/lunr.ko.min.js +1 -0
  166. data/site/assets/javascripts/lunr/min/lunr.multi.min.js +1 -0
  167. data/site/assets/javascripts/lunr/min/lunr.nl.min.js +18 -0
  168. data/site/assets/javascripts/lunr/min/lunr.no.min.js +18 -0
  169. data/site/assets/javascripts/lunr/min/lunr.pt.min.js +18 -0
  170. data/site/assets/javascripts/lunr/min/lunr.ro.min.js +18 -0
  171. data/site/assets/javascripts/lunr/min/lunr.ru.min.js +18 -0
  172. data/site/assets/javascripts/lunr/min/lunr.sa.min.js +1 -0
  173. data/site/assets/javascripts/lunr/min/lunr.stemmer.support.min.js +1 -0
  174. data/site/assets/javascripts/lunr/min/lunr.sv.min.js +18 -0
  175. data/site/assets/javascripts/lunr/min/lunr.ta.min.js +1 -0
  176. data/site/assets/javascripts/lunr/min/lunr.te.min.js +1 -0
  177. data/site/assets/javascripts/lunr/min/lunr.th.min.js +1 -0
  178. data/site/assets/javascripts/lunr/min/lunr.tr.min.js +18 -0
  179. data/site/assets/javascripts/lunr/min/lunr.vi.min.js +1 -0
  180. data/site/assets/javascripts/lunr/min/lunr.zh.min.js +1 -0
  181. data/site/assets/javascripts/lunr/tinyseg.js +206 -0
  182. data/site/assets/javascripts/lunr/wordcut.js +6708 -0
  183. data/site/assets/javascripts/workers/search.2c215733.min.js +42 -0
  184. data/site/assets/javascripts/workers/search.2c215733.min.js.map +7 -0
  185. data/site/assets/stylesheets/main.484c7ddc.min.css +1 -0
  186. data/site/assets/stylesheets/main.484c7ddc.min.css.map +1 -0
  187. data/site/assets/stylesheets/palette.ab4e12ef.min.css +1 -0
  188. data/site/assets/stylesheets/palette.ab4e12ef.min.css.map +1 -0
  189. data/site/concepts/index.html +3455 -0
  190. data/site/examples/basic-chat/index.html +2880 -0
  191. data/site/examples/index.html +2907 -0
  192. data/site/examples/mcp-server/index.html +3018 -0
  193. data/site/examples/multi-robot-network/index.html +3131 -0
  194. data/site/examples/rails-application/index.html +3329 -0
  195. data/site/examples/tool-usage/index.html +3085 -0
  196. data/site/getting-started/configuration/index.html +3745 -0
  197. data/site/getting-started/index.html +2572 -0
  198. data/site/getting-started/installation/index.html +2981 -0
  199. data/site/getting-started/quick-start/index.html +2942 -0
  200. data/site/guides/building-robots/index.html +4290 -0
  201. data/site/guides/creating-networks/index.html +3858 -0
  202. data/site/guides/index.html +2586 -0
  203. data/site/guides/mcp-integration/index.html +3581 -0
  204. data/site/guides/memory/index.html +3586 -0
  205. data/site/guides/rails-integration/index.html +4019 -0
  206. data/site/guides/streaming/index.html +3157 -0
  207. data/site/guides/using-tools/index.html +3802 -0
  208. data/site/index.html +2671 -0
  209. data/site/search/search_index.json +1 -0
  210. data/site/sitemap.xml +183 -0
  211. data/site/sitemap.xml.gz +0 -0
  212. data/site/tags.json +1 -0
  213. data/temp.md +6 -0
  214. data/tool_manifest_plan.md +155 -0
  215. metadata +154 -92
  216. data/docs/examples/rails-application.md +0 -419
  217. data/docs/guides/ractor-parallelism.md +0 -364
  218. data/docs/guides/rails-integration.md +0 -681
  219. data/docs/superpowers/plans/2026-04-14-ractor-integration.md +0 -1538
  220. data/docs/superpowers/specs/2026-04-14-ractor-integration-design.md +0 -258
  221. data/lib/generators/robot_lab/install_generator.rb +0 -90
  222. data/lib/generators/robot_lab/job_generator.rb +0 -40
  223. data/lib/generators/robot_lab/robot_generator.rb +0 -55
  224. data/lib/generators/robot_lab/templates/initializer.rb.tt +0 -42
  225. data/lib/generators/robot_lab/templates/job.rb.tt +0 -21
  226. data/lib/generators/robot_lab/templates/migration.rb.tt +0 -32
  227. data/lib/generators/robot_lab/templates/result_model.rb.tt +0 -52
  228. data/lib/generators/robot_lab/templates/robot.rb.tt +0 -31
  229. data/lib/generators/robot_lab/templates/robot_job.rb.tt +0 -18
  230. data/lib/generators/robot_lab/templates/robot_test.rb.tt +0 -34
  231. data/lib/generators/robot_lab/templates/routing_robot.rb.tt +0 -59
  232. data/lib/generators/robot_lab/templates/thread_model.rb.tt +0 -40
  233. data/lib/robot_lab/document_store.rb +0 -155
  234. data/lib/robot_lab/ractor_boundary.rb +0 -42
  235. data/lib/robot_lab/ractor_job.rb +0 -37
  236. data/lib/robot_lab/ractor_memory_proxy.rb +0 -85
  237. data/lib/robot_lab/ractor_network_scheduler.rb +0 -154
  238. data/lib/robot_lab/ractor_worker_pool.rb +0 -117
  239. data/lib/robot_lab/rails_integration/engine.rb +0 -29
  240. data/lib/robot_lab/rails_integration/job.rb +0 -158
  241. data/lib/robot_lab/rails_integration/railtie.rb +0 -51
  242. data/lib/robot_lab/rails_integration/turbo_stream_callbacks.rb +0 -72
@@ -0,0 +1,3140 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en" class="no-js">
4
+ <head>
5
+
6
+ <meta charset="utf-8">
7
+ <meta name="viewport" content="width=device-width,initial-scale=1">
8
+
9
+ <meta name="description" content="Multi-robot LLM workflow orchestration for Ruby">
10
+
11
+
12
+ <meta name="author" content="Dewayne VanHoozer">
13
+
14
+
15
+ <link rel="canonical" href="https://madbomber.github.io/robot_lab/architecture/robot-execution/">
16
+
17
+
18
+ <link rel="prev" href="../core-concepts/">
19
+
20
+
21
+ <link rel="next" href="../network-orchestration/">
22
+
23
+
24
+
25
+
26
+
27
+ <link rel="icon" href="../../assets/images/favicon.png">
28
+ <meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.7.1">
29
+
30
+
31
+
32
+ <title>Robot Execution - RobotLab</title>
33
+
34
+
35
+
36
+ <link rel="stylesheet" href="../../assets/stylesheets/main.484c7ddc.min.css">
37
+
38
+
39
+ <link rel="stylesheet" href="../../assets/stylesheets/palette.ab4e12ef.min.css">
40
+
41
+
42
+
43
+
44
+
45
+
46
+
47
+
48
+
49
+
50
+
51
+
52
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
53
+ <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
54
+ <style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
55
+
56
+
57
+
58
+ <link rel="stylesheet" href="../../assets/css/custom.css">
59
+
60
+ <script>__md_scope=new URL("../..",location),__md_hash=e=>[...e].reduce(((e,_)=>(e<<5)-e+_.charCodeAt(0)),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
61
+
62
+
63
+
64
+
65
+
66
+
67
+
68
+ </head>
69
+
70
+
71
+
72
+
73
+
74
+
75
+
76
+
77
+
78
+ <body dir="ltr" data-md-color-scheme="default" data-md-color-primary="deep-purple" data-md-color-accent="amber">
79
+
80
+
81
+ <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
82
+ <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
83
+ <label class="md-overlay" for="__drawer"></label>
84
+ <div data-md-component="skip">
85
+
86
+
87
+ <a href="#robot-execution" class="md-skip">
88
+ Skip to content
89
+ </a>
90
+
91
+ </div>
92
+ <div data-md-component="announce">
93
+
94
+ </div>
95
+
96
+
97
+
98
+
99
+
100
+
101
+ <header class="md-header md-header--shadow md-header--lifted" data-md-component="header">
102
+ <nav class="md-header__inner md-grid" aria-label="Header">
103
+ <a href="../.." title="RobotLab" class="md-header__button md-logo" aria-label="RobotLab" data-md-component="logo">
104
+
105
+
106
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 2a2 2 0 0 1 2 2c0 .74-.4 1.39-1 1.73V7h1a7 7 0 0 1 7 7h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h1a7 7 0 0 1 7-7h1V5.73c-.6-.34-1-.99-1-1.73a2 2 0 0 1 2-2M7.5 13A2.5 2.5 0 0 0 5 15.5 2.5 2.5 0 0 0 7.5 18a2.5 2.5 0 0 0 2.5-2.5A2.5 2.5 0 0 0 7.5 13m9 0a2.5 2.5 0 0 0-2.5 2.5 2.5 2.5 0 0 0 2.5 2.5 2.5 2.5 0 0 0 2.5-2.5 2.5 2.5 0 0 0-2.5-2.5"/></svg>
107
+
108
+ </a>
109
+ <label class="md-header__button md-icon" for="__drawer">
110
+
111
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z"/></svg>
112
+ </label>
113
+ <div class="md-header__title" data-md-component="header-title">
114
+ <div class="md-header__ellipsis">
115
+ <div class="md-header__topic">
116
+ <span class="md-ellipsis">
117
+ RobotLab
118
+ </span>
119
+ </div>
120
+ <div class="md-header__topic" data-md-component="header-topic">
121
+ <span class="md-ellipsis">
122
+
123
+ Robot Execution
124
+
125
+ </span>
126
+ </div>
127
+ </div>
128
+ </div>
129
+
130
+
131
+ <form class="md-header__option" data-md-component="palette">
132
+
133
+
134
+
135
+
136
+ <input class="md-option" data-md-color-media="" data-md-color-scheme="default" data-md-color-primary="deep-purple" data-md-color-accent="amber" aria-label="Switch to dark mode" type="radio" name="__palette" id="__palette_0">
137
+
138
+ <label class="md-header__button md-icon" title="Switch to dark mode" for="__palette_1" hidden>
139
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a4 4 0 0 0-4 4 4 4 0 0 0 4 4 4 4 0 0 0 4-4 4 4 0 0 0-4-4m0 10a6 6 0 0 1-6-6 6 6 0 0 1 6-6 6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
140
+ </label>
141
+
142
+
143
+
144
+
145
+
146
+ <input class="md-option" data-md-color-media="" data-md-color-scheme="slate" data-md-color-primary="deep-purple" data-md-color-accent="amber" aria-label="Switch to light mode" type="radio" name="__palette" id="__palette_1">
147
+
148
+ <label class="md-header__button md-icon" title="Switch to light mode" for="__palette_0" hidden>
149
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 18c-.89 0-1.74-.2-2.5-.55C11.56 16.5 13 14.42 13 12s-1.44-4.5-3.5-5.45C10.26 6.2 11.11 6 12 6a6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
150
+ </label>
151
+
152
+
153
+ </form>
154
+
155
+
156
+
157
+ <script>var palette=__md_get("__palette");if(palette&&palette.color){if("(prefers-color-scheme)"===palette.color.media){var media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent")}for(var[key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
158
+
159
+
160
+
161
+
162
+
163
+ <label class="md-header__button md-icon" for="__search">
164
+
165
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
166
+ </label>
167
+ <div class="md-search" data-md-component="search" role="dialog">
168
+ <label class="md-search__overlay" for="__search"></label>
169
+ <div class="md-search__inner" role="search">
170
+ <form class="md-search__form" name="search">
171
+ <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
172
+ <label class="md-search__icon md-icon" for="__search">
173
+
174
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
175
+
176
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
177
+ </label>
178
+ <nav class="md-search__options" aria-label="Search">
179
+
180
+ <a href="javascript:void(0)" class="md-search__icon md-icon" title="Share" aria-label="Share" data-clipboard data-clipboard-text="" data-md-component="search-share" tabindex="-1">
181
+
182
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M18 16.08c-.76 0-1.44.3-1.96.77L8.91 12.7c.05-.23.09-.46.09-.7s-.04-.47-.09-.7l7.05-4.11c.54.5 1.25.81 2.04.81a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3c0 .24.04.47.09.7L8.04 9.81C7.5 9.31 6.79 9 6 9a3 3 0 0 0-3 3 3 3 0 0 0 3 3c.79 0 1.5-.31 2.04-.81l7.12 4.15c-.05.21-.08.43-.08.66 0 1.61 1.31 2.91 2.92 2.91s2.92-1.3 2.92-2.91A2.92 2.92 0 0 0 18 16.08"/></svg>
183
+ </a>
184
+
185
+ <button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
186
+
187
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>
188
+ </button>
189
+ </nav>
190
+
191
+ <div class="md-search__suggest" data-md-component="search-suggest"></div>
192
+
193
+ </form>
194
+ <div class="md-search__output">
195
+ <div class="md-search__scrollwrap" tabindex="0" data-md-scrollfix>
196
+ <div class="md-search-result" data-md-component="search-result">
197
+ <div class="md-search-result__meta">
198
+ Initializing search
199
+ </div>
200
+ <ol class="md-search-result__list" role="presentation"></ol>
201
+ </div>
202
+ </div>
203
+ </div>
204
+ </div>
205
+ </div>
206
+
207
+
208
+
209
+ <div class="md-header__source">
210
+ <a href="https://github.com/madbomber/robot_lab" title="Go to repository" class="md-source" data-md-component="source">
211
+ <div class="md-source__icon md-icon">
212
+
213
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
214
+ </div>
215
+ <div class="md-source__repository">
216
+ madbomber/robot_lab
217
+ </div>
218
+ </a>
219
+ </div>
220
+
221
+ </nav>
222
+
223
+
224
+
225
+ <nav class="md-tabs" aria-label="Tabs" data-md-component="tabs">
226
+ <div class="md-grid">
227
+ <ul class="md-tabs__list">
228
+
229
+
230
+
231
+
232
+
233
+
234
+
235
+
236
+ <li class="md-tabs__item">
237
+ <a href="../.." class="md-tabs__link">
238
+
239
+
240
+
241
+
242
+
243
+ Home
244
+
245
+ </a>
246
+ </li>
247
+
248
+
249
+
250
+
251
+
252
+
253
+
254
+
255
+
256
+
257
+
258
+ <li class="md-tabs__item">
259
+ <a href="../../getting-started/" class="md-tabs__link">
260
+
261
+
262
+
263
+
264
+
265
+ Getting Started
266
+
267
+ </a>
268
+ </li>
269
+
270
+
271
+
272
+
273
+
274
+
275
+
276
+
277
+
278
+
279
+
280
+
281
+
282
+ <li class="md-tabs__item md-tabs__item--active">
283
+ <a href="../" class="md-tabs__link">
284
+
285
+
286
+
287
+
288
+
289
+ Architecture
290
+
291
+ </a>
292
+ </li>
293
+
294
+
295
+
296
+
297
+
298
+
299
+
300
+
301
+
302
+
303
+
304
+ <li class="md-tabs__item">
305
+ <a href="../../guides/" class="md-tabs__link">
306
+
307
+
308
+
309
+
310
+
311
+ Guides
312
+
313
+ </a>
314
+ </li>
315
+
316
+
317
+
318
+
319
+
320
+
321
+
322
+
323
+
324
+
325
+
326
+ <li class="md-tabs__item">
327
+ <a href="../../api/" class="md-tabs__link">
328
+
329
+
330
+
331
+
332
+
333
+ API Reference
334
+
335
+ </a>
336
+ </li>
337
+
338
+
339
+
340
+
341
+
342
+
343
+
344
+
345
+
346
+
347
+
348
+ <li class="md-tabs__item">
349
+ <a href="../../examples/" class="md-tabs__link">
350
+
351
+
352
+
353
+
354
+
355
+ Examples
356
+
357
+ </a>
358
+ </li>
359
+
360
+
361
+
362
+
363
+ </ul>
364
+ </div>
365
+ </nav>
366
+
367
+
368
+ </header>
369
+
370
+ <div class="md-container" data-md-component="container">
371
+
372
+
373
+
374
+
375
+ <main class="md-main" data-md-component="main">
376
+ <div class="md-main__inner md-grid">
377
+
378
+
379
+
380
+ <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
381
+ <div class="md-sidebar__scrollwrap">
382
+ <div class="md-sidebar__inner">
383
+
384
+
385
+
386
+
387
+
388
+
389
+ <nav class="md-nav md-nav--primary md-nav--lifted" aria-label="Navigation" data-md-level="0">
390
+ <label class="md-nav__title" for="__drawer">
391
+ <a href="../.." title="RobotLab" class="md-nav__button md-logo" aria-label="RobotLab" data-md-component="logo">
392
+
393
+
394
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 2a2 2 0 0 1 2 2c0 .74-.4 1.39-1 1.73V7h1a7 7 0 0 1 7 7h1a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1h-1v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a1 1 0 0 1-1-1v-3a1 1 0 0 1 1-1h1a7 7 0 0 1 7-7h1V5.73c-.6-.34-1-.99-1-1.73a2 2 0 0 1 2-2M7.5 13A2.5 2.5 0 0 0 5 15.5 2.5 2.5 0 0 0 7.5 18a2.5 2.5 0 0 0 2.5-2.5A2.5 2.5 0 0 0 7.5 13m9 0a2.5 2.5 0 0 0-2.5 2.5 2.5 2.5 0 0 0 2.5 2.5 2.5 2.5 0 0 0 2.5-2.5 2.5 2.5 0 0 0-2.5-2.5"/></svg>
395
+
396
+ </a>
397
+ RobotLab
398
+ </label>
399
+
400
+ <div class="md-nav__source">
401
+ <a href="https://github.com/madbomber/robot_lab" title="Go to repository" class="md-source" data-md-component="source">
402
+ <div class="md-source__icon md-icon">
403
+
404
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
405
+ </div>
406
+ <div class="md-source__repository">
407
+ madbomber/robot_lab
408
+ </div>
409
+ </a>
410
+ </div>
411
+
412
+ <ul class="md-nav__list" data-md-scrollfix>
413
+
414
+
415
+
416
+
417
+
418
+
419
+
420
+
421
+
422
+
423
+
424
+
425
+
426
+
427
+
428
+
429
+
430
+
431
+
432
+
433
+
434
+
435
+
436
+ <li class="md-nav__item md-nav__item--nested">
437
+
438
+
439
+
440
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_1" >
441
+
442
+
443
+ <div class="md-nav__link md-nav__container">
444
+ <a href="../.." class="md-nav__link ">
445
+
446
+
447
+
448
+ <span class="md-ellipsis">
449
+
450
+
451
+ Home
452
+
453
+
454
+
455
+ </span>
456
+
457
+
458
+
459
+ </a>
460
+
461
+
462
+ <label class="md-nav__link " for="__nav_1" id="__nav_1_label" tabindex="0">
463
+ <span class="md-nav__icon md-icon"></span>
464
+ </label>
465
+
466
+ </div>
467
+
468
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_1_label" aria-expanded="false">
469
+ <label class="md-nav__title" for="__nav_1">
470
+ <span class="md-nav__icon md-icon"></span>
471
+
472
+
473
+ Home
474
+
475
+
476
+ </label>
477
+ <ul class="md-nav__list" data-md-scrollfix>
478
+
479
+
480
+
481
+
482
+
483
+
484
+
485
+
486
+
487
+ <li class="md-nav__item">
488
+ <a href="../../concepts/" class="md-nav__link">
489
+
490
+
491
+
492
+ <span class="md-ellipsis">
493
+
494
+
495
+ Concepts
496
+
497
+
498
+
499
+ </span>
500
+
501
+
502
+
503
+ </a>
504
+ </li>
505
+
506
+
507
+
508
+
509
+ </ul>
510
+ </nav>
511
+
512
+ </li>
513
+
514
+
515
+
516
+
517
+
518
+
519
+
520
+
521
+
522
+
523
+
524
+
525
+
526
+
527
+
528
+
529
+
530
+
531
+
532
+
533
+
534
+
535
+
536
+
537
+
538
+
539
+
540
+
541
+
542
+ <li class="md-nav__item md-nav__item--nested">
543
+
544
+
545
+
546
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_2" >
547
+
548
+
549
+ <div class="md-nav__link md-nav__container">
550
+ <a href="../../getting-started/" class="md-nav__link ">
551
+
552
+
553
+
554
+ <span class="md-ellipsis">
555
+
556
+
557
+ Getting Started
558
+
559
+
560
+
561
+ </span>
562
+
563
+
564
+
565
+ </a>
566
+
567
+
568
+ <label class="md-nav__link " for="__nav_2" id="__nav_2_label" tabindex="0">
569
+ <span class="md-nav__icon md-icon"></span>
570
+ </label>
571
+
572
+ </div>
573
+
574
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_2_label" aria-expanded="false">
575
+ <label class="md-nav__title" for="__nav_2">
576
+ <span class="md-nav__icon md-icon"></span>
577
+
578
+
579
+ Getting Started
580
+
581
+
582
+ </label>
583
+ <ul class="md-nav__list" data-md-scrollfix>
584
+
585
+
586
+
587
+
588
+
589
+
590
+
591
+
592
+
593
+ <li class="md-nav__item">
594
+ <a href="../../getting-started/installation/" class="md-nav__link">
595
+
596
+
597
+
598
+ <span class="md-ellipsis">
599
+
600
+
601
+ Installation
602
+
603
+
604
+
605
+ </span>
606
+
607
+
608
+
609
+ </a>
610
+ </li>
611
+
612
+
613
+
614
+
615
+
616
+
617
+
618
+
619
+
620
+
621
+ <li class="md-nav__item">
622
+ <a href="../../getting-started/quick-start/" class="md-nav__link">
623
+
624
+
625
+
626
+ <span class="md-ellipsis">
627
+
628
+
629
+ Quick Start
630
+
631
+
632
+
633
+ </span>
634
+
635
+
636
+
637
+ </a>
638
+ </li>
639
+
640
+
641
+
642
+
643
+
644
+
645
+
646
+
647
+
648
+
649
+ <li class="md-nav__item">
650
+ <a href="../../getting-started/configuration/" class="md-nav__link">
651
+
652
+
653
+
654
+ <span class="md-ellipsis">
655
+
656
+
657
+ Configuration
658
+
659
+
660
+
661
+ </span>
662
+
663
+
664
+
665
+ </a>
666
+ </li>
667
+
668
+
669
+
670
+
671
+ </ul>
672
+ </nav>
673
+
674
+ </li>
675
+
676
+
677
+
678
+
679
+
680
+
681
+
682
+
683
+
684
+
685
+
686
+
687
+
688
+
689
+
690
+
691
+
692
+
693
+
694
+
695
+
696
+
697
+
698
+
699
+
700
+
701
+
702
+
703
+
704
+
705
+
706
+
707
+
708
+
709
+
710
+
711
+
712
+
713
+ <li class="md-nav__item md-nav__item--active md-nav__item--section md-nav__item--nested">
714
+
715
+
716
+
717
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3" checked>
718
+
719
+
720
+ <div class="md-nav__link md-nav__container">
721
+ <a href="../" class="md-nav__link ">
722
+
723
+
724
+
725
+ <span class="md-ellipsis">
726
+
727
+
728
+ Architecture
729
+
730
+
731
+
732
+ </span>
733
+
734
+
735
+
736
+ </a>
737
+
738
+
739
+ <label class="md-nav__link " for="__nav_3" id="__nav_3_label" tabindex="">
740
+ <span class="md-nav__icon md-icon"></span>
741
+ </label>
742
+
743
+ </div>
744
+
745
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_3_label" aria-expanded="true">
746
+ <label class="md-nav__title" for="__nav_3">
747
+ <span class="md-nav__icon md-icon"></span>
748
+
749
+
750
+ Architecture
751
+
752
+
753
+ </label>
754
+ <ul class="md-nav__list" data-md-scrollfix>
755
+
756
+
757
+
758
+
759
+
760
+
761
+
762
+
763
+
764
+ <li class="md-nav__item">
765
+ <a href="../core-concepts/" class="md-nav__link">
766
+
767
+
768
+
769
+ <span class="md-ellipsis">
770
+
771
+
772
+ Core Concepts
773
+
774
+
775
+
776
+ </span>
777
+
778
+
779
+
780
+ </a>
781
+ </li>
782
+
783
+
784
+
785
+
786
+
787
+
788
+
789
+
790
+
791
+
792
+
793
+
794
+ <li class="md-nav__item md-nav__item--active">
795
+
796
+ <input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
797
+
798
+
799
+
800
+
801
+
802
+ <label class="md-nav__link md-nav__link--active" for="__toc">
803
+
804
+
805
+
806
+ <span class="md-ellipsis">
807
+
808
+
809
+ Robot Execution
810
+
811
+
812
+
813
+ </span>
814
+
815
+
816
+
817
+ <span class="md-nav__icon md-icon"></span>
818
+ </label>
819
+
820
+ <a href="./" class="md-nav__link md-nav__link--active">
821
+
822
+
823
+
824
+ <span class="md-ellipsis">
825
+
826
+
827
+ Robot Execution
828
+
829
+
830
+
831
+ </span>
832
+
833
+
834
+
835
+ </a>
836
+
837
+
838
+
839
+
840
+
841
+ <nav class="md-nav md-nav--secondary" aria-label="On this page">
842
+
843
+
844
+
845
+
846
+
847
+
848
+ <label class="md-nav__title" for="__toc">
849
+ <span class="md-nav__icon md-icon"></span>
850
+ On this page
851
+ </label>
852
+ <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
853
+
854
+ <li class="md-nav__item">
855
+ <a href="#execution-overview" class="md-nav__link">
856
+ <span class="md-ellipsis">
857
+
858
+ Execution Overview
859
+
860
+ </span>
861
+ </a>
862
+
863
+ </li>
864
+
865
+ <li class="md-nav__item">
866
+ <a href="#step-by-step-flow" class="md-nav__link">
867
+ <span class="md-ellipsis">
868
+
869
+ Step-by-Step Flow
870
+
871
+ </span>
872
+ </a>
873
+
874
+ <nav class="md-nav" aria-label="Step-by-Step Flow">
875
+ <ul class="md-nav__list">
876
+
877
+ <li class="md-nav__item">
878
+ <a href="#1-memory-resolution" class="md-nav__link">
879
+ <span class="md-ellipsis">
880
+
881
+ 1. Memory Resolution
882
+
883
+ </span>
884
+ </a>
885
+
886
+ </li>
887
+
888
+ <li class="md-nav__item">
889
+ <a href="#2-mcp-hierarchy-resolution" class="md-nav__link">
890
+ <span class="md-ellipsis">
891
+
892
+ 2. MCP Hierarchy Resolution
893
+
894
+ </span>
895
+ </a>
896
+
897
+ </li>
898
+
899
+ <li class="md-nav__item">
900
+ <a href="#3-mcp-client-initialization" class="md-nav__link">
901
+ <span class="md-ellipsis">
902
+
903
+ 3. MCP Client Initialization
904
+
905
+ </span>
906
+ </a>
907
+
908
+ </li>
909
+
910
+ <li class="md-nav__item">
911
+ <a href="#4-tools-resolution" class="md-nav__link">
912
+ <span class="md-ellipsis">
913
+
914
+ 4. Tools Resolution
915
+
916
+ </span>
917
+ </a>
918
+
919
+ </li>
920
+
921
+ <li class="md-nav__item">
922
+ <a href="#5-llm-inference" class="md-nav__link">
923
+ <span class="md-ellipsis">
924
+
925
+ 5. LLM Inference
926
+
927
+ </span>
928
+ </a>
929
+
930
+ </li>
931
+
932
+ <li class="md-nav__item">
933
+ <a href="#6-tool-execution-loop" class="md-nav__link">
934
+ <span class="md-ellipsis">
935
+
936
+ 6. Tool Execution Loop
937
+
938
+ </span>
939
+ </a>
940
+
941
+ </li>
942
+
943
+ <li class="md-nav__item">
944
+ <a href="#7-result-construction" class="md-nav__link">
945
+ <span class="md-ellipsis">
946
+
947
+ 7. Result Construction
948
+
949
+ </span>
950
+ </a>
951
+
952
+ </li>
953
+
954
+ </ul>
955
+ </nav>
956
+
957
+ </li>
958
+
959
+ <li class="md-nav__item">
960
+ <a href="#robotresult" class="md-nav__link">
961
+ <span class="md-ellipsis">
962
+
963
+ RobotResult
964
+
965
+ </span>
966
+ </a>
967
+
968
+ </li>
969
+
970
+ <li class="md-nav__item">
971
+ <a href="#streaming" class="md-nav__link">
972
+ <span class="md-ellipsis">
973
+
974
+ Streaming
975
+
976
+ </span>
977
+ </a>
978
+
979
+ </li>
980
+
981
+ <li class="md-nav__item">
982
+ <a href="#template-resolution" class="md-nav__link">
983
+ <span class="md-ellipsis">
984
+
985
+ Template Resolution
986
+
987
+ </span>
988
+ </a>
989
+
990
+ <nav class="md-nav" aria-label="Template Resolution">
991
+ <ul class="md-nav__list">
992
+
993
+ <li class="md-nav__item">
994
+ <a href="#front-matter-config-keys" class="md-nav__link">
995
+ <span class="md-ellipsis">
996
+
997
+ Front Matter Config Keys
998
+
999
+ </span>
1000
+ </a>
1001
+
1002
+ </li>
1003
+
1004
+ </ul>
1005
+ </nav>
1006
+
1007
+ </li>
1008
+
1009
+ <li class="md-nav__item">
1010
+ <a href="#model-selection" class="md-nav__link">
1011
+ <span class="md-ellipsis">
1012
+
1013
+ Model Selection
1014
+
1015
+ </span>
1016
+ </a>
1017
+
1018
+ </li>
1019
+
1020
+ <li class="md-nav__item">
1021
+ <a href="#simpleflow-integration" class="md-nav__link">
1022
+ <span class="md-ellipsis">
1023
+
1024
+ SimpleFlow Integration
1025
+
1026
+ </span>
1027
+ </a>
1028
+
1029
+ </li>
1030
+
1031
+ <li class="md-nav__item">
1032
+ <a href="#next-steps" class="md-nav__link">
1033
+ <span class="md-ellipsis">
1034
+
1035
+ Next Steps
1036
+
1037
+ </span>
1038
+ </a>
1039
+
1040
+ </li>
1041
+
1042
+ </ul>
1043
+
1044
+ </nav>
1045
+
1046
+ </li>
1047
+
1048
+
1049
+
1050
+
1051
+
1052
+
1053
+
1054
+
1055
+
1056
+
1057
+ <li class="md-nav__item">
1058
+ <a href="../network-orchestration/" class="md-nav__link">
1059
+
1060
+
1061
+
1062
+ <span class="md-ellipsis">
1063
+
1064
+
1065
+ Network Orchestration
1066
+
1067
+
1068
+
1069
+ </span>
1070
+
1071
+
1072
+
1073
+ </a>
1074
+ </li>
1075
+
1076
+
1077
+
1078
+
1079
+
1080
+
1081
+
1082
+
1083
+
1084
+
1085
+ <li class="md-nav__item">
1086
+ <a href="../state-management/" class="md-nav__link">
1087
+
1088
+
1089
+
1090
+ <span class="md-ellipsis">
1091
+
1092
+
1093
+ State Management
1094
+
1095
+
1096
+
1097
+ </span>
1098
+
1099
+
1100
+
1101
+ </a>
1102
+ </li>
1103
+
1104
+
1105
+
1106
+
1107
+
1108
+
1109
+
1110
+
1111
+
1112
+
1113
+ <li class="md-nav__item">
1114
+ <a href="../message-flow/" class="md-nav__link">
1115
+
1116
+
1117
+
1118
+ <span class="md-ellipsis">
1119
+
1120
+
1121
+ Message Flow
1122
+
1123
+
1124
+
1125
+ </span>
1126
+
1127
+
1128
+
1129
+ </a>
1130
+ </li>
1131
+
1132
+
1133
+
1134
+
1135
+ </ul>
1136
+ </nav>
1137
+
1138
+ </li>
1139
+
1140
+
1141
+
1142
+
1143
+
1144
+
1145
+
1146
+
1147
+
1148
+
1149
+
1150
+
1151
+
1152
+
1153
+
1154
+
1155
+
1156
+
1157
+
1158
+
1159
+
1160
+
1161
+
1162
+
1163
+
1164
+
1165
+
1166
+
1167
+
1168
+
1169
+
1170
+
1171
+
1172
+
1173
+
1174
+
1175
+
1176
+ <li class="md-nav__item md-nav__item--nested">
1177
+
1178
+
1179
+
1180
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_4" >
1181
+
1182
+
1183
+ <div class="md-nav__link md-nav__container">
1184
+ <a href="../../guides/" class="md-nav__link ">
1185
+
1186
+
1187
+
1188
+ <span class="md-ellipsis">
1189
+
1190
+
1191
+ Guides
1192
+
1193
+
1194
+
1195
+ </span>
1196
+
1197
+
1198
+
1199
+ </a>
1200
+
1201
+
1202
+ <label class="md-nav__link " for="__nav_4" id="__nav_4_label" tabindex="0">
1203
+ <span class="md-nav__icon md-icon"></span>
1204
+ </label>
1205
+
1206
+ </div>
1207
+
1208
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="false">
1209
+ <label class="md-nav__title" for="__nav_4">
1210
+ <span class="md-nav__icon md-icon"></span>
1211
+
1212
+
1213
+ Guides
1214
+
1215
+
1216
+ </label>
1217
+ <ul class="md-nav__list" data-md-scrollfix>
1218
+
1219
+
1220
+
1221
+
1222
+
1223
+
1224
+
1225
+
1226
+
1227
+ <li class="md-nav__item">
1228
+ <a href="../../guides/building-robots/" class="md-nav__link">
1229
+
1230
+
1231
+
1232
+ <span class="md-ellipsis">
1233
+
1234
+
1235
+ Building Robots
1236
+
1237
+
1238
+
1239
+ </span>
1240
+
1241
+
1242
+
1243
+ </a>
1244
+ </li>
1245
+
1246
+
1247
+
1248
+
1249
+
1250
+
1251
+
1252
+
1253
+
1254
+
1255
+ <li class="md-nav__item">
1256
+ <a href="../../guides/creating-networks/" class="md-nav__link">
1257
+
1258
+
1259
+
1260
+ <span class="md-ellipsis">
1261
+
1262
+
1263
+ Creating Networks
1264
+
1265
+
1266
+
1267
+ </span>
1268
+
1269
+
1270
+
1271
+ </a>
1272
+ </li>
1273
+
1274
+
1275
+
1276
+
1277
+
1278
+
1279
+
1280
+
1281
+
1282
+
1283
+ <li class="md-nav__item">
1284
+ <a href="../../guides/using-tools/" class="md-nav__link">
1285
+
1286
+
1287
+
1288
+ <span class="md-ellipsis">
1289
+
1290
+
1291
+ Using Tools
1292
+
1293
+
1294
+
1295
+ </span>
1296
+
1297
+
1298
+
1299
+ </a>
1300
+ </li>
1301
+
1302
+
1303
+
1304
+
1305
+
1306
+
1307
+
1308
+
1309
+
1310
+
1311
+ <li class="md-nav__item">
1312
+ <a href="../../guides/mcp-integration/" class="md-nav__link">
1313
+
1314
+
1315
+
1316
+ <span class="md-ellipsis">
1317
+
1318
+
1319
+ MCP Integration
1320
+
1321
+
1322
+
1323
+ </span>
1324
+
1325
+
1326
+
1327
+ </a>
1328
+ </li>
1329
+
1330
+
1331
+
1332
+
1333
+
1334
+
1335
+
1336
+
1337
+
1338
+
1339
+ <li class="md-nav__item">
1340
+ <a href="../../guides/streaming/" class="md-nav__link">
1341
+
1342
+
1343
+
1344
+ <span class="md-ellipsis">
1345
+
1346
+
1347
+ Streaming Responses
1348
+
1349
+
1350
+
1351
+ </span>
1352
+
1353
+
1354
+
1355
+ </a>
1356
+ </li>
1357
+
1358
+
1359
+
1360
+
1361
+
1362
+
1363
+
1364
+
1365
+
1366
+
1367
+ <li class="md-nav__item">
1368
+ <a href="../../guides/memory/" class="md-nav__link">
1369
+
1370
+
1371
+
1372
+ <span class="md-ellipsis">
1373
+
1374
+
1375
+ Memory System
1376
+
1377
+
1378
+
1379
+ </span>
1380
+
1381
+
1382
+
1383
+ </a>
1384
+ </li>
1385
+
1386
+
1387
+
1388
+
1389
+
1390
+
1391
+
1392
+
1393
+
1394
+
1395
+ <li class="md-nav__item">
1396
+ <a href="../../guides/rails-integration/" class="md-nav__link">
1397
+
1398
+
1399
+
1400
+ <span class="md-ellipsis">
1401
+
1402
+
1403
+ Rails Integration
1404
+
1405
+
1406
+
1407
+ </span>
1408
+
1409
+
1410
+
1411
+ </a>
1412
+ </li>
1413
+
1414
+
1415
+
1416
+
1417
+ </ul>
1418
+ </nav>
1419
+
1420
+ </li>
1421
+
1422
+
1423
+
1424
+
1425
+
1426
+
1427
+
1428
+
1429
+
1430
+
1431
+
1432
+
1433
+
1434
+
1435
+
1436
+
1437
+
1438
+
1439
+
1440
+
1441
+
1442
+
1443
+
1444
+
1445
+
1446
+
1447
+
1448
+
1449
+
1450
+
1451
+
1452
+ <li class="md-nav__item md-nav__item--nested">
1453
+
1454
+
1455
+
1456
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5" >
1457
+
1458
+
1459
+ <div class="md-nav__link md-nav__container">
1460
+ <a href="../../api/" class="md-nav__link ">
1461
+
1462
+
1463
+
1464
+ <span class="md-ellipsis">
1465
+
1466
+
1467
+ API Reference
1468
+
1469
+
1470
+
1471
+ </span>
1472
+
1473
+
1474
+
1475
+ </a>
1476
+
1477
+
1478
+ <label class="md-nav__link " for="__nav_5" id="__nav_5_label" tabindex="0">
1479
+ <span class="md-nav__icon md-icon"></span>
1480
+ </label>
1481
+
1482
+ </div>
1483
+
1484
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_5_label" aria-expanded="false">
1485
+ <label class="md-nav__title" for="__nav_5">
1486
+ <span class="md-nav__icon md-icon"></span>
1487
+
1488
+
1489
+ API Reference
1490
+
1491
+
1492
+ </label>
1493
+ <ul class="md-nav__list" data-md-scrollfix>
1494
+
1495
+
1496
+
1497
+
1498
+
1499
+
1500
+
1501
+
1502
+
1503
+
1504
+
1505
+
1506
+
1507
+
1508
+
1509
+
1510
+
1511
+
1512
+
1513
+
1514
+
1515
+
1516
+
1517
+
1518
+
1519
+
1520
+
1521
+
1522
+
1523
+
1524
+
1525
+
1526
+
1527
+ <li class="md-nav__item md-nav__item--nested">
1528
+
1529
+
1530
+
1531
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5_2" >
1532
+
1533
+
1534
+ <div class="md-nav__link md-nav__container">
1535
+ <a href="../../api/core/" class="md-nav__link ">
1536
+
1537
+
1538
+
1539
+ <span class="md-ellipsis">
1540
+
1541
+
1542
+ Core Classes
1543
+
1544
+
1545
+
1546
+ </span>
1547
+
1548
+
1549
+
1550
+ </a>
1551
+
1552
+
1553
+ <label class="md-nav__link " for="__nav_5_2" id="__nav_5_2_label" tabindex="0">
1554
+ <span class="md-nav__icon md-icon"></span>
1555
+ </label>
1556
+
1557
+ </div>
1558
+
1559
+ <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_5_2_label" aria-expanded="false">
1560
+ <label class="md-nav__title" for="__nav_5_2">
1561
+ <span class="md-nav__icon md-icon"></span>
1562
+
1563
+
1564
+ Core Classes
1565
+
1566
+
1567
+ </label>
1568
+ <ul class="md-nav__list" data-md-scrollfix>
1569
+
1570
+
1571
+
1572
+
1573
+
1574
+
1575
+
1576
+
1577
+
1578
+ <li class="md-nav__item">
1579
+ <a href="../../api/core/robot/" class="md-nav__link">
1580
+
1581
+
1582
+
1583
+ <span class="md-ellipsis">
1584
+
1585
+
1586
+ Robot
1587
+
1588
+
1589
+
1590
+ </span>
1591
+
1592
+
1593
+
1594
+ </a>
1595
+ </li>
1596
+
1597
+
1598
+
1599
+
1600
+
1601
+
1602
+
1603
+
1604
+
1605
+
1606
+ <li class="md-nav__item">
1607
+ <a href="../../api/core/network/" class="md-nav__link">
1608
+
1609
+
1610
+
1611
+ <span class="md-ellipsis">
1612
+
1613
+
1614
+ Network
1615
+
1616
+
1617
+
1618
+ </span>
1619
+
1620
+
1621
+
1622
+ </a>
1623
+ </li>
1624
+
1625
+
1626
+
1627
+
1628
+
1629
+
1630
+
1631
+
1632
+
1633
+
1634
+ <li class="md-nav__item">
1635
+ <a href="../../api/core/state/" class="md-nav__link">
1636
+
1637
+
1638
+
1639
+ <span class="md-ellipsis">
1640
+
1641
+
1642
+ State
1643
+
1644
+
1645
+
1646
+ </span>
1647
+
1648
+
1649
+
1650
+ </a>
1651
+ </li>
1652
+
1653
+
1654
+
1655
+
1656
+
1657
+
1658
+
1659
+
1660
+
1661
+
1662
+ <li class="md-nav__item">
1663
+ <a href="../../api/core/tool/" class="md-nav__link">
1664
+
1665
+
1666
+
1667
+ <span class="md-ellipsis">
1668
+
1669
+
1670
+ Tool
1671
+
1672
+
1673
+
1674
+ </span>
1675
+
1676
+
1677
+
1678
+ </a>
1679
+ </li>
1680
+
1681
+
1682
+
1683
+
1684
+
1685
+
1686
+
1687
+
1688
+
1689
+
1690
+ <li class="md-nav__item">
1691
+ <a href="../../api/core/memory/" class="md-nav__link">
1692
+
1693
+
1694
+
1695
+ <span class="md-ellipsis">
1696
+
1697
+
1698
+ Memory
1699
+
1700
+
1701
+
1702
+ </span>
1703
+
1704
+
1705
+
1706
+ </a>
1707
+ </li>
1708
+
1709
+
1710
+
1711
+
1712
+ </ul>
1713
+ </nav>
1714
+
1715
+ </li>
1716
+
1717
+
1718
+
1719
+
1720
+
1721
+
1722
+
1723
+
1724
+
1725
+
1726
+
1727
+
1728
+
1729
+
1730
+
1731
+
1732
+
1733
+
1734
+
1735
+
1736
+
1737
+
1738
+
1739
+
1740
+
1741
+
1742
+
1743
+
1744
+
1745
+
1746
+
1747
+
1748
+ <li class="md-nav__item md-nav__item--nested">
1749
+
1750
+
1751
+
1752
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5_3" >
1753
+
1754
+
1755
+ <div class="md-nav__link md-nav__container">
1756
+ <a href="../../api/messages/" class="md-nav__link ">
1757
+
1758
+
1759
+
1760
+ <span class="md-ellipsis">
1761
+
1762
+
1763
+ Messages
1764
+
1765
+
1766
+
1767
+ </span>
1768
+
1769
+
1770
+
1771
+ </a>
1772
+
1773
+
1774
+ <label class="md-nav__link " for="__nav_5_3" id="__nav_5_3_label" tabindex="0">
1775
+ <span class="md-nav__icon md-icon"></span>
1776
+ </label>
1777
+
1778
+ </div>
1779
+
1780
+ <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_5_3_label" aria-expanded="false">
1781
+ <label class="md-nav__title" for="__nav_5_3">
1782
+ <span class="md-nav__icon md-icon"></span>
1783
+
1784
+
1785
+ Messages
1786
+
1787
+
1788
+ </label>
1789
+ <ul class="md-nav__list" data-md-scrollfix>
1790
+
1791
+
1792
+
1793
+
1794
+
1795
+
1796
+
1797
+
1798
+
1799
+ <li class="md-nav__item">
1800
+ <a href="../../api/messages/user-message/" class="md-nav__link">
1801
+
1802
+
1803
+
1804
+ <span class="md-ellipsis">
1805
+
1806
+
1807
+ UserMessage
1808
+
1809
+
1810
+
1811
+ </span>
1812
+
1813
+
1814
+
1815
+ </a>
1816
+ </li>
1817
+
1818
+
1819
+
1820
+
1821
+
1822
+
1823
+
1824
+
1825
+
1826
+
1827
+ <li class="md-nav__item">
1828
+ <a href="../../api/messages/text-message/" class="md-nav__link">
1829
+
1830
+
1831
+
1832
+ <span class="md-ellipsis">
1833
+
1834
+
1835
+ TextMessage
1836
+
1837
+
1838
+
1839
+ </span>
1840
+
1841
+
1842
+
1843
+ </a>
1844
+ </li>
1845
+
1846
+
1847
+
1848
+
1849
+
1850
+
1851
+
1852
+
1853
+
1854
+
1855
+ <li class="md-nav__item">
1856
+ <a href="../../api/messages/tool-call-message/" class="md-nav__link">
1857
+
1858
+
1859
+
1860
+ <span class="md-ellipsis">
1861
+
1862
+
1863
+ ToolCallMessage
1864
+
1865
+
1866
+
1867
+ </span>
1868
+
1869
+
1870
+
1871
+ </a>
1872
+ </li>
1873
+
1874
+
1875
+
1876
+
1877
+
1878
+
1879
+
1880
+
1881
+
1882
+
1883
+ <li class="md-nav__item">
1884
+ <a href="../../api/messages/tool-result-message/" class="md-nav__link">
1885
+
1886
+
1887
+
1888
+ <span class="md-ellipsis">
1889
+
1890
+
1891
+ ToolResultMessage
1892
+
1893
+
1894
+
1895
+ </span>
1896
+
1897
+
1898
+
1899
+ </a>
1900
+ </li>
1901
+
1902
+
1903
+
1904
+
1905
+ </ul>
1906
+ </nav>
1907
+
1908
+ </li>
1909
+
1910
+
1911
+
1912
+
1913
+
1914
+
1915
+
1916
+
1917
+
1918
+
1919
+
1920
+
1921
+
1922
+
1923
+
1924
+
1925
+
1926
+
1927
+
1928
+
1929
+
1930
+
1931
+
1932
+
1933
+
1934
+
1935
+
1936
+
1937
+
1938
+
1939
+ <li class="md-nav__item md-nav__item--nested">
1940
+
1941
+
1942
+
1943
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5_4" >
1944
+
1945
+
1946
+ <div class="md-nav__link md-nav__container">
1947
+ <a href="../../api/mcp/" class="md-nav__link ">
1948
+
1949
+
1950
+
1951
+ <span class="md-ellipsis">
1952
+
1953
+
1954
+ MCP
1955
+
1956
+
1957
+
1958
+ </span>
1959
+
1960
+
1961
+
1962
+ </a>
1963
+
1964
+
1965
+ <label class="md-nav__link " for="__nav_5_4" id="__nav_5_4_label" tabindex="0">
1966
+ <span class="md-nav__icon md-icon"></span>
1967
+ </label>
1968
+
1969
+ </div>
1970
+
1971
+ <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_5_4_label" aria-expanded="false">
1972
+ <label class="md-nav__title" for="__nav_5_4">
1973
+ <span class="md-nav__icon md-icon"></span>
1974
+
1975
+
1976
+ MCP
1977
+
1978
+
1979
+ </label>
1980
+ <ul class="md-nav__list" data-md-scrollfix>
1981
+
1982
+
1983
+
1984
+
1985
+
1986
+
1987
+
1988
+
1989
+
1990
+ <li class="md-nav__item">
1991
+ <a href="../../api/mcp/client/" class="md-nav__link">
1992
+
1993
+
1994
+
1995
+ <span class="md-ellipsis">
1996
+
1997
+
1998
+ Client
1999
+
2000
+
2001
+
2002
+ </span>
2003
+
2004
+
2005
+
2006
+ </a>
2007
+ </li>
2008
+
2009
+
2010
+
2011
+
2012
+
2013
+
2014
+
2015
+
2016
+
2017
+
2018
+ <li class="md-nav__item">
2019
+ <a href="../../api/mcp/server/" class="md-nav__link">
2020
+
2021
+
2022
+
2023
+ <span class="md-ellipsis">
2024
+
2025
+
2026
+ Server
2027
+
2028
+
2029
+
2030
+ </span>
2031
+
2032
+
2033
+
2034
+ </a>
2035
+ </li>
2036
+
2037
+
2038
+
2039
+
2040
+
2041
+
2042
+
2043
+
2044
+
2045
+
2046
+ <li class="md-nav__item">
2047
+ <a href="../../api/mcp/transports/" class="md-nav__link">
2048
+
2049
+
2050
+
2051
+ <span class="md-ellipsis">
2052
+
2053
+
2054
+ Transports
2055
+
2056
+
2057
+
2058
+ </span>
2059
+
2060
+
2061
+
2062
+ </a>
2063
+ </li>
2064
+
2065
+
2066
+
2067
+
2068
+ </ul>
2069
+ </nav>
2070
+
2071
+ </li>
2072
+
2073
+
2074
+
2075
+
2076
+
2077
+
2078
+
2079
+
2080
+
2081
+
2082
+
2083
+
2084
+
2085
+
2086
+
2087
+
2088
+
2089
+
2090
+
2091
+
2092
+
2093
+
2094
+
2095
+
2096
+
2097
+
2098
+
2099
+
2100
+ <li class="md-nav__item md-nav__item--nested">
2101
+
2102
+
2103
+
2104
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5_5" >
2105
+
2106
+
2107
+ <div class="md-nav__link md-nav__container">
2108
+ <a href="../../api/streaming/" class="md-nav__link ">
2109
+
2110
+
2111
+
2112
+ <span class="md-ellipsis">
2113
+
2114
+
2115
+ Streaming
2116
+
2117
+
2118
+
2119
+ </span>
2120
+
2121
+
2122
+
2123
+ </a>
2124
+
2125
+
2126
+ <label class="md-nav__link " for="__nav_5_5" id="__nav_5_5_label" tabindex="0">
2127
+ <span class="md-nav__icon md-icon"></span>
2128
+ </label>
2129
+
2130
+ </div>
2131
+
2132
+ <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_5_5_label" aria-expanded="false">
2133
+ <label class="md-nav__title" for="__nav_5_5">
2134
+ <span class="md-nav__icon md-icon"></span>
2135
+
2136
+
2137
+ Streaming
2138
+
2139
+
2140
+ </label>
2141
+ <ul class="md-nav__list" data-md-scrollfix>
2142
+
2143
+
2144
+
2145
+
2146
+
2147
+
2148
+
2149
+
2150
+
2151
+ <li class="md-nav__item">
2152
+ <a href="../../api/streaming/context/" class="md-nav__link">
2153
+
2154
+
2155
+
2156
+ <span class="md-ellipsis">
2157
+
2158
+
2159
+ Context
2160
+
2161
+
2162
+
2163
+ </span>
2164
+
2165
+
2166
+
2167
+ </a>
2168
+ </li>
2169
+
2170
+
2171
+
2172
+
2173
+
2174
+
2175
+
2176
+
2177
+
2178
+
2179
+ <li class="md-nav__item">
2180
+ <a href="../../api/streaming/events/" class="md-nav__link">
2181
+
2182
+
2183
+
2184
+ <span class="md-ellipsis">
2185
+
2186
+
2187
+ Events
2188
+
2189
+
2190
+
2191
+ </span>
2192
+
2193
+
2194
+
2195
+ </a>
2196
+ </li>
2197
+
2198
+
2199
+
2200
+
2201
+ </ul>
2202
+ </nav>
2203
+
2204
+ </li>
2205
+
2206
+
2207
+
2208
+
2209
+ </ul>
2210
+ </nav>
2211
+
2212
+ </li>
2213
+
2214
+
2215
+
2216
+
2217
+
2218
+
2219
+
2220
+
2221
+
2222
+
2223
+
2224
+
2225
+
2226
+
2227
+
2228
+
2229
+
2230
+
2231
+
2232
+
2233
+
2234
+
2235
+
2236
+
2237
+
2238
+
2239
+
2240
+
2241
+
2242
+
2243
+
2244
+
2245
+
2246
+ <li class="md-nav__item md-nav__item--nested">
2247
+
2248
+
2249
+
2250
+ <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_6" >
2251
+
2252
+
2253
+ <div class="md-nav__link md-nav__container">
2254
+ <a href="../../examples/" class="md-nav__link ">
2255
+
2256
+
2257
+
2258
+ <span class="md-ellipsis">
2259
+
2260
+
2261
+ Examples
2262
+
2263
+
2264
+
2265
+ </span>
2266
+
2267
+
2268
+
2269
+ </a>
2270
+
2271
+
2272
+ <label class="md-nav__link " for="__nav_6" id="__nav_6_label" tabindex="0">
2273
+ <span class="md-nav__icon md-icon"></span>
2274
+ </label>
2275
+
2276
+ </div>
2277
+
2278
+ <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_6_label" aria-expanded="false">
2279
+ <label class="md-nav__title" for="__nav_6">
2280
+ <span class="md-nav__icon md-icon"></span>
2281
+
2282
+
2283
+ Examples
2284
+
2285
+
2286
+ </label>
2287
+ <ul class="md-nav__list" data-md-scrollfix>
2288
+
2289
+
2290
+
2291
+
2292
+
2293
+
2294
+
2295
+
2296
+
2297
+ <li class="md-nav__item">
2298
+ <a href="../../examples/basic-chat/" class="md-nav__link">
2299
+
2300
+
2301
+
2302
+ <span class="md-ellipsis">
2303
+
2304
+
2305
+ Basic Chat
2306
+
2307
+
2308
+
2309
+ </span>
2310
+
2311
+
2312
+
2313
+ </a>
2314
+ </li>
2315
+
2316
+
2317
+
2318
+
2319
+
2320
+
2321
+
2322
+
2323
+
2324
+
2325
+ <li class="md-nav__item">
2326
+ <a href="../../examples/multi-robot-network/" class="md-nav__link">
2327
+
2328
+
2329
+
2330
+ <span class="md-ellipsis">
2331
+
2332
+
2333
+ Multi-Robot Network
2334
+
2335
+
2336
+
2337
+ </span>
2338
+
2339
+
2340
+
2341
+ </a>
2342
+ </li>
2343
+
2344
+
2345
+
2346
+
2347
+
2348
+
2349
+
2350
+
2351
+
2352
+
2353
+ <li class="md-nav__item">
2354
+ <a href="../../examples/tool-usage/" class="md-nav__link">
2355
+
2356
+
2357
+
2358
+ <span class="md-ellipsis">
2359
+
2360
+
2361
+ Tool Usage
2362
+
2363
+
2364
+
2365
+ </span>
2366
+
2367
+
2368
+
2369
+ </a>
2370
+ </li>
2371
+
2372
+
2373
+
2374
+
2375
+
2376
+
2377
+
2378
+
2379
+
2380
+
2381
+ <li class="md-nav__item">
2382
+ <a href="../../examples/mcp-server/" class="md-nav__link">
2383
+
2384
+
2385
+
2386
+ <span class="md-ellipsis">
2387
+
2388
+
2389
+ MCP Server
2390
+
2391
+
2392
+
2393
+ </span>
2394
+
2395
+
2396
+
2397
+ </a>
2398
+ </li>
2399
+
2400
+
2401
+
2402
+
2403
+
2404
+
2405
+
2406
+
2407
+
2408
+
2409
+ <li class="md-nav__item">
2410
+ <a href="../../examples/rails-application/" class="md-nav__link">
2411
+
2412
+
2413
+
2414
+ <span class="md-ellipsis">
2415
+
2416
+
2417
+ Rails Application
2418
+
2419
+
2420
+
2421
+ </span>
2422
+
2423
+
2424
+
2425
+ </a>
2426
+ </li>
2427
+
2428
+
2429
+
2430
+
2431
+ </ul>
2432
+ </nav>
2433
+
2434
+ </li>
2435
+
2436
+
2437
+
2438
+ </ul>
2439
+ </nav>
2440
+ </div>
2441
+ </div>
2442
+ </div>
2443
+
2444
+
2445
+
2446
+ <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
2447
+ <div class="md-sidebar__scrollwrap">
2448
+ <div class="md-sidebar__inner">
2449
+
2450
+
2451
+
2452
+
2453
+ <nav class="md-nav md-nav--secondary" aria-label="On this page">
2454
+
2455
+
2456
+
2457
+
2458
+
2459
+
2460
+ <label class="md-nav__title" for="__toc">
2461
+ <span class="md-nav__icon md-icon"></span>
2462
+ On this page
2463
+ </label>
2464
+ <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
2465
+
2466
+ <li class="md-nav__item">
2467
+ <a href="#execution-overview" class="md-nav__link">
2468
+ <span class="md-ellipsis">
2469
+
2470
+ Execution Overview
2471
+
2472
+ </span>
2473
+ </a>
2474
+
2475
+ </li>
2476
+
2477
+ <li class="md-nav__item">
2478
+ <a href="#step-by-step-flow" class="md-nav__link">
2479
+ <span class="md-ellipsis">
2480
+
2481
+ Step-by-Step Flow
2482
+
2483
+ </span>
2484
+ </a>
2485
+
2486
+ <nav class="md-nav" aria-label="Step-by-Step Flow">
2487
+ <ul class="md-nav__list">
2488
+
2489
+ <li class="md-nav__item">
2490
+ <a href="#1-memory-resolution" class="md-nav__link">
2491
+ <span class="md-ellipsis">
2492
+
2493
+ 1. Memory Resolution
2494
+
2495
+ </span>
2496
+ </a>
2497
+
2498
+ </li>
2499
+
2500
+ <li class="md-nav__item">
2501
+ <a href="#2-mcp-hierarchy-resolution" class="md-nav__link">
2502
+ <span class="md-ellipsis">
2503
+
2504
+ 2. MCP Hierarchy Resolution
2505
+
2506
+ </span>
2507
+ </a>
2508
+
2509
+ </li>
2510
+
2511
+ <li class="md-nav__item">
2512
+ <a href="#3-mcp-client-initialization" class="md-nav__link">
2513
+ <span class="md-ellipsis">
2514
+
2515
+ 3. MCP Client Initialization
2516
+
2517
+ </span>
2518
+ </a>
2519
+
2520
+ </li>
2521
+
2522
+ <li class="md-nav__item">
2523
+ <a href="#4-tools-resolution" class="md-nav__link">
2524
+ <span class="md-ellipsis">
2525
+
2526
+ 4. Tools Resolution
2527
+
2528
+ </span>
2529
+ </a>
2530
+
2531
+ </li>
2532
+
2533
+ <li class="md-nav__item">
2534
+ <a href="#5-llm-inference" class="md-nav__link">
2535
+ <span class="md-ellipsis">
2536
+
2537
+ 5. LLM Inference
2538
+
2539
+ </span>
2540
+ </a>
2541
+
2542
+ </li>
2543
+
2544
+ <li class="md-nav__item">
2545
+ <a href="#6-tool-execution-loop" class="md-nav__link">
2546
+ <span class="md-ellipsis">
2547
+
2548
+ 6. Tool Execution Loop
2549
+
2550
+ </span>
2551
+ </a>
2552
+
2553
+ </li>
2554
+
2555
+ <li class="md-nav__item">
2556
+ <a href="#7-result-construction" class="md-nav__link">
2557
+ <span class="md-ellipsis">
2558
+
2559
+ 7. Result Construction
2560
+
2561
+ </span>
2562
+ </a>
2563
+
2564
+ </li>
2565
+
2566
+ </ul>
2567
+ </nav>
2568
+
2569
+ </li>
2570
+
2571
+ <li class="md-nav__item">
2572
+ <a href="#robotresult" class="md-nav__link">
2573
+ <span class="md-ellipsis">
2574
+
2575
+ RobotResult
2576
+
2577
+ </span>
2578
+ </a>
2579
+
2580
+ </li>
2581
+
2582
+ <li class="md-nav__item">
2583
+ <a href="#streaming" class="md-nav__link">
2584
+ <span class="md-ellipsis">
2585
+
2586
+ Streaming
2587
+
2588
+ </span>
2589
+ </a>
2590
+
2591
+ </li>
2592
+
2593
+ <li class="md-nav__item">
2594
+ <a href="#template-resolution" class="md-nav__link">
2595
+ <span class="md-ellipsis">
2596
+
2597
+ Template Resolution
2598
+
2599
+ </span>
2600
+ </a>
2601
+
2602
+ <nav class="md-nav" aria-label="Template Resolution">
2603
+ <ul class="md-nav__list">
2604
+
2605
+ <li class="md-nav__item">
2606
+ <a href="#front-matter-config-keys" class="md-nav__link">
2607
+ <span class="md-ellipsis">
2608
+
2609
+ Front Matter Config Keys
2610
+
2611
+ </span>
2612
+ </a>
2613
+
2614
+ </li>
2615
+
2616
+ </ul>
2617
+ </nav>
2618
+
2619
+ </li>
2620
+
2621
+ <li class="md-nav__item">
2622
+ <a href="#model-selection" class="md-nav__link">
2623
+ <span class="md-ellipsis">
2624
+
2625
+ Model Selection
2626
+
2627
+ </span>
2628
+ </a>
2629
+
2630
+ </li>
2631
+
2632
+ <li class="md-nav__item">
2633
+ <a href="#simpleflow-integration" class="md-nav__link">
2634
+ <span class="md-ellipsis">
2635
+
2636
+ SimpleFlow Integration
2637
+
2638
+ </span>
2639
+ </a>
2640
+
2641
+ </li>
2642
+
2643
+ <li class="md-nav__item">
2644
+ <a href="#next-steps" class="md-nav__link">
2645
+ <span class="md-ellipsis">
2646
+
2647
+ Next Steps
2648
+
2649
+ </span>
2650
+ </a>
2651
+
2652
+ </li>
2653
+
2654
+ </ul>
2655
+
2656
+ </nav>
2657
+ </div>
2658
+ </div>
2659
+ </div>
2660
+
2661
+
2662
+
2663
+ <div class="md-content" data-md-component="content">
2664
+
2665
+
2666
+
2667
+
2668
+
2669
+
2670
+
2671
+ <article class="md-content__inner md-typeset">
2672
+
2673
+
2674
+
2675
+
2676
+
2677
+ <a href="https://github.com/madbomber/robot_lab/edit/main/docs/architecture/robot-execution.md" title="Edit this page" class="md-content__button md-icon" rel="edit">
2678
+
2679
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M10 20H6V4h7v5h5v3.1l2-2V8l-6-6H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h4zm10.2-7c.1 0 .3.1.4.2l1.3 1.3c.2.2.2.6 0 .8l-1 1-2.1-2.1 1-1c.1-.1.2-.2.4-.2m0 3.9L14.1 23H12v-2.1l6.1-6.1z"/></svg>
2680
+ </a>
2681
+
2682
+
2683
+
2684
+
2685
+
2686
+ <a href="https://github.com/madbomber/robot_lab/raw/main/docs/architecture/robot-execution.md" title="View source of this page" class="md-content__button md-icon">
2687
+
2688
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M17 18c.56 0 1 .44 1 1s-.44 1-1 1-1-.44-1-1 .44-1 1-1m0-3c-2.73 0-5.06 1.66-6 4 .94 2.34 3.27 4 6 4s5.06-1.66 6-4c-.94-2.34-3.27-4-6-4m0 6.5a2.5 2.5 0 0 1-2.5-2.5 2.5 2.5 0 0 1 2.5-2.5 2.5 2.5 0 0 1 2.5 2.5 2.5 2.5 0 0 1-2.5 2.5M9.27 20H6V4h7v5h5v4.07c.7.08 1.36.25 2 .49V8l-6-6H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h4.5a8.2 8.2 0 0 1-1.23-2"/></svg>
2689
+ </a>
2690
+
2691
+
2692
+
2693
+ <h1 id="robot-execution">Robot Execution<a class="headerlink" href="#robot-execution" title="Permanent link">&para;</a></h1>
2694
+ <p>This page details how a robot processes messages and generates responses.</p>
2695
+ <h2 id="execution-overview">Execution Overview<a class="headerlink" href="#execution-overview" title="Permanent link">&para;</a></h2>
2696
+ <p>When you call <code>robot.run("message")</code>, several steps occur:</p>
2697
+ <pre class="mermaid"><code>sequenceDiagram
2698
+ participant App as Application
2699
+ participant Robot
2700
+ participant Memory
2701
+ participant Chat as @chat (RubyLLM)
2702
+ participant LLM
2703
+
2704
+ App-&gt;&gt;Robot: run("message")
2705
+ Robot-&gt;&gt;Memory: resolve_active_memory()
2706
+ Robot-&gt;&gt;Robot: resolve_mcp_hierarchy()
2707
+ Robot-&gt;&gt;Robot: resolve_tools_hierarchy()
2708
+ Robot-&gt;&gt;Robot: ensure_mcp_clients()
2709
+ Robot-&gt;&gt;Robot: filtered_tools()
2710
+ Robot-&gt;&gt;Chat: with_tools(*filtered)
2711
+ Robot-&gt;&gt;Chat: ask("message")
2712
+ Chat-&gt;&gt;LLM: API Request
2713
+
2714
+ loop Tool Calls
2715
+ LLM--&gt;&gt;Chat: tool_call response
2716
+ Chat-&gt;&gt;Chat: execute tool
2717
+ Chat-&gt;&gt;LLM: tool result
2718
+ end
2719
+
2720
+ LLM--&gt;&gt;Chat: final response
2721
+ Chat--&gt;&gt;Robot: RubyLLM::Response
2722
+ Robot-&gt;&gt;Robot: build_result(response)
2723
+ Robot--&gt;&gt;App: RobotResult</code></pre>
2724
+ <h2 id="step-by-step-flow">Step-by-Step Flow<a class="headerlink" href="#step-by-step-flow" title="Permanent link">&para;</a></h2>
2725
+ <h3 id="1-memory-resolution">1. Memory Resolution<a class="headerlink" href="#1-memory-resolution" title="Permanent link">&para;</a></h3>
2726
+ <p>The robot determines which memory to use for this run:</p>
2727
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-0-1"><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a><span class="c1"># Priority order:</span>
2728
+ </span><span id="__span-0-2"><a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a><span class="c1"># 1. Explicit network_memory: parameter</span>
2729
+ </span><span id="__span-0-3"><a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a><span class="c1"># 2. Network&#39;s memory (if running in a network)</span>
2730
+ </span><span id="__span-0-4"><a id="__codelineno-0-4" name="__codelineno-0-4" href="#__codelineno-0-4"></a><span class="c1"># 3. Robot&#39;s inherent @memory (standalone mode)</span>
2731
+ </span><span id="__span-0-5"><a id="__codelineno-0-5" name="__codelineno-0-5" href="#__codelineno-0-5"></a><span class="n">run_memory</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">resolve_active_memory</span><span class="p">(</span><span class="ss">network</span><span class="p">:</span><span class="w"> </span><span class="n">network</span><span class="p">,</span><span class="w"> </span><span class="ss">network_memory</span><span class="p">:</span><span class="w"> </span><span class="n">network_memory</span><span class="p">)</span>
2732
+ </span><span id="__span-0-6"><a id="__codelineno-0-6" name="__codelineno-0-6" href="#__codelineno-0-6"></a>
2733
+ </span><span id="__span-0-7"><a id="__codelineno-0-7" name="__codelineno-0-7" href="#__codelineno-0-7"></a><span class="c1"># Merge runtime memory if provided</span>
2734
+ </span><span id="__span-0-8"><a id="__codelineno-0-8" name="__codelineno-0-8" href="#__codelineno-0-8"></a><span class="k">case</span><span class="w"> </span><span class="n">memory</span>
2735
+ </span><span id="__span-0-9"><a id="__codelineno-0-9" name="__codelineno-0-9" href="#__codelineno-0-9"></a><span class="k">when</span><span class="w"> </span><span class="no">Memory</span><span class="w"> </span><span class="k">then</span><span class="w"> </span><span class="n">run_memory</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">memory</span>
2736
+ </span><span id="__span-0-10"><a id="__codelineno-0-10" name="__codelineno-0-10" href="#__codelineno-0-10"></a><span class="k">when</span><span class="w"> </span><span class="no">Hash</span><span class="w"> </span><span class="k">then</span><span class="w"> </span><span class="n">run_memory</span><span class="o">.</span><span class="n">merge!</span><span class="p">(</span><span class="n">memory</span><span class="p">)</span>
2737
+ </span><span id="__span-0-11"><a id="__codelineno-0-11" name="__codelineno-0-11" href="#__codelineno-0-11"></a><span class="k">end</span>
2738
+ </span><span id="__span-0-12"><a id="__codelineno-0-12" name="__codelineno-0-12" href="#__codelineno-0-12"></a>
2739
+ </span><span id="__span-0-13"><a id="__codelineno-0-13" name="__codelineno-0-13" href="#__codelineno-0-13"></a><span class="c1"># Track who is writing to memory</span>
2740
+ </span><span id="__span-0-14"><a id="__codelineno-0-14" name="__codelineno-0-14" href="#__codelineno-0-14"></a><span class="n">run_memory</span><span class="o">.</span><span class="n">current_writer</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="vi">@name</span>
2741
+ </span></code></pre></div>
2742
+ <h3 id="2-mcp-hierarchy-resolution">2. MCP Hierarchy Resolution<a class="headerlink" href="#2-mcp-hierarchy-resolution" title="Permanent link">&para;</a></h3>
2743
+ <p>MCP servers are resolved through a hierarchy: <strong>runtime &gt; robot build-time &gt; network &gt; global config</strong>.</p>
2744
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-1-1"><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a><span class="c1"># Resolve build-time config against network/global</span>
2745
+ </span><span id="__span-1-2"><a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a><span class="n">parent_value</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">network</span><span class="o">&amp;.</span><span class="n">network</span><span class="o">&amp;.</span><span class="n">mcp</span><span class="w"> </span><span class="o">||</span><span class="w"> </span><span class="no">RobotLab</span><span class="o">.</span><span class="n">config</span><span class="o">.</span><span class="n">mcp</span>
2746
+ </span><span id="__span-1-3"><a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a><span class="n">build_resolved</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">ToolConfig</span><span class="o">.</span><span class="n">resolve_mcp</span><span class="p">(</span><span class="vi">@mcp_config</span><span class="p">,</span><span class="w"> </span><span class="ss">parent_value</span><span class="p">:</span><span class="w"> </span><span class="n">parent_value</span><span class="p">)</span>
2747
+ </span><span id="__span-1-4"><a id="__codelineno-1-4" name="__codelineno-1-4" href="#__codelineno-1-4"></a>
2748
+ </span><span id="__span-1-5"><a id="__codelineno-1-5" name="__codelineno-1-5" href="#__codelineno-1-5"></a><span class="c1"># Then resolve runtime override against build-time</span>
2749
+ </span><span id="__span-1-6"><a id="__codelineno-1-6" name="__codelineno-1-6" href="#__codelineno-1-6"></a><span class="n">resolved_mcp</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">ToolConfig</span><span class="o">.</span><span class="n">resolve_mcp</span><span class="p">(</span><span class="n">runtime_mcp</span><span class="p">,</span><span class="w"> </span><span class="ss">parent_value</span><span class="p">:</span><span class="w"> </span><span class="n">build_resolved</span><span class="p">)</span>
2750
+ </span></code></pre></div>
2751
+ <p>Values at each level:</p>
2752
+ <ul>
2753
+ <li><code>:none</code> -- no MCP servers at this level</li>
2754
+ <li><code>:inherit</code> -- use parent level's MCP config</li>
2755
+ <li><code>Array</code> -- explicit list of server configurations</li>
2756
+ </ul>
2757
+ <h3 id="3-mcp-client-initialization">3. MCP Client Initialization<a class="headerlink" href="#3-mcp-client-initialization" title="Permanent link">&para;</a></h3>
2758
+ <p>If MCP servers need to be connected (or reconnected), the robot initializes clients:</p>
2759
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-2-1"><a id="__codelineno-2-1" name="__codelineno-2-1" href="#__codelineno-2-1"></a><span class="c1"># Connect to each MCP server</span>
2760
+ </span><span id="__span-2-2"><a id="__codelineno-2-2" name="__codelineno-2-2" href="#__codelineno-2-2"></a><span class="n">mcp_servers</span><span class="o">.</span><span class="n">each</span><span class="w"> </span><span class="k">do</span><span class="w"> </span><span class="o">|</span><span class="n">server_config</span><span class="o">|</span>
2761
+ </span><span id="__span-2-3"><a id="__codelineno-2-3" name="__codelineno-2-3" href="#__codelineno-2-3"></a><span class="w"> </span><span class="n">client</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">MCP</span><span class="o">::</span><span class="no">Client</span><span class="o">.</span><span class="n">new</span><span class="p">(</span><span class="n">server_config</span><span class="p">)</span>
2762
+ </span><span id="__span-2-4"><a id="__codelineno-2-4" name="__codelineno-2-4" href="#__codelineno-2-4"></a><span class="w"> </span><span class="n">client</span><span class="o">.</span><span class="n">connect</span>
2763
+ </span><span id="__span-2-5"><a id="__codelineno-2-5" name="__codelineno-2-5" href="#__codelineno-2-5"></a>
2764
+ </span><span id="__span-2-6"><a id="__codelineno-2-6" name="__codelineno-2-6" href="#__codelineno-2-6"></a><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">client</span><span class="o">.</span><span class="n">connected?</span>
2765
+ </span><span id="__span-2-7"><a id="__codelineno-2-7" name="__codelineno-2-7" href="#__codelineno-2-7"></a><span class="w"> </span><span class="vi">@mcp_clients</span><span class="o">[</span><span class="n">client</span><span class="o">.</span><span class="n">server</span><span class="o">.</span><span class="n">name</span><span class="o">]</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">client</span>
2766
+ </span><span id="__span-2-8"><a id="__codelineno-2-8" name="__codelineno-2-8" href="#__codelineno-2-8"></a><span class="w"> </span><span class="n">discover_mcp_tools</span><span class="p">(</span><span class="n">client</span><span class="p">,</span><span class="w"> </span><span class="n">server_name</span><span class="p">)</span><span class="w"> </span><span class="c1"># Auto-discover tools</span>
2767
+ </span><span id="__span-2-9"><a id="__codelineno-2-9" name="__codelineno-2-9" href="#__codelineno-2-9"></a><span class="w"> </span><span class="k">end</span>
2768
+ </span><span id="__span-2-10"><a id="__codelineno-2-10" name="__codelineno-2-10" href="#__codelineno-2-10"></a><span class="k">end</span>
2769
+ </span></code></pre></div>
2770
+ <h3 id="4-tools-resolution">4. Tools Resolution<a class="headerlink" href="#4-tools-resolution" title="Permanent link">&para;</a></h3>
2771
+ <p>Tools are resolved through the same hierarchy and filtered:</p>
2772
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-3-1"><a id="__codelineno-3-1" name="__codelineno-3-1" href="#__codelineno-3-1"></a><span class="c1"># Collect all available tools</span>
2773
+ </span><span id="__span-3-2"><a id="__codelineno-3-2" name="__codelineno-3-2" href="#__codelineno-3-2"></a><span class="n">available</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="vi">@local_tools</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="vi">@mcp_tools</span>
2774
+ </span><span id="__span-3-3"><a id="__codelineno-3-3" name="__codelineno-3-3" href="#__codelineno-3-3"></a>
2775
+ </span><span id="__span-3-4"><a id="__codelineno-3-4" name="__codelineno-3-4" href="#__codelineno-3-4"></a><span class="c1"># Apply whitelist if specified</span>
2776
+ </span><span id="__span-3-5"><a id="__codelineno-3-5" name="__codelineno-3-5" href="#__codelineno-3-5"></a><span class="n">filtered</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">ToolConfig</span><span class="o">.</span><span class="n">filter_tools</span><span class="p">(</span><span class="n">available</span><span class="p">,</span><span class="w"> </span><span class="ss">allowed_names</span><span class="p">:</span><span class="w"> </span><span class="n">resolved_tools</span><span class="p">)</span>
2777
+ </span><span id="__span-3-6"><a id="__codelineno-3-6" name="__codelineno-3-6" href="#__codelineno-3-6"></a>
2778
+ </span><span id="__span-3-7"><a id="__codelineno-3-7" name="__codelineno-3-7" href="#__codelineno-3-7"></a><span class="c1"># Apply tools to the persistent chat</span>
2779
+ </span><span id="__span-3-8"><a id="__codelineno-3-8" name="__codelineno-3-8" href="#__codelineno-3-8"></a><span class="vi">@chat</span><span class="o">.</span><span class="n">with_tools</span><span class="p">(</span><span class="o">*</span><span class="n">filtered</span><span class="p">)</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">filtered</span><span class="o">.</span><span class="n">any?</span>
2780
+ </span></code></pre></div>
2781
+ <h3 id="5-llm-inference">5. LLM Inference<a class="headerlink" href="#5-llm-inference" title="Permanent link">&para;</a></h3>
2782
+ <p>The message is sent to the LLM via <code>Agent#ask</code>, which delegates to <code>@chat.ask</code>:</p>
2783
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-4-1"><a id="__codelineno-4-1" name="__codelineno-4-1" href="#__codelineno-4-1"></a><span class="c1"># Robot#run calls Agent#ask</span>
2784
+ </span><span id="__span-4-2"><a id="__codelineno-4-2" name="__codelineno-4-2" href="#__codelineno-4-2"></a><span class="n">response</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">ask</span><span class="p">(</span><span class="n">message</span><span class="p">,</span><span class="w"> </span><span class="o">**</span><span class="n">kwargs</span><span class="p">)</span>
2785
+ </span><span id="__span-4-3"><a id="__codelineno-4-3" name="__codelineno-4-3" href="#__codelineno-4-3"></a>
2786
+ </span><span id="__span-4-4"><a id="__codelineno-4-4" name="__codelineno-4-4" href="#__codelineno-4-4"></a><span class="c1"># Internally, Agent#ask calls:</span>
2787
+ </span><span id="__span-4-5"><a id="__codelineno-4-5" name="__codelineno-4-5" href="#__codelineno-4-5"></a><span class="c1"># @chat.ask(message)</span>
2788
+ </span></code></pre></div>
2789
+ <p>The persistent <code>@chat</code> (a <code>RubyLLM::Chat</code> instance) handles:</p>
2790
+ <ul>
2791
+ <li>Maintaining conversation history</li>
2792
+ <li>Sending the system prompt</li>
2793
+ <li>Formatting messages for the provider</li>
2794
+ <li>Executing the tool call loop automatically</li>
2795
+ </ul>
2796
+ <h3 id="6-tool-execution-loop">6. Tool Execution Loop<a class="headerlink" href="#6-tool-execution-loop" title="Permanent link">&para;</a></h3>
2797
+ <p>RubyLLM's <code>@chat</code> handles the tool loop automatically. When the LLM requests a tool call:</p>
2798
+ <ol>
2799
+ <li><code>@chat</code> identifies the tool from its registered tools</li>
2800
+ <li>Calls the tool's <code>execute</code> method (for <code>RubyLLM::Tool</code> subclasses) or <code>call</code> method (for <code>RobotLab::Tool</code>)</li>
2801
+ <li>Sends the result back to the LLM</li>
2802
+ <li>Repeats until the LLM produces a final text response</li>
2803
+ </ol>
2804
+ <p>The <code>on_tool_call</code> and <code>on_tool_result</code> callbacks fire during this loop if configured:</p>
2805
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-5-1"><a id="__codelineno-5-1" name="__codelineno-5-1" href="#__codelineno-5-1"></a><span class="c1"># These callbacks are registered on @chat during Robot#initialize</span>
2806
+ </span><span id="__span-5-2"><a id="__codelineno-5-2" name="__codelineno-5-2" href="#__codelineno-5-2"></a><span class="vi">@chat</span><span class="o">.</span><span class="n">on_tool_call</span><span class="p">(</span><span class="o">&amp;</span><span class="vi">@on_tool_call</span><span class="p">)</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="vi">@on_tool_call</span>
2807
+ </span><span id="__span-5-3"><a id="__codelineno-5-3" name="__codelineno-5-3" href="#__codelineno-5-3"></a><span class="vi">@chat</span><span class="o">.</span><span class="n">on_tool_result</span><span class="p">(</span><span class="o">&amp;</span><span class="vi">@on_tool_result</span><span class="p">)</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="vi">@on_tool_result</span>
2808
+ </span></code></pre></div>
2809
+ <h3 id="7-result-construction">7. Result Construction<a class="headerlink" href="#7-result-construction" title="Permanent link">&para;</a></h3>
2810
+ <p>After the LLM responds, a <code>RobotResult</code> is built:</p>
2811
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-6-1"><a id="__codelineno-6-1" name="__codelineno-6-1" href="#__codelineno-6-1"></a><span class="k">def</span><span class="w"> </span><span class="nf">build_result</span><span class="p">(</span><span class="n">response</span><span class="p">,</span><span class="w"> </span><span class="n">_memory</span><span class="p">)</span>
2812
+ </span><span id="__span-6-2"><a id="__codelineno-6-2" name="__codelineno-6-2" href="#__codelineno-6-2"></a><span class="w"> </span><span class="n">output</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">respond_to?</span><span class="p">(</span><span class="ss">:content</span><span class="p">)</span><span class="w"> </span><span class="o">&amp;&amp;</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">content</span>
2813
+ </span><span id="__span-6-3"><a id="__codelineno-6-3" name="__codelineno-6-3" href="#__codelineno-6-3"></a><span class="w"> </span><span class="o">[</span><span class="no">TextMessage</span><span class="o">.</span><span class="n">new</span><span class="p">(</span><span class="ss">role</span><span class="p">:</span><span class="w"> </span><span class="s1">&#39;assistant&#39;</span><span class="p">,</span><span class="w"> </span><span class="ss">content</span><span class="p">:</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">content</span><span class="p">)</span><span class="o">]</span>
2814
+ </span><span id="__span-6-4"><a id="__codelineno-6-4" name="__codelineno-6-4" href="#__codelineno-6-4"></a><span class="w"> </span><span class="k">else</span>
2815
+ </span><span id="__span-6-5"><a id="__codelineno-6-5" name="__codelineno-6-5" href="#__codelineno-6-5"></a><span class="w"> </span><span class="o">[]</span>
2816
+ </span><span id="__span-6-6"><a id="__codelineno-6-6" name="__codelineno-6-6" href="#__codelineno-6-6"></a><span class="w"> </span><span class="k">end</span>
2817
+ </span><span id="__span-6-7"><a id="__codelineno-6-7" name="__codelineno-6-7" href="#__codelineno-6-7"></a>
2818
+ </span><span id="__span-6-8"><a id="__codelineno-6-8" name="__codelineno-6-8" href="#__codelineno-6-8"></a><span class="w"> </span><span class="n">tool_calls</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">respond_to?</span><span class="p">(</span><span class="ss">:tool_calls</span><span class="p">)</span><span class="w"> </span><span class="p">?</span><span class="w"> </span><span class="p">(</span><span class="n">response</span><span class="o">.</span><span class="n">tool_calls</span><span class="w"> </span><span class="o">||</span><span class="w"> </span><span class="o">[]</span><span class="p">)</span><span class="w"> </span><span class="p">:</span><span class="w"> </span><span class="o">[]</span>
2819
+ </span><span id="__span-6-9"><a id="__codelineno-6-9" name="__codelineno-6-9" href="#__codelineno-6-9"></a>
2820
+ </span><span id="__span-6-10"><a id="__codelineno-6-10" name="__codelineno-6-10" href="#__codelineno-6-10"></a><span class="w"> </span><span class="no">RobotResult</span><span class="o">.</span><span class="n">new</span><span class="p">(</span>
2821
+ </span><span id="__span-6-11"><a id="__codelineno-6-11" name="__codelineno-6-11" href="#__codelineno-6-11"></a><span class="w"> </span><span class="ss">robot_name</span><span class="p">:</span><span class="w"> </span><span class="vi">@name</span><span class="p">,</span>
2822
+ </span><span id="__span-6-12"><a id="__codelineno-6-12" name="__codelineno-6-12" href="#__codelineno-6-12"></a><span class="w"> </span><span class="ss">output</span><span class="p">:</span><span class="w"> </span><span class="n">output</span><span class="p">,</span>
2823
+ </span><span id="__span-6-13"><a id="__codelineno-6-13" name="__codelineno-6-13" href="#__codelineno-6-13"></a><span class="w"> </span><span class="ss">tool_calls</span><span class="p">:</span><span class="w"> </span><span class="n">normalize_tool_calls</span><span class="p">(</span><span class="n">tool_calls</span><span class="p">),</span>
2824
+ </span><span id="__span-6-14"><a id="__codelineno-6-14" name="__codelineno-6-14" href="#__codelineno-6-14"></a><span class="w"> </span><span class="ss">stop_reason</span><span class="p">:</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">respond_to?</span><span class="p">(</span><span class="ss">:stop_reason</span><span class="p">)</span><span class="w"> </span><span class="p">?</span><span class="w"> </span><span class="n">response</span><span class="o">.</span><span class="n">stop_reason</span><span class="w"> </span><span class="p">:</span><span class="w"> </span><span class="kp">nil</span>
2825
+ </span><span id="__span-6-15"><a id="__codelineno-6-15" name="__codelineno-6-15" href="#__codelineno-6-15"></a><span class="w"> </span><span class="p">)</span>
2826
+ </span><span id="__span-6-16"><a id="__codelineno-6-16" name="__codelineno-6-16" href="#__codelineno-6-16"></a><span class="k">end</span>
2827
+ </span></code></pre></div>
2828
+ <h2 id="robotresult">RobotResult<a class="headerlink" href="#robotresult" title="Permanent link">&para;</a></h2>
2829
+ <p>The result object from a <code>robot.run</code> call:</p>
2830
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-7-1"><a id="__codelineno-7-1" name="__codelineno-7-1" href="#__codelineno-7-1"></a><span class="n">result</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">robot</span><span class="o">.</span><span class="n">run</span><span class="p">(</span><span class="s2">&quot;Hello!&quot;</span><span class="p">)</span>
2831
+ </span><span id="__span-7-2"><a id="__codelineno-7-2" name="__codelineno-7-2" href="#__codelineno-7-2"></a>
2832
+ </span><span id="__span-7-3"><a id="__codelineno-7-3" name="__codelineno-7-3" href="#__codelineno-7-3"></a><span class="n">result</span><span class="o">.</span><span class="n">robot_name</span><span class="w"> </span><span class="c1"># =&gt; &quot;assistant&quot;</span>
2833
+ </span><span id="__span-7-4"><a id="__codelineno-7-4" name="__codelineno-7-4" href="#__codelineno-7-4"></a><span class="n">result</span><span class="o">.</span><span class="n">output</span><span class="w"> </span><span class="c1"># =&gt; [TextMessage, ...]</span>
2834
+ </span><span id="__span-7-5"><a id="__codelineno-7-5" name="__codelineno-7-5" href="#__codelineno-7-5"></a><span class="n">result</span><span class="o">.</span><span class="n">tool_calls</span><span class="w"> </span><span class="c1"># =&gt; [ToolResultMessage, ...]</span>
2835
+ </span><span id="__span-7-6"><a id="__codelineno-7-6" name="__codelineno-7-6" href="#__codelineno-7-6"></a><span class="n">result</span><span class="o">.</span><span class="n">stop_reason</span><span class="w"> </span><span class="c1"># =&gt; &quot;stop&quot; or nil</span>
2836
+ </span><span id="__span-7-7"><a id="__codelineno-7-7" name="__codelineno-7-7" href="#__codelineno-7-7"></a><span class="n">result</span><span class="o">.</span><span class="n">created_at</span><span class="w"> </span><span class="c1"># =&gt; Time</span>
2837
+ </span><span id="__span-7-8"><a id="__codelineno-7-8" name="__codelineno-7-8" href="#__codelineno-7-8"></a><span class="n">result</span><span class="o">.</span><span class="n">id</span><span class="w"> </span><span class="c1"># =&gt; UUID string</span>
2838
+ </span><span id="__span-7-9"><a id="__codelineno-7-9" name="__codelineno-7-9" href="#__codelineno-7-9"></a>
2839
+ </span><span id="__span-7-10"><a id="__codelineno-7-10" name="__codelineno-7-10" href="#__codelineno-7-10"></a><span class="c1"># Convenience methods</span>
2840
+ </span><span id="__span-7-11"><a id="__codelineno-7-11" name="__codelineno-7-11" href="#__codelineno-7-11"></a><span class="n">result</span><span class="o">.</span><span class="n">last_text_content</span><span class="w"> </span><span class="c1"># =&gt; &quot;Hi there!&quot; (last text message content)</span>
2841
+ </span><span id="__span-7-12"><a id="__codelineno-7-12" name="__codelineno-7-12" href="#__codelineno-7-12"></a><span class="n">result</span><span class="o">.</span><span class="n">has_tool_calls?</span><span class="w"> </span><span class="c1"># =&gt; false</span>
2842
+ </span><span id="__span-7-13"><a id="__codelineno-7-13" name="__codelineno-7-13" href="#__codelineno-7-13"></a><span class="n">result</span><span class="o">.</span><span class="n">stopped?</span><span class="w"> </span><span class="c1"># =&gt; true</span>
2843
+ </span></code></pre></div>
2844
+ <h2 id="streaming">Streaming<a class="headerlink" href="#streaming" title="Permanent link">&para;</a></h2>
2845
+ <p>Robots support streaming by passing a block to <code>run</code>:</p>
2846
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-8-1"><a id="__codelineno-8-1" name="__codelineno-8-1" href="#__codelineno-8-1"></a><span class="n">result</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">robot</span><span class="o">.</span><span class="n">run</span><span class="p">(</span><span class="s2">&quot;Tell me a story&quot;</span><span class="p">)</span><span class="w"> </span><span class="k">do</span><span class="w"> </span><span class="o">|</span><span class="n">event</span><span class="o">|</span>
2847
+ </span><span id="__span-8-2"><a id="__codelineno-8-2" name="__codelineno-8-2" href="#__codelineno-8-2"></a><span class="w"> </span><span class="nb">print</span><span class="w"> </span><span class="n">event</span><span class="o">.</span><span class="n">text</span><span class="w"> </span><span class="k">if</span><span class="w"> </span><span class="n">event</span><span class="o">.</span><span class="n">respond_to?</span><span class="p">(</span><span class="ss">:text</span><span class="p">)</span>
2848
+ </span><span id="__span-8-3"><a id="__codelineno-8-3" name="__codelineno-8-3" href="#__codelineno-8-3"></a><span class="k">end</span>
2849
+ </span></code></pre></div>
2850
+ <p>The block is forwarded to <code>Agent#ask</code> which passes it to <code>@chat.ask</code>. Streaming events are provider-specific but typically include text deltas.</p>
2851
+ <h2 id="template-resolution">Template Resolution<a class="headerlink" href="#template-resolution" title="Permanent link">&para;</a></h2>
2852
+ <p>When a robot has a <code>template:</code>, it is resolved during initialization:</p>
2853
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-9-1"><a id="__codelineno-9-1" name="__codelineno-9-1" href="#__codelineno-9-1"></a><span class="c1"># 1. Parse the template via prompt_manager</span>
2854
+ </span><span id="__span-9-2"><a id="__codelineno-9-2" name="__codelineno-9-2" href="#__codelineno-9-2"></a><span class="n">parsed</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">PM</span><span class="o">.</span><span class="n">parse</span><span class="p">(</span><span class="vi">@template</span><span class="p">)</span>
2855
+ </span><span id="__span-9-3"><a id="__codelineno-9-3" name="__codelineno-9-3" href="#__codelineno-9-3"></a>
2856
+ </span><span id="__span-9-4"><a id="__codelineno-9-4" name="__codelineno-9-4" href="#__codelineno-9-4"></a><span class="c1"># 2. Extract and apply front matter config</span>
2857
+ </span><span id="__span-9-5"><a id="__codelineno-9-5" name="__codelineno-9-5" href="#__codelineno-9-5"></a><span class="c1"># (model, temperature, top_p, etc.)</span>
2858
+ </span><span id="__span-9-6"><a id="__codelineno-9-6" name="__codelineno-9-6" href="#__codelineno-9-6"></a><span class="n">apply_front_matter_config</span><span class="p">(</span><span class="n">parsed</span><span class="o">.</span><span class="n">metadata</span><span class="p">)</span>
2859
+ </span><span id="__span-9-7"><a id="__codelineno-9-7" name="__codelineno-9-7" href="#__codelineno-9-7"></a>
2860
+ </span><span id="__span-9-8"><a id="__codelineno-9-8" name="__codelineno-9-8" href="#__codelineno-9-8"></a><span class="c1"># 3. Render the template body with context</span>
2861
+ </span><span id="__span-9-9"><a id="__codelineno-9-9" name="__codelineno-9-9" href="#__codelineno-9-9"></a><span class="n">rendered</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">parsed</span><span class="o">.</span><span class="n">to_s</span><span class="p">(</span><span class="o">**</span><span class="n">resolved_context</span><span class="p">)</span>
2862
+ </span><span id="__span-9-10"><a id="__codelineno-9-10" name="__codelineno-9-10" href="#__codelineno-9-10"></a>
2863
+ </span><span id="__span-9-11"><a id="__codelineno-9-11" name="__codelineno-9-11" href="#__codelineno-9-11"></a><span class="c1"># 4. Set as system instructions on @chat</span>
2864
+ </span><span id="__span-9-12"><a id="__codelineno-9-12" name="__codelineno-9-12" href="#__codelineno-9-12"></a><span class="vi">@chat</span><span class="o">.</span><span class="n">with_instructions</span><span class="p">(</span><span class="n">rendered</span><span class="p">)</span>
2865
+ </span></code></pre></div>
2866
+ <h3 id="front-matter-config-keys">Front Matter Config Keys<a class="headerlink" href="#front-matter-config-keys" title="Permanent link">&para;</a></h3>
2867
+ <p>Templates can configure the chat via YAML front matter:</p>
2868
+ <table>
2869
+ <thead>
2870
+ <tr>
2871
+ <th>Key</th>
2872
+ <th>Effect</th>
2873
+ </tr>
2874
+ </thead>
2875
+ <tbody>
2876
+ <tr>
2877
+ <td><code>model</code></td>
2878
+ <td>Sets the LLM model</td>
2879
+ </tr>
2880
+ <tr>
2881
+ <td><code>temperature</code></td>
2882
+ <td>Sets randomness</td>
2883
+ </tr>
2884
+ <tr>
2885
+ <td><code>top_p</code></td>
2886
+ <td>Sets nucleus sampling</td>
2887
+ </tr>
2888
+ <tr>
2889
+ <td><code>top_k</code></td>
2890
+ <td>Sets top-k sampling</td>
2891
+ </tr>
2892
+ <tr>
2893
+ <td><code>max_tokens</code></td>
2894
+ <td>Sets max response tokens</td>
2895
+ </tr>
2896
+ <tr>
2897
+ <td><code>presence_penalty</code></td>
2898
+ <td>Sets presence penalty</td>
2899
+ </tr>
2900
+ <tr>
2901
+ <td><code>frequency_penalty</code></td>
2902
+ <td>Sets frequency penalty</td>
2903
+ </tr>
2904
+ <tr>
2905
+ <td><code>stop</code></td>
2906
+ <td>Sets stop sequences</td>
2907
+ </tr>
2908
+ </tbody>
2909
+ </table>
2910
+ <h2 id="model-selection">Model Selection<a class="headerlink" href="#model-selection" title="Permanent link">&para;</a></h2>
2911
+ <p>The model is determined by:</p>
2912
+ <ol>
2913
+ <li>Robot's explicit <code>model:</code> parameter</li>
2914
+ <li>Front matter <code>model</code> from template</li>
2915
+ <li>Global <code>RobotLab.config.ruby_llm.model</code></li>
2916
+ </ol>
2917
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-10-1"><a id="__codelineno-10-1" name="__codelineno-10-1" href="#__codelineno-10-1"></a><span class="n">robot</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="no">RobotLab</span><span class="o">.</span><span class="n">build</span><span class="p">(</span>
2918
+ </span><span id="__span-10-2"><a id="__codelineno-10-2" name="__codelineno-10-2" href="#__codelineno-10-2"></a><span class="w"> </span><span class="nb">name</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;bot&quot;</span><span class="p">,</span>
2919
+ </span><span id="__span-10-3"><a id="__codelineno-10-3" name="__codelineno-10-3" href="#__codelineno-10-3"></a><span class="w"> </span><span class="ss">model</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;claude-sonnet-4&quot;</span><span class="w"> </span><span class="c1"># Takes precedence</span>
2920
+ </span><span id="__span-10-4"><a id="__codelineno-10-4" name="__codelineno-10-4" href="#__codelineno-10-4"></a><span class="p">)</span>
2921
+ </span><span id="__span-10-5"><a id="__codelineno-10-5" name="__codelineno-10-5" href="#__codelineno-10-5"></a>
2922
+ </span><span id="__span-10-6"><a id="__codelineno-10-6" name="__codelineno-10-6" href="#__codelineno-10-6"></a><span class="c1"># Or configure globally via config files / environment variables</span>
2923
+ </span><span id="__span-10-7"><a id="__codelineno-10-7" name="__codelineno-10-7" href="#__codelineno-10-7"></a><span class="c1"># ROBOT_LAB_RUBY_LLM__MODEL=gpt-4o</span>
2924
+ </span></code></pre></div>
2925
+ <h2 id="simpleflow-integration">SimpleFlow Integration<a class="headerlink" href="#simpleflow-integration" title="Permanent link">&para;</a></h2>
2926
+ <p>When a robot runs inside a network, the <code>call</code> method is invoked by SimpleFlow:</p>
2927
+ <pre class="mermaid"><code>sequenceDiagram
2928
+ participant SF as SimpleFlow
2929
+ participant Task as Task Wrapper
2930
+ participant Robot
2931
+ participant Chat as @chat
2932
+
2933
+ SF-&gt;&gt;Task: call(result)
2934
+ Task-&gt;&gt;Task: deep_merge(run_params, task_context)
2935
+ Task-&gt;&gt;Robot: call(enhanced_result)
2936
+ Robot-&gt;&gt;Robot: extract_run_context(result)
2937
+ Robot-&gt;&gt;Robot: message = context.delete(:message)
2938
+ Robot-&gt;&gt;Robot: run(message, **context)
2939
+ Robot-&gt;&gt;Chat: ask(message)
2940
+ Chat--&gt;&gt;Robot: response
2941
+ Robot--&gt;&gt;SF: result.continue(robot_result)</code></pre>
2942
+ <p>The <code>Task</code> wrapper deep-merges per-task configuration (context, mcp, tools) before delegating to the robot's <code>call</code>. The base <code>Robot#call</code> extracts the message and calls <code>run</code>:</p>
2943
+ <div class="language-ruby highlight"><pre><span></span><code><span id="__span-11-1"><a id="__codelineno-11-1" name="__codelineno-11-1" href="#__codelineno-11-1"></a><span class="k">def</span><span class="w"> </span><span class="nf">call</span><span class="p">(</span><span class="n">result</span><span class="p">)</span>
2944
+ </span><span id="__span-11-2"><a id="__codelineno-11-2" name="__codelineno-11-2" href="#__codelineno-11-2"></a><span class="w"> </span><span class="n">run_context</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">extract_run_context</span><span class="p">(</span><span class="n">result</span><span class="p">)</span>
2945
+ </span><span id="__span-11-3"><a id="__codelineno-11-3" name="__codelineno-11-3" href="#__codelineno-11-3"></a><span class="w"> </span><span class="n">message</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">run_context</span><span class="o">.</span><span class="n">delete</span><span class="p">(</span><span class="ss">:message</span><span class="p">)</span>
2946
+ </span><span id="__span-11-4"><a id="__codelineno-11-4" name="__codelineno-11-4" href="#__codelineno-11-4"></a><span class="w"> </span><span class="n">robot_result</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">run</span><span class="p">(</span><span class="n">message</span><span class="p">,</span><span class="w"> </span><span class="o">**</span><span class="n">run_context</span><span class="p">)</span>
2947
+ </span><span id="__span-11-5"><a id="__codelineno-11-5" name="__codelineno-11-5" href="#__codelineno-11-5"></a>
2948
+ </span><span id="__span-11-6"><a id="__codelineno-11-6" name="__codelineno-11-6" href="#__codelineno-11-6"></a><span class="w"> </span><span class="n">result</span>
2949
+ </span><span id="__span-11-7"><a id="__codelineno-11-7" name="__codelineno-11-7" href="#__codelineno-11-7"></a><span class="w"> </span><span class="o">.</span><span class="n">with_context</span><span class="p">(</span><span class="vi">@name</span><span class="o">.</span><span class="n">to_sym</span><span class="p">,</span><span class="w"> </span><span class="n">robot_result</span><span class="p">)</span>
2950
+ </span><span id="__span-11-8"><a id="__codelineno-11-8" name="__codelineno-11-8" href="#__codelineno-11-8"></a><span class="w"> </span><span class="o">.</span><span class="n">continue</span><span class="p">(</span><span class="n">robot_result</span><span class="p">)</span>
2951
+ </span><span id="__span-11-9"><a id="__codelineno-11-9" name="__codelineno-11-9" href="#__codelineno-11-9"></a><span class="k">end</span>
2952
+ </span></code></pre></div>
2953
+ <h2 id="next-steps">Next Steps<a class="headerlink" href="#next-steps" title="Permanent link">&para;</a></h2>
2954
+ <ul>
2955
+ <li><a href="../network-orchestration/">Network Orchestration</a> - Multi-robot coordination</li>
2956
+ <li><a href="../core-concepts/">Core Concepts</a> - Fundamental building blocks</li>
2957
+ <li><a href="../../guides/using-tools/">Using Tools</a> - Creating and using tools</li>
2958
+ </ul>
2959
+
2960
+
2961
+
2962
+
2963
+
2964
+
2965
+
2966
+
2967
+
2968
+
2969
+
2970
+
2971
+
2972
+ <form class="md-feedback" name="feedback" hidden>
2973
+ <fieldset>
2974
+ <legend class="md-feedback__title">
2975
+ Was this page helpful?
2976
+ </legend>
2977
+ <div class="md-feedback__inner">
2978
+ <div class="md-feedback__list">
2979
+
2980
+ <button class="md-feedback__icon md-icon" type="submit" title="This page was helpful" data-md-value="1">
2981
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 12a8 8 0 0 0-8-8 8 8 0 0 0-8 8 8 8 0 0 0 8 8 8 8 0 0 0 8-8m2 0a10 10 0 0 1-10 10A10 10 0 0 1 2 12 10 10 0 0 1 12 2a10 10 0 0 1 10 10M10 9.5c0 .8-.7 1.5-1.5 1.5S7 10.3 7 9.5 7.7 8 8.5 8s1.5.7 1.5 1.5m7 0c0 .8-.7 1.5-1.5 1.5S14 10.3 14 9.5 14.7 8 15.5 8s1.5.7 1.5 1.5m-5 7.73c-1.75 0-3.29-.73-4.19-1.81L9.23 14c.45.72 1.52 1.23 2.77 1.23s2.32-.51 2.77-1.23l1.42 1.42c-.9 1.08-2.44 1.81-4.19 1.81"/></svg>
2982
+ </button>
2983
+
2984
+ <button class="md-feedback__icon md-icon" type="submit" title="This page could be improved" data-md-value="0">
2985
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 12a8 8 0 0 0-8-8 8 8 0 0 0-8 8 8 8 0 0 0 8 8 8 8 0 0 0 8-8m2 0a10 10 0 0 1-10 10A10 10 0 0 1 2 12 10 10 0 0 1 12 2a10 10 0 0 1 10 10m-6.5-4c.8 0 1.5.7 1.5 1.5s-.7 1.5-1.5 1.5-1.5-.7-1.5-1.5.7-1.5 1.5-1.5M10 9.5c0 .8-.7 1.5-1.5 1.5S7 10.3 7 9.5 7.7 8 8.5 8s1.5.7 1.5 1.5m2 4.5c1.75 0 3.29.72 4.19 1.81l-1.42 1.42C14.32 16.5 13.25 16 12 16s-2.32.5-2.77 1.23l-1.42-1.42C8.71 14.72 10.25 14 12 14"/></svg>
2986
+ </button>
2987
+
2988
+ </div>
2989
+ <div class="md-feedback__note">
2990
+
2991
+ <div data-md-value="1" hidden>
2992
+
2993
+
2994
+
2995
+
2996
+
2997
+
2998
+
2999
+
3000
+
3001
+ Thanks for your feedback!
3002
+ </div>
3003
+
3004
+ <div data-md-value="0" hidden>
3005
+
3006
+
3007
+
3008
+
3009
+
3010
+
3011
+
3012
+
3013
+
3014
+ Thanks for your feedback! Help us improve by creating an issue.
3015
+ </div>
3016
+
3017
+ </div>
3018
+ </div>
3019
+ </fieldset>
3020
+ </form>
3021
+
3022
+
3023
+
3024
+ </article>
3025
+ </div>
3026
+
3027
+
3028
+ <script>var tabs=__md_get("__tabs");if(Array.isArray(tabs))e:for(var set of document.querySelectorAll(".tabbed-set")){var labels=set.querySelector(".tabbed-labels");for(var tab of tabs)for(var label of labels.getElementsByTagName("label"))if(label.innerText.trim()===tab){var input=document.getElementById(label.htmlFor);input.checked=!0;continue e}}</script>
3029
+
3030
+ <script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
3031
+ </div>
3032
+
3033
+ <button type="button" class="md-top md-icon" data-md-component="top" hidden>
3034
+
3035
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M13 20h-2V8l-5.5 5.5-1.42-1.42L12 4.16l7.92 7.92-1.42 1.42L13 8z"/></svg>
3036
+ Back to top
3037
+ </button>
3038
+
3039
+ </main>
3040
+
3041
+ <footer class="md-footer">
3042
+
3043
+
3044
+
3045
+ <nav class="md-footer__inner md-grid" aria-label="Footer" >
3046
+
3047
+
3048
+ <a href="../core-concepts/" class="md-footer__link md-footer__link--prev" aria-label="Previous: Core Concepts">
3049
+ <div class="md-footer__button md-icon">
3050
+
3051
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
3052
+ </div>
3053
+ <div class="md-footer__title">
3054
+ <span class="md-footer__direction">
3055
+ Previous
3056
+ </span>
3057
+ <div class="md-ellipsis">
3058
+ Core Concepts
3059
+ </div>
3060
+ </div>
3061
+ </a>
3062
+
3063
+
3064
+
3065
+ <a href="../network-orchestration/" class="md-footer__link md-footer__link--next" aria-label="Next: Network Orchestration">
3066
+ <div class="md-footer__title">
3067
+ <span class="md-footer__direction">
3068
+ Next
3069
+ </span>
3070
+ <div class="md-ellipsis">
3071
+ Network Orchestration
3072
+ </div>
3073
+ </div>
3074
+ <div class="md-footer__button md-icon">
3075
+
3076
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11z"/></svg>
3077
+ </div>
3078
+ </a>
3079
+
3080
+ </nav>
3081
+
3082
+
3083
+ <div class="md-footer-meta md-typeset">
3084
+ <div class="md-footer-meta__inner md-grid">
3085
+ <div class="md-copyright">
3086
+
3087
+ <div class="md-copyright__highlight">
3088
+ Copyright &copy; 2025 Dewayne VanHoozer
3089
+ </div>
3090
+
3091
+
3092
+ Made with
3093
+ <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
3094
+ Material for MkDocs
3095
+ </a>
3096
+
3097
+ </div>
3098
+
3099
+
3100
+ <div class="md-social">
3101
+
3102
+
3103
+
3104
+
3105
+
3106
+ <a href="https://github.com/madbomber/robot_lab" target="_blank" rel="noopener" title="RobotLab on GitHub" class="md-social__link">
3107
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
3108
+ </a>
3109
+
3110
+
3111
+
3112
+
3113
+
3114
+ <a href="https://rubygems.org/gems/robot_lab" target="_blank" rel="noopener" title="RobotLab on RubyGems" class="md-social__link">
3115
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M116.7 33.8c4.5-6.1 11.7-9.8 19.3-9.8h240c7.6 0 14.8 3.6 19.3 9.8l112 152c6.8 9.2 6.1 21.9-1.5 30.4l-232 256c-4.5 5-11 7.9-17.8 7.9s-13.2-2.9-17.8-7.9l-232-256c-7.7-8.5-8.3-21.2-1.5-30.4zm38.5 39.8c-3.3 2.5-4.2 7-2.1 10.5l57.4 95.7L63.3 192c-4.1.3-7.3 3.8-7.3 8s3.2 7.6 7.3 8l192 16h1.3l192-16c4.1-.3 7.3-3.8 7.3-8s-3.2-7.6-7.3-8l-147.2-12.3 57.4-95.6c2.1-3.5 1.2-8.1-2.1-10.5s-7.9-2-10.7 1l-90 97.6-90.1-97.6c-2.8-3-7.4-3.4-10.7-1"/></svg>
3116
+ </a>
3117
+
3118
+ </div>
3119
+
3120
+ </div>
3121
+ </div>
3122
+ </footer>
3123
+
3124
+ </div>
3125
+ <div class="md-dialog" data-md-component="dialog">
3126
+ <div class="md-dialog__inner md-typeset"></div>
3127
+ </div>
3128
+
3129
+
3130
+
3131
+
3132
+
3133
+ <script id="__config" type="application/json">{"annotate": null, "base": "../..", "features": ["navigation.instant", "navigation.tracking", "navigation.tabs", "navigation.tabs.sticky", "navigation.path", "navigation.indexes", "navigation.top", "navigation.footer", "toc.follow", "search.suggest", "search.highlight", "search.share", "header.autohide", "content.code.copy", "content.code.annotate", "content.tabs.link", "content.tooltips", "content.action.edit", "content.action.view"], "search": "../../assets/javascripts/workers/search.2c215733.min.js", "tags": null, "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}, "version": null}</script>
3134
+
3135
+
3136
+ <script src="../../assets/javascripts/bundle.79ae519e.min.js"></script>
3137
+
3138
+
3139
+ </body>
3140
+ </html>