notdiamond 2.0.0-rc1 → 2.0.0-rc10

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 (137) hide show
  1. package/CHANGELOG.md +89 -0
  2. package/README.md +299 -97
  3. package/client.d.mts +19 -33
  4. package/client.d.mts.map +1 -1
  5. package/client.d.ts +19 -33
  6. package/client.d.ts.map +1 -1
  7. package/client.js +19 -35
  8. package/client.js.map +1 -1
  9. package/client.mjs +19 -35
  10. package/client.mjs.map +1 -1
  11. package/internal/tslib.js +17 -17
  12. package/internal/utils/env.d.mts.map +1 -1
  13. package/internal/utils/env.d.ts.map +1 -1
  14. package/internal/utils/env.js +4 -2
  15. package/internal/utils/env.js.map +1 -1
  16. package/internal/utils/env.mjs +4 -2
  17. package/internal/utils/env.mjs.map +1 -1
  18. package/package.json +10 -11
  19. package/resources/custom-router.d.mts +145 -0
  20. package/resources/custom-router.d.mts.map +1 -0
  21. package/resources/custom-router.d.ts +145 -0
  22. package/resources/custom-router.d.ts.map +1 -0
  23. package/resources/custom-router.js +83 -0
  24. package/resources/custom-router.js.map +1 -0
  25. package/resources/custom-router.mjs +79 -0
  26. package/resources/custom-router.mjs.map +1 -0
  27. package/resources/index.d.mts +6 -6
  28. package/resources/index.d.mts.map +1 -1
  29. package/resources/index.d.ts +6 -6
  30. package/resources/index.d.ts.map +1 -1
  31. package/resources/index.js +6 -6
  32. package/resources/index.js.map +1 -1
  33. package/resources/index.mjs +3 -3
  34. package/resources/index.mjs.map +1 -1
  35. package/resources/model-router.d.mts +196 -0
  36. package/resources/model-router.d.mts.map +1 -0
  37. package/resources/model-router.d.ts +196 -0
  38. package/resources/model-router.d.ts.map +1 -0
  39. package/resources/model-router.js +70 -0
  40. package/resources/model-router.js.map +1 -0
  41. package/resources/model-router.mjs +66 -0
  42. package/resources/model-router.mjs.map +1 -0
  43. package/resources/models.d.mts +50 -25
  44. package/resources/models.d.mts.map +1 -1
  45. package/resources/models.d.ts +50 -25
  46. package/resources/models.d.ts.map +1 -1
  47. package/resources/models.js +5 -0
  48. package/resources/models.js.map +1 -1
  49. package/resources/models.mjs +5 -0
  50. package/resources/models.mjs.map +1 -1
  51. package/resources/preferences.d.mts +34 -48
  52. package/resources/preferences.d.mts.map +1 -1
  53. package/resources/preferences.d.ts +34 -48
  54. package/resources/preferences.d.ts.map +1 -1
  55. package/resources/preferences.js +14 -36
  56. package/resources/preferences.js.map +1 -1
  57. package/resources/preferences.mjs +14 -36
  58. package/resources/preferences.mjs.map +1 -1
  59. package/resources/prompt-adaptation.d.mts +339 -234
  60. package/resources/prompt-adaptation.d.mts.map +1 -1
  61. package/resources/prompt-adaptation.d.ts +339 -234
  62. package/resources/prompt-adaptation.d.ts.map +1 -1
  63. package/resources/prompt-adaptation.js +30 -53
  64. package/resources/prompt-adaptation.js.map +1 -1
  65. package/resources/prompt-adaptation.mjs +30 -53
  66. package/resources/prompt-adaptation.mjs.map +1 -1
  67. package/resources/report/index.d.mts +3 -0
  68. package/resources/report/index.d.mts.map +1 -0
  69. package/resources/report/index.d.ts +3 -0
  70. package/resources/report/index.d.ts.map +1 -0
  71. package/resources/report/index.js +9 -0
  72. package/resources/report/index.js.map +1 -0
  73. package/resources/report/index.mjs +4 -0
  74. package/resources/report/index.mjs.map +1 -0
  75. package/resources/report/metrics.d.mts +87 -0
  76. package/resources/report/metrics.d.mts.map +1 -0
  77. package/resources/report/metrics.d.ts +87 -0
  78. package/resources/report/metrics.d.ts.map +1 -0
  79. package/resources/report/metrics.js +57 -0
  80. package/resources/report/metrics.js.map +1 -0
  81. package/resources/report/metrics.mjs +53 -0
  82. package/resources/report/metrics.mjs.map +1 -0
  83. package/resources/report/report.d.mts +10 -0
  84. package/resources/report/report.d.mts.map +1 -0
  85. package/resources/report/report.d.ts +10 -0
  86. package/resources/report/report.d.ts.map +1 -0
  87. package/resources/report/report.js +17 -0
  88. package/resources/report/report.js.map +1 -0
  89. package/resources/report/report.mjs +12 -0
  90. package/resources/report/report.mjs.map +1 -0
  91. package/resources/report.d.mts +1 -244
  92. package/resources/report.d.mts.map +1 -1
  93. package/resources/report.d.ts +1 -244
  94. package/resources/report.d.ts.map +1 -1
  95. package/resources/report.js +2 -82
  96. package/resources/report.js.map +1 -1
  97. package/resources/report.mjs +1 -80
  98. package/resources/report.mjs.map +1 -1
  99. package/src/client.ts +65 -116
  100. package/src/internal/utils/env.ts +4 -2
  101. package/src/resources/custom-router.ts +168 -0
  102. package/src/resources/index.ts +23 -34
  103. package/src/resources/model-router.ts +224 -0
  104. package/src/resources/models.ts +55 -32
  105. package/src/resources/preferences.ts +40 -77
  106. package/src/resources/prompt-adaptation.ts +361 -291
  107. package/src/resources/report/index.ts +4 -0
  108. package/src/resources/report/metrics.ts +99 -0
  109. package/src/resources/report/report.ts +19 -0
  110. package/src/resources/report.ts +1 -298
  111. package/src/version.ts +1 -1
  112. package/version.d.mts +1 -1
  113. package/version.d.mts.map +1 -1
  114. package/version.d.ts +1 -1
  115. package/version.d.ts.map +1 -1
  116. package/version.js +1 -1
  117. package/version.js.map +1 -1
  118. package/version.mjs +1 -1
  119. package/version.mjs.map +1 -1
  120. package/resources/admin.d.mts +0 -4
  121. package/resources/admin.d.mts.map +0 -1
  122. package/resources/admin.d.ts +0 -4
  123. package/resources/admin.d.ts.map +0 -1
  124. package/resources/admin.js +0 -9
  125. package/resources/admin.js.map +0 -1
  126. package/resources/admin.mjs +0 -5
  127. package/resources/admin.mjs.map +0 -1
  128. package/resources/routing.d.mts +0 -391
  129. package/resources/routing.d.mts.map +0 -1
  130. package/resources/routing.d.ts +0 -391
  131. package/resources/routing.d.ts.map +0 -1
  132. package/resources/routing.js +0 -163
  133. package/resources/routing.js.map +0 -1
  134. package/resources/routing.mjs +0 -159
  135. package/resources/routing.mjs.map +0 -1
  136. package/src/resources/admin.ts +0 -5
  137. package/src/resources/routing.ts +0 -476
