arize-phoenix 11.18.0__tar.gz → 11.20.0__tar.gz

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.

Potentially problematic release.


This version of arize-phoenix might be problematic. Click here for more details.

Files changed (450) hide show
  1. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/PKG-INFO +1 -1
  2. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/helpers.py +27 -0
  3. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/playground_clients.py +2 -0
  4. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/queries.py +450 -3
  5. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/projects.py +5 -4
  6. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/spans.py +128 -3
  7. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Dataset.py +19 -0
  8. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/prometheus.py +1 -0
  9. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/.vite/manifest.json +9 -9
  10. arize_phoenix-11.18.0/src/phoenix/server/static/assets/components-B1Ec5V_g.js → arize_phoenix-11.20.0/src/phoenix/server/static/assets/components-BNcxEjYs.js +332 -265
  11. arize_phoenix-11.18.0/src/phoenix/server/static/assets/index-DYx39hbu.js → arize_phoenix-11.20.0/src/phoenix/server/static/assets/index-CKIBKnVD.js +2 -2
  12. arize_phoenix-11.18.0/src/phoenix/server/static/assets/pages-B77OHHSB.js → arize_phoenix-11.20.0/src/phoenix/server/static/assets/pages-3RoC-adr.js +489 -461
  13. arize_phoenix-11.20.0/src/phoenix/version.py +1 -0
  14. arize_phoenix-11.18.0/src/phoenix/version.py +0 -1
  15. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/.gitignore +0 -0
  16. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/IP_NOTICE +0 -0
  17. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/LICENSE +0 -0
  18. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/README.md +0 -0
  19. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/pyproject.toml +0 -0
  20. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/__init__.py +0 -0
  21. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/auth.py +0 -0
  22. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/config.py +0 -0
  23. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/core/__init__.py +0 -0
  24. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/core/embedding_dimension.py +0 -0
  25. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/core/model.py +0 -0
  26. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/core/model_schema.py +0 -0
  27. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/core/model_schema_adapter.py +0 -0
  28. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/datetime_utils.py +0 -0
  29. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/README.md +0 -0
  30. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/__init__.py +0 -0
  31. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/alembic.ini +0 -0
  32. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/bulk_inserter.py +0 -0
  33. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/constants.py +0 -0
  34. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/engines.py +0 -0
  35. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/enums.py +0 -0
  36. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/facilitator.py +0 -0
  37. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/__init__.py +0 -0
  38. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/constants.py +0 -0
  39. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/dataset.py +0 -0
  40. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/document_annotation.py +0 -0
  41. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/evaluation.py +0 -0
  42. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/helpers.py +0 -0
  43. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/span.py +0 -0
  44. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/span_annotation.py +0 -0
  45. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/trace_annotation.py +0 -0
  46. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/insertion/types.py +0 -0
  47. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrate.py +0 -0
  48. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/__init__.py +0 -0
  49. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/data_migration_scripts/__init__.py +0 -0
  50. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/data_migration_scripts/populate_project_sessions.py +0 -0
  51. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/env.py +0 -0
  52. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/script.py.mako +0 -0
  53. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/10460e46d750_datasets.py +0 -0
  54. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/2f9d1a65945f_annotation_config_migration.py +0 -0
  55. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/3be8647b87d8_add_token_columns_to_spans_table.py +0 -0
  56. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/4ded9e43755f_create_project_sessions_table.py +0 -0
  57. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/6a88424799fe_update_users_with_auth_method.py +0 -0
  58. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/8a3764fe7f1a_change_jsonb_to_json_for_prompts.py +0 -0
  59. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/a20694b15f82_cost.py +0 -0
  60. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/bb8139330879_create_project_trace_retention_policies_table.py +0 -0
  61. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/bc8fea3c2bc8_add_prompt_tables.py +0 -0
  62. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/cd164e83824f_users_and_tokens.py +0 -0
  63. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/migrations/versions/cf03bd6bae1d_init.py +0 -0
  64. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/models.py +0 -0
  65. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/pg_config.py +0 -0
  66. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/__init__.py +0 -0
  67. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/annotation_configs.py +0 -0
  68. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/db_models.py +0 -0
  69. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/identifier.py +0 -0
  70. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/model_provider.py +0 -0
  71. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/token_price_customization.py +0 -0
  72. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/db/types/trace_retention.py +0 -0
  73. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/exceptions.py +0 -0
  74. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/__init__.py +0 -0
  75. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/evaluators/__init__.py +0 -0
  76. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/evaluators/base.py +0 -0
  77. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/evaluators/code_evaluators.py +0 -0
  78. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/evaluators/llm_evaluators.py +0 -0
  79. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/evaluators/utils.py +0 -0
  80. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/functions.py +0 -0
  81. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/tracing.py +0 -0
  82. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/types.py +0 -0
  83. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/experiments/utils.py +0 -0
  84. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/__init__.py +0 -0
  85. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/errors.py +0 -0
  86. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/fixtures.py +0 -0
  87. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/inferences.py +0 -0
  88. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/schema.py +0 -0
  89. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/inferences/validation.py +0 -0
  90. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/logging/__init__.py +0 -0
  91. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/logging/_config.py +0 -0
  92. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/logging/_filter.py +0 -0
  93. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/logging/_formatter.py +0 -0
  94. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/README.md +0 -0
  95. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/__init__.py +0 -0
  96. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/binning.py +0 -0
  97. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/metrics.py +0 -0
  98. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/mixins.py +0 -0
  99. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/retrieval_metrics.py +0 -0
  100. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/timeseries.py +0 -0
  101. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/metrics/wrappers.py +0 -0
  102. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/pointcloud/__init__.py +0 -0
  103. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/pointcloud/clustering.py +0 -0
  104. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/pointcloud/pointcloud.py +0 -0
  105. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/pointcloud/projectors.py +0 -0
  106. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/pointcloud/umap_parameters.py +0 -0
  107. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/py.typed +0 -0
  108. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/__init__.py +0 -0
  109. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/README.md +0 -0
  110. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/__init__.py +0 -0
  111. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/auth.py +0 -0
  112. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/context.py +0 -0
  113. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/__init__.py +0 -0
  114. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/annotation_configs_by_project.py +0 -0
  115. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/annotation_summaries.py +0 -0
  116. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/average_experiment_run_latency.py +0 -0
  117. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/cache/__init__.py +0 -0
  118. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/cache/two_tier_cache.py +0 -0
  119. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -0
  120. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/dataset_example_spans.py +0 -0
  121. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/document_evaluation_summaries.py +0 -0
  122. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/document_evaluations.py +0 -0
  123. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/document_retrieval_metrics.py +0 -0
  124. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/experiment_annotation_summaries.py +0 -0
  125. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/experiment_error_rates.py +0 -0
  126. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/experiment_run_annotations.py +0 -0
  127. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/experiment_run_counts.py +0 -0
  128. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/experiment_sequence_number.py +0 -0
  129. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/last_used_times_by_generative_model_id.py +0 -0
  130. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/latency_ms_quantile.py +0 -0
  131. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/min_start_or_max_end_times.py +0 -0
  132. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/num_child_spans.py +0 -0
  133. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/num_spans_per_trace.py +0 -0
  134. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/project_by_name.py +0 -0
  135. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/project_ids_by_trace_retention_policy_id.py +0 -0
  136. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/prompt_version_sequence_number.py +0 -0
  137. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/record_counts.py +0 -0
  138. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/session_io.py +0 -0
  139. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/session_num_traces.py +0 -0
  140. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/session_num_traces_with_error.py +0 -0
  141. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/session_token_usages.py +0 -0
  142. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/session_trace_latency_ms_quantile.py +0 -0
  143. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_annotations.py +0 -0
  144. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_by_id.py +0 -0
  145. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_by_span.py +0 -0
  146. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_generative_model.py +0 -0
  147. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_project_session.py +0 -0
  148. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_span.py +0 -0
  149. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_trace.py +0 -0
  150. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_details_by_span_cost.py +0 -0
  151. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment.py +0 -0
  152. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment_run.py +0 -0
  153. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_generative_model.py +0 -0
  154. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project.py +0 -0
  155. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project_session.py +0 -0
  156. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_trace.py +0 -0
  157. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_costs.py +0 -0
  158. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_dataset_examples.py +0 -0
  159. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_descendants.py +0 -0
  160. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/span_projects.py +0 -0
  161. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/table_fields.py +0 -0
  162. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/token_counts.py +0 -0
  163. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/trace_by_trace_ids.py +0 -0
  164. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/trace_retention_policy_id_by_project_id.py +0 -0
  165. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/trace_root_spans.py +0 -0
  166. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/types.py +0 -0
  167. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/user_roles.py +0 -0
  168. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/dataloaders/users.py +0 -0
  169. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/exceptions.py +0 -0
  170. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/__init__.py +0 -0
  171. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/annotations.py +0 -0
  172. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/dataset_helpers.py +0 -0
  173. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/experiment_run_filters.py +0 -0
  174. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/playground_registry.py +0 -0
  175. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/playground_spans.py +0 -0
  176. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/__init__.py +0 -0
  177. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/conversions/__init__.py +0 -0
  178. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/conversions/anthropic.py +0 -0
  179. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/conversions/aws.py +0 -0
  180. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/conversions/openai.py +0 -0
  181. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/helpers/prompts/models.py +0 -0
  182. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/AddExamplesToDatasetInput.py +0 -0
  183. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/AddSpansToDatasetInput.py +0 -0
  184. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ChatCompletionInput.py +0 -0
  185. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ChatCompletionMessageInput.py +0 -0
  186. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ClearProjectInput.py +0 -0
  187. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ClusterInput.py +0 -0
  188. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/Coordinates.py +0 -0
  189. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/CreateDatasetInput.py +0 -0
  190. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/CreateProjectInput.py +0 -0
  191. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/CreateSpanAnnotationInput.py +0 -0
  192. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/CreateTraceAnnotationInput.py +0 -0
  193. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DataQualityMetricInput.py +0 -0
  194. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DatasetExampleInput.py +0 -0
  195. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DatasetFilter.py +0 -0
  196. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DatasetSort.py +0 -0
  197. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DatasetVersionSort.py +0 -0
  198. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DeleteAnnotationsInput.py +0 -0
  199. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DeleteDatasetExamplesInput.py +0 -0
  200. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DeleteDatasetInput.py +0 -0
  201. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DeleteExperimentsInput.py +0 -0
  202. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DimensionFilter.py +0 -0
  203. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/DimensionInput.py +0 -0
  204. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/GenerativeCredentialInput.py +0 -0
  205. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/GenerativeModelInput.py +0 -0
  206. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/Granularity.py +0 -0
  207. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/InvocationParameters.py +0 -0
  208. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PatchAnnotationInput.py +0 -0
  209. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PatchDatasetExamplesInput.py +0 -0
  210. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PatchDatasetInput.py +0 -0
  211. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PerformanceMetricInput.py +0 -0
  212. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ProjectFilter.py +0 -0
  213. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ProjectSessionSort.py +0 -0
  214. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/ProjectSort.py +0 -0
  215. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PromptFilter.py +0 -0
  216. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PromptTemplateOptions.py +0 -0
  217. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/PromptVersionInput.py +0 -0
  218. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/SpanAnnotationFilter.py +0 -0
  219. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/SpanAnnotationSort.py +0 -0
  220. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/SpanSort.py +0 -0
  221. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/TimeBinConfig.py +0 -0
  222. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/TimeRange.py +0 -0
  223. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/TraceAnnotationSort.py +0 -0
  224. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/UserRoleInput.py +0 -0
  225. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/input_types/__init__.py +0 -0
  226. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/interceptor.py +0 -0
  227. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/__init__.py +0 -0
  228. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/annotation_config_mutations.py +0 -0
  229. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/api_key_mutations.py +0 -0
  230. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/chat_mutations.py +0 -0
  231. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/dataset_mutations.py +0 -0
  232. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/experiment_mutations.py +0 -0
  233. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/export_events_mutations.py +0 -0
  234. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/model_mutations.py +0 -0
  235. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/project_mutations.py +0 -0
  236. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +0 -0
  237. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/prompt_label_mutations.py +0 -0
  238. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/prompt_mutations.py +0 -0
  239. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/prompt_version_tag_mutations.py +0 -0
  240. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/span_annotations_mutations.py +0 -0
  241. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/trace_annotations_mutations.py +0 -0
  242. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/trace_mutations.py +0 -0
  243. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/mutations/user_mutations.py +0 -0
  244. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/openapi/__init__.py +0 -0
  245. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/openapi/main.py +0 -0
  246. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/openapi/schema.py +0 -0
  247. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/__init__.py +0 -0
  248. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/auth.py +0 -0
  249. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/embeddings.py +0 -0
  250. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/oauth2.py +0 -0
  251. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/utils.py +0 -0
  252. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/__init__.py +0 -0
  253. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/annotation_configs.py +0 -0
  254. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/annotations.py +0 -0
  255. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/datasets.py +0 -0
  256. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/evaluations.py +0 -0
  257. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/experiment_evaluations.py +0 -0
  258. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/experiment_runs.py +0 -0
  259. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/experiments.py +0 -0
  260. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/models.py +0 -0
  261. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/prompts.py +0 -0
  262. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/traces.py +0 -0
  263. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/users.py +0 -0
  264. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/routers/v1/utils.py +0 -0
  265. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/schema.py +0 -0
  266. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/subscriptions.py +0 -0
  267. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Annotation.py +0 -0
  268. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/AnnotationConfig.py +0 -0
  269. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/AnnotationSource.py +0 -0
  270. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/AnnotationSummary.py +0 -0
  271. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/AnnotatorKind.py +0 -0
  272. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ApiKey.py +0 -0
  273. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/AuthMethod.py +0 -0
  274. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ChatCompletionMessageRole.py +0 -0
  275. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +0 -0
  276. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Cluster.py +0 -0
  277. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/CostBreakdown.py +0 -0
  278. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/CreateDatasetPayload.py +0 -0
  279. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/CronExpression.py +0 -0
  280. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DataQualityMetric.py +0 -0
  281. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DatasetExample.py +0 -0
  282. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DatasetExampleRevision.py +0 -0
  283. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DatasetValues.py +0 -0
  284. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DatasetVersion.py +0 -0
  285. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Dimension.py +0 -0
  286. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DimensionDataType.py +0 -0
  287. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DimensionShape.py +0 -0
  288. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DimensionType.py +0 -0
  289. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DimensionWithValue.py +0 -0
  290. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DocumentEvaluationSummary.py +0 -0
  291. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/DocumentRetrievalMetrics.py +0 -0
  292. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/EmbeddingDimension.py +0 -0
  293. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/EmbeddingMetadata.py +0 -0
  294. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Evaluation.py +0 -0
  295. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/EvaluationSummary.py +0 -0
  296. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Event.py +0 -0
  297. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/EventMetadata.py +0 -0
  298. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExampleRevisionInterface.py +0 -0
  299. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Experiment.py +0 -0
  300. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExperimentAnnotationSummary.py +0 -0
  301. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExperimentComparison.py +0 -0
  302. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExperimentRun.py +0 -0
  303. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExperimentRunAnnotation.py +0 -0
  304. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ExportedFile.py +0 -0
  305. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Functionality.py +0 -0
  306. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/GenerativeModel.py +0 -0
  307. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/GenerativeProvider.py +0 -0
  308. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Identifier.py +0 -0
  309. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/InferenceModel.py +0 -0
  310. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Inferences.py +0 -0
  311. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/InferencesRole.py +0 -0
  312. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/LabelFraction.py +0 -0
  313. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/MimeType.py +0 -0
  314. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ModelInterface.py +0 -0
  315. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/NumericRange.py +0 -0
  316. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PerformanceMetric.py +0 -0
  317. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PlaygroundModel.py +0 -0
  318. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Project.py +0 -0
  319. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ProjectSession.py +0 -0
  320. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ProjectTraceRetentionPolicy.py +0 -0
  321. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Prompt.py +0 -0
  322. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PromptLabel.py +0 -0
  323. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PromptResponse.py +0 -0
  324. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PromptVersion.py +0 -0
  325. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PromptVersionTag.py +0 -0
  326. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/PromptVersionTemplate.py +0 -0
  327. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ResponseFormat.py +0 -0
  328. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Retrieval.py +0 -0
  329. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ScalarDriftMetricEnum.py +0 -0
  330. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Segments.py +0 -0
  331. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ServerStatus.py +0 -0
  332. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SortDir.py +0 -0
  333. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Span.py +0 -0
  334. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SpanAnnotation.py +0 -0
  335. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SpanCostDetailSummaryEntry.py +0 -0
  336. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SpanCostSummary.py +0 -0
  337. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SpanIOValue.py +0 -0
  338. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/SystemApiKey.py +0 -0
  339. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/TimeSeries.py +0 -0
  340. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/TokenCountPromptDetails.py +0 -0
  341. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/TokenPrice.py +0 -0
  342. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/TokenUsage.py +0 -0
  343. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ToolDefinition.py +0 -0
  344. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/Trace.py +0 -0
  345. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/TraceAnnotation.py +0 -0
  346. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/UMAPPoints.py +0 -0
  347. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/User.py +0 -0
  348. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/UserApiKey.py +0 -0
  349. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/UserRole.py +0 -0
  350. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/ValidationResult.py +0 -0
  351. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/VectorDriftMetricEnum.py +0 -0
  352. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/__init__.py +0 -0
  353. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/node.py +0 -0
  354. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/types/pagination.py +0 -0
  355. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/api/utils.py +0 -0
  356. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/app.py +0 -0
  357. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/authorization.py +0 -0
  358. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/bearer_auth.py +0 -0
  359. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/__init__.py +0 -0
  360. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/cost_details_calculator.py +0 -0
  361. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/cost_model_lookup.py +0 -0
  362. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/helpers.py +0 -0
  363. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/model_cost_manifest.json +0 -0
  364. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/regex_specificity.py +0 -0
  365. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/cost_tracking/token_cost_calculator.py +0 -0
  366. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/daemons/__init__.py +0 -0
  367. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/daemons/db_disk_usage_monitor.py +0 -0
  368. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/daemons/generative_model_store.py +0 -0
  369. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/daemons/span_cost_calculator.py +0 -0
  370. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/dml_event.py +0 -0
  371. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/dml_event_handler.py +0 -0
  372. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/__init__.py +0 -0
  373. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/sender.py +0 -0
  374. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/templates/__init__.py +0 -0
  375. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/templates/db_disk_usage_notification.html +0 -0
  376. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/templates/password_reset.html +0 -0
  377. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/templates/welcome.html +0 -0
  378. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/email/types.py +0 -0
  379. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/experiments/__init__.py +0 -0
  380. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/experiments/utils.py +0 -0
  381. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/grpc_server.py +0 -0
  382. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/jwt_store.py +0 -0
  383. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/main.py +0 -0
  384. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/middleware/__init__.py +0 -0
  385. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/middleware/gzip.py +0 -0
  386. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/oauth2.py +0 -0
  387. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/openapi/__init__.py +0 -0
  388. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/rate_limiters.py +0 -0
  389. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/retention.py +0 -0
  390. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-114x114.png +0 -0
  391. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-120x120.png +0 -0
  392. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-144x144.png +0 -0
  393. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-152x152.png +0 -0
  394. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-180x180.png +0 -0
  395. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-72x72.png +0 -0
  396. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon-76x76.png +0 -0
  397. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/apple-touch-icon.png +0 -0
  398. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-BbqekBfb.js +0 -0
  399. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-CqDb5u4o.css +0 -0
  400. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-arizeai-CEwHhYfL.js +0 -0
  401. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-codemirror-CHApHLLJ.js +0 -0
  402. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-recharts-Bqf7C6Cm.js +0 -0
  403. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-shiki-BQ88Q1b1.js +0 -0
  404. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/assets/vendor-three-BLWp5bic.js +0 -0
  405. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/favicon.ico +0 -0
  406. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/static/modernizr.js +0 -0
  407. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/telemetry.py +0 -0
  408. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/templates/__init__.py +0 -0
  409. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/templates/index.html +0 -0
  410. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/thread_server.py +0 -0
  411. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/server/types.py +0 -0
  412. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/services.py +0 -0
  413. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/session/__init__.py +0 -0
  414. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/session/client.py +0 -0
  415. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/session/data_extractor.py +0 -0
  416. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/session/evaluation.py +0 -0
  417. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/session/session.py +0 -0
  418. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/settings.py +0 -0
  419. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/__init__.py +0 -0
  420. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/attributes.py +0 -0
  421. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/dsl/README.md +0 -0
  422. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/dsl/__init__.py +0 -0
  423. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/dsl/filter.py +0 -0
  424. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/dsl/helpers.py +0 -0
  425. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/dsl/query.py +0 -0
  426. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/errors.py +0 -0
  427. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/evaluation_conventions.py +0 -0
  428. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/exporter.py +0 -0
  429. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/fixtures.py +0 -0
  430. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/otel.py +0 -0
  431. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/projects.py +0 -0
  432. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/schemas.py +0 -0
  433. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/span_evaluations.py +0 -0
  434. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/span_json_decoder.py +0 -0
  435. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/span_json_encoder.py +0 -0
  436. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/trace_dataset.py +0 -0
  437. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/utils.py +0 -0
  438. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/v1/__init__.py +0 -0
  439. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/v1/evaluation_pb2.py +0 -0
  440. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/trace/v1/evaluation_pb2.pyi +0 -0
  441. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/__init__.py +0 -0
  442. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/client.py +0 -0
  443. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/deprecation.py +0 -0
  444. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/error_handling.py +0 -0
  445. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/json.py +0 -0
  446. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/logging.py +0 -0
  447. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/project.py +0 -0
  448. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/re.py +0 -0
  449. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/span_store.py +0 -0
  450. {arize_phoenix-11.18.0 → arize_phoenix-11.20.0}/src/phoenix/utilities/template_formatters.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: arize-phoenix
