arize-phoenix 11.28.0__tar.gz → 11.30.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 (455) hide show
  1. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/PKG-INFO +3 -2
  2. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/pyproject.toml +2 -1
  3. arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/average_experiment_run_latency.py +47 -0
  4. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_evaluations.py +3 -3
  5. arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/experiment_annotation_summaries.py +133 -0
  6. arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/experiment_error_rates.py +51 -0
  7. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/__init__.py +2 -0
  8. arize_phoenix-11.30.0/src/phoenix/server/api/routers/v1/documents.py +175 -0
  9. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/spans.py +5 -3
  10. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/traces.py +5 -3
  11. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Dataset.py +69 -21
  12. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Evaluation.py +5 -4
  13. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Experiment.py +4 -5
  14. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Span.py +2 -2
  15. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/.vite/manifest.json +9 -9
  16. arize_phoenix-11.28.0/src/phoenix/server/static/assets/components-C3HQDu_r.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/components-BBwXqJXQ.js +4 -3
  17. arize_phoenix-11.28.0/src/phoenix/server/static/assets/index-C-sjZRYC.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/index-C_gU3x10.js +1 -1
  18. arize_phoenix-11.28.0/src/phoenix/server/static/assets/pages-DvrxSPg3.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/pages-YmQb55Uo.js +399 -392
  19. arize_phoenix-11.30.0/src/phoenix/version.py +1 -0
  20. arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/average_experiment_run_latency.py +0 -54
  21. arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/experiment_annotation_summaries.py +0 -79
  22. arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/experiment_error_rates.py +0 -58
  23. arize_phoenix-11.28.0/src/phoenix/version.py +0 -1
  24. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/.gitignore +0 -0
  25. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/IP_NOTICE +0 -0
  26. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/LICENSE +0 -0
  27. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/README.md +0 -0
  28. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/__init__.py +0 -0
  29. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/auth.py +0 -0
  30. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/config.py +0 -0
  31. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/__init__.py +0 -0
  32. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/embedding_dimension.py +0 -0
  33. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model.py +0 -0
  34. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model_schema.py +0 -0
  35. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model_schema_adapter.py +0 -0
  36. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/datetime_utils.py +0 -0
  37. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/README.md +0 -0
  38. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/__init__.py +0 -0
  39. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/alembic.ini +0 -0
  40. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/bulk_inserter.py +0 -0
  41. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/constants.py +0 -0
  42. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/engines.py +0 -0
  43. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/enums.py +0 -0
  44. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/facilitator.py +0 -0
  45. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/helpers.py +0 -0
  46. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/__init__.py +0 -0
  47. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/constants.py +0 -0
  48. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/dataset.py +0 -0
  49. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/document_annotation.py +0 -0
  50. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/evaluation.py +0 -0
  51. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/helpers.py +0 -0
  52. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/span.py +0 -0
  53. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/span_annotation.py +0 -0
  54. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/trace_annotation.py +0 -0
  55. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/types.py +0 -0
  56. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrate.py +0 -0
  57. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/__init__.py +0 -0
  58. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/data_migration_scripts/__init__.py +0 -0
  59. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/data_migration_scripts/populate_project_sessions.py +0 -0
  60. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/env.py +0 -0
  61. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/script.py.mako +0 -0
  62. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/10460e46d750_datasets.py +0 -0
  63. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/2f9d1a65945f_annotation_config_migration.py +0 -0
  64. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/3be8647b87d8_add_token_columns_to_spans_table.py +0 -0
  65. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/4ded9e43755f_create_project_sessions_table.py +0 -0
  66. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/6a88424799fe_update_users_with_auth_method.py +0 -0
  67. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/8a3764fe7f1a_change_jsonb_to_json_for_prompts.py +0 -0
  68. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/a20694b15f82_cost.py +0 -0
  69. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/bb8139330879_create_project_trace_retention_policies_table.py +0 -0
  70. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/bc8fea3c2bc8_add_prompt_tables.py +0 -0
  71. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/cd164e83824f_users_and_tokens.py +0 -0
  72. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/cf03bd6bae1d_init.py +0 -0
  73. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/models.py +0 -0
  74. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/pg_config.py +0 -0
  75. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/__init__.py +0 -0
  76. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/annotation_configs.py +0 -0
  77. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/db_models.py +0 -0
  78. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/identifier.py +0 -0
  79. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/model_provider.py +0 -0
  80. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/token_price_customization.py +0 -0
  81. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/trace_retention.py +0 -0
  82. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/exceptions.py +0 -0
  83. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/__init__.py +0 -0
  84. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/__init__.py +0 -0
  85. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/base.py +0 -0
  86. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/code_evaluators.py +0 -0
  87. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/llm_evaluators.py +0 -0
  88. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/utils.py +0 -0
  89. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/functions.py +0 -0
  90. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/tracing.py +0 -0
  91. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/types.py +0 -0
  92. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/utils.py +0 -0
  93. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/__init__.py +0 -0
  94. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/errors.py +0 -0
  95. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/fixtures.py +0 -0
  96. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/inferences.py +0 -0
  97. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/schema.py +0 -0
  98. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/validation.py +0 -0
  99. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/__init__.py +0 -0
  100. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_config.py +0 -0
  101. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_filter.py +0 -0
  102. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_formatter.py +0 -0
  103. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/README.md +0 -0
  104. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/__init__.py +0 -0
  105. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/binning.py +0 -0
  106. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/metrics.py +0 -0
  107. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/mixins.py +0 -0
  108. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/retrieval_metrics.py +0 -0
  109. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/timeseries.py +0 -0
  110. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/wrappers.py +0 -0
  111. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/__init__.py +0 -0
  112. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/clustering.py +0 -0
  113. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/pointcloud.py +0 -0
  114. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/projectors.py +0 -0
  115. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/umap_parameters.py +0 -0
  116. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/py.typed +0 -0
  117. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/__init__.py +0 -0
  118. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/README.md +0 -0
  119. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/__init__.py +0 -0
  120. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/auth.py +0 -0
  121. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/context.py +0 -0
  122. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/__init__.py +0 -0
  123. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/annotation_configs_by_project.py +0 -0
  124. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/annotation_summaries.py +0 -0
  125. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/cache/__init__.py +0 -0
  126. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/cache/two_tier_cache.py +0 -0
  127. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -0
  128. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/dataset_example_spans.py +0 -0
  129. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_evaluation_summaries.py +0 -0
  130. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_retrieval_metrics.py +0 -0
  131. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_run_annotations.py +0 -0
  132. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_run_counts.py +0 -0
  133. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_sequence_number.py +0 -0
  134. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/last_used_times_by_generative_model_id.py +0 -0
  135. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/latency_ms_quantile.py +0 -0
  136. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/min_start_or_max_end_times.py +0 -0
  137. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/num_child_spans.py +0 -0
  138. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/num_spans_per_trace.py +0 -0
  139. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/project_by_name.py +0 -0
  140. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/project_ids_by_trace_retention_policy_id.py +0 -0
  141. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/prompt_version_sequence_number.py +0 -0
  142. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/record_counts.py +0 -0
  143. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_io.py +0 -0
  144. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_num_traces.py +0 -0
  145. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_num_traces_with_error.py +0 -0
  146. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_token_usages.py +0 -0
  147. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_trace_latency_ms_quantile.py +0 -0
  148. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_annotations.py +0 -0
  149. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_by_id.py +0 -0
  150. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_by_span.py +0 -0
  151. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_generative_model.py +0 -0
  152. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_project_session.py +0 -0
  153. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_span.py +0 -0
  154. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_trace.py +0 -0
  155. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_details_by_span_cost.py +0 -0
  156. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment.py +0 -0
  157. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment_run.py +0 -0
  158. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_generative_model.py +0 -0
  159. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project.py +0 -0
  160. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project_session.py +0 -0
  161. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_trace.py +0 -0
  162. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_costs.py +0 -0
  163. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_dataset_examples.py +0 -0
  164. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_descendants.py +0 -0
  165. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_projects.py +0 -0
  166. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/table_fields.py +0 -0
  167. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/token_counts.py +0 -0
  168. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_by_trace_ids.py +0 -0
  169. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_retention_policy_id_by_project_id.py +0 -0
  170. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_root_spans.py +0 -0
  171. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/types.py +0 -0
  172. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/user_roles.py +0 -0
  173. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/users.py +0 -0
  174. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/exceptions.py +0 -0
  175. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/__init__.py +0 -0
  176. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/annotations.py +0 -0
  177. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/dataset_helpers.py +0 -0
  178. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/experiment_run_filters.py +0 -0
  179. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_clients.py +0 -0
  180. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_registry.py +0 -0
  181. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_spans.py +0 -0
  182. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/__init__.py +0 -0
  183. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/__init__.py +0 -0
  184. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/anthropic.py +0 -0
  185. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/aws.py +0 -0
  186. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/openai.py +0 -0
  187. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/models.py +0 -0
  188. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/AddExamplesToDatasetInput.py +0 -0
  189. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/AddSpansToDatasetInput.py +0 -0
  190. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ChatCompletionInput.py +0 -0
  191. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ChatCompletionMessageInput.py +0 -0
  192. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ClearProjectInput.py +0 -0
  193. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ClusterInput.py +0 -0
  194. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/Coordinates.py +0 -0
  195. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateDatasetInput.py +0 -0
  196. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateProjectInput.py +0 -0
  197. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateSpanAnnotationInput.py +0 -0
  198. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateTraceAnnotationInput.py +0 -0
  199. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DataQualityMetricInput.py +0 -0
  200. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetExampleInput.py +0 -0
  201. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetFilter.py +0 -0
  202. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetSort.py +0 -0
  203. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetVersionSort.py +0 -0
  204. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteAnnotationsInput.py +0 -0
  205. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteDatasetExamplesInput.py +0 -0
  206. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteDatasetInput.py +0 -0
  207. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteExperimentsInput.py +0 -0
  208. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DimensionFilter.py +0 -0
  209. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DimensionInput.py +0 -0
  210. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/GenerativeCredentialInput.py +0 -0
  211. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/GenerativeModelInput.py +0 -0
  212. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/Granularity.py +0 -0
  213. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/InvocationParameters.py +0 -0
  214. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchAnnotationInput.py +0 -0
  215. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchDatasetExamplesInput.py +0 -0
  216. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchDatasetInput.py +0 -0
  217. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PerformanceMetricInput.py +0 -0
  218. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectFilter.py +0 -0
  219. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectSessionSort.py +0 -0
  220. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectSort.py +0 -0
  221. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptFilter.py +0 -0
  222. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptTemplateOptions.py +0 -0
  223. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptVersionInput.py +0 -0
  224. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanAnnotationFilter.py +0 -0
  225. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanAnnotationSort.py +0 -0
  226. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanSort.py +0 -0
  227. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TimeBinConfig.py +0 -0
  228. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TimeRange.py +0 -0
  229. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TraceAnnotationSort.py +0 -0
  230. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/UserRoleInput.py +0 -0
  231. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/__init__.py +0 -0
  232. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/interceptor.py +0 -0
  233. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/__init__.py +0 -0
  234. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/annotation_config_mutations.py +0 -0
  235. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/api_key_mutations.py +0 -0
  236. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/chat_mutations.py +0 -0
  237. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/dataset_mutations.py +0 -0
  238. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/experiment_mutations.py +0 -0
  239. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/export_events_mutations.py +0 -0
  240. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/model_mutations.py +0 -0
  241. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/project_mutations.py +0 -0
  242. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +0 -0
  243. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_label_mutations.py +0 -0
  244. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_mutations.py +0 -0
  245. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_version_tag_mutations.py +0 -0
  246. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/span_annotations_mutations.py +0 -0
  247. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/trace_annotations_mutations.py +0 -0
  248. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/trace_mutations.py +0 -0
  249. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/user_mutations.py +0 -0
  250. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/__init__.py +0 -0
  251. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/main.py +0 -0
  252. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/schema.py +0 -0
  253. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/queries.py +0 -0
  254. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/__init__.py +0 -0
  255. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/auth.py +0 -0
  256. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/embeddings.py +0 -0
  257. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/oauth2.py +0 -0
  258. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/utils.py +0 -0
  259. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/annotation_configs.py +0 -0
  260. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/annotations.py +0 -0
  261. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/datasets.py +0 -0
  262. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/evaluations.py +0 -0
  263. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiment_evaluations.py +0 -0
  264. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiment_runs.py +0 -0
  265. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiments.py +0 -0
  266. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/models.py +0 -0
  267. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/projects.py +0 -0
  268. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/prompts.py +0 -0
  269. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/users.py +0 -0
  270. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/utils.py +0 -0
  271. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/schema.py +0 -0
  272. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/subscriptions.py +0 -0
  273. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Annotation.py +0 -0
  274. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationConfig.py +0 -0
  275. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationSource.py +0 -0
  276. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationSummary.py +0 -0
  277. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotatorKind.py +0 -0
  278. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ApiKey.py +0 -0
  279. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AuthMethod.py +0 -0
  280. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ChatCompletionMessageRole.py +0 -0
  281. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +0 -0
  282. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Cluster.py +0 -0
  283. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CostBreakdown.py +0 -0
  284. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CreateDatasetPayload.py +0 -0
  285. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CronExpression.py +0 -0
  286. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DataQualityMetric.py +0 -0
  287. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetExample.py +0 -0
  288. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetExampleRevision.py +0 -0
  289. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetValues.py +0 -0
  290. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetVersion.py +0 -0
  291. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Dimension.py +0 -0
  292. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionDataType.py +0 -0
  293. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionShape.py +0 -0
  294. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionType.py +0 -0
  295. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionWithValue.py +0 -0
  296. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DocumentEvaluationSummary.py +0 -0
  297. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DocumentRetrievalMetrics.py +0 -0
  298. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EmbeddingDimension.py +0 -0
  299. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EmbeddingMetadata.py +0 -0
  300. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EvaluationSummary.py +0 -0
  301. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Event.py +0 -0
  302. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EventMetadata.py +0 -0
  303. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExampleRevisionInterface.py +0 -0
  304. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentAnnotationSummary.py +0 -0
  305. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentComparison.py +0 -0
  306. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentRun.py +0 -0
  307. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentRunAnnotation.py +0 -0
  308. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExportedFile.py +0 -0
  309. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Functionality.py +0 -0
  310. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/GenerativeModel.py +0 -0
  311. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/GenerativeProvider.py +0 -0
  312. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Identifier.py +0 -0
  313. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/InferenceModel.py +0 -0
  314. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Inferences.py +0 -0
  315. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/InferencesRole.py +0 -0
  316. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/LabelFraction.py +0 -0
  317. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/MimeType.py +0 -0
  318. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ModelInterface.py +0 -0
  319. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/NumericRange.py +0 -0
  320. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PerformanceMetric.py +0 -0
  321. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PlaygroundModel.py +0 -0
  322. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Project.py +0 -0
  323. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ProjectSession.py +0 -0
  324. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ProjectTraceRetentionPolicy.py +0 -0
  325. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Prompt.py +0 -0
  326. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptLabel.py +0 -0
  327. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptResponse.py +0 -0
  328. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersion.py +0 -0
  329. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersionTag.py +0 -0
  330. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersionTemplate.py +0 -0
  331. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ResponseFormat.py +0 -0
  332. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Retrieval.py +0 -0
  333. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ScalarDriftMetricEnum.py +0 -0
  334. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Segments.py +0 -0
  335. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ServerStatus.py +0 -0
  336. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SortDir.py +0 -0
  337. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanAnnotation.py +0 -0
  338. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanCostDetailSummaryEntry.py +0 -0
  339. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanCostSummary.py +0 -0
  340. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanIOValue.py +0 -0
  341. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SystemApiKey.py +0 -0
  342. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TimeSeries.py +0 -0
  343. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenCountPromptDetails.py +0 -0
  344. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenPrice.py +0 -0
  345. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenUsage.py +0 -0
  346. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ToolDefinition.py +0 -0
  347. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Trace.py +0 -0
  348. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TraceAnnotation.py +0 -0
  349. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UMAPPoints.py +0 -0
  350. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/User.py +0 -0
  351. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UserApiKey.py +0 -0
  352. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UserRole.py +0 -0
  353. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ValidationResult.py +0 -0
  354. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/VectorDriftMetricEnum.py +0 -0
  355. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/__init__.py +0 -0
  356. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/node.py +0 -0
  357. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/pagination.py +0 -0
  358. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/utils.py +0 -0
  359. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/app.py +0 -0
  360. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/authorization.py +0 -0
  361. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/bearer_auth.py +0 -0
  362. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/__init__.py +0 -0
  363. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/cost_details_calculator.py +0 -0
  364. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/cost_model_lookup.py +0 -0
  365. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/helpers.py +0 -0
  366. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/model_cost_manifest.json +0 -0
  367. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/regex_specificity.py +0 -0
  368. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/token_cost_calculator.py +0 -0
  369. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/__init__.py +0 -0
  370. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/db_disk_usage_monitor.py +0 -0
  371. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/generative_model_store.py +0 -0
  372. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/span_cost_calculator.py +0 -0
  373. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/dml_event.py +0 -0
  374. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/dml_event_handler.py +0 -0
  375. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/__init__.py +0 -0
  376. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/sender.py +0 -0
  377. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/__init__.py +0 -0
  378. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/db_disk_usage_notification.html +0 -0
  379. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/password_reset.html +0 -0
  380. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/welcome.html +0 -0
  381. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/types.py +0 -0
  382. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/experiments/__init__.py +0 -0
  383. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/experiments/utils.py +0 -0
  384. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/grpc_server.py +0 -0
  385. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/jwt_store.py +0 -0
  386. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/main.py +0 -0
  387. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/middleware/__init__.py +0 -0
  388. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/middleware/gzip.py +0 -0
  389. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/oauth2.py +0 -0
  390. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/openapi/__init__.py +0 -0
  391. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/prometheus.py +0 -0
  392. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/rate_limiters.py +0 -0
  393. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/retention.py +0 -0
  394. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/session_filters.py +0 -0
  395. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-114x114.png +0 -0
  396. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-120x120.png +0 -0
  397. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-144x144.png +0 -0
  398. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-152x152.png +0 -0
  399. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-180x180.png +0 -0
  400. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-72x72.png +0 -0
  401. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-76x76.png +0 -0
  402. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon.png +0 -0
  403. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-CqDb5u4o.css +0 -0
  404. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-RdRDaQiR.js +0 -0
  405. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-arizeai-DsYDNOqt.js +0 -0
  406. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-codemirror-BzJDUbEx.js +0 -0
  407. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-recharts-BTHn5Y2R.js +0 -0
  408. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-shiki-BAcocHFl.js +0 -0
  409. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-three-BLWp5bic.js +0 -0
  410. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/favicon.ico +0 -0
  411. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/modernizr.js +0 -0
  412. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/telemetry.py +0 -0
  413. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/templates/__init__.py +0 -0
  414. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/templates/index.html +0 -0
  415. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/thread_server.py +0 -0
  416. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/types.py +0 -0
  417. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/services.py +0 -0
  418. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/__init__.py +0 -0
  419. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/client.py +0 -0
  420. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/data_extractor.py +0 -0
  421. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/evaluation.py +0 -0
  422. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/session.py +0 -0
  423. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/settings.py +0 -0
  424. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/__init__.py +0 -0
  425. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/attributes.py +0 -0
  426. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/README.md +0 -0
  427. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/__init__.py +0 -0
  428. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/filter.py +0 -0
  429. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/helpers.py +0 -0
  430. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/query.py +0 -0
  431. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/errors.py +0 -0
  432. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/evaluation_conventions.py +0 -0
  433. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/exporter.py +0 -0
  434. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/fixtures.py +0 -0
  435. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/otel.py +0 -0
  436. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/projects.py +0 -0
  437. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/schemas.py +0 -0
  438. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_evaluations.py +0 -0
  439. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_json_decoder.py +0 -0
  440. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_json_encoder.py +0 -0
  441. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/trace_dataset.py +0 -0
  442. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/utils.py +0 -0
  443. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/__init__.py +0 -0
  444. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/evaluation_pb2.py +0 -0
  445. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/evaluation_pb2.pyi +0 -0
  446. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/__init__.py +0 -0
  447. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/client.py +0 -0
  448. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/deprecation.py +0 -0
  449. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/error_handling.py +0 -0
  450. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/json.py +0 -0
  451. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/logging.py +0 -0
  452. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/project.py +0 -0
  453. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/re.py +0 -0
  454. {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/span_store.py +0 -0
  455. {arize_phoenix-11.28.0 → arize_phoenix-11.30.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.28.0
3
+ Version: 11.30.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
@@ -50,7 +50,8 @@ Requires-Dist: python-multipart
50
50
  Requires-Dist: scikit-learn
51
51
  Requires-Dist: scipy
52
52
  Requires-Dist: sqlalchemy[asyncio]<3,>=2.0.4
53
- Requires-Dist: sqlean-py>=3.45.1
53
+ Requires-Dist: sqlean-py<3.50,>=3.45.1; platform_system == 'Windows'
54
+ Requires-Dist: sqlean-py>=3.45.1; platform_system != 'Windows'
54
55
  Requires-Dist: starlette
55
56
  Requires-Dist: strawberry-graphql==0.270.1
56
57
  Requires-Dist: tqdm
@@ -49,7 +49,8 @@ dependencies = [
49
49
  "alembic>=1.3.0, <2",
50
50
  "aiosqlite",
51
51
  "aioitertools",
52
- "sqlean.py>=3.45.1",
52
+ "sqlean.py>=3.45.1; platform_system != 'Windows'",
53
+ "sqlean.py>=3.45.1,<3.50; platform_system == 'Windows'", # https://github.com/nalgeon/sqlean.py/commit/2714a4789998811b7dd9f102f5b45ea071ed879e
53
54
  "cachetools",
54
55
  "python-multipart", # see https://www.starlette.io/#dependencies
55
56
  "arize-phoenix-evals>=0.20.6",
@@ -0,0 +1,47 @@
1
+ from typing import Optional
2
+
3
+ from sqlalchemy import func, select
4
+ from strawberry.dataloader import DataLoader
5
+ from typing_extensions import TypeAlias
6
+
7
+ from phoenix.db import models
8
+ from phoenix.server.types import DbSessionFactory
9
+
10
+ ExperimentID: TypeAlias = int
11
+ RunLatency: TypeAlias = Optional[float]
12
+ Key: TypeAlias = ExperimentID
13
+ Result: TypeAlias = RunLatency
14
+
15
+
16
+ class AverageExperimentRunLatencyDataLoader(DataLoader[Key, Result]):
17
+ def __init__(
18
+ self,
19
+ db: DbSessionFactory,
20
+ ) -> None:
21
+ super().__init__(load_fn=self._load_fn)
22
+ self._db = db
23
+
24
+ async def _load_fn(self, keys: list[Key]) -> list[Result]:
25
+ experiment_ids = keys
26
+ average_repetition_latency_ms = (
27
+ select(
28
+ models.ExperimentRun.experiment_id.label("experiment_id"),
29
+ func.avg(models.ExperimentRun.latency_ms).label("average_repetition_latency_ms"),
30
+ )
31
+ .select_from(models.ExperimentRun)
32
+ .where(models.ExperimentRun.experiment_id.in_(experiment_ids))
33
+ .group_by(models.ExperimentRun.dataset_example_id, models.ExperimentRun.experiment_id)
34
+ .subquery()
35
+ )
36
+ query = select(
37
+ average_repetition_latency_ms.c.experiment_id,
38
+ func.avg(average_repetition_latency_ms.c.average_repetition_latency_ms).label(
39
+ "average_run_latency_ms"
40
+ ),
41
+ ).group_by(average_repetition_latency_ms.c.experiment_id)
42
+ async with self._db() as session:
43
+ average_run_latencies_ms = {
44
+ experiment_id: average_run_latency_ms
45
+ async for experiment_id, average_run_latency_ms in await session.stream(query)
46
+ }
47
+ return [average_run_latencies_ms.get(experiment_id) for experiment_id in keys]
@@ -5,11 +5,11 @@ from strawberry.dataloader import DataLoader
5
5
  from typing_extensions import TypeAlias
6
6
 
7
7
  from phoenix.db import models
8
- from phoenix.server.api.types.Evaluation import DocumentEvaluation
8
+ from phoenix.server.api.types.Evaluation import DocumentAnnotation
9
9
  from phoenix.server.types import DbSessionFactory
10
10
 
11
11
  Key: TypeAlias = int
12
- Result: TypeAlias = list[DocumentEvaluation]
12
+ Result: TypeAlias = list[DocumentAnnotation]
13
13
 
14
14
 
15
15
  class DocumentEvaluationsDataLoader(DataLoader[Key, Result]):
@@ -26,6 +26,6 @@ class DocumentEvaluationsDataLoader(DataLoader[Key, Result]):
26
26
  )
27
27
  async for document_evaluation in data:
28
28
  document_evaluations_by_id[document_evaluation.span_rowid].append(
29
- DocumentEvaluation.from_sql_document_annotation(document_evaluation)
29
+ DocumentAnnotation.from_sql_document_annotation(document_evaluation)
30
30
  )
31
31
  return [document_evaluations_by_id[key] for key in keys]
@@ -0,0 +1,133 @@
1
+ from collections import defaultdict
2
+ from dataclasses import dataclass
3
+ from typing import Optional
4
+
5
+ from sqlalchemy import and_, func, select
6
+ from strawberry.dataloader import AbstractCache, DataLoader
7
+ from typing_extensions import TypeAlias
8
+
9
+ from phoenix.db import models
10
+ from phoenix.server.types import DbSessionFactory
11
+
12
+
13
+ @dataclass
14
+ class ExperimentAnnotationSummary:
15
+ annotation_name: str
16
+ min_score: float
17
+ max_score: float
18
+ mean_score: float
19
+ count: int
20
+ error_count: int
21
+
22
+
23
+ ExperimentID: TypeAlias = int
24
+ Key: TypeAlias = ExperimentID
25
+ Result: TypeAlias = list[ExperimentAnnotationSummary]
26
+
27
+
28
+ class ExperimentAnnotationSummaryDataLoader(DataLoader[Key, Result]):
29
+ def __init__(
30
+ self,
31
+ db: DbSessionFactory,
32
+ cache_map: Optional[AbstractCache[Key, Result]] = None,
33
+ ) -> None:
34
+ super().__init__(load_fn=self._load_fn)
35
+ self._db = db
36
+
37
+ async def _load_fn(self, keys: list[Key]) -> list[Result]:
38
+ experiment_ids = keys
39
+ summaries: defaultdict[ExperimentID, Result] = defaultdict(list)
40
+ repetition_mean_scores_by_example_subquery = (
41
+ select(
42
+ models.ExperimentRun.experiment_id.label("experiment_id"),
43
+ models.ExperimentRunAnnotation.name.label("annotation_name"),
44
+ func.avg(models.ExperimentRunAnnotation.score).label("mean_repetition_score"),
45
+ )
46
+ .select_from(models.ExperimentRunAnnotation)
47
+ .join(
48
+ models.ExperimentRun,
49
+ models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
50
+ )
51
+ .where(models.ExperimentRun.experiment_id.in_(experiment_ids))
52
+ .group_by(
53
+ models.ExperimentRun.experiment_id,
54
+ models.ExperimentRun.dataset_example_id,
55
+ models.ExperimentRunAnnotation.name,
56
+ )
57
+ .subquery()
58
+ .alias("repetition_mean_scores_by_example")
59
+ )
60
+ repetition_mean_scores_subquery = (
61
+ select(
62
+ repetition_mean_scores_by_example_subquery.c.experiment_id.label("experiment_id"),
63
+ repetition_mean_scores_by_example_subquery.c.annotation_name.label(
64
+ "annotation_name"
65
+ ),
66
+ func.avg(repetition_mean_scores_by_example_subquery.c.mean_repetition_score).label(
67
+ "mean_score"
68
+ ),
69
+ )
70
+ .select_from(repetition_mean_scores_by_example_subquery)
71
+ .group_by(
72
+ repetition_mean_scores_by_example_subquery.c.experiment_id,
73
+ repetition_mean_scores_by_example_subquery.c.annotation_name,
74
+ )
75
+ .subquery()
76
+ .alias("repetition_mean_scores")
77
+ )
78
+ repetitions_subquery = (
79
+ select(
80
+ models.ExperimentRun.experiment_id.label("experiment_id"),
81
+ models.ExperimentRunAnnotation.name.label("annotation_name"),
82
+ func.min(models.ExperimentRunAnnotation.score).label("min_score"),
83
+ func.max(models.ExperimentRunAnnotation.score).label("max_score"),
84
+ func.count().label("count"),
85
+ func.count(models.ExperimentRunAnnotation.error).label("error_count"),
86
+ )
87
+ .select_from(models.ExperimentRunAnnotation)
88
+ .join(
89
+ models.ExperimentRun,
90
+ models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
91
+ )
92
+ .where(models.ExperimentRun.experiment_id.in_(experiment_ids))
93
+ .group_by(models.ExperimentRun.experiment_id, models.ExperimentRunAnnotation.name)
94
+ .subquery()
95
+ )
96
+ run_scores_query = (
97
+ select(
98
+ repetition_mean_scores_subquery.c.experiment_id.label("experiment_id"),
99
+ repetition_mean_scores_subquery.c.annotation_name.label("annotation_name"),
100
+ repetition_mean_scores_subquery.c.mean_score.label("mean_score"),
101
+ repetitions_subquery.c.min_score.label("min_score"),
102
+ repetitions_subquery.c.max_score.label("max_score"),
103
+ repetitions_subquery.c.count.label("count_"),
104
+ repetitions_subquery.c.error_count.label("error_count"),
105
+ )
106
+ .select_from(repetition_mean_scores_subquery)
107
+ .join(
108
+ repetitions_subquery,
109
+ and_(
110
+ repetitions_subquery.c.experiment_id
111
+ == repetition_mean_scores_subquery.c.experiment_id,
112
+ repetitions_subquery.c.annotation_name
113
+ == repetition_mean_scores_subquery.c.annotation_name,
114
+ ),
115
+ )
116
+ .order_by(repetition_mean_scores_subquery.c.annotation_name)
117
+ )
118
+ async with self._db() as session:
119
+ async for scores_tuple in await session.stream(run_scores_query):
120
+ summaries[scores_tuple.experiment_id].append(
121
+ ExperimentAnnotationSummary(
122
+ annotation_name=scores_tuple.annotation_name,
123
+ min_score=scores_tuple.min_score,
124
+ max_score=scores_tuple.max_score,
125
+ mean_score=scores_tuple.mean_score,
126
+ count=scores_tuple.count_,
127
+ error_count=scores_tuple.error_count,
128
+ )
129
+ )
130
+ return [
131
+ sorted(summaries[experiment_id], key=lambda summary: summary.annotation_name)
132
+ for experiment_id in experiment_ids
133
+ ]
@@ -0,0 +1,51 @@
1
+ from typing import Optional
2
+
3
+ from sqlalchemy import func, select
4
+ from strawberry.dataloader import DataLoader
5
+ from typing_extensions import TypeAlias
6
+
7
+ from phoenix.db import models
8
+ from phoenix.server.types import DbSessionFactory
9
+
10
+ ExperimentID: TypeAlias = int
11
+ ErrorRate: TypeAlias = float
12
+ Key: TypeAlias = ExperimentID
13
+ Result: TypeAlias = Optional[ErrorRate]
14
+
15
+
16
+ class ExperimentErrorRatesDataLoader(DataLoader[Key, Result]):
17
+ def __init__(
18
+ self,
19
+ db: DbSessionFactory,
20
+ ) -> None:
21
+ super().__init__(load_fn=self._load_fn)
22
+ self._db = db
23
+
24
+ async def _load_fn(self, keys: list[Key]) -> list[Result]:
25
+ experiment_ids = keys
26
+ average_repetition_error_rates_subquery = (
27
+ select(
28
+ models.ExperimentRun.experiment_id.label("experiment_id"),
29
+ (
30
+ func.count(models.ExperimentRun.error) / func.count(models.ExperimentRun.id)
31
+ ).label("average_repetition_error_rate"),
32
+ )
33
+ .where(models.ExperimentRun.experiment_id.in_(experiment_ids))
34
+ .group_by(models.ExperimentRun.dataset_example_id, models.ExperimentRun.experiment_id)
35
+ .subquery()
36
+ .alias("average_repetition_error_rates")
37
+ )
38
+ average_run_error_rates_query = select(
39
+ average_repetition_error_rates_subquery.c.experiment_id,
40
+ func.avg(average_repetition_error_rates_subquery.c.average_repetition_error_rate).label(
41
+ "average_run_error_rates"
42
+ ),
43
+ ).group_by(average_repetition_error_rates_subquery.c.experiment_id)
44
+ async with self._db() as session:
45
+ average_run_error_rates = {
46
+ experiment_id: error_rate
47
+ async for experiment_id, error_rate in await session.stream(
48
+ average_run_error_rates_query
49
+ )
50
+ }
51
+ return [average_run_error_rates.get(experiment_id) for experiment_id in experiment_ids]
@@ -7,6 +7,7 @@ from phoenix.server.bearer_auth import is_authenticated
7
7
  from .annotation_configs import router as annotation_configs_router
8
8
  from .annotations import router as annotations_router
9
9
  from .datasets import router as datasets_router
10
+ from .documents import router as documents_router
10
11
  from .evaluations import router as evaluations_router
11
12
  from .experiment_evaluations import router as experiment_evaluations_router
12
13
  from .experiment_runs import router as experiment_runs_router
@@ -70,5 +71,6 @@ def create_v1_router(authentication_enabled: bool) -> APIRouter:
70
71
  router.include_router(evaluations_router)
71
72
  router.include_router(prompts_router)
72
73
  router.include_router(projects_router)
74
+ router.include_router(documents_router)
73
75
  router.include_router(users_router)
74
76
  return router
@@ -0,0 +1,175 @@
1
+ from datetime import datetime, timezone
2
+ from typing import Any, Literal, Optional
3
+
4
+ from fastapi import APIRouter, Depends, HTTPException, Query
5
+ from pydantic import Field
6
+ from sqlalchemy import select
7
+ from starlette.requests import Request
8
+ from starlette.status import HTTP_404_NOT_FOUND
9
+ from strawberry.relay import GlobalID
10
+
11
+ from phoenix.db import models
12
+ from phoenix.db.helpers import SupportedSQLDialect
13
+ from phoenix.db.insertion.helpers import as_kv, insert_on_conflict
14
+ from phoenix.db.insertion.types import Precursors
15
+ from phoenix.server.api.types.Evaluation import DocumentAnnotation
16
+ from phoenix.server.authorization import is_not_locked
17
+ from phoenix.server.bearer_auth import PhoenixUser
18
+ from phoenix.server.dml_event import DocumentAnnotationInsertEvent
19
+
20
+ from .models import V1RoutesBaseModel
21
+ from .spans import SpanAnnotationResult
22
+ from .utils import RequestBody, ResponseBody, add_errors_to_responses
23
+
24
+ # Since the document annotations are spans related, we place it under spans
25
+ router = APIRouter(tags=["spans"])
26
+
27
+
28
+ class SpanDocumentAnnotationData(V1RoutesBaseModel):
29
+ span_id: str = Field(description="OpenTelemetry Span ID (hex format w/o 0x prefix)")
30
+ name: str = Field(description="The name of the document annotation. E.x. relevance")
31
+ annotator_kind: Literal["LLM", "CODE", "HUMAN"] = Field(
32
+ description="The kind of annotator. E.g. llm judge, a heuristic piece of code, or a human"
33
+ )
34
+ document_position: int = Field(
35
+ description="A 0 based index of the document. E.x. the first document during retrieval is 0"
36
+ )
37
+ result: Optional[SpanAnnotationResult] = Field(
38
+ default=None, description="The score and or label of the annotation"
39
+ )
40
+ metadata: Optional[dict[str, Any]] = Field(
41
+ default=None, description="Metadata for custom values of the annotation"
42
+ )
43
+ identifier: str = Field(
44
+ default="",
45
+ description=(
46
+ "An custom ID for the annotation. "
47
+ "If provided, the annotation will be updated if it already exists."
48
+ ),
49
+ )
50
+
51
+ # Precursor here means a value to add to a queue for processing async
52
+ def as_precursor(self, *, user_id: Optional[int] = None) -> Precursors.DocumentAnnotation:
53
+ return Precursors.DocumentAnnotation(
54
+ datetime.now(timezone.utc),
55
+ self.span_id,
56
+ self.document_position,
57
+ models.DocumentAnnotation(
58
+ name=self.name,
59
+ annotator_kind=self.annotator_kind,
60
+ document_position=self.document_position,
61
+ score=self.result.score if self.result else None,
62
+ label=self.result.label if self.result else None,
63
+ explanation=self.result.explanation if self.result else None,
64
+ metadata_=self.metadata or {},
65
+ identifier=self.identifier,
66
+ source="API",
67
+ user_id=user_id,
68
+ ),
69
+ )
70
+
71
+
72
+ class AnnotateSpanDocumentsRequestBody(RequestBody[list[SpanDocumentAnnotationData]]):
73
+ pass
74
+
75
+
76
+ class InsertedSpanDocumentAnnotation(V1RoutesBaseModel):
77
+ id: str = Field(description="The ID of the inserted span document annotation")
78
+
79
+
80
+ class AnnotateSpanDocumentsResponseBody(ResponseBody[list[InsertedSpanDocumentAnnotation]]):
81
+ pass
82
+
83
+
84
+ @router.post(
85
+ "/document_annotations",
86
+ dependencies=[Depends(is_not_locked)],
87
+ operation_id="annotateSpanDocuments",
88
+ responses=add_errors_to_responses(
89
+ [
90
+ {
91
+ "status_code": HTTP_404_NOT_FOUND,
92
+ "description": "Span not found",
93
+ }
94
+ ]
95
+ ),
96
+ response_description="Span document annotation inserted successfully",
97
+ include_in_schema=True,
98
+ )
99
+ async def annotate_span_documents(
100
+ request: Request,
101
+ request_body: AnnotateSpanDocumentsRequestBody,
102
+ sync: bool = Query(
103
+ default=False, description="If set to true, the annotations are inserted synchronously."
104
+ ),
105
+ ) -> AnnotateSpanDocumentsResponseBody:
106
+ if not request_body.data:
107
+ return AnnotateSpanDocumentsResponseBody(data=[])
108
+
109
+ user_id: Optional[int] = None
110
+ if request.app.state.authentication_enabled and isinstance(request.user, PhoenixUser):
111
+ user_id = int(request.user.identity)
112
+
113
+ span_document_annotations = request_body.data
114
+
115
+ precursors = [
116
+ annotation.as_precursor(user_id=user_id) for annotation in span_document_annotations
117
+ ]
118
+ if not sync:
119
+ await request.state.enqueue(*precursors)
120
+
121
+ span_ids = {p.span_id for p in precursors}
122
+ # Account for the fact that the spans could arrive after the annotation
123
+ async with request.app.state.db() as session:
124
+ existing_spans = {
125
+ span_id: (id_, num_docs)
126
+ async for span_id, id_, num_docs in await session.stream(
127
+ select(models.Span.span_id, models.Span.id, models.Span.num_documents).filter(
128
+ models.Span.span_id.in_(span_ids)
129
+ )
130
+ )
131
+ }
132
+
133
+ missing_span_ids = span_ids - set(existing_spans.keys())
134
+ # We prefer to fail the entire operation if there are missing spans in sync mode
135
+ if missing_span_ids:
136
+ raise HTTPException(
137
+ detail=f"Spans with IDs {', '.join(missing_span_ids)} do not exist.",
138
+ status_code=HTTP_404_NOT_FOUND,
139
+ )
140
+
141
+ # Validate that document positions are within bounds
142
+ for annotation in span_document_annotations:
143
+ _, num_docs = existing_spans[annotation.span_id]
144
+ if annotation.document_position not in range(num_docs):
145
+ raise HTTPException(
146
+ detail=f"Document position {annotation.document_position} is out of bounds for "
147
+ f"span {annotation.span_id} (max: {num_docs - 1})",
148
+ status_code=422, # Unprocessable Entity
149
+ )
150
+
151
+ inserted_document_annotation_ids = []
152
+ dialect = SupportedSQLDialect(session.bind.dialect.name)
153
+ for anno in precursors:
154
+ span_rowid, _ = existing_spans[anno.span_id]
155
+ values = dict(as_kv(anno.as_insertable(span_rowid).row))
156
+ span_document_annotation_id = await session.scalar(
157
+ insert_on_conflict(
158
+ values,
159
+ dialect=dialect,
160
+ table=models.DocumentAnnotation,
161
+ unique_by=("name", "span_rowid", "identifier", "document_position"),
162
+ ).returning(models.DocumentAnnotation.id)
163
+ )
164
+ inserted_document_annotation_ids.append(span_document_annotation_id)
165
+
166
+ # We queue an event to let the application know that annotations have changed
167
+ request.state.event_queue.put(
168
+ DocumentAnnotationInsertEvent(tuple(inserted_document_annotation_ids))
169
+ )
170
+ return AnnotateSpanDocumentsResponseBody(
171
+ data=[
172
+ InsertedSpanDocumentAnnotation(id=str(GlobalID(DocumentAnnotation.__name__, str(id_))))
173
+ for id_ in inserted_document_annotation_ids
174
+ ]
175
+ )
@@ -949,9 +949,11 @@ async def annotate_spans(
949
949
  span_ids = {p.span_id for p in precursors}
950
950
  async with request.app.state.db() as session:
951
951
  existing_spans = {
952
- span.span_id: span.id
953
- async for span in await session.stream_scalars(
954
- select(models.Span).filter(models.Span.span_id.in_(span_ids))
952
+ span_id: id_
953
+ async for span_id, id_ in await session.stream(
954
+ select(models.Span.span_id, models.Span.id).filter(
955
+ models.Span.span_id.in_(span_ids)
956
+ )
955
957
  )
956
958
  }
957
959
 
@@ -193,9 +193,11 @@ async def annotate_traces(
193
193
  trace_ids = {p.trace_id for p in precursors}
194
194
  async with request.app.state.db() as session:
195
195
  existing_traces = {
196
- trace.trace_id: trace.id
197
- async for trace in await session.stream_scalars(
198
- select(models.Trace).filter(models.Trace.trace_id.in_(trace_ids))
196
+ trace_id: id_
197
+ async for trace_id, id_ in await session.stream(
198
+ select(models.Trace.trace_id, models.Trace.id).filter(
199
+ models.Trace.trace_id.in_(trace_ids)
200
+ )
199
201
  )
200
202
  }
201
203
 
@@ -272,15 +272,53 @@ class Dataset(Node):
272
272
  self, info: Info[Context, None]
273
273
  ) -> list[ExperimentAnnotationSummary]:
274
274
  dataset_id = self.id_attr
275
- query = (
275
+ repetition_mean_scores_by_example_subquery = (
276
276
  select(
277
+ models.ExperimentRunAnnotation.name.label("annotation_name"),
278
+ func.avg(models.ExperimentRunAnnotation.score).label("mean_repetition_score"),
279
+ )
280
+ .select_from(models.ExperimentRunAnnotation)
281
+ .join(
282
+ models.ExperimentRun,
283
+ models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
284
+ )
285
+ .join(
286
+ models.Experiment,
287
+ models.ExperimentRun.experiment_id == models.Experiment.id,
288
+ )
289
+ .where(models.Experiment.dataset_id == dataset_id)
290
+ .group_by(
291
+ models.ExperimentRun.dataset_example_id,
277
292
  models.ExperimentRunAnnotation.name,
278
- func.min(models.ExperimentRunAnnotation.score),
279
- func.max(models.ExperimentRunAnnotation.score),
280
- func.avg(models.ExperimentRunAnnotation.score),
281
- func.count(),
282
- func.count(models.ExperimentRunAnnotation.error),
283
293
  )
294
+ .subquery()
295
+ .alias("repetition_mean_scores_by_example")
296
+ )
297
+ repetition_mean_scores_subquery = (
298
+ select(
299
+ repetition_mean_scores_by_example_subquery.c.annotation_name.label(
300
+ "annotation_name"
301
+ ),
302
+ func.avg(repetition_mean_scores_by_example_subquery.c.mean_repetition_score).label(
303
+ "mean_score"
304
+ ),
305
+ )
306
+ .select_from(repetition_mean_scores_by_example_subquery)
307
+ .group_by(
308
+ repetition_mean_scores_by_example_subquery.c.annotation_name,
309
+ )
310
+ .subquery()
311
+ .alias("repetition_mean_scores")
312
+ )
313
+ repetitions_subquery = (
314
+ select(
315
+ models.ExperimentRunAnnotation.name.label("annotation_name"),
316
+ func.min(models.ExperimentRunAnnotation.score).label("min_score"),
317
+ func.max(models.ExperimentRunAnnotation.score).label("max_score"),
318
+ func.count().label("count"),
319
+ func.count(models.ExperimentRunAnnotation.error).label("error_count"),
320
+ )
321
+ .select_from(models.ExperimentRunAnnotation)
284
322
  .join(
285
323
  models.ExperimentRun,
286
324
  models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
@@ -291,26 +329,36 @@ class Dataset(Node):
291
329
  )
292
330
  .where(models.Experiment.dataset_id == dataset_id)
293
331
  .group_by(models.ExperimentRunAnnotation.name)
294
- .order_by(models.ExperimentRunAnnotation.name)
332
+ .subquery()
333
+ )
334
+ run_scores_query = (
335
+ select(
336
+ repetition_mean_scores_subquery.c.annotation_name.label("annotation_name"),
337
+ repetition_mean_scores_subquery.c.mean_score.label("mean_score"),
338
+ repetitions_subquery.c.min_score.label("min_score"),
339
+ repetitions_subquery.c.max_score.label("max_score"),
340
+ repetitions_subquery.c.count.label("count_"),
341
+ repetitions_subquery.c.error_count.label("error_count"),
342
+ )
343
+ .select_from(repetition_mean_scores_subquery)
344
+ .join(
345
+ repetitions_subquery,
346
+ repetitions_subquery.c.annotation_name
347
+ == repetition_mean_scores_subquery.c.annotation_name,
348
+ )
349
+ .order_by(repetition_mean_scores_subquery.c.annotation_name)
295
350
  )
296
351
  async with info.context.db() as session:
297
352
  return [
298
353
  ExperimentAnnotationSummary(
299
- annotation_name=annotation_name,
300
- min_score=min_score,
301
- max_score=max_score,
302
- mean_score=mean_score,
303
- count=count_,
304
- error_count=error_count,
354
+ annotation_name=scores_tuple.annotation_name,
355
+ min_score=scores_tuple.min_score,
356
+ max_score=scores_tuple.max_score,
357
+ mean_score=scores_tuple.mean_score,
358
+ count=scores_tuple.count_,
359
+ error_count=scores_tuple.error_count,
305
360
  )
306
- async for (
307
- annotation_name,
308
- min_score,
309
- max_score,
310
- mean_score,
311
- count_,
312
- error_count,
313
- ) in await session.stream(query)
361
+ async for scores_tuple in await session.stream(run_scores_query)
314
362
  ]
315
363
 
316
364
  @strawberry.field
@@ -1,6 +1,7 @@
1
1
  import strawberry
2
2
 
3
- from phoenix.db.models import DocumentAnnotation, TraceAnnotation
3
+ from phoenix.db.models import DocumentAnnotation as DBDocumentAnnotation
4
+ from phoenix.db.models import TraceAnnotation
4
5
 
5
6
  from .Annotation import Annotation
6
7
 
@@ -20,15 +21,15 @@ class TraceEvaluation(Annotation):
20
21
 
21
22
 
22
23
  @strawberry.type
23
- class DocumentEvaluation(Annotation):
24
+ class DocumentAnnotation(Annotation):
24
25
  document_position: int = strawberry.field(
25
26
  description="The zero-based index among retrieved documents, which "
26
27
  "is collected as a list (even when ordering is not inherently meaningful)."
27
28
  )
28
29
 
29
30
  @staticmethod
30
- def from_sql_document_annotation(annotation: DocumentAnnotation) -> "DocumentEvaluation":
31
- return DocumentEvaluation(
31
+ def from_sql_document_annotation(annotation: DBDocumentAnnotation) -> "DocumentAnnotation":
32
+ return DocumentAnnotation(
32
33
  name=annotation.name,
33
34
  score=annotation.score,
34
35
  label=annotation.label,