@@ -1,159 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
- import { APIResource } from "../core/resource.mjs";
3
- import { buildHeaders } from "../internal/headers.mjs";
4
- import { multipartFormRequestOptions } from "../internal/uploads.mjs";
5
- export class Routing extends APIResource {
6
- /**
7
- * Survey Response
8
- *
9
- * @example
10
- * ```ts
11
- * const response = await client.routing.createSurveyResponse({
12
- * constraint_priorities: 'constraint_priorities',
13
- * email: 'email',
14
- * llm_providers: 'llm_providers',
15
- * use_case_desc: 'use_case_desc',
16
- * user_id: 'user_id',
17
- * 'x-token': 'x-token',
18
- * });
19
- * ```
20
- */
21
- createSurveyResponse(params, options) {
22
- const { 'x-token': xToken, ...body } = params;
23
- return this._client.post('/v2/pzn/surveyResponse', multipartFormRequestOptions({ body, ...options, headers: buildHeaders([{ 'x-token': xToken }, options?.headers]) }, this._client));
24
- }
25
- /**
26
- * Select the optimal LLM to handle your query based on Not Diamond's routing
27
- * algorithm.
28
- *
29
- * This endpoint analyzes your messages and returns the best-suited model from your
30
- * specified providers. The router considers factors like query complexity, model
31
- * capabilities, cost, and latency based on your preferences.
32
- *
33
- * **Key Features:**
34
- *
35
- * - Intelligent routing across multiple LLM providers
36
- * - Support for custom routers trained on your evaluation data
37
- * - Optional cost/latency optimization
38
- * - Function calling support for compatible models
39
- * - Privacy-preserving content hashing
40
- *
41
- * **Usage:**
42
- *
43
- * 1. Pass your messages in OpenAI format (array of objects with 'role' and
44
- * 'content')
45
- * 2. Specify which LLM providers you want to route between
46
- * 3. Optionally provide a preference_id for personalized routing
47
- * 4. Receive a recommended model and session_id
48
- * 5. Use the session_id to submit feedback and improve routing
49
- *
50
- * **Related Endpoints:**
51
- *
52
- * - `POST /v2/preferences/userPreferenceCreate` - Create a preference ID for
53
- * personalized routing
54
- * - `POST /v2/report/metrics/feedback` - Submit feedback on routing decisions
55
- * - `POST /v2/pzn/trainCustomRouter` - Train a custom router on your evaluation
56
- * data
57
- *
58
- * @example
59
- * ```ts
60
- * const response = await client.routing.selectModel({
61
- * llm_providers: [
62
- * { provider: 'openai', model: 'gpt-4o' },
63
- * {
64
- * provider: 'anthropic',
65
- * model: 'claude-3-5-sonnet-20241022',
66
- * },
67
- * { provider: 'google', model: 'gemini-1.5-pro' },
68
- * ],
69
- * messages: [
70
- * {
71
- * role: 'system',
72
- * content: 'You are a helpful assistant.',
73
- * },
74
- * {
75
- * role: 'user',
76
- * content: 'Explain quantum computing in simple terms',
77
- * },
78
- * ],
79
- * });
80
- * ```
81
- */
82
- selectModel(params, options) {
83
- const { type, ...body } = params;
84
- return this._client.post('/v2/modelRouter/modelSelect', { query: { type }, body, ...options });
85
- }
86
- /**
87
- * Train a custom router on your evaluation data to optimize routing for your
88
- * specific use case.
89
- *
90
- * This endpoint allows you to train a domain-specific router that learns which
91
- * models perform best for different types of queries in your application. The
92
- * router analyzes your evaluation dataset, clusters similar queries, and learns
93
- * model performance patterns.
94
- *
95
- * **Training Process:**
96
- *
97
- * 1. Upload a CSV file with your evaluation data
98
- * 2. Specify which models to route between
99
- * 3. Define the evaluation metric (score column)
100
- * 4. The system trains asynchronously and returns a preference_id
101
- * 5. Use the preference_id in model_select() calls once training completes
102
- *
103
- * **Dataset Requirements:**
104
- *
105
- * - Format: CSV file
106
- * - Minimum samples: 25 (more is better for accuracy)
107
- * - Required columns:
108
- * - Prompt column (specified in prompt_column parameter)
109
- * - For each model: `{provider}/{model}/score` and `{provider}/{model}/response`
110
- *
111
- * **Example CSV structure:**
112
- *
113
- * ```
114
- * prompt,openai/gpt-4o/score,openai/gpt-4o/response,anthropic/claude-3-5-sonnet-20241022/score,anthropic/claude-3-5-sonnet-20241022/response
115
- * "Explain quantum computing",0.95,"Quantum computing uses...",0.87,"Quantum computers leverage..."
116
- * "Write a Python function",0.82,"def my_function()...",0.91,"Here's a Python function..."
117
- * ```
118
- *
119
- * **Model Selection:**
120
- *
121
- * - Specify standard models: `{"provider": "openai", "model": "gpt-4o"}`
122
- * - Or custom models with pricing:
123
- * `{"provider": "custom", "model": "my-model", "is_custom": true, "input_price": 10.0, "output_price": 30.0, "context_length": 8192, "latency": 1.5}`
124
- *
125
- * **Training Time:**
126
- *
127
- * - Training is asynchronous and typically takes 5-15 minutes
128
- * - Larger datasets or more models take longer
129
- * - You'll receive a preference_id immediately
130
- * - Check training status by attempting to use the preference_id in model_select()
131
- *
132
- * **Best Practices:**
133
- *
134
- * 1. Use diverse, representative examples from your production workload
135
- * 2. Include at least 50-100 samples for best results
136
- * 3. Ensure consistent evaluation metrics across all models
137
- * 4. Use the same models you plan to route between in production
138
- *
139
- * **Related Documentation:** See
140
- * https://docs.notdiamond.ai/docs/adapting-prompts-to-new-models for detailed
141
- * guide.
142
- *
143
- * @example
144
- * ```ts
145
- * const response = await client.routing.trainCustomRouter({
146
- * dataset_file: fs.createReadStream('path/to/file'),
147
- * language: 'english',
148
- * llm_providers:
149
- * '[{"provider": "openai", "model": "gpt-4o"}, {"provider": "anthropic", "model": "claude-3-5-sonnet-20241022"}]',
150
- * maximize: true,
151
- * prompt_column: 'prompt',
152
- * });
153
- * ```
154
- */
155
- trainCustomRouter(body, options) {
156
- return this._client.post('/v2/pzn/trainCustomRouter', multipartFormRequestOptions({ body, ...options }, this._client));
157
- }
158
- }
159
- //# sourceMappingURL=routing.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"routing.mjs","sourceRoot":"","sources":["../src/resources/routing.ts"],"names":[],"mappings":"AAAA,sFAAsF;OAE/E,EAAE,WAAW,EAAE;OAGf,EAAE,YAAY,EAAE;OAEhB,EAAE,2BAA2B,EAAE;AAEtC,MAAM,OAAO,OAAQ,SAAQ,WAAW;IACtC;;;;;;;;;;;;;;OAcG;IACH,oBAAoB,CAClB,MAAyC,EACzC,OAAwB;QAExB,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QAC9C,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,wBAAwB,EACxB,2BAA2B,CACzB,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,EAAE,EACtF,IAAI,CAAC,OAAO,CACb,CACF,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAwDG;IACH,WAAW,CACT,MAAgC,EAChC,OAAwB;QAExB,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;QACjC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,6BAA6B,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACjG,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoEG;IACH,iBAAiB,CACf,IAAoC,EACpC,OAAwB;QAExB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,2BAA2B,EAC3B,2BAA2B,CAAC,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,CAChE,CAAC;IACJ,CAAC;CACF"}
@@ -1,5 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { APIResource } from '../core/resource';
4
-
5
- export class Admin extends APIResource {}
@@ -1,476 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { APIResource } from '../core/resource';
4
- import { APIPromise } from '../core/api-promise';
5
- import { type Uploadable } from '../core/uploads';
6
- import { buildHeaders } from '../internal/headers';
7
- import { RequestOptions } from '../internal/request-options';
8
- import { multipartFormRequestOptions } from '../internal/uploads';
9
-
10
- export class Routing extends APIResource {
11
- /**
12
- * Survey Response
13
- *
14
- * @example
15
- * ```ts
16
- * const response = await client.routing.createSurveyResponse({
17
- * constraint_priorities: 'constraint_priorities',
18
- * email: 'email',
19
- * llm_providers: 'llm_providers',
20
- * use_case_desc: 'use_case_desc',
21
- * user_id: 'user_id',
22
- * 'x-token': 'x-token',
23
- * });
24
- * ```
25
- */
26
- createSurveyResponse(
27
- params: RoutingCreateSurveyResponseParams,
28
- options?: RequestOptions,
29
- ): APIPromise<unknown> {
30
- const { 'x-token': xToken, ...body } = params;
31
- return this._client.post(
32
- '/v2/pzn/surveyResponse',
33
- multipartFormRequestOptions(
34
- { body, ...options, headers: buildHeaders([{ 'x-token': xToken }, options?.headers]) },
35
- this._client,
36
- ),
37
- );
38
- }
39
-
40
- /**
41
- * Select the optimal LLM to handle your query based on Not Diamond's routing
42
- * algorithm.
43
- *
44
- * This endpoint analyzes your messages and returns the best-suited model from your
45
- * specified providers. The router considers factors like query complexity, model
46
- * capabilities, cost, and latency based on your preferences.
47
- *
48
- * **Key Features:**
49
- *
50
- * - Intelligent routing across multiple LLM providers
51
- * - Support for custom routers trained on your evaluation data
52
- * - Optional cost/latency optimization
53
- * - Function calling support for compatible models
54
- * - Privacy-preserving content hashing
55
- *
56
- * **Usage:**
57
- *
58
- * 1. Pass your messages in OpenAI format (array of objects with 'role' and
59
- * 'content')
60
- * 2. Specify which LLM providers you want to route between
61
- * 3. Optionally provide a preference_id for personalized routing
62
- * 4. Receive a recommended model and session_id
63
- * 5. Use the session_id to submit feedback and improve routing
64
- *
65
- * **Related Endpoints:**
66
- *
67
- * - `POST /v2/preferences/userPreferenceCreate` - Create a preference ID for
68
- * personalized routing
69
- * - `POST /v2/report/metrics/feedback` - Submit feedback on routing decisions
70
- * - `POST /v2/pzn/trainCustomRouter` - Train a custom router on your evaluation
71
- * data
72
- *
73
- * @example
74
- * ```ts
75
- * const response = await client.routing.selectModel({
76
- * llm_providers: [
77
- * { provider: 'openai', model: 'gpt-4o' },
78
- * {
79
- * provider: 'anthropic',
80
- * model: 'claude-3-5-sonnet-20241022',
81
- * },
82
- * { provider: 'google', model: 'gemini-1.5-pro' },
83
- * ],
84
- * messages: [
85
- * {
86
- * role: 'system',
87
- * content: 'You are a helpful assistant.',
88
- * },
89
- * {
90
- * role: 'user',
91
- * content: 'Explain quantum computing in simple terms',
92
- * },
93
- * ],
94
- * });
95
- * ```
96
- */
97
- selectModel(
98
- params: RoutingSelectModelParams,
99
- options?: RequestOptions,
100
- ): APIPromise<RoutingSelectModelResponse> {
101
- const { type, ...body } = params;
102
- return this._client.post('/v2/modelRouter/modelSelect', { query: { type }, body, ...options });
103
- }
104
-
105
- /**
106
- * Train a custom router on your evaluation data to optimize routing for your
107
- * specific use case.
108
- *
109
- * This endpoint allows you to train a domain-specific router that learns which
110
- * models perform best for different types of queries in your application. The
111
- * router analyzes your evaluation dataset, clusters similar queries, and learns
112
- * model performance patterns.
113
- *
114
- * **Training Process:**
115
- *
116
- * 1. Upload a CSV file with your evaluation data
117
- * 2. Specify which models to route between
118
- * 3. Define the evaluation metric (score column)
119
- * 4. The system trains asynchronously and returns a preference_id
120
- * 5. Use the preference_id in model_select() calls once training completes
121
- *
122
- * **Dataset Requirements:**
123
- *
124
- * - Format: CSV file
125
- * - Minimum samples: 25 (more is better for accuracy)
126
- * - Required columns:
127
- * - Prompt column (specified in prompt_column parameter)
128
- * - For each model: `{provider}/{model}/score` and `{provider}/{model}/response`
129
- *
130
- * **Example CSV structure:**
131
- *
132
- * ```
133
- * prompt,openai/gpt-4o/score,openai/gpt-4o/response,anthropic/claude-3-5-sonnet-20241022/score,anthropic/claude-3-5-sonnet-20241022/response
134
- * "Explain quantum computing",0.95,"Quantum computing uses...",0.87,"Quantum computers leverage..."
135
- * "Write a Python function",0.82,"def my_function()...",0.91,"Here's a Python function..."
136
- * ```
137
- *
138
- * **Model Selection:**
139
- *
140
- * - Specify standard models: `{"provider": "openai", "model": "gpt-4o"}`
141
- * - Or custom models with pricing:
142
- * `{"provider": "custom", "model": "my-model", "is_custom": true, "input_price": 10.0, "output_price": 30.0, "context_length": 8192, "latency": 1.5}`
143
- *
144
- * **Training Time:**
145
- *
146
- * - Training is asynchronous and typically takes 5-15 minutes
147
- * - Larger datasets or more models take longer
148
- * - You'll receive a preference_id immediately
149
- * - Check training status by attempting to use the preference_id in model_select()
150
- *
151
- * **Best Practices:**
152
- *
153
- * 1. Use diverse, representative examples from your production workload
154
- * 2. Include at least 50-100 samples for best results
155
- * 3. Ensure consistent evaluation metrics across all models
156
- * 4. Use the same models you plan to route between in production
157
- *
158
- * **Related Documentation:** See
159
- * https://docs.notdiamond.ai/docs/adapting-prompts-to-new-models for detailed
160
- * guide.
161
- *
162
- * @example
163
- * ```ts
164
- * const response = await client.routing.trainCustomRouter({
165
- * dataset_file: fs.createReadStream('path/to/file'),
166
- * language: 'english',
167
- * llm_providers:
168
- * '[{"provider": "openai", "model": "gpt-4o"}, {"provider": "anthropic", "model": "claude-3-5-sonnet-20241022"}]',
169
- * maximize: true,
170
- * prompt_column: 'prompt',
171
- * });
172
- * ```
173
- */
174
- trainCustomRouter(
175
- body: RoutingTrainCustomRouterParams,
176
- options?: RequestOptions,
177
- ): APIPromise<RoutingTrainCustomRouterResponse> {
178
- return this._client.post(
179
- '/v2/pzn/trainCustomRouter',
180
- multipartFormRequestOptions({ body, ...options }, this._client),
181
- );
182
- }
183
- }
184
-
185
- export type RoutingCreateSurveyResponseResponse = unknown;
186
-
187
- /**
188
- * Response from model selection endpoint.
189
- */
190
- export interface RoutingSelectModelResponse {
191
- /**
192
- * List containing the selected provider
193
- */
194
- providers: Array<RoutingSelectModelResponse.Provider>;
195
-
196
- /**
197
- * Unique session ID for this routing decision
198
- */
199
- session_id: string;
200
- }
201
-
202
- export namespace RoutingSelectModelResponse {
203
- /**
204
- * Selected LLM provider information.
205
- */
206
- export interface Provider {
207
- /**
208
- * Model name
209
- */
210
- model: string;
211
-
212
- /**
213
- * Provider name
214
- */
215
- provider: string;
216
- }
217
- }
218
-
219
- /**
220
- * Response from custom router training endpoint.
221
- */
222
- export interface RoutingTrainCustomRouterResponse {
223
- /**
224
- * The preference ID for the custom router. Training happens asynchronously - use
225
- * this ID to check status and make routing calls once training is complete
226
- */
227
- preference_id: string;
228
- }
229
-
230
- export interface RoutingCreateSurveyResponseParams {
231
- /**
232
- * Body param:
233
- */
234
- constraint_priorities: string;
235
-
236
- /**
237
- * Body param:
238
- */
239
- email: string;
240
-
241
- /**
242
- * Body param:
243
- */
244
- llm_providers: string;
245
-
246
- /**
247
- * Body param:
248
- */
249
- use_case_desc: string;
250
-
251
- /**
252
- * Body param:
253
- */
254
- user_id: string;
255
-
256
- /**
257
- * Header param:
258
- */
259
- 'x-token': string;
260
-
261
- /**
262
- * Body param:
263
- */
264
- additional_preferences?: string | null;
265
-
266
- /**
267
- * Body param:
268
- */
269
- dataset_file?: Uploadable | null;
270
-
271
- /**
272
- * Body param:
273
- */
274
- name?: string | null;
275
-
276
- /**
277
- * Body param:
278
- */
279
- prompt_file?: Uploadable | null;
280
-
281
- /**
282
- * Body param:
283
- */
284
- prompts?: string | null;
285
- }
286
-
287
- export interface RoutingSelectModelParams {
288
- /**
289
- * Body param: List of LLM providers to route between. Specify at least one
290
- * provider in format {provider, model}
291
- */
292
- llm_providers: Array<
293
- RoutingSelectModelParams.RequestProvider | RoutingSelectModelParams.OpenRouterProvider
294
- >;
295
-
296
- /**
297
- * Body param: Array of message objects in OpenAI format (with 'role' and 'content'
298
- * keys)
299
- */
300
- messages: Array<{ [key: string]: string | Array<unknown> }> | string;
301
-
302
- /**
303
- * Query param: Optional format type. Use 'openrouter' to accept and return
304
- * OpenRouter-format model identifiers
305
- */
306
- type?: string | null;
307
-
308
- /**
309
- * Body param: Whether to hash message content for privacy
310
- */
311
- hash_content?: boolean;
312
-
313
- /**
314
- * Body param: Maximum number of models to consider for routing. If not specified,
315
- * considers all provided models
316
- */
317
- max_model_depth?: number | null;
318
-
319
- /**
320
- * Body param: Optimization metric for model selection
321
- */
322
- metric?: string;
323
-
324
- /**
325
- * Body param: Preference ID for personalized routing. Create one via POST
326
- * /v2/preferences/userPreferenceCreate
327
- */
328
- preference_id?: string | null;
329
-
330
- /**
331
- * Body param: Previous session ID to link related requests
332
- */
333
- previous_session?: string | null;
334
-
335
- /**
336
- * Body param: OpenAI-format function calling tools
337
- */
338
- tools?: Array<{ [key: string]: unknown }> | null;
339
-
340
- /**
341
- * Body param: Optimization tradeoff strategy. Use 'cost' to prioritize cost
342
- * savings or 'latency' to prioritize speed
343
- */
344
- tradeoff?: string | null;
345
- }
346
-
347
- export namespace RoutingSelectModelParams {
348
- /**
349
- * Model for specifying an LLM provider in API requests.
350
- */
351
- export interface RequestProvider {
352
- /**
353
- * Model name (e.g., 'gpt-4o', 'claude-3-5-sonnet-20241022')
354
- */
355
- model: string;
356
-
357
- /**
358
- * Provider name (e.g., 'openai', 'anthropic', 'google')
359
- */
360
- provider: string;
361
-
362
- /**
363
- * Maximum context length for the model (required for custom models)
364
- */
365
- context_length?: number | null;
366
-
367
- /**
368
- * Input token price per million tokens in USD (required for custom models)
369
- */
370
- input_price?: number | null;
371
-
372
- /**
373
- * Whether this is a custom model not in Not Diamond's supported model list
374
- */
375
- is_custom?: boolean;
376
-
377
- /**
378
- * Average latency in seconds (required for custom models)
379
- */
380
- latency?: number | null;
381
-
382
- /**
383
- * Output token price per million tokens in USD (required for custom models)
384
- */
385
- output_price?: number | null;
386
- }
387
-
388
- /**
389
- * Model for specifying an LLM provider using OpenRouter format.
390
- */
391
- export interface OpenRouterProvider {
392
- /**
393
- * OpenRouter model identifier in format 'provider/model'
394
- */
395
- model: string;
396
-
397
- /**
398
- * Maximum context length for the model (required for custom models)
399
- */
400
- context_length?: number | null;
401
-
402
- /**
403
- * Input token price per million tokens in USD (required for custom models)
404
- */
405
- input_price?: number | null;
406
-
407
- /**
408
- * Whether this is a custom model not in Not Diamond's supported model list
409
- */
410
- is_custom?: boolean;
411
-
412
- /**
413
- * Average latency in seconds (required for custom models)
414
- */
415
- latency?: number | null;
416
-
417
- /**
418
- * Output token price per million tokens in USD (required for custom models)
419
- */
420
- output_price?: number | null;
421
- }
422
- }
423
-
424
- export interface RoutingTrainCustomRouterParams {
425
- /**
426
- * CSV file containing evaluation data with prompt column and score/response
427
- * columns for each model
428
- */
429
- dataset_file: Uploadable;
430
-
431
- /**
432
- * Language of the evaluation data. Use 'english' for English-only data or
433
- * 'multilingual' for multi-language support
434
- */
435
- language: string;
436
-
437
- /**
438
- * JSON string array of LLM providers to train the router on. Format:
439
- * '[{"provider": "openai", "model": "gpt-4o"}, {"provider": "anthropic", "model":
440
- * "claude-3-5-sonnet-20241022"}]'
441
- */
442
- llm_providers: string;
443
-
444
- /**
445
- * Whether higher scores are better. Set to true if higher scores indicate better
446
- * performance, false otherwise
447
- */
448
- maximize: boolean;
449
-
450
- /**
451
- * Name of the column in the CSV file that contains the prompts
452
- */
453
- prompt_column: string;
454
-
455
- /**
456
- * Whether to override an existing custom router for this preference_id
457
- */
458
- override?: boolean | null;
459
-
460
- /**
461
- * Optional preference ID to update an existing router. If not provided, a new
462
- * preference will be created
463
- */
464
- preference_id?: string | null;
465
- }
466
-
467
- export declare namespace Routing {
468
- export {
469
- type RoutingCreateSurveyResponseResponse as RoutingCreateSurveyResponseResponse,
470
- type RoutingSelectModelResponse as RoutingSelectModelResponse,
471
- type RoutingTrainCustomRouterResponse as RoutingTrainCustomRouterResponse,
472
- type RoutingCreateSurveyResponseParams as RoutingCreateSurveyResponseParams,
473
- type RoutingSelectModelParams as RoutingSelectModelParams,
474
- type RoutingTrainCustomRouterParams as RoutingTrainCustomRouterParams,
475
- };
476
- }