triton-model-analyzer 1.48.0__py3-none-any.whl

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 (204) hide show
  1. model_analyzer/__init__.py +15 -0
  2. model_analyzer/analyzer.py +448 -0
  3. model_analyzer/cli/__init__.py +15 -0
  4. model_analyzer/cli/cli.py +193 -0
  5. model_analyzer/config/__init__.py +15 -0
  6. model_analyzer/config/generate/__init__.py +15 -0
  7. model_analyzer/config/generate/automatic_model_config_generator.py +164 -0
  8. model_analyzer/config/generate/base_model_config_generator.py +352 -0
  9. model_analyzer/config/generate/brute_plus_binary_parameter_search_run_config_generator.py +164 -0
  10. model_analyzer/config/generate/brute_run_config_generator.py +154 -0
  11. model_analyzer/config/generate/concurrency_sweeper.py +75 -0
  12. model_analyzer/config/generate/config_generator_interface.py +52 -0
  13. model_analyzer/config/generate/coordinate.py +143 -0
  14. model_analyzer/config/generate/coordinate_data.py +86 -0
  15. model_analyzer/config/generate/generator_utils.py +116 -0
  16. model_analyzer/config/generate/manual_model_config_generator.py +187 -0
  17. model_analyzer/config/generate/model_config_generator_factory.py +92 -0
  18. model_analyzer/config/generate/model_profile_spec.py +74 -0
  19. model_analyzer/config/generate/model_run_config_generator.py +154 -0
  20. model_analyzer/config/generate/model_variant_name_manager.py +150 -0
  21. model_analyzer/config/generate/neighborhood.py +536 -0
  22. model_analyzer/config/generate/optuna_plus_concurrency_sweep_run_config_generator.py +141 -0
  23. model_analyzer/config/generate/optuna_run_config_generator.py +838 -0
  24. model_analyzer/config/generate/perf_analyzer_config_generator.py +312 -0
  25. model_analyzer/config/generate/quick_plus_concurrency_sweep_run_config_generator.py +130 -0
  26. model_analyzer/config/generate/quick_run_config_generator.py +753 -0
  27. model_analyzer/config/generate/run_config_generator_factory.py +329 -0
  28. model_analyzer/config/generate/search_config.py +112 -0
  29. model_analyzer/config/generate/search_dimension.py +73 -0
  30. model_analyzer/config/generate/search_dimensions.py +85 -0
  31. model_analyzer/config/generate/search_parameter.py +49 -0
  32. model_analyzer/config/generate/search_parameters.py +388 -0
  33. model_analyzer/config/input/__init__.py +15 -0
  34. model_analyzer/config/input/config_command.py +483 -0
  35. model_analyzer/config/input/config_command_profile.py +1747 -0
  36. model_analyzer/config/input/config_command_report.py +267 -0
  37. model_analyzer/config/input/config_defaults.py +236 -0
  38. model_analyzer/config/input/config_enum.py +83 -0
  39. model_analyzer/config/input/config_field.py +216 -0
  40. model_analyzer/config/input/config_list_generic.py +112 -0
  41. model_analyzer/config/input/config_list_numeric.py +151 -0
  42. model_analyzer/config/input/config_list_string.py +111 -0
  43. model_analyzer/config/input/config_none.py +71 -0
  44. model_analyzer/config/input/config_object.py +129 -0
  45. model_analyzer/config/input/config_primitive.py +81 -0
  46. model_analyzer/config/input/config_status.py +75 -0
  47. model_analyzer/config/input/config_sweep.py +83 -0
  48. model_analyzer/config/input/config_union.py +113 -0
  49. model_analyzer/config/input/config_utils.py +128 -0
  50. model_analyzer/config/input/config_value.py +243 -0
  51. model_analyzer/config/input/objects/__init__.py +15 -0
  52. model_analyzer/config/input/objects/config_model_profile_spec.py +325 -0
  53. model_analyzer/config/input/objects/config_model_report_spec.py +173 -0
  54. model_analyzer/config/input/objects/config_plot.py +198 -0
  55. model_analyzer/config/input/objects/config_protobuf_utils.py +101 -0
  56. model_analyzer/config/input/yaml_config_validator.py +82 -0
  57. model_analyzer/config/run/__init__.py +15 -0
  58. model_analyzer/config/run/model_run_config.py +313 -0
  59. model_analyzer/config/run/run_config.py +168 -0
  60. model_analyzer/constants.py +76 -0
  61. model_analyzer/device/__init__.py +15 -0
  62. model_analyzer/device/device.py +24 -0
  63. model_analyzer/device/gpu_device.py +87 -0
  64. model_analyzer/device/gpu_device_factory.py +248 -0
  65. model_analyzer/entrypoint.py +307 -0
  66. model_analyzer/log_formatter.py +65 -0
  67. model_analyzer/model_analyzer_exceptions.py +24 -0
  68. model_analyzer/model_manager.py +255 -0
  69. model_analyzer/monitor/__init__.py +15 -0
  70. model_analyzer/monitor/cpu_monitor.py +69 -0
  71. model_analyzer/monitor/dcgm/DcgmDiag.py +191 -0
  72. model_analyzer/monitor/dcgm/DcgmFieldGroup.py +83 -0
  73. model_analyzer/monitor/dcgm/DcgmGroup.py +815 -0
  74. model_analyzer/monitor/dcgm/DcgmHandle.py +141 -0
  75. model_analyzer/monitor/dcgm/DcgmJsonReader.py +69 -0
  76. model_analyzer/monitor/dcgm/DcgmReader.py +623 -0
  77. model_analyzer/monitor/dcgm/DcgmStatus.py +57 -0
  78. model_analyzer/monitor/dcgm/DcgmSystem.py +412 -0
  79. model_analyzer/monitor/dcgm/__init__.py +15 -0
  80. model_analyzer/monitor/dcgm/common/__init__.py +13 -0
  81. model_analyzer/monitor/dcgm/common/dcgm_client_cli_parser.py +194 -0
  82. model_analyzer/monitor/dcgm/common/dcgm_client_main.py +86 -0
  83. model_analyzer/monitor/dcgm/dcgm_agent.py +887 -0
  84. model_analyzer/monitor/dcgm/dcgm_collectd_plugin.py +369 -0
  85. model_analyzer/monitor/dcgm/dcgm_errors.py +395 -0
  86. model_analyzer/monitor/dcgm/dcgm_field_helpers.py +546 -0
  87. model_analyzer/monitor/dcgm/dcgm_fields.py +815 -0
  88. model_analyzer/monitor/dcgm/dcgm_fields_collectd.py +671 -0
  89. model_analyzer/monitor/dcgm/dcgm_fields_internal.py +29 -0
  90. model_analyzer/monitor/dcgm/dcgm_fluentd.py +45 -0
  91. model_analyzer/monitor/dcgm/dcgm_monitor.py +138 -0
  92. model_analyzer/monitor/dcgm/dcgm_prometheus.py +326 -0
  93. model_analyzer/monitor/dcgm/dcgm_structs.py +2357 -0
  94. model_analyzer/monitor/dcgm/dcgm_telegraf.py +65 -0
  95. model_analyzer/monitor/dcgm/dcgm_value.py +151 -0
  96. model_analyzer/monitor/dcgm/dcgmvalue.py +155 -0
  97. model_analyzer/monitor/dcgm/denylist_recommendations.py +573 -0
  98. model_analyzer/monitor/dcgm/pydcgm.py +47 -0
  99. model_analyzer/monitor/monitor.py +143 -0
  100. model_analyzer/monitor/remote_monitor.py +137 -0
  101. model_analyzer/output/__init__.py +15 -0
  102. model_analyzer/output/file_writer.py +63 -0
  103. model_analyzer/output/output_writer.py +42 -0
  104. model_analyzer/perf_analyzer/__init__.py +15 -0
  105. model_analyzer/perf_analyzer/genai_perf_config.py +206 -0
  106. model_analyzer/perf_analyzer/perf_analyzer.py +882 -0
  107. model_analyzer/perf_analyzer/perf_config.py +479 -0
  108. model_analyzer/plots/__init__.py +15 -0
  109. model_analyzer/plots/detailed_plot.py +266 -0
  110. model_analyzer/plots/plot_manager.py +224 -0
  111. model_analyzer/plots/simple_plot.py +213 -0
  112. model_analyzer/record/__init__.py +15 -0
  113. model_analyzer/record/gpu_record.py +68 -0
  114. model_analyzer/record/metrics_manager.py +887 -0
  115. model_analyzer/record/record.py +280 -0
  116. model_analyzer/record/record_aggregator.py +256 -0
  117. model_analyzer/record/types/__init__.py +15 -0
  118. model_analyzer/record/types/cpu_available_ram.py +93 -0
  119. model_analyzer/record/types/cpu_used_ram.py +93 -0
  120. model_analyzer/record/types/gpu_free_memory.py +96 -0
  121. model_analyzer/record/types/gpu_power_usage.py +107 -0
  122. model_analyzer/record/types/gpu_total_memory.py +96 -0
  123. model_analyzer/record/types/gpu_used_memory.py +96 -0
  124. model_analyzer/record/types/gpu_utilization.py +108 -0
  125. model_analyzer/record/types/inter_token_latency_avg.py +60 -0
  126. model_analyzer/record/types/inter_token_latency_base.py +74 -0
  127. model_analyzer/record/types/inter_token_latency_max.py +60 -0
  128. model_analyzer/record/types/inter_token_latency_min.py +60 -0
  129. model_analyzer/record/types/inter_token_latency_p25.py +60 -0
  130. model_analyzer/record/types/inter_token_latency_p50.py +60 -0
  131. model_analyzer/record/types/inter_token_latency_p75.py +60 -0
  132. model_analyzer/record/types/inter_token_latency_p90.py +60 -0
  133. model_analyzer/record/types/inter_token_latency_p95.py +60 -0
  134. model_analyzer/record/types/inter_token_latency_p99.py +60 -0
  135. model_analyzer/record/types/output_token_throughput.py +105 -0
  136. model_analyzer/record/types/perf_client_response_wait.py +97 -0
  137. model_analyzer/record/types/perf_client_send_recv.py +97 -0
  138. model_analyzer/record/types/perf_latency.py +111 -0
  139. model_analyzer/record/types/perf_latency_avg.py +60 -0
  140. model_analyzer/record/types/perf_latency_base.py +74 -0
  141. model_analyzer/record/types/perf_latency_p90.py +60 -0
  142. model_analyzer/record/types/perf_latency_p95.py +60 -0
  143. model_analyzer/record/types/perf_latency_p99.py +60 -0
  144. model_analyzer/record/types/perf_server_compute_infer.py +97 -0
  145. model_analyzer/record/types/perf_server_compute_input.py +97 -0
  146. model_analyzer/record/types/perf_server_compute_output.py +97 -0
  147. model_analyzer/record/types/perf_server_queue.py +97 -0
  148. model_analyzer/record/types/perf_throughput.py +105 -0
  149. model_analyzer/record/types/time_to_first_token_avg.py +60 -0
  150. model_analyzer/record/types/time_to_first_token_base.py +74 -0
  151. model_analyzer/record/types/time_to_first_token_max.py +60 -0
  152. model_analyzer/record/types/time_to_first_token_min.py +60 -0
  153. model_analyzer/record/types/time_to_first_token_p25.py +60 -0
  154. model_analyzer/record/types/time_to_first_token_p50.py +60 -0
  155. model_analyzer/record/types/time_to_first_token_p75.py +60 -0
  156. model_analyzer/record/types/time_to_first_token_p90.py +60 -0
  157. model_analyzer/record/types/time_to_first_token_p95.py +60 -0
  158. model_analyzer/record/types/time_to_first_token_p99.py +60 -0
  159. model_analyzer/reports/__init__.py +15 -0
  160. model_analyzer/reports/html_report.py +195 -0
  161. model_analyzer/reports/pdf_report.py +50 -0
  162. model_analyzer/reports/report.py +86 -0
  163. model_analyzer/reports/report_factory.py +62 -0
  164. model_analyzer/reports/report_manager.py +1376 -0
  165. model_analyzer/reports/report_utils.py +42 -0
  166. model_analyzer/result/__init__.py +15 -0
  167. model_analyzer/result/constraint_manager.py +150 -0
  168. model_analyzer/result/model_config_measurement.py +354 -0
  169. model_analyzer/result/model_constraints.py +105 -0
  170. model_analyzer/result/parameter_search.py +246 -0
  171. model_analyzer/result/result_manager.py +430 -0
  172. model_analyzer/result/result_statistics.py +159 -0
  173. model_analyzer/result/result_table.py +217 -0
  174. model_analyzer/result/result_table_manager.py +646 -0
  175. model_analyzer/result/result_utils.py +42 -0
  176. model_analyzer/result/results.py +277 -0
  177. model_analyzer/result/run_config_measurement.py +658 -0
  178. model_analyzer/result/run_config_result.py +210 -0
  179. model_analyzer/result/run_config_result_comparator.py +110 -0
  180. model_analyzer/result/sorted_results.py +151 -0
  181. model_analyzer/state/__init__.py +15 -0
  182. model_analyzer/state/analyzer_state.py +76 -0
  183. model_analyzer/state/analyzer_state_manager.py +215 -0
  184. model_analyzer/triton/__init__.py +15 -0
  185. model_analyzer/triton/client/__init__.py +15 -0
  186. model_analyzer/triton/client/client.py +234 -0
  187. model_analyzer/triton/client/client_factory.py +57 -0
  188. model_analyzer/triton/client/grpc_client.py +104 -0
  189. model_analyzer/triton/client/http_client.py +107 -0
  190. model_analyzer/triton/model/__init__.py +15 -0
  191. model_analyzer/triton/model/model_config.py +556 -0
  192. model_analyzer/triton/model/model_config_variant.py +29 -0
  193. model_analyzer/triton/server/__init__.py +15 -0
  194. model_analyzer/triton/server/server.py +76 -0
  195. model_analyzer/triton/server/server_config.py +269 -0
  196. model_analyzer/triton/server/server_docker.py +229 -0
  197. model_analyzer/triton/server/server_factory.py +306 -0
  198. model_analyzer/triton/server/server_local.py +158 -0
  199. triton_model_analyzer-1.48.0.dist-info/METADATA +52 -0
  200. triton_model_analyzer-1.48.0.dist-info/RECORD +204 -0
  201. triton_model_analyzer-1.48.0.dist-info/WHEEL +5 -0
  202. triton_model_analyzer-1.48.0.dist-info/entry_points.txt +2 -0
  203. triton_model_analyzer-1.48.0.dist-info/licenses/LICENSE +67 -0
  204. triton_model_analyzer-1.48.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,277 @@
