@agentica/core 0.43.3 → 0.44.0-dev.20260313

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 (205) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +218 -218
  3. package/lib/constants/AgenticaSystemPrompt.js +1 -1
  4. package/lib/constants/AgenticaSystemPrompt.js.map +1 -1
  5. package/lib/context/AgenticaOperation.d.ts +3 -2
  6. package/lib/context/internal/AgenticaOperationComposer.js.map +1 -1
  7. package/lib/context/internal/AgenticaTokenUsageAggregator.js.map +1 -1
  8. package/lib/context/internal/__IChatInitialApplication.d.ts +1 -1
  9. package/lib/errors/AgenticaJsonParseError.d.ts +5 -8
  10. package/lib/errors/AgenticaJsonParseError.js +11 -6
  11. package/lib/errors/AgenticaJsonParseError.js.map +1 -1
  12. package/lib/errors/AgenticaValidationError.d.ts +1 -1
  13. package/lib/events/AgenticaExecuteEvent.d.ts +1 -1
  14. package/lib/events/AgenticaJsonParseErrorEvent.d.ts +2 -2
  15. package/lib/factory/events.d.ts +2 -3
  16. package/lib/factory/events.js +1 -2
  17. package/lib/factory/events.js.map +1 -1
  18. package/lib/functional/assertHttpController.d.ts +2 -3
  19. package/lib/functional/assertHttpController.js +3939 -2656
  20. package/lib/functional/assertHttpController.js.map +1 -1
  21. package/lib/functional/assertHttpLlmApplication.d.ts +3 -3
  22. package/lib/functional/assertHttpLlmApplication.js +3939 -2656
  23. package/lib/functional/assertHttpLlmApplication.js.map +1 -1
  24. package/lib/functional/assertMcpController.d.ts +2 -2
  25. package/lib/functional/assertMcpController.js +202 -629
  26. package/lib/functional/assertMcpController.js.map +1 -1
  27. package/lib/functional/createMcpLlmApplication.d.ts +6 -0
  28. package/lib/functional/createMcpLlmApplication.js +56 -0
  29. package/lib/functional/createMcpLlmApplication.js.map +1 -0
  30. package/lib/functional/validateHttpController.d.ts +3 -3
  31. package/lib/functional/validateHttpController.js +3367 -2268
  32. package/lib/functional/validateHttpController.js.map +1 -1
  33. package/lib/functional/validateHttpLlmApplication.d.ts +3 -4
  34. package/lib/functional/validateHttpLlmApplication.js +3367 -2268
  35. package/lib/functional/validateHttpLlmApplication.js.map +1 -1
  36. package/lib/functional/validateMcpController.d.ts +2 -2
  37. package/lib/functional/validateMcpController.js +388 -1161
  38. package/lib/functional/validateMcpController.js.map +1 -1
  39. package/lib/histories/AgenticaExecuteHistory.d.ts +1 -1
  40. package/lib/index.mjs +21256 -18946
  41. package/lib/index.mjs.map +1 -1
  42. package/lib/orchestrate/call.js +43 -56
  43. package/lib/orchestrate/call.js.map +1 -1
  44. package/lib/orchestrate/cancel.js +9 -66
  45. package/lib/orchestrate/cancel.js.map +1 -1
  46. package/lib/orchestrate/initialize.js +4 -947
  47. package/lib/orchestrate/initialize.js.map +1 -1
  48. package/lib/orchestrate/select.js +11 -68
  49. package/lib/orchestrate/select.js.map +1 -1
  50. package/lib/structures/IAgenticaController.d.ts +143 -151
  51. package/lib/structures/IMcpTool.d.ts +52 -0
  52. package/lib/structures/IMcpTool.js +3 -0
  53. package/lib/structures/IMcpTool.js.map +1 -0
  54. package/lib/utils/ChatGptCompletionMessageUtil.js +16 -5
  55. package/lib/utils/ChatGptCompletionMessageUtil.js.map +1 -1
  56. package/lib/utils/ChatGptCompletionMessageUtil.spec.js +0 -5
  57. package/lib/utils/ChatGptCompletionMessageUtil.spec.js.map +1 -1
  58. package/package.json +7 -9
  59. package/prompts/cancel.md +5 -5
  60. package/prompts/common.md +3 -3
  61. package/prompts/describe.md +7 -7
  62. package/prompts/execute.md +122 -122
  63. package/prompts/initialize.md +3 -3
  64. package/prompts/json_parse_error.md +35 -33
  65. package/prompts/select.md +7 -7
  66. package/prompts/validate.md +123 -123
  67. package/prompts/validate_repeated.md +31 -31
  68. package/src/Agentica.ts +367 -367
  69. package/src/MicroAgentica.ts +357 -357
  70. package/src/constants/AgenticaConstant.ts +4 -4
  71. package/src/constants/AgenticaDefaultPrompt.ts +44 -44
  72. package/src/constants/AgenticaSystemPrompt.ts +1 -1
  73. package/src/constants/index.ts +2 -2
  74. package/src/context/AgenticaContext.ts +136 -136
  75. package/src/context/AgenticaContextRequestResult.ts +14 -14
  76. package/src/context/AgenticaOperation.ts +73 -72
  77. package/src/context/AgenticaOperationCollection.ts +49 -49
  78. package/src/context/AgenticaOperationSelection.ts +9 -9
  79. package/src/context/AgenticaTokenUsage.ts +186 -186
  80. package/src/context/MicroAgenticaContext.ts +99 -99
  81. package/src/context/index.ts +5 -5
  82. package/src/context/internal/AgenticaOperationComposer.ts +177 -177
  83. package/src/context/internal/AgenticaTokenUsageAggregator.ts +66 -66
  84. package/src/context/internal/__IChatCancelFunctionsApplication.ts +23 -23
  85. package/src/context/internal/__IChatFunctionReference.ts +21 -21
  86. package/src/context/internal/__IChatInitialApplication.ts +15 -15
  87. package/src/context/internal/__IChatSelectFunctionsApplication.ts +24 -24
  88. package/src/context/internal/isAgenticaContext.ts +11 -11
  89. package/src/errors/AgenticaJsonParseError.ts +52 -47
  90. package/src/errors/AgenticaValidationError.ts +49 -49
  91. package/src/errors/index.ts +2 -2
  92. package/src/events/AgenticaAssistantMessageEvent.ts +12 -12
  93. package/src/events/AgenticaCallEvent.ts +27 -27
  94. package/src/events/AgenticaCancelEvent.ts +9 -9
  95. package/src/events/AgenticaDescribeEvent.ts +14 -14
  96. package/src/events/AgenticaEvent.ts +59 -59
  97. package/src/events/AgenticaEvent.type.ts +19 -19
  98. package/src/events/AgenticaEventBase.ts +18 -18
  99. package/src/events/AgenticaEventSource.ts +6 -6
  100. package/src/events/AgenticaExecuteEvent.ts +45 -45
  101. package/src/events/AgenticaInitializeEvent.ts +7 -7
  102. package/src/events/AgenticaJsonParseErrorEvent.ts +16 -15
  103. package/src/events/AgenticaRequestEvent.ts +27 -27
  104. package/src/events/AgenticaResponseEvent.ts +32 -32
  105. package/src/events/AgenticaSelectEvent.ts +11 -11
  106. package/src/events/AgenticaUserMessageEvent.ts +12 -12
  107. package/src/events/AgenticaValidateEvent.ts +32 -32
  108. package/src/events/MicroAgenticaEvent.ts +45 -45
  109. package/src/events/index.ts +15 -15
  110. package/src/factory/events.ts +357 -359
  111. package/src/factory/histories.ts +348 -348
  112. package/src/factory/index.ts +3 -3
  113. package/src/factory/operations.ts +16 -16
  114. package/src/functional/assertHttpController.ts +106 -104
  115. package/src/functional/assertHttpLlmApplication.ts +52 -57
  116. package/src/functional/assertMcpController.ts +47 -44
  117. package/src/functional/createMcpLlmApplication.ts +72 -0
  118. package/src/functional/index.ts +7 -7
  119. package/src/functional/validateHttpController.ts +113 -110
  120. package/src/functional/validateHttpLlmApplication.ts +65 -70
  121. package/src/functional/validateMcpController.ts +53 -50
  122. package/src/histories/AgenticaAssistantMessageHistory.ts +10 -10
  123. package/src/histories/AgenticaCancelHistory.ts +8 -8
  124. package/src/histories/AgenticaDescribeHistory.ts +18 -18
  125. package/src/histories/AgenticaExecuteHistory.ts +64 -64
  126. package/src/histories/AgenticaHistory.ts +28 -28
  127. package/src/histories/AgenticaHistoryBase.ts +35 -35
  128. package/src/histories/AgenticaSelectHistory.ts +8 -8
  129. package/src/histories/AgenticaSystemMessageHistory.ts +10 -10
  130. package/src/histories/AgenticaUserMessageHistory.ts +11 -11
  131. package/src/histories/MicroAgenticaHistory.ts +19 -19
  132. package/src/histories/contents/AgenticaUserMessageAudioContent.ts +21 -21
  133. package/src/histories/contents/AgenticaUserMessageContent.ts +19 -19
  134. package/src/histories/contents/AgenticaUserMessageContentBase.ts +6 -6
  135. package/src/histories/contents/AgenticaUserMessageFileContent.ts +25 -25
  136. package/src/histories/contents/AgenticaUserMessageImageContent.ts +33 -33
  137. package/src/histories/contents/AgenticaUserMessageTextContent.ts +15 -15
  138. package/src/histories/contents/index.ts +5 -5
  139. package/src/histories/index.ts +10 -10
  140. package/src/index.ts +15 -15
  141. package/src/json/IAgenticaEventJson.ts +265 -265
  142. package/src/json/IAgenticaEventJson.type.ts +19 -19
  143. package/src/json/IAgenticaHistoryJson.ts +165 -165
  144. package/src/json/IAgenticaHistoryJson.type.ts +19 -19
  145. package/src/json/IAgenticaOperationJson.ts +36 -36
  146. package/src/json/IAgenticaOperationSelectionJson.ts +26 -26
  147. package/src/json/IAgenticaTokenUsageJson.ts +107 -107
  148. package/src/json/IMicroAgenticaEventJson.ts +22 -22
  149. package/src/json/IMicroAgenticaHistoryJson.ts +25 -25
  150. package/src/json/index.ts +7 -7
  151. package/src/orchestrate/call.ts +542 -558
  152. package/src/orchestrate/cancel.ts +265 -269
  153. package/src/orchestrate/describe.ts +66 -66
  154. package/src/orchestrate/execute.ts +61 -61
  155. package/src/orchestrate/index.ts +6 -6
  156. package/src/orchestrate/initialize.ts +102 -102
  157. package/src/orchestrate/internal/cancelFunctionFromContext.ts +33 -33
  158. package/src/orchestrate/internal/selectFunctionFromContext.ts +34 -34
  159. package/src/orchestrate/select.ts +320 -322
  160. package/src/structures/IAgenticaConfig.ts +83 -83
  161. package/src/structures/IAgenticaConfigBase.ts +87 -87
  162. package/src/structures/IAgenticaController.ts +143 -151
  163. package/src/structures/IAgenticaExecutor.ts +167 -167
  164. package/src/structures/IAgenticaProps.ts +78 -78
  165. package/src/structures/IAgenticaSystemPrompt.ts +236 -236
  166. package/src/structures/IAgenticaVendor.ts +54 -54
  167. package/src/structures/IMcpTool.ts +60 -0
  168. package/src/structures/IMicroAgenticaConfig.ts +56 -56
  169. package/src/structures/IMicroAgenticaExecutor.ts +67 -67
  170. package/src/structures/IMicroAgenticaProps.ts +77 -77
  171. package/src/structures/IMicroAgenticaSystemPrompt.ts +169 -169
  172. package/src/structures/index.ts +10 -10
  173. package/src/transformers/transformHistory.ts +172 -172
  174. package/src/utils/AssistantMessageEmptyError.ts +20 -20
  175. package/src/utils/AsyncQueue.spec.ts +355 -355
  176. package/src/utils/AsyncQueue.ts +95 -95
  177. package/src/utils/ByteArrayUtil.ts +5 -5
  178. package/src/utils/ChatGptCompletionMessageUtil.spec.ts +314 -320
  179. package/src/utils/ChatGptCompletionMessageUtil.ts +210 -195
  180. package/src/utils/ChatGptCompletionStreamingUtil.spec.ts +909 -909
  181. package/src/utils/ChatGptCompletionStreamingUtil.ts +91 -91
  182. package/src/utils/ChatGptTokenUsageAggregator.spec.ts +226 -226
  183. package/src/utils/ChatGptTokenUsageAggregator.ts +57 -57
  184. package/src/utils/MPSC.spec.ts +276 -276
  185. package/src/utils/MPSC.ts +42 -42
  186. package/src/utils/Singleton.spec.ts +138 -138
  187. package/src/utils/Singleton.ts +42 -42
  188. package/src/utils/StreamUtil.spec.ts +512 -512
  189. package/src/utils/StreamUtil.ts +87 -87
  190. package/src/utils/__map_take.spec.ts +140 -140
  191. package/src/utils/__map_take.ts +13 -13
  192. package/src/utils/__retry.spec.ts +198 -198
  193. package/src/utils/__retry.ts +18 -18
  194. package/src/utils/assertExecuteFailure.ts +16 -16
  195. package/src/utils/index.ts +4 -4
  196. package/src/utils/request.ts +140 -140
  197. package/src/utils/types.ts +50 -50
  198. package/lib/context/internal/AgenticaOperationComposer.spec.d.ts +0 -1
  199. package/lib/context/internal/AgenticaOperationComposer.spec.js +0 -353
  200. package/lib/context/internal/AgenticaOperationComposer.spec.js.map +0 -1
  201. package/lib/utils/JsonUtil.d.ts +0 -8
  202. package/lib/utils/JsonUtil.js +0 -349
  203. package/lib/utils/JsonUtil.js.map +0 -1
  204. package/src/context/internal/AgenticaOperationComposer.spec.ts +0 -401
  205. package/src/utils/JsonUtil.ts +0 -460
