openrunner-sdk 2.1.0__tar.gz → 2.2.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.
Files changed (114) hide show
  1. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/PKG-INFO +1 -1
  2. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/media.py +91 -1
  3. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/pyproject.toml +1 -1
  4. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/.gitignore +0 -0
  5. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/=6.0 +0 -0
  6. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/=8.1 +0 -0
  7. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/README.md +0 -0
  8. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/__init__.py +0 -0
  9. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/api_client.py +0 -0
  10. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/artifact.py +0 -0
  11. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/buffer.py +0 -0
  12. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/cache.py +0 -0
  13. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/cli.py +0 -0
  14. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/config.py +0 -0
  15. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/cost.py +0 -0
  16. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/dataset.py +0 -0
  17. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/environment.py +0 -0
  18. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/evaluation.py +0 -0
  19. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/feedback.py +0 -0
  20. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/git_info.py +0 -0
  21. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/guardrails.py +0 -0
  22. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/__init__.py +0 -0
  23. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/accelerate.py +0 -0
  24. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/anthropic_tracer.py +0 -0
  25. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/catboost.py +0 -0
  26. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/diffusers.py +0 -0
  27. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/fastai.py +0 -0
  28. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/forced_alignment.py +0 -0
  29. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/gladia.py +0 -0
  30. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/gymnasium.py +0 -0
  31. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/huggingface.py +0 -0
  32. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/hydra.py +0 -0
  33. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/ignite.py +0 -0
  34. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/jax.py +0 -0
  35. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/keras.py +0 -0
  36. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/langchain.py +0 -0
  37. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/lightgbm.py +0 -0
  38. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/lightning.py +0 -0
  39. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/llamaindex.py +0 -0
  40. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/openai_finetune.py +0 -0
  41. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/openai_tracer.py +0 -0
  42. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/optuna.py +0 -0
  43. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/pytorch.py +0 -0
  44. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/sb3.py +0 -0
  45. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/sklearn.py +0 -0
  46. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/tensorflow.py +0 -0
  47. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/trl.py +0 -0
  48. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/tts.py +0 -0
  49. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/ultralytics.py +0 -0
  50. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/voice_agent.py +0 -0
  51. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/whisper.py +0 -0
  52. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/integration/xgboost.py +0 -0
  53. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/launch.py +0 -0
  54. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/migrate.py +0 -0
  55. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/model.py +0 -0
  56. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/offline.py +0 -0
  57. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/pii.py +0 -0
  58. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/plot.py +0 -0
  59. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/prompt.py +0 -0
  60. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/query_api.py +0 -0
  61. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/run.py +0 -0
  62. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/scorers.py +0 -0
  63. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/sender.py +0 -0
  64. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/settings.py +0 -0
  65. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/summary.py +0 -0
  66. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/sweep.py +0 -0
  67. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/system_metrics.py +0 -0
  68. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/tensorboard.py +0 -0
  69. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/trace.py +0 -0
  70. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/transcript_formatter.py +0 -0
  71. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/wal.py +0 -0
  72. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/wandb_compat/__init__.py +0 -0
  73. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/openrunner/wandb_compat/_shim.py +0 -0
  74. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/__init__.py +0 -0
  75. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/conftest.py +0 -0
  76. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_alert.py +0 -0
  77. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_aliases.py +0 -0
  78. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_api_client.py +0 -0
  79. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_artifact.py +0 -0
  80. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_buffer.py +0 -0
  81. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_cache.py +0 -0
  82. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_class_scorers.py +0 -0
  83. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_cli.py +0 -0
  84. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_config.py +0 -0
  85. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_evaluation.py +0 -0
  86. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_finish.py +0 -0
  87. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_git_info.py +0 -0
  88. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_init.py +0 -0
  89. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_fastai.py +0 -0
  90. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_huggingface.py +0 -0
  91. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_keras.py +0 -0
  92. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_langchain.py +0 -0
  93. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_lightning.py +0 -0
  94. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_pytorch.py +0 -0
  95. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_sklearn.py +0 -0
  96. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_integration_xgboost.py +0 -0
  97. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_launch.py +0 -0
  98. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_log.py +0 -0
  99. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_log_code.py +0 -0
  100. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_media.py +0 -0
  101. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_migrate.py +0 -0
  102. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_offline.py +0 -0
  103. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_offline_sync.py +0 -0
  104. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_pii.py +0 -0
  105. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_plot.py +0 -0
  106. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_query_api.py +0 -0
  107. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_resume.py +0 -0
  108. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_sdk_features.py +0 -0
  109. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_sender.py +0 -0
  110. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_summary.py +0 -0
  111. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_sweep.py +0 -0
  112. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_system_metrics.py +0 -0
  113. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_trace.py +0 -0
  114. {openrunner_sdk-2.1.0 → openrunner_sdk-2.2.0}/tests/test_wandb_compat.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: openrunner-sdk