3
- Version: 11.18.0
3
+ Version: 11.20.0
4
4
  Summary: AI Observability and Evaluation
5
5
  Project-URL: Documentation, https://arize.com/docs/phoenix/
6
6
  Project-URL: Issues, https://github.com/Arize-ai/phoenix/issues
@@ -328,3 +328,30 @@ def _date_trunc_for_sqlite(
328
328
 
329
329
  # Convert back to UTC by subtracting the offset
330
330
  return func.datetime(t, f"{-utc_offset_minutes} minutes")
331
+
332
+
333
+ def get_ancestor_span_rowids(parent_id: str) -> Select[tuple[int]]:
334
+ """
335
+ Get all ancestor span IDs for a given parent_id using recursive CTE.
336
+
337
+ This function returns a query that finds all ancestors of a span with the given parent_id.
338
+ It uses a recursive Common Table Expression (CTE) to traverse up the span hierarchy.
339
+
340
+ Args:
341
+ parent_id: The span_id of the parent span to start the ancestor search from.
342
+
343
+ Returns:
344
+ A Select query that returns tuples of (span_id,) for all ancestor spans.
345
+ """
346
+ ancestors = (
347
+ select(models.Span.id, models.Span.parent_id)
348
+ .where(models.Span.span_id == parent_id)
349
+ .cte(recursive=True)
350
+ )
351
+ child = ancestors.alias()
352
+ ancestors = ancestors.union_all(
353
+ select(models.Span.id, models.Span.parent_id).join(
354
+ child, models.Span.span_id == child.c.parent_id
355
+ )
356
+ )
357
+ return select(ancestors.c.id)
@@ -1677,6 +1677,8 @@ class AnthropicStreamingClient(PlaygroundStreamingClient):
1677
1677
  model_names=[
1678
1678
  "claude-sonnet-4-0",
1679
1679
  "claude-sonnet-4-20250514",
1680
+ "claude-opus-4-1",
1681
+ "claude-opus-4-1-20250805",
1680
1682
  "claude-opus-4-0",
1681
1683
  "claude-opus-4-20250514",
1682
1684
  "claude-3-7-sonnet-latest",
@@ -1,14 +1,14 @@
1
1
  import re
2
2
  from collections import defaultdict
3
3
  from datetime import datetime
4
- from typing import Iterable, Iterator, Optional, Union
4
+ from typing import Any, Iterable, Iterator, Optional, Union
5
5
  from typing import cast as type_cast
6
6
 
7
7
  import numpy as np
8
8
  import numpy.typing as npt
9
9
  import strawberry
10
- from sqlalchemy import String, and_, cast, distinct, func, select, text
11
- from sqlalchemy.orm import joinedload
10
+ from sqlalchemy import ColumnElement, String, and_, case, cast, distinct, func, select, text
11
+ from sqlalchemy.orm import aliased, joinedload
12
12
  from starlette.authentication import UnauthenticatedUser
13
13
  from strawberry import ID, UNSET
14
14
  from strawberry.relay import Connection, GlobalID, Node
@@ -23,6 +23,7 @@ from phoenix.config import (
23
23
  from phoenix.db import models
24
24
  from phoenix.db.constants import DEFAULT_PROJECT_TRACE_RETENTION_POLICY_ID
25
25
  from phoenix.db.helpers import SupportedSQLDialect, exclude_experiment_projects
26
+ from phoenix.db.models import LatencyMs
26
27
  from phoenix.pointcloud.clustering import Hdbscan
27
28
  from phoenix.server.api.auth import MSG_ADMIN_ONLY, IsAdmin
28
29
  from phoenix.server.api.context import Context
@@ -106,6 +107,32 @@ class DbTableStats:
106
107
  num_bytes: float
107
108
 
108
109
 
110
+ @strawberry.type
111
+ class MetricCounts:
112
+ num_increases: int
113
+ num_decreases: int
114
+ num_equal: int
115
+
116
+
117
+ @strawberry.type
118
+ class CompareExperimentRunMetricCounts:
119
+ compare_experiment_id: GlobalID
120
+ latency: MetricCounts
121
+ prompt_token_count: MetricCounts
122
+ completion_token_count: MetricCounts
123
+ total_token_count: MetricCounts
124
+ total_cost: MetricCounts
125
+
126
+
127
+ @strawberry.type
128
+ class CompareExperimentRunAnnotationMetricCounts:
129
+ annotation_name: str
130
+ compare_experiment_id: GlobalID
131
+ num_increases: int
132
+ num_decreases: int
133
+ num_equal: int
134
+
135
+
109
136
  @strawberry.type
110
137
  class Query:
111
138
  @strawberry.field
@@ -481,6 +508,409 @@ class Query:
481
508
  has_next_page=has_next_page,
482
509
  )
483
510
 
511
+ @strawberry.field
512
+ async def compare_experiment_run_metric_counts(
513
+ self,
514
+ info: Info[Context, None],
515
+ base_experiment_id: GlobalID,
516
+ compare_experiment_ids: list[GlobalID],
517
+ ) -> list[CompareExperimentRunMetricCounts]:
518
+ if base_experiment_id in compare_experiment_ids:
519
+ raise BadRequest("Compare experiment IDs cannot contain the base experiment ID")
520
+ if not compare_experiment_ids:
521
+ raise BadRequest("At least one compare experiment ID must be provided")
522
+ if len(set(compare_experiment_ids)) < len(compare_experiment_ids):
523
+ raise BadRequest("Compare experiment IDs must be unique")
524
+
525
+ try:
526
+ base_experiment_rowid = from_global_id_with_expected_type(
527
+ base_experiment_id, models.Experiment.__name__
528
+ )
529
+ except ValueError:
530
+ raise BadRequest(f"Invalid base experiment ID: {base_experiment_id}")
531
+
532
+ compare_experiment_rowids = []
533
+ for compare_experiment_id in compare_experiment_ids:
534
+ try:
535
+ compare_experiment_rowids.append(
536
+ from_global_id_with_expected_type(
537
+ compare_experiment_id, models.Experiment.__name__
538
+ )
539
+ )
540
+ except ValueError:
541
+ raise BadRequest(f"Invalid compare experiment ID: {compare_experiment_id}")
542
+
543
+ base_experiment_runs = (
544
+ select(models.ExperimentRun)
545
+ .where(models.ExperimentRun.experiment_id == base_experiment_rowid)
546
+ .subquery()
547
+ .alias("base_experiment_runs")
548
+ )
549
+ base_experiment_traces = aliased(models.Trace, name="base_experiment_traces")
550
+ base_experiment_span_costs = (
551
+ select(
552
+ models.SpanCost.trace_rowid,
553
+ func.coalesce(func.sum(models.SpanCost.total_tokens), 0).label("total_tokens"),
554
+ func.coalesce(func.sum(models.SpanCost.prompt_tokens), 0).label("prompt_tokens"),
555
+ func.coalesce(func.sum(models.SpanCost.completion_tokens), 0).label(
556
+ "completion_tokens"
557
+ ),
558
+ func.coalesce(func.sum(models.SpanCost.total_cost), 0).label("total_cost"),
559
+ )
560
+ .select_from(models.SpanCost)
561
+ .group_by(
562
+ models.SpanCost.trace_rowid,
563
+ )
564
+ .subquery()
565
+ .alias("base_experiment_span_costs")
566
+ )
567
+
568
+ query = (
569
+ select() # add selected columns below
570
+ .select_from(base_experiment_runs)
571
+ .join(
572
+ base_experiment_traces,
573
+ onclause=base_experiment_runs.c.trace_id == base_experiment_traces.trace_id,
574
+ isouter=True,
575
+ )
576
+ .join(
577
+ base_experiment_span_costs,
578
+ onclause=base_experiment_traces.id == base_experiment_span_costs.c.trace_rowid,
579
+ isouter=True,
580
+ )
581
+ )
582
+
583
+ base_experiment_run_latency = LatencyMs(
584
+ base_experiment_runs.c.start_time, base_experiment_runs.c.end_time
585
+ ).label("base_experiment_run_latency_ms")
586
+ base_experiment_run_prompt_token_count = base_experiment_span_costs.c.prompt_tokens
587
+ base_experiment_run_completion_token_count = base_experiment_span_costs.c.completion_tokens
588
+ base_experiment_run_total_token_count = base_experiment_span_costs.c.total_tokens
589
+ base_experiment_run_total_cost = base_experiment_span_costs.c.total_cost
590
+
591
+ for compare_experiment_index, compare_experiment_rowid in enumerate(
592
+ compare_experiment_rowids
593
+ ):
594
+ compare_experiment_runs = (
595
+ select(models.ExperimentRun)
596
+ .where(models.ExperimentRun.experiment_id == compare_experiment_rowid)
597
+ .subquery()
598
+ .alias(f"comp_exp_{compare_experiment_index}_runs")
599
+ )
600
+ compare_experiment_traces = aliased(
601
+ models.Trace, name=f"comp_exp_{compare_experiment_index}_traces"
602
+ )
603
+ compare_experiment_span_costs = (
604
+ select(
605
+ models.SpanCost.trace_rowid,
606
+ func.coalesce(func.sum(models.SpanCost.total_tokens), 0).label("total_tokens"),
607
+ func.coalesce(func.sum(models.SpanCost.prompt_tokens), 0).label(
608
+ "prompt_tokens"
609
+ ),
610
+ func.coalesce(func.sum(models.SpanCost.completion_tokens), 0).label(
611
+ "completion_tokens"
612
+ ),
613
+ func.coalesce(func.sum(models.SpanCost.total_cost), 0).label("total_cost"),
614
+ )
615
+ .select_from(models.SpanCost)
616
+ .group_by(models.SpanCost.trace_rowid)
617
+ .subquery()
618
+ .alias(f"comp_exp_{compare_experiment_index}_span_costs")
619
+ )
620
+ compare_experiment_run_latency = LatencyMs(
621
+ compare_experiment_runs.c.start_time, compare_experiment_runs.c.end_time
622
+ ).label(f"comp_exp_{compare_experiment_index}_run_latency_ms")
623
+ compare_experiment_run_prompt_token_count = (
624
+ compare_experiment_span_costs.c.prompt_tokens
625
+ )
626
+ compare_experiment_run_completion_token_count = (
627
+ compare_experiment_span_costs.c.completion_tokens
628
+ )
629
+ compare_experiment_run_total_token_count = compare_experiment_span_costs.c.total_tokens
630
+ compare_experiment_run_total_cost = compare_experiment_span_costs.c.total_cost
631
+
632
+ query = (
633
+ query.add_columns(
634
+ _count_rows(
635
+ base_experiment_run_latency < compare_experiment_run_latency,
636
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_increased_latency"),
637
+ _count_rows(
638
+ base_experiment_run_latency > compare_experiment_run_latency,
639
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_decreased_latency"),
640
+ _count_rows(
641
+ base_experiment_run_latency == compare_experiment_run_latency,
642
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_equal_latency"),
643
+ _count_rows(
644
+ base_experiment_run_prompt_token_count
645
+ < compare_experiment_run_prompt_token_count,
646
+ ).label(
647
+ f"comp_exp_{compare_experiment_index}_num_runs_increased_prompt_token_count"
648
+ ),
649
+ _count_rows(
650
+ base_experiment_run_prompt_token_count
651
+ > compare_experiment_run_prompt_token_count,
652
+ ).label(
653
+ f"comp_exp_{compare_experiment_index}_num_runs_decreased_prompt_token_count"
654
+ ),
655
+ _count_rows(
656
+ base_experiment_run_prompt_token_count
657
+ == compare_experiment_run_prompt_token_count,
658
+ ).label(
659
+ f"comp_exp_{compare_experiment_index}_num_runs_equal_prompt_token_count"
660
+ ),
661
+ _count_rows(
662
+ base_experiment_run_completion_token_count
663
+ < compare_experiment_run_completion_token_count,
664
+ ).label(
665
+ f"comp_exp_{compare_experiment_index}_num_runs_increased_completion_token_count"
666
+ ),
667
+ _count_rows(
668
+ base_experiment_run_completion_token_count
669
+ > compare_experiment_run_completion_token_count,
670
+ ).label(
671
+ f"comp_exp_{compare_experiment_index}_num_runs_decreased_completion_token_count"
672
+ ),
673
+ _count_rows(
674
+ base_experiment_run_completion_token_count
675
+ == compare_experiment_run_completion_token_count,
676
+ ).label(
677
+ f"comp_exp_{compare_experiment_index}_num_runs_equal_completion_token_count"
678
+ ),
679
+ _count_rows(
680
+ base_experiment_run_total_token_count
681
+ < compare_experiment_run_total_token_count,
682
+ ).label(
683
+ f"comp_exp_{compare_experiment_index}_num_runs_increased_total_token_count"
684
+ ),
685
+ _count_rows(
686
+ base_experiment_run_total_token_count
687
+ > compare_experiment_run_total_token_count,
688
+ ).label(
689
+ f"comp_exp_{compare_experiment_index}_num_runs_decreased_total_token_count"
690
+ ),
691
+ _count_rows(
692
+ base_experiment_run_total_token_count
693
+ == compare_experiment_run_total_token_count,
694
+ ).label(
695
+ f"comp_exp_{compare_experiment_index}_num_runs_equal_total_token_count"
696
+ ),
697
+ _count_rows(
698
+ base_experiment_run_total_cost < compare_experiment_run_total_cost,
699
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_increased_total_cost"),
700
+ _count_rows(
701
+ base_experiment_run_total_cost > compare_experiment_run_total_cost,
702
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_decreased_total_cost"),
703
+ _count_rows(
704
+ base_experiment_run_total_cost == compare_experiment_run_total_cost,
705
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_equal_total_cost"),
706
+ )
707
+ .join(
708
+ compare_experiment_runs,
709
+ onclause=base_experiment_runs.c.dataset_example_id
710
+ == compare_experiment_runs.c.dataset_example_id,
711
+ isouter=True,
712
+ )
713
+ .join(
714
+ compare_experiment_traces,
715
+ onclause=compare_experiment_runs.c.trace_id
716
+ == compare_experiment_traces.trace_id,
717
+ isouter=True,
718
+ )
719
+ .join(
720
+ compare_experiment_span_costs,
721
+ onclause=compare_experiment_traces.id
722
+ == compare_experiment_span_costs.c.trace_rowid,
723
+ isouter=True,
724
+ )
725
+ )
726
+
727
+ async with info.context.db() as session:
728
+ result = (await session.execute(query)).first()
729
+ assert result is not None
730
+
731
+ num_columns_per_compare_experiment = len(query.columns) // len(compare_experiment_ids)
732
+ counts = []
733
+ for compare_experiment_index, compare_experiment_id in enumerate(compare_experiment_ids):
734
+ start_index = compare_experiment_index * num_columns_per_compare_experiment
735
+ end_index = start_index + num_columns_per_compare_experiment
736
+ (
737
+ num_runs_with_increased_latency,
738
+ num_runs_with_decreased_latency,
739
+ num_runs_with_equal_latency,
740
+ num_runs_with_increased_prompt_token_count,
741
+ num_runs_with_decreased_prompt_token_count,
742
+ num_runs_with_equal_prompt_token_count,
743
+ num_runs_with_increased_completion_token_count,
744
+ num_runs_with_decreased_completion_token_count,
745
+ num_runs_with_equal_completion_token_count,
746
+ num_runs_with_increased_total_token_count,
747
+ num_runs_with_decreased_total_token_count,
748
+ num_runs_with_equal_total_token_count,
749
+ num_runs_with_increased_total_cost,
750
+ num_runs_with_decreased_total_cost,
751
+ num_runs_with_equal_total_cost,
752
+ ) = result[start_index:end_index]
753
+ counts.append(
754
+ CompareExperimentRunMetricCounts(
755
+ compare_experiment_id=compare_experiment_id,
756
+ latency=MetricCounts(
757
+ num_increases=num_runs_with_increased_latency,
758
+ num_decreases=num_runs_with_decreased_latency,
759
+ num_equal=num_runs_with_equal_latency,
760
+ ),
761
+ prompt_token_count=MetricCounts(
762
+ num_increases=num_runs_with_increased_prompt_token_count,
763
+ num_decreases=num_runs_with_decreased_prompt_token_count,
764
+ num_equal=num_runs_with_equal_prompt_token_count,
765
+ ),
766
+ completion_token_count=MetricCounts(
767
+ num_increases=num_runs_with_increased_completion_token_count,
768
+ num_decreases=num_runs_with_decreased_completion_token_count,
769
+ num_equal=num_runs_with_equal_completion_token_count,
770
+ ),
771
+ total_token_count=MetricCounts(
772
+ num_increases=num_runs_with_increased_total_token_count,
773
+ num_decreases=num_runs_with_decreased_total_token_count,
774
+ num_equal=num_runs_with_equal_total_token_count,
775
+ ),
776
+ total_cost=MetricCounts(
777
+ num_increases=num_runs_with_increased_total_cost,
778
+ num_decreases=num_runs_with_decreased_total_cost,
779
+ num_equal=num_runs_with_equal_total_cost,
780
+ ),
781
+ )
782
+ )
783
+ return counts
784
+
785
+ @strawberry.field
786
+ async def compare_experiment_run_annotation_metric_counts(
787
+ self,
788
+ info: Info[Context, None],
789
+ base_experiment_id: GlobalID,
790
+ compare_experiment_ids: list[GlobalID],
791
+ ) -> list[CompareExperimentRunAnnotationMetricCounts]:
792
+ if base_experiment_id in compare_experiment_ids:
793
+ raise BadRequest("Compare experiment IDs cannot contain the base experiment ID")
794
+ if not compare_experiment_ids:
795
+ raise BadRequest("At least one compare experiment ID must be provided")
796
+ if len(set(compare_experiment_ids)) < len(compare_experiment_ids):
797
+ raise BadRequest("Compare experiment IDs must be unique")
798
+
799
+ try:
800
+ base_experiment_rowid = from_global_id_with_expected_type(
801
+ base_experiment_id, models.Experiment.__name__
802
+ )
803
+ except ValueError:
804
+ raise BadRequest(f"Invalid base experiment ID: {base_experiment_id}")
805
+
806
+ compare_experiment_rowids = []
807
+ for compare_experiment_id in compare_experiment_ids:
808
+ try:
809
+ compare_experiment_rowids.append(
810
+ from_global_id_with_expected_type(
811
+ compare_experiment_id, models.Experiment.__name__
812
+ )
813
+ )
814
+ except ValueError:
815
+ raise BadRequest(f"Invalid compare experiment ID: {compare_experiment_id}")
816
+
817
+ base_experiment_runs = (
818
+ select(models.ExperimentRun)
819
+ .where(
820
+ models.ExperimentRun.experiment_id == base_experiment_rowid,
821
+ )
822
+ .subquery()
823
+ .alias("base_experiment_runs")
824
+ )
825
+ base_experiment_run_annotations = aliased(
826
+ models.ExperimentRunAnnotation, name="base_experiment_run_annotations"
827
+ )
828
+ query = (
829
+ select(base_experiment_run_annotations.name)
830
+ .select_from(base_experiment_runs)
831
+ .join(
832
+ base_experiment_run_annotations,
833
+ onclause=base_experiment_runs.c.id
834
+ == base_experiment_run_annotations.experiment_run_id,
835
+ isouter=True,
836
+ )
837
+ .group_by(base_experiment_run_annotations.name)
838
+ .order_by(base_experiment_run_annotations.name)
839
+ )
840
+ for compare_experiment_index, compare_experiment_rowid in enumerate(
841
+ compare_experiment_rowids
842
+ ):
843
+ compare_experiment_runs = (
844
+ select(models.ExperimentRun)
845
+ .where(
846
+ models.ExperimentRun.experiment_id == compare_experiment_rowid,
847
+ )
848
+ .subquery()
849
+ .alias(f"comp_exp_{compare_experiment_index}_runs")
850
+ )
851
+ compare_experiment_run_annotations = aliased(
852
+ models.ExperimentRunAnnotation,
853
+ name=f"comp_exp_{compare_experiment_index}_run_annotations",
854
+ )
855
+ query = (
856
+ query.add_columns(
857
+ _count_rows(
858
+ base_experiment_run_annotations.score
859
+ < compare_experiment_run_annotations.score,
860
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_increased_score"),
861
+ _count_rows(
862
+ base_experiment_run_annotations.score
863
+ > compare_experiment_run_annotations.score,
864
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_decreased_score"),
865
+ _count_rows(
866
+ base_experiment_run_annotations.score
867
+ == compare_experiment_run_annotations.score,
868
+ ).label(f"comp_exp_{compare_experiment_index}_num_runs_equal_score"),
869
+ )
870
+ .join(
871
+ compare_experiment_runs,
872
+ onclause=base_experiment_runs.c.dataset_example_id
873
+ == compare_experiment_runs.c.dataset_example_id,
874
+ isouter=True,
875
+ )
876
+ .join(
877
+ compare_experiment_run_annotations,
878
+ onclause=compare_experiment_runs.c.id
879
+ == compare_experiment_run_annotations.experiment_run_id,
880
+ isouter=True,
881
+ )
882
+ .where(
883
+ base_experiment_run_annotations.name == compare_experiment_run_annotations.name
884
+ )
885
+ )
886
+ async with info.context.db() as session:
887
+ result = (await session.execute(query)).all()
888
+ assert result is not None
889
+ num_columns_per_compare_experiment = (len(query.columns) - 1) // len(compare_experiment_ids)
890
+ metric_counts = []
891
+ for record in result:
892
+ annotation_name, *counts = record
893
+ for compare_experiment_index, compare_experiment_id in enumerate(
894
+ compare_experiment_ids
895
+ ):
896
+ start_index = compare_experiment_index * num_columns_per_compare_experiment
897
+ end_index = start_index + num_columns_per_compare_experiment
898
+ (
899
+ num_runs_with_increased_score,
900
+ num_runs_with_decreased_score,
901
+ num_runs_with_equal_score,
902
+ ) = counts[start_index:end_index]
903
+ metric_counts.append(
904
+ CompareExperimentRunAnnotationMetricCounts(
905
+ annotation_name=annotation_name,
906
+ compare_experiment_id=compare_experiment_id,
907
+ num_increases=num_runs_with_increased_score,
908
+ num_decreases=num_runs_with_decreased_score,
909
+ num_equal=num_runs_with_equal_score,
910
+ )
911
+ )
912
+ return metric_counts
913
+
484
914
  @strawberry.field
485
915
  async def validate_experiment_run_filter_condition(
486
916
  self,
@@ -1106,3 +1536,20 @@ def _longest_matching_prefix(s: str, prefixes: Iterable[str]) -> str:
1106
1536
  if s.startswith(prefix) and len(prefix) > len(longest):
1107
1537
  longest = prefix
1108
1538
  return longest
1539
+
1540
+
1541
+ def _count_rows(
1542
+ condition: ColumnElement[Any],
1543
+ ) -> ColumnElement[Any]:
1544
+ """
1545
+ Returns an expression that counts the number of rows satisfying the condition.
1546
+ """
1547
+ return func.coalesce(
1548
+ func.sum(
1549
+ case(
1550
+ (condition, 1),
1551
+ else_=0,
1552
+ )
1553
+ ),
1554
+ 0,
1555
+ )
@@ -15,6 +15,7 @@ from strawberry.relay import GlobalID
15
15
  from phoenix.config import DEFAULT_PROJECT_NAME
16
16
  from phoenix.db import models
17
17
  from phoenix.db.helpers import exclude_experiment_projects
18
+ from phoenix.db.models import UserRoleName
18
19
  from phoenix.server.api.routers.v1.models import V1RoutesBaseModel
19
20
  from phoenix.server.api.routers.v1.utils import (
20
21
  PaginatedResponseBody,
@@ -258,8 +259,8 @@ async def update_project(
258
259
  .join(models.User)
259
260
  .where(models.User.id == int(request.user.identity))
260
261
  )
261
- role_name = await session.scalar(stmt)
262
- if role_name != "ADMIN":
262
+ role_name: UserRoleName = await session.scalar(stmt)
263
+ if role_name != "ADMIN" and role_name != "SYSTEM":
263
264
  raise HTTPException(
264
265
  status_code=HTTP_403_FORBIDDEN,
265
266
  detail="Only admins can update projects",
@@ -318,8 +319,8 @@ async def delete_project(
318
319
  .join(models.User)
319
320
  .where(models.User.id == int(request.user.identity))
320
321
  )
321
- role_name = await session.scalar(stmt)
322
- if role_name != "ADMIN":
322
+ role_name: UserRoleName = await session.scalar(stmt)
323
+ if role_name != "ADMIN" and role_name != "SYSTEM":
323
324
  raise HTTPException(
324
325
  status_code=HTTP_403_FORBIDDEN,
325
326
  detail="Only admins can delete projects",