@@ -1,49 +1,49 @@
1
- import type { AgenticaOperation } from "./AgenticaOperation";
2
-
3
- /**
4
- * Collection of operations used in the Agentica Agent.
5
- *
6
- * `IAgenticaOperationCollection` is an interface type representing
7
- * a collection of operations for several purposes used in the
8
- * {@link Agentica} internally.
9
- *
10
- * @author Samchon
11
- */
12
- export interface AgenticaOperationCollection {
13
- /**
14
- * List of every operations.
15
- */
16
- array: AgenticaOperation[];
17
- /**
18
- * Divided operations.
19
- *
20
- * If you've configured the {@link IAgenticaConfig.capacity} property,
21
- * the A.I. chatbot ({@link Agentica}) will separate the operations
22
- * into the several groups to divide and conquer and LLM function selecting
23
- * for accuracy.
24
- *
25
- * In that case, this property `divided`'s length would be dtermined by
26
- * dividing the number of operations ({@link array}'s length) by the
27
- * {@link IAgenticaConfig.capacity}.
28
- *
29
- * Otherwise, if the {@link IAgenticaConfig.capacity} has not been
30
- * configured, this `divided` property would be the `undefined` value.
31
- */
32
- divided?: AgenticaOperation[][] | undefined;
33
-
34
- /**
35
- * Flat dictionary of operations.
36
- *
37
- * Dictionary of operations with their {@link IAgenticaOperation.name}.
38
- */
39
- flat: Map<string, AgenticaOperation>;
40
-
41
- /**
42
- * Group dictionary of operations.
43
- *
44
- * Dictionary of operations with their
45
- * {@link IAgenticaOperation.controller.name} and
46
- * {@link IAgenticaOperation.function.name}.
47
- */
48
- group: Map<string, Map<string, AgenticaOperation>>;
49
- }
1
+ import type { AgenticaOperation } from "./AgenticaOperation";
2
+
3
+ /**
4
+ * Collection of operations used in the Agentica Agent.
5
+ *
6
+ * `IAgenticaOperationCollection` is an interface type representing
7
+ * a collection of operations for several purposes used in the
8
+ * {@link Agentica} internally.
9
+ *
10
+ * @author Samchon
11
+ */
12
+ export interface AgenticaOperationCollection {
13
+ /**
14
+ * List of every operations.
15
+ */
16
+ array: AgenticaOperation[];
17
+ /**
18
+ * Divided operations.
19
+ *
20
+ * If you've configured the {@link IAgenticaConfig.capacity} property,
21
+ * the A.I. chatbot ({@link Agentica}) will separate the operations
22
+ * into the several groups to divide and conquer and LLM function selecting
23
+ * for accuracy.
24
+ *
25
+ * In that case, this property `divided`'s length would be dtermined by
26
+ * dividing the number of operations ({@link array}'s length) by the
27
+ * {@link IAgenticaConfig.capacity}.
28
+ *
29
+ * Otherwise, if the {@link IAgenticaConfig.capacity} has not been
30
+ * configured, this `divided` property would be the `undefined` value.
31
+ */
32
+ divided?: AgenticaOperation[][] | undefined;
33
+
34
+ /**
35
+ * Flat dictionary of operations.
36
+ *
37
+ * Dictionary of operations with their {@link IAgenticaOperation.name}.
38
+ */
39
+ flat: Map<string, AgenticaOperation>;
40
+
41
+ /**
42
+ * Group dictionary of operations.
43
+ *
44
+ * Dictionary of operations with their
45
+ * {@link IAgenticaOperation.controller.name} and
46
+ * {@link IAgenticaOperation.function.name}.
47
+ */
48
+ group: Map<string, Map<string, AgenticaOperation>>;
49
+ }
@@ -1,9 +1,9 @@
1
- import type { IAgenticaOperationSelectionJson } from "../json/IAgenticaOperationSelectionJson";
2
-
3
- import type { AgenticaOperation } from "./AgenticaOperation";
4
-
5
- export interface AgenticaOperationSelection {
6
- operation: AgenticaOperation;
7
- reason: string;
8
- toJSON: () => IAgenticaOperationSelectionJson;
9
- }
1
+ import type { IAgenticaOperationSelectionJson } from "../json/IAgenticaOperationSelectionJson";
2
+
3
+ import type { AgenticaOperation } from "./AgenticaOperation";
4
+
5
+ export interface AgenticaOperationSelection {
6
+ operation: AgenticaOperation;
7
+ reason: string;
8
+ toJSON: () => IAgenticaOperationSelectionJson;
9
+ }
@@ -1,186 +1,186 @@
1
- import type { CompletionUsage } from "openai/resources";
2
-
3
- import typia from "typia";
4
-
5
- import type { IAgenticaTokenUsageJson } from "../json/IAgenticaTokenUsageJson";
6
-
7
- import { AgenticaTokenUsageAggregator } from "./internal/AgenticaTokenUsageAggregator";
8
-
9
- export class AgenticaTokenUsage implements IAgenticaTokenUsageJson {
10
- /**
11
- * Aggregated token usage.
12
- */
13
- public readonly aggregate: AgenticaTokenUsage.IComponent;
14
-
15
- /**
16
- * Token uasge of initializer agent.
17
- */
18
- public readonly initialize: AgenticaTokenUsage.IComponent;
19
-
20
- /**
21
- * Token usage of function selector agent.
22
- */
23
- public readonly select: AgenticaTokenUsage.IComponent;
24
-
25
- /**
26
- * Token usage of function canceler agent.
27
- */
28
- public readonly cancel: AgenticaTokenUsage.IComponent;
29
-
30
- /**
31
- * Token usage of function caller agent.
32
- */
33
- public readonly call: AgenticaTokenUsage.IComponent;
34
-
35
- /**
36
- * Token usage of function calling describer agent.
37
- */
38
- public readonly describe: AgenticaTokenUsage.IComponent;
39
-
40
- public constructor(props?: IAgenticaTokenUsageJson) {
41
- if (props === undefined) {
42
- const zero = AgenticaTokenUsage.zero();
43
- this.aggregate = zero.aggregate;
44
- this.initialize = zero.initialize;
45
- this.select = zero.select;
46
- this.cancel = zero.cancel;
47
- this.call = zero.call;
48
- this.describe = zero.describe;
49
- }
50
- else {
51
- this.aggregate = props.aggregate;
52
- this.initialize = props.initialize;
53
- this.select = props.select;
54
- this.cancel = props.cancel;
55
- this.call = props.call;
56
- this.describe = props.describe;
57
- }
58
- }
59
-
60
- public increment(y: IAgenticaTokenUsageJson): void {
61
- const increment = (
62
- x: IAgenticaTokenUsageJson.IComponent,
63
- y: IAgenticaTokenUsageJson.IComponent,
64
- ): void => {
65
- x.total += y.total;
66
- x.input.total += y.input.total;
67
- x.input.cached += y.input.cached;
68
- x.output.total += y.output.total;
69
- x.output.reasoning += y.output.reasoning;
70
- x.output.accepted_prediction += y.output.accepted_prediction;
71
- x.output.rejected_prediction += y.output.rejected_prediction;
72
- };
73
- increment(this.aggregate, y.aggregate);
74
- increment(this.initialize, y.initialize);
75
- increment(this.select, y.select);
76
- increment(this.cancel, y.cancel);
77
- increment(this.call, y.call);
78
- increment(this.describe, y.describe);
79
- }
80
-
81
- public use(
82
- kind: Exclude<keyof IAgenticaTokenUsageJson, "aggregate">,
83
- completionUsage: CompletionUsage,
84
- ): void {
85
- AgenticaTokenUsageAggregator.aggregate({
86
- kind,
87
- completionUsage,
88
- usage: this,
89
- });
90
- }
91
-
92
- public toJSON(): IAgenticaTokenUsageJson {
93
- return typia.misc.clone<IAgenticaTokenUsageJson>(this);
94
- }
95
-
96
- public static zero(): AgenticaTokenUsage {
97
- const component = (): IAgenticaTokenUsageJson.IComponent => ({
98
- total: 0,
99
- input: {
100
- total: 0,
101
- cached: 0,
102
- },
103
- output: {
104
- total: 0,
105
- reasoning: 0,
106
- accepted_prediction: 0,
107
- rejected_prediction: 0,
108
- },
109
- });
110
- return new AgenticaTokenUsage({
111
- aggregate: component(),
112
- initialize: component(),
113
- select: component(),
114
- cancel: component(),
115
- call: component(),
116
- describe: component(),
117
- });
118
- }
119
-
120
- public static plus(
121
- x: AgenticaTokenUsage,
122
- y: AgenticaTokenUsage,
123
- ): AgenticaTokenUsage {
124
- const z: AgenticaTokenUsage = new AgenticaTokenUsage(x.toJSON());
125
- z.increment(y.toJSON());
126
- return z;
127
- }
128
- }
129
- export namespace AgenticaTokenUsage {
130
- export interface IComponent {
131
- /**
132
- * Total token usage.
133
- */
134
- total: number;
135
-
136
- /**
137
- * Input token usage of detailed.
138
- */
139
- input: IInput;
140
-
141
- /**
142
- * Output token usage of detailed.
143
- */
144
- output: IOutput;
145
- }
146
-
147
- /**
148
- * Input token usage of detailed.
149
- */
150
- export interface IInput {
151
- /**
152
- * Total amount of input token uasge.
153
- */
154
- total: number;
155
-
156
- /**
157
- * Cached token usage.
158
- */
159
- cached: number;
160
- }
161
-
162
- /**
163
- * Output token usage of detailed.
164
- */
165
- export interface IOutput {
166
- /**
167
- * Total amount of output token usage.
168
- */
169
- total: number;
170
-
171
- /**
172
- * Reasoning token usage.
173
- */
174
- reasoning: number;
175
-
176
- /**
177
- * Prediction token usage.
178
- */
179
- accepted_prediction: number;
180
-
181
- /**
182
- * Rejected prediction token usage.
183
- */
184
- rejected_prediction: number;
185
- }
186
- }
1
+ import type { CompletionUsage } from "openai/resources";
2
+
3
+ import typia from "typia";
4
+
5
+ import type { IAgenticaTokenUsageJson } from "../json/IAgenticaTokenUsageJson";
6
+
7
+ import { AgenticaTokenUsageAggregator } from "./internal/AgenticaTokenUsageAggregator";
8
+
9
+ export class AgenticaTokenUsage implements IAgenticaTokenUsageJson {
10
+ /**
11
+ * Aggregated token usage.
12
+ */
13
+ public readonly aggregate: AgenticaTokenUsage.IComponent;
14
+
15
+ /**
16
+ * Token uasge of initializer agent.
17
+ */
18
+ public readonly initialize: AgenticaTokenUsage.IComponent;
19
+
20
+ /**
21
+ * Token usage of function selector agent.
22
+ */
23
+ public readonly select: AgenticaTokenUsage.IComponent;
24
+
25
+ /**
26
+ * Token usage of function canceler agent.
27
+ */
28
+ public readonly cancel: AgenticaTokenUsage.IComponent;
29
+
30
+ /**
31
+ * Token usage of function caller agent.
32
+ */
33
+ public readonly call: AgenticaTokenUsage.IComponent;
34
+
35
+ /**
36
+ * Token usage of function calling describer agent.
37
+ */
38
+ public readonly describe: AgenticaTokenUsage.IComponent;
39
+
40
+ public constructor(props?: IAgenticaTokenUsageJson) {
41
+ if (props === undefined) {
42
+ const zero = AgenticaTokenUsage.zero();
43
+ this.aggregate = zero.aggregate;
44
+ this.initialize = zero.initialize;
45
+ this.select = zero.select;
46
+ this.cancel = zero.cancel;
47
+ this.call = zero.call;
48
+ this.describe = zero.describe;
49
+ }
50
+ else {
51
+ this.aggregate = props.aggregate;
52
+ this.initialize = props.initialize;
53
+ this.select = props.select;
54
+ this.cancel = props.cancel;
55
+ this.call = props.call;
56
+ this.describe = props.describe;
57
+ }
58
+ }
59
+
60
+ public increment(y: IAgenticaTokenUsageJson): void {
61
+ const increment = (
62
+ x: IAgenticaTokenUsageJson.IComponent,
63
+ y: IAgenticaTokenUsageJson.IComponent,
64
+ ): void => {
65
+ x.total += y.total;
66
+ x.input.total += y.input.total;
67
+ x.input.cached += y.input.cached;
68
+ x.output.total += y.output.total;
69
+ x.output.reasoning += y.output.reasoning;
70
+ x.output.accepted_prediction += y.output.accepted_prediction;
71
+ x.output.rejected_prediction += y.output.rejected_prediction;
72
+ };
73
+ increment(this.aggregate, y.aggregate);
74
+ increment(this.initialize, y.initialize);
75
+ increment(this.select, y.select);
76
+ increment(this.cancel, y.cancel);
77
+ increment(this.call, y.call);
78
+ increment(this.describe, y.describe);
79
+ }
80
+
81
+ public use(
82
+ kind: Exclude<keyof IAgenticaTokenUsageJson, "aggregate">,
83
+ completionUsage: CompletionUsage,
84
+ ): void {
85
+ AgenticaTokenUsageAggregator.aggregate({
86
+ kind,
87
+ completionUsage,
88
+ usage: this,
89
+ });
90
+ }
91
+
92
+ public toJSON(): IAgenticaTokenUsageJson {
93
+ return typia.misc.clone<IAgenticaTokenUsageJson>(this);
94
+ }
95
+
96
+ public static zero(): AgenticaTokenUsage {
97
+ const component = (): IAgenticaTokenUsageJson.IComponent => ({
98
+ total: 0,
99
+ input: {
100
+ total: 0,
101
+ cached: 0,
102
+ },
103
+ output: {
104
+ total: 0,
105
+ reasoning: 0,
106
+ accepted_prediction: 0,
107
+ rejected_prediction: 0,
108
+ },
109
+ });
110
+ return new AgenticaTokenUsage({
111
+ aggregate: component(),
112
+ initialize: component(),
113
+ select: component(),
114
+ cancel: component(),
115
+ call: component(),
116
+ describe: component(),
117
+ });
118
+ }
119
+
120
+ public static plus(
121
+ x: AgenticaTokenUsage,
122
+ y: AgenticaTokenUsage,
123
+ ): AgenticaTokenUsage {
124
+ const z: AgenticaTokenUsage = new AgenticaTokenUsage(x.toJSON());
125
+ z.increment(y.toJSON());
126
+ return z;
127
+ }
128
+ }
129
+ export namespace AgenticaTokenUsage {
130
+ export interface IComponent {
131
+ /**
132
+ * Total token usage.
133
+ */
134
+ total: number;
135
+
136
+ /**
137
+ * Input token usage of detailed.
138
+ */
139
+ input: IInput;
140
+
141
+ /**
142
+ * Output token usage of detailed.
143
+ */
144
+ output: IOutput;
145
+ }
146
+
147
+ /**
148
+ * Input token usage of detailed.
149
+ */
150
+ export interface IInput {
151
+ /**
152
+ * Total amount of input token uasge.
153
+ */
154
+ total: number;
155
+
156
+ /**
157
+ * Cached token usage.
158
+ */
159
+ cached: number;
160
+ }
161
+
162
+ /**
163
+ * Output token usage of detailed.
164
+ */
165
+ export interface IOutput {
166
+ /**
167
+ * Total amount of output token usage.
168
+ */
169
+ total: number;
170
+
171
+ /**
172
+ * Reasoning token usage.
173
+ */
174
+ reasoning: number;
175
+
176
+ /**
177
+ * Prediction token usage.
178
+ */
179
+ accepted_prediction: number;
180
+
181
+ /**
182
+ * Rejected prediction token usage.
183
+ */
184
+ rejected_prediction: number;
185
+ }
186
+ }