3
- Version: 2.1.0
3
+ Version: 2.2.0
4
4
  Summary: OpenRunner SDK - W&B-compatible ML experiment tracking client
5
5
  Project-URL: Homepage, https://github.com/jqueguiner/openrunner
6
6
  Project-URL: Repository, https://github.com/jqueguiner/openrunner
@@ -310,9 +310,99 @@ class Table:
310
310
  data = df.values.tolist()
311
311
  return cls(columns=columns, data=data)
312
312
 
313
+ def set_reference_column(self, column: str = "sample_id") -> None:
314
+ """Mark a column as the dataset reference/sample ID.
315
+
316
+ This tells the UI to treat this column as a link back to the
317
+ original dataset, enabling sample traceability.
318
+
319
+ Args:
320
+ column: Name of the column containing sample IDs/references.
321
+ Must already exist in the table.
322
+ """
323
+ if column not in self.columns:
324
+ raise ValueError(f"Column '{column}' not in table. Columns: {self.columns}")
325
+ self._reference_column = column
326
+
327
+ @classmethod
328
+ def from_predictions(
329
+ cls,
330
+ *,
331
+ sample_ids: list[str],
332
+ references: list[str],
333
+ hypotheses: list[str],
334
+ audio_paths: list[str] | None = None,
335
+ metadata: dict[str, list] | None = None,
336
+ extra_columns: dict[str, list] | None = None,
337
+ ) -> "Table":
338
+ """Create a predictions table with sample traceability.
339
+
340
+ Convenience constructor for evaluation results. Ensures consistent
341
+ column naming (sample_id, ref, hyp, audio) that the UI recognizes
342
+ for diff highlighting and audio playback.
343
+
344
+ Args:
345
+ sample_ids: Unique IDs linking each row to the source dataset
346
+ references: Ground truth transcriptions
347
+ hypotheses: Model predictions
348
+ audio_paths: Optional audio file paths for inline playback
349
+ metadata: Optional per-sample metadata dict (e.g. {"speaker": [...], "duration": [...], "language": [...]})
350
+ extra_columns: Alias for metadata (deprecated, use metadata)
351
+
352
+ Example:
353
+ table = Table.from_predictions(
354
+ sample_ids=["file_001", "file_002"],
355
+ references=["hello world", "press one"],
356
+ hypotheses=["hello word", "press 1"],
357
+ audio_paths=["audio/001.wav", "audio/002.wav"],
358
+ metadata={
359
+ "duration_s": [3.2, 1.8],
360
+ "speaker": ["agent", "ivr"],
361
+ "language": ["en", "es"],
362
+ "source_file": ["call_123.wav", "call_456.wav"],
363
+ },
364
+ )
365
+ openrunner.log({"predictions": table})
366
+ """
367
+ columns = ["sample_id"]
368
+ n = len(sample_ids)
369
+ data: list[list[Any]] = [[sid] for sid in sample_ids]
370
+
371
+ if audio_paths:
372
+ columns.append("audio")
373
+ for i, p in enumerate(audio_paths):
374
+ data[i].append(p)
375
+
376
+ columns.append("hyp")
377
+ for i, h in enumerate(hypotheses):
378
+ data[i].append(h)
379
+
380
+ columns.append("ref")
381
+ for i, r in enumerate(references):
382
+ data[i].append(r)
383
+
384
+ # Merge metadata and extra_columns
385
+ all_extra = {}
386
+ if metadata:
387
+ all_extra.update(metadata)
388
+ if extra_columns:
389
+ all_extra.update(extra_columns)
390
+
391
+ for col_name, col_data in all_extra.items():
392
+ columns.append(col_name)
393
+ for i, v in enumerate(col_data[:n]):
394
+ data[i].append(v)
395
+
396
+ t = cls(columns=columns, data=data)
397
+ t._reference_column = "sample_id"
398
+ return t
399
+
313
400
  def _serialize(self) -> dict[str, Any]:
314
401
  """Serialize to a dict for JSON transmission."""
315
- return {"columns": self.columns, "data": self._data}
402
+ result: dict[str, Any] = {"columns": self.columns, "data": self._data}
403
+ if hasattr(self, "_reference_column"):
404
+ result["reference_column"] = self._reference_column
405
+ return result
316
406
 
317
407
 
318
408
  class Audio:
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "openrunner-sdk"
3
- version = "2.1.0"
3
+ version = "2.2.0"
4
4
  description = "OpenRunner SDK - W&B-compatible ML experiment tracking client"
5
5
  readme = "README.md"
6
6
  license = {text = "MIT"}
File without changes
File without changes
File without changes