1
+ #!/usr/bin/env python3
2
+
3
+ # Copyright 2022-2023, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ import logging
18
+
19
+ from model_analyzer.config.run.run_config import RunConfig
20
+ from model_analyzer.constants import LOGGER_NAME
21
+ from model_analyzer.result.run_config_measurement import RunConfigMeasurement
22
+
23
+ logger = logging.getLogger(LOGGER_NAME)
24
+
25
+
26
+ class Results:
27
+ """
28
+ Provides storage and accessor functions for measurements
29
+ """
30
+
31
+ RUN_CONFIG_INDEX = 0
32
+ MEASUREMENTS_INDEX = 1
33
+
34
+ def __init__(self):
35
+ """ """
36
+ self._results = {}
37
+
38
+ @classmethod
39
+ def from_dict(cls, results_dict):
40
+ """
41
+ Populate the Results class based on the dictionary value
42
+ (stored in the checkpoint)
43
+
44
+ The checkpoint format is:
45
+ {models_name: { [run_config: (key, {run_config_measurements} ) ] } }
46
+ ---results_dict-------------------------------------------
47
+ ---model_dict------------------------------
48
+ ---model_config_tuple_list-------------
49
+ -key, run_config_measurement_dict-
50
+ """
51
+ results = Results()
52
+
53
+ for models_name, model_dict in results_dict["_results"].items():
54
+ for model_variants_name, run_config_tuple_list in model_dict.items():
55
+ run_config = RunConfig.from_dict(
56
+ run_config_tuple_list[Results.RUN_CONFIG_INDEX]
57
+ )
58
+
59
+ for key, measurement_dict in run_config_tuple_list[
60
+ Results.MEASUREMENTS_INDEX
61
+ ].items():
62
+ run_config_measurement = RunConfigMeasurement.from_dict(
63
+ measurement_dict
64
+ )
65
+
66
+ results._add_run_config_measurement(
67
+ models_name,
68
+ run_config,
69
+ model_variants_name,
70
+ key,
71
+ run_config_measurement,
72
+ )
73
+
74
+ return results
75
+
76
+ def add_run_config_measurement(self, run_config, run_config_measurement):
77
+ """
78
+ Given a RunConfig and a RunConfigMeasurement, add the measurement to the
79
+ RunConfig's measurements
80
+
81
+ Parameters
82
+ ----------
83
+ run_config: RunConfig
84
+ run_config_measurement: RunConfigMeasurement
85
+ """
86
+
87
+ models_name = run_config.models_name()
88
+ model_variants_name = run_config.model_variants_name()
89
+ key = run_config.representation()
90
+
91
+ self._add_run_config_measurement(
92
+ models_name, run_config, model_variants_name, key, run_config_measurement
93
+ )
94
+
95
+ def contains_model(self, models_name):
96
+ """
97
+ Checks if the models name exists
98
+ in the results
99
+
100
+ Parameters
101
+ ----------
102
+ models_name : str
103
+ The models name
104
+
105
+ Returns
106
+ -------
107
+ bool
108
+ """
109
+ return models_name in self._results
110
+
111
+ def contains_model_variant(self, models_name, model_variants_name):
112
+ """
113
+ Checks if the models name and model variants name
114
+ exist in the results
115
+
116
+ Parameters
117
+ ----------
118
+ models_name : str
119
+ model_variants_name: str
120
+
121
+ Returns
122
+ -------
123
+ bool
124
+ """
125
+ if not self.contains_model(models_name):
126
+ return False
127
+
128
+ return model_variants_name in self._results[models_name]
129
+
130
+ def get_list_of_models(self):
131
+ """
132
+ Returns the list of models profiled
133
+
134
+ Returns
135
+ -------
136
+ list of str
137
+ List of the names of model's profiled
138
+ """
139
+ return list(self._results.keys())
140
+
141
+ def get_list_of_model_config_measurement_tuples(self):
142
+ """
143
+ Returns a list of model configs with their
144
+ corresponding RunConfigMeasurements
145
+
146
+ Returns
147
+ -------
148
+ list of tuples - [(ModelConfig, list of RunConfigMeasurements)]
149
+ List of model configs and a dict of all associated
150
+ measurement values
151
+ """
152
+ return list(self._results.values())
153
+
154
+ def get_list_of_run_config_measurements(self):
155
+ """
156
+ Return a list of RunConfigMeasurements from every model/model_config
157
+
158
+ Parameters
159
+ ----------
160
+ None
161
+
162
+ Returns
163
+ -------
164
+ List of RunConfigMeasurements
165
+ """
166
+ measurements = []
167
+ for model_result in self._results.values():
168
+ for model_config_result in model_result.values():
169
+ for measurement in model_config_result[
170
+ Results.MEASUREMENTS_INDEX
171
+ ].values():
172
+ measurements.append(measurement)
173
+
174
+ return measurements
175
+
176
+ def get_model_measurements_dict(self, models_name, suppress_warning=False):
177
+ """
178
+ Given a model name, return a dict with all measurements for that model.
179
+
180
+ Parameters
181
+ ----------
182
+ models_name : str
183
+ The model name for the requested results
184
+
185
+ Returns
186
+ -------
187
+ Dict (keyed by model_variants_name) of tuples containing a RunConfig and
188
+ a dict of Keys:RunConfigMeasurements
189
+ {
190
+ model_variants_name_1:
191
+ (
192
+ RunConfig1,
193
+ {
194
+ Key1: RunConfigMeasurement1
195
+ Key2: RunConfigMeasurement2
196
+ }
197
+ ),
198
+ model_variants_name_2:
199
+ (
200
+ RunConfig2,
201
+ {
202
+ Key3: RunConfigMeasurement3
203
+ Key4: RunConfigMeasurement4
204
+ }
205
+ )
206
+ }
207
+ """
208
+ if not self.contains_model(models_name):
209
+ if not suppress_warning:
210
+ logger.error(f"No results found for model: {models_name}")
211
+
212
+ return {}
213
+
214
+ return self._results[models_name]
215
+
216
+ def get_model_variants_measurements_dict(self, models_name, model_variants_name):
217
+ """
218
+ Given a models name and model variants name, return a dict of all
219
+ associated RunConfigMeasurements
220
+
221
+ Parameters
222
+ ----------
223
+ model_name : str
224
+ model_variants_name: str
225
+
226
+ Returns
227
+ -------
228
+ Dict of {Key:RunConfigMeasurement}
229
+ """
230
+ if not self.contains_model(models_name) or not self.contains_model_variant(
231
+ models_name, model_variants_name
232
+ ):
233
+ logger.error(f"No results found for variant: {model_variants_name}")
234
+ return {}
235
+
236
+ return self._results[models_name][model_variants_name][
237
+ Results.MEASUREMENTS_INDEX
238
+ ]
239
+
240
+ def get_all_model_variant_measurements(self, models_name, model_variants_name):
241
+ """
242
+ Given a model name and model variant name, return the RunConfig and
243
+ a list of all associated measurement values
244
+
245
+ Parameters
246
+ ----------
247
+ models_name : str
248
+ model_variants_name: str
249
+
250
+ Returns
251
+ -------
252
+ Tuple - (RunConfig, list of RunConfigMeasurements)
253
+ """
254
+ if not self.contains_model(models_name) or not self.contains_model_variant(
255
+ models_name, model_variants_name
256
+ ):
257
+ logger.error(f"No results found for model variant: {model_variants_name}")
258
+ return (None, [])
259
+
260
+ model_config_data = self._results[models_name][model_variants_name]
261
+
262
+ return model_config_data[Results.RUN_CONFIG_INDEX], list(
263
+ model_config_data[Results.MEASUREMENTS_INDEX].values()
264
+ )
265
+
266
+ def _add_run_config_measurement(
267
+ self, models_name, run_config, model_variants_name, key, run_config_measurement
268
+ ):
269
+ if models_name not in self._results:
270
+ self._results[models_name] = {}
271
+
272
+ if model_variants_name not in self._results[models_name]:
273
+ self._results[models_name][model_variants_name] = (run_config, {})
274
+
275
+ self._results[models_name][model_variants_name][Results.MEASUREMENTS_INDEX][
276
+ key
277
+ ] = run_config_measurement