Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651
  1. {
  2. "id": 5,
  3. "title": "Text To SQL",
  4. "description": "An agent that converts user queries into SQL statements. You must prepare three knowledge bases: 1: DDL for your database; 2: Examples of user queries converted to SQL statements; 3: A comprehensive description of your database, including but not limited to tables and records.",
  5. "canvas_type": "chatbot",
  6. "dsl": {
  7. "answer": [],
  8. "components": {
  9. "Answer:SocialAdsWonder": {
  10. "downstream": [
  11. "Retrieval:TrueCornersJam",
  12. "Retrieval:EasyDryersShop",
  13. "Retrieval:LazyChefsWatch"
  14. ],
  15. "obj": {
  16. "component_name": "Answer",
  17. "inputs": [],
  18. "output": null,
  19. "params": {
  20. "debug_inputs": [],
  21. "inputs": [],
  22. "message_history_window_size": 22,
  23. "output": null,
  24. "output_var_name": "output",
  25. "post_answers": [],
  26. "query": []
  27. }
  28. },
  29. "upstream": [
  30. "begin",
  31. "Generate:CurlyFalconsWorry"
  32. ]
  33. },
  34. "Generate:CurlyFalconsWorry": {
  35. "downstream": [
  36. "Answer:SocialAdsWonder"
  37. ],
  38. "obj": {
  39. "component_name": "Generate",
  40. "inputs": [],
  41. "output": null,
  42. "params": {
  43. "cite": false,
  44. "debug_inputs": [],
  45. "frequency_penalty": 0.7,
  46. "inputs": [],
  47. "llm_id": "deepseek-chat@DeepSeek",
  48. "max_tokens": 0,
  49. "message_history_window_size": 1,
  50. "output": null,
  51. "output_var_name": "output",
  52. "parameters": [],
  53. "presence_penalty": 0.4,
  54. "prompt": "##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.\n\n##You may use the following DDL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:TrueCornersJam}.\n\n##You may use the following documentation as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:LazyChefsWatch}.\n\n##You may use the following SQL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:EasyDryersShop}.\n\n",
  55. "query": [],
  56. "temperature": 0.1,
  57. "top_p": 0.3
  58. }
  59. },
  60. "upstream": [
  61. "Retrieval:LazyChefsWatch",
  62. "Retrieval:EasyDryersShop",
  63. "Retrieval:TrueCornersJam"
  64. ]
  65. },
  66. "Retrieval:EasyDryersShop": {
  67. "downstream": [
  68. "Generate:CurlyFalconsWorry"
  69. ],
  70. "obj": {
  71. "component_name": "Retrieval",
  72. "inputs": [],
  73. "output": null,
  74. "params": {
  75. "debug_inputs": [],
  76. "empty_response": "Nothing found in Q-SQL!",
  77. "inputs": [],
  78. "kb_ids": [],
  79. "keywords_similarity_weight": 0.3,
  80. "message_history_window_size": 22,
  81. "output": null,
  82. "output_var_name": "output",
  83. "query": [],
  84. "rerank_id": "",
  85. "similarity_threshold": 0.2,
  86. "top_k": 1024,
  87. "top_n": 8
  88. }
  89. },
  90. "upstream": [
  91. "Answer:SocialAdsWonder"
  92. ]
  93. },
  94. "Retrieval:LazyChefsWatch": {
  95. "downstream": [
  96. "Generate:CurlyFalconsWorry"
  97. ],
  98. "obj": {
  99. "component_name": "Retrieval",
  100. "inputs": [],
  101. "output": null,
  102. "params": {
  103. "debug_inputs": [],
  104. "empty_response": "Nothing found in DB-Description!",
  105. "inputs": [],
  106. "kb_ids": [],
  107. "keywords_similarity_weight": 0.3,
  108. "message_history_window_size": 22,
  109. "output": null,
  110. "output_var_name": "output",
  111. "query": [],
  112. "rerank_id": "",
  113. "similarity_threshold": 0.2,
  114. "top_k": 1024,
  115. "top_n": 8
  116. }
  117. },
  118. "upstream": [
  119. "Answer:SocialAdsWonder"
  120. ]
  121. },
  122. "Retrieval:TrueCornersJam": {
  123. "downstream": [
  124. "Generate:CurlyFalconsWorry"
  125. ],
  126. "obj": {
  127. "component_name": "Retrieval",
  128. "inputs": [],
  129. "output": null,
  130. "params": {
  131. "debug_inputs": [],
  132. "empty_response": "Nothing found in DDL!",
  133. "inputs": [],
  134. "kb_ids": [],
  135. "keywords_similarity_weight": 0.3,
  136. "message_history_window_size": 22,
  137. "output": null,
  138. "output_var_name": "output",
  139. "query": [],
  140. "rerank_id": "",
  141. "similarity_threshold": 0.02,
  142. "top_k": 1024,
  143. "top_n": 8
  144. }
  145. },
  146. "upstream": [
  147. "Answer:SocialAdsWonder"
  148. ]
  149. },
  150. "begin": {
  151. "downstream": [
  152. "Answer:SocialAdsWonder"
  153. ],
  154. "obj": {
  155. "component_name": "Begin",
  156. "inputs": [],
  157. "output": null,
  158. "params": {
  159. "debug_inputs": [],
  160. "inputs": [],
  161. "message_history_window_size": 22,
  162. "output": null,
  163. "output_var_name": "output",
  164. "prologue": "Hi! I'm your smart assistant. What can I do for you?",
  165. "query": []
  166. }
  167. },
  168. "upstream": []
  169. }
  170. },
  171. "embed_id": "",
  172. "graph": {
  173. "edges": [
  174. {
  175. "id": "reactflow__edge-begin-Answer:SocialAdsWonderc",
  176. "markerEnd": "logo",
  177. "source": "begin",
  178. "sourceHandle": null,
  179. "style": {
  180. "stroke": "rgb(202 197 245)",
  181. "strokeWidth": 2
  182. },
  183. "target": "Answer:SocialAdsWonder",
  184. "targetHandle": "c",
  185. "type": "buttonEdge"
  186. },
  187. {
  188. "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:TrueCornersJamc",
  189. "markerEnd": "logo",
  190. "source": "Answer:SocialAdsWonder",
  191. "sourceHandle": "b",
  192. "style": {
  193. "stroke": "rgb(202 197 245)",
  194. "strokeWidth": 2
  195. },
  196. "target": "Retrieval:TrueCornersJam",
  197. "targetHandle": "c",
  198. "type": "buttonEdge"
  199. },
  200. {
  201. "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:EasyDryersShopc",
  202. "markerEnd": "logo",
  203. "source": "Answer:SocialAdsWonder",
  204. "sourceHandle": "b",
  205. "style": {
  206. "stroke": "rgb(202 197 245)",
  207. "strokeWidth": 2
  208. },
  209. "target": "Retrieval:EasyDryersShop",
  210. "targetHandle": "c",
  211. "type": "buttonEdge"
  212. },
  213. {
  214. "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:LazyChefsWatchc",
  215. "markerEnd": "logo",
  216. "source": "Answer:SocialAdsWonder",
  217. "sourceHandle": "b",
  218. "style": {
  219. "stroke": "rgb(202 197 245)",
  220. "strokeWidth": 2
  221. },
  222. "target": "Retrieval:LazyChefsWatch",
  223. "targetHandle": "c",
  224. "type": "buttonEdge"
  225. },
  226. {
  227. "id": "xy-edge__Retrieval:LazyChefsWatchb-Generate:CurlyFalconsWorryb",
  228. "markerEnd": "logo",
  229. "source": "Retrieval:LazyChefsWatch",
  230. "sourceHandle": "b",
  231. "style": {
  232. "stroke": "rgb(202 197 245)",
  233. "strokeWidth": 2
  234. },
  235. "target": "Generate:CurlyFalconsWorry",
  236. "targetHandle": "b",
  237. "type": "buttonEdge",
  238. "zIndex": 1001
  239. },
  240. {
  241. "id": "xy-edge__Retrieval:EasyDryersShopb-Generate:CurlyFalconsWorryb",
  242. "markerEnd": "logo",
  243. "source": "Retrieval:EasyDryersShop",
  244. "sourceHandle": "b",
  245. "style": {
  246. "stroke": "rgb(202 197 245)",
  247. "strokeWidth": 2
  248. },
  249. "target": "Generate:CurlyFalconsWorry",
  250. "targetHandle": "b",
  251. "type": "buttonEdge",
  252. "zIndex": 1001
  253. },
  254. {
  255. "id": "xy-edge__Retrieval:TrueCornersJamb-Generate:CurlyFalconsWorryb",
  256. "markerEnd": "logo",
  257. "source": "Retrieval:TrueCornersJam",
  258. "sourceHandle": "b",
  259. "style": {
  260. "stroke": "rgb(202 197 245)",
  261. "strokeWidth": 2
  262. },
  263. "target": "Generate:CurlyFalconsWorry",
  264. "targetHandle": "b",
  265. "type": "buttonEdge",
  266. "zIndex": 1001
  267. },
  268. {
  269. "id": "xy-edge__Generate:CurlyFalconsWorryc-Answer:SocialAdsWonderc",
  270. "markerEnd": "logo",
  271. "source": "Generate:CurlyFalconsWorry",
  272. "sourceHandle": "c",
  273. "style": {
  274. "stroke": "rgb(202 197 245)",
  275. "strokeWidth": 2
  276. },
  277. "target": "Answer:SocialAdsWonder",
  278. "targetHandle": "c",
  279. "type": "buttonEdge",
  280. "zIndex": 1001
  281. }
  282. ],
  283. "nodes": [
  284. {
  285. "data": {
  286. "label": "Begin",
  287. "name": "begin"
  288. },
  289. "dragging": false,
  290. "height": 44,
  291. "id": "begin",
  292. "measured": {
  293. "height": 44,
  294. "width": 100
  295. },
  296. "position": {
  297. "x": -520.486587527275,
  298. "y": 117.87988995940702
  299. },
  300. "positionAbsolute": {
  301. "x": -520.486587527275,
  302. "y": 117.87988995940702
  303. },
  304. "selected": false,
  305. "sourcePosition": "left",
  306. "targetPosition": "right",
  307. "type": "beginNode"
  308. },
  309. {
  310. "data": {
  311. "form": {},
  312. "label": "Answer",
  313. "name": "interface"
  314. },
  315. "dragging": false,
  316. "height": 44,
  317. "id": "Answer:SocialAdsWonder",
  318. "measured": {
  319. "height": 44,
  320. "width": 200
  321. },
  322. "position": {
  323. "x": -237.69220760465112,
  324. "y": 119.9282206409824
  325. },
  326. "positionAbsolute": {
  327. "x": -284.9289105495367,
  328. "y": 119.9282206409824
  329. },
  330. "selected": false,
  331. "sourcePosition": "right",
  332. "targetPosition": "left",
  333. "type": "logicNode",
  334. "width": 200
  335. },
  336. {
  337. "data": {
  338. "form": {
  339. "empty_response": "Nothing found in DDL!",
  340. "kb_ids": [],
  341. "keywords_similarity_weight": 0.3,
  342. "similarity_threshold": 0.02,
  343. "top_n": 8
  344. },
  345. "label": "Retrieval",
  346. "name": "DDL"
  347. },
  348. "dragging": false,
  349. "height": 44,
  350. "id": "Retrieval:TrueCornersJam",
  351. "measured": {
  352. "height": 44,
  353. "width": 200
  354. },
  355. "position": {
  356. "x": 119.61927071085717,
  357. "y": -40.184181873335746
  358. },
  359. "positionAbsolute": {
  360. "x": 119.61927071085717,
  361. "y": -40.184181873335746
  362. },
  363. "selected": false,
  364. "sourcePosition": "right",
  365. "targetPosition": "left",
  366. "type": "retrievalNode",
  367. "width": 200
  368. },
  369. {
  370. "data": {
  371. "form": {
  372. "empty_response": "Nothing found in Q-SQL!",
  373. "kb_ids": [],
  374. "keywords_similarity_weight": 0.3,
  375. "similarity_threshold": 0.2,
  376. "top_n": 8
  377. },
  378. "label": "Retrieval",
  379. "name": "Q->SQL"
  380. },
  381. "dragging": false,
  382. "height": 44,
  383. "id": "Retrieval:EasyDryersShop",
  384. "measured": {
  385. "height": 44,
  386. "width": 200
  387. },
  388. "position": {
  389. "x": 80.07777425685605,
  390. "y": 120.03075150115158
  391. },
  392. "positionAbsolute": {
  393. "x": 81.2024576603057,
  394. "y": 94.16303322180948
  395. },
  396. "selected": false,
  397. "sourcePosition": "right",
  398. "targetPosition": "left",
  399. "type": "retrievalNode",
  400. "width": 200
  401. },
  402. {
  403. "data": {
  404. "form": {
  405. "empty_response": "Nothing found in DB-Description!",
  406. "kb_ids": [],
  407. "keywords_similarity_weight": 0.3,
  408. "similarity_threshold": 0.2,
  409. "top_n": 8
  410. },
  411. "label": "Retrieval",
  412. "name": "DB Description"
  413. },
  414. "dragging": false,
  415. "height": 44,
  416. "id": "Retrieval:LazyChefsWatch",
  417. "measured": {
  418. "height": 44,
  419. "width": 200
  420. },
  421. "position": {
  422. "x": 51.228157704293324,
  423. "y": 252.77721891325103
  424. },
  425. "positionAbsolute": {
  426. "x": 51.228157704293324,
  427. "y": 252.77721891325103
  428. },
  429. "selected": false,
  430. "sourcePosition": "right",
  431. "targetPosition": "left",
  432. "type": "retrievalNode",
  433. "width": 200
  434. },
  435. {
  436. "data": {
  437. "form": {
  438. "text": "Receives a sentence that the user wants to convert into SQL and displays the result of the large model's SQL conversion."
  439. },
  440. "label": "Note",
  441. "name": "N: Interface"
  442. },
  443. "dragHandle": ".note-drag-handle",
  444. "dragging": false,
  445. "height": 132,
  446. "id": "Note:GentleRabbitsWonder",
  447. "measured": {
  448. "height": 132,
  449. "width": 324
  450. },
  451. "position": {
  452. "x": -287.3066094433631,
  453. "y": -30.808189185380513
  454. },
  455. "positionAbsolute": {
  456. "x": -287.3066094433631,
  457. "y": -30.808189185380513
  458. },
  459. "resizing": false,
  460. "selected": false,
  461. "sourcePosition": "right",
  462. "style": {
  463. "height": 132,
  464. "width": 324
  465. },
  466. "targetPosition": "left",
  467. "type": "noteNode",
  468. "width": 324
  469. },
  470. {
  471. "data": {
  472. "form": {
  473. "text": "The large model learns which tables may be available based on the responses from three knowledge bases and converts the user's input into SQL statements."
  474. },
  475. "label": "Note",
  476. "name": "N: LLM"
  477. },
  478. "dragHandle": ".note-drag-handle",
  479. "dragging": false,
  480. "height": 163,
  481. "id": "Note:SixCitiesJoke",
  482. "measured": {
  483. "height": 163,
  484. "width": 334
  485. },
  486. "position": {
  487. "x": 19.243366453487255,
  488. "y": 531.9336820600888
  489. },
  490. "positionAbsolute": {
  491. "x": 5.12121582244032,
  492. "y": 637.6539219843564
  493. },
  494. "resizing": false,
  495. "selected": false,
  496. "sourcePosition": "right",
  497. "style": {
  498. "height": 147,
  499. "width": 326
  500. },
  501. "targetPosition": "left",
  502. "type": "noteNode",
  503. "width": 334
  504. },
  505. {
  506. "data": {
  507. "form": {
  508. "text": "Searches for description about meanings of tables and fields."
  509. },
  510. "label": "Note",
  511. "name": "N: DB description"
  512. },
  513. "dragHandle": ".note-drag-handle",
  514. "dragging": false,
  515. "height": 128,
  516. "id": "Note:FamousCarpetsTaste",
  517. "measured": {
  518. "height": 128,
  519. "width": 269
  520. },
  521. "position": {
  522. "x": 399.9267065852242,
  523. "y": 250.0329701879931
  524. },
  525. "positionAbsolute": {
  526. "x": 399.9267065852242,
  527. "y": 250.0329701879931
  528. },
  529. "selected": false,
  530. "sourcePosition": "right",
  531. "targetPosition": "left",
  532. "type": "noteNode",
  533. "width": 269
  534. },
  535. {
  536. "data": {
  537. "form": {
  538. "text": "Searches for samples about question to SQL.\nPlease check this dataset: https://huggingface.co/datasets/InfiniFlow/text2sql"
  539. },
  540. "label": "Note",
  541. "name": "N: Q->SQL"
  542. },
  543. "dragHandle": ".note-drag-handle",
  544. "dragging": false,
  545. "height": 140,
  546. "id": "Note:PoliteBeesArrive",
  547. "measured": {
  548. "height": 140,
  549. "width": 455
  550. },
  551. "position": {
  552. "x": 491.0393427986917,
  553. "y": 96.58232093146341
  554. },
  555. "positionAbsolute": {
  556. "x": 489.0393427986917,
  557. "y": 96.58232093146341
  558. },
  559. "resizing": false,
  560. "selected": false,
  561. "sourcePosition": "right",
  562. "style": {
  563. "height": 130,
  564. "width": 451
  565. },
  566. "targetPosition": "left",
  567. "type": "noteNode",
  568. "width": 455
  569. },
  570. {
  571. "data": {
  572. "form": {
  573. "text": "DDL(Data Definition Language).\n\nSearches for relevant database creation statements.\n\nIt should bind with a KB to which DDL is dumped in.\nYou could use 'General' as parsing method and ';' as delimiter."
  574. },
  575. "label": "Note",
  576. "name": "N: DDL"
  577. },
  578. "dragHandle": ".note-drag-handle",
  579. "dragging": false,
  580. "height": 272,
  581. "id": "Note:SmartWingsDouble",
  582. "measured": {
  583. "height": 272,
  584. "width": 288
  585. },
  586. "position": {
  587. "x": 406.6930553966363,
  588. "y": -208.84980249039137
  589. },
  590. "positionAbsolute": {
  591. "x": 404.1930553966363,
  592. "y": -208.84980249039137
  593. },
  594. "resizing": false,
  595. "selected": false,
  596. "sourcePosition": "right",
  597. "style": {
  598. "height": 258,
  599. "width": 283
  600. },
  601. "targetPosition": "left",
  602. "type": "noteNode",
  603. "width": 288
  604. },
  605. {
  606. "data": {
  607. "form": {
  608. "cite": false,
  609. "frequencyPenaltyEnabled": true,
  610. "frequency_penalty": 0.7,
  611. "llm_id": "deepseek-chat@DeepSeek",
  612. "maxTokensEnabled": false,
  613. "max_tokens": 256,
  614. "message_history_window_size": 1,
  615. "parameter": "Precise",
  616. "parameters": [],
  617. "presencePenaltyEnabled": true,
  618. "presence_penalty": 0.4,
  619. "prompt": "##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.\n\n##You may use the following DDL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:TrueCornersJam}.\n\n##You may use the following documentation as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:LazyChefsWatch}.\n\n##You may use the following SQL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {Retrieval:EasyDryersShop}.\n\n",
  620. "temperature": 0.1,
  621. "temperatureEnabled": true,
  622. "topPEnabled": true,
  623. "top_p": 0.3
  624. },
  625. "label": "Generate",
  626. "name": "GenSQL"
  627. },
  628. "dragging": false,
  629. "id": "Generate:CurlyFalconsWorry",
  630. "measured": {
  631. "height": 106,
  632. "width": 200
  633. },
  634. "position": {
  635. "x": 10.728415797190792,
  636. "y": 410.2569651241076
  637. },
  638. "selected": false,
  639. "sourcePosition": "right",
  640. "targetPosition": "left",
  641. "type": "generateNode"
  642. }
  643. ]
  644. },
  645. "history": [],
  646. "messages": [],
  647. "path": [],
  648. "reference": []
  649. },
  650. "avatar": ""
  651. }