@absolutejs/rag 0.0.2 → 0.0.3

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 (94) hide show
  1. package/dist/ai/client/index.js +12 -49
  2. package/dist/ai/client/index.js.map +8 -8
  3. package/dist/ai/client/ui.js +12 -49
  4. package/dist/ai/client/ui.js.map +5 -5
  5. package/dist/ai/rag/index.js +34 -157
  6. package/dist/ai/rag/index.js.map +30 -30
  7. package/dist/ai/rag/quality.js +12 -49
  8. package/dist/ai/rag/quality.js.map +5 -5
  9. package/dist/ai/rag/ui.js +12 -49
  10. package/dist/ai/rag/ui.js.map +5 -5
  11. package/dist/angular/ai/index.js.map +8 -8
  12. package/dist/react/ai/index.js.map +22 -22
  13. package/dist/src/ai/client/createRAGAnswerWorkflow.d.ts +1 -1
  14. package/dist/src/ai/client/createRAGStream.d.ts +2 -2
  15. package/dist/src/ai/client/createRAGWorkflow.d.ts +3 -3
  16. package/dist/src/ai/client/index.d.ts +8 -8
  17. package/dist/src/ai/client/ragClient.d.ts +6 -6
  18. package/dist/src/ai/client/ui.d.ts +5 -5
  19. package/dist/src/ai/rag/accessControl.d.ts +1 -1
  20. package/dist/src/ai/rag/adapters/inMemory.d.ts +2 -2
  21. package/dist/src/ai/rag/adapters/postgres.d.ts +3 -3
  22. package/dist/src/ai/rag/adapters/sqlite.d.ts +4 -4
  23. package/dist/src/ai/rag/chat.d.ts +2 -2
  24. package/dist/src/ai/rag/collection.d.ts +1 -1
  25. package/dist/src/ai/rag/emailProviders.d.ts +1 -1
  26. package/dist/src/ai/rag/embedding.d.ts +1 -1
  27. package/dist/src/ai/rag/embeddingProviders.d.ts +1 -1
  28. package/dist/src/ai/rag/extractorProviders.d.ts +1 -1
  29. package/dist/src/ai/rag/grounding.d.ts +1 -1
  30. package/dist/src/ai/rag/htmxConfig.d.ts +1 -1
  31. package/dist/src/ai/rag/htmxWorkflowRenderers.d.ts +1 -1
  32. package/dist/src/ai/rag/index.d.ts +31 -31
  33. package/dist/src/ai/rag/ingestion.d.ts +1 -1
  34. package/dist/src/ai/rag/jobState.d.ts +1 -1
  35. package/dist/src/ai/rag/lexical.d.ts +2 -2
  36. package/dist/src/ai/rag/presentation.d.ts +9 -9
  37. package/dist/src/ai/rag/quality.d.ts +67 -67
  38. package/dist/src/ai/rag/queryTransforms.d.ts +2 -2
  39. package/dist/src/ai/rag/reranking.d.ts +2 -2
  40. package/dist/src/ai/rag/resolveAbsoluteSQLiteVec.d.ts +1 -1
  41. package/dist/src/ai/rag/retrievalStrategies.d.ts +1 -1
  42. package/dist/src/ai/rag/sync.d.ts +2 -2
  43. package/dist/src/ai/rag/types.d.ts +4 -4
  44. package/dist/src/ai/rag/ui.d.ts +4 -4
  45. package/dist/src/ai/rag/workflowState.d.ts +1 -1
  46. package/dist/src/angular/ai/ai-rag-stream.service.d.ts +1 -1
  47. package/dist/src/angular/ai/ai-rag-workflow.service.d.ts +1 -1
  48. package/dist/src/angular/ai/index.d.ts +3 -3
  49. package/dist/src/angular/ai/rag-client.service.d.ts +42 -42
  50. package/dist/src/react/ai/index.d.ts +18 -18
  51. package/dist/src/react/ai/useRAGChunkPreview.d.ts +1 -1
  52. package/dist/src/react/ai/useRAGCitations.d.ts +1 -1
  53. package/dist/src/react/ai/useRAGDocuments.d.ts +1 -1
  54. package/dist/src/react/ai/useRAGEvaluate.d.ts +1 -1
  55. package/dist/src/react/ai/useRAGGrounding.d.ts +1 -1
  56. package/dist/src/react/ai/useRAGIndexAdmin.d.ts +1 -1
  57. package/dist/src/react/ai/useRAGIngest.d.ts +1 -1
  58. package/dist/src/react/ai/useRAGOps.d.ts +1 -1
  59. package/dist/src/react/ai/useRAGSearch.d.ts +3 -3
  60. package/dist/src/react/ai/useRAGSources.d.ts +1 -1
  61. package/dist/src/react/ai/useRAGStatus.d.ts +1 -1
  62. package/dist/src/react/ai/useRAGStream.d.ts +1 -1
  63. package/dist/src/react/ai/useRAGStreamProgress.d.ts +2 -2
  64. package/dist/src/svelte/ai/createRAGChunkPreview.d.ts +1 -1
  65. package/dist/src/svelte/ai/createRAGCitations.d.ts +2 -2
  66. package/dist/src/svelte/ai/createRAGDocuments.d.ts +1 -1
  67. package/dist/src/svelte/ai/createRAGEvaluate.d.ts +1 -1
  68. package/dist/src/svelte/ai/createRAGGrounding.d.ts +2 -2
  69. package/dist/src/svelte/ai/createRAGIndexAdmin.d.ts +1 -1
  70. package/dist/src/svelte/ai/createRAGIngest.d.ts +1 -1
  71. package/dist/src/svelte/ai/createRAGOps.d.ts +1 -1
  72. package/dist/src/svelte/ai/createRAGSearch.d.ts +3 -3
  73. package/dist/src/svelte/ai/createRAGSources.d.ts +2 -2
  74. package/dist/src/svelte/ai/createRAGStatus.d.ts +1 -1
  75. package/dist/src/svelte/ai/createRAGStream.d.ts +1 -1
  76. package/dist/src/svelte/ai/createRAGStreamProgress.d.ts +2 -2
  77. package/dist/src/svelte/ai/index.d.ts +17 -17
  78. package/dist/src/vue/ai/index.d.ts +17 -17
  79. package/dist/src/vue/ai/useRAGChunkPreview.d.ts +1 -1
  80. package/dist/src/vue/ai/useRAGCitations.d.ts +2 -2
  81. package/dist/src/vue/ai/useRAGDocuments.d.ts +1 -1
  82. package/dist/src/vue/ai/useRAGEvaluate.d.ts +1 -1
  83. package/dist/src/vue/ai/useRAGGrounding.d.ts +2 -2
  84. package/dist/src/vue/ai/useRAGIndexAdmin.d.ts +1 -1
  85. package/dist/src/vue/ai/useRAGIngest.d.ts +1 -1
  86. package/dist/src/vue/ai/useRAGOps.d.ts +1 -1
  87. package/dist/src/vue/ai/useRAGSearch.d.ts +3 -3
  88. package/dist/src/vue/ai/useRAGSources.d.ts +2 -2
  89. package/dist/src/vue/ai/useRAGStatus.d.ts +1 -1
  90. package/dist/src/vue/ai/useRAGStream.d.ts +1 -1
  91. package/dist/src/vue/ai/useRAGStreamProgress.d.ts +2 -2
  92. package/dist/svelte/ai/index.js.map +20 -20
  93. package/dist/vue/ai/index.js.map +20 -20
  94. package/package.json +104 -80
@@ -2,16 +2,16 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/angular/ai/ai-rag-workflow.service.ts", "../src/angular/ai/ai-rag-stream.service.ts", "../src/ai/rag/grounding.ts", "../src/ai/rag/quality.ts", "node:path", "../src/ai/rag/presentation.ts", "../src/angular/ai/rag-client.service.ts", "../src/ai/client/ragClient.ts"],
4
4
  "sourcesContent": [
5
- "import { computed, Injectable } from '@angular/core';\nimport { RAGStreamService } from './ai-rag-stream.service';\n\n@Injectable({ providedIn: 'root' })\nexport class RAGWorkflowService extends RAGStreamService {\n\tconnect(path: string, conversationId?: string) {\n\t\tconst stream = super.connect(path, conversationId);\n\n\t\treturn {\n\t\t\t...stream,\n\t\t\tstate: computed(() => stream.workflow())\n\t\t};\n\t}\n}\n",
6
- "import { computed, Injectable } from '@angular/core';\nimport {\n\tbuildRAGAnswerWorkflowState,\n\tbuildRAGStreamProgress\n} from '../../ai/rag/workflowState';\nimport { AIStreamService } from '@absolutejs/ai/angular';\n\n@Injectable({ providedIn: 'root' })\nexport class RAGStreamService extends AIStreamService {\n\tconnect(path: string, conversationId?: string) {\n\t\tconst stream = super.connect(path, conversationId);\n\n\t\tconst workflow = computed(() =>\n\t\t\tbuildRAGAnswerWorkflowState({\n\t\t\t\terror: stream.error(),\n\t\t\t\tisStreaming: stream.isStreaming(),\n\t\t\t\tmessages: stream.messages()\n\t\t\t})\n\t\t);\n\t\tconst progress = computed(() =>\n\t\t\tbuildRAGStreamProgress({\n\t\t\t\terror: stream.error(),\n\t\t\t\tisStreaming: stream.isStreaming(),\n\t\t\t\tmessages: stream.messages()\n\t\t\t})\n\t\t);\n\t\tconst latestAssistantMessage = computed(\n\t\t\t() => workflow().latestAssistantMessage\n\t\t);\n\t\tconst sources = computed(() => workflow().sources);\n\t\tconst sourceGroups = computed(() => workflow().sourceGroups);\n\t\tconst citations = computed(() => workflow().citations);\n\t\tconst sourceSummaries = computed(() => workflow().sourceSummaries);\n\t\tconst citationReferenceMap = computed(\n\t\t\t() => workflow().citationReferenceMap\n\t\t);\n\t\tconst retrieval = computed(() => workflow().retrieval);\n\t\tconst groundedAnswer = computed(() => workflow().groundedAnswer);\n\t\tconst groundingReferences = computed(\n\t\t\t() => workflow().groundingReferences\n\t\t);\n\t\tconst hasRetrieved = computed(() => workflow().hasRetrieved);\n\t\tconst hasSources = computed(() => workflow().hasSources);\n\t\tconst isRetrieving = computed(() => workflow().isRetrieving);\n\t\tconst isRetrieved = computed(() => workflow().isRetrieved);\n\t\tconst isAnswerStreaming = computed(() => workflow().isAnswerStreaming);\n\t\tconst isComplete = computed(() => workflow().isComplete);\n\t\tconst isError = computed(() => workflow().isError);\n\t\tconst isRunning = computed(() => workflow().isRunning);\n\t\tconst stage = computed(() => workflow().stage);\n\n\t\treturn {\n\t\t\t...stream,\n\t\t\tcitations,\n\t\t\tcitationReferenceMap,\n\t\t\tgroundedAnswer,\n\t\t\tgroundingReferences,\n\t\t\thasRetrieved,\n\t\t\thasSources,\n\t\t\tisAnswerStreaming,\n\t\t\tisComplete,\n\t\t\tisError,\n\t\t\tisRetrieved,\n\t\t\tisRetrieving,\n\t\t\tisRunning,\n\t\t\tlatestAssistantMessage,\n\t\t\tprogress,\n\t\t\tquery: stream.send,\n\t\t\tretrieval,\n\t\t\tsourceGroups,\n\t\t\tsourceSummaries,\n\t\t\tsources,\n\t\t\tstage,\n\t\t\tworkflow\n\t\t};\n\t}\n}\n",
7
- "import type {\n\tRAGCitation,\n\tRAGCitationReferenceMap,\n\tRAGExcerptModeCounts,\n\tRAGGroundedAnswer,\n\tRAGGroundedAnswerCitationDetail,\n\tRAGGroundedAnswerSectionSummary,\n\tRAGGroundingReference,\n\tRAGSource\n} from '@absolutejs/ai';\n\nconst getContextString = (value: unknown) =>\n\ttypeof value === 'string' && value.trim().length > 0\n\t\t? value.trim()\n\t\t: undefined;\n\nconst getContextNumber = (value: unknown) =>\n\ttypeof value === 'number' && Number.isFinite(value) ? value : undefined;\n\nconst getAttachmentName = (source?: string, title?: string) => {\n\tconst sourceAttachment = source?.split('/').at(-1);\n\tif (sourceAttachment && sourceAttachment.includes('.')) {\n\t\treturn sourceAttachment;\n\t}\n\n\tconst titleAttachment = title?.split(' · ').at(-1);\n\tif (titleAttachment && titleAttachment.includes('.')) {\n\t\treturn titleAttachment;\n\t}\n\n\treturn undefined;\n};\n\nconst buildContextLabel = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst emailKind = getContextString(metadata.emailKind);\n\tconst officeBlockKindValue = getContextString(metadata.officeBlockKind);\n\tconst officeBlockKind =\n\t\tofficeBlockKindValue === 'table' ||\n\t\tofficeBlockKindValue === 'list' ||\n\t\tofficeBlockKindValue === 'paragraph'\n\t\t\t? officeBlockKindValue\n\t\t\t: undefined;\n\tif (emailKind === 'attachment') {\n\t\treturn 'Attachment evidence';\n\t}\n\n\tif (emailKind === 'message') {\n\t\tconst from = getContextString(metadata.from);\n\t\treturn from ? `Message from ${from}` : 'Message evidence';\n\t}\n\n\tconst page =\n\t\tgetContextNumber(metadata.page) ??\n\t\tgetContextNumber(metadata.pageNumber) ??\n\t\t(typeof metadata.pageIndex === 'number'\n\t\t\t? metadata.pageIndex + 1\n\t\t\t: undefined);\n\tconst region =\n\t\tgetContextNumber(metadata.regionNumber) ??\n\t\t(typeof metadata.regionIndex === 'number'\n\t\t\t? metadata.regionIndex + 1\n\t\t\t: undefined);\n\tif (page && region) {\n\t\treturn `Page ${page} region ${region}`;\n\t}\n\tif (page) {\n\t\treturn `Page ${page}`;\n\t}\n\n\tconst sheet =\n\t\tgetContextString(metadata.sheetName) ??\n\t\t(Array.isArray(metadata.sheetNames)\n\t\t\t? getContextString(metadata.sheetNames[0])\n\t\t\t: undefined);\n\tif (sheet) {\n\t\treturn `Sheet ${sheet}`;\n\t}\n\n\tconst slide =\n\t\tgetContextNumber(metadata.slide) ??\n\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\tif (slide) {\n\t\treturn slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n\t}\n\n\tconst archiveEntry =\n\t\tgetContextString(metadata.archiveEntryPath) ??\n\t\tgetContextString(metadata.entryPath);\n\tif (archiveEntry) {\n\t\treturn `Archive entry ${archiveEntry}`;\n\t}\n\n\tconst threadTopic = getContextString(metadata.threadTopic);\n\tif (threadTopic) {\n\t\treturn `Thread ${threadTopic}`;\n\t}\n\n\tconst speaker = getContextString(metadata.speaker);\n\tif (speaker) {\n\t\treturn `Speaker ${speaker}`;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tconst officeSectionLabel =\n\t\tsectionPath.length > 0 ? sectionPath.join(' > ') : sectionTitle;\n\tif (officeBlockKind === 'table' && officeSectionLabel) {\n\t\treturn `Office table block ${officeSectionLabel}`;\n\t}\n\tif (officeBlockKind === 'list' && officeSectionLabel) {\n\t\treturn `Office list block ${officeSectionLabel}`;\n\t}\n\tif (officeBlockKind === 'paragraph' && officeSectionLabel) {\n\t\treturn `Office paragraph block ${officeSectionLabel}`;\n\t}\n\tif (sectionTitle) {\n\t\treturn `Section ${sectionTitle}`;\n\t}\n\n\treturn undefined;\n};\n\nconst formatMediaTimestamp = (value: unknown) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value) || value < 0) {\n\t\treturn undefined;\n\t}\n\n\tconst totalSeconds = Math.floor(value / 1000);\n\tconst minutes = Math.floor(totalSeconds / 60);\n\tconst seconds = totalSeconds % 60;\n\tconst milliseconds = Math.floor(value % 1000);\n\n\treturn `${String(minutes).padStart(2, '0')}:${String(seconds).padStart(\n\t\t2,\n\t\t'0'\n\t)}.${String(milliseconds).padStart(3, '0')}`;\n};\n\nconst formatMediaDurationLabel = (value: unknown) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value) || value < 0) {\n\t\treturn undefined;\n\t}\n\n\treturn formatMediaTimestamp(value);\n};\n\nconst formatOfficeListLevelsLabel = (value: unknown) => {\n\tif (!Array.isArray(value) || value.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst levels = value\n\t\t.map((entry) => getContextNumber(entry))\n\t\t.filter((entry): entry is number => typeof entry === 'number')\n\t\t.sort((left, right) => left - right);\n\n\tif (levels.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst minLevel = levels[0];\n\tconst maxLevel = levels[levels.length - 1];\n\n\treturn minLevel === maxLevel\n\t\t? `Office list level ${minLevel}`\n\t\t: `Office list levels ${minLevel}-${maxLevel}`;\n};\n\ntype OfficeCitationScope = {\n\tblockKind: 'list' | 'paragraph' | 'table';\n\tfamilyPath: string[];\n\thasContext: boolean;\n\tordinalPath: number[];\n\tpathDepth: number;\n\tsectionFamilyKey: string;\n\tsectionOrdinal: number;\n\tsectionTitle: string;\n};\n\ntype GenericStructuredCitationScope = {\n\tfamilyPath: string[];\n\tkind: 'presentation_slide' | 'spreadsheet_rows';\n\tordinalPath: number[];\n\tpathDepth: number;\n\tsectionFamilyKey: string;\n\tsectionOrdinal: number;\n};\n\nconst getOfficeTableCitationScope = (\n\tmetadata?: Record<string, unknown>\n): OfficeCitationScope | undefined => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst officeBlockKindValue = getContextString(metadata.officeBlockKind);\n\tconst officeBlockKind =\n\t\tofficeBlockKindValue === 'table' ||\n\t\tofficeBlockKindValue === 'list' ||\n\t\tofficeBlockKindValue === 'paragraph'\n\t\t\t? officeBlockKindValue\n\t\t\t: undefined;\n\tif (\n\t\tofficeBlockKind !== 'table' &&\n\t\tofficeBlockKind !== 'list' &&\n\t\tofficeBlockKind !== 'paragraph'\n\t) {\n\t\treturn undefined;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tconst officeContextText =\n\t\tofficeBlockKind === 'table'\n\t\t\t? getContextString(metadata.officeTableContextText)\n\t\t\t: officeBlockKind === 'list'\n\t\t\t\t? getContextString(metadata.officeListContextText)\n\t\t\t\t: undefined;\n\n\tif (!sectionTitle) {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tblockKind: officeBlockKind,\n\t\tfamilyPath: (() => {\n\t\t\tconst explicitGenericFamilyPath = Array.isArray(\n\t\t\t\tmetadata.sectionFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.sectionFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tconst explicitGenericOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.sectionOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.sectionOrdinalPath\n\t\t\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tif (\n\t\t\t\texplicitGenericFamilyPath.length > 0 &&\n\t\t\t\texplicitGenericFamilyPath.length ===\n\t\t\t\t\texplicitGenericOrdinalPath.length\n\t\t\t) {\n\t\t\t\treturn explicitGenericFamilyPath;\n\t\t\t}\n\n\t\t\tconst explicitOfficeFamilyPath = Array.isArray(\n\t\t\t\tmetadata.officeFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.officeFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\treturn explicitOfficeFamilyPath.length > 0\n\t\t\t\t? explicitOfficeFamilyPath\n\t\t\t\t: sectionPath.map((value) =>\n\t\t\t\t\t\tvalue.replace(/\\s+\\((\\d+)\\)$/, '').trim()\n\t\t\t\t\t);\n\t\t})(),\n\t\tpathDepth: sectionPath.length,\n\t\tordinalPath: (() => {\n\t\t\tconst explicitGenericFamilyPath = Array.isArray(\n\t\t\t\tmetadata.sectionFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.sectionFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tconst explicitGenericOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.sectionOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.sectionOrdinalPath\n\t\t\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tif (\n\t\t\t\texplicitGenericFamilyPath.length > 0 &&\n\t\t\t\texplicitGenericFamilyPath.length ===\n\t\t\t\t\texplicitGenericOrdinalPath.length\n\t\t\t) {\n\t\t\t\treturn explicitGenericOrdinalPath;\n\t\t\t}\n\n\t\t\tconst explicitOfficeOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.officeOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.officeOrdinalPath\n\t\t\t\t\t\t.map((value) =>\n\t\t\t\t\t\t\ttypeof value === 'number' && Number.isFinite(value)\n\t\t\t\t\t\t\t\t? value\n\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\treturn explicitOfficeOrdinalPath.length > 0\n\t\t\t\t? explicitOfficeOrdinalPath\n\t\t\t\t: sectionPath.map((value) => {\n\t\t\t\t\t\tconst match = value.match(/\\((\\d+)\\)$/);\n\t\t\t\t\t\treturn match ? Number.parseInt(match[1] ?? '1', 10) : 1;\n\t\t\t\t\t});\n\t\t})(),\n\t\tsectionFamilyKey:\n\t\t\tgetContextString(metadata.sectionSiblingFamilyKey) ??\n\t\t\tgetContextString(metadata.officeSiblingFamilyKey) ??\n\t\t\tsectionPath\n\t\t\t\t.at(-1)\n\t\t\t\t?.replace(/\\s+\\((\\d+)\\)$/, '')\n\t\t\t\t.trim() ??\n\t\t\tsectionTitle,\n\t\tsectionOrdinal:\n\t\t\tgetContextNumber(metadata.sectionSiblingOrdinal) ??\n\t\t\tgetContextNumber(metadata.officeSiblingOrdinal) ??\n\t\t\t(() => {\n\t\t\t\tconst match = sectionTitle.match(/\\((\\d+)\\)$/);\n\t\t\t\treturn match ? Number.parseInt(match[1] ?? '1', 10) : 1;\n\t\t\t})(),\n\t\tsectionTitle,\n\t\thasContext: typeof officeContextText === 'string'\n\t};\n};\n\nconst areOfficeCitationScopesComparable = (\n\tleft:\n\t\t| {\n\t\t\t\tblockKind: 'list' | 'paragraph' | 'table';\n\t\t\t\tfamilyPath: string[];\n\t\t\t\thasContext: boolean;\n\t\t\t\tordinalPath: number[];\n\t\t\t\tpathDepth: number;\n\t\t\t\tsectionFamilyKey: string;\n\t\t\t\tsectionOrdinal: number;\n\t\t\t\tsectionTitle: string;\n\t\t }\n\t\t| undefined,\n\tright:\n\t\t| {\n\t\t\t\tblockKind: 'list' | 'paragraph' | 'table';\n\t\t\t\tfamilyPath: string[];\n\t\t\t\thasContext: boolean;\n\t\t\t\tordinalPath: number[];\n\t\t\t\tpathDepth: number;\n\t\t\t\tsectionFamilyKey: string;\n\t\t\t\tsectionOrdinal: number;\n\t\t\t\tsectionTitle: string;\n\t\t }\n\t\t| undefined\n) => {\n\tif (!left || !right) {\n\t\treturn false;\n\t}\n\tif (\n\t\tleft.blockKind !== right.blockKind ||\n\t\tleft.sectionFamilyKey !== right.sectionFamilyKey ||\n\t\tleft.sectionOrdinal !== right.sectionOrdinal\n\t) {\n\t\treturn false;\n\t}\n\tconst leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n\tconst rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n\tconst leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n\tconst rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n\tconst sharedDepth = Math.min(\n\t\tleftAncestorFamilyPath.length,\n\t\trightAncestorFamilyPath.length\n\t);\n\tfor (let index = 0; index < sharedDepth; index += 1) {\n\t\tif (\n\t\t\tleftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n\t\t\tleftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn true;\n};\n\nconst getGenericStructuredCitationScope = (\n\tmetadata?: Record<string, unknown>\n): GenericStructuredCitationScope | undefined => {\n\tif (!metadata || metadata.officeBlockKind || metadata.pageNumber) {\n\t\treturn undefined;\n\t}\n\n\tconst kind =\n\t\tmetadata.sectionKind === 'spreadsheet_rows' ||\n\t\tmetadata.sectionKind === 'presentation_slide'\n\t\t\t? metadata.sectionKind\n\t\t\t: undefined;\n\tif (!kind) {\n\t\treturn undefined;\n\t}\n\n\tconst explicitFamilyPath = Array.isArray(metadata.sectionFamilyPath)\n\t\t? metadata.sectionFamilyPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst explicitOrdinalPath = Array.isArray(metadata.sectionOrdinalPath)\n\t\t? metadata.sectionOrdinalPath\n\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t.filter((value): value is number => typeof value === 'number')\n\t\t: [];\n\tlet familyPath =\n\t\texplicitFamilyPath.length > 0 &&\n\t\texplicitFamilyPath.length === explicitOrdinalPath.length\n\t\t\t? explicitFamilyPath\n\t\t\t: [];\n\tlet ordinalPath =\n\t\texplicitFamilyPath.length > 0 &&\n\t\texplicitFamilyPath.length === explicitOrdinalPath.length\n\t\t\t? explicitOrdinalPath\n\t\t\t: [];\n\n\tif (familyPath.length === 0) {\n\t\tif (kind === 'spreadsheet_rows') {\n\t\t\tconst sheetName = getContextString(metadata.sheetName) ?? 'Sheet';\n\t\t\tconst tableIndex =\n\t\t\t\tgetContextNumber(metadata.spreadsheetTableIndex) ?? 1;\n\t\t\tfamilyPath = [sheetName, 'Spreadsheet Table'];\n\t\t\tordinalPath = [1, tableIndex];\n\t\t} else {\n\t\t\tconst slideFamily =\n\t\t\t\tgetContextString(metadata.slideTitle) ?? 'Slide';\n\t\t\tconst slideOrdinal =\n\t\t\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t\t\t? metadata.slideIndex + 1\n\t\t\t\t\t: 1);\n\t\t\tfamilyPath = [slideFamily];\n\t\t\tordinalPath = [slideOrdinal];\n\t\t}\n\t}\n\n\tconst sectionFamilyKey =\n\t\tgetContextString(metadata.sectionSiblingFamilyKey) ?? familyPath.at(-1);\n\tconst sectionOrdinal =\n\t\tgetContextNumber(metadata.sectionSiblingOrdinal) ?? ordinalPath.at(-1);\n\tif (!sectionFamilyKey || typeof sectionOrdinal !== 'number') {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tfamilyPath,\n\t\tkind,\n\t\tordinalPath,\n\t\tpathDepth: familyPath.length,\n\t\tsectionFamilyKey,\n\t\tsectionOrdinal\n\t};\n};\n\nconst areGenericStructuredCitationScopesComparable = (\n\tleft: GenericStructuredCitationScope | undefined,\n\tright: GenericStructuredCitationScope | undefined\n) => {\n\tif (!left || !right) {\n\t\treturn false;\n\t}\n\tif (\n\t\tleft.kind !== right.kind ||\n\t\tleft.sectionFamilyKey !== right.sectionFamilyKey ||\n\t\tleft.sectionOrdinal !== right.sectionOrdinal\n\t) {\n\t\treturn false;\n\t}\n\tconst leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n\tconst rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n\tconst leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n\tconst rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n\tconst sharedDepth = Math.min(\n\t\tleftAncestorFamilyPath.length,\n\t\trightAncestorFamilyPath.length\n\t);\n\tfor (let index = 0; index < sharedDepth; index += 1) {\n\t\tif (\n\t\t\tleftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n\t\t\tleftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn true;\n};\n\nconst getOfficeTableCitationPreference = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tconst scope = getOfficeTableCitationScope(metadata);\n\tif (!scope) {\n\t\treturn 0;\n\t}\n\n\treturn (\n\t\tscope.pathDepth * 10 +\n\t\t(scope.hasContext ? 1 : 0) +\n\t\t(scope.blockKind === 'list' &&\n\t\ttypeof metadata?.officeListGroupItemCount === 'number' &&\n\t\tmetadata.officeListGroupItemCount > 1\n\t\t\t? 1\n\t\t\t: 0)\n\t);\n};\n\nconst getGenericStructuredCitationPreference = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tconst scope = getGenericStructuredCitationScope(metadata);\n\tif (!scope) {\n\t\treturn 0;\n\t}\n\n\treturn (\n\t\tscope.pathDepth * 10 +\n\t\t(scope.kind === 'spreadsheet_rows' &&\n\t\ttypeof metadata?.spreadsheetTableIndex === 'number'\n\t\t\t? 2\n\t\t\t: 0) +\n\t\t(Array.isArray(metadata?.spreadsheetHeaders) &&\n\t\tmetadata.spreadsheetHeaders.length > 0\n\t\t\t? 1\n\t\t\t: 0) +\n\t\t(typeof metadata?.slideNotesText === 'string' &&\n\t\tmetadata.slideNotesText.trim().length > 0\n\t\t\t? 1\n\t\t\t: 0)\n\t);\n};\n\nconst buildLocatorLabel = (\n\tmetadata?: Record<string, unknown>,\n\tsource?: string,\n\ttitle?: string\n) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst page =\n\t\tgetContextNumber(metadata.page) ??\n\t\tgetContextNumber(metadata.pageNumber) ??\n\t\t(typeof metadata.pageIndex === 'number'\n\t\t\t? metadata.pageIndex + 1\n\t\t\t: undefined);\n\tconst region =\n\t\tgetContextNumber(metadata.regionNumber) ??\n\t\t(typeof metadata.regionIndex === 'number'\n\t\t\t? metadata.regionIndex + 1\n\t\t\t: undefined);\n\tif (page && region) {\n\t\treturn `Page ${page} · Region ${region}`;\n\t}\n\tif (page) {\n\t\treturn `Page ${page}`;\n\t}\n\n\tconst sheet =\n\t\tgetContextString(metadata.sheetName) ??\n\t\t(Array.isArray(metadata.sheetNames)\n\t\t\t? getContextString(metadata.sheetNames[0])\n\t\t\t: undefined);\n\tif (sheet) {\n\t\treturn `Sheet ${sheet}`;\n\t}\n\n\tconst slide =\n\t\tgetContextNumber(metadata.slide) ??\n\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\tif (slide) {\n\t\treturn slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n\t}\n\n\tconst archiveEntry =\n\t\tgetContextString(metadata.archiveEntryPath) ??\n\t\tgetContextString(metadata.entryPath);\n\tif (archiveEntry) {\n\t\treturn `Archive entry ${archiveEntry}`;\n\t}\n\n\tconst emailKind = getContextString(metadata.emailKind);\n\tconst officeBlockKind = getContextString(metadata.officeBlockKind);\n\tconst officeBlockNumber = getContextNumber(metadata.officeBlockNumber);\n\tconst officeTableBodyRowStart = getContextNumber(\n\t\tmetadata.officeTableBodyRowStart\n\t);\n\tconst officeTableBodyRowEnd = getContextNumber(\n\t\tmetadata.officeTableBodyRowEnd\n\t);\n\tif (emailKind === 'attachment') {\n\t\tconst attachmentName =\n\t\t\tgetContextString(metadata.attachmentName) ??\n\t\t\tgetAttachmentName(source, title);\n\t\treturn attachmentName ? `Attachment ${attachmentName}` : 'Attachment';\n\t}\n\n\tconst mediaStart = formatMediaTimestamp(metadata.startMs);\n\tconst mediaEnd = formatMediaTimestamp(metadata.endMs);\n\tif (mediaStart && mediaEnd) {\n\t\treturn `Timestamp ${mediaStart} - ${mediaEnd}`;\n\t}\n\n\tif (mediaStart) {\n\t\treturn `Timestamp ${mediaStart}`;\n\t}\n\n\tif (officeBlockNumber && officeBlockKind === 'table') {\n\t\tif (\n\t\t\ttypeof officeTableBodyRowStart === 'number' &&\n\t\t\ttypeof officeTableBodyRowEnd === 'number'\n\t\t) {\n\t\t\treturn officeTableBodyRowStart === officeTableBodyRowEnd\n\t\t\t\t? `Office table block ${officeBlockNumber} · Row ${officeTableBodyRowStart}`\n\t\t\t\t: `Office table block ${officeBlockNumber} · Rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`;\n\t\t}\n\t\treturn `Office table block ${officeBlockNumber}`;\n\t}\n\tif (officeBlockNumber && officeBlockKind === 'list') {\n\t\treturn `Office list block ${officeBlockNumber}`;\n\t}\n\tif (officeBlockNumber && officeBlockKind === 'paragraph') {\n\t\treturn `Office paragraph block ${officeBlockNumber}`;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tif (sectionPath.length > 0) {\n\t\treturn `Section ${sectionPath.join(' > ')}`;\n\t}\n\n\treturn undefined;\n};\n\nconst formatTimestampLabel = (value: unknown) => {\n\tconst timestamp =\n\t\ttypeof value === 'number' && Number.isFinite(value)\n\t\t\t? value\n\t\t\t: typeof value === 'string'\n\t\t\t\t? Date.parse(value)\n\t\t\t\t: Number.NaN;\n\tif (!Number.isFinite(timestamp)) {\n\t\treturn undefined;\n\t}\n\n\treturn new Date(timestamp).toLocaleString('en-US', {\n\t\tdateStyle: 'medium',\n\t\ttimeStyle: 'short'\n\t});\n};\n\nconst buildProvenanceLabel = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst threadTopic = getContextString(metadata.threadTopic);\n\tconst from = getContextString(metadata.from);\n\tconst sentAt =\n\t\tformatTimestampLabel(metadata.sentAt) ??\n\t\tformatTimestampLabel(metadata.receivedAt);\n\tconst speaker = getContextString(metadata.speaker);\n\tconst mediaKind = getContextString(metadata.mediaKind);\n\tconst mediaSegmentCount = getContextNumber(metadata.mediaSegmentCount);\n\tconst mediaSegmentGroupSize = getContextNumber(\n\t\tmetadata.mediaSegmentGroupSize\n\t);\n\tconst mediaSegmentGroupIndex = getContextNumber(\n\t\tmetadata.mediaSegmentGroupIndex\n\t);\n\tconst mediaChannel = getContextString(metadata.mediaChannel);\n\tconst mediaSpeakerCount = getContextNumber(metadata.mediaSpeakerCount);\n\tconst mediaDurationLabel = formatMediaDurationLabel(\n\t\tmetadata.mediaDurationMs\n\t);\n\tconst transcriptSource = getContextString(metadata.transcriptSource);\n\tconst pdfTextMode = getContextString(metadata.pdfTextMode);\n\tconst officeBlockKind = getContextString(metadata.officeBlockKind);\n\tconst officeListContextText = getContextString(\n\t\tmetadata.officeListContextText\n\t);\n\tconst officeListGroupItemCount = getContextNumber(\n\t\tmetadata.officeListGroupItemCount\n\t);\n\tconst officeListLevelsLabel = formatOfficeListLevelsLabel(\n\t\tmetadata.officeListLevels\n\t);\n\tconst officeTableHeaders = Array.isArray(metadata.officeTableHeaders)\n\t\t? metadata.officeTableHeaders\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst officeTableColumnCount = getContextNumber(\n\t\tmetadata.officeTableColumnCount\n\t);\n\tconst officeTableBodyRowCount = getContextNumber(\n\t\tmetadata.officeTableBodyRowCount\n\t);\n\tconst officeTableBodyRowStart = getContextNumber(\n\t\tmetadata.officeTableBodyRowStart\n\t);\n\tconst officeTableBodyRowEnd = getContextNumber(\n\t\tmetadata.officeTableBodyRowEnd\n\t);\n\tconst officeTableContextText = getContextString(\n\t\tmetadata.officeTableContextText\n\t);\n\tconst officeTableFollowUpText = getContextString(\n\t\tmetadata.officeTableFollowUpText\n\t);\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst ocrEngine = getContextString(metadata.ocrEngine);\n\tconst ocrConfidence =\n\t\tgetContextNumber(metadata.ocrRegionConfidence) ??\n\t\tgetContextNumber(metadata.ocrConfidence);\n\n\tconst labels = [\n\t\tpdfTextMode ? `PDF ${pdfTextMode}` : '',\n\t\tofficeBlockKind ? `Office ${officeBlockKind}` : '',\n\t\ttypeof officeListGroupItemCount === 'number'\n\t\t\t? `Office list ${officeListGroupItemCount} items`\n\t\t\t: '',\n\t\tofficeListLevelsLabel ?? '',\n\t\tsectionPath.length > 0 && officeBlockKind\n\t\t\t? `Source-aware office ${officeBlockKind} block ${sectionPath.join(' > ')}`\n\t\t\t: '',\n\t\tofficeListContextText\n\t\t\t? `Office list context ${officeListContextText}`\n\t\t\t: '',\n\t\tofficeTableHeaders.length > 0\n\t\t\t? `Office table ${officeTableHeaders.join(', ')}`\n\t\t\t: '',\n\t\ttypeof officeTableColumnCount === 'number'\n\t\t\t? `Office table ${officeTableColumnCount} cols`\n\t\t\t: '',\n\t\ttypeof officeTableBodyRowCount === 'number'\n\t\t\t? `Office table ${officeTableBodyRowCount} body rows`\n\t\t\t: '',\n\t\ttypeof officeTableBodyRowStart === 'number' &&\n\t\ttypeof officeTableBodyRowEnd === 'number'\n\t\t\t? officeTableBodyRowStart === officeTableBodyRowEnd\n\t\t\t\t? `Office table row ${officeTableBodyRowStart}`\n\t\t\t\t: `Office table rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`\n\t\t\t: '',\n\t\tofficeTableContextText\n\t\t\t? `Office table context ${officeTableContextText}`\n\t\t\t: '',\n\t\tofficeTableFollowUpText\n\t\t\t? `Office table follow-up ${officeTableFollowUpText}`\n\t\t\t: '',\n\t\tocrEngine ? `OCR ${ocrEngine}` : '',\n\t\ttypeof ocrConfidence === 'number'\n\t\t\t? `Confidence ${ocrConfidence.toFixed(2)}`\n\t\t\t: '',\n\t\tmediaKind ? `Media ${mediaKind}` : '',\n\t\tmediaSegmentCount ? `${mediaSegmentCount} segments` : '',\n\t\tmediaSegmentGroupSize\n\t\t\t? `${mediaSegmentGroupSize} grouped segments`\n\t\t\t: '',\n\t\tmediaSegmentGroupIndex !== undefined\n\t\t\t? `Segment group ${mediaSegmentGroupIndex + 1}`\n\t\t\t: '',\n\t\tmediaChannel ? `Channel ${mediaChannel}` : '',\n\t\tmediaSpeakerCount ? `${mediaSpeakerCount} speakers` : '',\n\t\tmediaDurationLabel ? `Duration ${mediaDurationLabel}` : '',\n\t\ttranscriptSource ? `Transcript ${transcriptSource}` : '',\n\t\tthreadTopic ? `Thread ${threadTopic}` : '',\n\t\tspeaker ? `Speaker ${speaker}` : '',\n\t\tfrom ? `Sender ${from}` : '',\n\t\tsentAt ? `Sent ${sentAt}` : ''\n\t].filter((value) => value.length > 0);\n\n\treturn labels.length > 0 ? labels.join(' · ') : undefined;\n};\n\nconst buildSourceLabel = (source: RAGSource) =>\n\tsource.source ?? source.title ?? source.chunkId;\n\nconst buildExcerpt = (text: string, maxLength = 160) => {\n\tconst normalized = text.replaceAll(/\\s+/g, ' ').trim();\n\tif (normalized.length <= maxLength) {\n\t\treturn normalized;\n\t}\n\n\treturn `${normalized.slice(0, Math.max(0, maxLength - 1)).trimEnd()}…`;\n};\n\nconst selectPreferredExcerpt = (\n\texcerpts?: {\n\t\tchunkExcerpt?: string;\n\t\twindowExcerpt?: string;\n\t\tsectionExcerpt?: string;\n\t},\n\tsectionChunkCount?: number\n) => {\n\tif (!excerpts) {\n\t\treturn {\n\t\t\texcerpt: '',\n\t\t\tmode: 'chunk' as const,\n\t\t\treason: 'single_chunk' as const\n\t\t};\n\t}\n\n\tconst chunkExcerpt = excerpts.chunkExcerpt?.trim() ?? '';\n\tconst windowExcerpt = excerpts.windowExcerpt?.trim() ?? '';\n\tconst sectionExcerpt = excerpts.sectionExcerpt?.trim() ?? '';\n\tif (\n\t\tsectionChunkCount &&\n\t\tsectionChunkCount > 1 &&\n\t\tchunkExcerpt.length > 0 &&\n\t\tchunkExcerpt.length < 72\n\t) {\n\t\tif (sectionChunkCount <= 3 && sectionExcerpt) {\n\t\t\treturn {\n\t\t\t\texcerpt: sectionExcerpt,\n\t\t\t\tmode: 'section' as const,\n\t\t\t\treason: 'section_small_enough' as const\n\t\t\t};\n\t\t}\n\t\tif (windowExcerpt) {\n\t\t\treturn {\n\t\t\t\texcerpt: windowExcerpt,\n\t\t\t\tmode: 'window' as const,\n\t\t\t\treason: 'section_too_large_use_window' as const\n\t\t\t};\n\t\t}\n\n\t\treturn {\n\t\t\texcerpt: chunkExcerpt,\n\t\t\tmode: 'chunk' as const,\n\t\t\treason: 'chunk_too_narrow' as const\n\t\t};\n\t}\n\n\treturn {\n\t\texcerpt: chunkExcerpt || windowExcerpt || sectionExcerpt,\n\t\tmode: 'chunk' as const,\n\t\treason:\n\t\t\t(sectionChunkCount ?? 0) > 1\n\t\t\t\t? ('chunk_too_narrow' as const)\n\t\t\t\t: ('single_chunk' as const)\n\t};\n};\n\nconst buildExcerptModeCounts = (\n\treferences: Array<\n\t\t| { excerptSelection?: { mode: 'chunk' | 'window' | 'section' } }\n\t\t| undefined\n\t>\n): RAGExcerptModeCounts =>\n\treferences.reduce<RAGExcerptModeCounts>(\n\t\t(counts, reference) => {\n\t\t\tif (reference?.excerptSelection) {\n\t\t\t\tcounts[reference.excerptSelection.mode] += 1;\n\t\t\t}\n\t\t\treturn counts;\n\t\t},\n\t\t{ chunk: 0, section: 0, window: 0 }\n\t);\n\nconst buildGroundingChunkExcerpts = (\n\tsources: RAGSource[],\n\tactiveChunkId?: string\n) => {\n\tif (sources.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst activeSource =\n\t\t(activeChunkId\n\t\t\t? sources.find((source) => source.chunkId === activeChunkId)\n\t\t\t: undefined) ?? sources[0];\n\tif (!activeSource) {\n\t\treturn undefined;\n\t}\n\n\tconst chunkMap = new Map(sources.map((source) => [source.chunkId, source]));\n\tconst activeMetadata = activeSource.metadata ?? {};\n\tconst previousChunkId = getContextString(activeMetadata.previousChunkId);\n\tconst nextChunkId = getContextString(activeMetadata.nextChunkId);\n\tconst sectionChunkId = getContextString(activeMetadata.sectionChunkId);\n\tconst sectionSources = sectionChunkId\n\t\t? sources\n\t\t\t\t.filter(\n\t\t\t\t\t(source) =>\n\t\t\t\t\t\tgetContextString(source.metadata?.sectionChunkId) ===\n\t\t\t\t\t\tsectionChunkId\n\t\t\t\t)\n\t\t\t\t.sort((left, right) => {\n\t\t\t\t\tconst leftIndex =\n\t\t\t\t\t\tgetContextNumber(left.metadata?.sectionChunkIndex) ??\n\t\t\t\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\t\t\t\tconst rightIndex =\n\t\t\t\t\t\tgetContextNumber(right.metadata?.sectionChunkIndex) ??\n\t\t\t\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\t\t\t\tif (leftIndex !== rightIndex) {\n\t\t\t\t\t\treturn leftIndex - rightIndex;\n\t\t\t\t\t}\n\t\t\t\t\treturn left.chunkId.localeCompare(right.chunkId);\n\t\t\t\t})\n\t\t: [activeSource];\n\tconst collectText = (chunkIds: string[]) =>\n\t\tchunkIds\n\t\t\t.map((chunkId) => chunkMap.get(chunkId)?.text)\n\t\t\t.filter((text): text is string => typeof text === 'string')\n\t\t\t.join('\\n\\n');\n\tconst orderedWindowIds = [\n\t\tpreviousChunkId,\n\t\tactiveSource.chunkId,\n\t\tnextChunkId\n\t].filter(\n\t\t(chunkId, index, values): chunkId is string =>\n\t\t\tBoolean(chunkId) && values.indexOf(chunkId) === index\n\t);\n\n\treturn {\n\t\tchunkExcerpt: buildExcerpt(activeSource.text, 160),\n\t\tsectionExcerpt: buildExcerpt(\n\t\t\tsectionSources.map((source) => source.text).join('\\n\\n'),\n\t\t\t320\n\t\t),\n\t\twindowExcerpt: buildExcerpt(collectText(orderedWindowIds), 240)\n\t};\n};\n\nconst buildGroundingReferenceEvidenceLabel = (\n\treference: RAGGroundingReference\n) =>\n\t[reference.label, reference.locatorLabel, reference.contextLabel]\n\t\t.filter((value): value is string => Boolean(value && value.length > 0))\n\t\t.filter(\n\t\t\t(value, index, values) =>\n\t\t\t\tvalues.findIndex((entry) => entry === value) === index\n\t\t)\n\t\t.join(' · ');\n\nconst buildGroundingReferenceEvidenceSummary = (\n\treference: RAGGroundingReference\n) =>\n\t[\n\t\treference.source ?? reference.title ?? reference.chunkId,\n\t\treference.locatorLabel,\n\t\treference.contextLabel,\n\t\treference.provenanceLabel\n\t]\n\t\t.filter((value): value is string => Boolean(value && value.length > 0))\n\t\t.filter(\n\t\t\t(value, index, values) =>\n\t\t\t\tvalues.findIndex((entry) => entry === value) === index\n\t\t)\n\t\t.join(' · ');\n\nconst buildGroundingSectionKey = (reference: RAGGroundingReference) =>\n\treference.contextLabel ??\n\treference.locatorLabel ??\n\treference.label ??\n\treference.source ??\n\treference.chunkId;\n\nconst buildGroundingSectionSummaryLine = (reference: RAGGroundingReference) =>\n\t[\n\t\treference.source ?? reference.title ?? reference.chunkId,\n\t\treference.locatorLabel,\n\t\treference.contextLabel,\n\t\treference.provenanceLabel\n\t]\n\t\t.filter((value): value is string => Boolean(value && value.length > 0))\n\t\t.filter(\n\t\t\t(value, index, values) =>\n\t\t\t\tvalues.findIndex((entry) => entry === value) === index\n\t\t)\n\t\t.join(' · ');\n\nconst buildGroundedAnswerCitationDetail = (\n\treference: RAGGroundingReference\n): RAGGroundedAnswerCitationDetail => ({\n\tcontextLabel: reference.contextLabel,\n\tevidenceLabel: buildGroundingReferenceEvidenceLabel(reference),\n\tevidenceSummary: buildGroundingReferenceEvidenceSummary(reference),\n\texcerpt:\n\t\tselectPreferredExcerpt(\n\t\t\treference.excerpts,\n\t\t\tgetContextNumber(reference.metadata?.sectionChunkCount)\n\t\t).excerpt || reference.excerpt,\n\texcerpts: reference.excerpts,\n\texcerptSelection: reference.excerptSelection,\n\tlabel: reference.label,\n\tlocatorLabel: reference.locatorLabel,\n\tnumber: reference.number,\n\tprovenanceLabel: reference.provenanceLabel,\n\tsource: reference.source,\n\ttitle: reference.title\n});\n\nexport const buildRAGCitationReferenceMap = (\n\tcitations: RAGCitation[]\n): RAGCitationReferenceMap =>\n\tObject.fromEntries(\n\t\tcitations.map((citation, index) => [citation.chunkId, index + 1])\n\t);\n\nexport const buildRAGCitations = (sources: RAGSource[]) => {\n\tconst unique = new Map<string, RAGCitation>();\n\n\tfor (const source of sources) {\n\t\tconst key = source.chunkId;\n\t\tconst existing = unique.get(key);\n\t\tconst hasBetterExisting =\n\t\t\texisting !== undefined && existing.score >= source.score;\n\t\tif (hasBetterExisting) continue;\n\t\tconst excerpts = buildGroundingChunkExcerpts(sources, source.chunkId);\n\t\tconst excerptSelection = selectPreferredExcerpt(\n\t\t\texcerpts,\n\t\t\tgetContextNumber(source.metadata?.sectionChunkCount)\n\t\t);\n\n\t\tunique.set(key, {\n\t\t\tchunkId: source.chunkId,\n\t\t\tcontextLabel:\n\t\t\t\tsource.labels?.contextLabel ??\n\t\t\t\tbuildContextLabel(source.metadata),\n\t\t\texcerpt: excerptSelection.excerpt || buildExcerpt(source.text),\n\t\t\texcerpts,\n\t\t\texcerptSelection,\n\t\t\tkey,\n\t\t\tlabel: buildSourceLabel(source),\n\t\t\tlocatorLabel:\n\t\t\t\tsource.labels?.locatorLabel ??\n\t\t\t\tbuildLocatorLabel(source.metadata, source.source, source.title),\n\t\t\tmetadata: source.metadata,\n\t\t\tprovenanceLabel:\n\t\t\t\tsource.labels?.provenanceLabel ??\n\t\t\t\tbuildProvenanceLabel(source.metadata),\n\t\t\tscore: source.score,\n\t\t\tsource: source.source,\n\t\t\ttext: source.text,\n\t\t\ttitle: source.title\n\t\t});\n\t}\n\n\treturn [...unique.values()].sort((left, right) => {\n\t\tconst leftOfficeScope = getOfficeTableCitationScope(left.metadata);\n\t\tconst rightOfficeScope = getOfficeTableCitationScope(right.metadata);\n\t\tif (\n\t\t\tleft.source === right.source &&\n\t\t\tareOfficeCitationScopesComparable(leftOfficeScope, rightOfficeScope)\n\t\t) {\n\t\t\tconst leftOfficePreference = getOfficeTableCitationPreference(\n\t\t\t\tleft.metadata\n\t\t\t);\n\t\t\tconst rightOfficePreference = getOfficeTableCitationPreference(\n\t\t\t\tright.metadata\n\t\t\t);\n\t\t\tif (rightOfficePreference !== leftOfficePreference) {\n\t\t\t\treturn rightOfficePreference - leftOfficePreference;\n\t\t\t}\n\t\t}\n\t\tconst leftGenericScope = getGenericStructuredCitationScope(\n\t\t\tleft.metadata\n\t\t);\n\t\tconst rightGenericScope = getGenericStructuredCitationScope(\n\t\t\tright.metadata\n\t\t);\n\t\tif (\n\t\t\tleft.source === right.source &&\n\t\t\tareGenericStructuredCitationScopesComparable(\n\t\t\t\tleftGenericScope,\n\t\t\t\trightGenericScope\n\t\t\t)\n\t\t) {\n\t\t\tconst leftGenericPreference =\n\t\t\t\tgetGenericStructuredCitationPreference(left.metadata);\n\t\t\tconst rightGenericPreference =\n\t\t\t\tgetGenericStructuredCitationPreference(right.metadata);\n\t\t\tif (rightGenericPreference !== leftGenericPreference) {\n\t\t\t\treturn rightGenericPreference - leftGenericPreference;\n\t\t\t}\n\t\t}\n\t\tif (right.score !== left.score) {\n\t\t\treturn right.score - left.score;\n\t\t}\n\n\t\treturn left.label.localeCompare(right.label);\n\t});\n};\n\nexport const buildRAGGroundedAnswer = (\n\tcontent: string,\n\tsources: RAGSource[]\n): RAGGroundedAnswer => {\n\tconst references = buildRAGGroundingReferences(sources);\n\tconst sectionSummaries = buildRAGGroundedAnswerSectionSummaries(references);\n\tconst referenceMap = new Map(\n\t\treferences.map((reference) => [reference.number, reference])\n\t);\n\tconst parts: RAGGroundedAnswer['parts'] = [];\n\tconst ungroundedReferenceNumbers = new Set<number>();\n\tconst citationPattern = /\\[(\\d+(?:\\s*,\\s*\\d+)*)\\]/g;\n\tlet cursor = 0;\n\n\tfor (const match of content.matchAll(citationPattern)) {\n\t\tconst raw = match[0];\n\t\tconst numbers = (match[1] ?? '')\n\t\t\t.split(',')\n\t\t\t.map((value) => Number.parseInt(value.trim(), 10))\n\t\t\t.filter((value) => Number.isInteger(value) && value > 0);\n\t\tconst start = match.index ?? cursor;\n\t\tif (start > cursor) {\n\t\t\tparts.push({\n\t\t\t\ttext: content.slice(cursor, start),\n\t\t\t\ttype: 'text'\n\t\t\t});\n\t\t}\n\n\t\tconst resolvedReferences = numbers\n\t\t\t.map((number) => referenceMap.get(number))\n\t\t\t.filter((reference): reference is RAGGroundingReference =>\n\t\t\t\tBoolean(reference)\n\t\t\t);\n\t\tfor (const number of numbers) {\n\t\t\tif (!referenceMap.has(number)) {\n\t\t\t\tungroundedReferenceNumbers.add(number);\n\t\t\t}\n\t\t}\n\t\tconst unresolvedNumbers = numbers.filter(\n\t\t\t(number) => !referenceMap.has(number)\n\t\t);\n\n\t\tparts.push({\n\t\t\treferenceNumbers: numbers,\n\t\t\treferenceDetails: resolvedReferences.map(\n\t\t\t\tbuildGroundedAnswerCitationDetail\n\t\t\t),\n\t\t\treferences: resolvedReferences,\n\t\t\ttext: raw,\n\t\t\ttype: 'citation',\n\t\t\tunresolvedReferenceNumbers: unresolvedNumbers\n\t\t});\n\t\tcursor = start + raw.length;\n\t}\n\n\tif (cursor < content.length || parts.length === 0) {\n\t\tparts.push({\n\t\t\ttext: content.slice(cursor),\n\t\t\ttype: 'text'\n\t\t});\n\t}\n\n\tconst hasCitations = parts.some((part) => part.type === 'citation');\n\tconst coverage: RAGGroundedAnswer['coverage'] = !hasCitations\n\t\t? 'ungrounded'\n\t\t: ungroundedReferenceNumbers.size === 0\n\t\t\t? 'grounded'\n\t\t\t: references.length > 0\n\t\t\t\t? 'partial'\n\t\t\t\t: 'ungrounded';\n\n\treturn {\n\t\tcontent,\n\t\tcoverage,\n\t\texcerptModeCounts: buildExcerptModeCounts([\n\t\t\t...references,\n\t\t\t...sectionSummaries\n\t\t]),\n\t\thasCitations,\n\t\tparts,\n\t\treferences,\n\t\tsectionSummaries,\n\t\tungroundedReferenceNumbers: [...ungroundedReferenceNumbers].sort(\n\t\t\t(left, right) => left - right\n\t\t)\n\t};\n};\n\nexport const buildRAGGroundedAnswerSectionSummaries = (\n\treferences: RAGGroundingReference[]\n): RAGGroundedAnswerSectionSummary[] => {\n\tconst groups = new Map<string, RAGGroundedAnswerSectionSummary>();\n\n\tfor (const reference of references) {\n\t\tconst key = buildGroundingSectionKey(reference);\n\t\tconst existing = groups.get(key);\n\t\tif (!existing) {\n\t\t\tconst excerpts = reference.excerpts\n\t\t\t\t? {\n\t\t\t\t\t\tchunkExcerpt: reference.excerpts.chunkExcerpt,\n\t\t\t\t\t\tsectionExcerpt: reference.excerpts.sectionExcerpt,\n\t\t\t\t\t\twindowExcerpt: reference.excerpts.windowExcerpt\n\t\t\t\t\t}\n\t\t\t\t: undefined;\n\t\t\tgroups.set(key, {\n\t\t\t\tchunkIds: [reference.chunkId],\n\t\t\t\tcontextLabel: reference.contextLabel,\n\t\t\t\tcount: 1,\n\t\t\t\texcerpt:\n\t\t\t\t\tselectPreferredExcerpt(\n\t\t\t\t\t\texcerpts,\n\t\t\t\t\t\tgetContextNumber(reference.metadata?.sectionChunkCount)\n\t\t\t\t\t).excerpt ||\n\t\t\t\t\texcerpts?.sectionExcerpt ||\n\t\t\t\t\treference.excerpt,\n\t\t\t\texcerpts,\n\t\t\t\texcerptSelection: reference.excerptSelection,\n\t\t\t\tkey,\n\t\t\t\tlabel: key,\n\t\t\t\tlocatorLabel: reference.locatorLabel,\n\t\t\t\tprovenanceLabel: reference.provenanceLabel,\n\t\t\t\treferenceNumbers: [reference.number],\n\t\t\t\treferences: [reference],\n\t\t\t\tsummary:\n\t\t\t\t\tbuildGroundingSectionSummaryLine(reference) ||\n\t\t\t\t\treference.label ||\n\t\t\t\t\treference.chunkId\n\t\t\t});\n\t\t\tcontinue;\n\t\t}\n\n\t\texisting.count += 1;\n\t\tif (!existing.chunkIds.includes(reference.chunkId)) {\n\t\t\texisting.chunkIds.push(reference.chunkId);\n\t\t}\n\t\tif (!existing.referenceNumbers.includes(reference.number)) {\n\t\t\texisting.referenceNumbers.push(reference.number);\n\t\t}\n\t\texisting.references.push(reference);\n\t\tif (!existing.contextLabel && reference.contextLabel) {\n\t\t\texisting.contextLabel = reference.contextLabel;\n\t\t}\n\t\tif (!existing.locatorLabel && reference.locatorLabel) {\n\t\t\texisting.locatorLabel = reference.locatorLabel;\n\t\t}\n\t\tif (!existing.provenanceLabel && reference.provenanceLabel) {\n\t\t\texisting.provenanceLabel = reference.provenanceLabel;\n\t\t}\n\t\tif (!existing.excerpts && reference.excerpts) {\n\t\t\texisting.excerpts = {\n\t\t\t\tchunkExcerpt: reference.excerpts.chunkExcerpt,\n\t\t\t\tsectionExcerpt: reference.excerpts.sectionExcerpt,\n\t\t\t\twindowExcerpt: reference.excerpts.windowExcerpt\n\t\t\t};\n\t\t\texisting.excerpt = reference.excerpts.sectionExcerpt;\n\t\t}\n\t\tif (!existing.excerptSelection && reference.excerptSelection) {\n\t\t\texisting.excerptSelection = reference.excerptSelection;\n\t\t}\n\t}\n\n\treturn [...groups.values()]\n\t\t.map((group) => ({\n\t\t\t...group,\n\t\t\treferenceNumbers: [...group.referenceNumbers].sort(\n\t\t\t\t(left, right) => left - right\n\t\t\t),\n\t\t\treferences: group.references\n\t\t\t\t.slice()\n\t\t\t\t.sort((left, right) => left.number - right.number)\n\t\t}))\n\t\t.sort((left, right) => {\n\t\t\tconst leftFirst =\n\t\t\t\tleft.referenceNumbers[0] ?? Number.POSITIVE_INFINITY;\n\t\t\tconst rightFirst =\n\t\t\t\tright.referenceNumbers[0] ?? Number.POSITIVE_INFINITY;\n\t\t\tif (leftFirst !== rightFirst) {\n\t\t\t\treturn leftFirst - rightFirst;\n\t\t\t}\n\t\t\treturn left.label.localeCompare(right.label);\n\t\t});\n};\n\nexport const buildRAGGroundingReferences = (sources: RAGSource[]) => {\n\tconst citations = buildRAGCitations(sources);\n\tconst citationReferenceMap = buildRAGCitationReferenceMap(citations);\n\n\treturn citations.map<RAGGroundingReference>((citation) => {\n\t\tconst excerpts = buildGroundingChunkExcerpts(sources, citation.chunkId);\n\t\tconst excerptSelection = selectPreferredExcerpt(\n\t\t\texcerpts,\n\t\t\tgetContextNumber(citation.metadata?.sectionChunkCount)\n\t\t);\n\t\treturn {\n\t\t\tchunkId: citation.chunkId,\n\t\t\tcontextLabel:\n\t\t\t\tcitation.contextLabel ?? buildContextLabel(citation.metadata),\n\t\t\texcerpt:\n\t\t\t\texcerptSelection.excerpt ||\n\t\t\t\texcerpts?.chunkExcerpt ||\n\t\t\t\tbuildExcerpt(citation.text),\n\t\t\texcerpts,\n\t\t\texcerptSelection,\n\t\t\tlabel: citation.label,\n\t\t\tlocatorLabel:\n\t\t\t\tcitation.locatorLabel ??\n\t\t\t\tbuildLocatorLabel(\n\t\t\t\t\tcitation.metadata,\n\t\t\t\t\tcitation.source,\n\t\t\t\t\tcitation.title\n\t\t\t\t),\n\t\t\tmetadata: citation.metadata,\n\t\t\tnumber: citationReferenceMap[citation.chunkId] ?? 0,\n\t\t\tprovenanceLabel:\n\t\t\t\tcitation.provenanceLabel ??\n\t\t\t\tbuildProvenanceLabel(citation.metadata),\n\t\t\tscore: citation.score,\n\t\t\tsource: citation.source,\n\t\t\ttext: citation.text,\n\t\t\ttitle: citation.title\n\t\t};\n\t});\n};\n",
8
- "import { mkdir, readFile, writeFile } from 'node:fs/promises';\nimport { dirname } from 'node:path';\nimport type { Database } from 'bun:sqlite';\nimport type {\n\tRAGAnswerGroundingCaseDifficultyDiffEntry,\n\tRAGAnswerGroundingCaseDifficultyHistory,\n\tRAGAnswerGroundingCaseDifficultyHistoryStore,\n\tRAGAnswerGroundingCaseDifficultyRun,\n\tRAGAnswerGroundingCaseDifficultyRunDiff,\n\tRAGAnswerGroundingEvaluationCaseDiff,\n\tRAGAnswerGroundingEvaluationCase,\n\tRAGAnswerGroundingEvaluationCaseDifficultyEntry,\n\tRAGAnswerGroundingEvaluationCaseSnapshot,\n\tRAGAnswerGroundingEvaluationCaseResult,\n\tRAGAnswerGroundingEvaluationHistory,\n\tRAGAnswerGroundingEvaluationLeaderboardEntry,\n\tRAGAnswerGroundingEvaluationHistoryStore,\n\tRAGAnswerGroundingEvaluationInput,\n\tRAGAnswerGroundingEvaluationResponse,\n\tRAGAnswerGroundingEvaluationRun,\n\tRAGAnswerGroundingEvaluationRunDiff,\n\tRAGCollection,\n\tRAGIndexedDocument,\n\tRAGEvaluationCase,\n\tRAGEvaluationCaseDiff,\n\tRAGEvaluationCaseTraceSnapshot,\n\tRAGEvaluationCaseResult,\n\tRAGEvaluationHistory,\n\tRAGEvaluationHistoryStore,\n\tRAGEvaluationHistoryPruneInput,\n\tRAGEvaluationHistoryPruneResult,\n\tRAGEvaluationInput,\n\tRAGEvaluationLeaderboardEntry,\n\tRAGEvaluationResponse,\n\tRAGEvaluationRunDiff,\n\tRAGLabelValueRow,\n\tRAGComparisonPresentation,\n\tRAGComparisonOverviewPresentation,\n\tRAGGroundingProviderPresentation,\n\tRAGGroundingProviderOverviewPresentation,\n\tRAGGroundingProviderCaseComparisonPresentation,\n\tRAGGroundingOverviewPresentation,\n\tRAGQualityOverviewPresentation,\n\tRAGDocumentChunk,\n\tRAGEvaluationSuite,\n\tRAGEvaluationSuiteGenerationOptions,\n\tRAGEvaluationSuiteDatasetSummary,\n\tRAGEvaluationSuiteSnapshot,\n\tRAGEvaluationSuiteSnapshotDiff,\n\tRAGEvaluationSuiteSnapshotHistory,\n\tRAGEvaluationSuiteSnapshotHistoryStore,\n\tRAGEvaluationSuiteRun,\n\tRAGEvaluationEntityQualitySummary,\n\tRAGEvaluationEntityQualityView,\n\tRAGAnswerGroundingEntityQualitySummary,\n\tRAGAnswerGroundingEntityQualityView,\n\tRAGRetrievalTraceSummaryRun,\n\tRAGHybridRetrievalMode,\n\tRAGSourceBalanceStrategy,\n\tRAGRetrievalCandidate,\n\tRAGRetrievalComparison,\n\tRAGRetrievalBaselineGatePolicy,\n\tRAGRetrievalBaselineGatePolicyHistoryRecord,\n\tRAGRetrievalBaselineGatePolicyHistoryStore,\n\tRAGRetrievalComparisonDecisionSummary,\n\tRAGRetrievalComparisonGateResult,\n\tRAGRetrievalReleaseVerdict,\n\tRAGRetrievalComparisonHistoryStore,\n\tRAGRetrievalBaselineRecord,\n\tRAGRetrievalBaselineStore,\n\tRAGRetrievalLaneHandoffDecisionRecord,\n\tRAGRetrievalLaneHandoffDecisionStore,\n\tRAGRetrievalLaneHandoffIncidentHistoryRecord,\n\tRAGRetrievalLaneHandoffIncidentHistoryStore,\n\tRAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord,\n\tRAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore,\n\tRAGRetrievalLaneHandoffIncidentRecord,\n\tRAGRetrievalLaneHandoffIncidentStore,\n\tRAGRetrievalIncidentRemediationDecisionRecord,\n\tRAGRetrievalIncidentRemediationDecisionStore,\n\tRAGRetrievalIncidentRemediationExecutionHistoryRecord,\n\tRAGRetrievalIncidentRemediationExecutionHistoryStore,\n\tRAGRetrievalReleaseDecisionRecord,\n\tRAGRetrievalReleaseLanePolicyHistoryRecord,\n\tRAGRetrievalReleaseLanePolicyHistoryStore,\n\tRAGRetrievalReleaseLaneEscalationPolicyHistoryRecord,\n\tRAGRetrievalReleaseLaneEscalationPolicyHistoryStore,\n\tRAGRetrievalReleaseDecisionStore,\n\tRAGRetrievalReleaseIncidentRecord,\n\tRAGRetrievalReleaseIncidentStore,\n\tRAGRetrievalComparisonRun,\n\tRAGRetrievalComparisonEntry,\n\tRAGRetrievalTrace,\n\tRAGRetrievalTraceComparisonSummary,\n\tRAGRetrievalTraceComparisonSummaryDiff,\n\tRAGRetrievalTraceStep,\n\tRAGRetrievalTraceStage,\n\tRAGQueryResult,\n\tRAGTraceSummaryListTrend,\n\tRAGTraceSummaryTrendDirection,\n\tRAGTraceSummaryNumericDelta,\n\tRAGTraceSummaryStageTrend,\n\tRAGTraceSummaryStageCountsDelta,\n\tRAGRetrievalComparisonSummary,\n\tRAGRetrievalTraceHistoryWindow,\n\tRAGRerankerCandidate,\n\tRAGRerankerComparison,\n\tRAGRerankerComparisonEntry,\n\tRAGRerankerComparisonSummary,\n\tRAGRerankerProviderLike,\n\tRAGRetrievalTraceTrend,\n\tRAGSearchTraceDiff,\n\tRAGSearchTraceGroupHistory,\n\tRAGSearchTraceGroupHistoryEntry,\n\tRAGSearchTraceHistory,\n\tRAGChatPluginConfig,\n\tRAGSearchTracePruneInput,\n\tRAGSearchTracePruneHistoryStore,\n\tRAGSearchTracePruneRun,\n\tRAGSearchTracePrunePreview,\n\tRAGSearchTracePruneResult,\n\tRAGSearchTraceRecord,\n\tRAGSearchTraceResultSnapshot,\n\tRAGSearchTraceStats,\n\tRAGSearchTraceStore,\n\tRAGRemediationAction,\n\tRAGSource,\n\tRAGCollectionSearchParams,\n\tRAGSQLiteStoreMigrationInspection,\n\tRAGSQLiteStoreMigrationIssue,\n\tRAGSQLiteStoreMigrationResult\n} from '@absolutejs/ai';\nimport { generateId } from '@absolutejs/ai';\nimport { buildRAGGroundedAnswer } from './grounding';\nimport { buildRAGSourceLabels } from './presentation';\n\nconst DEFAULT_TOP_K = 6;\nconst DEFAULT_HISTORY_LIMIT = 20;\nconst DEFAULT_SEARCH_TRACE_TABLE_NAME = 'rag_search_traces';\n\nconst getTraceLabelString = (value: unknown) =>\n\ttypeof value === 'string' && value.trim().length > 0\n\t\t? value.trim()\n\t\t: undefined;\n\nconst getTraceLabelNumber = (value: unknown) =>\n\ttypeof value === 'number' && Number.isFinite(value) ? value : undefined;\n\nconst formatTraceSpreadsheetTableLabel = (\n\ttableIndex?: number,\n\ttableCount?: number\n) => {\n\tif (\n\t\ttypeof tableIndex !== 'number' ||\n\t\t!Number.isFinite(tableIndex) ||\n\t\ttableIndex < 1\n\t) {\n\t\treturn undefined;\n\t}\n\n\tif (\n\t\ttypeof tableCount === 'number' &&\n\t\tNumber.isFinite(tableCount) &&\n\t\ttableCount >= tableIndex\n\t) {\n\t\treturn `Table ${tableIndex} of ${tableCount}`;\n\t}\n\n\treturn `Table ${tableIndex}`;\n};\n\nconst formatTraceSourceAwareChunkReason = (value: unknown) => {\n\tconst reason = getTraceLabelString(value);\n\tif (reason === 'section_boundary') {\n\t\treturn 'Chunk boundary section';\n\t}\n\tif (reason === 'size_limit') {\n\t\treturn 'Chunk boundary size limit';\n\t}\n\tif (reason === 'source_native_unit') {\n\t\treturn 'Chunk boundary source-native unit';\n\t}\n\treturn undefined;\n};\n\nconst buildTraceSourceAwareUnitScopeLabel = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst sectionKind = getTraceLabelString(metadata.sectionKind);\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getTraceLabelString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetTraceLabelString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tconst pdfTextKind = getTraceLabelString(metadata.pdfTextKind);\n\tconst officeBlockKind = getTraceLabelString(metadata.officeBlockKind);\n\tconst sheetName = getTraceLabelString(metadata.sheetName);\n\tconst spreadsheetTableLabel = formatTraceSpreadsheetTableLabel(\n\t\tgetTraceLabelNumber(metadata.spreadsheetTableIndex),\n\t\tgetTraceLabelNumber(metadata.spreadsheetTableCount)\n\t);\n\tconst slideTitle = getTraceLabelString(metadata.slideTitle);\n\tconst slideNumber =\n\t\tgetTraceLabelNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\n\tif (\n\t\tsectionPath.length > 0 &&\n\t\t(sectionKind === 'markdown_heading' ||\n\t\t\tsectionKind === 'html_heading' ||\n\t\t\tsectionKind === 'office_heading' ||\n\t\t\tsectionKind === undefined)\n\t) {\n\t\treturn `Source-aware section ${sectionPath.join(' > ')}`;\n\t}\n\n\tif (sectionKind === 'pdf_block') {\n\t\tif (pdfTextKind === 'table_like' && sectionTitle) {\n\t\t\treturn `Source-aware PDF table block ${sectionTitle}`;\n\t\t}\n\t\tif (sectionTitle) {\n\t\t\treturn `Source-aware PDF block ${sectionTitle}`;\n\t\t}\n\t\treturn 'Source-aware PDF block';\n\t}\n\n\tif (sectionKind === 'office_block') {\n\t\tif (officeBlockKind && sectionTitle) {\n\t\t\treturn `Source-aware office ${officeBlockKind} block ${sectionTitle}`;\n\t\t}\n\t\tif (sectionTitle) {\n\t\t\treturn `Source-aware office block ${sectionTitle}`;\n\t\t}\n\t\treturn 'Source-aware office block';\n\t}\n\n\tif (\n\t\tsectionKind === 'spreadsheet_rows' ||\n\t\t(sectionKind === undefined &&\n\t\t\t(sheetName ||\n\t\t\t\tspreadsheetTableLabel ||\n\t\t\t\tgetTraceLabelNumber(metadata.spreadsheetRowStart) !==\n\t\t\t\t\tundefined ||\n\t\t\t\tgetTraceLabelNumber(metadata.spreadsheetRowEnd) !== undefined))\n\t) {\n\t\tif (sheetName && spreadsheetTableLabel) {\n\t\t\treturn `Source-aware spreadsheet ${sheetName} ${spreadsheetTableLabel}`;\n\t\t}\n\t\tif (sheetName) {\n\t\t\treturn `Source-aware spreadsheet ${sheetName}`;\n\t\t}\n\t\treturn 'Source-aware spreadsheet';\n\t}\n\n\tif (sectionKind === 'presentation_slide') {\n\t\tif (slideNumber && slideTitle) {\n\t\t\treturn `Source-aware slide ${slideNumber} ${slideTitle}`;\n\t\t}\n\t\tif (slideTitle) {\n\t\t\treturn `Source-aware slide ${slideTitle}`;\n\t\t}\n\t\tif (slideNumber) {\n\t\t\treturn `Source-aware slide ${slideNumber}`;\n\t\t}\n\t\treturn 'Source-aware slide';\n\t}\n\n\treturn undefined;\n};\n\nconst buildEvaluationLeadSnapshot = (input?: {\n\tmetadata?: Record<string, unknown>;\n\tsource?: string;\n\ttitle?: string;\n}): Pick<\n\tRAGEvaluationCaseTraceSnapshot,\n\t| 'topContextLabel'\n\t| 'topLocatorLabel'\n\t| 'sourceAwareChunkReasonLabel'\n\t| 'sourceAwareUnitScopeLabel'\n> => {\n\tconst labels = buildRAGSourceLabels({\n\t\tmetadata: input?.metadata,\n\t\tsource: input?.source,\n\t\ttitle: input?.title\n\t});\n\n\treturn {\n\t\tsourceAwareChunkReasonLabel: formatTraceSourceAwareChunkReason(\n\t\t\tinput?.metadata?.sourceAwareChunkReason\n\t\t),\n\t\tsourceAwareUnitScopeLabel: buildTraceSourceAwareUnitScopeLabel(\n\t\t\tinput?.metadata\n\t\t),\n\t\ttopContextLabel: labels?.contextLabel,\n\t\ttopLocatorLabel: labels?.locatorLabel\n\t};\n};\n\nconst buildEvaluationLeadMediaCueSnapshot = (\n\ttrace?: RAGRetrievalTrace\n): Pick<\n\tRAGEvaluationCaseTraceSnapshot,\n\t| 'leadSpeakerCue'\n\t| 'leadSpeakerAttributionCue'\n\t| 'leadChannelCue'\n\t| 'leadChannelAttributionCue'\n\t| 'leadContinuityCue'\n> => {\n\tconst rerankStep = trace?.steps.find((step) => step.stage === 'rerank');\n\tconst metadata = rerankStep?.metadata ?? {};\n\n\treturn {\n\t\tleadChannelAttributionCue:\n\t\t\ttypeof metadata.leadChannelAttributionCue === 'string'\n\t\t\t\t? metadata.leadChannelAttributionCue\n\t\t\t\t: undefined,\n\t\tleadChannelCue:\n\t\t\ttypeof metadata.leadChannelCue === 'string'\n\t\t\t\t? metadata.leadChannelCue\n\t\t\t\t: undefined,\n\t\tleadContinuityCue:\n\t\t\ttypeof metadata.leadContinuityCue === 'string'\n\t\t\t\t? metadata.leadContinuityCue\n\t\t\t\t: undefined,\n\t\tleadSpeakerAttributionCue:\n\t\t\ttypeof metadata.leadSpeakerAttributionCue === 'string'\n\t\t\t\t? metadata.leadSpeakerAttributionCue\n\t\t\t\t: undefined,\n\t\tleadSpeakerCue:\n\t\t\ttypeof metadata.leadSpeakerCue === 'string'\n\t\t\t\t? metadata.leadSpeakerCue\n\t\t\t\t: undefined\n\t};\n};\n\nconst buildEvaluationLeadPresentationCueSnapshot = (\n\ttrace?: RAGRetrievalTrace\n): Pick<RAGEvaluationCaseTraceSnapshot, 'leadPresentationCue'> => {\n\tconst rerankStep = trace?.steps.find((step) => step.stage === 'rerank');\n\tconst metadata = rerankStep?.metadata ?? {};\n\tconst cue = metadata.leadPresentationCue;\n\n\treturn {\n\t\tleadPresentationCue:\n\t\t\tcue === 'title' || cue === 'body' || cue === 'notes'\n\t\t\t\t? cue\n\t\t\t\t: undefined\n\t};\n};\n\nconst buildEvaluationLeadSpreadsheetCueSnapshot = (\n\ttrace?: RAGRetrievalTrace\n): Pick<RAGEvaluationCaseTraceSnapshot, 'leadSpreadsheetCue'> => {\n\tconst rerankStep = trace?.steps.find((step) => step.stage === 'rerank');\n\tconst metadata = rerankStep?.metadata ?? {};\n\tconst cue = metadata.leadSpreadsheetCue;\n\n\treturn {\n\t\tleadSpreadsheetCue:\n\t\t\tcue === 'sheet' || cue === 'table' || cue === 'column'\n\t\t\t\t? cue\n\t\t\t\t: undefined\n\t};\n};\n\nconst buildEvaluationSQLiteQueryPlanSnapshot = (\n\ttrace?: RAGRetrievalTrace\n): Pick<\n\tRAGEvaluationCaseTraceSnapshot,\n\t| 'sqliteQueryMode'\n\t| 'sqliteQueryPushdownMode'\n\t| 'sqliteQueryPushdownApplied'\n\t| 'sqliteQueryPushdownClauseCount'\n\t| 'sqliteQueryTotalFilterClauseCount'\n\t| 'sqliteQueryJsRemainderClauseCount'\n\t| 'sqliteQueryMultiplierUsed'\n\t| 'sqliteQueryCandidateLimitUsed'\n\t| 'sqliteQueryMaxBackfillsUsed'\n\t| 'sqliteQueryMinResultsUsed'\n\t| 'sqliteQueryFillPolicyUsed'\n\t| 'sqliteQueryPushdownCoverageRatio'\n\t| 'sqliteQueryJsRemainderRatio'\n\t| 'sqliteQueryFilteredCandidates'\n\t| 'sqliteQueryInitialSearchK'\n\t| 'sqliteQueryFinalSearchK'\n\t| 'sqliteQuerySearchExpansionRatio'\n\t| 'sqliteQueryBackfillCount'\n\t| 'sqliteQueryBackfillLimitReached'\n\t| 'sqliteQueryMinResultsSatisfied'\n\t| 'sqliteQueryReturnedCount'\n\t| 'sqliteQueryCandidateYieldRatio'\n\t| 'sqliteQueryTopKFillRatio'\n\t| 'sqliteQueryUnderfilledTopK'\n\t| 'sqliteQueryCandidateBudgetExhausted'\n\t| 'sqliteQueryCandidateCoverage'\n> => {\n\tconst vectorStep = trace?.steps.find(\n\t\t(step) => step.stage === 'vector_search'\n\t);\n\tconst metadata = vectorStep?.metadata ?? {};\n\n\treturn {\n\t\tsqliteQueryBackfillCount:\n\t\t\ttypeof metadata.sqliteQueryBackfillCount === 'number'\n\t\t\t\t? metadata.sqliteQueryBackfillCount\n\t\t\t\t: undefined,\n\t\tsqliteQueryCandidateBudgetExhausted:\n\t\t\ttypeof metadata.sqliteQueryCandidateBudgetExhausted === 'boolean'\n\t\t\t\t? metadata.sqliteQueryCandidateBudgetExhausted\n\t\t\t\t: undefined,\n\t\tsqliteQueryCandidateCoverage:\n\t\t\tmetadata.sqliteQueryCandidateCoverage === 'empty' ||\n\t\t\tmetadata.sqliteQueryCandidateCoverage === 'under_target' ||\n\t\t\tmetadata.sqliteQueryCandidateCoverage === 'target_sized' ||\n\t\t\tmetadata.sqliteQueryCandidateCoverage === 'broad'\n\t\t\t\t? metadata.sqliteQueryCandidateCoverage\n\t\t\t\t: undefined,\n\t\tsqliteQueryFilteredCandidates:\n\t\t\ttypeof metadata.sqliteQueryFilteredCandidates === 'number'\n\t\t\t\t? metadata.sqliteQueryFilteredCandidates\n\t\t\t\t: undefined,\n\t\tsqliteQueryFinalSearchK:\n\t\t\ttypeof metadata.sqliteQueryFinalSearchK === 'number'\n\t\t\t\t? metadata.sqliteQueryFinalSearchK\n\t\t\t\t: undefined,\n\t\tsqliteQueryInitialSearchK:\n\t\t\ttypeof metadata.sqliteQueryInitialSearchK === 'number'\n\t\t\t\t? metadata.sqliteQueryInitialSearchK\n\t\t\t\t: undefined,\n\t\tsqliteQuerySearchExpansionRatio:\n\t\t\ttypeof metadata.sqliteQuerySearchExpansionRatio === 'number'\n\t\t\t\t? metadata.sqliteQuerySearchExpansionRatio\n\t\t\t\t: undefined,\n\t\tsqliteQueryMode:\n\t\t\tmetadata.sqliteQueryMode === 'json_fallback' ||\n\t\t\tmetadata.sqliteQueryMode === 'native_vec0'\n\t\t\t\t? metadata.sqliteQueryMode\n\t\t\t\t: undefined,\n\t\tsqliteQueryPushdownMode:\n\t\t\tmetadata.sqliteQueryPushdownMode === 'none' ||\n\t\t\tmetadata.sqliteQueryPushdownMode === 'partial' ||\n\t\t\tmetadata.sqliteQueryPushdownMode === 'full'\n\t\t\t\t? metadata.sqliteQueryPushdownMode\n\t\t\t\t: undefined,\n\t\tsqliteQueryPushdownApplied:\n\t\t\ttypeof metadata.sqliteQueryPushdownApplied === 'boolean'\n\t\t\t\t? metadata.sqliteQueryPushdownApplied\n\t\t\t\t: undefined,\n\t\tsqliteQueryPushdownClauseCount:\n\t\t\ttypeof metadata.sqliteQueryPushdownClauseCount === 'number'\n\t\t\t\t? metadata.sqliteQueryPushdownClauseCount\n\t\t\t\t: undefined,\n\t\tsqliteQueryTotalFilterClauseCount:\n\t\t\ttypeof metadata.sqliteQueryTotalFilterClauseCount === 'number'\n\t\t\t\t? metadata.sqliteQueryTotalFilterClauseCount\n\t\t\t\t: undefined,\n\t\tsqliteQueryJsRemainderClauseCount:\n\t\t\ttypeof metadata.sqliteQueryJsRemainderClauseCount === 'number'\n\t\t\t\t? metadata.sqliteQueryJsRemainderClauseCount\n\t\t\t\t: undefined,\n\t\tsqliteQueryMultiplierUsed:\n\t\t\ttypeof metadata.sqliteQueryMultiplierUsed === 'number'\n\t\t\t\t? metadata.sqliteQueryMultiplierUsed\n\t\t\t\t: undefined,\n\t\tsqliteQueryCandidateLimitUsed:\n\t\t\ttypeof metadata.sqliteQueryCandidateLimitUsed === 'number'\n\t\t\t\t? metadata.sqliteQueryCandidateLimitUsed\n\t\t\t\t: undefined,\n\t\tsqliteQueryMaxBackfillsUsed:\n\t\t\ttypeof metadata.sqliteQueryMaxBackfillsUsed === 'number'\n\t\t\t\t? metadata.sqliteQueryMaxBackfillsUsed\n\t\t\t\t: undefined,\n\t\tsqliteQueryMinResultsUsed:\n\t\t\ttypeof metadata.sqliteQueryMinResultsUsed === 'number'\n\t\t\t\t? metadata.sqliteQueryMinResultsUsed\n\t\t\t\t: undefined,\n\t\tsqliteQueryFillPolicyUsed:\n\t\t\tmetadata.sqliteQueryFillPolicyUsed === 'strict_topk' ||\n\t\t\tmetadata.sqliteQueryFillPolicyUsed === 'satisfy_min_results'\n\t\t\t\t? metadata.sqliteQueryFillPolicyUsed\n\t\t\t\t: undefined,\n\t\tsqliteQueryPushdownCoverageRatio:\n\t\t\ttypeof metadata.sqliteQueryPushdownCoverageRatio === 'number'\n\t\t\t\t? metadata.sqliteQueryPushdownCoverageRatio\n\t\t\t\t: undefined,\n\t\tsqliteQueryJsRemainderRatio:\n\t\t\ttypeof metadata.sqliteQueryJsRemainderRatio === 'number'\n\t\t\t\t? metadata.sqliteQueryJsRemainderRatio\n\t\t\t\t: undefined,\n\t\tsqliteQueryReturnedCount:\n\t\t\ttypeof metadata.sqliteQueryReturnedCount === 'number'\n\t\t\t\t? metadata.sqliteQueryReturnedCount\n\t\t\t\t: undefined,\n\t\tsqliteQueryCandidateYieldRatio:\n\t\t\ttypeof metadata.sqliteQueryCandidateYieldRatio === 'number'\n\t\t\t\t? metadata.sqliteQueryCandidateYieldRatio\n\t\t\t\t: undefined,\n\t\tsqliteQueryBackfillLimitReached:\n\t\t\ttypeof metadata.sqliteQueryBackfillLimitReached === 'boolean'\n\t\t\t\t? metadata.sqliteQueryBackfillLimitReached\n\t\t\t\t: undefined,\n\t\tsqliteQueryMinResultsSatisfied:\n\t\t\ttypeof metadata.sqliteQueryMinResultsSatisfied === 'boolean'\n\t\t\t\t? metadata.sqliteQueryMinResultsSatisfied\n\t\t\t\t: undefined,\n\t\tsqliteQueryTopKFillRatio:\n\t\t\ttypeof metadata.sqliteQueryTopKFillRatio === 'number'\n\t\t\t\t? metadata.sqliteQueryTopKFillRatio\n\t\t\t\t: undefined,\n\t\tsqliteQueryUnderfilledTopK:\n\t\t\ttypeof metadata.sqliteQueryUnderfilledTopK === 'boolean'\n\t\t\t\t? metadata.sqliteQueryUnderfilledTopK\n\t\t\t\t: undefined\n\t};\n};\n\nconst buildEvaluationPostgresQueryPlanSnapshot = (\n\ttrace?: RAGRetrievalTrace\n): Pick<\n\tRAGEvaluationCaseTraceSnapshot,\n\t| 'postgresQueryMode'\n\t| 'postgresQueryPushdownMode'\n\t| 'postgresQueryPushdownApplied'\n\t| 'postgresQueryPushdownClauseCount'\n\t| 'postgresQueryTotalFilterClauseCount'\n\t| 'postgresQueryJsRemainderClauseCount'\n\t| 'postgresQueryMultiplierUsed'\n\t| 'postgresQueryCandidateLimitUsed'\n\t| 'postgresQueryMaxBackfillsUsed'\n\t| 'postgresQueryMinResultsUsed'\n\t| 'postgresQueryFillPolicyUsed'\n\t| 'postgresQueryPushdownCoverageRatio'\n\t| 'postgresQueryJsRemainderRatio'\n\t| 'postgresQueryFilteredCandidates'\n\t| 'postgresQueryInitialSearchK'\n\t| 'postgresQueryFinalSearchK'\n\t| 'postgresQuerySearchExpansionRatio'\n\t| 'postgresQueryBackfillCount'\n\t| 'postgresQueryBackfillLimitReached'\n\t| 'postgresQueryMinResultsSatisfied'\n\t| 'postgresQueryReturnedCount'\n\t| 'postgresQueryCandidateYieldRatio'\n\t| 'postgresQueryTopKFillRatio'\n\t| 'postgresQueryUnderfilledTopK'\n\t| 'postgresQueryCandidateBudgetExhausted'\n\t| 'postgresQueryCandidateCoverage'\n> => {\n\tconst vectorStep = trace?.steps.find(\n\t\t(step) => step.stage === 'vector_search'\n\t);\n\tconst metadata = vectorStep?.metadata ?? {};\n\n\treturn {\n\t\tpostgresQueryBackfillCount:\n\t\t\ttypeof metadata.postgresQueryBackfillCount === 'number'\n\t\t\t\t? metadata.postgresQueryBackfillCount\n\t\t\t\t: undefined,\n\t\tpostgresQueryCandidateBudgetExhausted:\n\t\t\ttypeof metadata.postgresQueryCandidateBudgetExhausted === 'boolean'\n\t\t\t\t? metadata.postgresQueryCandidateBudgetExhausted\n\t\t\t\t: undefined,\n\t\tpostgresQueryCandidateCoverage:\n\t\t\tmetadata.postgresQueryCandidateCoverage === 'empty' ||\n\t\t\tmetadata.postgresQueryCandidateCoverage === 'under_target' ||\n\t\t\tmetadata.postgresQueryCandidateCoverage === 'target_sized' ||\n\t\t\tmetadata.postgresQueryCandidateCoverage === 'broad'\n\t\t\t\t? metadata.postgresQueryCandidateCoverage\n\t\t\t\t: undefined,\n\t\tpostgresQueryFilteredCandidates:\n\t\t\ttypeof metadata.postgresQueryFilteredCandidates === 'number'\n\t\t\t\t? metadata.postgresQueryFilteredCandidates\n\t\t\t\t: undefined,\n\t\tpostgresQueryFinalSearchK:\n\t\t\ttypeof metadata.postgresQueryFinalSearchK === 'number'\n\t\t\t\t? metadata.postgresQueryFinalSearchK\n\t\t\t\t: undefined,\n\t\tpostgresQueryInitialSearchK:\n\t\t\ttypeof metadata.postgresQueryInitialSearchK === 'number'\n\t\t\t\t? metadata.postgresQueryInitialSearchK\n\t\t\t\t: undefined,\n\t\tpostgresQuerySearchExpansionRatio:\n\t\t\ttypeof metadata.postgresQuerySearchExpansionRatio === 'number'\n\t\t\t\t? metadata.postgresQuerySearchExpansionRatio\n\t\t\t\t: undefined,\n\t\tpostgresQueryMode:\n\t\t\tmetadata.postgresQueryMode === 'native_pgvector'\n\t\t\t\t? metadata.postgresQueryMode\n\t\t\t\t: undefined,\n\t\tpostgresQueryPushdownMode:\n\t\t\tmetadata.postgresQueryPushdownMode === 'none' ||\n\t\t\tmetadata.postgresQueryPushdownMode === 'partial' ||\n\t\t\tmetadata.postgresQueryPushdownMode === 'full'\n\t\t\t\t? metadata.postgresQueryPushdownMode\n\t\t\t\t: undefined,\n\t\tpostgresQueryPushdownApplied:\n\t\t\ttypeof metadata.postgresQueryPushdownApplied === 'boolean'\n\t\t\t\t? metadata.postgresQueryPushdownApplied\n\t\t\t\t: undefined,\n\t\tpostgresQueryPushdownClauseCount:\n\t\t\ttypeof metadata.postgresQueryPushdownClauseCount === 'number'\n\t\t\t\t? metadata.postgresQueryPushdownClauseCount\n\t\t\t\t: undefined,\n\t\tpostgresQueryTotalFilterClauseCount:\n\t\t\ttypeof metadata.postgresQueryTotalFilterClauseCount === 'number'\n\t\t\t\t? metadata.postgresQueryTotalFilterClauseCount\n\t\t\t\t: undefined,\n\t\tpostgresQueryJsRemainderClauseCount:\n\t\t\ttypeof metadata.postgresQueryJsRemainderClauseCount === 'number'\n\t\t\t\t? metadata.postgresQueryJsRemainderClauseCount\n\t\t\t\t: undefined,\n\t\tpostgresQueryMultiplierUsed:\n\t\t\ttypeof metadata.postgresQueryMultiplierUsed === 'number'\n\t\t\t\t? metadata.postgresQueryMultiplierUsed\n\t\t\t\t: undefined,\n\t\tpostgresQueryCandidateLimitUsed:\n\t\t\ttypeof metadata.postgresQueryCandidateLimitUsed === 'number'\n\t\t\t\t? metadata.postgresQueryCandidateLimitUsed\n\t\t\t\t: undefined,\n\t\tpostgresQueryMaxBackfillsUsed:\n\t\t\ttypeof metadata.postgresQueryMaxBackfillsUsed === 'number'\n\t\t\t\t? metadata.postgresQueryMaxBackfillsUsed\n\t\t\t\t: undefined,\n\t\tpostgresQueryMinResultsUsed:\n\t\t\ttypeof metadata.postgresQueryMinResultsUsed === 'number'\n\t\t\t\t? metadata.postgresQueryMinResultsUsed\n\t\t\t\t: undefined,\n\t\tpostgresQueryFillPolicyUsed:\n\t\t\tmetadata.postgresQueryFillPolicyUsed === 'strict_topk' ||\n\t\t\tmetadata.postgresQueryFillPolicyUsed === 'satisfy_min_results'\n\t\t\t\t? metadata.postgresQueryFillPolicyUsed\n\t\t\t\t: undefined,\n\t\tpostgresQueryPushdownCoverageRatio:\n\t\t\ttypeof metadata.postgresQueryPushdownCoverageRatio === 'number'\n\t\t\t\t? metadata.postgresQueryPushdownCoverageRatio\n\t\t\t\t: undefined,\n\t\tpostgresQueryJsRemainderRatio:\n\t\t\ttypeof metadata.postgresQueryJsRemainderRatio === 'number'\n\t\t\t\t? metadata.postgresQueryJsRemainderRatio\n\t\t\t\t: undefined,\n\t\tpostgresQueryReturnedCount:\n\t\t\ttypeof metadata.postgresQueryReturnedCount === 'number'\n\t\t\t\t? metadata.postgresQueryReturnedCount\n\t\t\t\t: undefined,\n\t\tpostgresQueryCandidateYieldRatio:\n\t\t\ttypeof metadata.postgresQueryCandidateYieldRatio === 'number'\n\t\t\t\t? metadata.postgresQueryCandidateYieldRatio\n\t\t\t\t: undefined,\n\t\tpostgresQueryBackfillLimitReached:\n\t\t\ttypeof metadata.postgresQueryBackfillLimitReached === 'boolean'\n\t\t\t\t? metadata.postgresQueryBackfillLimitReached\n\t\t\t\t: undefined,\n\t\tpostgresQueryMinResultsSatisfied:\n\t\t\ttypeof metadata.postgresQueryMinResultsSatisfied === 'boolean'\n\t\t\t\t? metadata.postgresQueryMinResultsSatisfied\n\t\t\t\t: undefined,\n\t\tpostgresQueryTopKFillRatio:\n\t\t\ttypeof metadata.postgresQueryTopKFillRatio === 'number'\n\t\t\t\t? metadata.postgresQueryTopKFillRatio\n\t\t\t\t: undefined,\n\t\tpostgresQueryUnderfilledTopK:\n\t\t\ttypeof metadata.postgresQueryUnderfilledTopK === 'boolean'\n\t\t\t\t? metadata.postgresQueryUnderfilledTopK\n\t\t\t\t: undefined\n\t};\n};\nconst DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME =\n\t'rag_retrieval_comparison_history';\nconst DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME =\n\t'rag_retrieval_release_decisions';\nconst DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME = 'rag_retrieval_baselines';\nconst DEFAULT_RETRIEVAL_RELEASE_INCIDENT_TABLE_NAME =\n\t'rag_retrieval_release_incidents';\ntype BunSQLiteModule = {\n\tDatabase: new (path?: string) => Database;\n};\n\ntype ImportMetaWithRequire = ImportMeta & {\n\trequire?: (specifier: string) => unknown;\n};\n\nconst loadBunSQLiteModule = (): BunSQLiteModule => {\n\tconst runtimeRequire = (import.meta as ImportMetaWithRequire).require;\n\tif (typeof runtimeRequire !== 'function') {\n\t\tthrow new Error(\n\t\t\t'SQLite trace storage requires Bun runtime support for import.meta.require.'\n\t\t);\n\t}\n\n\treturn runtimeRequire('bun:sqlite') as BunSQLiteModule;\n};\n\nconst normalizeStringArray = (value: unknown) => {\n\tif (!Array.isArray(value)) {\n\t\treturn [];\n\t}\n\n\treturn value\n\t\t.filter((candidate) => typeof candidate === 'string')\n\t\t.map((candidate) => candidate.trim())\n\t\t.filter((candidate) => candidate.length > 0);\n};\n\nconst normalizeLabelFilter = (value?: string) => {\n\tif (typeof value !== 'string') {\n\t\treturn undefined;\n\t}\n\n\tconst normalized = value.trim().toLowerCase();\n\treturn normalized.length > 0 ? normalized : undefined;\n};\n\nconst normalizeRetrievalBaselineRecords = (\n\trecords: RAGRetrievalBaselineRecord[]\n) => [...records].sort((left, right) => right.promotedAt - left.promotedAt);\n\nconst normalizeRetrievalReleaseDecisionRecords = (\n\trecords: RAGRetrievalReleaseDecisionRecord[]\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalLaneHandoffDecisionRecords = (\n\trecords: RAGRetrievalLaneHandoffDecisionRecord[]\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalReleaseIncidentRecords = (\n\trecords: RAGRetrievalReleaseIncidentRecord[]\n) => [...records].sort((left, right) => right.triggeredAt - left.triggeredAt);\n\nconst normalizeRetrievalIncidentRemediationDecisionRecords = (\n\trecords: RAGRetrievalIncidentRemediationDecisionRecord[]\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalIncidentRemediationExecutionHistoryRecords = (\n\trecords: RAGRetrievalIncidentRemediationExecutionHistoryRecord[]\n) => [...records].sort((left, right) => right.executedAt - left.executedAt);\n\nconst matchesWinner = (run: RAGRetrievalComparisonRun, winnerId?: string) => {\n\tif (!winnerId) {\n\t\treturn true;\n\t}\n\n\treturn (\n\t\trun.comparison.summary.bestByPassingRate === winnerId ||\n\t\trun.decisionSummary?.winnerByPassingRate === winnerId\n\t);\n};\n\nconst findRetrievalComparisonEntry = (\n\tcomparison: RAGRetrievalComparison,\n\tretrievalId?: string\n) => {\n\tif (!retrievalId) {\n\t\treturn undefined;\n\t}\n\n\treturn comparison.entries.find(\n\t\t(entry) => entry.retrievalId === retrievalId\n\t);\n};\n\nconst evaluateRetrievalComparisonGate = ({\n\tdelta,\n\tpolicy\n}: {\n\tdelta?: {\n\t\tpassingRateDelta: number;\n\t\taverageF1Delta: number;\n\t\telapsedMsDelta: number;\n\t\tpresentationTitleCueCasesDelta?: number;\n\t\tpresentationBodyCueCasesDelta?: number;\n\t\tpresentationNotesCueCasesDelta?: number;\n\t\tspreadsheetSheetCueCasesDelta?: number;\n\t\tspreadsheetTableCueCasesDelta?: number;\n\t\tspreadsheetColumnCueCasesDelta?: number;\n\t\tmultiVectorCollapsedCasesDelta?: number;\n\t\tmultiVectorLexicalHitCasesDelta?: number;\n\t\tmultiVectorVectorHitCasesDelta?: number;\n\t\tevidenceReconcileCasesDelta?: number;\n\t\truntimeCandidateBudgetExhaustedCasesDelta?: number;\n\t\truntimeUnderfilledTopKCasesDelta?: number;\n\t};\n\tpolicy?: RAGRetrievalBaselineGatePolicy;\n}): RAGRetrievalComparisonGateResult | undefined => {\n\tif (!delta || !policy) {\n\t\treturn undefined;\n\t}\n\n\tconst reasons: string[] = [];\n\tif (\n\t\ttypeof policy.minPassingRateDelta === 'number' &&\n\t\tdelta.passingRateDelta < policy.minPassingRateDelta\n\t) {\n\t\treasons.push(\n\t\t\t`passing rate delta ${delta.passingRateDelta} is below ${policy.minPassingRateDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minAverageF1Delta === 'number' &&\n\t\tdelta.averageF1Delta < policy.minAverageF1Delta\n\t) {\n\t\treasons.push(\n\t\t\t`average F1 delta ${delta.averageF1Delta} is below ${policy.minAverageF1Delta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.maxElapsedMsDelta === 'number' &&\n\t\tdelta.elapsedMsDelta > policy.maxElapsedMsDelta\n\t) {\n\t\treasons.push(\n\t\t\t`elapsed ms delta ${delta.elapsedMsDelta} exceeds ${policy.maxElapsedMsDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minPresentationTitleCueCasesDelta === 'number' &&\n\t\t(delta.presentationTitleCueCasesDelta ?? 0) <\n\t\t\tpolicy.minPresentationTitleCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`presentation title cue delta ${delta.presentationTitleCueCasesDelta ?? 0} is below ${policy.minPresentationTitleCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minPresentationBodyCueCasesDelta === 'number' &&\n\t\t(delta.presentationBodyCueCasesDelta ?? 0) <\n\t\t\tpolicy.minPresentationBodyCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`presentation body cue delta ${delta.presentationBodyCueCasesDelta ?? 0} is below ${policy.minPresentationBodyCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minPresentationNotesCueCasesDelta === 'number' &&\n\t\t(delta.presentationNotesCueCasesDelta ?? 0) <\n\t\t\tpolicy.minPresentationNotesCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`presentation notes cue delta ${delta.presentationNotesCueCasesDelta ?? 0} is below ${policy.minPresentationNotesCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minSpreadsheetSheetCueCasesDelta === 'number' &&\n\t\t(delta.spreadsheetSheetCueCasesDelta ?? 0) <\n\t\t\tpolicy.minSpreadsheetSheetCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`spreadsheet sheet cue delta ${delta.spreadsheetSheetCueCasesDelta ?? 0} is below ${policy.minSpreadsheetSheetCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minSpreadsheetTableCueCasesDelta === 'number' &&\n\t\t(delta.spreadsheetTableCueCasesDelta ?? 0) <\n\t\t\tpolicy.minSpreadsheetTableCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`spreadsheet table cue delta ${delta.spreadsheetTableCueCasesDelta ?? 0} is below ${policy.minSpreadsheetTableCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minSpreadsheetColumnCueCasesDelta === 'number' &&\n\t\t(delta.spreadsheetColumnCueCasesDelta ?? 0) <\n\t\t\tpolicy.minSpreadsheetColumnCueCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`spreadsheet column cue delta ${delta.spreadsheetColumnCueCasesDelta ?? 0} is below ${policy.minSpreadsheetColumnCueCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minMultiVectorCollapsedCasesDelta === 'number' &&\n\t\t(delta.multiVectorCollapsedCasesDelta ?? 0) <\n\t\t\tpolicy.minMultiVectorCollapsedCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`multivector collapsed delta ${delta.multiVectorCollapsedCasesDelta ?? 0} is below ${policy.minMultiVectorCollapsedCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minMultiVectorLexicalHitCasesDelta === 'number' &&\n\t\t(delta.multiVectorLexicalHitCasesDelta ?? 0) <\n\t\t\tpolicy.minMultiVectorLexicalHitCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`multivector lexical-hit delta ${delta.multiVectorLexicalHitCasesDelta ?? 0} is below ${policy.minMultiVectorLexicalHitCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minMultiVectorVectorHitCasesDelta === 'number' &&\n\t\t(delta.multiVectorVectorHitCasesDelta ?? 0) <\n\t\t\tpolicy.minMultiVectorVectorHitCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`multivector vector-hit delta ${delta.multiVectorVectorHitCasesDelta ?? 0} is below ${policy.minMultiVectorVectorHitCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.minEvidenceReconcileCasesDelta === 'number' &&\n\t\t(delta.evidenceReconcileCasesDelta ?? 0) <\n\t\t\tpolicy.minEvidenceReconcileCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`evidence reconcile delta ${delta.evidenceReconcileCasesDelta ?? 0} is below ${policy.minEvidenceReconcileCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.maxRuntimeCandidateBudgetExhaustedCasesDelta ===\n\t\t\t'number' &&\n\t\t(delta.runtimeCandidateBudgetExhaustedCasesDelta ?? 0) >\n\t\t\tpolicy.maxRuntimeCandidateBudgetExhaustedCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`runtime candidate-budget-exhausted delta ${delta.runtimeCandidateBudgetExhaustedCasesDelta ?? 0} exceeds ${policy.maxRuntimeCandidateBudgetExhaustedCasesDelta}`\n\t\t);\n\t}\n\tif (\n\t\ttypeof policy.maxRuntimeUnderfilledTopKCasesDelta === 'number' &&\n\t\t(delta.runtimeUnderfilledTopKCasesDelta ?? 0) >\n\t\t\tpolicy.maxRuntimeUnderfilledTopKCasesDelta\n\t) {\n\t\treasons.push(\n\t\t\t`runtime underfilled-topk delta ${delta.runtimeUnderfilledTopKCasesDelta ?? 0} exceeds ${policy.maxRuntimeUnderfilledTopKCasesDelta}`\n\t\t);\n\t}\n\n\tif (reasons.length === 0) {\n\t\treturn {\n\t\t\tpolicy,\n\t\t\treasons: [],\n\t\t\tstatus: 'pass'\n\t\t};\n\t}\n\n\treturn {\n\t\tpolicy,\n\t\treasons,\n\t\tstatus: policy.severity === 'warn' ? 'warn' : 'fail'\n\t};\n};\n\nexport const buildRAGRetrievalReleaseVerdict = ({\n\tgroupKey,\n\tdecisionSummary\n}: {\n\tgroupKey?: string;\n\tdecisionSummary?: RAGRetrievalComparisonDecisionSummary;\n}): RAGRetrievalReleaseVerdict | undefined => {\n\tif (!decisionSummary) {\n\t\treturn undefined;\n\t}\n\n\tconst gate = decisionSummary.gate;\n\tconst delta = decisionSummary.delta;\n\tconst baselineRetrievalId = decisionSummary.baselineRetrievalId;\n\tconst candidateRetrievalId = decisionSummary.candidateRetrievalId;\n\n\tif (gate) {\n\t\tif (gate.status === 'pass') {\n\t\t\treturn {\n\t\t\t\tbaselineGroupKey: groupKey,\n\t\t\t\tbaselineRetrievalId,\n\t\t\t\tcandidateRetrievalId,\n\t\t\t\tdelta,\n\t\t\t\tgate,\n\t\t\t\tstatus: 'pass',\n\t\t\t\tsummary: 'Candidate passed the active baseline gate.'\n\t\t\t};\n\t\t}\n\n\t\treturn {\n\t\t\tbaselineGroupKey: groupKey,\n\t\t\tbaselineRetrievalId,\n\t\t\tcandidateRetrievalId,\n\t\t\tdelta,\n\t\t\tgate,\n\t\t\tstatus: gate.status,\n\t\t\tsummary:\n\t\t\t\tgate.status === 'warn'\n\t\t\t\t\t? 'Candidate triggered a baseline gate warning.'\n\t\t\t\t\t: 'Candidate failed the active baseline gate.'\n\t\t};\n\t}\n\n\tif (delta) {\n\t\tconst requiresReview =\n\t\t\tdelta.passingRateDelta < 0 ||\n\t\t\tdelta.averageF1Delta < 0 ||\n\t\t\t(delta.evidenceReconcileCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.presentationTitleCueCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.presentationBodyCueCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.presentationNotesCueCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.spreadsheetSheetCueCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.spreadsheetTableCueCasesDelta ?? 0) < 0 ||\n\t\t\t(delta.spreadsheetColumnCueCasesDelta ?? 0) < 0;\n\t\treturn {\n\t\t\tbaselineGroupKey: groupKey,\n\t\t\tbaselineRetrievalId,\n\t\t\tcandidateRetrievalId,\n\t\t\tdelta,\n\t\t\tstatus: requiresReview ? 'needs_review' : 'pass',\n\t\t\tsummary: requiresReview\n\t\t\t\t? 'Candidate should be reviewed before promotion.'\n\t\t\t\t: 'Candidate improved or matched the baseline.'\n\t\t};\n\t}\n\n\treturn {\n\t\tbaselineGroupKey: groupKey,\n\t\tbaselineRetrievalId,\n\t\tcandidateRetrievalId,\n\t\tstatus: 'needs_review',\n\t\tsummary: 'No explicit baseline verdict could be determined.'\n\t};\n};\n\nconst isObjectRecord = (value: unknown): value is Record<string, unknown> =>\n\tBoolean(value) && typeof value === 'object';\n\nconst parseJSONRecord = (value: string | null) => {\n\tif (value === null) {\n\t\treturn undefined;\n\t}\n\n\ttry {\n\t\tconst parsed = JSON.parse(value);\n\n\t\treturn isObjectRecord(parsed) ? parsed : undefined;\n\t} catch {\n\t\treturn undefined;\n\t}\n};\n\nconst parseJSONArray = <T>(value: string | null, fallback: T[]): T[] => {\n\tif (value === null) {\n\t\treturn fallback;\n\t}\n\n\ttry {\n\t\tconst parsed = JSON.parse(value);\n\n\t\treturn Array.isArray(parsed) ? (parsed as T[]) : fallback;\n\t} catch {\n\t\treturn fallback;\n\t}\n};\n\nconst normalizeExpectedIds = (input: string[]) =>\n\tArray.from(new Set(input.map((item) => item.trim()).filter(Boolean)));\n\nconst hasSourceExtension = (\n\tvalue: string | undefined,\n\textensions: string[]\n) => {\n\tif (!value) {\n\t\treturn false;\n\t}\n\tconst normalized = value.trim().toLowerCase();\n\n\treturn extensions.some((extension) => normalized.endsWith(extension));\n};\n\nconst hasMetadataNumber = (\n\tmetadata: Record<string, unknown> | undefined,\n\tkey: string\n) => typeof metadata?.[key] === 'number';\n\nconst hasMetadataString = (\n\tmetadata: Record<string, unknown> | undefined,\n\tkey: string\n) => typeof metadata?.[key] === 'string' && metadata[key] !== '';\n\nconst hasMetadataArray = (\n\tmetadata: Record<string, unknown> | undefined,\n\tkey: string\n) => Array.isArray(metadata?.[key]) && metadata[key].length > 0;\n\nconst detectSectionEvidence = (\n\tids: string[],\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tsources.some(\n\t\t(source) =>\n\t\t\thasMetadataArray(source.metadata, 'sectionPath') ||\n\t\t\thasMetadataString(source.metadata, 'sectionTitle') ||\n\t\t\thasMetadataString(source.metadata, 'sectionKind')\n\t);\n\nconst detectSectionGraphEvidence = (\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tsources.some(\n\t\t(source) =>\n\t\t\thasMetadataString(source.metadata, 'sectionChunkId') ||\n\t\t\thasMetadataNumber(source.metadata, 'sectionChunkIndex') ||\n\t\t\t(hasMetadataNumber(source.metadata, 'sectionChunkCount') &&\n\t\t\t\tNumber(source.metadata?.sectionChunkCount) > 1)\n\t);\n\nconst detectSectionHierarchyEvidence = (\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tsources.some((source) => {\n\t\tconst path = Array.isArray(source.metadata?.sectionPath)\n\t\t\t? source.metadata.sectionPath.filter(\n\t\t\t\t\t(entry): entry is string =>\n\t\t\t\t\t\ttypeof entry === 'string' && entry.trim().length > 0\n\t\t\t\t)\n\t\t\t: [];\n\n\t\treturn path.length > 1;\n\t});\n\nconst detectSpreadsheetEvidence = (\n\tids: string[],\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tids.some((id) =>\n\t\thasSourceExtension(id, ['.xlsx', '.xls', '.csv', '.ods', '.tsv'])\n\t) ||\n\tsources.some(\n\t\t(source) =>\n\t\t\thasSourceExtension(source.source, [\n\t\t\t\t'.xlsx',\n\t\t\t\t'.xls',\n\t\t\t\t'.csv',\n\t\t\t\t'.ods',\n\t\t\t\t'.tsv'\n\t\t\t]) ||\n\t\t\thasMetadataString(source.metadata, 'sheetName') ||\n\t\t\thasMetadataNumber(source.metadata, 'spreadsheetRowStart') ||\n\t\t\thasMetadataNumber(source.metadata, 'spreadsheetTableIndex')\n\t);\n\nconst detectMediaEvidence = (\n\tids: string[],\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tids.some((id) =>\n\t\thasSourceExtension(id, [\n\t\t\t'.mp3',\n\t\t\t'.wav',\n\t\t\t'.m4a',\n\t\t\t'.aac',\n\t\t\t'.ogg',\n\t\t\t'.flac',\n\t\t\t'.mp4',\n\t\t\t'.mov',\n\t\t\t'.mkv',\n\t\t\t'.webm'\n\t\t])\n\t) ||\n\tsources.some(\n\t\t(source) =>\n\t\t\thasSourceExtension(source.source, [\n\t\t\t\t'.mp3',\n\t\t\t\t'.wav',\n\t\t\t\t'.m4a',\n\t\t\t\t'.aac',\n\t\t\t\t'.ogg',\n\t\t\t\t'.flac',\n\t\t\t\t'.mp4',\n\t\t\t\t'.mov',\n\t\t\t\t'.mkv',\n\t\t\t\t'.webm'\n\t\t\t]) ||\n\t\t\thasMetadataString(source.metadata, 'mediaKind') ||\n\t\t\thasMetadataString(source.metadata, 'speaker') ||\n\t\t\thasMetadataNumber(source.metadata, 'startMs')\n\t);\n\nconst detectOCREvidence = (\n\tids: string[],\n\tsources: Array<Pick<RAGSource, 'source' | 'metadata'>> = []\n) =>\n\tids.some((id) =>\n\t\thasSourceExtension(id, ['.png', '.jpg', '.jpeg', '.webp'])\n\t) ||\n\tsources.some(\n\t\t(source) =>\n\t\t\thasSourceExtension(source.source, [\n\t\t\t\t'.png',\n\t\t\t\t'.jpg',\n\t\t\t\t'.jpeg',\n\t\t\t\t'.webp'\n\t\t\t]) ||\n\t\t\thasMetadataNumber(source.metadata, 'ocrConfidence') ||\n\t\t\thasMetadataNumber(source.metadata, 'ocrRegionConfidence') ||\n\t\t\thasMetadataString(source.metadata, 'ocrEngine') ||\n\t\t\tsource.metadata?.pdfTextMode === 'ocr'\n\t);\n\nconst getRetrievalTrace = (\n\ttrace: RAGSearchTraceRecord | RAGRetrievalTrace | undefined\n) => (trace && 'trace' in trace ? trace.trace : trace);\n\nconst classifyRAGEvaluationFailure = (input: {\n\texpectedCount: number;\n\tmatchedCount: number;\n\tmissingIds: string[];\n\tretrievedCount: number;\n\tretrievedIds: string[];\n\tretrievedSources?: RAGSource[];\n\ttrace?: RAGSearchTraceRecord | RAGRetrievalTrace;\n}): NonNullable<RAGEvaluationCaseResult['failureClasses']> => {\n\tconst classes: NonNullable<RAGEvaluationCaseResult['failureClasses']> = [];\n\tif (input.expectedCount === 0) {\n\t\tclasses.push('no_expected_targets');\n\t}\n\tif (input.retrievedCount === 0) {\n\t\tclasses.push('no_results');\n\t}\n\tif (input.expectedCount > 0 && input.matchedCount === 0) {\n\t\tclasses.push('no_match');\n\t}\n\tif (\n\t\tinput.expectedCount > 0 &&\n\t\tinput.matchedCount > 0 &&\n\t\tinput.matchedCount < input.expectedCount\n\t) {\n\t\tclasses.push('partial_recall');\n\t}\n\tif (input.retrievedIds.length > input.matchedCount) {\n\t\tclasses.push('extra_noise');\n\t}\n\tconst sourceSignals = input.retrievedSources ?? [];\n\tconst relevantIds = [...input.missingIds, ...input.retrievedIds];\n\tif (\n\t\t(input.missingIds.length > 0 || input.matchedCount === 0) &&\n\t\tdetectSectionEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('section_evidence_miss');\n\t\tif (detectSectionGraphEvidence(sourceSignals)) {\n\t\t\tclasses.push('section_graph_miss');\n\t\t}\n\t\tif (detectSectionHierarchyEvidence(sourceSignals)) {\n\t\t\tclasses.push('section_hierarchy_miss');\n\t\t}\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.matchedCount === 0) &&\n\t\tdetectSpreadsheetEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('spreadsheet_evidence_miss');\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.matchedCount === 0) &&\n\t\tdetectMediaEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('media_evidence_miss');\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.matchedCount === 0) &&\n\t\tdetectOCREvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('ocr_evidence_miss');\n\t}\n\tconst retrievalTrace = getRetrievalTrace(input.trace);\n\tif (\n\t\t(input.retrievedCount === 0 || input.matchedCount === 0) &&\n\t\t(retrievalTrace?.routingLabel || retrievalTrace?.routingReason)\n\t) {\n\t\tclasses.push('routing_miss');\n\t}\n\n\treturn classes;\n};\n\nconst classifyRAGGroundingFailure = (input: {\n\texpectedCount: number;\n\tmatchedCount: number;\n\tmissingIds: string[];\n\textraIds: string[];\n\tcitationCount: number;\n\tunresolvedCitationCount: number;\n\tavailableSources?: RAGSource[];\n}): NonNullable<RAGAnswerGroundingEvaluationCaseResult['failureClasses']> => {\n\tconst classes: NonNullable<\n\t\tRAGAnswerGroundingEvaluationCaseResult['failureClasses']\n\t> = [];\n\tif (input.expectedCount === 0) {\n\t\tclasses.push('no_expected_targets');\n\t}\n\tif (input.citationCount === 0) {\n\t\tclasses.push('no_citations');\n\t}\n\tif (input.unresolvedCitationCount > 0) {\n\t\tclasses.push('unresolved_citations');\n\t}\n\tif (\n\t\tinput.missingIds.length > 0 ||\n\t\tinput.matchedCount < input.expectedCount\n\t) {\n\t\tclasses.push('missing_expected_sources');\n\t}\n\tif (input.extraIds.length > 0) {\n\t\tclasses.push('extra_citations');\n\t}\n\tconst sourceSignals = input.availableSources ?? [];\n\tconst relevantIds = [...input.missingIds, ...input.extraIds];\n\tif (\n\t\t(input.missingIds.length > 0 || input.citationCount === 0) &&\n\t\tdetectSectionEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('section_source_miss');\n\t\tif (detectSectionGraphEvidence(sourceSignals)) {\n\t\t\tclasses.push('section_graph_source_miss');\n\t\t}\n\t\tif (detectSectionHierarchyEvidence(sourceSignals)) {\n\t\t\tclasses.push('section_hierarchy_source_miss');\n\t\t}\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.citationCount === 0) &&\n\t\tdetectSpreadsheetEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('spreadsheet_source_miss');\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.citationCount === 0) &&\n\t\tdetectMediaEvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('media_source_miss');\n\t}\n\tif (\n\t\t(input.missingIds.length > 0 || input.citationCount === 0) &&\n\t\tdetectOCREvidence(relevantIds, sourceSignals)\n\t) {\n\t\tclasses.push('ocr_source_miss');\n\t}\n\n\treturn classes;\n};\n\nconst normalizeSyntheticText = (value: string) =>\n\tvalue\n\t\t.replace(/^#+\\s*/gm, '')\n\t\t.replace(/`+/g, '')\n\t\t.replace(/\\[(.*?)\\]\\((.*?)\\)/g, '$1')\n\t\t.replace(/\\s+/g, ' ')\n\t\t.trim();\n\nconst buildSyntheticEvaluationQuery = (document: RAGIndexedDocument) => {\n\tconst title = normalizeSyntheticText(document.title);\n\tconst sourceTail = normalizeSyntheticText(\n\t\tdocument.source.split('/').at(-1) ?? document.source\n\t);\n\tconst text = normalizeSyntheticText(document.text ?? '');\n\tconst firstSentence =\n\t\ttext\n\t\t\t.split(/(?<=[.!?])\\s+/)\n\t\t\t.map((entry) => entry.trim())\n\t\t\t.find((entry) => entry.length >= 24) ??\n\t\ttext\n\t\t\t.split(/\\n+/)\n\t\t\t.map((entry) => entry.trim())\n\t\t\t.find((entry) => entry.length >= 24) ??\n\t\ttitle ??\n\t\tsourceTail;\n\tconst prefixedSentence =\n\t\ttitle.length > 0 &&\n\t\tfirstSentence.toLowerCase().startsWith(title.toLowerCase())\n\t\t\t? firstSentence\n\t\t\t: [title, firstSentence].filter(Boolean).join(' ');\n\tconst queryTerms = normalizeSyntheticText(prefixedSentence)\n\t\t.split(/\\s+/)\n\t\t.slice(0, 12)\n\t\t.join(' ');\n\n\treturn queryTerms.length > 0 ? queryTerms : sourceTail;\n};\n\nconst resolveEvaluationMode = (caseInput: {\n\texpectedChunkIds?: string[];\n\texpectedSources?: string[];\n\texpectedDocumentIds?: string[];\n}): 'chunkId' | 'source' | 'documentId' => {\n\tif (normalizeStringArray(caseInput.expectedChunkIds).length > 0) {\n\t\treturn 'chunkId';\n\t}\n\tif (normalizeStringArray(caseInput.expectedSources).length > 0) {\n\t\treturn 'source';\n\t}\n\n\treturn 'documentId';\n};\n\nconst getDocumentId = (source: RAGSource): string => {\n\tconst metadataDocumentId =\n\t\ttypeof source.metadata?.documentId === 'string'\n\t\t\t? source.metadata.documentId\n\t\t\t: undefined;\n\tif (metadataDocumentId) {\n\t\treturn metadataDocumentId;\n\t}\n\tif (source.source) {\n\t\treturn source.source;\n\t}\n\n\tconst [documentId] = source.chunkId.split(':');\n\n\treturn documentId ?? source.chunkId;\n};\n\nconst extractExpectedId = (\n\tsource: RAGSource,\n\tmode: 'chunkId' | 'source' | 'documentId'\n): string =>\n\tmode === 'chunkId'\n\t\t? source.chunkId\n\t\t: mode === 'source'\n\t\t\t? (source.source ?? source.title ?? source.chunkId)\n\t\t\t: getDocumentId(source);\n\nconst buildSources = (\n\tresults: Array<{\n\t\tchunkId: string;\n\t\tchunkText: string;\n\t\tscore: number;\n\t\ttitle?: string;\n\t\tsource?: string;\n\t\tmetadata?: Record<string, unknown>;\n\t}>\n) =>\n\tresults.map((result) => ({\n\t\tchunkId: result.chunkId,\n\t\tmetadata: result.metadata,\n\t\tscore: Number.isFinite(result.score) ? result.score : 0,\n\t\tsource: result.source,\n\t\ttext: result.chunkText,\n\t\ttitle: result.title\n\t}));\n\nconst buildAnswerGroundingStatus = ({\n\tcoverage,\n\texpectedCount,\n\tmatchedCount,\n\tunresolvedCitationCount,\n\tresolvedCitationCount\n}: {\n\tcoverage: RAGAnswerGroundingEvaluationCaseResult['coverage'];\n\texpectedCount: number;\n\tmatchedCount: number;\n\tunresolvedCitationCount: number;\n\tresolvedCitationCount: number;\n}): RAGAnswerGroundingEvaluationCaseResult['status'] => {\n\tif (expectedCount > 0) {\n\t\tif (\n\t\t\tmatchedCount === expectedCount &&\n\t\t\tunresolvedCitationCount === 0 &&\n\t\t\tcoverage !== 'ungrounded'\n\t\t) {\n\t\t\treturn 'pass';\n\t\t}\n\n\t\tif (matchedCount > 0 || resolvedCitationCount > 0) {\n\t\t\treturn 'partial';\n\t\t}\n\n\t\treturn 'fail';\n\t}\n\n\tif (coverage === 'grounded' && unresolvedCitationCount === 0) {\n\t\treturn 'pass';\n\t}\n\n\tif (resolvedCitationCount > 0 || coverage === 'partial') {\n\t\treturn 'partial';\n\t}\n\n\treturn 'fail';\n};\n\nexport const buildRAGEvaluationLeaderboard = (\n\truns: RAGEvaluationSuiteRun[]\n) => {\n\tconst sorted = [...runs].sort((left, right) => {\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\n\treturn sorted.map<RAGEvaluationLeaderboardEntry>((run, index) => ({\n\t\taverageF1: run.response.summary.averageF1,\n\t\taverageLatencyMs: run.response.summary.averageLatencyMs,\n\t\tlabel: run.label,\n\t\tpassingRate: run.response.passingRate,\n\t\trank: index + 1,\n\t\trunId: run.id,\n\t\tsuiteId: run.suiteId,\n\t\ttotalCases: run.response.totalCases\n\t}));\n};\n\nexport const buildRAGAnswerGroundingEvaluationLeaderboard = (\n\truns: RAGAnswerGroundingEvaluationRun[]\n) => {\n\tconst sorted = [...runs].sort((left, right) => {\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageCitationF1 !==\n\t\t\tleft.response.summary.averageCitationF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageCitationF1 -\n\t\t\t\tleft.response.summary.averageCitationF1\n\t\t\t);\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageResolvedCitationRate !==\n\t\t\tleft.response.summary.averageResolvedCitationRate\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageResolvedCitationRate -\n\t\t\t\tleft.response.summary.averageResolvedCitationRate\n\t\t\t);\n\t\t}\n\n\t\treturn left.elapsedMs - right.elapsedMs;\n\t});\n\n\treturn sorted.map<RAGAnswerGroundingEvaluationLeaderboardEntry>(\n\t\t(run, index) => ({\n\t\t\taverageCitationF1: run.response.summary.averageCitationF1,\n\t\t\taverageResolvedCitationRate:\n\t\t\t\trun.response.summary.averageResolvedCitationRate,\n\t\t\tlabel: run.label,\n\t\t\tpassingRate: run.response.passingRate,\n\t\t\trank: index + 1,\n\t\t\trunId: run.id,\n\t\t\tsuiteId: run.suiteId,\n\t\t\ttotalCases: run.response.totalCases\n\t\t})\n\t);\n};\n\nconst buildTraceStageCounts = (traces: RAGRetrievalTrace[]) => {\n\tconst counts: Partial<\n\t\tRecord<RAGRetrievalTrace['steps'][number]['stage'], number>\n\t> = {};\n\n\tfor (const trace of traces) {\n\t\tfor (const step of trace.steps) {\n\t\t\tcounts[step.stage] = (counts[step.stage] ?? 0) + 1;\n\t\t}\n\t}\n\n\treturn counts;\n};\n\nconst diffTraceStageCounts = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: Partial<\n\t\tRecord<RAGRetrievalTrace['steps'][number]['stage'], number>\n\t>;\n\tprevious: Partial<\n\t\tRecord<RAGRetrievalTrace['steps'][number]['stage'], number>\n\t>;\n}) => {\n\tconst next: Partial<\n\t\tRecord<RAGRetrievalTrace['steps'][number]['stage'], number>\n\t> = {};\n\tconst stages = new Set([\n\t\t...Object.keys(current),\n\t\t...Object.keys(previous)\n\t] as RAGRetrievalTrace['steps'][number]['stage'][]);\n\n\tfor (const stage of stages) {\n\t\tconst delta = (current[stage] ?? 0) - (previous[stage] ?? 0);\n\t\tif (delta !== 0) {\n\t\t\tnext[stage] = delta;\n\t\t}\n\t}\n\n\treturn next;\n};\n\nconst normalizeSummaryList = <T extends string>(values: T[]) =>\n\tArray.from(new Set(values)).sort();\n\nconst buildSummaryListDelta = <T extends string>(\n\tcurrent: T[],\n\tprevious: T[]\n) => {\n\tconst currentSet = new Set(current);\n\tconst previousSet = new Set(previous);\n\tconst added = current.filter((value) => !previousSet.has(value));\n\tconst removed = previous.filter((value) => !currentSet.has(value));\n\n\treturn {\n\t\tadded: normalizeSummaryList(Array.from(new Set(added))),\n\t\tcurrent: normalizeSummaryList(current),\n\t\tprevious: normalizeSummaryList(previous),\n\t\tremoved: normalizeSummaryList(Array.from(new Set(removed)))\n\t};\n};\n\nfunction summarizeListTurnover<T extends string>(params: {\n\tcurrent: T[];\n\tprevious: T[];\n\thistory: T[][];\n}): RAGTraceSummaryListTrend<T> {\n\tconst { current, previous, history } = params;\n\tconst currentSet = new Set(current);\n\tconst previousSet = new Set(previous);\n\tconst frequency: Record<string, number> = {};\n\n\tfor (const entry of history) {\n\t\tfor (const value of entry) {\n\t\t\tfrequency[value] = (frequency[value] ?? 0) + 1;\n\t\t}\n\t}\n\n\treturn {\n\t\tappeared: normalizeSummaryList(\n\t\t\tArray.from(\n\t\t\t\tnew Set(current.filter((value) => !previousSet.has(value)))\n\t\t\t)\n\t\t),\n\t\tcurrent: normalizeSummaryList(current),\n\t\tdisappeared: normalizeSummaryList(\n\t\t\tArray.from(\n\t\t\t\tnew Set(previous.filter((value) => !currentSet.has(value)))\n\t\t\t)\n\t\t),\n\t\tfrequency,\n\t\tprevious: normalizeSummaryList(previous),\n\t\tstable: normalizeSummaryList(\n\t\t\tArray.from(\n\t\t\t\tnew Set(current.filter((value) => previousSet.has(value)))\n\t\t\t)\n\t\t)\n\t};\n}\n\nconst diffTraceSummaryStageCounts = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGRetrievalTraceComparisonSummary['stageCounts'];\n\tprevious: RAGRetrievalTraceComparisonSummary['stageCounts'];\n}) => {\n\tconst stages = new Set([\n\t\t...Object.keys(current),\n\t\t...Object.keys(previous)\n\t]) as Set<RAGRetrievalTraceStep['stage']>;\n\tconst next: Partial<\n\t\tRecord<RAGRetrievalTraceStage, RAGTraceSummaryStageCountsDelta>\n\t> = {};\n\n\tfor (const stage of stages) {\n\t\tconst currentCount = current[stage] ?? 0;\n\t\tconst previousCount = previous[stage] ?? 0;\n\t\tconst delta = currentCount - previousCount;\n\t\tif (delta !== 0 || currentCount !== 0 || previousCount !== 0) {\n\t\t\tnext[stage] = {\n\t\t\t\tcurrent: currentCount,\n\t\t\t\tdelta,\n\t\t\t\tprevious: previousCount\n\t\t\t};\n\t\t}\n\t}\n\n\treturn next;\n};\n\nconst roundTraceAverage = (value: number, total: number) =>\n\ttotal > 0 ? Number((value / total).toFixed(2)) : 0;\n\nconst buildTraceSummaryDirection = (\n\tdelta: number\n): RAGTraceSummaryTrendDirection =>\n\tdelta > 0 ? 'up' : delta < 0 ? 'down' : 'flat';\n\nconst buildTraceSummaryAggregate = ({\n\tsummaries\n}: {\n\tsummaries: RAGRetrievalTraceComparisonSummary[];\n}): {\n\taggregate: RAGTraceSummaryNumericDelta[];\n\tbestMetric: RAGTraceSummaryNumericDelta | undefined;\n\tworstMetric: RAGTraceSummaryNumericDelta | undefined;\n} => {\n\tif (summaries.length === 0) {\n\t\tconst aggregate: RAGTraceSummaryNumericDelta[] = [\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'totalCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'averageFinalCount',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'averageVectorCount',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'averageLexicalCount',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'averageCandidateTopK',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'averageLexicalTopK',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'vectorCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'lexicalCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'balancedCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'roundRobinCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'transformedCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'variantCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'multiVectorCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'multiVectorVectorHitCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'multiVectorLexicalHitCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'multiVectorCollapsedCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'runtimeCandidateBudgetExhaustedCases',\n\t\t\t\tprevious: 0\n\t\t\t},\n\t\t\t{\n\t\t\t\tcurrent: 0,\n\t\t\t\tdelta: 0,\n\t\t\t\tdirection: 'flat',\n\t\t\t\tmetric: 'runtimeUnderfilledTopKCases',\n\t\t\t\tprevious: 0\n\t\t\t}\n\t\t];\n\n\t\treturn {\n\t\t\taggregate,\n\t\t\tbestMetric: undefined,\n\t\t\tworstMetric: undefined\n\t\t};\n\t}\n\n\tconst latest = summaries[0]!;\n\tconst previous = summaries[summaries.length - 1]!;\n\tconst aggregate: RAGTraceSummaryNumericDelta[] = [\n\t\t{\n\t\t\tcurrent: latest.totalCases,\n\t\t\tdelta: latest.totalCases - previous.totalCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.totalCases - previous.totalCases\n\t\t\t),\n\t\t\tmetric: 'totalCases',\n\t\t\tprevious: previous.totalCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.averageFinalCount,\n\t\t\tdelta: latest.averageFinalCount - previous.averageFinalCount,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.averageFinalCount - previous.averageFinalCount\n\t\t\t),\n\t\t\tmetric: 'averageFinalCount',\n\t\t\tprevious: previous.averageFinalCount\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.averageVectorCount,\n\t\t\tdelta: latest.averageVectorCount - previous.averageVectorCount,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.averageVectorCount - previous.averageVectorCount\n\t\t\t),\n\t\t\tmetric: 'averageVectorCount',\n\t\t\tprevious: previous.averageVectorCount\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.averageLexicalCount,\n\t\t\tdelta: latest.averageLexicalCount - previous.averageLexicalCount,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.averageLexicalCount - previous.averageLexicalCount\n\t\t\t),\n\t\t\tmetric: 'averageLexicalCount',\n\t\t\tprevious: previous.averageLexicalCount\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.averageCandidateTopK,\n\t\t\tdelta: latest.averageCandidateTopK - previous.averageCandidateTopK,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.averageCandidateTopK - previous.averageCandidateTopK\n\t\t\t),\n\t\t\tmetric: 'averageCandidateTopK',\n\t\t\tprevious: previous.averageCandidateTopK\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.averageLexicalTopK,\n\t\t\tdelta: latest.averageLexicalTopK - previous.averageLexicalTopK,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.averageLexicalTopK - previous.averageLexicalTopK\n\t\t\t),\n\t\t\tmetric: 'averageLexicalTopK',\n\t\t\tprevious: previous.averageLexicalTopK\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.vectorCases,\n\t\t\tdelta: latest.vectorCases - previous.vectorCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.vectorCases - previous.vectorCases\n\t\t\t),\n\t\t\tmetric: 'vectorCases',\n\t\t\tprevious: previous.vectorCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.lexicalCases,\n\t\t\tdelta: latest.lexicalCases - previous.lexicalCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.lexicalCases - previous.lexicalCases\n\t\t\t),\n\t\t\tmetric: 'lexicalCases',\n\t\t\tprevious: previous.lexicalCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.balancedCases,\n\t\t\tdelta: latest.balancedCases - previous.balancedCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.balancedCases - previous.balancedCases\n\t\t\t),\n\t\t\tmetric: 'balancedCases',\n\t\t\tprevious: previous.balancedCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.roundRobinCases,\n\t\t\tdelta: latest.roundRobinCases - previous.roundRobinCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.roundRobinCases - previous.roundRobinCases\n\t\t\t),\n\t\t\tmetric: 'roundRobinCases',\n\t\t\tprevious: previous.roundRobinCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.transformedCases,\n\t\t\tdelta: latest.transformedCases - previous.transformedCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.transformedCases - previous.transformedCases\n\t\t\t),\n\t\t\tmetric: 'transformedCases',\n\t\t\tprevious: previous.transformedCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.variantCases,\n\t\t\tdelta: latest.variantCases - previous.variantCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.variantCases - previous.variantCases\n\t\t\t),\n\t\t\tmetric: 'variantCases',\n\t\t\tprevious: previous.variantCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.multiVectorCases,\n\t\t\tdelta: latest.multiVectorCases - previous.multiVectorCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.multiVectorCases - previous.multiVectorCases\n\t\t\t),\n\t\t\tmetric: 'multiVectorCases',\n\t\t\tprevious: previous.multiVectorCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.multiVectorVectorHitCases,\n\t\t\tdelta:\n\t\t\t\tlatest.multiVectorVectorHitCases -\n\t\t\t\tprevious.multiVectorVectorHitCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.multiVectorVectorHitCases -\n\t\t\t\t\tprevious.multiVectorVectorHitCases\n\t\t\t),\n\t\t\tmetric: 'multiVectorVectorHitCases',\n\t\t\tprevious: previous.multiVectorVectorHitCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.multiVectorLexicalHitCases,\n\t\t\tdelta:\n\t\t\t\tlatest.multiVectorLexicalHitCases -\n\t\t\t\tprevious.multiVectorLexicalHitCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.multiVectorLexicalHitCases -\n\t\t\t\t\tprevious.multiVectorLexicalHitCases\n\t\t\t),\n\t\t\tmetric: 'multiVectorLexicalHitCases',\n\t\t\tprevious: previous.multiVectorLexicalHitCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.multiVectorCollapsedCases,\n\t\t\tdelta:\n\t\t\t\tlatest.multiVectorCollapsedCases -\n\t\t\t\tprevious.multiVectorCollapsedCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.multiVectorCollapsedCases -\n\t\t\t\t\tprevious.multiVectorCollapsedCases\n\t\t\t),\n\t\t\tmetric: 'multiVectorCollapsedCases',\n\t\t\tprevious: previous.multiVectorCollapsedCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.runtimeCandidateBudgetExhaustedCases,\n\t\t\tdelta:\n\t\t\t\tlatest.runtimeCandidateBudgetExhaustedCases -\n\t\t\t\tprevious.runtimeCandidateBudgetExhaustedCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.runtimeCandidateBudgetExhaustedCases -\n\t\t\t\t\tprevious.runtimeCandidateBudgetExhaustedCases\n\t\t\t),\n\t\t\tmetric: 'runtimeCandidateBudgetExhaustedCases',\n\t\t\tprevious: previous.runtimeCandidateBudgetExhaustedCases\n\t\t},\n\t\t{\n\t\t\tcurrent: latest.runtimeUnderfilledTopKCases,\n\t\t\tdelta:\n\t\t\t\tlatest.runtimeUnderfilledTopKCases -\n\t\t\t\tprevious.runtimeUnderfilledTopKCases,\n\t\t\tdirection: buildTraceSummaryDirection(\n\t\t\t\tlatest.runtimeUnderfilledTopKCases -\n\t\t\t\t\tprevious.runtimeUnderfilledTopKCases\n\t\t\t),\n\t\t\tmetric: 'runtimeUnderfilledTopKCases',\n\t\t\tprevious: previous.runtimeUnderfilledTopKCases\n\t\t}\n\t];\n\tconst absoluteSorted = [...aggregate].sort(\n\t\t(left, right) =>\n\t\t\tMath.abs(right.delta) - Math.abs(left.delta) ||\n\t\t\tleft.metric.localeCompare(right.metric)\n\t);\n\n\treturn {\n\t\taggregate,\n\t\tbestMetric: absoluteSorted[0],\n\t\tworstMetric: absoluteSorted[absoluteSorted.length - 1]\n\t};\n};\n\nconst buildRAGRetrievalTraceStageChurn = ({\n\twindows\n}: {\n\twindows: RAGRetrievalTraceHistoryWindow[];\n}): RAGTraceSummaryStageTrend[] => {\n\tconst stages = new Set<RAGRetrievalTraceStep['stage']>();\n\tfor (const window of windows) {\n\t\tfor (const stage of Object.keys(window.current.stageCounts) as Array<\n\t\t\tRAGRetrievalTraceStep['stage']\n\t\t>) {\n\t\t\tstages.add(stage);\n\t\t}\n\t\tfor (const stage of Object.keys(window.previous.stageCounts) as Array<\n\t\t\tRAGRetrievalTraceStep['stage']\n\t\t>) {\n\t\t\tstages.add(stage);\n\t\t}\n\t}\n\n\treturn [...stages]\n\t\t.map((stage) => {\n\t\t\tlet netDelta = 0;\n\t\t\tlet totalChanges = 0;\n\t\t\tfor (const window of windows) {\n\t\t\t\tconst delta = window.delta?.stageCountsDelta[stage]?.delta ?? 0;\n\t\t\t\tnetDelta += delta;\n\t\t\t\ttotalChanges += Math.abs(delta);\n\t\t\t}\n\t\t\treturn {\n\t\t\t\tlatestDelta:\n\t\t\t\t\twindows[0]?.delta?.stageCountsDelta[stage]?.delta ?? 0,\n\t\t\t\tnetDelta,\n\t\t\t\tstage,\n\t\t\t\ttotalChanges\n\t\t\t};\n\t\t})\n\t\t.sort(\n\t\t\t(left, right) =>\n\t\t\t\tright.totalChanges - left.totalChanges ||\n\t\t\t\tleft.stage.localeCompare(right.stage)\n\t\t);\n};\n\nconst summarizeRetrievalTraces = (\n\ttraces: RAGRetrievalTrace[]\n): RAGRetrievalTraceComparisonSummary | undefined => {\n\tif (traces.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst totalCases = traces.length;\n\tconst modeSet = new Set<RAGHybridRetrievalMode>();\n\tconst sourceBalanceStrategySet = new Set<RAGSourceBalanceStrategy>();\n\tlet vectorCases = 0;\n\tlet lexicalCases = 0;\n\tlet balancedCases = 0;\n\tlet roundRobinCases = 0;\n\tlet transformedCases = 0;\n\tlet variantCases = 0;\n\tlet multiVectorCases = 0;\n\tlet multiVectorVectorHitCases = 0;\n\tlet multiVectorLexicalHitCases = 0;\n\tlet multiVectorCollapsedCases = 0;\n\tlet officeEvidenceReconcileCases = 0;\n\tlet officeParagraphEvidenceReconcileCases = 0;\n\tlet officeListEvidenceReconcileCases = 0;\n\tlet officeTableEvidenceReconcileCases = 0;\n\tlet pdfEvidenceReconcileCases = 0;\n\tlet runtimeCandidateBudgetExhaustedCases = 0;\n\tlet runtimeUnderfilledTopKCases = 0;\n\tlet finalCountSum = 0;\n\tlet vectorCountSum = 0;\n\tlet lexicalCountSum = 0;\n\tlet candidateTopKSum = 0;\n\tlet lexicalTopKSum = 0;\n\n\tfor (const trace of traces) {\n\t\tconst vectorSearchMetadata = trace.steps.find(\n\t\t\t(step) => step.stage === 'vector_search'\n\t\t)?.metadata;\n\t\tmodeSet.add(trace.mode);\n\t\tsourceBalanceStrategySet.add(trace.sourceBalanceStrategy ?? 'cap');\n\t\tif (trace.runVector) {\n\t\t\tvectorCases += 1;\n\t\t}\n\t\tif (trace.runLexical) {\n\t\t\tlexicalCases += 1;\n\t\t}\n\t\tif (typeof trace.maxResultsPerSource === 'number') {\n\t\t\tbalancedCases += 1;\n\t\t\tif (trace.sourceBalanceStrategy === 'round_robin') {\n\t\t\t\troundRobinCases += 1;\n\t\t\t}\n\t\t}\n\t\tif (trace.transformedQuery !== trace.query) {\n\t\t\ttransformedCases += 1;\n\t\t}\n\t\tif (trace.variantQueries.length > 0) {\n\t\t\tvariantCases += 1;\n\t\t}\n\t\tif (trace.multiVector?.configured) {\n\t\t\tmultiVectorCases += 1;\n\t\t}\n\t\tif ((trace.multiVector?.vectorVariantHits ?? 0) > 0) {\n\t\t\tmultiVectorVectorHitCases += 1;\n\t\t}\n\t\tif ((trace.multiVector?.lexicalVariantHits ?? 0) > 0) {\n\t\t\tmultiVectorLexicalHitCases += 1;\n\t\t}\n\t\tif ((trace.multiVector?.collapsedParents ?? 0) > 0) {\n\t\t\tmultiVectorCollapsedCases += 1;\n\t\t}\n\t\tconst evidenceReconcileMetadata = trace.steps.find(\n\t\t\t(step) => step.stage === 'evidence_reconcile'\n\t\t)?.metadata;\n\t\tif (\n\t\t\ttypeof evidenceReconcileMetadata?.officeAffectedScopes ===\n\t\t\t\t'number' &&\n\t\t\tevidenceReconcileMetadata.officeAffectedScopes > 0\n\t\t) {\n\t\t\tofficeEvidenceReconcileCases += 1;\n\t\t}\n\t\tif (\n\t\t\ttypeof evidenceReconcileMetadata?.officeParagraphAffectedScopes ===\n\t\t\t\t'number' &&\n\t\t\tevidenceReconcileMetadata.officeParagraphAffectedScopes > 0\n\t\t) {\n\t\t\tofficeParagraphEvidenceReconcileCases += 1;\n\t\t}\n\t\tif (\n\t\t\ttypeof evidenceReconcileMetadata?.officeListAffectedScopes ===\n\t\t\t\t'number' &&\n\t\t\tevidenceReconcileMetadata.officeListAffectedScopes > 0\n\t\t) {\n\t\t\tofficeListEvidenceReconcileCases += 1;\n\t\t}\n\t\tif (\n\t\t\ttypeof evidenceReconcileMetadata?.officeTableAffectedScopes ===\n\t\t\t\t'number' &&\n\t\t\tevidenceReconcileMetadata.officeTableAffectedScopes > 0\n\t\t) {\n\t\t\tofficeTableEvidenceReconcileCases += 1;\n\t\t}\n\t\tif (\n\t\t\ttypeof evidenceReconcileMetadata?.pdfAffectedScopes === 'number' &&\n\t\t\tevidenceReconcileMetadata.pdfAffectedScopes > 0\n\t\t) {\n\t\t\tpdfEvidenceReconcileCases += 1;\n\t\t}\n\t\tif (vectorSearchMetadata?.sqliteQueryCandidateBudgetExhausted) {\n\t\t\truntimeCandidateBudgetExhaustedCases += 1;\n\t\t}\n\t\tif (vectorSearchMetadata?.postgresQueryCandidateBudgetExhausted) {\n\t\t\truntimeCandidateBudgetExhaustedCases += 1;\n\t\t}\n\t\tif (vectorSearchMetadata?.sqliteQueryUnderfilledTopK) {\n\t\t\truntimeUnderfilledTopKCases += 1;\n\t\t}\n\t\tif (vectorSearchMetadata?.postgresQueryUnderfilledTopK) {\n\t\t\truntimeUnderfilledTopKCases += 1;\n\t\t}\n\t\tfinalCountSum += trace.resultCounts.final;\n\t\tvectorCountSum += trace.resultCounts.vector;\n\t\tlexicalCountSum += trace.resultCounts.lexical;\n\t\tcandidateTopKSum += trace.candidateTopK;\n\t\tlexicalTopKSum += trace.lexicalTopK;\n\t}\n\n\treturn {\n\t\taverageCandidateTopK: roundTraceAverage(candidateTopKSum, totalCases),\n\t\taverageFinalCount: roundTraceAverage(finalCountSum, totalCases),\n\t\taverageLexicalCount: roundTraceAverage(lexicalCountSum, totalCases),\n\t\taverageLexicalTopK: roundTraceAverage(lexicalTopKSum, totalCases),\n\t\tbalancedCases,\n\t\taverageVectorCount: roundTraceAverage(vectorCountSum, totalCases),\n\t\tlexicalCases,\n\t\tmodes: Array.from(modeSet),\n\t\troundRobinCases,\n\t\tsourceBalanceStrategies: Array.from(sourceBalanceStrategySet),\n\t\tstageCounts: buildTraceStageCounts(traces),\n\t\ttotalCases,\n\t\ttransformedCases,\n\t\tvariantCases,\n\t\tmultiVectorCases,\n\t\tmultiVectorVectorHitCases,\n\t\tmultiVectorLexicalHitCases,\n\t\tmultiVectorCollapsedCases,\n\t\tofficeEvidenceReconcileCases,\n\t\tofficeParagraphEvidenceReconcileCases,\n\t\tofficeListEvidenceReconcileCases,\n\t\tofficeTableEvidenceReconcileCases,\n\t\tpdfEvidenceReconcileCases,\n\t\truntimeCandidateBudgetExhaustedCases,\n\t\truntimeUnderfilledTopKCases,\n\t\tvectorCases\n\t};\n};\n\nconst evaluateRAGCollectionCases = async ({\n\tcollection,\n\tinput,\n\tdefaultTopK = DEFAULT_TOP_K,\n\trerank,\n\tincludeTrace = false\n}: {\n\tcollection: RAGCollection;\n\tinput: RAGEvaluationInput;\n\tdefaultTopK?: number;\n\trerank?: RAGRerankerProviderLike;\n\tincludeTrace?: boolean;\n}): Promise<\n\tArray<{\n\t\tcaseResult: RAGEvaluationCaseResult;\n\t\ttrace?: RAGRetrievalTrace;\n\t\tfilter?: Record<string, unknown>;\n\t\tretrieval?: RAGCollectionSearchParams['retrieval'];\n\t\ttopResult?: RAGQueryResult;\n\t}>\n> => {\n\tif (input.dryRun) {\n\t\treturn executeDryRunRAGEvaluation(input, defaultTopK).map(\n\t\t\t(caseResult, caseIndex) => ({\n\t\t\t\tcaseResult,\n\t\t\t\tfilter:\n\t\t\t\t\ttypeof input.cases?.[caseIndex]?.filter === 'object'\n\t\t\t\t\t\t? input.cases[caseIndex]?.filter\n\t\t\t\t\t\t: input.filter,\n\t\t\t\tretrieval:\n\t\t\t\t\tinput.cases?.[caseIndex]?.retrieval ?? input.retrieval,\n\t\t\t\ttopResult: undefined,\n\t\t\t\ttrace: undefined\n\t\t\t})\n\t\t);\n\t}\n\n\treturn Promise.all(\n\t\tinput.cases.map(async (caseInput, caseIndex) => {\n\t\t\tconst startedAt = Date.now();\n\t\t\tconst mode = resolveEvaluationMode(caseInput);\n\t\t\tconst query = caseInput.query.trim();\n\t\t\tconst expectedIds = normalizeExpectedIds(\n\t\t\t\tmode === 'chunkId'\n\t\t\t\t\t? (caseInput.expectedChunkIds ?? [])\n\t\t\t\t\t: mode === 'source'\n\t\t\t\t\t\t? (caseInput.expectedSources ?? [])\n\t\t\t\t\t\t: (caseInput.expectedDocumentIds ?? [])\n\t\t\t);\n\t\t\tconst topK =\n\t\t\t\ttypeof caseInput.topK === 'number'\n\t\t\t\t\t? caseInput.topK\n\t\t\t\t\t: typeof input.topK === 'number'\n\t\t\t\t\t\t? input.topK\n\t\t\t\t\t\t: defaultTopK;\n\t\t\tconst searchInput = {\n\t\t\t\tfilter: caseInput.corpusKey\n\t\t\t\t\t? {\n\t\t\t\t\t\t\t...((typeof caseInput.filter === 'object'\n\t\t\t\t\t\t\t\t? caseInput.filter\n\t\t\t\t\t\t\t\t: input.filter) ?? {}),\n\t\t\t\t\t\t\tcorpusKey: caseInput.corpusKey\n\t\t\t\t\t\t}\n\t\t\t\t\t: typeof caseInput.filter === 'object'\n\t\t\t\t\t\t? caseInput.filter\n\t\t\t\t\t\t: input.filter,\n\t\t\t\tmodel: caseInput.model ?? input.model,\n\t\t\t\tquery,\n\t\t\t\trerank,\n\t\t\t\tscoreThreshold:\n\t\t\t\t\ttypeof caseInput.scoreThreshold === 'number'\n\t\t\t\t\t\t? caseInput.scoreThreshold\n\t\t\t\t\t\t: input.scoreThreshold,\n\t\t\t\tretrieval: caseInput.retrieval ?? input.retrieval,\n\t\t\t\ttopK\n\t\t\t};\n\t\t\tconst searchOutcome = includeTrace\n\t\t\t\t? await collection.searchWithTrace(searchInput)\n\t\t\t\t: {\n\t\t\t\t\t\tresults: await collection.search(searchInput),\n\t\t\t\t\t\ttrace: undefined\n\t\t\t\t\t};\n\t\t\tconst sources = buildSources(searchOutcome.results);\n\t\t\tconst elapsedMs = Date.now() - startedAt;\n\t\t\tconst retrievedIds = normalizeExpectedIds(\n\t\t\t\tsources.map((source) => extractExpectedId(source, mode))\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\tcaseResult: summarizeRAGEvaluationCase({\n\t\t\t\t\tcaseIndex,\n\t\t\t\t\tcaseInput: { ...caseInput, topK },\n\t\t\t\t\telapsedMs,\n\t\t\t\t\texpectedIds,\n\t\t\t\t\tmode,\n\t\t\t\t\tquery,\n\t\t\t\t\tretrievedIds,\n\t\t\t\t\tretrievedSources: sources,\n\t\t\t\t\ttrace: searchOutcome.trace\n\t\t\t\t}),\n\t\t\t\ttrace: searchOutcome.trace,\n\t\t\t\tfilter: searchInput.filter,\n\t\t\t\tretrieval: searchInput.retrieval,\n\t\t\t\ttopResult: searchOutcome.results[0]\n\t\t\t};\n\t\t})\n\t);\n};\n\nexport const buildRAGAnswerGroundingCaseDifficultyLeaderboard = (\n\tentries: Array<{\n\t\tlabel: string;\n\t\tresponse: RAGAnswerGroundingEvaluationResponse;\n\t}>\n) => {\n\tconst grouped = new Map<\n\t\tstring,\n\t\t{\n\t\t\tcaseId: string;\n\t\t\tlabel?: string;\n\t\t\tquery?: string;\n\t\t\tpassCount: number;\n\t\t\tpartialCount: number;\n\t\t\tfailCount: number;\n\t\t\tgroundedCount: number;\n\t\t\ttotalEvaluations: number;\n\t\t\ttotalCitationF1: number;\n\t\t\ttotalResolvedCitationRate: number;\n\t\t}\n\t>();\n\n\tfor (const entry of entries) {\n\t\tfor (const result of entry.response.cases) {\n\t\t\tconst current = grouped.get(result.caseId) ?? {\n\t\t\t\tcaseId: result.caseId,\n\t\t\t\tfailCount: 0,\n\t\t\t\tgroundedCount: 0,\n\t\t\t\tlabel: result.label,\n\t\t\t\tpassCount: 0,\n\t\t\t\tpartialCount: 0,\n\t\t\t\tquery: result.query,\n\t\t\t\ttotalCitationF1: 0,\n\t\t\t\ttotalEvaluations: 0,\n\t\t\t\ttotalResolvedCitationRate: 0\n\t\t\t};\n\t\t\tcurrent.label ??= result.label;\n\t\t\tcurrent.query ??= result.query;\n\t\t\tcurrent.totalEvaluations += 1;\n\t\t\tcurrent.totalCitationF1 += result.citationF1;\n\t\t\tcurrent.totalResolvedCitationRate += result.resolvedCitationRate;\n\t\t\tif (result.status === 'pass') {\n\t\t\t\tcurrent.passCount += 1;\n\t\t\t} else if (result.status === 'partial') {\n\t\t\t\tcurrent.partialCount += 1;\n\t\t\t} else {\n\t\t\t\tcurrent.failCount += 1;\n\t\t\t}\n\t\t\tif (result.coverage === 'grounded') {\n\t\t\t\tcurrent.groundedCount += 1;\n\t\t\t}\n\t\t\tgrouped.set(result.caseId, current);\n\t\t}\n\t}\n\n\tconst ranked = Array.from(grouped.values()).sort((left, right) => {\n\t\tconst leftPassRate = left.passCount / left.totalEvaluations;\n\t\tconst rightPassRate = right.passCount / right.totalEvaluations;\n\t\tif (leftPassRate !== rightPassRate) {\n\t\t\treturn leftPassRate - rightPassRate;\n\t\t}\n\t\tconst leftCitationF1 = left.totalCitationF1 / left.totalEvaluations;\n\t\tconst rightCitationF1 = right.totalCitationF1 / right.totalEvaluations;\n\t\tif (leftCitationF1 !== rightCitationF1) {\n\t\t\treturn leftCitationF1 - rightCitationF1;\n\t\t}\n\t\tconst leftResolved =\n\t\t\tleft.totalResolvedCitationRate / left.totalEvaluations;\n\t\tconst rightResolved =\n\t\t\tright.totalResolvedCitationRate / right.totalEvaluations;\n\t\tif (leftResolved !== rightResolved) {\n\t\t\treturn leftResolved - rightResolved;\n\t\t}\n\n\t\treturn left.caseId.localeCompare(right.caseId);\n\t});\n\n\treturn ranked.map<RAGAnswerGroundingEvaluationCaseDifficultyEntry>(\n\t\t(entry, index) => ({\n\t\t\taverageCitationF1: entry.totalCitationF1 / entry.totalEvaluations,\n\t\t\taverageResolvedCitationRate:\n\t\t\t\tentry.totalResolvedCitationRate / entry.totalEvaluations,\n\t\t\tcaseId: entry.caseId,\n\t\t\tfailRate: (entry.failCount / entry.totalEvaluations) * 100,\n\t\t\tgroundedRate: (entry.groundedCount / entry.totalEvaluations) * 100,\n\t\t\tlabel: entry.label,\n\t\t\tpassRate: (entry.passCount / entry.totalEvaluations) * 100,\n\t\t\tpartialRate: (entry.partialCount / entry.totalEvaluations) * 100,\n\t\t\tquery: entry.query,\n\t\t\trank: index + 1,\n\t\t\ttotalEvaluations: entry.totalEvaluations\n\t\t})\n\t);\n};\n\nconst buildGroundingDifficultyDiffEntry = (\n\tcurrent: RAGAnswerGroundingEvaluationCaseDifficultyEntry,\n\tprevious?: RAGAnswerGroundingEvaluationCaseDifficultyEntry\n): RAGAnswerGroundingCaseDifficultyDiffEntry => ({\n\tcaseId: current.caseId,\n\tcurrentAverageCitationF1: current.averageCitationF1,\n\tcurrentFailRate: current.failRate,\n\tcurrentPassRate: current.passRate,\n\tcurrentRank: current.rank,\n\tlabel: current.label,\n\tpreviousAverageCitationF1: previous?.averageCitationF1,\n\tpreviousFailRate: previous?.failRate,\n\tpreviousPassRate: previous?.passRate,\n\tpreviousRank: previous?.rank,\n\tquery: current.query\n});\n\nconst buildRAGAnswerGroundingCaseDifficultyTrends = ({\n\truns\n}: {\n\truns: RAGAnswerGroundingCaseDifficultyRun[];\n}) => {\n\tconst movementCounts = new Map<\n\t\tstring,\n\t\t{\n\t\t\tlabel?: string;\n\t\t\tharder: number;\n\t\t\teasier: number;\n\t\t\tunchanged: number;\n\t\t}\n\t>();\n\n\tfor (let index = 0; index < runs.length - 1; index += 1) {\n\t\tconst current = runs[index];\n\t\tconst previous = runs[index + 1];\n\t\tif (!current || !previous) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst diff = buildRAGAnswerGroundingCaseDifficultyRunDiff({\n\t\t\tcurrent,\n\t\t\tprevious\n\t\t});\n\n\t\tfor (const entry of diff.harderCases) {\n\t\t\tconst currentCounts = movementCounts.get(entry.caseId) ?? {\n\t\t\t\teasier: 0,\n\t\t\t\tharder: 0,\n\t\t\t\tlabel: entry.label,\n\t\t\t\tunchanged: 0\n\t\t\t};\n\t\t\tcurrentCounts.harder += 1;\n\t\t\tcurrentCounts.label ??= entry.label;\n\t\t\tmovementCounts.set(entry.caseId, currentCounts);\n\t\t}\n\n\t\tfor (const entry of diff.easierCases) {\n\t\t\tconst currentCounts = movementCounts.get(entry.caseId) ?? {\n\t\t\t\teasier: 0,\n\t\t\t\tharder: 0,\n\t\t\t\tlabel: entry.label,\n\t\t\t\tunchanged: 0\n\t\t\t};\n\t\t\tcurrentCounts.easier += 1;\n\t\t\tcurrentCounts.label ??= entry.label;\n\t\t\tmovementCounts.set(entry.caseId, currentCounts);\n\t\t}\n\n\t\tfor (const entry of diff.unchangedCases) {\n\t\t\tconst currentCounts = movementCounts.get(entry.caseId) ?? {\n\t\t\t\teasier: 0,\n\t\t\t\tharder: 0,\n\t\t\t\tlabel: entry.label,\n\t\t\t\tunchanged: 0\n\t\t\t};\n\t\t\tcurrentCounts.unchanged += 1;\n\t\t\tcurrentCounts.label ??= entry.label;\n\t\t\tmovementCounts.set(entry.caseId, currentCounts);\n\t\t}\n\t}\n\n\tconst movementEntries = [...movementCounts.entries()];\n\tconst mostOftenHarderCaseIds = movementEntries\n\t\t.filter(([, counts]) => counts.harder > 0)\n\t\t.sort((left, right) => {\n\t\t\tif (right[1].harder !== left[1].harder) {\n\t\t\t\treturn right[1].harder - left[1].harder;\n\t\t\t}\n\t\t\treturn left[0].localeCompare(right[0]);\n\t\t})\n\t\t.map(([caseId]) => caseId);\n\tconst mostOftenEasierCaseIds = movementEntries\n\t\t.filter(([, counts]) => counts.easier > 0)\n\t\t.sort((left, right) => {\n\t\t\tif (right[1].easier !== left[1].easier) {\n\t\t\t\treturn right[1].easier - left[1].easier;\n\t\t\t}\n\t\t\treturn left[0].localeCompare(right[0]);\n\t\t})\n\t\t.map(([caseId]) => caseId);\n\n\treturn {\n\t\teasiestCaseIds:\n\t\t\truns[runs.length - 1]?.entries\n\t\t\t\t.map((entry) => entry.caseId)\n\t\t\t\t.reverse() ?? [],\n\t\thardestCaseIds: runs[0]?.entries.map((entry) => entry.caseId) ?? [],\n\t\tmostOftenEasierCaseIds,\n\t\tmostOftenHarderCaseIds,\n\t\tmovementCounts: Object.fromEntries(\n\t\t\tmovementEntries.map(([caseId, counts]) => [\n\t\t\t\tcaseId,\n\t\t\t\t{\n\t\t\t\t\teasier: counts.easier,\n\t\t\t\t\tharder: counts.harder,\n\t\t\t\t\tunchanged: counts.unchanged\n\t\t\t\t}\n\t\t\t])\n\t\t)\n\t};\n};\n\nexport const buildRAGAnswerGroundingCaseDifficultyRunDiff = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGAnswerGroundingCaseDifficultyRun;\n\tprevious?: RAGAnswerGroundingCaseDifficultyRun;\n}): RAGAnswerGroundingCaseDifficultyRunDiff => {\n\tconst previousEntries = new Map(\n\t\t(previous?.entries ?? []).map((entry) => [entry.caseId, entry])\n\t);\n\tconst diffs = current.entries.map((entry) =>\n\t\tbuildGroundingDifficultyDiffEntry(\n\t\t\tentry,\n\t\t\tpreviousEntries.get(entry.caseId)\n\t\t)\n\t);\n\n\treturn {\n\t\tcurrentRunId: current.id,\n\t\teasierCases: diffs.filter((entry) => {\n\t\t\tconst previousRank = entry.previousRank ?? entry.currentRank;\n\t\t\treturn entry.currentRank > previousRank;\n\t\t}),\n\t\tharderCases: diffs.filter((entry) => {\n\t\t\tconst previousRank = entry.previousRank ?? Number.MAX_SAFE_INTEGER;\n\t\t\treturn entry.currentRank < previousRank;\n\t\t}),\n\t\tpreviousRunId: previous?.id,\n\t\tsuiteId: current.suiteId,\n\t\tunchangedCases: diffs.filter((entry) => {\n\t\t\tconst previousRank = entry.previousRank ?? entry.currentRank;\n\t\t\treturn entry.currentRank === previousRank;\n\t\t})\n\t};\n};\n\nconst toHistorySortOrder = (\n\tleft: RAGEvaluationSuiteRun,\n\tright: RAGEvaluationSuiteRun\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeHistoryRuns = (runs: RAGEvaluationSuiteRun[]) =>\n\t[...runs].sort(toHistorySortOrder);\n\nconst normalizeRetrievalComparisonRuns = (runs: RAGRetrievalComparisonRun[]) =>\n\t[...runs].sort((left, right) => right.finishedAt - left.finishedAt);\n\nconst toTraceSummaryRunSortOrder = (\n\tleft: RAGRetrievalTraceSummaryRun,\n\tright: RAGRetrievalTraceSummaryRun\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeTraceSummaryRuns = <TRun extends RAGRetrievalTraceSummaryRun>(\n\truns: TRun[]\n) => [...runs].sort(toTraceSummaryRunSortOrder);\n\nconst applyRAGEvaluationHistoryPrunePolicy = <\n\tTRun extends {\n\t\tid: string;\n\t\tsuiteId: string;\n\t\tfinishedAt?: number;\n\t\tcreatedAt?: number;\n\t}\n>({\n\tinput,\n\truns,\n\tsort\n}: {\n\tinput?: RAGEvaluationHistoryPruneInput;\n\truns: TRun[];\n\tsort: (runs: TRun[]) => TRun[];\n}): {\n\tnext: TRun[];\n\tremoved: TRun[];\n\tkeptCount: number;\n\tremovedCount: number;\n} => {\n\tconst sorted = sort(runs);\n\tconst targeted = sorted.filter(\n\t\t(run) => !input?.suiteId || run.suiteId === input.suiteId\n\t);\n\tconst untouched = sorted.filter(\n\t\t(run) => input?.suiteId && run.suiteId !== input.suiteId\n\t);\n\tconst now = input?.now ?? Date.now();\n\tlet kept = [...targeted];\n\n\tif (\n\t\ttypeof input?.maxAgeMs === 'number' &&\n\t\tNumber.isFinite(input.maxAgeMs)\n\t) {\n\t\tconst cutoff = now - input.maxAgeMs;\n\t\tkept = kept.filter((run) => {\n\t\t\tconst timestamp = run.finishedAt ?? run.createdAt ?? 0;\n\t\t\treturn timestamp >= cutoff;\n\t\t});\n\t}\n\n\tif (\n\t\ttypeof input?.maxRunsPerSuite === 'number' &&\n\t\tNumber.isFinite(input.maxRunsPerSuite) &&\n\t\tinput.maxRunsPerSuite >= 0\n\t) {\n\t\tconst remainingBySuite = new Map<string, number>();\n\t\tkept = kept.filter((run) => {\n\t\t\tconst current = remainingBySuite.get(run.suiteId) ?? 0;\n\t\t\tif (current >= input.maxRunsPerSuite!) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tremainingBySuite.set(run.suiteId, current + 1);\n\t\t\treturn true;\n\t\t});\n\t}\n\n\tconst keptIds = new Set(kept.map((run) => run.id));\n\tconst removed = targeted.filter((run) => !keptIds.has(run.id));\n\tconst next = sort([...untouched, ...kept]);\n\n\treturn {\n\t\tkeptCount: next.length,\n\t\tnext,\n\t\tremoved,\n\t\tremovedCount: removed.length\n\t};\n};\n\nconst applyRAGSearchTracePrunePolicy = ({\n\tinput,\n\ttraces\n}: {\n\tinput?: RAGSearchTracePruneInput;\n\ttraces: RAGSearchTraceRecord[];\n}) => {\n\tconst sorted = normalizeTraceSummaryRuns(traces);\n\tconst matchesTag = (trace: RAGSearchTraceRecord) =>\n\t\t!input?.tag || (trace.tags ?? []).includes(input.tag);\n\tconst targeted = sorted.filter(matchesTag);\n\tconst untouched = sorted.filter((trace) => !matchesTag(trace));\n\tconst now = input?.now ?? Date.now();\n\tlet kept = [...targeted];\n\n\tif (\n\t\ttypeof input?.maxAgeMs === 'number' &&\n\t\tNumber.isFinite(input.maxAgeMs)\n\t) {\n\t\tconst cutoff = now - input.maxAgeMs;\n\t\tkept = kept.filter((trace) => trace.finishedAt >= cutoff);\n\t}\n\n\tif (\n\t\ttypeof input?.maxRecordsPerQuery === 'number' &&\n\t\tNumber.isFinite(input.maxRecordsPerQuery) &&\n\t\tinput.maxRecordsPerQuery >= 0\n\t) {\n\t\tconst remainingByQuery = new Map<string, number>();\n\t\tkept = kept.filter((trace) => {\n\t\t\tconst current = remainingByQuery.get(trace.query) ?? 0;\n\t\t\tif (current >= input.maxRecordsPerQuery!) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tremainingByQuery.set(trace.query, current + 1);\n\t\t\treturn true;\n\t\t});\n\t}\n\n\tif (\n\t\ttypeof input?.maxRecordsPerGroup === 'number' &&\n\t\tNumber.isFinite(input.maxRecordsPerGroup) &&\n\t\tinput.maxRecordsPerGroup >= 0\n\t) {\n\t\tconst remainingByGroup = new Map<string, number>();\n\t\tkept = kept.filter((trace) => {\n\t\t\tif (!trace.groupKey) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tconst current = remainingByGroup.get(trace.groupKey) ?? 0;\n\t\t\tif (current >= input.maxRecordsPerGroup!) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tremainingByGroup.set(trace.groupKey, current + 1);\n\t\t\treturn true;\n\t\t});\n\t}\n\n\tconst keptIds = new Set(kept.map((trace) => trace.id));\n\tconst removed = targeted.filter((trace) => !keptIds.has(trace.id));\n\tconst next = normalizeTraceSummaryRuns([...untouched, ...kept]);\n\n\treturn {\n\t\tkeptCount: next.length,\n\t\tnext,\n\t\tremoved,\n\t\tremovedCount: removed.length\n\t};\n};\n\nconst buildRAGSearchTraceStatsFromTraces = (\n\ttraces: RAGSearchTraceRecord[]\n): RAGSearchTraceStats => {\n\tconst queryKeys = new Set<string>();\n\tconst groupKeys = new Set<string>();\n\tconst tagCounts = new Map<string, number>();\n\tlet oldestFinishedAt: number | undefined;\n\tlet newestFinishedAt: number | undefined;\n\n\tfor (const trace of traces) {\n\t\tqueryKeys.add(trace.query);\n\t\tif (trace.groupKey) {\n\t\t\tgroupKeys.add(trace.groupKey);\n\t\t}\n\t\tfor (const tag of trace.tags ?? []) {\n\t\t\ttagCounts.set(tag, (tagCounts.get(tag) ?? 0) + 1);\n\t\t}\n\t\toldestFinishedAt =\n\t\t\ttypeof oldestFinishedAt === 'number'\n\t\t\t\t? Math.min(oldestFinishedAt, trace.finishedAt)\n\t\t\t\t: trace.finishedAt;\n\t\tnewestFinishedAt =\n\t\t\ttypeof newestFinishedAt === 'number'\n\t\t\t\t? Math.max(newestFinishedAt, trace.finishedAt)\n\t\t\t\t: trace.finishedAt;\n\t}\n\n\treturn {\n\t\tgroupCount: groupKeys.size,\n\t\tnewestFinishedAt,\n\t\toldestFinishedAt,\n\t\tqueryCount: queryKeys.size,\n\t\ttagCounts: Object.fromEntries(tagCounts.entries()),\n\t\ttotalTraces: traces.length\n\t};\n};\n\nconst normalizeTraceTags = (tags?: string[]) =>\n\tArray.from(\n\t\tnew Set((tags ?? []).map((tag) => tag.trim()).filter(Boolean))\n\t).sort((left, right) => left.localeCompare(right));\n\nconst toGroundingHistorySortOrder = (\n\tleft: RAGAnswerGroundingEvaluationRun,\n\tright: RAGAnswerGroundingEvaluationRun\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeGroundingHistoryRuns = (\n\truns: RAGAnswerGroundingEvaluationRun[]\n) => [...runs].sort(toGroundingHistorySortOrder);\n\nconst toSearchTracePruneRunSortOrder = (\n\tleft: RAGSearchTracePruneRun,\n\tright: RAGSearchTracePruneRun\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeSearchTracePruneRuns = (runs: RAGSearchTracePruneRun[]) =>\n\t[...runs].sort(toSearchTracePruneRunSortOrder);\n\nconst toGroundingDifficultyHistorySortOrder = (\n\tleft: RAGAnswerGroundingCaseDifficultyRun,\n\tright: RAGAnswerGroundingCaseDifficultyRun\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeGroundingDifficultyHistoryRuns = (\n\truns: RAGAnswerGroundingCaseDifficultyRun[]\n) => [...runs].sort(toGroundingDifficultyHistorySortOrder);\n\nconst buildCaseDiff = (\n\tcurrentCase: RAGEvaluationCaseResult,\n\tpreviousCase?: RAGEvaluationCaseResult\n): RAGEvaluationCaseDiff => ({\n\tcaseId: currentCase.caseId,\n\tcurrentF1: currentCase.f1,\n\tcurrentMatchedIds: currentCase.matchedIds,\n\tcurrentMissingIds: currentCase.missingIds,\n\tcurrentStatus: currentCase.status,\n\tlabel: currentCase.label,\n\tpreviousF1: previousCase?.f1,\n\tpreviousMatchedIds: previousCase?.matchedIds ?? [],\n\tpreviousMissingIds: previousCase?.missingIds ?? [],\n\tpreviousStatus: previousCase?.status,\n\tpreviousFailureClasses: previousCase?.failureClasses ?? [],\n\tquery: currentCase.query,\n\tcurrentFailureClasses: currentCase.failureClasses ?? []\n});\n\nconst buildGroundingCaseDiff = (\n\tcurrentCase: RAGAnswerGroundingEvaluationCaseResult,\n\tpreviousCase?: RAGAnswerGroundingEvaluationCaseResult\n): RAGAnswerGroundingEvaluationCaseDiff => ({\n\tanswerChanged:\n\t\ttypeof previousCase?.answer === 'string'\n\t\t\t? previousCase.answer !== currentCase.answer\n\t\t\t: true,\n\tcaseId: currentCase.caseId,\n\tcurrentCitationF1: currentCase.citationF1,\n\tcurrentCitedIds: currentCase.citedIds,\n\tcurrentCoverage: currentCase.coverage,\n\tcurrentExtraIds: currentCase.extraIds,\n\tcurrentMatchedIds: currentCase.matchedIds,\n\tcurrentMissingIds: currentCase.missingIds,\n\tcurrentReferenceCount: currentCase.referenceCount,\n\tcurrentResolvedCitationCount: currentCase.resolvedCitationCount,\n\tcurrentAnswer: currentCase.answer,\n\tcurrentStatus: currentCase.status,\n\tcurrentUngroundedReferenceNumbers:\n\t\tcurrentCase.groundedAnswer.ungroundedReferenceNumbers,\n\tcurrentUnresolvedCitationCount: currentCase.unresolvedCitationCount,\n\tlabel: currentCase.label,\n\tpreviousAnswer: previousCase?.answer,\n\tpreviousCitationF1: previousCase?.citationF1,\n\tpreviousCitedIds: previousCase?.citedIds ?? [],\n\tpreviousCoverage: previousCase?.coverage,\n\tpreviousExtraIds: previousCase?.extraIds ?? [],\n\tpreviousFailureClasses: previousCase?.failureClasses ?? [],\n\tpreviousMatchedIds: previousCase?.matchedIds ?? [],\n\tpreviousMissingIds: previousCase?.missingIds ?? [],\n\tpreviousReferenceCount: previousCase?.referenceCount,\n\tpreviousResolvedCitationCount: previousCase?.resolvedCitationCount,\n\tpreviousStatus: previousCase?.status,\n\tpreviousUngroundedReferenceNumbers:\n\t\tpreviousCase?.groundedAnswer.ungroundedReferenceNumbers ?? [],\n\tpreviousUnresolvedCitationCount: previousCase?.unresolvedCitationCount,\n\tquery: currentCase.query,\n\tcurrentFailureClasses: currentCase.failureClasses ?? []\n});\n\nconst buildGroundingCaseSnapshots = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent?: RAGAnswerGroundingEvaluationRun;\n\tprevious?: RAGAnswerGroundingEvaluationRun;\n}): RAGAnswerGroundingEvaluationCaseSnapshot[] => {\n\tif (!current) {\n\t\treturn [];\n\t}\n\n\tconst previousCases = new Map(\n\t\t(previous?.response.cases ?? []).map((entry) => [entry.caseId, entry])\n\t);\n\n\treturn current.response.cases.map((entry) => {\n\t\tconst previousCase = previousCases.get(entry.caseId);\n\t\treturn {\n\t\t\tanswer: entry.answer,\n\t\t\tanswerChange:\n\t\t\t\ttypeof previousCase?.answer === 'string'\n\t\t\t\t\t? previousCase.answer === entry.answer\n\t\t\t\t\t\t? 'unchanged'\n\t\t\t\t\t\t: 'changed'\n\t\t\t\t\t: 'new',\n\t\t\tcaseId: entry.caseId,\n\t\t\tcitationCount: entry.citationCount,\n\t\t\tcitationF1: entry.citationF1,\n\t\t\tcitedIds: entry.citedIds,\n\t\t\tcoverage: entry.coverage,\n\t\t\textraIds: entry.extraIds,\n\t\t\tfailureClasses: entry.failureClasses,\n\t\t\tlabel: entry.label,\n\t\t\tmatchedIds: entry.matchedIds,\n\t\t\tmissingIds: entry.missingIds,\n\t\t\tpreviousAnswer: previousCase?.answer,\n\t\t\tquery: entry.query,\n\t\t\treferenceCount: entry.referenceCount,\n\t\t\tresolvedCitationCount: entry.resolvedCitationCount,\n\t\t\tresolvedCitationRate: entry.resolvedCitationRate,\n\t\t\tstatus: entry.status,\n\t\t\tungroundedReferenceNumbers:\n\t\t\t\tentry.groundedAnswer.ungroundedReferenceNumbers,\n\t\t\tunresolvedCitationCount: entry.unresolvedCitationCount\n\t\t};\n\t});\n};\n\nconst areStageCountsEqual = (\n\tleft: Partial<Record<RAGRetrievalTraceStage, number>>,\n\tright: Partial<Record<RAGRetrievalTraceStage, number>>\n) => {\n\tconst keys = new Set([\n\t\t...Object.keys(left),\n\t\t...Object.keys(right)\n\t]) as Set<RAGRetrievalTraceStage>;\n\n\tfor (const key of keys) {\n\t\tif ((left[key] ?? 0) !== (right[key] ?? 0)) {\n\t\t\treturn false;\n\t\t}\n\t}\n\n\treturn true;\n};\n\nconst buildEvaluationCaseTraceSnapshot = ({\n\tcaseResult,\n\tfilter,\n\tretrieval,\n\tcurrentTrace,\n\tpreviousTrace,\n\tcurrentSnapshot,\n\ttopResult\n}: {\n\tcaseResult: RAGEvaluationCaseResult;\n\tfilter?: Record<string, unknown>;\n\tretrieval?: RAGCollectionSearchParams['retrieval'];\n\tcurrentTrace?: RAGRetrievalTrace;\n\tpreviousTrace?: RAGEvaluationCaseTraceSnapshot;\n\tcurrentSnapshot?: RAGEvaluationCaseTraceSnapshot;\n\ttopResult?: RAGQueryResult;\n}): RAGEvaluationCaseTraceSnapshot => {\n\tconst stageCounts = currentTrace\n\t\t? buildTraceStageCounts([currentTrace])\n\t\t: {};\n\tconst previousStageCounts = previousTrace?.stageCounts ?? {};\n\tconst currentLeadSnapshot =\n\t\ttopResult || currentSnapshot\n\t\t\t? buildEvaluationLeadSnapshot({\n\t\t\t\t\tmetadata: topResult?.metadata,\n\t\t\t\t\tsource: topResult?.source,\n\t\t\t\t\ttitle: topResult?.title\n\t\t\t\t})\n\t\t\t: {};\n\tconst topContextLabel =\n\t\tcurrentLeadSnapshot.topContextLabel ?? currentSnapshot?.topContextLabel;\n\tconst topLocatorLabel =\n\t\tcurrentLeadSnapshot.topLocatorLabel ?? currentSnapshot?.topLocatorLabel;\n\tconst sourceAwareChunkReasonLabel =\n\t\tcurrentLeadSnapshot.sourceAwareChunkReasonLabel ??\n\t\tcurrentSnapshot?.sourceAwareChunkReasonLabel;\n\tconst sourceAwareUnitScopeLabel =\n\t\tcurrentLeadSnapshot.sourceAwareUnitScopeLabel ??\n\t\tcurrentSnapshot?.sourceAwareUnitScopeLabel;\n\tconst currentLeadMediaCueSnapshot = currentTrace\n\t\t? buildEvaluationLeadMediaCueSnapshot(currentTrace)\n\t\t: {};\n\tconst currentLeadPresentationCueSnapshot = currentTrace\n\t\t? buildEvaluationLeadPresentationCueSnapshot(currentTrace)\n\t\t: {};\n\tconst currentLeadSpreadsheetCueSnapshot = currentTrace\n\t\t? buildEvaluationLeadSpreadsheetCueSnapshot(currentTrace)\n\t\t: {};\n\tconst currentSQLiteQueryPlanSnapshot = currentTrace\n\t\t? buildEvaluationSQLiteQueryPlanSnapshot(currentTrace)\n\t\t: {};\n\tconst currentPostgresQueryPlanSnapshot = currentTrace\n\t\t? buildEvaluationPostgresQueryPlanSnapshot(currentTrace)\n\t\t: {};\n\tconst leadSpeakerCue =\n\t\tcurrentLeadMediaCueSnapshot.leadSpeakerCue ??\n\t\tcurrentSnapshot?.leadSpeakerCue;\n\tconst leadPresentationCue =\n\t\tcurrentLeadPresentationCueSnapshot.leadPresentationCue ??\n\t\tcurrentSnapshot?.leadPresentationCue;\n\tconst leadSpreadsheetCue =\n\t\tcurrentLeadSpreadsheetCueSnapshot.leadSpreadsheetCue ??\n\t\tcurrentSnapshot?.leadSpreadsheetCue;\n\tconst leadSpeakerAttributionCue =\n\t\tcurrentLeadMediaCueSnapshot.leadSpeakerAttributionCue ??\n\t\tcurrentSnapshot?.leadSpeakerAttributionCue;\n\tconst leadChannelCue =\n\t\tcurrentLeadMediaCueSnapshot.leadChannelCue ??\n\t\tcurrentSnapshot?.leadChannelCue;\n\tconst leadChannelAttributionCue =\n\t\tcurrentLeadMediaCueSnapshot.leadChannelAttributionCue ??\n\t\tcurrentSnapshot?.leadChannelAttributionCue;\n\tconst leadContinuityCue =\n\t\tcurrentLeadMediaCueSnapshot.leadContinuityCue ??\n\t\tcurrentSnapshot?.leadContinuityCue;\n\tconst sqliteQueryMode =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryMode ??\n\t\tcurrentSnapshot?.sqliteQueryMode;\n\tconst sqliteQueryPushdownMode =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryPushdownMode ??\n\t\tcurrentSnapshot?.sqliteQueryPushdownMode;\n\tconst sqliteQueryPushdownApplied =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryPushdownApplied ??\n\t\tcurrentSnapshot?.sqliteQueryPushdownApplied;\n\tconst sqliteQueryPushdownClauseCount =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryPushdownClauseCount ??\n\t\tcurrentSnapshot?.sqliteQueryPushdownClauseCount;\n\tconst sqliteQueryTotalFilterClauseCount =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryTotalFilterClauseCount ??\n\t\tcurrentSnapshot?.sqliteQueryTotalFilterClauseCount;\n\tconst sqliteQueryJsRemainderClauseCount =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryJsRemainderClauseCount ??\n\t\tcurrentSnapshot?.sqliteQueryJsRemainderClauseCount;\n\tconst sqliteQueryMultiplierUsed =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryMultiplierUsed ??\n\t\tcurrentSnapshot?.sqliteQueryMultiplierUsed;\n\tconst sqliteQueryCandidateLimitUsed =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryCandidateLimitUsed ??\n\t\tcurrentSnapshot?.sqliteQueryCandidateLimitUsed;\n\tconst sqliteQueryMaxBackfillsUsed =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryMaxBackfillsUsed ??\n\t\tcurrentSnapshot?.sqliteQueryMaxBackfillsUsed;\n\tconst sqliteQueryMinResultsUsed =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryMinResultsUsed ??\n\t\tcurrentSnapshot?.sqliteQueryMinResultsUsed;\n\tconst sqliteQueryFillPolicyUsed =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryFillPolicyUsed ??\n\t\tcurrentSnapshot?.sqliteQueryFillPolicyUsed;\n\tconst sqliteQueryPushdownCoverageRatio =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryPushdownCoverageRatio ??\n\t\tcurrentSnapshot?.sqliteQueryPushdownCoverageRatio;\n\tconst sqliteQueryJsRemainderRatio =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryJsRemainderRatio ??\n\t\tcurrentSnapshot?.sqliteQueryJsRemainderRatio;\n\tconst sqliteQueryFilteredCandidates =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryFilteredCandidates ??\n\t\tcurrentSnapshot?.sqliteQueryFilteredCandidates;\n\tconst sqliteQueryInitialSearchK =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryInitialSearchK ??\n\t\tcurrentSnapshot?.sqliteQueryInitialSearchK;\n\tconst sqliteQueryFinalSearchK =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryFinalSearchK ??\n\t\tcurrentSnapshot?.sqliteQueryFinalSearchK;\n\tconst sqliteQuerySearchExpansionRatio =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQuerySearchExpansionRatio ??\n\t\tcurrentSnapshot?.sqliteQuerySearchExpansionRatio;\n\tconst sqliteQueryBackfillCount =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryBackfillCount ??\n\t\tcurrentSnapshot?.sqliteQueryBackfillCount;\n\tconst sqliteQueryBackfillLimitReached =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryBackfillLimitReached ??\n\t\tcurrentSnapshot?.sqliteQueryBackfillLimitReached;\n\tconst sqliteQueryMinResultsSatisfied =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryMinResultsSatisfied ??\n\t\tcurrentSnapshot?.sqliteQueryMinResultsSatisfied;\n\tconst sqliteQueryReturnedCount =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryReturnedCount ??\n\t\tcurrentSnapshot?.sqliteQueryReturnedCount;\n\tconst sqliteQueryCandidateYieldRatio =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryCandidateYieldRatio ??\n\t\tcurrentSnapshot?.sqliteQueryCandidateYieldRatio;\n\tconst sqliteQueryTopKFillRatio =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryTopKFillRatio ??\n\t\tcurrentSnapshot?.sqliteQueryTopKFillRatio;\n\tconst sqliteQueryUnderfilledTopK =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryUnderfilledTopK ??\n\t\tcurrentSnapshot?.sqliteQueryUnderfilledTopK;\n\tconst sqliteQueryCandidateBudgetExhausted =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryCandidateBudgetExhausted ??\n\t\tcurrentSnapshot?.sqliteQueryCandidateBudgetExhausted;\n\tconst sqliteQueryCandidateCoverage =\n\t\tcurrentSQLiteQueryPlanSnapshot.sqliteQueryCandidateCoverage ??\n\t\tcurrentSnapshot?.sqliteQueryCandidateCoverage;\n\tconst postgresQueryMode =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryMode ??\n\t\tcurrentSnapshot?.postgresQueryMode;\n\tconst postgresQueryPushdownMode =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryPushdownMode ??\n\t\tcurrentSnapshot?.postgresQueryPushdownMode;\n\tconst postgresQueryPushdownApplied =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryPushdownApplied ??\n\t\tcurrentSnapshot?.postgresQueryPushdownApplied;\n\tconst postgresQueryPushdownClauseCount =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryPushdownClauseCount ??\n\t\tcurrentSnapshot?.postgresQueryPushdownClauseCount;\n\tconst postgresQueryTotalFilterClauseCount =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryTotalFilterClauseCount ??\n\t\tcurrentSnapshot?.postgresQueryTotalFilterClauseCount;\n\tconst postgresQueryJsRemainderClauseCount =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryJsRemainderClauseCount ??\n\t\tcurrentSnapshot?.postgresQueryJsRemainderClauseCount;\n\tconst postgresQueryMultiplierUsed =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryMultiplierUsed ??\n\t\tcurrentSnapshot?.postgresQueryMultiplierUsed;\n\tconst postgresQueryCandidateLimitUsed =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryCandidateLimitUsed ??\n\t\tcurrentSnapshot?.postgresQueryCandidateLimitUsed;\n\tconst postgresQueryMaxBackfillsUsed =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryMaxBackfillsUsed ??\n\t\tcurrentSnapshot?.postgresQueryMaxBackfillsUsed;\n\tconst postgresQueryMinResultsUsed =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryMinResultsUsed ??\n\t\tcurrentSnapshot?.postgresQueryMinResultsUsed;\n\tconst postgresQueryFillPolicyUsed =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryFillPolicyUsed ??\n\t\tcurrentSnapshot?.postgresQueryFillPolicyUsed;\n\tconst postgresQueryPushdownCoverageRatio =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryPushdownCoverageRatio ??\n\t\tcurrentSnapshot?.postgresQueryPushdownCoverageRatio;\n\tconst postgresQueryJsRemainderRatio =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryJsRemainderRatio ??\n\t\tcurrentSnapshot?.postgresQueryJsRemainderRatio;\n\tconst postgresQueryFilteredCandidates =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryFilteredCandidates ??\n\t\tcurrentSnapshot?.postgresQueryFilteredCandidates;\n\tconst postgresQueryInitialSearchK =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryInitialSearchK ??\n\t\tcurrentSnapshot?.postgresQueryInitialSearchK;\n\tconst postgresQueryFinalSearchK =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryFinalSearchK ??\n\t\tcurrentSnapshot?.postgresQueryFinalSearchK;\n\tconst postgresQuerySearchExpansionRatio =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQuerySearchExpansionRatio ??\n\t\tcurrentSnapshot?.postgresQuerySearchExpansionRatio;\n\tconst postgresQueryBackfillCount =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryBackfillCount ??\n\t\tcurrentSnapshot?.postgresQueryBackfillCount;\n\tconst postgresQueryBackfillLimitReached =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryBackfillLimitReached ??\n\t\tcurrentSnapshot?.postgresQueryBackfillLimitReached;\n\tconst postgresQueryMinResultsSatisfied =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryMinResultsSatisfied ??\n\t\tcurrentSnapshot?.postgresQueryMinResultsSatisfied;\n\tconst postgresQueryReturnedCount =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryReturnedCount ??\n\t\tcurrentSnapshot?.postgresQueryReturnedCount;\n\tconst postgresQueryCandidateYieldRatio =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryCandidateYieldRatio ??\n\t\tcurrentSnapshot?.postgresQueryCandidateYieldRatio;\n\tconst postgresQueryTopKFillRatio =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryTopKFillRatio ??\n\t\tcurrentSnapshot?.postgresQueryTopKFillRatio;\n\tconst postgresQueryUnderfilledTopK =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryUnderfilledTopK ??\n\t\tcurrentSnapshot?.postgresQueryUnderfilledTopK;\n\tconst postgresQueryCandidateBudgetExhausted =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryCandidateBudgetExhausted ??\n\t\tcurrentSnapshot?.postgresQueryCandidateBudgetExhausted;\n\tconst postgresQueryCandidateCoverage =\n\t\tcurrentPostgresQueryPlanSnapshot.postgresQueryCandidateCoverage ??\n\t\tcurrentSnapshot?.postgresQueryCandidateCoverage;\n\tconst currentFilterSignature = JSON.stringify(filter ?? undefined);\n\tconst previousFilterSignature = JSON.stringify(\n\t\tpreviousTrace?.inputFilter ?? undefined\n\t);\n\tconst currentRetrievalSignature = JSON.stringify(retrieval ?? undefined);\n\tconst previousRetrievalSignature = JSON.stringify(\n\t\tpreviousTrace?.inputRetrieval ?? undefined\n\t);\n\tconst traceChange = !previousTrace\n\t\t? currentTrace\n\t\t\t? 'new'\n\t\t\t: 'unchanged'\n\t\t: previousTrace.traceMode !== currentTrace?.mode ||\n\t\t\t previousFilterSignature !== currentFilterSignature ||\n\t\t\t previousRetrievalSignature !== currentRetrievalSignature ||\n\t\t\t previousTrace.sourceBalanceStrategy !==\n\t\t\t\t\tcurrentTrace?.sourceBalanceStrategy ||\n\t\t\t previousTrace.transformedQuery !==\n\t\t\t\t\t(currentTrace?.transformedQuery || undefined) ||\n\t\t\t previousTrace.variantQueries.join('|') !==\n\t\t\t\t\t(currentTrace?.variantQueries ?? []).join('|') ||\n\t\t\t previousTrace.finalCount !==\n\t\t\t\t\t(currentTrace?.resultCounts.final ?? 0) ||\n\t\t\t previousTrace.vectorCount !==\n\t\t\t\t\t(currentTrace?.resultCounts.vector ?? 0) ||\n\t\t\t previousTrace.lexicalCount !==\n\t\t\t\t\t(currentTrace?.resultCounts.lexical ?? 0) ||\n\t\t\t previousTrace.candidateTopK !==\n\t\t\t\t\t(currentTrace?.candidateTopK ?? 0) ||\n\t\t\t previousTrace.lexicalTopK !== (currentTrace?.lexicalTopK ?? 0) ||\n\t\t\t previousTrace.topContextLabel !== topContextLabel ||\n\t\t\t previousTrace.topLocatorLabel !== topLocatorLabel ||\n\t\t\t previousTrace.sourceAwareChunkReasonLabel !==\n\t\t\t\t\tsourceAwareChunkReasonLabel ||\n\t\t\t previousTrace.sourceAwareUnitScopeLabel !==\n\t\t\t\t\tsourceAwareUnitScopeLabel ||\n\t\t\t previousTrace.leadSpeakerCue !== leadSpeakerCue ||\n\t\t\t previousTrace.leadPresentationCue !== leadPresentationCue ||\n\t\t\t previousTrace.leadSpreadsheetCue !== leadSpreadsheetCue ||\n\t\t\t previousTrace.leadSpeakerAttributionCue !==\n\t\t\t\t\tleadSpeakerAttributionCue ||\n\t\t\t previousTrace.leadChannelCue !== leadChannelCue ||\n\t\t\t previousTrace.leadChannelAttributionCue !==\n\t\t\t\t\tleadChannelAttributionCue ||\n\t\t\t previousTrace.leadContinuityCue !== leadContinuityCue ||\n\t\t\t previousTrace.sqliteQueryMode !== sqliteQueryMode ||\n\t\t\t previousTrace.sqliteQueryPushdownMode !==\n\t\t\t\t\tsqliteQueryPushdownMode ||\n\t\t\t previousTrace.sqliteQueryPushdownApplied !==\n\t\t\t\t\tsqliteQueryPushdownApplied ||\n\t\t\t previousTrace.sqliteQueryPushdownClauseCount !==\n\t\t\t\t\tsqliteQueryPushdownClauseCount ||\n\t\t\t previousTrace.sqliteQueryTotalFilterClauseCount !==\n\t\t\t\t\tsqliteQueryTotalFilterClauseCount ||\n\t\t\t previousTrace.sqliteQueryJsRemainderClauseCount !==\n\t\t\t\t\tsqliteQueryJsRemainderClauseCount ||\n\t\t\t previousTrace.sqliteQueryMultiplierUsed !==\n\t\t\t\t\tsqliteQueryMultiplierUsed ||\n\t\t\t previousTrace.sqliteQueryCandidateLimitUsed !==\n\t\t\t\t\tsqliteQueryCandidateLimitUsed ||\n\t\t\t previousTrace.sqliteQueryMaxBackfillsUsed !==\n\t\t\t\t\tsqliteQueryMaxBackfillsUsed ||\n\t\t\t previousTrace.sqliteQueryMinResultsUsed !==\n\t\t\t\t\tsqliteQueryMinResultsUsed ||\n\t\t\t previousTrace.sqliteQueryFillPolicyUsed !==\n\t\t\t\t\tsqliteQueryFillPolicyUsed ||\n\t\t\t previousTrace.sqliteQueryPushdownCoverageRatio !==\n\t\t\t\t\tsqliteQueryPushdownCoverageRatio ||\n\t\t\t previousTrace.sqliteQueryJsRemainderRatio !==\n\t\t\t\t\tsqliteQueryJsRemainderRatio ||\n\t\t\t previousTrace.sqliteQueryFilteredCandidates !==\n\t\t\t\t\tsqliteQueryFilteredCandidates ||\n\t\t\t previousTrace.sqliteQueryInitialSearchK !==\n\t\t\t\t\tsqliteQueryInitialSearchK ||\n\t\t\t previousTrace.sqliteQueryFinalSearchK !==\n\t\t\t\t\tsqliteQueryFinalSearchK ||\n\t\t\t previousTrace.sqliteQuerySearchExpansionRatio !==\n\t\t\t\t\tsqliteQuerySearchExpansionRatio ||\n\t\t\t previousTrace.sqliteQueryBackfillCount !==\n\t\t\t\t\tsqliteQueryBackfillCount ||\n\t\t\t previousTrace.sqliteQueryBackfillLimitReached !==\n\t\t\t\t\tsqliteQueryBackfillLimitReached ||\n\t\t\t previousTrace.sqliteQueryMinResultsSatisfied !==\n\t\t\t\t\tsqliteQueryMinResultsSatisfied ||\n\t\t\t previousTrace.sqliteQueryReturnedCount !==\n\t\t\t\t\tsqliteQueryReturnedCount ||\n\t\t\t previousTrace.sqliteQueryCandidateYieldRatio !==\n\t\t\t\t\tsqliteQueryCandidateYieldRatio ||\n\t\t\t previousTrace.sqliteQueryTopKFillRatio !==\n\t\t\t\t\tsqliteQueryTopKFillRatio ||\n\t\t\t previousTrace.sqliteQueryUnderfilledTopK !==\n\t\t\t\t\tsqliteQueryUnderfilledTopK ||\n\t\t\t previousTrace.sqliteQueryCandidateBudgetExhausted !==\n\t\t\t\t\tsqliteQueryCandidateBudgetExhausted ||\n\t\t\t previousTrace.sqliteQueryCandidateCoverage !==\n\t\t\t\t\tsqliteQueryCandidateCoverage ||\n\t\t\t previousTrace.postgresQueryMode !== postgresQueryMode ||\n\t\t\t previousTrace.postgresQueryPushdownMode !==\n\t\t\t\t\tpostgresQueryPushdownMode ||\n\t\t\t previousTrace.postgresQueryPushdownApplied !==\n\t\t\t\t\tpostgresQueryPushdownApplied ||\n\t\t\t previousTrace.postgresQueryPushdownClauseCount !==\n\t\t\t\t\tpostgresQueryPushdownClauseCount ||\n\t\t\t previousTrace.postgresQueryTotalFilterClauseCount !==\n\t\t\t\t\tpostgresQueryTotalFilterClauseCount ||\n\t\t\t previousTrace.postgresQueryJsRemainderClauseCount !==\n\t\t\t\t\tpostgresQueryJsRemainderClauseCount ||\n\t\t\t previousTrace.postgresQueryMultiplierUsed !==\n\t\t\t\t\tpostgresQueryMultiplierUsed ||\n\t\t\t previousTrace.postgresQueryCandidateLimitUsed !==\n\t\t\t\t\tpostgresQueryCandidateLimitUsed ||\n\t\t\t previousTrace.postgresQueryMaxBackfillsUsed !==\n\t\t\t\t\tpostgresQueryMaxBackfillsUsed ||\n\t\t\t previousTrace.postgresQueryMinResultsUsed !==\n\t\t\t\t\tpostgresQueryMinResultsUsed ||\n\t\t\t previousTrace.postgresQueryFillPolicyUsed !==\n\t\t\t\t\tpostgresQueryFillPolicyUsed ||\n\t\t\t previousTrace.postgresQueryPushdownCoverageRatio !==\n\t\t\t\t\tpostgresQueryPushdownCoverageRatio ||\n\t\t\t previousTrace.postgresQueryJsRemainderRatio !==\n\t\t\t\t\tpostgresQueryJsRemainderRatio ||\n\t\t\t previousTrace.postgresQueryFilteredCandidates !==\n\t\t\t\t\tpostgresQueryFilteredCandidates ||\n\t\t\t previousTrace.postgresQueryInitialSearchK !==\n\t\t\t\t\tpostgresQueryInitialSearchK ||\n\t\t\t previousTrace.postgresQueryFinalSearchK !==\n\t\t\t\t\tpostgresQueryFinalSearchK ||\n\t\t\t previousTrace.postgresQuerySearchExpansionRatio !==\n\t\t\t\t\tpostgresQuerySearchExpansionRatio ||\n\t\t\t previousTrace.postgresQueryBackfillCount !==\n\t\t\t\t\tpostgresQueryBackfillCount ||\n\t\t\t previousTrace.postgresQueryBackfillLimitReached !==\n\t\t\t\t\tpostgresQueryBackfillLimitReached ||\n\t\t\t previousTrace.postgresQueryMinResultsSatisfied !==\n\t\t\t\t\tpostgresQueryMinResultsSatisfied ||\n\t\t\t previousTrace.postgresQueryReturnedCount !==\n\t\t\t\t\tpostgresQueryReturnedCount ||\n\t\t\t previousTrace.postgresQueryCandidateYieldRatio !==\n\t\t\t\t\tpostgresQueryCandidateYieldRatio ||\n\t\t\t previousTrace.postgresQueryTopKFillRatio !==\n\t\t\t\t\tpostgresQueryTopKFillRatio ||\n\t\t\t previousTrace.postgresQueryUnderfilledTopK !==\n\t\t\t\t\tpostgresQueryUnderfilledTopK ||\n\t\t\t previousTrace.postgresQueryCandidateBudgetExhausted !==\n\t\t\t\t\tpostgresQueryCandidateBudgetExhausted ||\n\t\t\t previousTrace.postgresQueryCandidateCoverage !==\n\t\t\t\t\tpostgresQueryCandidateCoverage ||\n\t\t\t !areStageCountsEqual(previousStageCounts, stageCounts)\n\t\t\t? 'changed'\n\t\t\t: 'unchanged';\n\n\treturn {\n\t\tcandidateTopK: currentTrace?.candidateTopK ?? 0,\n\t\tcaseId: caseResult.caseId,\n\t\tcorpusKey: caseResult.corpusKey,\n\t\tinputFilter: filter,\n\t\tfinalCount: currentTrace?.resultCounts.final ?? 0,\n\t\tlabel: caseResult.label,\n\t\tlexicalCount: currentTrace?.resultCounts.lexical ?? 0,\n\t\tlexicalTopK: currentTrace?.lexicalTopK ?? 0,\n\t\tinputRetrieval: retrieval,\n\t\tpreviousCandidateTopK: previousTrace?.candidateTopK,\n\t\tpreviousFinalCount: previousTrace?.finalCount,\n\t\tpreviousLexicalCount: previousTrace?.lexicalCount,\n\t\tpreviousLexicalTopK: previousTrace?.lexicalTopK,\n\t\tpreviousInputFilter: previousTrace?.inputFilter,\n\t\tpreviousInputRetrieval: previousTrace?.inputRetrieval,\n\t\tpreviousLeadChannelAttributionCue:\n\t\t\tpreviousTrace?.leadChannelAttributionCue,\n\t\tpreviousLeadChannelCue: previousTrace?.leadChannelCue,\n\t\tpreviousLeadContinuityCue: previousTrace?.leadContinuityCue,\n\t\tpreviousLeadPresentationCue: previousTrace?.leadPresentationCue,\n\t\tpreviousLeadSpreadsheetCue: previousTrace?.leadSpreadsheetCue,\n\t\tpreviousLeadSpeakerAttributionCue:\n\t\t\tpreviousTrace?.leadSpeakerAttributionCue,\n\t\tpreviousLeadSpeakerCue: previousTrace?.leadSpeakerCue,\n\t\tpreviousSqliteQueryBackfillCount:\n\t\t\tpreviousTrace?.sqliteQueryBackfillCount,\n\t\tpreviousSqliteQueryBackfillLimitReached:\n\t\t\tpreviousTrace?.sqliteQueryBackfillLimitReached,\n\t\tpreviousSqliteQueryMinResultsSatisfied:\n\t\t\tpreviousTrace?.sqliteQueryMinResultsSatisfied,\n\t\tpreviousSqliteQueryCandidateBudgetExhausted:\n\t\t\tpreviousTrace?.sqliteQueryCandidateBudgetExhausted,\n\t\tpreviousSqliteQueryCandidateCoverage:\n\t\t\tpreviousTrace?.sqliteQueryCandidateCoverage,\n\t\tpreviousSqliteQueryFilteredCandidates:\n\t\t\tpreviousTrace?.sqliteQueryFilteredCandidates,\n\t\tpreviousSqliteQueryFinalSearchK: previousTrace?.sqliteQueryFinalSearchK,\n\t\tpreviousSqliteQueryInitialSearchK:\n\t\t\tpreviousTrace?.sqliteQueryInitialSearchK,\n\t\tpreviousSqliteQuerySearchExpansionRatio:\n\t\t\tpreviousTrace?.sqliteQuerySearchExpansionRatio,\n\t\tpreviousSqliteQueryMode: previousTrace?.sqliteQueryMode,\n\t\tpreviousSqliteQueryPushdownMode: previousTrace?.sqliteQueryPushdownMode,\n\t\tpreviousSqliteQueryPushdownApplied:\n\t\t\tpreviousTrace?.sqliteQueryPushdownApplied,\n\t\tpreviousSqliteQueryPushdownClauseCount:\n\t\t\tpreviousTrace?.sqliteQueryPushdownClauseCount,\n\t\tpreviousSqliteQueryTotalFilterClauseCount:\n\t\t\tpreviousTrace?.sqliteQueryTotalFilterClauseCount,\n\t\tpreviousSqliteQueryJsRemainderClauseCount:\n\t\t\tpreviousTrace?.sqliteQueryJsRemainderClauseCount,\n\t\tpreviousSqliteQueryMultiplierUsed:\n\t\t\tpreviousTrace?.sqliteQueryMultiplierUsed,\n\t\tpreviousSqliteQueryCandidateLimitUsed:\n\t\t\tpreviousTrace?.sqliteQueryCandidateLimitUsed,\n\t\tpreviousSqliteQueryMaxBackfillsUsed:\n\t\t\tpreviousTrace?.sqliteQueryMaxBackfillsUsed,\n\t\tpreviousSqliteQueryMinResultsUsed:\n\t\t\tpreviousTrace?.sqliteQueryMinResultsUsed,\n\t\tpreviousSqliteQueryFillPolicyUsed:\n\t\t\tpreviousTrace?.sqliteQueryFillPolicyUsed,\n\t\tpreviousSqliteQueryPushdownCoverageRatio:\n\t\t\tpreviousTrace?.sqliteQueryPushdownCoverageRatio,\n\t\tpreviousSqliteQueryJsRemainderRatio:\n\t\t\tpreviousTrace?.sqliteQueryJsRemainderRatio,\n\t\tpreviousSqliteQueryReturnedCount:\n\t\t\tpreviousTrace?.sqliteQueryReturnedCount,\n\t\tpreviousSqliteQueryCandidateYieldRatio:\n\t\t\tpreviousTrace?.sqliteQueryCandidateYieldRatio,\n\t\tpreviousSqliteQueryTopKFillRatio:\n\t\t\tpreviousTrace?.sqliteQueryTopKFillRatio,\n\t\tpreviousSqliteQueryUnderfilledTopK:\n\t\t\tpreviousTrace?.sqliteQueryUnderfilledTopK,\n\t\tpreviousPostgresQueryBackfillCount:\n\t\t\tpreviousTrace?.postgresQueryBackfillCount,\n\t\tpreviousPostgresQueryBackfillLimitReached:\n\t\t\tpreviousTrace?.postgresQueryBackfillLimitReached,\n\t\tpreviousPostgresQueryMinResultsSatisfied:\n\t\t\tpreviousTrace?.postgresQueryMinResultsSatisfied,\n\t\tpreviousPostgresQueryCandidateBudgetExhausted:\n\t\t\tpreviousTrace?.postgresQueryCandidateBudgetExhausted,\n\t\tpreviousPostgresQueryCandidateCoverage:\n\t\t\tpreviousTrace?.postgresQueryCandidateCoverage,\n\t\tpreviousPostgresQueryFilteredCandidates:\n\t\t\tpreviousTrace?.postgresQueryFilteredCandidates,\n\t\tpreviousPostgresQueryFinalSearchK:\n\t\t\tpreviousTrace?.postgresQueryFinalSearchK,\n\t\tpreviousPostgresQueryInitialSearchK:\n\t\t\tpreviousTrace?.postgresQueryInitialSearchK,\n\t\tpreviousPostgresQuerySearchExpansionRatio:\n\t\t\tpreviousTrace?.postgresQuerySearchExpansionRatio,\n\t\tpreviousPostgresQueryMode: previousTrace?.postgresQueryMode,\n\t\tpreviousPostgresQueryPushdownMode:\n\t\t\tpreviousTrace?.postgresQueryPushdownMode,\n\t\tpreviousPostgresQueryPushdownApplied:\n\t\t\tpreviousTrace?.postgresQueryPushdownApplied,\n\t\tpreviousPostgresQueryPushdownClauseCount:\n\t\t\tpreviousTrace?.postgresQueryPushdownClauseCount,\n\t\tpreviousPostgresQueryTotalFilterClauseCount:\n\t\t\tpreviousTrace?.postgresQueryTotalFilterClauseCount,\n\t\tpreviousPostgresQueryJsRemainderClauseCount:\n\t\t\tpreviousTrace?.postgresQueryJsRemainderClauseCount,\n\t\tpreviousPostgresQueryMultiplierUsed:\n\t\t\tpreviousTrace?.postgresQueryMultiplierUsed,\n\t\tpreviousPostgresQueryCandidateLimitUsed:\n\t\t\tpreviousTrace?.postgresQueryCandidateLimitUsed,\n\t\tpreviousPostgresQueryMaxBackfillsUsed:\n\t\t\tpreviousTrace?.postgresQueryMaxBackfillsUsed,\n\t\tpreviousPostgresQueryMinResultsUsed:\n\t\t\tpreviousTrace?.postgresQueryMinResultsUsed,\n\t\tpreviousPostgresQueryFillPolicyUsed:\n\t\t\tpreviousTrace?.postgresQueryFillPolicyUsed,\n\t\tpreviousPostgresQueryPushdownCoverageRatio:\n\t\t\tpreviousTrace?.postgresQueryPushdownCoverageRatio,\n\t\tpreviousPostgresQueryJsRemainderRatio:\n\t\t\tpreviousTrace?.postgresQueryJsRemainderRatio,\n\t\tpreviousPostgresQueryReturnedCount:\n\t\t\tpreviousTrace?.postgresQueryReturnedCount,\n\t\tpreviousPostgresQueryCandidateYieldRatio:\n\t\t\tpreviousTrace?.postgresQueryCandidateYieldRatio,\n\t\tpreviousPostgresQueryTopKFillRatio:\n\t\t\tpreviousTrace?.postgresQueryTopKFillRatio,\n\t\tpreviousPostgresQueryUnderfilledTopK:\n\t\t\tpreviousTrace?.postgresQueryUnderfilledTopK,\n\t\tpreviousSourceBalanceStrategy: previousTrace?.sourceBalanceStrategy,\n\t\tpreviousSourceAwareChunkReasonLabel:\n\t\t\tpreviousTrace?.sourceAwareChunkReasonLabel,\n\t\tpreviousStageCounts,\n\t\tpreviousTopContextLabel: previousTrace?.topContextLabel,\n\t\tpreviousTopLocatorLabel: previousTrace?.topLocatorLabel,\n\t\tpreviousTraceMode: previousTrace?.traceMode,\n\t\tpreviousTransformedQuery: previousTrace?.transformedQuery,\n\t\tpreviousSourceAwareUnitScopeLabel:\n\t\t\tpreviousTrace?.sourceAwareUnitScopeLabel,\n\t\tpreviousVariantQueries: previousTrace?.variantQueries ?? [],\n\t\tpreviousVectorCount: previousTrace?.vectorCount,\n\t\tquery: caseResult.query,\n\t\tleadChannelAttributionCue,\n\t\tleadChannelCue,\n\t\tleadContinuityCue,\n\t\tleadPresentationCue,\n\t\tleadSpreadsheetCue,\n\t\tleadSpeakerAttributionCue,\n\t\tleadSpeakerCue,\n\t\tsqliteQueryBackfillCount,\n\t\tsqliteQueryBackfillLimitReached,\n\t\tsqliteQueryMinResultsSatisfied,\n\t\tsqliteQueryCandidateBudgetExhausted,\n\t\tsqliteQueryCandidateCoverage,\n\t\tsqliteQueryFilteredCandidates,\n\t\tsqliteQueryFinalSearchK,\n\t\tsqliteQueryInitialSearchK,\n\t\tsqliteQuerySearchExpansionRatio,\n\t\tsqliteQueryMode,\n\t\tsqliteQueryPushdownMode,\n\t\tsqliteQueryPushdownApplied,\n\t\tsqliteQueryPushdownClauseCount,\n\t\tsqliteQueryTotalFilterClauseCount,\n\t\tsqliteQueryJsRemainderClauseCount,\n\t\tsqliteQueryMultiplierUsed,\n\t\tsqliteQueryCandidateLimitUsed,\n\t\tsqliteQueryMaxBackfillsUsed,\n\t\tsqliteQueryMinResultsUsed,\n\t\tsqliteQueryFillPolicyUsed,\n\t\tsqliteQueryPushdownCoverageRatio,\n\t\tsqliteQueryJsRemainderRatio,\n\t\tsqliteQueryReturnedCount,\n\t\tsqliteQueryCandidateYieldRatio,\n\t\tsqliteQueryTopKFillRatio,\n\t\tsqliteQueryUnderfilledTopK,\n\t\tpostgresQueryBackfillCount,\n\t\tpostgresQueryBackfillLimitReached,\n\t\tpostgresQueryMinResultsSatisfied,\n\t\tpostgresQueryCandidateBudgetExhausted,\n\t\tpostgresQueryCandidateCoverage,\n\t\tpostgresQueryFilteredCandidates,\n\t\tpostgresQueryFinalSearchK,\n\t\tpostgresQueryInitialSearchK,\n\t\tpostgresQuerySearchExpansionRatio,\n\t\tpostgresQueryMode,\n\t\tpostgresQueryPushdownMode,\n\t\tpostgresQueryPushdownApplied,\n\t\tpostgresQueryPushdownClauseCount,\n\t\tpostgresQueryTotalFilterClauseCount,\n\t\tpostgresQueryJsRemainderClauseCount,\n\t\tpostgresQueryMultiplierUsed,\n\t\tpostgresQueryCandidateLimitUsed,\n\t\tpostgresQueryMaxBackfillsUsed,\n\t\tpostgresQueryMinResultsUsed,\n\t\tpostgresQueryFillPolicyUsed,\n\t\tpostgresQueryPushdownCoverageRatio,\n\t\tpostgresQueryJsRemainderRatio,\n\t\tpostgresQueryReturnedCount,\n\t\tpostgresQueryCandidateYieldRatio,\n\t\tpostgresQueryTopKFillRatio,\n\t\tpostgresQueryUnderfilledTopK,\n\t\tsourceAwareChunkReasonLabel,\n\t\tsourceAwareUnitScopeLabel,\n\t\tstageCounts,\n\t\tstatus: caseResult.status,\n\t\tsourceBalanceStrategy: currentTrace?.sourceBalanceStrategy,\n\t\ttopContextLabel,\n\t\ttopLocatorLabel,\n\t\ttraceChange,\n\t\ttraceMode: currentTrace?.mode,\n\t\ttransformedQuery: currentTrace?.transformedQuery || undefined,\n\t\tvariantQueries: currentTrace?.variantQueries ?? [],\n\t\tvectorCount: currentTrace?.resultCounts.vector ?? 0\n\t};\n};\n\nconst buildEvaluationCaseTraceSnapshotsFromEvaluated = (\n\tevaluated: Array<{\n\t\tcaseResult: RAGEvaluationCaseResult;\n\t\ttrace?: RAGRetrievalTrace;\n\t\tfilter?: Record<string, unknown>;\n\t\tretrieval?: RAGCollectionSearchParams['retrieval'];\n\t\ttopResult?: RAGQueryResult;\n\t}>\n): RAGEvaluationCaseTraceSnapshot[] =>\n\tevaluated.map(({ caseResult, filter, retrieval, trace, topResult }) =>\n\t\tbuildEvaluationCaseTraceSnapshot({\n\t\t\tcaseResult,\n\t\t\tfilter,\n\t\t\tretrieval,\n\t\t\tcurrentTrace: trace,\n\t\t\ttopResult\n\t\t})\n\t);\n\nconst buildEvaluationCaseTraceSnapshots = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent?: RAGEvaluationSuiteRun;\n\tprevious?: RAGEvaluationSuiteRun;\n}): RAGEvaluationCaseTraceSnapshot[] => {\n\tif (!current) {\n\t\treturn [];\n\t}\n\n\tconst currentTraces = new Map(\n\t\t(current.caseTraceSnapshots ?? []).map((entry) => [entry.caseId, entry])\n\t);\n\tconst previousTraces = new Map(\n\t\t(previous?.caseTraceSnapshots ?? []).map((entry) => [\n\t\t\tentry.caseId,\n\t\t\tentry\n\t\t])\n\t);\n\n\treturn current.response.cases.map((caseResult) =>\n\t\tbuildEvaluationCaseTraceSnapshot({\n\t\t\tcaseResult,\n\t\t\tcurrentSnapshot: currentTraces.get(caseResult.caseId),\n\t\t\tcurrentTrace: (() => {\n\t\t\t\tconst currentSnapshot = currentTraces.get(caseResult.caseId);\n\t\t\t\tif (!currentSnapshot) {\n\t\t\t\t\treturn undefined;\n\t\t\t\t}\n\n\t\t\t\treturn {\n\t\t\t\t\tcandidateTopK: currentSnapshot.candidateTopK,\n\t\t\t\t\tlexicalTopK: currentSnapshot.lexicalTopK,\n\t\t\t\t\tmode: currentSnapshot.traceMode ?? 'vector',\n\t\t\t\t\tquery: caseResult.query,\n\t\t\t\t\tresultCounts: {\n\t\t\t\t\t\tfinal: currentSnapshot.finalCount,\n\t\t\t\t\t\tfused: currentSnapshot.finalCount,\n\t\t\t\t\t\tlexical: currentSnapshot.lexicalCount,\n\t\t\t\t\t\treranked: currentSnapshot.finalCount,\n\t\t\t\t\t\tvector: currentSnapshot.vectorCount\n\t\t\t\t\t},\n\t\t\t\t\trunLexical: currentSnapshot.lexicalCount > 0,\n\t\t\t\t\trunVector: currentSnapshot.vectorCount > 0,\n\t\t\t\t\tsourceBalanceStrategy:\n\t\t\t\t\t\tcurrentSnapshot.sourceBalanceStrategy ?? 'cap',\n\t\t\t\t\tsteps: [],\n\t\t\t\t\ttopK: caseResult.topK,\n\t\t\t\t\ttransformedQuery:\n\t\t\t\t\t\tcurrentSnapshot.transformedQuery ?? caseResult.query,\n\t\t\t\t\tvariantQueries: currentSnapshot.variantQueries\n\t\t\t\t} satisfies RAGRetrievalTrace;\n\t\t\t})(),\n\t\t\tpreviousTrace: previousTraces.get(caseResult.caseId)\n\t\t})\n\t);\n};\n\nconst getStatusRank = (status: RAGEvaluationCaseResult['status']) =>\n\tstatus === 'pass' ? 2 : status === 'partial' ? 1 : 0;\n\nconst buildCaseTraceLeadLabel = (\n\ttrace?: Pick<\n\t\tRAGEvaluationCaseTraceSnapshot,\n\t\t| 'topLocatorLabel'\n\t\t| 'topContextLabel'\n\t\t| 'sourceAwareUnitScopeLabel'\n\t\t| 'sourceAwareChunkReasonLabel'\n\t>\n) =>\n\ttrace?.topLocatorLabel ??\n\ttrace?.topContextLabel ??\n\ttrace?.sourceAwareUnitScopeLabel ??\n\ttrace?.sourceAwareChunkReasonLabel;\n\nexport const buildRAGEvaluationRunDiff = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGEvaluationSuiteRun;\n\tprevious?: RAGEvaluationSuiteRun;\n}): RAGEvaluationRunDiff => {\n\tconst previousCases = new Map(\n\t\t(previous?.response.cases ?? []).map((entry) => [entry.caseId, entry])\n\t);\n\tconst diffs = current.response.cases.map((entry) =>\n\t\tbuildCaseDiff(entry, previousCases.get(entry.caseId))\n\t);\n\tconst regressedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) <\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\tconst improvedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) >\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\tconst unchangedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) ===\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\tconst previousCaseTraces = new Map(\n\t\t(previous?.caseTraceSnapshots ?? []).map((entry) => [\n\t\t\tentry.caseId,\n\t\t\tentry\n\t\t])\n\t);\n\tconst traceLeadChanges = (current.caseTraceSnapshots ?? [])\n\t\t.map((entry) => {\n\t\t\tconst previousEntry = previousCaseTraces.get(entry.caseId);\n\t\t\tconst currentLead = buildCaseTraceLeadLabel(entry);\n\t\t\tconst previousLead = buildCaseTraceLeadLabel(previousEntry);\n\t\t\tif (!currentLead || currentLead === previousLead) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tcaseId: entry.caseId,\n\t\t\t\tcurrentLead,\n\t\t\t\tlabel: entry.label,\n\t\t\t\tpreviousLead\n\t\t\t};\n\t\t})\n\t\t.filter(\n\t\t\t(entry): entry is NonNullable<typeof entry> =>\n\t\t\t\ttypeof entry !== 'undefined'\n\t\t);\n\n\treturn {\n\t\tcurrentRunId: current.id,\n\t\timprovedCases,\n\t\tpreviousRunId: previous?.id,\n\t\tregressedCases,\n\t\tsuiteId: current.suiteId,\n\t\ttraceLeadChanges:\n\t\t\ttraceLeadChanges.length > 0 ? traceLeadChanges : undefined,\n\t\tsummaryDelta: {\n\t\t\taverageF1:\n\t\t\t\tcurrent.response.summary.averageF1 -\n\t\t\t\t(previous?.response.summary.averageF1 ?? 0),\n\t\t\taverageLatencyMs:\n\t\t\t\tcurrent.response.summary.averageLatencyMs -\n\t\t\t\t(previous?.response.summary.averageLatencyMs ?? 0),\n\t\t\tfailedCases:\n\t\t\t\tcurrent.response.summary.failedCases -\n\t\t\t\t(previous?.response.summary.failedCases ?? 0),\n\t\t\tpassedCases:\n\t\t\t\tcurrent.response.summary.passedCases -\n\t\t\t\t(previous?.response.summary.passedCases ?? 0),\n\t\t\tpassingRate:\n\t\t\t\tcurrent.response.passingRate -\n\t\t\t\t(previous?.response.passingRate ?? 0),\n\t\t\tpartialCases:\n\t\t\t\tcurrent.response.summary.partialCases -\n\t\t\t\t(previous?.response.summary.partialCases ?? 0)\n\t\t},\n\t\ttraceSummaryDelta:\n\t\t\tcurrent.traceSummary || previous?.traceSummary\n\t\t\t\t? {\n\t\t\t\t\t\taverageCandidateTopK:\n\t\t\t\t\t\t\t(current.traceSummary?.averageCandidateTopK ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.averageCandidateTopK ?? 0),\n\t\t\t\t\t\taverageFinalCount:\n\t\t\t\t\t\t\t(current.traceSummary?.averageFinalCount ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.averageFinalCount ?? 0),\n\t\t\t\t\t\taverageLexicalCount:\n\t\t\t\t\t\t\t(current.traceSummary?.averageLexicalCount ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.averageLexicalCount ?? 0),\n\t\t\t\t\t\taverageLexicalTopK:\n\t\t\t\t\t\t\t(current.traceSummary?.averageLexicalTopK ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.averageLexicalTopK ?? 0),\n\t\t\t\t\t\taverageVectorCount:\n\t\t\t\t\t\t\t(current.traceSummary?.averageVectorCount ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.averageVectorCount ?? 0),\n\t\t\t\t\t\tbalancedCases:\n\t\t\t\t\t\t\t(current.traceSummary?.balancedCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.balancedCases ?? 0),\n\t\t\t\t\t\tofficeEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t\t(current.traceSummary\n\t\t\t\t\t\t\t\t?.officeEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary\n\t\t\t\t\t\t\t\t?.officeEvidenceReconcileCases ?? 0),\n\t\t\t\t\t\tofficeParagraphEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t\t(current.traceSummary\n\t\t\t\t\t\t\t\t?.officeParagraphEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary\n\t\t\t\t\t\t\t\t?.officeParagraphEvidenceReconcileCases ?? 0),\n\t\t\t\t\t\tofficeListEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t\t(current.traceSummary\n\t\t\t\t\t\t\t\t?.officeListEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary\n\t\t\t\t\t\t\t\t?.officeListEvidenceReconcileCases ?? 0),\n\t\t\t\t\t\tofficeTableEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t\t(current.traceSummary\n\t\t\t\t\t\t\t\t?.officeTableEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary\n\t\t\t\t\t\t\t\t?.officeTableEvidenceReconcileCases ?? 0),\n\t\t\t\t\t\tpdfEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t\t(current.traceSummary?.pdfEvidenceReconcileCases ??\n\t\t\t\t\t\t\t\t0) -\n\t\t\t\t\t\t\t(previous?.traceSummary\n\t\t\t\t\t\t\t\t?.pdfEvidenceReconcileCases ?? 0),\n\t\t\t\t\t\tlexicalCases:\n\t\t\t\t\t\t\t(current.traceSummary?.lexicalCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.lexicalCases ?? 0),\n\t\t\t\t\t\tmodesChanged:\n\t\t\t\t\t\t\t(current.traceSummary?.modes ?? []).join('|') !==\n\t\t\t\t\t\t\t(previous?.traceSummary?.modes ?? []).join('|'),\n\t\t\t\t\t\troundRobinCases:\n\t\t\t\t\t\t\t(current.traceSummary?.roundRobinCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.roundRobinCases ?? 0),\n\t\t\t\t\t\tstageCounts: diffTraceStageCounts({\n\t\t\t\t\t\t\tcurrent: current.traceSummary?.stageCounts ?? {},\n\t\t\t\t\t\t\tprevious: previous?.traceSummary?.stageCounts ?? {}\n\t\t\t\t\t\t}),\n\t\t\t\t\t\tsourceBalanceStrategiesChanged:\n\t\t\t\t\t\t\t(\n\t\t\t\t\t\t\t\tcurrent.traceSummary?.sourceBalanceStrategies ??\n\t\t\t\t\t\t\t\t[]\n\t\t\t\t\t\t\t).join('|') !==\n\t\t\t\t\t\t\t(\n\t\t\t\t\t\t\t\tprevious?.traceSummary\n\t\t\t\t\t\t\t\t\t?.sourceBalanceStrategies ?? []\n\t\t\t\t\t\t\t).join('|'),\n\t\t\t\t\t\ttransformedCases:\n\t\t\t\t\t\t\t(current.traceSummary?.transformedCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.transformedCases ?? 0),\n\t\t\t\t\t\tvariantCases:\n\t\t\t\t\t\t\t(current.traceSummary?.variantCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.variantCases ?? 0),\n\t\t\t\t\t\tvectorCases:\n\t\t\t\t\t\t\t(current.traceSummary?.vectorCases ?? 0) -\n\t\t\t\t\t\t\t(previous?.traceSummary?.vectorCases ?? 0)\n\t\t\t\t\t}\n\t\t\t\t: undefined,\n\t\tunchangedCases\n\t};\n};\n\nexport const buildRAGAnswerGroundingEvaluationRunDiff = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGAnswerGroundingEvaluationRun;\n\tprevious?: RAGAnswerGroundingEvaluationRun;\n}): RAGAnswerGroundingEvaluationRunDiff => {\n\tconst previousCases = new Map(\n\t\t(previous?.response.cases ?? []).map((entry) => [entry.caseId, entry])\n\t);\n\tconst diffs = current.response.cases.map((entry) =>\n\t\tbuildGroundingCaseDiff(entry, previousCases.get(entry.caseId))\n\t);\n\tconst regressedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) <\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\tconst improvedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) >\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\tconst unchangedCases = diffs.filter(\n\t\t(entry) =>\n\t\t\tgetStatusRank(entry.currentStatus) ===\n\t\t\tgetStatusRank(entry.previousStatus ?? 'fail')\n\t);\n\n\treturn {\n\t\tcurrentRunId: current.id,\n\t\timprovedCases,\n\t\tpreviousRunId: previous?.id,\n\t\tregressedCases,\n\t\tsuiteId: current.suiteId,\n\t\tsummaryDelta: {\n\t\t\taverageCitationF1:\n\t\t\t\tcurrent.response.summary.averageCitationF1 -\n\t\t\t\t(previous?.response.summary.averageCitationF1 ?? 0),\n\t\t\taverageResolvedCitationRate:\n\t\t\t\tcurrent.response.summary.averageResolvedCitationRate -\n\t\t\t\t(previous?.response.summary.averageResolvedCitationRate ?? 0),\n\t\t\tfailedCases:\n\t\t\t\tcurrent.response.summary.failedCases -\n\t\t\t\t(previous?.response.summary.failedCases ?? 0),\n\t\t\tpassedCases:\n\t\t\t\tcurrent.response.summary.passedCases -\n\t\t\t\t(previous?.response.summary.passedCases ?? 0),\n\t\t\tpassingRate:\n\t\t\t\tcurrent.response.passingRate -\n\t\t\t\t(previous?.response.passingRate ?? 0),\n\t\t\tpartialCases:\n\t\t\t\tcurrent.response.summary.partialCases -\n\t\t\t\t(previous?.response.summary.partialCases ?? 0)\n\t\t},\n\t\tunchangedCases\n\t};\n};\n\nexport const createRAGFileEvaluationHistoryStore = (\n\tpath: string\n): RAGEvaluationHistoryStore => ({\n\tlistRuns: async ({ limit, suiteId } = {}) => {\n\t\tlet parsed: RAGEvaluationSuiteRun[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) => !suiteId || entry.suiteId === suiteId\n\t\t);\n\t\tconst sorted = normalizeHistoryRuns(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveRun: async (run) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeHistoryRuns([\n\t\t\trun,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGEvaluationSuiteRun) => entry.id !== run.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t},\n\tpruneRuns: async (input) => {\n\t\tlet existing: RAGEvaluationSuiteRun[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\texisting = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\tinput,\n\t\t\truns: existing,\n\t\t\tsort: normalizeHistoryRuns\n\t\t});\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(pruned.next, null, '\\t') + '\\n',\n\t\t\t'utf8'\n\t\t);\n\t\treturn {\n\t\t\tkeptCount: pruned.keptCount,\n\t\t\tremovedCount: pruned.removedCount\n\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t}\n});\n\nconst normalizeEvaluationSuiteSnapshots = (\n\tsnapshots: RAGEvaluationSuiteSnapshot[]\n) =>\n\t[...snapshots].sort((left, right) => {\n\t\tif (right.createdAt !== left.createdAt) {\n\t\t\treturn right.createdAt - left.createdAt;\n\t\t}\n\t\tif (right.version !== left.version) {\n\t\t\treturn right.version - left.version;\n\t\t}\n\t\treturn right.id.localeCompare(left.id);\n\t});\n\nexport const createRAGFileEvaluationSuiteSnapshotHistoryStore = (\n\tpath: string\n): RAGEvaluationSuiteSnapshotHistoryStore => ({\n\tlistSnapshots: async ({ limit, suiteId } = {}) => {\n\t\tlet parsed: RAGEvaluationSuiteSnapshot[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) => !suiteId || entry.suiteId === suiteId\n\t\t);\n\t\tconst sorted = normalizeEvaluationSuiteSnapshots(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveSnapshot: async (snapshot) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeEvaluationSuiteSnapshots([\n\t\t\tsnapshot,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGEvaluationSuiteSnapshot) => entry.id !== snapshot.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t},\n\tpruneSnapshots: async (input) => {\n\t\tlet existing: RAGEvaluationSuiteSnapshot[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\texisting = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\tinput,\n\t\t\truns: existing,\n\t\t\tsort: normalizeEvaluationSuiteSnapshots\n\t\t});\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(pruned.next, null, '\\t') + '\\n',\n\t\t\t'utf8'\n\t\t);\n\t\treturn {\n\t\t\tkeptCount: pruned.keptCount,\n\t\t\tremovedCount: pruned.removedCount\n\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t}\n});\n\nexport const createRAGFileRetrievalComparisonHistoryStore = (\n\tpath: string\n): RAGRetrievalComparisonHistoryStore => ({\n\tlistRuns: async ({\n\t\tgroupKey,\n\t\tlabel,\n\t\tlimit,\n\t\tsuiteId,\n\t\ttag,\n\t\twinnerId\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalComparisonRun[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst normalizedLabel = normalizeLabelFilter(label);\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!suiteId || entry.suiteId === suiteId) &&\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!tag || (entry.tags ?? []).includes(tag)) &&\n\t\t\t\t(!normalizedLabel ||\n\t\t\t\t\tentry.label.toLowerCase().includes(normalizedLabel) ||\n\t\t\t\t\tentry.suiteLabel.toLowerCase().includes(normalizedLabel)) &&\n\t\t\t\tmatchesWinner(entry, winnerId)\n\t\t);\n\t\tconst sorted = normalizeRetrievalComparisonRuns(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveRun: async (run) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalComparisonRuns([\n\t\t\trun,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGRetrievalComparisonRun) => entry.id !== run.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalBaselineStore = (\n\tpath: string\n): RAGRetrievalBaselineStore => {\n\tconst listBaselines: RAGRetrievalBaselineStore['listBaselines'] = async ({\n\t\tgroupKey,\n\t\tlimit,\n\t\ttag,\n\t\tstatus\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalBaselineRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!tag || (entry.tags ?? []).includes(tag)) &&\n\t\t\t\t(!status || entry.status === status)\n\t\t);\n\t\tconst sorted = normalizeRetrievalBaselineRecords(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t};\n\n\treturn {\n\t\tgetBaseline: async (groupKey) => {\n\t\t\tconst baselines = await Promise.resolve(\n\t\t\t\tlistBaselines({ groupKey, limit: 1 })\n\t\t\t);\n\t\t\treturn baselines[0] ?? null;\n\t\t},\n\t\tlistBaselines,\n\t\tsaveBaseline: async (record) => {\n\t\t\tconst existing = await (async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t\t} catch (error) {\n\t\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\t\tthrow error;\n\t\t\t\t\t}\n\t\t\t\t\treturn [];\n\t\t\t\t}\n\t\t\t})();\n\t\t\tconst currentVersion =\n\t\t\t\texisting\n\t\t\t\t\t.filter(\n\t\t\t\t\t\t(entry: RAGRetrievalBaselineRecord) =>\n\t\t\t\t\t\t\tentry.groupKey === record.groupKey\n\t\t\t\t\t)\n\t\t\t\t\t.reduce(\n\t\t\t\t\t\t(max, entry) => Math.max(max, entry.version ?? 0),\n\t\t\t\t\t\t0\n\t\t\t\t\t) ?? 0;\n\t\t\tconst next = normalizeRetrievalBaselineRecords([\n\t\t\t\t{\n\t\t\t\t\t...record,\n\t\t\t\t\tstatus: 'active',\n\t\t\t\t\tversion:\n\t\t\t\t\t\ttypeof record.version === 'number'\n\t\t\t\t\t\t\t? record.version\n\t\t\t\t\t\t\t: currentVersion + 1\n\t\t\t\t},\n\t\t\t\t...existing.map((entry: RAGRetrievalBaselineRecord) =>\n\t\t\t\t\tentry.groupKey === record.groupKey &&\n\t\t\t\t\t(entry.rolloutLabel ?? undefined) ===\n\t\t\t\t\t\t(record.rolloutLabel ?? undefined)\n\t\t\t\t\t\t? { ...entry, status: 'superseded' as const }\n\t\t\t\t\t\t: entry\n\t\t\t\t)\n\t\t\t]);\n\t\t\tawait mkdir(dirname(path), { recursive: true });\n\t\t\tawait writeFile(\n\t\t\t\tpath,\n\t\t\t\tJSON.stringify(next, null, '\\t') + '\\n',\n\t\t\t\t'utf8'\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGFileRetrievalReleaseDecisionStore = (\n\tpath: string\n): RAGRetrievalReleaseDecisionStore => ({\n\tlistDecisions: async ({ groupKey, kind, limit } = {}) => {\n\t\tlet parsed: RAGRetrievalReleaseDecisionRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!kind || entry.kind === kind)\n\t\t);\n\t\tconst sorted = normalizeRetrievalReleaseDecisionRecords(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveDecision: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalReleaseDecisionRecords([\n\t\t\trecord,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGRetrievalReleaseDecisionRecord) =>\n\t\t\t\t\tentry.id !== record.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalLaneHandoffDecisionStore = (\n\tpath: string\n): RAGRetrievalLaneHandoffDecisionStore => ({\n\tlistDecisions: async ({\n\t\tgroupKey,\n\t\tkind,\n\t\tlimit,\n\t\tsourceRolloutLabel,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalLaneHandoffDecisionRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!kind || entry.kind === kind) &&\n\t\t\t\t(!sourceRolloutLabel ||\n\t\t\t\t\tentry.sourceRolloutLabel === sourceRolloutLabel) &&\n\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t);\n\t\tconst sorted = normalizeRetrievalLaneHandoffDecisionRecords(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveDecision: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalLaneHandoffDecisionRecords([\n\t\t\trecord,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGRetrievalLaneHandoffDecisionRecord) =>\n\t\t\t\t\tentry.id !== record.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalReleaseIncidentStore = (\n\tpath: string\n): RAGRetrievalReleaseIncidentStore => ({\n\tlistIncidents: async ({\n\t\tcorpusGroupKey,\n\t\tgroupKey,\n\t\tlimit,\n\t\tseverity,\n\t\tstatus,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalReleaseIncidentRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!corpusGroupKey || entry.corpusGroupKey === corpusGroupKey) &&\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel) &&\n\t\t\t\t(!severity || entry.severity === severity) &&\n\t\t\t\t(!status || entry.status === status)\n\t\t);\n\t\tconst sorted = normalizeRetrievalReleaseIncidentRecords(filtered);\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveIncident: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalReleaseIncidentRecords([\n\t\t\trecord,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGRetrievalReleaseIncidentRecord) =>\n\t\t\t\t\tentry.id !== record.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalLaneHandoffIncidentStore = (\n\tpath: string\n): RAGRetrievalLaneHandoffIncidentStore => ({\n\tlistIncidents: async ({\n\t\tgroupKey,\n\t\tlimit,\n\t\tseverity,\n\t\tstatus,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalLaneHandoffIncidentRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) =>\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel) &&\n\t\t\t\t(!severity || entry.severity === severity) &&\n\t\t\t\t(!status || entry.status === status)\n\t\t);\n\t\tconst sorted = normalizeRetrievalReleaseIncidentRecords(\n\t\t\tfiltered as RAGRetrievalReleaseIncidentRecord[]\n\t\t) as RAGRetrievalLaneHandoffIncidentRecord[];\n\t\treturn typeof limit === 'number' ? sorted.slice(0, limit) : sorted;\n\t},\n\tsaveIncident: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalReleaseIncidentRecords([\n\t\t\trecord as RAGRetrievalReleaseIncidentRecord,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGRetrievalLaneHandoffIncidentRecord) =>\n\t\t\t\t\tentry.id !== record.id\n\t\t\t)\n\t\t]) as RAGRetrievalLaneHandoffIncidentRecord[];\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalLaneHandoffIncidentHistoryStore = (\n\tpath: string\n): RAGRetrievalLaneHandoffIncidentHistoryStore => ({\n\tlistRecords: async ({\n\t\taction,\n\t\tgroupKey,\n\t\tincidentId,\n\t\tlimit,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalLaneHandoffIncidentHistoryRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed\n\t\t\t.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!action || entry.action === action) &&\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!incidentId || entry.incidentId === incidentId) &&\n\t\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t\t)\n\t\t\t.sort((left, right) => right.recordedAt - left.recordedAt);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = [record, ...existing].sort(\n\t\t\t(\n\t\t\t\tleft: RAGRetrievalLaneHandoffIncidentHistoryRecord,\n\t\t\t\tright: RAGRetrievalLaneHandoffIncidentHistoryRecord\n\t\t\t) => right.recordedAt - left.recordedAt\n\t\t);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalIncidentRemediationDecisionStore = (\n\tpath: string\n): RAGRetrievalIncidentRemediationDecisionStore => ({\n\tlistRecords: async ({\n\t\tgroupKey,\n\t\tincidentId,\n\t\tlimit,\n\t\tremediationKind,\n\t\tstatus,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalIncidentRemediationDecisionRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered = normalizeRetrievalIncidentRemediationDecisionRecords(\n\t\t\tparsed\n\t\t).filter(\n\t\t\t(entry) =>\n\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t(!incidentId || entry.incidentId === incidentId) &&\n\t\t\t\t(!remediationKind ||\n\t\t\t\t\tentry.remediationKind === remediationKind) &&\n\t\t\t\t(!status || entry.status === status) &&\n\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeRetrievalIncidentRemediationDecisionRecords([\n\t\t\trecord,\n\t\t\t...existing\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalIncidentRemediationExecutionHistoryStore = (\n\tpath: string\n): RAGRetrievalIncidentRemediationExecutionHistoryStore => ({\n\tlistRecords: async ({\n\t\tactionKind,\n\t\tblockedByGuardrail,\n\t\tcode,\n\t\tgroupKey,\n\t\tidempotentReplay,\n\t\tincidentId,\n\t\tlimit,\n\t\ttargetRolloutLabel\n\t} = {}) => {\n\t\tlet parsed: RAGRetrievalIncidentRemediationExecutionHistoryRecord[] =\n\t\t\t[];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered =\n\t\t\tnormalizeRetrievalIncidentRemediationExecutionHistoryRecords(\n\t\t\t\tparsed\n\t\t\t).filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!incidentId || entry.incidentId === incidentId) &&\n\t\t\t\t\t(!actionKind || entry.action.kind === actionKind) &&\n\t\t\t\t\t(!code || entry.code === code) &&\n\t\t\t\t\t(typeof blockedByGuardrail !== 'boolean' ||\n\t\t\t\t\t\tentry.blockedByGuardrail === blockedByGuardrail) &&\n\t\t\t\t\t(typeof idempotentReplay !== 'boolean' ||\n\t\t\t\t\t\tentry.idempotentReplay === idempotentReplay) &&\n\t\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t\t);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next =\n\t\t\tnormalizeRetrievalIncidentRemediationExecutionHistoryRecords([\n\t\t\t\trecord,\n\t\t\t\t...existing\n\t\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalLaneHandoffAutoCompletePolicyHistoryStore = (\n\tpath: string\n): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore => ({\n\tlistRecords: async ({ groupKey, limit, targetRolloutLabel } = {}) => {\n\t\tlet parsed: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord[] =\n\t\t\t[];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered = parsed\n\t\t\t.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t\t)\n\t\t\t.sort((left, right) => right.recordedAt - left.recordedAt);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = [record, ...existing].sort(\n\t\t\t(\n\t\t\t\tleft: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord,\n\t\t\t\tright: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord\n\t\t\t) => right.recordedAt - left.recordedAt\n\t\t);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalReleaseLanePolicyHistoryStore = (\n\tpath: string\n): RAGRetrievalReleaseLanePolicyHistoryStore => ({\n\tlistRecords: async ({ groupKey, limit, rolloutLabel, scope } = {}) => {\n\t\tlet parsed: RAGRetrievalReleaseLanePolicyHistoryRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered = parsed\n\t\t\t.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!rolloutLabel || entry.rolloutLabel === rolloutLabel) &&\n\t\t\t\t\t(!scope || entry.scope === scope)\n\t\t\t)\n\t\t\t.sort((left, right) => right.recordedAt - left.recordedAt);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = [record, ...existing].sort(\n\t\t\t(\n\t\t\t\tleft: RAGRetrievalReleaseLanePolicyHistoryRecord,\n\t\t\t\tright: RAGRetrievalReleaseLanePolicyHistoryRecord\n\t\t\t) => right.recordedAt - left.recordedAt\n\t\t);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalBaselineGatePolicyHistoryStore = (\n\tpath: string\n): RAGRetrievalBaselineGatePolicyHistoryStore => ({\n\tlistRecords: async ({ groupKey, limit, rolloutLabel, scope } = {}) => {\n\t\tlet parsed: RAGRetrievalBaselineGatePolicyHistoryRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered = parsed\n\t\t\t.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!rolloutLabel || entry.rolloutLabel === rolloutLabel) &&\n\t\t\t\t\t(!scope || entry.scope === scope)\n\t\t\t)\n\t\t\t.sort((left, right) => right.recordedAt - left.recordedAt);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = [record, ...existing].sort(\n\t\t\t(\n\t\t\t\tleft: RAGRetrievalBaselineGatePolicyHistoryRecord,\n\t\t\t\tright: RAGRetrievalBaselineGatePolicyHistoryRecord\n\t\t\t) => right.recordedAt - left.recordedAt\n\t\t);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileRetrievalReleaseLaneEscalationPolicyHistoryStore = (\n\tpath: string\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryStore => ({\n\tlistRecords: async ({ groupKey, limit, targetRolloutLabel } = {}) => {\n\t\tlet parsed: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst filtered = parsed\n\t\t\t.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\t(!groupKey || entry.groupKey === groupKey) &&\n\t\t\t\t\t(!targetRolloutLabel ||\n\t\t\t\t\t\tentry.targetRolloutLabel === targetRolloutLabel)\n\t\t\t)\n\t\t\t.sort((left, right) => right.recordedAt - left.recordedAt);\n\t\treturn typeof limit === 'number' ? filtered.slice(0, limit) : filtered;\n\t},\n\tsaveRecord: async (record) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = [record, ...existing].sort(\n\t\t\t(\n\t\t\t\tleft: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord,\n\t\t\t\tright: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord\n\t\t\t) => right.recordedAt - left.recordedAt\n\t\t);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport const createRAGFileSearchTraceStore = (\n\tpath: string\n): RAGSearchTraceStore => ({\n\tasync listTraces(input) {\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\ttraces?: RAGSearchTraceRecord[];\n\t\t\t};\n\t\t\tconst traces = Array.isArray(data.traces) ? data.traces : [];\n\t\t\tconst filtered = traces.filter((trace) => {\n\t\t\t\tif (input?.query && trace.query !== input.query) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (input?.groupKey && trace.groupKey !== input.groupKey) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (input?.tag && !(trace.tags ?? []).includes(input.tag)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t});\n\n\t\t\treturn normalizeTraceSummaryRuns(filtered).slice(\n\t\t\t\t0,\n\t\t\t\tinput?.limit ?? DEFAULT_HISTORY_LIMIT\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\terror &&\n\t\t\t\ttypeof error === 'object' &&\n\t\t\t\t'code' in error &&\n\t\t\t\terror.code === 'ENOENT'\n\t\t\t) {\n\t\t\t\treturn [];\n\t\t\t}\n\n\t\t\tthrow error;\n\t\t}\n\t},\n\tasync saveTrace(trace) {\n\t\tlet traces: RAGSearchTraceRecord[] = [];\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\ttraces?: RAGSearchTraceRecord[];\n\t\t\t};\n\t\t\ttraces = Array.isArray(data.traces) ? data.traces : [];\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\t!error ||\n\t\t\t\ttypeof error !== 'object' ||\n\t\t\t\t!('code' in error) ||\n\t\t\t\terror.code !== 'ENOENT'\n\t\t\t) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst nextTraces = normalizeTraceSummaryRuns([\n\t\t\ttrace,\n\t\t\t...traces.filter((entry) => entry.id !== trace.id)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(\n\t\t\t\t{\n\t\t\t\t\ttraces: nextTraces\n\t\t\t\t},\n\t\t\t\tnull,\n\t\t\t\t2\n\t\t\t)\n\t\t);\n\t},\n\tasync pruneTraces(input) {\n\t\tlet traces: RAGSearchTraceRecord[] = [];\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\ttraces?: RAGSearchTraceRecord[];\n\t\t\t};\n\t\t\ttraces = Array.isArray(data.traces) ? data.traces : [];\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\t!error ||\n\t\t\t\ttypeof error !== 'object' ||\n\t\t\t\t!('code' in error) ||\n\t\t\t\terror.code !== 'ENOENT'\n\t\t\t) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst pruned = applyRAGSearchTracePrunePolicy({\n\t\t\tinput,\n\t\t\ttraces\n\t\t});\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(\n\t\t\t\t{\n\t\t\t\t\ttraces: pruned.next\n\t\t\t\t},\n\t\t\t\tnull,\n\t\t\t\t2\n\t\t\t)\n\t\t);\n\n\t\treturn {\n\t\t\tkeptCount: pruned.keptCount,\n\t\t\tremovedCount: pruned.removedCount\n\t\t};\n\t}\n});\n\nexport const createRAGFileSearchTracePruneHistoryStore = (\n\tpath: string\n): RAGSearchTracePruneHistoryStore => ({\n\tlistRuns: async (input) => {\n\t\tlet parsed: RAGSearchTracePruneRun[] = [];\n\t\ttry {\n\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\tconst value = JSON.parse(content);\n\t\t\tparsed = Array.isArray(value) ? value : [];\n\t\t} catch (error) {\n\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst filtered = parsed.filter(\n\t\t\t(entry) => !input?.trigger || entry.trigger === input.trigger\n\t\t);\n\t\tconst sorted = normalizeSearchTracePruneRuns(filtered);\n\t\treturn typeof input?.limit === 'number'\n\t\t\t? sorted.slice(0, input.limit)\n\t\t\t: sorted;\n\t},\n\tsaveRun: async (run) => {\n\t\tconst existing = await (async () => {\n\t\t\ttry {\n\t\t\t\tconst content = await readFile(path, 'utf8');\n\t\t\t\tconst value = JSON.parse(content);\n\t\t\t\treturn Array.isArray(value) ? value : [];\n\t\t\t} catch (error) {\n\t\t\t\tif ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\treturn [];\n\t\t\t}\n\t\t})();\n\t\tconst next = normalizeSearchTracePruneRuns([\n\t\t\trun,\n\t\t\t...existing.filter(\n\t\t\t\t(entry: RAGSearchTracePruneRun) => entry.id !== run.id\n\t\t\t)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(path, JSON.stringify(next, null, '\\t') + '\\n', 'utf8');\n\t}\n});\n\nexport type SQLiteRAGSearchTraceStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGEvaluationHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGEvaluationSuiteSnapshotHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGAnswerGroundingEvaluationHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGSearchTracePruneHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalComparisonHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseDecisionStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalBaselineStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseIncidentStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffDecisionStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffIncidentStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffIncidentHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalIncidentRemediationDecisionStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalIncidentRemediationExecutionHistoryStoreOptions =\n\t{\n\t\tdb?: Database;\n\t\tpath?: string;\n\t\ttableName?: string;\n\t};\n\nexport type SQLiteRAGRetrievalLaneHandoffAutoCompletePolicyHistoryStoreOptions =\n\t{\n\t\tdb?: Database;\n\t\tpath?: string;\n\t\ttableName?: string;\n\t};\n\nexport type SQLiteRAGRetrievalReleaseLanePolicyHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalBaselineGatePolicyHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseLaneEscalationPolicyHistoryStoreOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttableName?: string;\n};\n\nexport type SQLiteRAGGovernanceStoreBundleOptions = {\n\tdb?: Database;\n\tpath?: string;\n\ttablePrefix?: string;\n};\n\nexport const createRAGSQLiteEvaluationHistoryStore = (\n\toptions: SQLiteRAGEvaluationHistoryStoreOptions\n): RAGEvaluationHistoryStore => {\n\tconst tableName = options.tableName ?? 'rag_evaluation_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`\n\t);\n\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tfinished_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRuns(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\t\t\tif (input.suiteId) {\n\t\t\t\twhere.push('suite_id = ?');\n\t\t\t\tparams.push(input.suiteId);\n\t\t\t}\n\t\t\tconst sql =\n\t\t\t\t`SELECT record_json FROM ${tableName}` +\n\t\t\t\t`${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY finished_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params) as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst runs = normalizeHistoryRuns(\n\t\t\t\trows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(row.record_json) as RAGEvaluationSuiteRun\n\t\t\t\t)\n\t\t\t);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? runs.slice(0, input.limit)\n\t\t\t\t: runs;\n\t\t},\n\t\tsaveRun(run) {\n\t\t\tinsert.run(\n\t\t\t\trun.id,\n\t\t\t\trun.suiteId,\n\t\t\t\trun.finishedAt,\n\t\t\t\tJSON.stringify(run)\n\t\t\t);\n\t\t},\n\t\tpruneRuns(input) {\n\t\t\tconst allRows = db\n\t\t\t\t.prepare(`SELECT record_json FROM ${tableName}`)\n\t\t\t\t.all() as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\t\tinput,\n\t\t\t\truns: allRows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(row.record_json) as RAGEvaluationSuiteRun\n\t\t\t\t),\n\t\t\t\tsort: normalizeHistoryRuns\n\t\t\t});\n\t\t\tfor (const run of pruned.removed) {\n\t\t\t\tdb.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(run.id);\n\t\t\t}\n\t\t\treturn {\n\t\t\t\tkeptCount: pruned.keptCount,\n\t\t\t\tremovedCount: pruned.removedCount\n\t\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteEvaluationSuiteSnapshotHistoryStore = (\n\toptions: SQLiteRAGEvaluationSuiteSnapshotHistoryStoreOptions\n): RAGEvaluationSuiteSnapshotHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_evaluation_suite_snapshot_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tversion INTEGER NOT NULL,\n\t\t\tcreated_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_suite_created_at_idx ON ${tableName} (suite_id, created_at DESC, version DESC)`\n\t);\n\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tversion,\n\t\t\tcreated_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tversion = excluded.version,\n\t\t\tcreated_at = excluded.created_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistSnapshots(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\t\t\tif (input.suiteId) {\n\t\t\t\twhere.push('suite_id = ?');\n\t\t\t\tparams.push(input.suiteId);\n\t\t\t}\n\t\t\tconst sql =\n\t\t\t\t`SELECT record_json FROM ${tableName}` +\n\t\t\t\t`${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY created_at DESC, version DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params) as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst snapshots = normalizeEvaluationSuiteSnapshots(\n\t\t\t\trows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(\n\t\t\t\t\t\t\trow.record_json\n\t\t\t\t\t\t) as RAGEvaluationSuiteSnapshot\n\t\t\t\t)\n\t\t\t);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? snapshots.slice(0, input.limit)\n\t\t\t\t: snapshots;\n\t\t},\n\t\tsaveSnapshot(snapshot) {\n\t\t\tinsert.run(\n\t\t\t\tsnapshot.id,\n\t\t\t\tsnapshot.suiteId,\n\t\t\t\tsnapshot.version,\n\t\t\t\tsnapshot.createdAt,\n\t\t\t\tJSON.stringify(snapshot)\n\t\t\t);\n\t\t},\n\t\tpruneSnapshots(input) {\n\t\t\tconst allRows = db\n\t\t\t\t.prepare(`SELECT record_json FROM ${tableName}`)\n\t\t\t\t.all() as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\t\tinput,\n\t\t\t\truns: allRows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(\n\t\t\t\t\t\t\trow.record_json\n\t\t\t\t\t\t) as RAGEvaluationSuiteSnapshot\n\t\t\t\t),\n\t\t\t\tsort: normalizeEvaluationSuiteSnapshots\n\t\t\t});\n\t\t\tfor (const snapshot of pruned.removed) {\n\t\t\t\tdb.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(\n\t\t\t\t\tsnapshot.id\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn {\n\t\t\t\tkeptCount: pruned.keptCount,\n\t\t\t\tremovedCount: pruned.removedCount\n\t\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteAnswerGroundingEvaluationHistoryStore = (\n\toptions: SQLiteRAGAnswerGroundingEvaluationHistoryStoreOptions\n): RAGAnswerGroundingEvaluationHistoryStore => {\n\tconst tableName = options.tableName ?? 'rag_answer_grounding_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`\n\t);\n\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tfinished_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRuns(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\t\t\tif (input.suiteId) {\n\t\t\t\twhere.push('suite_id = ?');\n\t\t\t\tparams.push(input.suiteId);\n\t\t\t}\n\t\t\tconst sql =\n\t\t\t\t`SELECT record_json FROM ${tableName}` +\n\t\t\t\t`${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY finished_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params) as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst runs = normalizeGroundingHistoryRuns(\n\t\t\t\trows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(\n\t\t\t\t\t\t\trow.record_json\n\t\t\t\t\t\t) as RAGAnswerGroundingEvaluationRun\n\t\t\t\t)\n\t\t\t);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? runs.slice(0, input.limit)\n\t\t\t\t: runs;\n\t\t},\n\t\tsaveRun(run) {\n\t\t\tinsert.run(\n\t\t\t\trun.id,\n\t\t\t\trun.suiteId,\n\t\t\t\trun.finishedAt,\n\t\t\t\tJSON.stringify(run)\n\t\t\t);\n\t\t},\n\t\tpruneRuns(input) {\n\t\t\tconst allRows = db\n\t\t\t\t.prepare(`SELECT record_json FROM ${tableName}`)\n\t\t\t\t.all() as Array<{\n\t\t\t\trecord_json: string;\n\t\t\t}>;\n\t\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\t\tinput,\n\t\t\t\truns: allRows.map(\n\t\t\t\t\t(row) =>\n\t\t\t\t\t\tJSON.parse(\n\t\t\t\t\t\t\trow.record_json\n\t\t\t\t\t\t) as RAGAnswerGroundingEvaluationRun\n\t\t\t\t),\n\t\t\t\tsort: normalizeGroundingHistoryRuns\n\t\t\t});\n\t\t\tfor (const run of pruned.removed) {\n\t\t\t\tdb.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(run.id);\n\t\t\t}\n\t\t\treturn {\n\t\t\t\tkeptCount: pruned.keptCount,\n\t\t\t\tremovedCount: pruned.removedCount\n\t\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t\t}\n\t};\n};\n\ntype SQLiteSearchTraceRow = {\n\tid: string;\n\tquery: string;\n\tlabel: string;\n\tgroup_key: string | null;\n\ttags_json: string | null;\n\tstarted_at: number;\n\tfinished_at: number;\n\telapsed_ms: number;\n\ttrace_json: string;\n\tsummary_json: string;\n\tresults_json: string;\n\tmetadata_json: string | null;\n};\n\ntype SQLiteSearchTracePruneHistoryRow = {\n\tid: string;\n\ttrigger: string;\n\tstarted_at: number;\n\tfinished_at: number;\n\telapsed_ms: number;\n\trun_json: string;\n};\n\nconst isSQLiteSearchTraceRow = (\n\tvalue: unknown\n): value is SQLiteSearchTraceRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\ttypeof value.query === 'string' &&\n\ttypeof value.label === 'string' &&\n\t(typeof value.group_key === 'string' || value.group_key === null) &&\n\t(typeof value.tags_json === 'string' || value.tags_json === null) &&\n\ttypeof value.started_at === 'number' &&\n\ttypeof value.finished_at === 'number' &&\n\ttypeof value.elapsed_ms === 'number' &&\n\ttypeof value.trace_json === 'string' &&\n\ttypeof value.summary_json === 'string' &&\n\ttypeof value.results_json === 'string' &&\n\t(typeof value.metadata_json === 'string' || value.metadata_json === null);\n\nconst isSQLiteSearchTracePruneHistoryRow = (\n\tvalue: unknown\n): value is SQLiteSearchTracePruneHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\ttypeof value.trigger === 'string' &&\n\ttypeof value.started_at === 'number' &&\n\ttypeof value.finished_at === 'number' &&\n\ttypeof value.elapsed_ms === 'number' &&\n\ttypeof value.run_json === 'string';\n\ntype SQLiteRetrievalComparisonHistoryRow = {\n\tid: string;\n\tsuite_id: string;\n\tsuite_label: string;\n\tlabel: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string | null;\n\ttags_json: string | null;\n\tstarted_at: number;\n\tfinished_at: number;\n\telapsed_ms: number;\n\tcomparison_json: string;\n\tdecision_summary_json: string | null;\n};\n\nconst isSQLiteRetrievalComparisonHistoryRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalComparisonHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\ttypeof value.suite_id === 'string' &&\n\ttypeof value.suite_label === 'string' &&\n\ttypeof value.label === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\t(typeof value.group_key === 'string' || value.group_key === null) &&\n\t(typeof value.tags_json === 'string' || value.tags_json === null) &&\n\ttypeof value.started_at === 'number' &&\n\ttypeof value.finished_at === 'number' &&\n\ttypeof value.elapsed_ms === 'number' &&\n\ttypeof value.comparison_json === 'string' &&\n\t(typeof value.decision_summary_json === 'string' ||\n\t\tvalue.decision_summary_json === null);\n\ntype SQLiteRetrievalReleaseDecisionRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\tkind: string;\n\tdecided_at: number;\n\trecord_json: string;\n};\n\nconst isSQLiteRetrievalReleaseDecisionRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalReleaseDecisionRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\ttypeof value.kind === 'string' &&\n\ttypeof value.decided_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\ntype SQLiteRetrievalBaselineRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\trollout_label: string | null;\n\tpromoted_at: number;\n\tstatus: string;\n\tversion: number;\n\ttags_json: string | null;\n\trecord_json: string;\n};\n\nconst isSQLiteRetrievalBaselineRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalBaselineRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\t(typeof value.rollout_label === 'string' || value.rollout_label === null) &&\n\ttypeof value.promoted_at === 'number' &&\n\ttypeof value.status === 'string' &&\n\ttypeof value.version === 'number' &&\n\t(typeof value.tags_json === 'string' || value.tags_json === null) &&\n\ttypeof value.record_json === 'string';\n\ntype SQLiteRetrievalReleaseIncidentRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\ttarget_rollout_label: string | null;\n\tseverity: string;\n\tstatus: string;\n\ttriggered_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffDecisionRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\tsource_rollout_label: string;\n\ttarget_rollout_label: string;\n\tkind: string;\n\tdecided_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffIncidentRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\ttarget_rollout_label: string | null;\n\tsource_rollout_label: string | null;\n\tseverity: string;\n\tstatus: string;\n\ttriggered_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffIncidentHistoryRow = {\n\tid: string;\n\tincident_id: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\ttarget_rollout_label: string | null;\n\taction: string;\n\trecorded_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteRetrievalIncidentRemediationDecisionRow = {\n\tid: string;\n\tincident_id: string;\n\tgroup_key: string;\n\ttarget_rollout_label: string | null;\n\tremediation_kind: string;\n\tstatus: string;\n\tdecided_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteRetrievalIncidentRemediationExecutionHistoryRow = {\n\tid: string;\n\tincident_id: string | null;\n\tgroup_key: string | null;\n\ttarget_rollout_label: string | null;\n\taction_kind: string;\n\tcode: string;\n\tblocked_by_guardrail: number;\n\tidempotent_replay: number;\n\texecuted_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteLaneHandoffAutoCompletePolicyHistoryRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\ttarget_rollout_label: string;\n\trecorded_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteReleaseLanePolicyHistoryRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string | null;\n\trollout_label: string;\n\tscope: string;\n\trecorded_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteBaselineGatePolicyHistoryRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string | null;\n\trollout_label: string;\n\tscope: string;\n\trecorded_at: number;\n\trecord_json: string;\n};\n\ntype SQLiteReleaseLaneEscalationPolicyHistoryRow = {\n\tid: string;\n\tcorpus_group_key: string | null;\n\tgroup_key: string;\n\ttarget_rollout_label: string;\n\trecorded_at: number;\n\trecord_json: string;\n};\n\nconst isSQLiteRetrievalReleaseIncidentRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalReleaseIncidentRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\t(typeof value.target_rollout_label === 'string' ||\n\t\tvalue.target_rollout_label === null) &&\n\ttypeof value.severity === 'string' &&\n\ttypeof value.status === 'string' &&\n\ttypeof value.triggered_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteRetrievalLaneHandoffDecisionRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalLaneHandoffDecisionRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\ttypeof value.source_rollout_label === 'string' &&\n\ttypeof value.target_rollout_label === 'string' &&\n\ttypeof value.kind === 'string' &&\n\ttypeof value.decided_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteRetrievalLaneHandoffIncidentRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalLaneHandoffIncidentRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\t(typeof value.target_rollout_label === 'string' ||\n\t\tvalue.target_rollout_label === null) &&\n\t(typeof value.source_rollout_label === 'string' ||\n\t\tvalue.source_rollout_label === null) &&\n\ttypeof value.severity === 'string' &&\n\ttypeof value.status === 'string' &&\n\ttypeof value.triggered_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteRetrievalLaneHandoffIncidentHistoryRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalLaneHandoffIncidentHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\ttypeof value.incident_id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\t(typeof value.target_rollout_label === 'string' ||\n\t\tvalue.target_rollout_label === null) &&\n\ttypeof value.action === 'string' &&\n\ttypeof value.recorded_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteRetrievalIncidentRemediationDecisionRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalIncidentRemediationDecisionRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\ttypeof value.incident_id === 'string' &&\n\ttypeof value.group_key === 'string' &&\n\t(typeof value.target_rollout_label === 'string' ||\n\t\tvalue.target_rollout_label === null) &&\n\ttypeof value.remediation_kind === 'string' &&\n\ttypeof value.status === 'string' &&\n\ttypeof value.decided_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteRetrievalIncidentRemediationExecutionHistoryRow = (\n\tvalue: unknown\n): value is SQLiteRetrievalIncidentRemediationExecutionHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.incident_id === 'string' || value.incident_id === null) &&\n\t(typeof value.group_key === 'string' || value.group_key === null) &&\n\t(typeof value.target_rollout_label === 'string' ||\n\t\tvalue.target_rollout_label === null) &&\n\ttypeof value.action_kind === 'string' &&\n\ttypeof value.code === 'string' &&\n\ttypeof value.blocked_by_guardrail === 'number' &&\n\ttypeof value.idempotent_replay === 'number' &&\n\ttypeof value.executed_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteLaneHandoffAutoCompletePolicyHistoryRow = (\n\tvalue: unknown\n): value is SQLiteLaneHandoffAutoCompletePolicyHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\ttypeof value.target_rollout_label === 'string' &&\n\ttypeof value.recorded_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteReleaseLanePolicyHistoryRow = (\n\tvalue: unknown\n): value is SQLiteReleaseLanePolicyHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\t(typeof value.group_key === 'string' || value.group_key === null) &&\n\ttypeof value.rollout_label === 'string' &&\n\ttypeof value.scope === 'string' &&\n\ttypeof value.recorded_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteBaselineGatePolicyHistoryRow = (\n\tvalue: unknown\n): value is SQLiteBaselineGatePolicyHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\t(typeof value.group_key === 'string' || value.group_key === null) &&\n\ttypeof value.rollout_label === 'string' &&\n\ttypeof value.scope === 'string' &&\n\ttypeof value.recorded_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst isSQLiteReleaseLaneEscalationPolicyHistoryRow = (\n\tvalue: unknown\n): value is SQLiteReleaseLaneEscalationPolicyHistoryRow =>\n\tisObjectRecord(value) &&\n\ttypeof value.id === 'string' &&\n\t(typeof value.corpus_group_key === 'string' ||\n\t\tvalue.corpus_group_key === null) &&\n\ttypeof value.group_key === 'string' &&\n\ttypeof value.target_rollout_label === 'string' &&\n\ttypeof value.recorded_at === 'number' &&\n\ttypeof value.record_json === 'string';\n\nconst assertSupportedIdentifier = (name: string) => {\n\tif (!/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(name)) {\n\t\tthrow new Error(\n\t\t\t`Invalid SQLite search trace table name \"${name}\". Only alphanumeric and underscore names are allowed.`\n\t\t);\n\t}\n};\n\nconst ensureSQLiteColumns = (\n\tdb: Database,\n\ttableName: string,\n\tcolumns: Array<{ name: string; definition: string }>\n) => {\n\tconst pragma = db.prepare(`PRAGMA table_info(${tableName})`).all();\n\tconst existing = new Set(\n\t\tArray.isArray(pragma)\n\t\t\t? pragma\n\t\t\t\t\t.filter(\n\t\t\t\t\t\t(row): row is { name?: unknown } =>\n\t\t\t\t\t\t\tisObjectRecord(row) && 'name' in row\n\t\t\t\t\t)\n\t\t\t\t\t.map((row) =>\n\t\t\t\t\t\ttypeof row.name === 'string' ? row.name : undefined\n\t\t\t\t\t)\n\t\t\t\t\t.filter((name): name is string => typeof name === 'string')\n\t\t\t: []\n\t);\n\n\tfor (const column of columns) {\n\t\tif (existing.has(column.name)) {\n\t\t\tcontinue;\n\t\t}\n\t\tdb.exec(\n\t\t\t`ALTER TABLE ${tableName} ADD COLUMN ${column.name} ${column.definition}`\n\t\t);\n\t}\n};\n\nconst getMissingSQLiteColumns = (\n\tdb: Database,\n\ttableName: string,\n\tcolumns: Array<{ name: string; definition: string }>\n): RAGSQLiteStoreMigrationIssue[] => {\n\tconst pragma = db.prepare(`PRAGMA table_info(${tableName})`).all();\n\tconst existing = new Set(\n\t\tArray.isArray(pragma)\n\t\t\t? pragma\n\t\t\t\t\t.filter(\n\t\t\t\t\t\t(row): row is { name?: unknown } =>\n\t\t\t\t\t\t\tisObjectRecord(row) && 'name' in row\n\t\t\t\t\t)\n\t\t\t\t\t.map((row) =>\n\t\t\t\t\t\ttypeof row.name === 'string' ? row.name : undefined\n\t\t\t\t\t)\n\t\t\t\t\t.filter((name): name is string => typeof name === 'string')\n\t\t\t: []\n\t);\n\n\treturn columns\n\t\t.filter((column) => !existing.has(column.name))\n\t\t.map((column) => ({\n\t\t\tcolumnName: column.name,\n\t\t\tdefinition: column.definition,\n\t\t\ttableName\n\t\t}));\n};\n\ntype SQLiteStoreMigrationDescriptor = {\n\ttableName: string;\n\tcolumns: Array<{ name: string; definition: string }>;\n};\n\nconst getDefaultSQLiteStoreMigrationDescriptors =\n\t(): SQLiteStoreMigrationDescriptor[] => [\n\t\t{\n\t\t\ttableName: DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME,\n\t\t\tcolumns: [{ definition: 'TEXT', name: 'corpus_group_key' }]\n\t\t},\n\t\t{\n\t\t\ttableName: DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME,\n\t\t\tcolumns: [{ definition: 'TEXT', name: 'corpus_group_key' }]\n\t\t},\n\t\t{\n\t\t\ttableName: DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME,\n\t\t\tcolumns: [\n\t\t\t\t{ definition: 'TEXT', name: 'group_key' },\n\t\t\t\t{ definition: 'TEXT', name: 'corpus_group_key' }\n\t\t\t]\n\t\t}\n\t];\n\nconst summarizeSQLiteStoreMigrationIssues = (\n\tissues: RAGSQLiteStoreMigrationIssue[]\n) =>\n\tissues.length > 0\n\t\t? `${issues.length} SQLite schema migration issue${issues.length === 1 ? '' : 's'} detected`\n\t\t: undefined;\n\nexport type SQLiteRAGStoreMigrationOptions = {\n\tdb?: Database;\n\tpath?: string;\n\tdescriptors?: SQLiteStoreMigrationDescriptor[];\n};\n\nexport const inspectRAGSQLiteStoreMigrations = (\n\toptions: SQLiteRAGStoreMigrationOptions = {}\n): RAGSQLiteStoreMigrationInspection => {\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\tconst descriptors =\n\t\toptions.descriptors ?? getDefaultSQLiteStoreMigrationDescriptors();\n\tconst issues = descriptors.flatMap((descriptor) =>\n\t\tgetMissingSQLiteColumns(db, descriptor.tableName, descriptor.columns)\n\t);\n\n\treturn {\n\t\tissues,\n\t\tsummary: summarizeSQLiteStoreMigrationIssues(issues)\n\t};\n};\n\nexport const applyRAGSQLiteStoreMigrations = (\n\toptions: SQLiteRAGStoreMigrationOptions = {}\n): RAGSQLiteStoreMigrationResult => {\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\tconst descriptors =\n\t\toptions.descriptors ?? getDefaultSQLiteStoreMigrationDescriptors();\n\tconst inspection = inspectRAGSQLiteStoreMigrations({\n\t\tdb,\n\t\tdescriptors\n\t});\n\n\tfor (const descriptor of descriptors) {\n\t\tensureSQLiteColumns(db, descriptor.tableName, descriptor.columns);\n\t}\n\n\treturn {\n\t\t...inspection,\n\t\tapplied: inspection.issues\n\t};\n};\n\nconst mapSQLiteSearchTraceRow = (\n\trow: SQLiteSearchTraceRow\n): RAGSearchTraceRecord => ({\n\telapsedMs: row.elapsed_ms,\n\tfinishedAt: row.finished_at,\n\tgroupKey: row.group_key ?? undefined,\n\tid: row.id,\n\tlabel: row.label,\n\tmetadata: parseJSONRecord(row.metadata_json),\n\tquery: row.query,\n\tresults: parseJSONArray(row.results_json, []),\n\tstartedAt: row.started_at,\n\tsummary: JSON.parse(row.summary_json),\n\ttags: normalizeStringArray(parseJSONArray(row.tags_json, [])),\n\ttrace: JSON.parse(row.trace_json)\n});\n\nconst mapSQLiteSearchTracePruneHistoryRow = (\n\trow: SQLiteSearchTracePruneHistoryRow\n): RAGSearchTracePruneRun => JSON.parse(row.run_json);\n\nconst mapSQLiteRetrievalComparisonHistoryRow = (\n\trow: SQLiteRetrievalComparisonHistoryRow\n): RAGRetrievalComparisonRun => ({\n\tcomparison: JSON.parse(row.comparison_json),\n\tcorpusGroupKey: row.corpus_group_key ?? undefined,\n\tdecisionSummary: row.decision_summary_json\n\t\t? JSON.parse(row.decision_summary_json)\n\t\t: undefined,\n\telapsedMs: row.elapsed_ms,\n\tfinishedAt: row.finished_at,\n\tgroupKey: row.group_key ?? undefined,\n\tid: row.id,\n\tlabel: row.label,\n\tstartedAt: row.started_at,\n\tsuiteId: row.suite_id,\n\tsuiteLabel: row.suite_label,\n\ttags: normalizeStringArray(parseJSONArray(row.tags_json, []))\n});\n\nconst mapSQLiteRetrievalReleaseDecisionRow = (\n\trow: SQLiteRetrievalReleaseDecisionRow\n): RAGRetrievalReleaseDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalBaselineRow = (\n\trow: SQLiteRetrievalBaselineRow\n): RAGRetrievalBaselineRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalReleaseIncidentRow = (\n\trow: SQLiteRetrievalReleaseIncidentRow\n): RAGRetrievalReleaseIncidentRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffDecisionRow = (\n\trow: SQLiteRetrievalLaneHandoffDecisionRow\n): RAGRetrievalLaneHandoffDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffIncidentRow = (\n\trow: SQLiteRetrievalLaneHandoffIncidentRow\n): RAGRetrievalLaneHandoffIncidentRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffIncidentHistoryRow = (\n\trow: SQLiteRetrievalLaneHandoffIncidentHistoryRow\n): RAGRetrievalLaneHandoffIncidentHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalIncidentRemediationDecisionRow = (\n\trow: SQLiteRetrievalIncidentRemediationDecisionRow\n): RAGRetrievalIncidentRemediationDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalIncidentRemediationExecutionHistoryRow = (\n\trow: SQLiteRetrievalIncidentRemediationExecutionHistoryRow\n): RAGRetrievalIncidentRemediationExecutionHistoryRecord =>\n\tJSON.parse(row.record_json);\n\nconst mapSQLiteLaneHandoffAutoCompletePolicyHistoryRow = (\n\trow: SQLiteLaneHandoffAutoCompletePolicyHistoryRow\n): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord =>\n\tJSON.parse(row.record_json);\n\nconst mapSQLiteReleaseLanePolicyHistoryRow = (\n\trow: SQLiteReleaseLanePolicyHistoryRow\n): RAGRetrievalReleaseLanePolicyHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteBaselineGatePolicyHistoryRow = (\n\trow: SQLiteBaselineGatePolicyHistoryRow\n): RAGRetrievalBaselineGatePolicyHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteReleaseLaneEscalationPolicyHistoryRow = (\n\trow: SQLiteReleaseLaneEscalationPolicyHistoryRow\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord =>\n\tJSON.parse(row.record_json);\n\nexport const createRAGSQLiteSearchTraceStore = (\n\toptions: SQLiteRAGSearchTraceStoreOptions\n): RAGSearchTraceStore => {\n\tconst tableName = options.tableName ?? DEFAULT_SEARCH_TRACE_TABLE_NAME;\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tquery TEXT NOT NULL,\n\t\t\tlabel TEXT NOT NULL,\n\t\t\tgroup_key TEXT,\n\t\t\ttags_json TEXT,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\ttrace_json TEXT NOT NULL,\n\t\t\tsummary_json TEXT NOT NULL,\n\t\t\tresults_json TEXT NOT NULL,\n\t\t\tmetadata_json TEXT\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_query_finished_at_idx ON ${tableName} (query, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_finished_at_idx ON ${tableName} (group_key, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tquery,\n\t\t\tlabel,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\ttrace_json,\n\t\t\tsummary_json,\n\t\t\tresults_json,\n\t\t\tmetadata_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tquery,\n\t\t\tlabel,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\ttrace_json,\n\t\t\tsummary_json,\n\t\t\tresults_json,\n\t\t\tmetadata_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tquery = excluded.query,\n\t\t\tlabel = excluded.label,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\ttrace_json = excluded.trace_json,\n\t\t\tsummary_json = excluded.summary_json,\n\t\t\tresults_json = excluded.results_json,\n\t\t\tmetadata_json = excluded.metadata_json\n\t`);\n\tconst remove = db.prepare(`DELETE FROM ${tableName} WHERE id = ?`);\n\n\treturn {\n\t\tlistTraces(input) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input?.query) {\n\t\t\t\twhere.push('query = ?');\n\t\t\t\tparams.push(input.query);\n\t\t\t}\n\n\t\t\tif (input?.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY finished_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst traces = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteSearchTraceRow)\n\t\t\t\t\t\t.map(mapSQLiteSearchTraceRow)\n\t\t\t\t: [];\n\t\t\tconst filtered = input?.tag\n\t\t\t\t? traces.filter((trace) =>\n\t\t\t\t\t\t(trace.tags ?? []).includes(input.tag as string)\n\t\t\t\t\t)\n\t\t\t\t: traces;\n\n\t\t\treturn normalizeTraceSummaryRuns(filtered).slice(\n\t\t\t\t0,\n\t\t\t\tinput?.limit ?? DEFAULT_HISTORY_LIMIT\n\t\t\t);\n\t\t},\n\t\tsaveTrace(trace) {\n\t\t\tinsert.run(\n\t\t\t\ttrace.id,\n\t\t\t\ttrace.query,\n\t\t\t\ttrace.label,\n\t\t\t\ttrace.groupKey ?? null,\n\t\t\t\tJSON.stringify(trace.tags ?? []),\n\t\t\t\ttrace.startedAt,\n\t\t\t\ttrace.finishedAt,\n\t\t\t\ttrace.elapsedMs,\n\t\t\t\tJSON.stringify(trace.trace),\n\t\t\t\tJSON.stringify(trace.summary),\n\t\t\t\tJSON.stringify(trace.results),\n\t\t\t\ttrace.metadata === undefined\n\t\t\t\t\t? null\n\t\t\t\t\t: JSON.stringify(trace.metadata)\n\t\t\t);\n\t\t},\n\t\tpruneTraces(input) {\n\t\t\tconst rows = db\n\t\t\t\t.prepare(`${listBase} ORDER BY finished_at DESC`)\n\t\t\t\t.all();\n\t\t\tconst traces = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteSearchTraceRow)\n\t\t\t\t\t\t.map(mapSQLiteSearchTraceRow)\n\t\t\t\t: [];\n\t\t\tconst pruned = applyRAGSearchTracePrunePolicy({\n\t\t\t\tinput,\n\t\t\t\ttraces\n\t\t\t});\n\n\t\t\tfor (const trace of pruned.removed) {\n\t\t\t\tremove.run(trace.id);\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tkeptCount: pruned.keptCount,\n\t\t\t\tremovedCount: pruned.removedCount\n\t\t\t};\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteSearchTracePruneHistoryStore = (\n\toptions: SQLiteRAGSearchTracePruneHistoryStoreOptions\n): RAGSearchTracePruneHistoryStore => {\n\tconst tableName = options.tableName ?? 'rag_search_trace_prune_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\ttrigger TEXT NOT NULL,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\trun_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_trigger_finished_at_idx ON ${tableName} (trigger, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\ttrigger,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\trun_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\ttrigger,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\trun_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\ttrigger = excluded.trigger,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\trun_json = excluded.run_json\n\t`);\n\n\treturn {\n\t\tlistRuns(input) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input?.trigger) {\n\t\t\t\twhere.push('trigger = ?');\n\t\t\t\tparams.push(input.trigger);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY finished_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst runs = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteSearchTracePruneHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteSearchTracePruneHistoryRow)\n\t\t\t\t: [];\n\t\t\tconst sorted = normalizeSearchTracePruneRuns(runs);\n\t\t\treturn typeof input?.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveRun(run) {\n\t\t\tinsert.run(\n\t\t\t\trun.id,\n\t\t\t\trun.trigger,\n\t\t\t\trun.startedAt,\n\t\t\t\trun.finishedAt,\n\t\t\t\trun.elapsedMs,\n\t\t\t\tJSON.stringify(run)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalComparisonHistoryStore = (\n\toptions: SQLiteRAGRetrievalComparisonHistoryStoreOptions\n): RAGRetrievalComparisonHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ?? DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME;\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tsuite_label TEXT NOT NULL,\n\t\t\tlabel TEXT NOT NULL,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\ttags_json TEXT,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\tcomparison_json TEXT NOT NULL,\n\t\t\tdecision_summary_json TEXT\n\t\t)\n\t`);\n\tensureSQLiteColumns(db, tableName, [\n\t\t{ definition: 'TEXT', name: 'corpus_group_key' }\n\t]);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_finished_at_idx ON ${tableName} (group_key, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_finished_at_idx ON ${tableName} (corpus_group_key, finished_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tsuite_label,\n\t\t\tlabel,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\tcomparison_json,\n\t\t\tdecision_summary_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tsuite_label,\n\t\t\tlabel,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\tcomparison_json,\n\t\t\tdecision_summary_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tsuite_label = excluded.suite_label,\n\t\t\tlabel = excluded.label,\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\tcomparison_json = excluded.comparison_json,\n\t\t\tdecision_summary_json = excluded.decision_summary_json\n\t`);\n\n\treturn {\n\t\tlistRuns(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.suiteId) {\n\t\t\t\twhere.push('suite_id = ?');\n\t\t\t\tparams.push(input.suiteId);\n\t\t\t}\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY finished_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst runs = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalComparisonHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalComparisonHistoryRow)\n\t\t\t\t: [];\n\t\t\tconst normalizedLabel = normalizeLabelFilter(input.label);\n\t\t\tconst filtered = normalizeRetrievalComparisonRuns(\n\t\t\t\truns.filter(\n\t\t\t\t\t(entry) =>\n\t\t\t\t\t\t(!input.tag ||\n\t\t\t\t\t\t\t(entry.tags ?? []).includes(input.tag)) &&\n\t\t\t\t\t\t(!normalizedLabel ||\n\t\t\t\t\t\t\tentry.label\n\t\t\t\t\t\t\t\t.toLowerCase()\n\t\t\t\t\t\t\t\t.includes(normalizedLabel) ||\n\t\t\t\t\t\t\tentry.suiteLabel\n\t\t\t\t\t\t\t\t.toLowerCase()\n\t\t\t\t\t\t\t\t.includes(normalizedLabel)) &&\n\t\t\t\t\t\tmatchesWinner(entry, input.winnerId)\n\t\t\t\t)\n\t\t\t);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? filtered.slice(0, input.limit)\n\t\t\t\t: filtered;\n\t\t},\n\t\tsaveRun(run) {\n\t\t\tinsert.run(\n\t\t\t\trun.id,\n\t\t\t\trun.suiteId,\n\t\t\t\trun.suiteLabel,\n\t\t\t\trun.label,\n\t\t\t\trun.corpusGroupKey ?? null,\n\t\t\t\trun.groupKey ?? null,\n\t\t\t\tJSON.stringify(run.tags ?? []),\n\t\t\t\trun.startedAt,\n\t\t\t\trun.finishedAt,\n\t\t\t\trun.elapsedMs,\n\t\t\t\tJSON.stringify(run.comparison),\n\t\t\t\trun.decisionSummary === undefined\n\t\t\t\t\t? null\n\t\t\t\t\t: JSON.stringify(run.decisionSummary)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalReleaseDecisionStore = (\n\toptions: SQLiteRAGRetrievalReleaseDecisionStoreOptions\n): RAGRetrievalReleaseDecisionStore => {\n\tconst tableName =\n\t\toptions.tableName ?? DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME;\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\tkind TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tensureSQLiteColumns(db, tableName, [\n\t\t{ definition: 'TEXT', name: 'corpus_group_key' }\n\t]);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_decided_at_idx ON ${tableName} (corpus_group_key, decided_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_kind_decided_at_idx ON ${tableName} (kind, decided_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\tkind = excluded.kind,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistDecisions(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.kind) {\n\t\t\t\twhere.push('kind = ?');\n\t\t\t\tparams.push(input.kind);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY decided_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst decisions = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalReleaseDecisionRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalReleaseDecisionRow)\n\t\t\t\t: [];\n\t\t\tconst sorted = normalizeRetrievalReleaseDecisionRecords(decisions);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveDecision(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.kind,\n\t\t\t\trecord.decidedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalBaselineStore = (\n\toptions: SQLiteRAGRetrievalBaselineStoreOptions\n): RAGRetrievalBaselineStore => {\n\tconst tableName =\n\t\toptions.tableName ?? DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME;\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\trollout_label TEXT,\n\t\t\tpromoted_at INTEGER NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\tversion INTEGER NOT NULL,\n\t\t\ttags_json TEXT,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tensureSQLiteColumns(db, tableName, [\n\t\t{ definition: 'TEXT', name: 'corpus_group_key' }\n\t]);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_promoted_at_idx ON ${tableName} (group_key, promoted_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_promoted_at_idx ON ${tableName} (corpus_group_key, promoted_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_rollout_status_idx ON ${tableName} (group_key, rollout_label, status)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tpromoted_at = excluded.promoted_at,\n\t\t\tstatus = excluded.status,\n\t\t\tversion = excluded.version,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\tconst updateExisting = db.prepare(`\n\t\tUPDATE ${tableName}\n\t\tSET\n\t\t\tstatus = ?,\n\t\t\trecord_json = ?\n\t\tWHERE id = ?\n\t`);\n\tconst currentVersion = db.prepare(`\n\t\tSELECT COALESCE(MAX(version), 0) AS max_version\n\t\tFROM ${tableName}\n\t\tWHERE group_key = ?\n\t`);\n\tconst matchingRolloutRows = db.prepare(`\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t\tWHERE group_key = ?\n\t\t\tAND (\n\t\t\t\t(rollout_label IS NULL AND ? IS NULL) OR\n\t\t\t\trollout_label = ?\n\t\t\t)\n\t`);\n\n\tconst listBaselinesSync = (\n\t\tinput: Parameters<RAGRetrievalBaselineStore['listBaselines']>[0] = {}\n\t): RAGRetrievalBaselineRecord[] => {\n\t\tconst where: string[] = [];\n\t\tconst params: Array<string | number> = [];\n\n\t\tif (input.corpusGroupKey) {\n\t\t\twhere.push('corpus_group_key = ?');\n\t\t\tparams.push(input.corpusGroupKey);\n\t\t}\n\n\t\tif (input.groupKey) {\n\t\t\twhere.push('group_key = ?');\n\t\t\tparams.push(input.groupKey);\n\t\t}\n\n\t\tif (input.status) {\n\t\t\twhere.push('status = ?');\n\t\t\tparams.push(input.status);\n\t\t}\n\n\t\tconst sql =\n\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t'ORDER BY promoted_at DESC';\n\t\tconst rows = db.prepare(sql).all(...params);\n\t\tconst baselines = Array.isArray(rows)\n\t\t\t? rows\n\t\t\t\t\t.filter(isSQLiteRetrievalBaselineRow)\n\t\t\t\t\t.map(mapSQLiteRetrievalBaselineRow)\n\t\t\t: [];\n\t\tconst tag = typeof input.tag === 'string' ? input.tag : undefined;\n\t\tconst filtered = tag\n\t\t\t? baselines.filter((entry) => (entry.tags ?? []).includes(tag))\n\t\t\t: baselines;\n\t\tconst sorted = normalizeRetrievalBaselineRecords(filtered);\n\n\t\treturn typeof input.limit === 'number'\n\t\t\t? sorted.slice(0, input.limit)\n\t\t\t: sorted;\n\t};\n\n\treturn {\n\t\tgetBaseline(groupKey) {\n\t\t\tconst baselines = listBaselinesSync({ groupKey, limit: 1 });\n\t\t\treturn Promise.resolve(baselines[0] ?? null);\n\t\t},\n\t\tlistBaselines(input) {\n\t\t\treturn Promise.resolve(listBaselinesSync(input));\n\t\t},\n\t\tsaveBaseline(record) {\n\t\t\tconst versionRow = currentVersion.get(record.groupKey) as\n\t\t\t\t| { max_version?: number }\n\t\t\t\t| undefined;\n\t\t\tconst nextVersion =\n\t\t\t\ttypeof record.version === 'number'\n\t\t\t\t\t? record.version\n\t\t\t\t\t: (versionRow?.max_version ?? 0) + 1;\n\t\t\tconst nextRecord: RAGRetrievalBaselineRecord = {\n\t\t\t\t...record,\n\t\t\t\tstatus: 'active',\n\t\t\t\tversion: nextVersion\n\t\t\t};\n\n\t\t\tconst rows = matchingRolloutRows.all(\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.rolloutLabel ?? null,\n\t\t\t\trecord.rolloutLabel ?? null\n\t\t\t);\n\t\t\tconst existing = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalBaselineRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalBaselineRow)\n\t\t\t\t: [];\n\n\t\t\tfor (const entry of existing) {\n\t\t\t\tupdateExisting.run(\n\t\t\t\t\t'superseded',\n\t\t\t\t\tJSON.stringify({\n\t\t\t\t\t\t...entry,\n\t\t\t\t\t\tstatus: 'superseded'\n\t\t\t\t\t}),\n\t\t\t\t\tentry.id\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tinsert.run(\n\t\t\t\tnextRecord.id,\n\t\t\t\tnextRecord.corpusGroupKey ?? null,\n\t\t\t\tnextRecord.groupKey,\n\t\t\t\tnextRecord.rolloutLabel ?? null,\n\t\t\t\tnextRecord.promotedAt,\n\t\t\t\tnextRecord.status,\n\t\t\t\tnextRecord.version,\n\t\t\t\tJSON.stringify(nextRecord.tags ?? []),\n\t\t\t\tJSON.stringify(nextRecord)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalReleaseIncidentStore = (\n\toptions: SQLiteRAGRetrievalReleaseIncidentStoreOptions\n): RAGRetrievalReleaseIncidentStore => {\n\tconst tableName =\n\t\toptions.tableName ?? DEFAULT_RETRIEVAL_RELEASE_INCIDENT_TABLE_NAME;\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tseverity TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\ttriggered_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_triggered_at_idx ON ${tableName} (group_key, triggered_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_status_idx ON ${tableName} (corpus_group_key, status, triggered_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tseverity = excluded.severity,\n\t\t\tstatus = excluded.status,\n\t\t\ttriggered_at = excluded.triggered_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistIncidents(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tif (input.severity) {\n\t\t\t\twhere.push('severity = ?');\n\t\t\t\tparams.push(input.severity);\n\t\t\t}\n\n\t\t\tif (input.status) {\n\t\t\t\twhere.push('status = ?');\n\t\t\t\tparams.push(input.status);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY triggered_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst incidents = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalReleaseIncidentRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalReleaseIncidentRow)\n\t\t\t\t: [];\n\t\t\tconst sorted = normalizeRetrievalReleaseIncidentRecords(incidents);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveIncident(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.targetRolloutLabel ?? null,\n\t\t\t\trecord.severity,\n\t\t\t\trecord.status,\n\t\t\t\trecord.triggeredAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffDecisionStore = (\n\toptions: SQLiteRAGRetrievalLaneHandoffDecisionStoreOptions\n): RAGRetrievalLaneHandoffDecisionStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_lane_handoff_decisions';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\tsource_rollout_label TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\tkind TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_rollout_idx ON ${tableName} (corpus_group_key, source_rollout_label, target_rollout_label, decided_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tsource_rollout_label,\n\t\t\ttarget_rollout_label,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tsource_rollout_label,\n\t\t\ttarget_rollout_label,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\tsource_rollout_label = excluded.source_rollout_label,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tkind = excluded.kind,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistDecisions(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.kind) {\n\t\t\t\twhere.push('kind = ?');\n\t\t\t\tparams.push(input.kind);\n\t\t\t}\n\n\t\t\tif (input.sourceRolloutLabel) {\n\t\t\t\twhere.push('source_rollout_label = ?');\n\t\t\t\tparams.push(input.sourceRolloutLabel);\n\t\t\t}\n\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY decided_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst decisions = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalLaneHandoffDecisionRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalLaneHandoffDecisionRow)\n\t\t\t\t: [];\n\t\t\tconst sorted =\n\t\t\t\tnormalizeRetrievalLaneHandoffDecisionRecords(decisions);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveDecision(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.sourceRolloutLabel,\n\t\t\t\trecord.targetRolloutLabel,\n\t\t\t\trecord.kind,\n\t\t\t\trecord.decidedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffIncidentStore = (\n\toptions: SQLiteRAGRetrievalLaneHandoffIncidentStoreOptions\n): RAGRetrievalLaneHandoffIncidentStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_lane_handoff_incidents';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tsource_rollout_label TEXT,\n\t\t\tseverity TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\ttriggered_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_triggered_at_idx ON ${tableName} (group_key, triggered_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_status_idx ON ${tableName} (corpus_group_key, status, triggered_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tsource_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tsource_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tsource_rollout_label = excluded.source_rollout_label,\n\t\t\tseverity = excluded.severity,\n\t\t\tstatus = excluded.status,\n\t\t\ttriggered_at = excluded.triggered_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistIncidents(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tif (input.severity) {\n\t\t\t\twhere.push('severity = ?');\n\t\t\t\tparams.push(input.severity);\n\t\t\t}\n\n\t\t\tif (input.status) {\n\t\t\t\twhere.push('status = ?');\n\t\t\t\tparams.push(input.status);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY triggered_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst incidents = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalLaneHandoffIncidentRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalLaneHandoffIncidentRow)\n\t\t\t\t: [];\n\t\t\tconst sorted = normalizeRetrievalReleaseIncidentRecords(\n\t\t\t\tincidents as RAGRetrievalReleaseIncidentRecord[]\n\t\t\t) as RAGRetrievalLaneHandoffIncidentRecord[];\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveIncident(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.targetRolloutLabel ?? null,\n\t\t\t\trecord.sourceRolloutLabel ?? null,\n\t\t\t\trecord.severity,\n\t\t\t\trecord.status,\n\t\t\t\trecord.triggeredAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffIncidentHistoryStore = (\n\toptions: SQLiteRAGRetrievalLaneHandoffIncidentHistoryStoreOptions\n): RAGRetrievalLaneHandoffIncidentHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_lane_handoff_incident_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT NOT NULL,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\taction TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_incident_recorded_at_idx ON ${tableName} (incident_id, recorded_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\taction = excluded.action,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRecords(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.incidentId) {\n\t\t\t\twhere.push('incident_id = ?');\n\t\t\t\tparams.push(input.incidentId);\n\t\t\t}\n\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tif (input.action) {\n\t\t\t\twhere.push('action = ?');\n\t\t\t\tparams.push(input.action);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY recorded_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalLaneHandoffIncidentHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalLaneHandoffIncidentHistoryRow)\n\t\t\t\t: [];\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? records.slice(0, input.limit)\n\t\t\t\t: records;\n\t\t},\n\t\tsaveRecord(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.incidentId,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.targetRolloutLabel ?? null,\n\t\t\t\trecord.action,\n\t\t\t\trecord.recordedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalIncidentRemediationDecisionStore = (\n\toptions: SQLiteRAGRetrievalIncidentRemediationDecisionStoreOptions\n): RAGRetrievalIncidentRemediationDecisionStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_incident_remediation_decisions';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT NOT NULL,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tremediation_kind TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_incident_status_idx ON ${tableName} (incident_id, status, decided_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tremediation_kind,\n\t\t\tstatus,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tremediation_kind,\n\t\t\tstatus,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tremediation_kind = excluded.remediation_kind,\n\t\t\tstatus = excluded.status,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRecords(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\n\t\t\tif (input.incidentId) {\n\t\t\t\twhere.push('incident_id = ?');\n\t\t\t\tparams.push(input.incidentId);\n\t\t\t}\n\n\t\t\tif (input.remediationKind) {\n\t\t\t\twhere.push('remediation_kind = ?');\n\t\t\t\tparams.push(input.remediationKind);\n\t\t\t}\n\n\t\t\tif (input.status) {\n\t\t\t\twhere.push('status = ?');\n\t\t\t\tparams.push(input.status);\n\t\t\t}\n\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY decided_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteRetrievalIncidentRemediationDecisionRow)\n\t\t\t\t\t\t.map(mapSQLiteRetrievalIncidentRemediationDecisionRow)\n\t\t\t\t: [];\n\t\t\tconst sorted =\n\t\t\t\tnormalizeRetrievalIncidentRemediationDecisionRecords(records);\n\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t: sorted;\n\t\t},\n\t\tsaveRecord(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.incidentId,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.targetRolloutLabel ?? null,\n\t\t\t\trecord.remediationKind,\n\t\t\t\trecord.status,\n\t\t\t\trecord.decidedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalIncidentRemediationExecutionHistoryStore =\n\t(\n\t\toptions: SQLiteRAGRetrievalIncidentRemediationExecutionHistoryStoreOptions\n\t): RAGRetrievalIncidentRemediationExecutionHistoryStore => {\n\t\tconst tableName =\n\t\t\toptions.tableName ??\n\t\t\t'rag_retrieval_incident_remediation_execution_history';\n\t\tassertSupportedIdentifier(tableName);\n\n\t\tconst db =\n\t\t\toptions.db ??\n\t\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\t\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\taction_kind TEXT NOT NULL,\n\t\t\tcode TEXT NOT NULL,\n\t\t\tblocked_by_guardrail INTEGER NOT NULL,\n\t\t\tidempotent_replay INTEGER NOT NULL,\n\t\t\texecuted_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\t\tdb.exec(\n\t\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_executed_at_idx ON ${tableName} (group_key, executed_at DESC)`\n\t\t);\n\t\tdb.exec(\n\t\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_incident_code_idx ON ${tableName} (incident_id, code, executed_at DESC)`\n\t\t);\n\n\t\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction_kind,\n\t\t\tcode,\n\t\t\tblocked_by_guardrail,\n\t\t\tidempotent_replay,\n\t\t\texecuted_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\t\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction_kind,\n\t\t\tcode,\n\t\t\tblocked_by_guardrail,\n\t\t\tidempotent_replay,\n\t\t\texecuted_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\taction_kind = excluded.action_kind,\n\t\t\tcode = excluded.code,\n\t\t\tblocked_by_guardrail = excluded.blocked_by_guardrail,\n\t\t\tidempotent_replay = excluded.idempotent_replay,\n\t\t\texecuted_at = excluded.executed_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\t\treturn {\n\t\t\tlistRecords(input = {}) {\n\t\t\t\tconst where: string[] = [];\n\t\t\t\tconst params: Array<string | number> = [];\n\n\t\t\t\tif (input.groupKey) {\n\t\t\t\t\twhere.push('group_key = ?');\n\t\t\t\t\tparams.push(input.groupKey);\n\t\t\t\t}\n\n\t\t\t\tif (input.incidentId) {\n\t\t\t\t\twhere.push('incident_id = ?');\n\t\t\t\t\tparams.push(input.incidentId);\n\t\t\t\t}\n\n\t\t\t\tif (input.actionKind) {\n\t\t\t\t\twhere.push('action_kind = ?');\n\t\t\t\t\tparams.push(input.actionKind);\n\t\t\t\t}\n\n\t\t\t\tif (input.code) {\n\t\t\t\t\twhere.push('code = ?');\n\t\t\t\t\tparams.push(input.code);\n\t\t\t\t}\n\n\t\t\t\tif (typeof input.blockedByGuardrail === 'boolean') {\n\t\t\t\t\twhere.push('blocked_by_guardrail = ?');\n\t\t\t\t\tparams.push(input.blockedByGuardrail ? 1 : 0);\n\t\t\t\t}\n\n\t\t\t\tif (typeof input.idempotentReplay === 'boolean') {\n\t\t\t\t\twhere.push('idempotent_replay = ?');\n\t\t\t\t\tparams.push(input.idempotentReplay ? 1 : 0);\n\t\t\t\t}\n\n\t\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t\t}\n\n\t\t\t\tconst sql =\n\t\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t\t'ORDER BY executed_at DESC';\n\t\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t\t? rows\n\t\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t\tisSQLiteRetrievalIncidentRemediationExecutionHistoryRow\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t.map(\n\t\t\t\t\t\t\t\tmapSQLiteRetrievalIncidentRemediationExecutionHistoryRow\n\t\t\t\t\t\t\t)\n\t\t\t\t\t: [];\n\t\t\t\tconst sorted =\n\t\t\t\t\tnormalizeRetrievalIncidentRemediationExecutionHistoryRecords(\n\t\t\t\t\t\trecords\n\t\t\t\t\t);\n\n\t\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t\t? sorted.slice(0, input.limit)\n\t\t\t\t\t: sorted;\n\t\t\t},\n\t\t\tsaveRecord(record) {\n\t\t\t\tinsert.run(\n\t\t\t\t\trecord.id,\n\t\t\t\t\trecord.incidentId ?? null,\n\t\t\t\t\trecord.groupKey ?? null,\n\t\t\t\t\trecord.targetRolloutLabel ?? null,\n\t\t\t\t\trecord.action.kind,\n\t\t\t\t\trecord.code,\n\t\t\t\t\trecord.blockedByGuardrail ? 1 : 0,\n\t\t\t\t\trecord.idempotentReplay ? 1 : 0,\n\t\t\t\t\trecord.executedAt,\n\t\t\t\t\tJSON.stringify(record)\n\t\t\t\t);\n\t\t\t}\n\t\t};\n\t};\n\nexport const createRAGSQLiteRetrievalLaneHandoffAutoCompletePolicyHistoryStore =\n\t(\n\t\toptions: SQLiteRAGRetrievalLaneHandoffAutoCompletePolicyHistoryStoreOptions\n\t): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore => {\n\t\tconst tableName =\n\t\t\toptions.tableName ??\n\t\t\t'rag_retrieval_lane_handoff_auto_complete_policy_history';\n\t\tassertSupportedIdentifier(tableName);\n\n\t\tconst db =\n\t\t\toptions.db ??\n\t\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\t\tdb.exec(`\n\t\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\t\tid TEXT PRIMARY KEY,\n\t\t\t\tcorpus_group_key TEXT,\n\t\t\t\tgroup_key TEXT NOT NULL,\n\t\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\t\trecord_json TEXT NOT NULL\n\t\t\t)\n\t\t`);\n\t\tdb.exec(\n\t\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`\n\t\t);\n\t\tdb.exec(\n\t\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_target_idx ON ${tableName} (corpus_group_key, target_rollout_label, recorded_at DESC)`\n\t\t);\n\n\t\tconst listBase = `\n\t\t\tSELECT\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\tFROM ${tableName}\n\t\t`;\n\t\tconst insert = db.prepare(`\n\t\t\tINSERT INTO ${tableName} (\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\t\tgroup_key = excluded.group_key,\n\t\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\t\trecorded_at = excluded.recorded_at,\n\t\t\t\trecord_json = excluded.record_json\n\t\t`);\n\n\t\treturn {\n\t\t\tlistRecords(input = {}) {\n\t\t\t\tconst where: string[] = [];\n\t\t\t\tconst params: Array<string | number> = [];\n\n\t\t\t\tif (input.corpusGroupKey) {\n\t\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t\t}\n\t\t\t\tif (input.groupKey) {\n\t\t\t\t\twhere.push('group_key = ?');\n\t\t\t\t\tparams.push(input.groupKey);\n\t\t\t\t}\n\t\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t\t}\n\n\t\t\t\tconst sql =\n\t\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t\t'ORDER BY recorded_at DESC';\n\t\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t\t? rows\n\t\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t\tisSQLiteLaneHandoffAutoCompletePolicyHistoryRow\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t.map(\n\t\t\t\t\t\t\t\tmapSQLiteLaneHandoffAutoCompletePolicyHistoryRow\n\t\t\t\t\t\t\t)\n\t\t\t\t\t: [];\n\t\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t\t? records.slice(0, input.limit)\n\t\t\t\t\t: records;\n\t\t\t},\n\t\t\tsaveRecord(record) {\n\t\t\t\tinsert.run(\n\t\t\t\t\trecord.id,\n\t\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\t\trecord.groupKey,\n\t\t\t\t\trecord.targetRolloutLabel,\n\t\t\t\t\trecord.recordedAt,\n\t\t\t\t\tJSON.stringify(record)\n\t\t\t\t);\n\t\t\t}\n\t\t};\n\t};\n\nexport const createRAGSQLiteRetrievalReleaseLanePolicyHistoryStore = (\n\toptions: SQLiteRAGRetrievalReleaseLanePolicyHistoryStoreOptions\n): RAGRetrievalReleaseLanePolicyHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_release_lane_policy_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\trollout_label TEXT NOT NULL,\n\t\t\tscope TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_rollout_recorded_at_idx ON ${tableName} (rollout_label, recorded_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_scope_idx ON ${tableName} (group_key, scope, recorded_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tscope = excluded.scope,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRecords(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\t\t\tif (input.rolloutLabel) {\n\t\t\t\twhere.push('rollout_label = ?');\n\t\t\t\tparams.push(input.rolloutLabel);\n\t\t\t}\n\t\t\tif (input.scope) {\n\t\t\t\twhere.push('scope = ?');\n\t\t\t\tparams.push(input.scope);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY recorded_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteReleaseLanePolicyHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteReleaseLanePolicyHistoryRow)\n\t\t\t\t: [];\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? records.slice(0, input.limit)\n\t\t\t\t: records;\n\t\t},\n\t\tsaveRecord(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey ?? null,\n\t\t\t\trecord.rolloutLabel,\n\t\t\t\trecord.scope,\n\t\t\t\trecord.recordedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalBaselineGatePolicyHistoryStore = (\n\toptions: SQLiteRAGRetrievalBaselineGatePolicyHistoryStoreOptions\n): RAGRetrievalBaselineGatePolicyHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ?? 'rag_retrieval_baseline_gate_policy_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\trollout_label TEXT NOT NULL,\n\t\t\tscope TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_rollout_recorded_at_idx ON ${tableName} (rollout_label, recorded_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_scope_idx ON ${tableName} (group_key, scope, recorded_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n\tconst insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tscope = excluded.scope,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n\treturn {\n\t\tlistRecords(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\t\t\tif (input.rolloutLabel) {\n\t\t\t\twhere.push('rollout_label = ?');\n\t\t\t\tparams.push(input.rolloutLabel);\n\t\t\t}\n\t\t\tif (input.scope) {\n\t\t\t\twhere.push('scope = ?');\n\t\t\t\tparams.push(input.scope);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY recorded_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteBaselineGatePolicyHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteBaselineGatePolicyHistoryRow)\n\t\t\t\t: [];\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? records.slice(0, input.limit)\n\t\t\t\t: records;\n\t\t},\n\t\tsaveRecord(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey ?? null,\n\t\t\t\trecord.rolloutLabel,\n\t\t\t\trecord.scope,\n\t\t\t\trecord.recordedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGSQLiteRetrievalReleaseLaneEscalationPolicyHistoryStore = (\n\toptions: SQLiteRAGRetrievalReleaseLaneEscalationPolicyHistoryStoreOptions\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryStore => {\n\tconst tableName =\n\t\toptions.tableName ??\n\t\t'rag_retrieval_release_lane_escalation_policy_history';\n\tassertSupportedIdentifier(tableName);\n\n\tconst db =\n\t\toptions.db ??\n\t\tnew (loadBunSQLiteModule().Database)(options.path ?? ':memory:');\n\n\tdb.exec(`\n\t\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\t\tid TEXT PRIMARY KEY,\n\t\t\t\tcorpus_group_key TEXT,\n\t\t\t\tgroup_key TEXT NOT NULL,\n\t\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\t\trecord_json TEXT NOT NULL\n\t\t\t)\n\t\t`);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`\n\t);\n\tdb.exec(\n\t\t`CREATE INDEX IF NOT EXISTS ${tableName}_corpus_target_idx ON ${tableName} (corpus_group_key, target_rollout_label, recorded_at DESC)`\n\t);\n\n\tconst listBase = `\n\t\t\tSELECT\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\tFROM ${tableName}\n\t\t`;\n\tconst insert = db.prepare(`\n\t\t\tINSERT INTO ${tableName} (\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\t\tgroup_key = excluded.group_key,\n\t\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\t\trecorded_at = excluded.recorded_at,\n\t\t\t\trecord_json = excluded.record_json\n\t\t`);\n\n\treturn {\n\t\tlistRecords(input = {}) {\n\t\t\tconst where: string[] = [];\n\t\t\tconst params: Array<string | number> = [];\n\n\t\t\tif (input.corpusGroupKey) {\n\t\t\t\twhere.push('corpus_group_key = ?');\n\t\t\t\tparams.push(input.corpusGroupKey);\n\t\t\t}\n\t\t\tif (input.groupKey) {\n\t\t\t\twhere.push('group_key = ?');\n\t\t\t\tparams.push(input.groupKey);\n\t\t\t}\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\twhere.push('target_rollout_label = ?');\n\t\t\t\tparams.push(input.targetRolloutLabel);\n\t\t\t}\n\n\t\t\tconst sql =\n\t\t\t\t`${listBase}${where.length > 0 ? ` WHERE ${where.join(' AND ')}` : ''} ` +\n\t\t\t\t'ORDER BY recorded_at DESC';\n\t\t\tconst rows = db.prepare(sql).all(...params);\n\t\t\tconst records = Array.isArray(rows)\n\t\t\t\t? rows\n\t\t\t\t\t\t.filter(isSQLiteReleaseLaneEscalationPolicyHistoryRow)\n\t\t\t\t\t\t.map(mapSQLiteReleaseLaneEscalationPolicyHistoryRow)\n\t\t\t\t: [];\n\t\t\treturn typeof input.limit === 'number'\n\t\t\t\t? records.slice(0, input.limit)\n\t\t\t\t: records;\n\t\t},\n\t\tsaveRecord(record) {\n\t\t\tinsert.run(\n\t\t\t\trecord.id,\n\t\t\t\trecord.corpusGroupKey ?? null,\n\t\t\t\trecord.groupKey,\n\t\t\t\trecord.targetRolloutLabel,\n\t\t\t\trecord.recordedAt,\n\t\t\t\tJSON.stringify(record)\n\t\t\t);\n\t\t}\n\t};\n};\n\nexport const createRAGFileAnswerGroundingEvaluationHistoryStore = (\n\tpath: string\n): RAGAnswerGroundingEvaluationHistoryStore => ({\n\tasync listRuns(input) {\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\truns?: RAGAnswerGroundingEvaluationRun[];\n\t\t\t};\n\t\t\tconst runs = Array.isArray(data.runs) ? data.runs : [];\n\t\t\tconst filtered = input?.suiteId\n\t\t\t\t? runs.filter((run) => run.suiteId === input.suiteId)\n\t\t\t\t: runs;\n\n\t\t\treturn filtered\n\t\t\t\t.sort(toGroundingHistorySortOrder)\n\t\t\t\t.slice(0, input?.limit ?? DEFAULT_HISTORY_LIMIT);\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\terror &&\n\t\t\t\ttypeof error === 'object' &&\n\t\t\t\t'code' in error &&\n\t\t\t\terror.code === 'ENOENT'\n\t\t\t) {\n\t\t\t\treturn [];\n\t\t\t}\n\n\t\t\tthrow error;\n\t\t}\n\t},\n\tasync saveRun(run) {\n\t\tlet runs: RAGAnswerGroundingEvaluationRun[] = [];\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\truns?: RAGAnswerGroundingEvaluationRun[];\n\t\t\t};\n\t\t\truns = Array.isArray(data.runs) ? data.runs : [];\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\t!error ||\n\t\t\t\ttypeof error !== 'object' ||\n\t\t\t\t!('code' in error) ||\n\t\t\t\terror.code !== 'ENOENT'\n\t\t\t) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst nextRuns = normalizeGroundingHistoryRuns([\n\t\t\trun,\n\t\t\t...runs.filter((entry) => entry.id !== run.id)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(\n\t\t\t\t{\n\t\t\t\t\truns: nextRuns\n\t\t\t\t},\n\t\t\t\tnull,\n\t\t\t\t2\n\t\t\t)\n\t\t);\n\t},\n\tasync pruneRuns(input) {\n\t\tlet runs: RAGAnswerGroundingEvaluationRun[] = [];\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\truns?: RAGAnswerGroundingEvaluationRun[];\n\t\t\t};\n\t\t\truns = Array.isArray(data.runs) ? data.runs : [];\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\t!error ||\n\t\t\t\ttypeof error !== 'object' ||\n\t\t\t\t!('code' in error) ||\n\t\t\t\terror.code !== 'ENOENT'\n\t\t\t) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst pruned = applyRAGEvaluationHistoryPrunePolicy({\n\t\t\tinput,\n\t\t\truns,\n\t\t\tsort: normalizeGroundingHistoryRuns\n\t\t});\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(\n\t\t\t\t{\n\t\t\t\t\truns: pruned.next\n\t\t\t\t},\n\t\t\t\tnull,\n\t\t\t\t2\n\t\t\t)\n\t\t);\n\t\treturn {\n\t\t\tkeptCount: pruned.keptCount,\n\t\t\tremovedCount: pruned.removedCount\n\t\t} satisfies RAGEvaluationHistoryPruneResult;\n\t}\n});\n\nexport const createRAGFileAnswerGroundingCaseDifficultyHistoryStore = (\n\tpath: string\n): RAGAnswerGroundingCaseDifficultyHistoryStore => ({\n\tasync listRuns(input) {\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\truns?: RAGAnswerGroundingCaseDifficultyRun[];\n\t\t\t};\n\t\t\tconst runs = Array.isArray(data.runs) ? data.runs : [];\n\t\t\tconst filtered = input?.suiteId\n\t\t\t\t? runs.filter((run) => run.suiteId === input.suiteId)\n\t\t\t\t: runs;\n\n\t\t\treturn normalizeGroundingDifficultyHistoryRuns(filtered).slice(\n\t\t\t\t0,\n\t\t\t\tinput?.limit ?? DEFAULT_HISTORY_LIMIT\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\terror &&\n\t\t\t\ttypeof error === 'object' &&\n\t\t\t\t'code' in error &&\n\t\t\t\terror.code === 'ENOENT'\n\t\t\t) {\n\t\t\t\treturn [];\n\t\t\t}\n\n\t\t\tthrow error;\n\t\t}\n\t},\n\tasync saveRun(run) {\n\t\tlet runs: RAGAnswerGroundingCaseDifficultyRun[] = [];\n\t\ttry {\n\t\t\tconst raw = await readFile(path, 'utf8');\n\t\t\tconst data = JSON.parse(raw) as {\n\t\t\t\truns?: RAGAnswerGroundingCaseDifficultyRun[];\n\t\t\t};\n\t\t\truns = Array.isArray(data.runs) ? data.runs : [];\n\t\t} catch (error) {\n\t\t\tif (\n\t\t\t\t!error ||\n\t\t\t\ttypeof error !== 'object' ||\n\t\t\t\t!('code' in error) ||\n\t\t\t\terror.code !== 'ENOENT'\n\t\t\t) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\n\t\tconst nextRuns = normalizeGroundingDifficultyHistoryRuns([\n\t\t\trun,\n\t\t\t...runs.filter((entry) => entry.id !== run.id)\n\t\t]);\n\t\tawait mkdir(dirname(path), { recursive: true });\n\t\tawait writeFile(\n\t\t\tpath,\n\t\t\tJSON.stringify(\n\t\t\t\t{\n\t\t\t\t\truns: nextRuns\n\t\t\t\t},\n\t\t\t\tnull,\n\t\t\t\t2\n\t\t\t)\n\t\t);\n\t}\n});\n\nexport const loadRAGEvaluationHistory = async ({\n\tstore,\n\tsuite,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGEvaluationHistoryStore;\n\tsuite: RAGEvaluationSuite;\n\tlimit?: number;\n}): Promise<RAGEvaluationHistory> => {\n\tconst runs = normalizeHistoryRuns(\n\t\tawait Promise.resolve(store.listRuns({ limit, suiteId: suite.id }))\n\t);\n\tconst latestRun = runs[0];\n\tconst previousRun = runs[1];\n\n\treturn {\n\t\tcaseTraceSnapshots: buildEvaluationCaseTraceSnapshots({\n\t\t\tcurrent: latestRun,\n\t\t\tprevious: previousRun\n\t\t}),\n\t\tretrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n\t\t\truns\n\t\t}),\n\t\tdiff:\n\t\t\tlatestRun && previousRun\n\t\t\t\t? buildRAGEvaluationRunDiff({\n\t\t\t\t\t\tcurrent: latestRun,\n\t\t\t\t\t\tprevious: previousRun\n\t\t\t\t\t})\n\t\t\t\t: undefined,\n\t\tlatestRun,\n\t\tleaderboard: buildRAGEvaluationLeaderboard(runs),\n\t\tpreviousRun,\n\t\truns,\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id\n\t};\n};\n\nexport const loadRAGEvaluationSuiteSnapshotHistory = async ({\n\tstore,\n\tsuite,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGEvaluationSuiteSnapshotHistoryStore;\n\tsuite: Pick<RAGEvaluationSuite, 'id' | 'label'>;\n\tlimit?: number;\n}): Promise<RAGEvaluationSuiteSnapshotHistory> => {\n\tconst snapshots = normalizeEvaluationSuiteSnapshots(\n\t\tawait Promise.resolve(\n\t\t\tstore.listSnapshots({\n\t\t\t\tlimit,\n\t\t\t\tsuiteId: suite.id\n\t\t\t})\n\t\t)\n\t);\n\tconst latestSnapshot = snapshots[0];\n\tconst previousSnapshot = snapshots[1];\n\n\treturn {\n\t\tdiff:\n\t\t\tlatestSnapshot && previousSnapshot\n\t\t\t\t? buildRAGEvaluationSuiteSnapshotDiff({\n\t\t\t\t\t\tcurrent: latestSnapshot,\n\t\t\t\t\t\tprevious: previousSnapshot\n\t\t\t\t\t})\n\t\t\t\t: undefined,\n\t\tlatestSnapshot,\n\t\tpreviousSnapshot,\n\t\tsnapshots,\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id\n\t};\n};\n\nexport const loadRAGSearchTraceHistory = async ({\n\tstore,\n\tquery,\n\tgroupKey,\n\ttag,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGSearchTraceStore;\n\tquery?: string;\n\tgroupKey?: string;\n\ttag?: string;\n\tlimit?: number;\n}): Promise<RAGSearchTraceHistory> => {\n\tconst traces = normalizeTraceSummaryRuns(\n\t\tawait Promise.resolve(store.listTraces({ groupKey, limit, query, tag }))\n\t);\n\tconst latestTrace = traces[0];\n\tconst previousTrace = traces[1];\n\n\treturn {\n\t\tdiff:\n\t\t\tlatestTrace && previousTrace\n\t\t\t\t? buildRAGSearchTraceDiff({\n\t\t\t\t\t\tcurrent: latestTrace,\n\t\t\t\t\t\tprevious: previousTrace\n\t\t\t\t\t})\n\t\t\t\t: undefined,\n\t\tlatestTrace,\n\t\tpreviousTrace,\n\t\tgroupKey,\n\t\tquery,\n\t\ttag,\n\t\tretrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n\t\t\truns: traces.map((trace) => ({\n\t\t\t\tfinishedAt: trace.finishedAt,\n\t\t\t\tid: trace.id,\n\t\t\t\tlabel: trace.label,\n\t\t\t\ttraceSummary: trace.summary\n\t\t\t}))\n\t\t}),\n\t\ttraces\n\t};\n};\n\nexport const loadRAGSearchTraceGroupHistory = async ({\n\tstore,\n\ttag,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGSearchTraceStore;\n\ttag?: string;\n\tlimit?: number;\n}): Promise<RAGSearchTraceGroupHistory> => {\n\tconst traces = normalizeTraceSummaryRuns(\n\t\tawait Promise.resolve(store.listTraces({ limit, tag }))\n\t);\n\tconst grouped = new Map<string, RAGSearchTraceRecord[]>();\n\n\tfor (const trace of traces) {\n\t\tconst groupKey = trace.groupKey ?? trace.query;\n\t\tconst existing = grouped.get(groupKey);\n\t\tif (existing) {\n\t\t\texisting.push(trace);\n\t\t\tcontinue;\n\t\t}\n\t\tgrouped.set(groupKey, [trace]);\n\t}\n\n\tconst groups = Array.from(grouped.entries())\n\t\t.map(([groupKey, entries]): RAGSearchTraceGroupHistoryEntry => {\n\t\t\tconst normalizedEntries = normalizeTraceSummaryRuns(entries);\n\t\t\tconst latestTrace = normalizedEntries[0];\n\t\t\tconst previousTrace = normalizedEntries[1];\n\n\t\t\treturn {\n\t\t\t\tdiff:\n\t\t\t\t\tlatestTrace && previousTrace\n\t\t\t\t\t\t? buildRAGSearchTraceDiff({\n\t\t\t\t\t\t\t\tcurrent: latestTrace,\n\t\t\t\t\t\t\t\tprevious: previousTrace\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t: undefined,\n\t\t\t\tgroupKey,\n\t\t\t\tlatestTrace,\n\t\t\t\tpreviousTrace,\n\t\t\t\tretrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n\t\t\t\t\truns: normalizedEntries.map((trace) => ({\n\t\t\t\t\t\tfinishedAt: trace.finishedAt,\n\t\t\t\t\t\tid: trace.id,\n\t\t\t\t\t\tlabel: trace.label,\n\t\t\t\t\t\ttraceSummary: trace.summary\n\t\t\t\t\t}))\n\t\t\t\t}),\n\t\t\t\ttraceCount: normalizedEntries.length\n\t\t\t};\n\t\t})\n\t\t.sort((left, right) => {\n\t\t\tconst leftFinishedAt = left.latestTrace?.finishedAt ?? 0;\n\t\t\tconst rightFinishedAt = right.latestTrace?.finishedAt ?? 0;\n\t\t\treturn rightFinishedAt - leftFinishedAt;\n\t\t});\n\n\treturn {\n\t\tgroups,\n\t\ttag\n\t};\n};\n\nexport const summarizeRAGSearchTraceStore = async ({\n\tstore,\n\ttag\n}: {\n\tstore: RAGSearchTraceStore;\n\ttag?: string;\n}): Promise<RAGSearchTraceStats> => {\n\tconst traces = normalizeTraceSummaryRuns(\n\t\tawait Promise.resolve(store.listTraces({ tag }))\n\t);\n\n\treturn buildRAGSearchTraceStatsFromTraces(traces);\n};\n\nexport const previewRAGSearchTraceStorePrune = async ({\n\tstore,\n\tinput\n}: {\n\tstore: RAGSearchTraceStore;\n\tinput?: RAGSearchTracePruneInput;\n}): Promise<RAGSearchTracePrunePreview> => {\n\tconst traces = normalizeTraceSummaryRuns(\n\t\tawait Promise.resolve(store.listTraces({ tag: input?.tag }))\n\t);\n\tconst pruned = applyRAGSearchTracePrunePolicy({\n\t\tinput,\n\t\ttraces\n\t});\n\n\treturn {\n\t\tinput,\n\t\tresult: {\n\t\t\tkeptCount: pruned.keptCount,\n\t\t\tremovedCount: pruned.removedCount\n\t\t},\n\t\tstatsAfter: buildRAGSearchTraceStatsFromTraces(pruned.next),\n\t\tstatsBefore: buildRAGSearchTraceStatsFromTraces(traces)\n\t};\n};\n\nexport const loadRAGAnswerGroundingEvaluationHistory = async ({\n\tstore,\n\tsuite,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGAnswerGroundingEvaluationHistoryStore;\n\tsuite: Pick<RAGEvaluationSuite, 'id' | 'label'>;\n\tlimit?: number;\n}): Promise<RAGAnswerGroundingEvaluationHistory> => {\n\tconst runs = normalizeGroundingHistoryRuns(\n\t\tawait Promise.resolve(\n\t\t\tstore.listRuns({\n\t\t\t\tlimit,\n\t\t\t\tsuiteId: suite.id\n\t\t\t})\n\t\t)\n\t);\n\tconst latestRun = runs[0];\n\tconst previousRun = runs[1];\n\n\treturn {\n\t\tcaseSnapshots: buildGroundingCaseSnapshots({\n\t\t\tcurrent: latestRun,\n\t\t\tprevious: previousRun\n\t\t}),\n\t\tdiff:\n\t\t\tlatestRun && previousRun\n\t\t\t\t? buildRAGAnswerGroundingEvaluationRunDiff({\n\t\t\t\t\t\tcurrent: latestRun,\n\t\t\t\t\t\tprevious: previousRun\n\t\t\t\t\t})\n\t\t\t\t: undefined,\n\t\tlatestRun,\n\t\tleaderboard: buildRAGAnswerGroundingEvaluationLeaderboard(runs),\n\t\tpreviousRun,\n\t\truns,\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id\n\t};\n};\n\nexport const loadRAGAnswerGroundingCaseDifficultyHistory = async ({\n\tstore,\n\tsuite,\n\tlimit = DEFAULT_HISTORY_LIMIT\n}: {\n\tstore: RAGAnswerGroundingCaseDifficultyHistoryStore;\n\tsuite: Pick<RAGEvaluationSuite, 'id' | 'label'>;\n\tlimit?: number;\n}): Promise<RAGAnswerGroundingCaseDifficultyHistory> => {\n\tconst runs = normalizeGroundingDifficultyHistoryRuns(\n\t\tawait Promise.resolve(\n\t\t\tstore.listRuns({\n\t\t\t\tlimit,\n\t\t\t\tsuiteId: suite.id\n\t\t\t})\n\t\t)\n\t);\n\tconst latestRun = runs[0];\n\tconst previousRun = runs[1];\n\n\treturn {\n\t\tdiff:\n\t\t\tlatestRun && previousRun\n\t\t\t\t? buildRAGAnswerGroundingCaseDifficultyRunDiff({\n\t\t\t\t\t\tcurrent: latestRun,\n\t\t\t\t\t\tprevious: previousRun\n\t\t\t\t\t})\n\t\t\t\t: undefined,\n\t\tlatestRun,\n\t\tpreviousRun,\n\t\truns,\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id,\n\t\ttrends: buildRAGAnswerGroundingCaseDifficultyTrends({ runs })\n\t};\n};\n\nexport const persistRAGEvaluationSuiteRun = async ({\n\tstore,\n\trun\n}: {\n\tstore: RAGEvaluationHistoryStore;\n\trun: RAGEvaluationSuiteRun;\n}) => {\n\tawait Promise.resolve(store.saveRun(run));\n\treturn run;\n};\n\nexport const persistRAGAnswerGroundingEvaluationRun = async ({\n\tstore,\n\trun\n}: {\n\tstore: RAGAnswerGroundingEvaluationHistoryStore;\n\trun: RAGAnswerGroundingEvaluationRun;\n}) => {\n\tawait Promise.resolve(store.saveRun(run));\n\treturn run;\n};\n\nexport const persistRAGAnswerGroundingCaseDifficultyRun = async ({\n\tstore,\n\trun\n}: {\n\tstore: RAGAnswerGroundingCaseDifficultyHistoryStore;\n\trun: RAGAnswerGroundingCaseDifficultyRun;\n}) => {\n\tawait Promise.resolve(store.saveRun(run));\n\treturn run;\n};\n\nexport const persistRAGSearchTraceRecord = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGSearchTraceStore;\n\trecord: RAGSearchTraceRecord;\n}) => {\n\tawait Promise.resolve(store.saveTrace(record));\n\treturn record;\n};\n\nexport const pruneRAGSearchTraceStore = async ({\n\tstore,\n\tinput\n}: {\n\tstore: RAGSearchTraceStore;\n\tinput?: RAGSearchTracePruneInput;\n}): Promise<RAGSearchTracePruneResult> =>\n\tPromise.resolve(store.pruneTraces(input));\n\nexport const persistRAGSearchTracePruneRun = async ({\n\tstore,\n\trun\n}: {\n\tstore: RAGSearchTracePruneHistoryStore;\n\trun: RAGSearchTracePruneRun;\n}) => {\n\tawait Promise.resolve(store.saveRun(run));\n\treturn run;\n};\n\nexport const persistRAGRetrievalComparisonRun = async ({\n\tstore,\n\trun\n}: {\n\tstore: RAGRetrievalComparisonHistoryStore;\n\trun: RAGRetrievalComparisonRun;\n}) => {\n\tawait Promise.resolve(store.saveRun(run));\n\treturn run;\n};\n\nexport const buildRAGRetrievalComparisonDecisionSummary = ({\n\tcomparison,\n\tbaselineRetrievalId,\n\tcandidateRetrievalId,\n\tpolicy\n}: {\n\tcomparison: RAGRetrievalComparison;\n\tbaselineRetrievalId?: string;\n\tcandidateRetrievalId?: string;\n\tpolicy?: RAGRetrievalBaselineGatePolicy;\n}): RAGRetrievalComparisonDecisionSummary | undefined => {\n\tconst baselineEntry =\n\t\tfindRetrievalComparisonEntry(comparison, baselineRetrievalId) ??\n\t\tcomparison.entries[0];\n\tconst candidateEntry =\n\t\tfindRetrievalComparisonEntry(comparison, candidateRetrievalId) ??\n\t\tcomparison.entries.find(\n\t\t\t(entry) => entry.retrievalId !== baselineEntry?.retrievalId\n\t\t) ??\n\t\tcomparison.entries[1];\n\n\tif (!baselineEntry && !candidateEntry) {\n\t\treturn undefined;\n\t}\n\n\tconst delta =\n\t\tbaselineEntry && candidateEntry\n\t\t\t? {\n\t\t\t\t\taverageF1Delta:\n\t\t\t\t\t\tcandidateEntry.response.summary.averageF1 -\n\t\t\t\t\t\tbaselineEntry.response.summary.averageF1,\n\t\t\t\t\telapsedMsDelta:\n\t\t\t\t\t\tcandidateEntry.response.elapsedMs -\n\t\t\t\t\t\tbaselineEntry.response.elapsedMs,\n\t\t\t\t\tpassingRateDelta:\n\t\t\t\t\t\tcandidateEntry.response.passingRate -\n\t\t\t\t\t\tbaselineEntry.response.passingRate,\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'title') > 0 ||\n\t\t\t\t\tcountPresentationCueCases(candidateEntry, 'title') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationTitleCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'title'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'title'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'body') > 0 ||\n\t\t\t\t\tcountPresentationCueCases(candidateEntry, 'body') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationBodyCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'body'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'body'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'notes') > 0 ||\n\t\t\t\t\tcountPresentationCueCases(candidateEntry, 'notes') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationNotesCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'notes'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'notes'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'sheet') > 0 ||\n\t\t\t\t\tcountSpreadsheetCueCases(candidateEntry, 'sheet') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetSheetCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'sheet'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'sheet'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'table') > 0 ||\n\t\t\t\t\tcountSpreadsheetCueCases(candidateEntry, 'table') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetTableCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'table'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'table'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'column') > 0 ||\n\t\t\t\t\tcountSpreadsheetCueCases(candidateEntry, 'column') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetColumnCueCasesDelta:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'column'\n\t\t\t\t\t\t\t\t\t) -\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'column'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\tmultiVectorCollapsedCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorCollapsedCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorCollapsedCases ?? 0),\n\t\t\t\t\tmultiVectorLexicalHitCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorLexicalHitCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorLexicalHitCases ?? 0),\n\t\t\t\t\tmultiVectorVectorHitCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorVectorHitCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.multiVectorVectorHitCases ?? 0),\n\t\t\t\t\tevidenceReconcileCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary?.stageCounts\n\t\t\t\t\t\t\t?.evidence_reconcile ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary?.stageCounts\n\t\t\t\t\t\t\t?.evidence_reconcile ?? 0),\n\t\t\t\t\tofficeEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.officeEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.officeEvidenceReconcileCases ?? 0),\n\t\t\t\t\tpdfEvidenceReconcileCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.pdfEvidenceReconcileCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.pdfEvidenceReconcileCases ?? 0),\n\t\t\t\t\truntimeCandidateBudgetExhaustedCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeCandidateBudgetExhaustedCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeCandidateBudgetExhaustedCases ?? 0),\n\t\t\t\t\truntimeUnderfilledTopKCasesDelta:\n\t\t\t\t\t\t(candidateEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeUnderfilledTopKCases ?? 0) -\n\t\t\t\t\t\t(baselineEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeUnderfilledTopKCases ?? 0)\n\t\t\t\t}\n\t\t\t: undefined;\n\n\treturn {\n\t\tbaseline: baselineEntry\n\t\t\t? {\n\t\t\t\t\taverageF1: baselineEntry.response.summary.averageF1,\n\t\t\t\t\telapsedMs: baselineEntry.response.elapsedMs,\n\t\t\t\t\tlabel: baselineEntry.label,\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'title') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationTitleCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'title'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'body') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationBodyCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'body'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(baselineEntry, 'notes') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationNotesCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'notes'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'sheet') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetSheetCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'sheet'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'table') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetTableCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'table'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(baselineEntry, 'column') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetColumnCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tbaselineEntry,\n\t\t\t\t\t\t\t\t\t\t'column'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\tmultiVectorCollapsedCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.multiVectorCollapsedCases,\n\t\t\t\t\tmultiVectorLexicalHitCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.multiVectorLexicalHitCases,\n\t\t\t\t\tmultiVectorVectorHitCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.multiVectorVectorHitCases,\n\t\t\t\t\tevidenceReconcileCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.stageCounts\n\t\t\t\t\t\t\t?.evidence_reconcile,\n\t\t\t\t\tofficeEvidenceReconcileCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary\n\t\t\t\t\t\t\t?.officeEvidenceReconcileCases,\n\t\t\t\t\tpdfEvidenceReconcileCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.pdfEvidenceReconcileCases,\n\t\t\t\t\truntimeCandidateBudgetExhaustedCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeCandidateBudgetExhaustedCases,\n\t\t\t\t\truntimeUnderfilledTopKCases:\n\t\t\t\t\t\tbaselineEntry.traceSummary?.runtimeUnderfilledTopKCases,\n\t\t\t\t\tpassingRate: baselineEntry.response.passingRate,\n\t\t\t\t\tretrievalId: baselineEntry.retrievalId\n\t\t\t\t}\n\t\t\t: undefined,\n\t\tbaselineRetrievalId: baselineEntry?.retrievalId,\n\t\tcandidate: candidateEntry\n\t\t\t? {\n\t\t\t\t\taverageF1: candidateEntry.response.summary.averageF1,\n\t\t\t\t\telapsedMs: candidateEntry.response.elapsedMs,\n\t\t\t\t\tlabel: candidateEntry.label,\n\t\t\t\t\t...(countPresentationCueCases(candidateEntry, 'title') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationTitleCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'title'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(candidateEntry, 'body') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationBodyCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'body'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countPresentationCueCases(candidateEntry, 'notes') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tpresentationNotesCueCases:\n\t\t\t\t\t\t\t\t\tcountPresentationCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'notes'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(candidateEntry, 'sheet') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetSheetCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'sheet'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(candidateEntry, 'table') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetTableCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'table'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\t...(countSpreadsheetCueCases(candidateEntry, 'column') > 0\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\tspreadsheetColumnCueCases:\n\t\t\t\t\t\t\t\t\tcountSpreadsheetCueCases(\n\t\t\t\t\t\t\t\t\t\tcandidateEntry,\n\t\t\t\t\t\t\t\t\t\t'column'\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t: {}),\n\t\t\t\t\tmultiVectorCollapsedCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary?.multiVectorCollapsedCases,\n\t\t\t\t\tmultiVectorLexicalHitCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary?.multiVectorLexicalHitCases,\n\t\t\t\t\tmultiVectorVectorHitCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary?.multiVectorVectorHitCases,\n\t\t\t\t\tevidenceReconcileCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary?.stageCounts\n\t\t\t\t\t\t\t?.evidence_reconcile,\n\t\t\t\t\tofficeEvidenceReconcileCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary\n\t\t\t\t\t\t\t?.officeEvidenceReconcileCases,\n\t\t\t\t\tpdfEvidenceReconcileCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary?.pdfEvidenceReconcileCases,\n\t\t\t\t\truntimeCandidateBudgetExhaustedCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeCandidateBudgetExhaustedCases,\n\t\t\t\t\truntimeUnderfilledTopKCases:\n\t\t\t\t\t\tcandidateEntry.traceSummary\n\t\t\t\t\t\t\t?.runtimeUnderfilledTopKCases,\n\t\t\t\t\tpassingRate: candidateEntry.response.passingRate,\n\t\t\t\t\tretrievalId: candidateEntry.retrievalId\n\t\t\t\t}\n\t\t\t: undefined,\n\t\tcandidateRetrievalId: candidateEntry?.retrievalId,\n\t\tdelta,\n\t\tfastest: comparison.summary.fastest,\n\t\tgate: evaluateRetrievalComparisonGate({ delta, policy }),\n\t\twinnerByAverageF1: comparison.summary.bestByAverageF1,\n\t\twinnerByPassingRate: comparison.summary.bestByPassingRate,\n\t\t...(comparison.summary.bestByPresentationTitleCueCases\n\t\t\t? {\n\t\t\t\t\twinnerByPresentationTitleCueCases:\n\t\t\t\t\t\tcomparison.summary.bestByPresentationTitleCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(comparison.summary.bestByPresentationBodyCueCases\n\t\t\t? {\n\t\t\t\t\twinnerByPresentationBodyCueCases:\n\t\t\t\t\t\tcomparison.summary.bestByPresentationBodyCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(comparison.summary.bestByPresentationNotesCueCases\n\t\t\t? {\n\t\t\t\t\twinnerByPresentationNotesCueCases:\n\t\t\t\t\t\tcomparison.summary.bestByPresentationNotesCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(comparison.summary.bestBySpreadsheetSheetCueCases\n\t\t\t? {\n\t\t\t\t\twinnerBySpreadsheetSheetCueCases:\n\t\t\t\t\t\tcomparison.summary.bestBySpreadsheetSheetCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(comparison.summary.bestBySpreadsheetTableCueCases\n\t\t\t? {\n\t\t\t\t\twinnerBySpreadsheetTableCueCases:\n\t\t\t\t\t\tcomparison.summary.bestBySpreadsheetTableCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(comparison.summary.bestBySpreadsheetColumnCueCases\n\t\t\t? {\n\t\t\t\t\twinnerBySpreadsheetColumnCueCases:\n\t\t\t\t\t\tcomparison.summary.bestBySpreadsheetColumnCueCases\n\t\t\t\t}\n\t\t\t: {}),\n\t\twinnerByMultivectorCollapsedCases:\n\t\t\tcomparison.summary.bestByMultivectorCollapsedCases,\n\t\twinnerByMultivectorLexicalHitCases:\n\t\t\tcomparison.summary.bestByMultivectorLexicalHitCases,\n\t\twinnerByMultivectorVectorHitCases:\n\t\t\tcomparison.summary.bestByMultivectorVectorHitCases,\n\t\twinnerByEvidenceReconcileCases:\n\t\t\tcomparison.summary.bestByEvidenceReconcileCases,\n\t\twinnerByOfficeEvidenceReconcileCases:\n\t\t\tcomparison.summary.bestByOfficeEvidenceReconcileCases,\n\t\twinnerByPDFEvidenceReconcileCases:\n\t\t\tcomparison.summary.bestByPDFEvidenceReconcileCases,\n\t\twinnerByLowestRuntimeCandidateBudgetExhaustedCases:\n\t\t\tcomparison.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases,\n\t\twinnerByLowestRuntimeUnderfilledTopKCases:\n\t\t\tcomparison.summary.bestByLowestRuntimeUnderfilledTopKCases\n\t};\n};\n\nexport const loadRAGSearchTracePruneHistory = async ({\n\tstore,\n\tlimit,\n\ttrigger\n}: {\n\tstore: RAGSearchTracePruneHistoryStore;\n\tlimit?: number;\n\ttrigger?: RAGSearchTracePruneRun['trigger'];\n}) =>\n\tnormalizeSearchTracePruneRuns(\n\t\tawait Promise.resolve(store.listRuns({ limit, trigger }))\n\t);\n\nexport const loadRAGRetrievalComparisonHistory = async ({\n\tstore,\n\tlimit,\n\tsuiteId,\n\tlabel,\n\twinnerId,\n\tcorpusGroupKey,\n\tgroupKey,\n\ttag\n}: {\n\tstore: RAGRetrievalComparisonHistoryStore;\n\tlimit?: number;\n\tsuiteId?: string;\n\tlabel?: string;\n\twinnerId?: string;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\ttag?: string;\n}) =>\n\tnormalizeRetrievalComparisonRuns(\n\t\tawait Promise.resolve(\n\t\t\tstore.listRuns({\n\t\t\t\tcorpusGroupKey,\n\t\t\t\tgroupKey,\n\t\t\t\tlabel,\n\t\t\t\tlimit,\n\t\t\t\tsuiteId,\n\t\t\t\ttag,\n\t\t\t\twinnerId\n\t\t\t})\n\t\t)\n\t);\n\nexport const loadRAGRetrievalBaselines = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\ttag,\n\tlimit,\n\tstatus\n}: {\n\tstore: RAGRetrievalBaselineStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\ttag?: string;\n\tlimit?: number;\n\tstatus?: RAGRetrievalBaselineRecord['status'];\n}) =>\n\tnormalizeRetrievalBaselineRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listBaselines({\n\t\t\t\tcorpusGroupKey,\n\t\t\t\tgroupKey,\n\t\t\t\tlimit,\n\t\t\t\tstatus,\n\t\t\t\ttag\n\t\t\t})\n\t\t)\n\t);\n\nexport const persistRAGRetrievalBaseline = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalBaselineStore;\n\trecord: RAGRetrievalBaselineRecord;\n}) => {\n\tawait Promise.resolve(store.saveBaseline(record));\n\treturn record;\n};\n\nexport const loadRAGRetrievalReleaseDecisions = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\tkind\n}: {\n\tstore: RAGRetrievalReleaseDecisionStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\tkind?: RAGRetrievalReleaseDecisionRecord['kind'];\n}) =>\n\tnormalizeRetrievalReleaseDecisionRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listDecisions({ corpusGroupKey, groupKey, kind, limit })\n\t\t)\n\t);\n\nexport const loadRAGRetrievalLaneHandoffDecisions = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\tkind,\n\tsourceRolloutLabel,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalLaneHandoffDecisionStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\tkind?: RAGRetrievalLaneHandoffDecisionRecord['kind'];\n\tsourceRolloutLabel?: RAGRetrievalLaneHandoffDecisionRecord['sourceRolloutLabel'];\n\ttargetRolloutLabel?: RAGRetrievalLaneHandoffDecisionRecord['targetRolloutLabel'];\n}) =>\n\tnormalizeRetrievalLaneHandoffDecisionRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listDecisions({\n\t\t\t\tcorpusGroupKey,\n\t\t\t\tgroupKey,\n\t\t\t\tkind,\n\t\t\t\tlimit,\n\t\t\t\tsourceRolloutLabel,\n\t\t\t\ttargetRolloutLabel\n\t\t\t})\n\t\t)\n\t);\n\nexport const loadRAGRetrievalReleaseIncidents = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\ttargetRolloutLabel,\n\tstatus,\n\tseverity\n}: {\n\tstore: RAGRetrievalReleaseIncidentStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalReleaseIncidentRecord['targetRolloutLabel'];\n\tstatus?: RAGRetrievalReleaseIncidentRecord['status'];\n\tseverity?: RAGRetrievalReleaseIncidentRecord['severity'];\n}) =>\n\tnormalizeRetrievalReleaseIncidentRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listIncidents({\n\t\t\t\tcorpusGroupKey,\n\t\t\t\tgroupKey,\n\t\t\t\tlimit,\n\t\t\t\tseverity,\n\t\t\t\tstatus,\n\t\t\t\ttargetRolloutLabel\n\t\t\t})\n\t\t)\n\t);\n\nexport const loadRAGRetrievalLaneHandoffIncidents = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\ttargetRolloutLabel,\n\tstatus,\n\tseverity\n}: {\n\tstore: RAGRetrievalLaneHandoffIncidentStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalLaneHandoffIncidentRecord['targetRolloutLabel'];\n\tstatus?: RAGRetrievalLaneHandoffIncidentRecord['status'];\n\tseverity?: RAGRetrievalLaneHandoffIncidentRecord['severity'];\n}) =>\n\tnormalizeRetrievalReleaseIncidentRecords(\n\t\t(await Promise.resolve(\n\t\t\tstore.listIncidents({\n\t\t\t\tcorpusGroupKey,\n\t\t\t\tgroupKey,\n\t\t\t\tlimit,\n\t\t\t\tseverity,\n\t\t\t\tstatus,\n\t\t\t\ttargetRolloutLabel\n\t\t\t})\n\t\t)) as RAGRetrievalReleaseIncidentRecord[]\n\t) as RAGRetrievalLaneHandoffIncidentRecord[];\n\nexport const loadRAGRetrievalLaneHandoffIncidentHistory = async ({\n\tstore,\n\tcorpusGroupKey,\n\taction,\n\tgroupKey,\n\tincidentId,\n\tlimit,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalLaneHandoffIncidentHistoryStore;\n\tcorpusGroupKey?: string;\n\taction?: RAGRetrievalLaneHandoffIncidentHistoryRecord['action'];\n\tgroupKey?: string;\n\tincidentId?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalLaneHandoffIncidentRecord['targetRolloutLabel'];\n}) =>\n\t(await Promise.resolve(\n\t\tstore.listRecords({\n\t\t\tcorpusGroupKey,\n\t\t\taction,\n\t\t\tgroupKey,\n\t\t\tincidentId,\n\t\t\tlimit,\n\t\t\ttargetRolloutLabel\n\t\t})\n\t)) as RAGRetrievalLaneHandoffIncidentHistoryRecord[];\n\nexport const loadRAGRetrievalIncidentRemediationDecisions = async ({\n\tstore,\n\tgroupKey,\n\tincidentId,\n\tlimit,\n\tremediationKind,\n\tstatus,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalIncidentRemediationDecisionStore;\n\tgroupKey?: string;\n\tincidentId?: string;\n\tlimit?: number;\n\tremediationKind?: RAGRetrievalIncidentRemediationDecisionRecord['remediationKind'];\n\tstatus?: RAGRetrievalIncidentRemediationDecisionRecord['status'];\n\ttargetRolloutLabel?: RAGRetrievalIncidentRemediationDecisionRecord['targetRolloutLabel'];\n}) =>\n\tnormalizeRetrievalIncidentRemediationDecisionRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listRecords({\n\t\t\t\tgroupKey,\n\t\t\t\tincidentId,\n\t\t\t\tlimit,\n\t\t\t\tremediationKind,\n\t\t\t\tstatus,\n\t\t\t\ttargetRolloutLabel\n\t\t\t})\n\t\t)\n\t);\n\nexport const loadRAGRetrievalIncidentRemediationExecutionHistory = async ({\n\tstore,\n\tactionKind,\n\tblockedByGuardrail,\n\tcode,\n\tgroupKey,\n\tidempotentReplay,\n\tincidentId,\n\tlimit,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalIncidentRemediationExecutionHistoryStore;\n\tactionKind?: RAGRemediationAction['kind'];\n\tblockedByGuardrail?: boolean;\n\tcode?: RAGRetrievalIncidentRemediationExecutionHistoryRecord['code'];\n\tgroupKey?: string;\n\tidempotentReplay?: boolean;\n\tincidentId?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalIncidentRemediationExecutionHistoryRecord['targetRolloutLabel'];\n}) =>\n\tnormalizeRetrievalIncidentRemediationExecutionHistoryRecords(\n\t\tawait Promise.resolve(\n\t\t\tstore.listRecords({\n\t\t\t\tactionKind,\n\t\t\t\tblockedByGuardrail,\n\t\t\t\tcode,\n\t\t\t\tgroupKey,\n\t\t\t\tidempotentReplay,\n\t\t\t\tincidentId,\n\t\t\t\tlimit,\n\t\t\t\ttargetRolloutLabel\n\t\t\t})\n\t\t)\n\t);\n\nexport const loadRAGRetrievalLaneHandoffAutoCompletePolicyHistory = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord['targetRolloutLabel'];\n}) =>\n\t(await Promise.resolve(\n\t\tstore.listRecords({\n\t\t\tcorpusGroupKey,\n\t\t\tgroupKey,\n\t\t\tlimit,\n\t\t\ttargetRolloutLabel\n\t\t})\n\t)) as RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalReleaseLanePolicyHistory = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\trolloutLabel,\n\tscope\n}: {\n\tstore: RAGRetrievalReleaseLanePolicyHistoryStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\trolloutLabel?: RAGRetrievalReleaseLanePolicyHistoryRecord['rolloutLabel'];\n\tscope?: RAGRetrievalReleaseLanePolicyHistoryRecord['scope'];\n}) =>\n\t(await Promise.resolve(\n\t\tstore.listRecords({\n\t\t\tcorpusGroupKey,\n\t\t\tgroupKey,\n\t\t\tlimit,\n\t\t\trolloutLabel,\n\t\t\tscope\n\t\t})\n\t)) as RAGRetrievalReleaseLanePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalBaselineGatePolicyHistory = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\trolloutLabel,\n\tscope\n}: {\n\tstore: RAGRetrievalBaselineGatePolicyHistoryStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\trolloutLabel?: RAGRetrievalBaselineGatePolicyHistoryRecord['rolloutLabel'];\n\tscope?: RAGRetrievalBaselineGatePolicyHistoryRecord['scope'];\n}) =>\n\t(await Promise.resolve(\n\t\tstore.listRecords({\n\t\t\tcorpusGroupKey,\n\t\t\tgroupKey,\n\t\t\tlimit,\n\t\t\trolloutLabel,\n\t\t\tscope\n\t\t})\n\t)) as RAGRetrievalBaselineGatePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalReleaseLaneEscalationPolicyHistory = async ({\n\tstore,\n\tcorpusGroupKey,\n\tgroupKey,\n\tlimit,\n\ttargetRolloutLabel\n}: {\n\tstore: RAGRetrievalReleaseLaneEscalationPolicyHistoryStore;\n\tcorpusGroupKey?: string;\n\tgroupKey?: string;\n\tlimit?: number;\n\ttargetRolloutLabel?: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord['targetRolloutLabel'];\n}) =>\n\t(await Promise.resolve(\n\t\tstore.listRecords({\n\t\t\tgroupKey,\n\t\t\tlimit,\n\t\t\ttargetRolloutLabel\n\t\t})\n\t)) as RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord[];\n\nexport const persistRAGRetrievalReleaseDecision = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalReleaseDecisionStore;\n\trecord: RAGRetrievalReleaseDecisionRecord;\n}) => {\n\tawait Promise.resolve(store.saveDecision(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalLaneHandoffDecision = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalLaneHandoffDecisionStore;\n\trecord: RAGRetrievalLaneHandoffDecisionRecord;\n}) => {\n\tawait Promise.resolve(store.saveDecision(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalReleaseIncident = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalReleaseIncidentStore;\n\trecord: RAGRetrievalReleaseIncidentRecord;\n}) => {\n\tawait Promise.resolve(store.saveIncident(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalLaneHandoffIncident = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalLaneHandoffIncidentStore;\n\trecord: RAGRetrievalLaneHandoffIncidentRecord;\n}) => {\n\tawait Promise.resolve(store.saveIncident(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalIncidentRemediationDecision = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalIncidentRemediationDecisionStore;\n\trecord: RAGRetrievalIncidentRemediationDecisionRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalIncidentRemediationExecutionHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalIncidentRemediationExecutionHistoryStore;\n\trecord: RAGRetrievalIncidentRemediationExecutionHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalLaneHandoffIncidentHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalLaneHandoffIncidentHistoryStore;\n\trecord: RAGRetrievalLaneHandoffIncidentHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalLaneHandoffAutoCompletePolicyHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore;\n\trecord: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalReleaseLanePolicyHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalReleaseLanePolicyHistoryStore;\n\trecord: RAGRetrievalReleaseLanePolicyHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalBaselineGatePolicyHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalBaselineGatePolicyHistoryStore;\n\trecord: RAGRetrievalBaselineGatePolicyHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const persistRAGRetrievalReleaseLaneEscalationPolicyHistory = async ({\n\tstore,\n\trecord\n}: {\n\tstore: RAGRetrievalReleaseLaneEscalationPolicyHistoryStore;\n\trecord: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord;\n}) => {\n\tawait Promise.resolve(store.saveRecord(record));\n\treturn record;\n};\n\nexport const createRAGSQLiteGovernanceStores = (\n\toptions: SQLiteRAGGovernanceStoreBundleOptions = {}\n): Pick<\n\tRAGChatPluginConfig,\n\t| 'searchTraceStore'\n\t| 'searchTracePruneHistoryStore'\n\t| 'retrievalComparisonHistoryStore'\n\t| 'retrievalBaselineStore'\n\t| 'retrievalReleaseDecisionStore'\n\t| 'retrievalLaneHandoffDecisionStore'\n\t| 'retrievalLaneHandoffIncidentStore'\n\t| 'retrievalLaneHandoffIncidentHistoryStore'\n\t| 'retrievalLaneHandoffAutoCompletePolicyHistoryStore'\n\t| 'retrievalReleaseLanePolicyHistoryStore'\n\t| 'retrievalBaselineGatePolicyHistoryStore'\n\t| 'retrievalReleaseLaneEscalationPolicyHistoryStore'\n\t| 'retrievalReleaseIncidentStore'\n\t| 'retrievalIncidentRemediationDecisionStore'\n\t| 'retrievalIncidentRemediationExecutionHistoryStore'\n> => {\n\tconst prefix = options.tablePrefix?.trim();\n\tconst table = (suffix: string) =>\n\t\tprefix && prefix.length > 0 ? `${prefix}_${suffix}` : suffix;\n\n\treturn {\n\t\tsearchTraceStore: createRAGSQLiteSearchTraceStore({\n\t\t\tdb: options.db,\n\t\t\tpath: options.path,\n\t\t\ttableName: table('rag_search_traces')\n\t\t}),\n\t\tsearchTracePruneHistoryStore:\n\t\t\tcreateRAGSQLiteSearchTracePruneHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_search_trace_prune_history')\n\t\t\t}),\n\t\tretrievalComparisonHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalComparisonHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_comparison_history')\n\t\t\t}),\n\t\tretrievalBaselineStore: createRAGSQLiteRetrievalBaselineStore({\n\t\t\tdb: options.db,\n\t\t\tpath: options.path,\n\t\t\ttableName: table('rag_retrieval_baselines')\n\t\t}),\n\t\tretrievalReleaseDecisionStore:\n\t\t\tcreateRAGSQLiteRetrievalReleaseDecisionStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_release_decisions')\n\t\t\t}),\n\t\tretrievalLaneHandoffDecisionStore:\n\t\t\tcreateRAGSQLiteRetrievalLaneHandoffDecisionStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_lane_handoff_decisions')\n\t\t\t}),\n\t\tretrievalLaneHandoffIncidentStore:\n\t\t\tcreateRAGSQLiteRetrievalLaneHandoffIncidentStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_lane_handoff_incidents')\n\t\t\t}),\n\t\tretrievalLaneHandoffIncidentHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalLaneHandoffIncidentHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_lane_handoff_incident_history')\n\t\t\t}),\n\t\tretrievalLaneHandoffAutoCompletePolicyHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalLaneHandoffAutoCompletePolicyHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table(\n\t\t\t\t\t'rag_retrieval_lane_handoff_auto_complete_policy_history'\n\t\t\t\t)\n\t\t\t}),\n\t\tretrievalReleaseLanePolicyHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalReleaseLanePolicyHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_release_lane_policy_history')\n\t\t\t}),\n\t\tretrievalBaselineGatePolicyHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalBaselineGatePolicyHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_baseline_gate_policy_history')\n\t\t\t}),\n\t\tretrievalReleaseLaneEscalationPolicyHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalReleaseLaneEscalationPolicyHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table(\n\t\t\t\t\t'rag_retrieval_release_lane_escalation_policy_history'\n\t\t\t\t)\n\t\t\t}),\n\t\tretrievalReleaseIncidentStore:\n\t\t\tcreateRAGSQLiteRetrievalReleaseIncidentStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_release_incidents')\n\t\t\t}),\n\t\tretrievalIncidentRemediationDecisionStore:\n\t\t\tcreateRAGSQLiteRetrievalIncidentRemediationDecisionStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table('rag_retrieval_incident_remediation_decisions')\n\t\t\t}),\n\t\tretrievalIncidentRemediationExecutionHistoryStore:\n\t\t\tcreateRAGSQLiteRetrievalIncidentRemediationExecutionHistoryStore({\n\t\t\t\tdb: options.db,\n\t\t\t\tpath: options.path,\n\t\t\t\ttableName: table(\n\t\t\t\t\t'rag_retrieval_incident_remediation_execution_history'\n\t\t\t\t)\n\t\t\t})\n\t};\n};\n\nexport const buildRAGEvaluationResponse = (\n\tcases: RAGEvaluationCaseResult[]\n): RAGEvaluationResponse => {\n\tconst totalCases = cases.length;\n\tconst corpusKeys = [\n\t\t...new Set(cases.flatMap((entry) => entry.corpusKey ?? []))\n\t];\n\tconst passedCases = cases.filter((entry) => entry.status === 'pass').length;\n\tconst partialCases = cases.filter(\n\t\t(entry) => entry.status === 'partial'\n\t).length;\n\tconst failedCases = cases.filter((entry) => entry.status === 'fail').length;\n\n\treturn {\n\t\tcases,\n\t\t...(corpusKeys.length > 0 ? { corpusKeys } : {}),\n\t\telapsedMs: cases.reduce((sum, result) => sum + result.elapsedMs, 0),\n\t\tok: true,\n\t\tpassingRate: totalCases > 0 ? (passedCases / totalCases) * 100 : 0,\n\t\tsummary: {\n\t\t\taverageF1:\n\t\t\t\tcases.reduce((sum, result) => sum + result.f1, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\taverageLatencyMs:\n\t\t\t\tcases.reduce((sum, result) => sum + result.elapsedMs, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\taveragePrecision:\n\t\t\t\tcases.reduce((sum, result) => sum + result.precision, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\taverageRecall:\n\t\t\t\tcases.reduce((sum, result) => sum + result.recall, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\tfailedCases,\n\t\t\tpartialCases,\n\t\t\tpassedCases,\n\t\t\ttotalCases\n\t\t},\n\t\ttotalCases\n\t};\n};\n\nconst incrementFailureCounts = (\n\ttarget: Record<string, number>,\n\tfailureClasses: string[] | undefined\n) => {\n\tfor (const failureClass of failureClasses ?? []) {\n\t\ttarget[failureClass] = (target[failureClass] ?? 0) + 1;\n\t}\n};\n\nconst sortEntityQualitySummaries = <\n\tT extends { passingRate: number; totalCases: number; label: string }\n>(\n\tentries: T[]\n) =>\n\tentries.sort((left, right) => {\n\t\tif (right.passingRate !== left.passingRate) {\n\t\t\treturn right.passingRate - left.passingRate;\n\t\t}\n\t\tif (right.totalCases !== left.totalCases) {\n\t\t\treturn right.totalCases - left.totalCases;\n\t\t}\n\n\t\treturn left.label.localeCompare(right.label);\n\t});\n\nexport const buildRAGEvaluationEntityQualityView = (\n\tresponse: RAGEvaluationResponse\n): RAGEvaluationEntityQualityView => {\n\tconst bySource = new Map<string, RAGEvaluationEntityQualitySummary>();\n\tconst byDocument = new Map<string, RAGEvaluationEntityQualitySummary>();\n\tfor (const entry of response.cases) {\n\t\tconst targets =\n\t\t\tentry.mode === 'source'\n\t\t\t\t? entry.expectedIds\n\t\t\t\t: entry.mode === 'documentId'\n\t\t\t\t\t? entry.expectedIds\n\t\t\t\t\t: [];\n\t\tconst targetMap =\n\t\t\tentry.mode === 'source'\n\t\t\t\t? bySource\n\t\t\t\t: entry.mode === 'documentId'\n\t\t\t\t\t? byDocument\n\t\t\t\t\t: undefined;\n\t\tif (!targetMap) {\n\t\t\tcontinue;\n\t\t}\n\t\tfor (const target of targets) {\n\t\t\tconst current =\n\t\t\t\ttargetMap.get(target) ??\n\t\t\t\t({\n\t\t\t\t\taverageF1: 0,\n\t\t\t\t\tcaseIds: [],\n\t\t\t\t\tentityType: entry.mode === 'source' ? 'source' : 'document',\n\t\t\t\t\tfailedCases: 0,\n\t\t\t\t\tfailureCounts: {},\n\t\t\t\t\tkey: target,\n\t\t\t\t\tlabel: target,\n\t\t\t\t\tpassedCases: 0,\n\t\t\t\t\tpassingRate: 0,\n\t\t\t\t\tpartialCases: 0,\n\t\t\t\t\ttotalCases: 0\n\t\t\t\t} satisfies RAGEvaluationEntityQualitySummary);\n\t\t\tcurrent.totalCases += 1;\n\t\t\tcurrent.averageF1 += entry.f1;\n\t\t\tcurrent.caseIds.push(entry.caseId);\n\t\t\tif (entry.status === 'pass') {\n\t\t\t\tcurrent.passedCases += 1;\n\t\t\t} else if (entry.status === 'partial') {\n\t\t\t\tcurrent.partialCases += 1;\n\t\t\t} else {\n\t\t\t\tcurrent.failedCases += 1;\n\t\t\t}\n\t\t\tincrementFailureCounts(current.failureCounts, entry.failureClasses);\n\t\t\ttargetMap.set(target, current);\n\t\t}\n\t}\n\n\tfor (const map of [bySource, byDocument]) {\n\t\tfor (const entry of map.values()) {\n\t\t\tentry.averageF1 =\n\t\t\t\tentry.totalCases > 0 ? entry.averageF1 / entry.totalCases : 0;\n\t\t\tentry.passingRate =\n\t\t\t\tentry.totalCases > 0\n\t\t\t\t\t? (entry.passedCases / entry.totalCases) * 100\n\t\t\t\t\t: 0;\n\t\t}\n\t}\n\n\treturn {\n\t\tbyDocument: sortEntityQualitySummaries([...byDocument.values()]),\n\t\tbySource: sortEntityQualitySummaries([...bySource.values()])\n\t};\n};\n\nexport const buildRAGAnswerGroundingEntityQualityView = (\n\tresponse: RAGAnswerGroundingEvaluationResponse\n): RAGAnswerGroundingEntityQualityView => {\n\tconst bySource = new Map<string, RAGAnswerGroundingEntityQualitySummary>();\n\tconst byDocument = new Map<\n\t\tstring,\n\t\tRAGAnswerGroundingEntityQualitySummary\n\t>();\n\tfor (const entry of response.cases) {\n\t\tconst targetMap =\n\t\t\tentry.mode === 'source'\n\t\t\t\t? bySource\n\t\t\t\t: entry.mode === 'documentId'\n\t\t\t\t\t? byDocument\n\t\t\t\t\t: undefined;\n\t\tif (!targetMap) {\n\t\t\tcontinue;\n\t\t}\n\t\tfor (const target of entry.expectedIds) {\n\t\t\tconst current =\n\t\t\t\ttargetMap.get(target) ??\n\t\t\t\t({\n\t\t\t\t\taverageCitationF1: 0,\n\t\t\t\t\taverageResolvedCitationRate: 0,\n\t\t\t\t\tcaseIds: [],\n\t\t\t\t\tentityType: entry.mode === 'source' ? 'source' : 'document',\n\t\t\t\t\tfailedCases: 0,\n\t\t\t\t\tfailureCounts: {},\n\t\t\t\t\tkey: target,\n\t\t\t\t\tlabel: target,\n\t\t\t\t\tpassedCases: 0,\n\t\t\t\t\tpassingRate: 0,\n\t\t\t\t\tpartialCases: 0,\n\t\t\t\t\ttotalCases: 0\n\t\t\t\t} satisfies RAGAnswerGroundingEntityQualitySummary);\n\t\t\tcurrent.totalCases += 1;\n\t\t\tcurrent.averageCitationF1 += entry.citationF1;\n\t\t\tcurrent.averageResolvedCitationRate += entry.resolvedCitationRate;\n\t\t\tcurrent.caseIds.push(entry.caseId);\n\t\t\tif (entry.status === 'pass') {\n\t\t\t\tcurrent.passedCases += 1;\n\t\t\t} else if (entry.status === 'partial') {\n\t\t\t\tcurrent.partialCases += 1;\n\t\t\t} else {\n\t\t\t\tcurrent.failedCases += 1;\n\t\t\t}\n\t\t\tincrementFailureCounts(current.failureCounts, entry.failureClasses);\n\t\t\ttargetMap.set(target, current);\n\t\t}\n\t}\n\n\tfor (const map of [bySource, byDocument]) {\n\t\tfor (const entry of map.values()) {\n\t\t\tentry.averageCitationF1 =\n\t\t\t\tentry.totalCases > 0\n\t\t\t\t\t? entry.averageCitationF1 / entry.totalCases\n\t\t\t\t\t: 0;\n\t\t\tentry.averageResolvedCitationRate =\n\t\t\t\tentry.totalCases > 0\n\t\t\t\t\t? entry.averageResolvedCitationRate / entry.totalCases\n\t\t\t\t\t: 0;\n\t\t\tentry.passingRate =\n\t\t\t\tentry.totalCases > 0\n\t\t\t\t\t? (entry.passedCases / entry.totalCases) * 100\n\t\t\t\t\t: 0;\n\t\t}\n\t}\n\n\treturn {\n\t\tbyDocument: sortEntityQualitySummaries([...byDocument.values()]),\n\t\tbySource: sortEntityQualitySummaries([...bySource.values()])\n\t};\n};\n\nexport const evaluateRAGAnswerGroundingCase = ({\n\tcaseIndex,\n\tcaseInput\n}: {\n\tcaseIndex: number;\n\tcaseInput: RAGAnswerGroundingEvaluationCase;\n}): RAGAnswerGroundingEvaluationCaseResult => {\n\tconst mode = resolveEvaluationMode(caseInput);\n\tconst expectedIds = normalizeExpectedIds(\n\t\tmode === 'chunkId'\n\t\t\t? (caseInput.expectedChunkIds ?? [])\n\t\t\t: mode === 'source'\n\t\t\t\t? (caseInput.expectedSources ?? [])\n\t\t\t\t: (caseInput.expectedDocumentIds ?? [])\n\t);\n\tconst groundedAnswer = buildRAGGroundedAnswer(\n\t\tcaseInput.answer,\n\t\tcaseInput.sources\n\t);\n\tconst citedReferences = groundedAnswer.parts.flatMap((part) =>\n\t\tpart.type === 'citation' ? part.references : []\n\t);\n\tconst citedIds = normalizeExpectedIds(\n\t\tcitedReferences.map((reference) => extractExpectedId(reference, mode))\n\t);\n\tconst expectedSet = new Set(expectedIds);\n\tconst citedSet = new Set(citedIds);\n\tconst matchedIds = normalizeExpectedIds(\n\t\t[...expectedSet].filter((id) => citedSet.has(id))\n\t);\n\tconst missingIds = normalizeExpectedIds(\n\t\t[...expectedSet].filter((id) => !citedSet.has(id))\n\t);\n\tconst extraIds = normalizeExpectedIds(\n\t\t[...citedSet].filter((id) => !expectedSet.has(id))\n\t);\n\tconst matchedCount = matchedIds.length;\n\tconst expectedCount = expectedIds.length;\n\tconst citedCount = citedIds.length;\n\tconst precision = citedCount > 0 ? matchedCount / citedCount : 0;\n\tconst recall = expectedCount > 0 ? matchedCount / expectedCount : 0;\n\tconst citationF1 =\n\t\tprecision + recall > 0\n\t\t\t? (2 * precision * recall) / (precision + recall)\n\t\t\t: 0;\n\tconst citationCount = groundedAnswer.parts.filter(\n\t\t(part) => part.type === 'citation'\n\t).length;\n\tconst unresolvedCitationCount = new Set(\n\t\tgroundedAnswer.ungroundedReferenceNumbers\n\t).size;\n\tconst resolvedCitationCount = citedReferences.length;\n\tconst resolvedCitationRate =\n\t\tcitationCount > 0\n\t\t\t? Math.min(1, resolvedCitationCount / citationCount)\n\t\t\t: 0;\n\n\treturn {\n\t\tanswer: caseInput.answer,\n\t\tcaseId: caseInput.id ?? `case-${caseIndex + 1}`,\n\t\tcitationCount,\n\t\tcitationF1,\n\t\tcitationPrecision: precision,\n\t\tcitationRecall: recall,\n\t\tcitedIds,\n\t\tcoverage: groundedAnswer.coverage,\n\t\texpectedCount,\n\t\texpectedIds,\n\t\textraIds,\n\t\tgroundedAnswer,\n\t\thasCitations: groundedAnswer.hasCitations,\n\t\tlabel: caseInput.label,\n\t\tmatchedCount,\n\t\tmatchedIds,\n\t\tfailureClasses: classifyRAGGroundingFailure({\n\t\t\tavailableSources: caseInput.sources,\n\t\t\tcitationCount,\n\t\t\texpectedCount,\n\t\t\textraIds,\n\t\t\tmatchedCount,\n\t\t\tmissingIds,\n\t\t\tunresolvedCitationCount\n\t\t}),\n\t\tmetadata: caseInput.metadata,\n\t\tmissingIds,\n\t\tmode,\n\t\tquery: caseInput.query,\n\t\treferenceCount: groundedAnswer.references.length,\n\t\tresolvedCitationCount,\n\t\tresolvedCitationRate,\n\t\tstatus: buildAnswerGroundingStatus({\n\t\t\tcoverage: groundedAnswer.coverage,\n\t\t\texpectedCount,\n\t\t\tmatchedCount,\n\t\t\tresolvedCitationCount,\n\t\t\tunresolvedCitationCount\n\t\t}),\n\t\tunresolvedCitationCount\n\t};\n};\n\nexport const buildRAGAnswerGroundingEvaluationResponse = (\n\tcases: RAGAnswerGroundingEvaluationCaseResult[]\n): RAGAnswerGroundingEvaluationResponse => {\n\tconst totalCases = cases.length;\n\tconst passedCases = cases.filter((entry) => entry.status === 'pass').length;\n\tconst partialCases = cases.filter(\n\t\t(entry) => entry.status === 'partial'\n\t).length;\n\tconst failedCases = cases.filter((entry) => entry.status === 'fail').length;\n\tconst groundedCases = cases.filter(\n\t\t(entry) => entry.coverage === 'grounded'\n\t).length;\n\tconst partiallyGroundedCases = cases.filter(\n\t\t(entry) => entry.coverage === 'partial'\n\t).length;\n\tconst ungroundedCases = cases.filter(\n\t\t(entry) => entry.coverage === 'ungrounded'\n\t).length;\n\n\treturn {\n\t\tcases,\n\t\tok: true,\n\t\tpassingRate: totalCases > 0 ? (passedCases / totalCases) * 100 : 0,\n\t\tsummary: {\n\t\t\taverageCitationF1:\n\t\t\t\tcases.reduce((sum, result) => sum + result.citationF1, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\taverageCitationPrecision:\n\t\t\t\tcases.reduce(\n\t\t\t\t\t(sum, result) => sum + result.citationPrecision,\n\t\t\t\t\t0\n\t\t\t\t) / (totalCases || 1),\n\t\t\taverageCitationRecall:\n\t\t\t\tcases.reduce((sum, result) => sum + result.citationRecall, 0) /\n\t\t\t\t(totalCases || 1),\n\t\t\taverageResolvedCitationRate:\n\t\t\t\tcases.reduce(\n\t\t\t\t\t(sum, result) => sum + result.resolvedCitationRate,\n\t\t\t\t\t0\n\t\t\t\t) / (totalCases || 1),\n\t\t\tfailedCases,\n\t\t\tgroundedCases,\n\t\t\tpartiallyGroundedCases,\n\t\t\tpassedCases,\n\t\t\tpartialCases,\n\t\t\ttotalCases,\n\t\t\tungroundedCases\n\t\t},\n\t\ttotalCases\n\t};\n};\n\nexport const evaluateRAGAnswerGrounding = (\n\tinput: RAGAnswerGroundingEvaluationInput\n): RAGAnswerGroundingEvaluationResponse =>\n\tbuildRAGAnswerGroundingEvaluationResponse(\n\t\tinput.cases.map((caseInput, caseIndex) =>\n\t\t\tevaluateRAGAnswerGroundingCase({ caseIndex, caseInput })\n\t\t)\n\t);\nexport const compareRAGRerankers = async ({\n\tcollection,\n\tsuite,\n\trerankers,\n\tdefaultTopK = DEFAULT_TOP_K\n}: {\n\tcollection: RAGCollection;\n\tsuite: RAGEvaluationSuite;\n\trerankers: RAGRerankerCandidate[];\n\tdefaultTopK?: number;\n}): Promise<RAGRerankerComparison> => {\n\tconst entries = await Promise.all(\n\t\trerankers.map(async (candidate) => {\n\t\t\tconst evaluated = await evaluateRAGCollectionCases({\n\t\t\t\tcollection,\n\t\t\t\tdefaultTopK,\n\t\t\t\tinput: suite.input,\n\t\t\t\tincludeTrace: true,\n\t\t\t\trerank: candidate.rerank\n\t\t\t});\n\t\t\tconst response = buildRAGEvaluationResponse(\n\t\t\t\tevaluated.map((entry) => entry.caseResult)\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\tcaseTraceSnapshots:\n\t\t\t\t\tbuildEvaluationCaseTraceSnapshotsFromEvaluated(evaluated),\n\t\t\t\tlabel: candidate.label ?? candidate.id,\n\t\t\t\tproviderName:\n\t\t\t\t\ttypeof candidate.rerank === 'function'\n\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t: candidate.rerank?.providerName,\n\t\t\t\tresponse,\n\t\t\t\trerankerId: candidate.id,\n\t\t\t\ttraceSummary: summarizeRetrievalTraces(\n\t\t\t\t\tevaluated\n\t\t\t\t\t\t.map((entry) => entry.trace)\n\t\t\t\t\t\t.filter((trace): trace is RAGRetrievalTrace =>\n\t\t\t\t\t\t\tBoolean(trace)\n\t\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t} satisfies RAGRerankerComparisonEntry;\n\t\t})\n\t);\n\n\tconst leaderboard = buildRAGEvaluationLeaderboard(\n\t\tentries.map((entry) => ({\n\t\t\telapsedMs: entry.response.elapsedMs,\n\t\t\tfinishedAt: 0,\n\t\t\tid: entry.rerankerId,\n\t\t\tlabel: entry.label,\n\t\t\tresponse: entry.response,\n\t\t\tstartedAt: 0,\n\t\t\tsuiteId: suite.id,\n\t\t\ttraceSummary: entry.traceSummary\n\t\t}))\n\t);\n\n\treturn {\n\t\tentries,\n\t\tleaderboard,\n\t\tsummary: summarizeRAGRerankerComparison(entries),\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id\n\t};\n};\nconst summarizeEvaluationResponseComparison = <\n\tTEntry extends {\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry\n) => {\n\tif (entries.length === 0) {\n\t\treturn {};\n\t}\n\n\tconst byPassingRate = [...entries].sort((left, right) => {\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst byAverageF1 = [...entries].sort(\n\t\t(left, right) =>\n\t\t\tright.response.summary.averageF1 - left.response.summary.averageF1\n\t);\n\tconst byLatency = [...entries].sort(\n\t\t(left, right) =>\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t);\n\tconst getId = (entry: TEntry) =>\n\t\ttypeof entry[idKey] === 'string' ? (entry[idKey] as string) : undefined;\n\n\treturn {\n\t\tbestByAverageF1: getId(byAverageF1[0] as TEntry),\n\t\tbestByPassingRate: getId(byPassingRate[0] as TEntry),\n\t\tfastest: getId(byLatency[0] as TEntry)\n\t};\n};\n\nconst selectComparisonEntryByTraceMetric = <\n\tTEntry extends {\n\t\ttraceSummary?: RAGRetrievalTraceComparisonSummary;\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry,\n\tmetric: keyof Pick<\n\t\tRAGRetrievalTraceComparisonSummary,\n\t\t| 'multiVectorCollapsedCases'\n\t\t| 'multiVectorLexicalHitCases'\n\t\t| 'multiVectorVectorHitCases'\n\t\t| 'officeEvidenceReconcileCases'\n\t\t| 'officeParagraphEvidenceReconcileCases'\n\t\t| 'officeListEvidenceReconcileCases'\n\t\t| 'officeTableEvidenceReconcileCases'\n\t\t| 'pdfEvidenceReconcileCases'\n\t>\n) => {\n\tconst ranked = [...entries].sort((left, right) => {\n\t\tconst leftMetric = left.traceSummary?.[metric] ?? 0;\n\t\tconst rightMetric = right.traceSummary?.[metric] ?? 0;\n\t\tif (rightMetric !== leftMetric) {\n\t\t\treturn rightMetric - leftMetric;\n\t\t}\n\t\tconst leftEvidenceScore =\n\t\t\t(left.traceSummary?.multiVectorCollapsedCases ?? 0) +\n\t\t\t(left.traceSummary?.multiVectorLexicalHitCases ?? 0) +\n\t\t\t(left.traceSummary?.multiVectorVectorHitCases ?? 0);\n\t\tconst rightEvidenceScore =\n\t\t\t(right.traceSummary?.multiVectorCollapsedCases ?? 0) +\n\t\t\t(right.traceSummary?.multiVectorLexicalHitCases ?? 0) +\n\t\t\t(right.traceSummary?.multiVectorVectorHitCases ?? 0);\n\t\tif (rightEvidenceScore !== leftEvidenceScore) {\n\t\t\treturn rightEvidenceScore - leftEvidenceScore;\n\t\t}\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst winner = ranked[0];\n\tif (!winner || (winner.traceSummary?.[metric] ?? 0) === 0) {\n\t\treturn undefined;\n\t}\n\n\treturn typeof winner[idKey] === 'string'\n\t\t? (winner[idKey] as string)\n\t\t: undefined;\n};\n\nconst selectComparisonEntryByLowestTraceMetric = <\n\tTEntry extends {\n\t\ttraceSummary?: RAGRetrievalTraceComparisonSummary;\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry,\n\tmetric: keyof Pick<\n\t\tRAGRetrievalTraceComparisonSummary,\n\t\t'runtimeCandidateBudgetExhaustedCases' | 'runtimeUnderfilledTopKCases'\n\t>\n) => {\n\tconst ranked = [...entries].sort((left, right) => {\n\t\tconst leftMetric = left.traceSummary?.[metric] ?? 0;\n\t\tconst rightMetric = right.traceSummary?.[metric] ?? 0;\n\t\tif (leftMetric !== rightMetric) {\n\t\t\treturn leftMetric - rightMetric;\n\t\t}\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst winner = ranked[0];\n\treturn typeof winner?.[idKey] === 'string'\n\t\t? (winner[idKey] as string)\n\t\t: undefined;\n};\n\nconst selectComparisonEntryByTraceStageCount = <\n\tTEntry extends {\n\t\ttraceSummary?: RAGRetrievalTraceComparisonSummary;\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry,\n\tstage: RAGRetrievalTraceStage\n) => {\n\tconst ranked = [...entries].sort((left, right) => {\n\t\tconst leftMetric = left.traceSummary?.stageCounts?.[stage] ?? 0;\n\t\tconst rightMetric = right.traceSummary?.stageCounts?.[stage] ?? 0;\n\t\tif (rightMetric !== leftMetric) {\n\t\t\treturn rightMetric - leftMetric;\n\t\t}\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst winner = ranked[0];\n\tif (!winner || (winner.traceSummary?.stageCounts?.[stage] ?? 0) === 0) {\n\t\treturn undefined;\n\t}\n\n\treturn typeof winner?.[idKey] === 'string'\n\t\t? (winner[idKey] as string)\n\t\t: undefined;\n};\n\nconst countPresentationCueCases = <\n\tTEntry extends { caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[] }\n>(\n\tentry: TEntry,\n\tcue: 'body' | 'notes' | 'title'\n) =>\n\t(entry.caseTraceSnapshots ?? []).filter(\n\t\t(snapshot) => snapshot.leadPresentationCue === cue\n\t).length;\n\nconst selectComparisonEntryByPresentationCueCases = <\n\tTEntry extends {\n\t\tcaseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[];\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry,\n\tcue: 'body' | 'notes' | 'title'\n) => {\n\tconst ranked = [...entries].sort((left, right) => {\n\t\tconst leftMetric = countPresentationCueCases(left, cue);\n\t\tconst rightMetric = countPresentationCueCases(right, cue);\n\t\tif (rightMetric !== leftMetric) {\n\t\t\treturn rightMetric - leftMetric;\n\t\t}\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst winner = ranked[0];\n\tif (!winner || countPresentationCueCases(winner, cue) === 0) {\n\t\treturn undefined;\n\t}\n\n\treturn typeof winner?.[idKey] === 'string'\n\t\t? (winner[idKey] as string)\n\t\t: undefined;\n};\n\nconst countSpreadsheetCueCases = <\n\tTEntry extends { caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[] }\n>(\n\tentry: TEntry,\n\tcue: 'column' | 'sheet' | 'table'\n) =>\n\t(entry.caseTraceSnapshots ?? []).filter(\n\t\t(snapshot) => snapshot.leadSpreadsheetCue === cue\n\t).length;\n\nconst selectComparisonEntryBySpreadsheetCueCases = <\n\tTEntry extends {\n\t\tcaseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[];\n\t\tresponse: RAGEvaluationResponse;\n\t\t[key: string]: unknown;\n\t}\n>(\n\tentries: TEntry[],\n\tidKey: keyof TEntry,\n\tcue: 'column' | 'sheet' | 'table'\n) => {\n\tconst ranked = [...entries].sort((left, right) => {\n\t\tconst leftMetric = countSpreadsheetCueCases(left, cue);\n\t\tconst rightMetric = countSpreadsheetCueCases(right, cue);\n\t\tif (rightMetric !== leftMetric) {\n\t\t\treturn rightMetric - leftMetric;\n\t\t}\n\t\tif (right.response.passingRate !== left.response.passingRate) {\n\t\t\treturn right.response.passingRate - left.response.passingRate;\n\t\t}\n\t\tif (\n\t\t\tright.response.summary.averageF1 !== left.response.summary.averageF1\n\t\t) {\n\t\t\treturn (\n\t\t\t\tright.response.summary.averageF1 -\n\t\t\t\tleft.response.summary.averageF1\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\tleft.response.summary.averageLatencyMs -\n\t\t\tright.response.summary.averageLatencyMs\n\t\t);\n\t});\n\tconst winner = ranked[0];\n\tif (!winner || countSpreadsheetCueCases(winner, cue) === 0) {\n\t\treturn undefined;\n\t}\n\n\treturn typeof winner?.[idKey] === 'string'\n\t\t? (winner[idKey] as string)\n\t\t: undefined;\n};\n\nconst resolveRetrievalMode = (\n\tcandidate: RAGRetrievalCandidate\n): RAGHybridRetrievalMode => {\n\tif (!candidate.retrieval) {\n\t\treturn 'vector';\n\t}\n\n\treturn typeof candidate.retrieval === 'string'\n\t\t? candidate.retrieval\n\t\t: (candidate.retrieval.mode ?? 'vector');\n};\nexport const compareRAGRetrievalStrategies = async ({\n\tcollection,\n\tsuite,\n\tretrievals,\n\tdefaultTopK = DEFAULT_TOP_K\n}: {\n\tcollection: RAGCollection;\n\tsuite: RAGEvaluationSuite;\n\tretrievals: RAGRetrievalCandidate[];\n\tdefaultTopK?: number;\n}): Promise<RAGRetrievalComparison> => {\n\tconst entries = await Promise.all(\n\t\tretrievals.map(async (candidate) => {\n\t\t\tconst tracedCollection = {\n\t\t\t\t...collection,\n\t\t\t\tsearch: (input) =>\n\t\t\t\t\tcollection.search({\n\t\t\t\t\t\t...input,\n\t\t\t\t\t\tqueryTransform:\n\t\t\t\t\t\t\tcandidate.queryTransform ?? input.queryTransform,\n\t\t\t\t\t\trerank: candidate.rerank ?? input.rerank,\n\t\t\t\t\t\tretrieval: candidate.retrieval ?? input.retrieval\n\t\t\t\t\t}),\n\t\t\t\tsearchWithTrace: (input) =>\n\t\t\t\t\tcollection.searchWithTrace({\n\t\t\t\t\t\t...input,\n\t\t\t\t\t\tqueryTransform:\n\t\t\t\t\t\t\tcandidate.queryTransform ?? input.queryTransform,\n\t\t\t\t\t\trerank: candidate.rerank ?? input.rerank,\n\t\t\t\t\t\tretrieval: candidate.retrieval ?? input.retrieval\n\t\t\t\t\t})\n\t\t\t} satisfies RAGCollection;\n\t\t\tconst evaluated = await evaluateRAGCollectionCases({\n\t\t\t\tcollection: {\n\t\t\t\t\t...tracedCollection\n\t\t\t\t},\n\t\t\t\tdefaultTopK,\n\t\t\t\tinput: suite.input,\n\t\t\t\tincludeTrace: true,\n\t\t\t\trerank: candidate.rerank\n\t\t\t});\n\t\t\tconst response = buildRAGEvaluationResponse(\n\t\t\t\tevaluated.map((entry) => entry.caseResult)\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\tcaseTraceSnapshots:\n\t\t\t\t\tbuildEvaluationCaseTraceSnapshotsFromEvaluated(evaluated),\n\t\t\t\tlabel: candidate.label ?? candidate.id,\n\t\t\t\tresponse,\n\t\t\t\tretrievalId: candidate.id,\n\t\t\t\tretrievalMode: resolveRetrievalMode(candidate),\n\t\t\t\ttraceSummary: summarizeRetrievalTraces(\n\t\t\t\t\tevaluated\n\t\t\t\t\t\t.map((entry) => entry.trace)\n\t\t\t\t\t\t.filter((trace): trace is RAGRetrievalTrace =>\n\t\t\t\t\t\t\tBoolean(trace)\n\t\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t} satisfies RAGRetrievalComparisonEntry;\n\t\t})\n\t);\n\n\tconst leaderboard = buildRAGEvaluationLeaderboard(\n\t\tentries.map((entry) => ({\n\t\t\telapsedMs: entry.response.elapsedMs,\n\t\t\tfinishedAt: 0,\n\t\t\tid: entry.retrievalId,\n\t\t\tlabel: entry.label,\n\t\t\tresponse: entry.response,\n\t\t\tstartedAt: 0,\n\t\t\tsuiteId: suite.id,\n\t\t\ttraceSummary: entry.traceSummary\n\t\t}))\n\t);\n\n\treturn {\n\t\tcorpusKeys: [\n\t\t\t...new Set(\n\t\t\t\tentries.flatMap((entry) => entry.response.corpusKeys ?? [])\n\t\t\t)\n\t\t],\n\t\tentries,\n\t\tleaderboard,\n\t\tsummary: summarizeRAGRetrievalComparison(entries),\n\t\tsuiteId: suite.id,\n\t\tsuiteLabel: suite.label ?? suite.id\n\t};\n};\n\nexport const summarizeRAGRetrievalTraces = (\n\ttraces: RAGRetrievalTrace[]\n): RAGRetrievalTraceComparisonSummary | undefined =>\n\tsummarizeRetrievalTraces(traces);\n\nexport const compareRAGRetrievalTraceSummaries = (\n\tcurrent: RAGRetrievalTraceComparisonSummary,\n\tprevious: RAGRetrievalTraceComparisonSummary\n): RAGRetrievalTraceComparisonSummaryDiff => ({\n\taverageCandidateTopKDelta:\n\t\tcurrent.averageCandidateTopK - previous.averageCandidateTopK,\n\taverageFinalCountDelta:\n\t\tcurrent.averageFinalCount - previous.averageFinalCount,\n\taverageLexicalCountDelta:\n\t\tcurrent.averageLexicalCount - previous.averageLexicalCount,\n\taverageLexicalTopKDelta:\n\t\tcurrent.averageLexicalTopK - previous.averageLexicalTopK,\n\taverageVectorCountDelta:\n\t\tcurrent.averageVectorCount - previous.averageVectorCount,\n\tbalancedCasesDelta: current.balancedCases - previous.balancedCases,\n\tcurrent,\n\tlexicalCasesDelta: current.lexicalCases - previous.lexicalCases,\n\tmodeDelta: buildSummaryListDelta(current.modes, previous.modes),\n\tprevious,\n\troundRobinCasesDelta: current.roundRobinCases - previous.roundRobinCases,\n\tsourceBalanceStrategyDelta: buildSummaryListDelta(\n\t\tcurrent.sourceBalanceStrategies,\n\t\tprevious.sourceBalanceStrategies\n\t),\n\tstageCountsDelta: diffTraceSummaryStageCounts({\n\t\tcurrent: current.stageCounts,\n\t\tprevious: previous.stageCounts\n\t}),\n\ttotalCasesDelta: current.totalCases - previous.totalCases,\n\ttransformedCasesDelta: current.transformedCases - previous.transformedCases,\n\tvectorCasesDelta: current.vectorCases - previous.vectorCases,\n\tvariantCasesDelta: current.variantCases - previous.variantCases,\n\tmultiVectorCasesDelta: current.multiVectorCases - previous.multiVectorCases,\n\tmultiVectorVectorHitCasesDelta:\n\t\tcurrent.multiVectorVectorHitCases - previous.multiVectorVectorHitCases,\n\tmultiVectorLexicalHitCasesDelta:\n\t\tcurrent.multiVectorLexicalHitCases -\n\t\tprevious.multiVectorLexicalHitCases,\n\tmultiVectorCollapsedCasesDelta:\n\t\tcurrent.multiVectorCollapsedCases - previous.multiVectorCollapsedCases,\n\tofficeEvidenceReconcileCasesDelta:\n\t\tcurrent.officeEvidenceReconcileCases -\n\t\tprevious.officeEvidenceReconcileCases,\n\tofficeParagraphEvidenceReconcileCasesDelta:\n\t\t(current.officeParagraphEvidenceReconcileCases ?? 0) -\n\t\t(previous.officeParagraphEvidenceReconcileCases ?? 0),\n\tofficeListEvidenceReconcileCasesDelta:\n\t\t(current.officeListEvidenceReconcileCases ?? 0) -\n\t\t(previous.officeListEvidenceReconcileCases ?? 0),\n\tofficeTableEvidenceReconcileCasesDelta:\n\t\t(current.officeTableEvidenceReconcileCases ?? 0) -\n\t\t(previous.officeTableEvidenceReconcileCases ?? 0),\n\tpdfEvidenceReconcileCasesDelta:\n\t\tcurrent.pdfEvidenceReconcileCases - previous.pdfEvidenceReconcileCases,\n\truntimeCandidateBudgetExhaustedCasesDelta:\n\t\tcurrent.runtimeCandidateBudgetExhaustedCases -\n\t\tprevious.runtimeCandidateBudgetExhaustedCases,\n\truntimeUnderfilledTopKCasesDelta:\n\t\tcurrent.runtimeUnderfilledTopKCases -\n\t\tprevious.runtimeUnderfilledTopKCases\n});\n\nconst buildSearchTraceResultSnapshots = (\n\tresults: Array<{\n\t\tchunkId: string;\n\t\tcorpusKey?: string;\n\t\tscore: number;\n\t\tsource?: string;\n\t\ttitle?: string;\n\t\tmetadata?: Record<string, unknown>;\n\t}>\n): RAGSearchTraceResultSnapshot[] =>\n\tresults.map((result) => ({\n\t\tchunkId: result.chunkId,\n\t\tcorpusKey:\n\t\t\tresult.corpusKey ??\n\t\t\t(typeof result.metadata?.corpusKey === 'string'\n\t\t\t\t? result.metadata.corpusKey\n\t\t\t\t: undefined),\n\t\tdocumentId:\n\t\t\ttypeof result.metadata?.documentId === 'string'\n\t\t\t\t? result.metadata.documentId\n\t\t\t\t: undefined,\n\t\tscore: result.score,\n\t\tsource: result.source,\n\t\ttitle: result.title\n\t}));\n\nexport const buildRAGSearchTraceRecord = (input: {\n\ttrace: RAGRetrievalTrace;\n\tresults?: Array<{\n\t\tchunkId: string;\n\t\tscore: number;\n\t\tsource?: string;\n\t\ttitle?: string;\n\t\tmetadata?: Record<string, unknown>;\n\t}>;\n\tid?: string;\n\tlabel?: string;\n\tgroupKey?: string;\n\ttags?: string[];\n\tstartedAt?: number;\n\tfinishedAt?: number;\n\telapsedMs?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGSearchTraceRecord => {\n\tconst startedAt = input.startedAt ?? Date.now();\n\tconst finishedAt = input.finishedAt ?? startedAt;\n\tconst elapsedMs = input.elapsedMs ?? Math.max(0, finishedAt - startedAt);\n\tconst summary =\n\t\tsummarizeRetrievalTraces([input.trace]) ??\n\t\tsummarizeRetrievalTraces([\n\t\t\t{\n\t\t\t\t...input.trace,\n\t\t\t\tsteps: [...input.trace.steps]\n\t\t\t}\n\t\t]);\n\n\tif (!summary) {\n\t\tthrow new Error('Failed to summarize retrieval trace');\n\t}\n\n\treturn {\n\t\telapsedMs,\n\t\tfinishedAt,\n\t\tgroupKey: input.groupKey,\n\t\tid: input.id ?? generateId(),\n\t\tlabel: input.label ?? input.trace.query,\n\t\tmetadata: input.metadata,\n\t\tquery: input.trace.query,\n\t\tresults: buildSearchTraceResultSnapshots(input.results ?? []),\n\t\tstartedAt,\n\t\tsummary,\n\t\ttags: normalizeTraceTags(input.tags),\n\t\ttrace: input.trace\n\t};\n};\n\nexport const buildRAGSearchTraceDiff = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGSearchTraceRecord;\n\tprevious?: RAGSearchTraceRecord;\n}): RAGSearchTraceDiff => {\n\tconst currentChunkIds = current.results.map((entry) => entry.chunkId);\n\tconst previousChunkIds =\n\t\tprevious?.results.map((entry) => entry.chunkId) ?? [];\n\tconst previousSet = new Set(previousChunkIds);\n\tconst currentSet = new Set(currentChunkIds);\n\n\treturn {\n\t\taddedChunkIds: currentChunkIds.filter(\n\t\t\t(chunkId) => !previousSet.has(chunkId)\n\t\t),\n\t\tcurrentTraceId: current.id,\n\t\tpreviousTraceId: previous?.id,\n\t\tremovedChunkIds: previousChunkIds.filter(\n\t\t\t(chunkId) => !currentSet.has(chunkId)\n\t\t),\n\t\tretainedChunkIds: currentChunkIds.filter((chunkId) =>\n\t\t\tpreviousSet.has(chunkId)\n\t\t),\n\t\tsummaryDelta: previous?.summary\n\t\t\t? compareRAGRetrievalTraceSummaries(\n\t\t\t\t\tcurrent.summary,\n\t\t\t\t\tprevious.summary\n\t\t\t\t)\n\t\t\t: undefined,\n\t\ttopResultChanged:\n\t\t\t(current.results[0]?.chunkId ?? undefined) !==\n\t\t\t(previous?.results[0]?.chunkId ?? undefined)\n\t};\n};\n\nexport const buildRAGRetrievalTraceHistoryTrend = ({\n\truns\n}: {\n\truns: RAGRetrievalTraceSummaryRun[];\n}): RAGRetrievalTraceTrend => {\n\tconst sortedRuns = normalizeTraceSummaryRuns(runs);\n\tconst runsWithSummary = sortedRuns.filter(\n\t\t(run) => run.traceSummary && run.label\n\t);\n\tconst traceSummaries = runsWithSummary\n\t\t.map((run) => run.traceSummary)\n\t\t.filter((summary): summary is RAGRetrievalTraceComparisonSummary =>\n\t\t\tBoolean(summary)\n\t\t);\n\tconst summaryTrendWindows: RAGRetrievalTraceHistoryWindow[] = [];\n\n\tfor (let index = 0; index < runsWithSummary.length - 1; index += 1) {\n\t\tconst currentRun = runsWithSummary[index]!;\n\t\tconst previousRun = runsWithSummary[index + 1]!;\n\t\tif (!currentRun.traceSummary || !previousRun.traceSummary) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst current = currentRun.traceSummary;\n\t\tconst previous = previousRun.traceSummary;\n\t\tconst delta = compareRAGRetrievalTraceSummaries(current, previous);\n\t\tsummaryTrendWindows.push({\n\t\t\tcurrent,\n\t\t\tcurrentRunId: currentRun.id,\n\t\t\tcurrentRunLabel: currentRun.label,\n\t\t\tdelta,\n\t\t\tprevious,\n\t\t\tpreviousRunId: previousRun.id,\n\t\t\tpreviousRunLabel: previousRun.label\n\t\t});\n\t}\n\n\tconst latest = runsWithSummary[0]?.traceSummary;\n\tconst previous = runsWithSummary[1]?.traceSummary;\n\tconst latestToPrevious =\n\t\tlatest && previous\n\t\t\t? compareRAGRetrievalTraceSummaries(latest, previous)\n\t\t\t: undefined;\n\tconst listHistoryModes = traceSummaries.map((summary) => summary.modes);\n\tconst listHistorySourceStrategies = traceSummaries.map(\n\t\t(summary) => summary.sourceBalanceStrategies\n\t);\n\tconst modes = summarizeListTurnover<RAGHybridRetrievalMode>({\n\t\tcurrent: normalizeSummaryList(latest?.modes ?? []),\n\t\thistory: listHistoryModes,\n\t\tprevious: normalizeSummaryList(previous?.modes ?? [])\n\t});\n\tconst sourceBalanceStrategies =\n\t\tsummarizeListTurnover<RAGSourceBalanceStrategy>({\n\t\t\tcurrent: normalizeSummaryList(\n\t\t\t\tlatest?.sourceBalanceStrategies ?? []\n\t\t\t),\n\t\t\thistory: listHistorySourceStrategies,\n\t\t\tprevious: normalizeSummaryList(\n\t\t\t\tprevious?.sourceBalanceStrategies ?? []\n\t\t\t)\n\t\t});\n\tconst { aggregate, bestMetric, worstMetric } = buildTraceSummaryAggregate({\n\t\tsummaries: traceSummaries\n\t});\n\tconst stageChurn = buildRAGRetrievalTraceStageChurn({\n\t\twindows: summaryTrendWindows\n\t});\n\n\treturn {\n\t\taggregate,\n\t\tbestMetric,\n\t\tmodeTurnover: modes,\n\t\trunsWithTraceSummary: traceSummaries.length,\n\t\tsourceBalanceStrategyTurnover: sourceBalanceStrategies,\n\t\tstageChurn,\n\t\tsummaryTrendWindows,\n\t\tworstMetric,\n\t\tworstVolatileStage: stageChurn.find((entry) => entry.totalChanges > 0),\n\t\tlatestToPrevious\n\t};\n};\nexport const createRAGEvaluationSuite = (\n\tsuite: RAGEvaluationSuite\n): RAGEvaluationSuite => {\n\tconst cases = suite.input.cases.map((entry) => ({\n\t\t...entry,\n\t\t...(entry.goldenSet === true ? { goldenSet: true } : {}),\n\t\t...(entry.expectedChunkIds\n\t\t\t? { expectedChunkIds: [...entry.expectedChunkIds] }\n\t\t\t: {}),\n\t\t...(entry.expectedSources\n\t\t\t? { expectedSources: [...entry.expectedSources] }\n\t\t\t: {}),\n\t\t...(entry.expectedDocumentIds\n\t\t\t? { expectedDocumentIds: [...entry.expectedDocumentIds] }\n\t\t\t: {}),\n\t\t...(entry.hardNegativeChunkIds\n\t\t\t? {\n\t\t\t\t\thardNegativeChunkIds: normalizeExpectedIds(\n\t\t\t\t\t\tentry.hardNegativeChunkIds\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(entry.hardNegativeSources\n\t\t\t? {\n\t\t\t\t\thardNegativeSources: normalizeExpectedIds(\n\t\t\t\t\t\tentry.hardNegativeSources\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(entry.hardNegativeDocumentIds\n\t\t\t? {\n\t\t\t\t\thardNegativeDocumentIds: normalizeExpectedIds(\n\t\t\t\t\t\tentry.hardNegativeDocumentIds\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t: {}),\n\t\t...(entry.filter ? { filter: { ...entry.filter } } : {}),\n\t\t...(entry.metadata ? { metadata: { ...entry.metadata } } : {}),\n\t\t...(entry.retrieval ? { retrieval: entry.retrieval } : {})\n\t}));\n\tconst duplicateCaseIds = Array.from(\n\t\tnew Set(\n\t\t\tcases\n\t\t\t\t.map((entry) => entry.id)\n\t\t\t\t.filter(\n\t\t\t\t\t(id, index, ids) =>\n\t\t\t\t\t\ttypeof id === 'string' && ids.indexOf(id) !== index\n\t\t\t\t)\n\t\t)\n\t);\n\tif (duplicateCaseIds.length > 0) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite contains duplicate case ids: ${duplicateCaseIds.join(', ')}`\n\t\t);\n\t}\n\n\treturn {\n\t\t...suite,\n\t\tinput: {\n\t\t\t...suite.input,\n\t\t\tcases,\n\t\t\t...(suite.input.filter\n\t\t\t\t? { filter: { ...suite.input.filter } }\n\t\t\t\t: {}),\n\t\t\t...(suite.input.retrieval\n\t\t\t\t? { retrieval: suite.input.retrieval }\n\t\t\t\t: {})\n\t\t},\n\t\t...(suite.metadata ? { metadata: { ...suite.metadata } } : {})\n\t};\n};\n\nexport const addRAGEvaluationSuiteCase = ({\n\tsuite,\n\tcaseInput,\n\tindex\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseInput: RAGEvaluationCase;\n\tindex?: number;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tif (\n\t\tnormalizedSuite.input.cases.some((entry) => entry.id === caseInput.id)\n\t) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite already contains case id ${caseInput.id}`\n\t\t);\n\t}\n\n\tconst nextCases = [...normalizedSuite.input.cases];\n\tconst insertAt =\n\t\ttypeof index === 'number' && Number.isFinite(index)\n\t\t\t? Math.max(0, Math.min(nextCases.length, Math.trunc(index)))\n\t\t\t: nextCases.length;\n\tnextCases.splice(insertAt, 0, caseInput);\n\n\treturn createRAGEvaluationSuite({\n\t\t...normalizedSuite,\n\t\tinput: {\n\t\t\t...normalizedSuite.input,\n\t\t\tcases: nextCases\n\t\t}\n\t});\n};\n\nexport const updateRAGEvaluationSuiteCase = ({\n\tsuite,\n\tcaseId,\n\tcaseInput\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseId: string;\n\tcaseInput: RAGEvaluationCase;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst targetIndex = normalizedSuite.input.cases.findIndex(\n\t\t(entry) => entry.id === caseId\n\t);\n\tif (targetIndex < 0) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite does not contain case id ${caseId}`\n\t\t);\n\t}\n\tif (\n\t\tcaseInput.id !== caseId &&\n\t\tnormalizedSuite.input.cases.some((entry) => entry.id === caseInput.id)\n\t) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite already contains case id ${caseInput.id}`\n\t\t);\n\t}\n\n\tconst nextCases = [...normalizedSuite.input.cases];\n\tnextCases[targetIndex] = caseInput;\n\n\treturn createRAGEvaluationSuite({\n\t\t...normalizedSuite,\n\t\tinput: {\n\t\t\t...normalizedSuite.input,\n\t\t\tcases: nextCases\n\t\t}\n\t});\n};\n\nexport const removeRAGEvaluationSuiteCase = ({\n\tsuite,\n\tcaseId\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseId: string;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst nextCases = normalizedSuite.input.cases.filter(\n\t\t(entry) => entry.id !== caseId\n\t);\n\tif (nextCases.length === normalizedSuite.input.cases.length) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite does not contain case id ${caseId}`\n\t\t);\n\t}\n\n\treturn {\n\t\t...normalizedSuite,\n\t\tinput: {\n\t\t\t...normalizedSuite.input,\n\t\t\tcases: nextCases\n\t\t}\n\t};\n};\n\nexport const reorderRAGEvaluationSuiteCases = ({\n\tsuite,\n\tcaseIds\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseIds: string[];\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst caseMap = new Map(\n\t\tnormalizedSuite.input.cases.map((entry) => [entry.id, entry])\n\t);\n\tif (caseIds.length !== normalizedSuite.input.cases.length) {\n\t\tthrow new Error(\n\t\t\t'RAG evaluation suite reorder requires exactly one id per case'\n\t\t);\n\t}\n\tconst unknownCaseIds = caseIds.filter((id) => !caseMap.has(id));\n\tif (unknownCaseIds.length > 0) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite reorder contains unknown case ids: ${unknownCaseIds.join(', ')}`\n\t\t);\n\t}\n\tif (new Set(caseIds).size !== caseIds.length) {\n\t\tthrow new Error(\n\t\t\t'RAG evaluation suite reorder contains duplicate case ids'\n\t\t);\n\t}\n\n\treturn {\n\t\t...normalizedSuite,\n\t\tinput: {\n\t\t\t...normalizedSuite.input,\n\t\t\tcases: caseIds.map((id) => caseMap.get(id)!)\n\t\t}\n\t};\n};\n\nexport const setRAGEvaluationSuiteCaseGoldenSet = ({\n\tsuite,\n\tcaseId,\n\tgoldenSet\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseId: string;\n\tgoldenSet: boolean;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst target = normalizedSuite.input.cases.find(\n\t\t(entry) => entry.id === caseId\n\t);\n\tif (!target) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite does not contain case id ${caseId}`\n\t\t);\n\t}\n\n\treturn updateRAGEvaluationSuiteCase({\n\t\tcaseId,\n\t\tcaseInput: {\n\t\t\t...target,\n\t\t\t...(goldenSet ? { goldenSet: true } : { goldenSet: undefined })\n\t\t},\n\t\tsuite: normalizedSuite\n\t});\n};\n\nconst resolveHardNegativeCaseField = (\n\tkind: 'chunkId' | 'source' | 'documentId'\n) =>\n\tkind === 'chunkId'\n\t\t? 'hardNegativeChunkIds'\n\t\t: kind === 'source'\n\t\t\t? 'hardNegativeSources'\n\t\t\t: 'hardNegativeDocumentIds';\n\nexport const addRAGEvaluationSuiteCaseHardNegative = ({\n\tsuite,\n\tcaseId,\n\tkind,\n\tvalue\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseId: string;\n\tkind: 'chunkId' | 'source' | 'documentId';\n\tvalue: string;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst target = normalizedSuite.input.cases.find(\n\t\t(entry) => entry.id === caseId\n\t);\n\tif (!target) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite does not contain case id ${caseId}`\n\t\t);\n\t}\n\n\tconst field = resolveHardNegativeCaseField(kind);\n\tconst nextValues = normalizeExpectedIds([\n\t\t...normalizeStringArray(target[field]),\n\t\tvalue\n\t]);\n\n\treturn updateRAGEvaluationSuiteCase({\n\t\tcaseId,\n\t\tcaseInput: {\n\t\t\t...target,\n\t\t\t[field]: nextValues\n\t\t},\n\t\tsuite: normalizedSuite\n\t});\n};\n\nexport const removeRAGEvaluationSuiteCaseHardNegative = ({\n\tsuite,\n\tcaseId,\n\tkind,\n\tvalue\n}: {\n\tsuite: RAGEvaluationSuite;\n\tcaseId: string;\n\tkind: 'chunkId' | 'source' | 'documentId';\n\tvalue: string;\n}): RAGEvaluationSuite => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst target = normalizedSuite.input.cases.find(\n\t\t(entry) => entry.id === caseId\n\t);\n\tif (!target) {\n\t\tthrow new Error(\n\t\t\t`RAG evaluation suite does not contain case id ${caseId}`\n\t\t);\n\t}\n\n\tconst field = resolveHardNegativeCaseField(kind);\n\tconst nextValues = normalizeStringArray(target[field]).filter(\n\t\t(entry) => entry !== value.trim()\n\t);\n\n\treturn updateRAGEvaluationSuiteCase({\n\t\tcaseId,\n\t\tcaseInput: {\n\t\t\t...target,\n\t\t\t[field]: nextValues.length > 0 ? nextValues : undefined\n\t\t},\n\t\tsuite: normalizedSuite\n\t});\n};\n\nexport const summarizeRAGEvaluationSuiteDataset = ({\n\tsuite\n}: {\n\tsuite: RAGEvaluationSuite;\n}): RAGEvaluationSuiteDatasetSummary => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\tconst cases = normalizedSuite.input.cases;\n\n\treturn {\n\t\tcaseCount: cases.length,\n\t\tgoldenSetCount: cases.filter((entry) => entry.goldenSet === true)\n\t\t\t.length,\n\t\thardNegativeCaseCount: cases.filter(\n\t\t\t(entry) =>\n\t\t\t\tnormalizeStringArray(entry.hardNegativeChunkIds).length > 0 ||\n\t\t\t\tnormalizeStringArray(entry.hardNegativeSources).length > 0 ||\n\t\t\t\tnormalizeStringArray(entry.hardNegativeDocumentIds).length > 0\n\t\t).length,\n\t\thardNegativeChunkIdCount: cases.reduce(\n\t\t\t(sum, entry) =>\n\t\t\t\tsum + normalizeStringArray(entry.hardNegativeChunkIds).length,\n\t\t\t0\n\t\t),\n\t\thardNegativeDocumentIdCount: cases.reduce(\n\t\t\t(sum, entry) =>\n\t\t\t\tsum +\n\t\t\t\tnormalizeStringArray(entry.hardNegativeDocumentIds).length,\n\t\t\t0\n\t\t),\n\t\thardNegativeSourceCount: cases.reduce(\n\t\t\t(sum, entry) =>\n\t\t\t\tsum + normalizeStringArray(entry.hardNegativeSources).length,\n\t\t\t0\n\t\t),\n\t\tsuiteId: normalizedSuite.id\n\t};\n};\n\nexport const generateRAGEvaluationSuiteFromDocuments = ({\n\tsuiteId,\n\tdocuments,\n\tlabel,\n\tdescription,\n\tmaxCases = 20,\n\ttopK = 5,\n\tscoreThreshold,\n\tfilter,\n\tretrieval,\n\tincludeGoldenSet = true,\n\thardNegativePerCase = 1,\n\tmetadata\n}: RAGEvaluationSuiteGenerationOptions): RAGEvaluationSuite => {\n\tconst normalizedDocuments = documents\n\t\t.filter(\n\t\t\t(document) =>\n\t\t\t\ttypeof document.id === 'string' &&\n\t\t\t\tdocument.id.trim().length > 0 &&\n\t\t\t\ttypeof document.source === 'string' &&\n\t\t\t\tdocument.source.trim().length > 0 &&\n\t\t\t\ttypeof document.title === 'string' &&\n\t\t\t\tdocument.title.trim().length > 0\n\t\t)\n\t\t.sort((left, right) =>\n\t\t\t`${left.source}\\u0000${left.title}\\u0000${left.id}`.localeCompare(\n\t\t\t\t`${right.source}\\u0000${right.title}\\u0000${right.id}`\n\t\t\t)\n\t\t)\n\t\t.slice(0, Math.max(0, Math.trunc(maxCases)));\n\n\tconst cases = normalizedDocuments.map((document, index) => {\n\t\tconst negativeCandidates = normalizedDocuments\n\t\t\t.slice(index + 1)\n\t\t\t.concat(normalizedDocuments.slice(0, index))\n\t\t\t.filter((candidate) => candidate.id !== document.id);\n\t\tconst hardNegativeDocumentIds = negativeCandidates\n\t\t\t.slice(0, Math.max(0, Math.trunc(hardNegativePerCase)))\n\t\t\t.map((candidate) => candidate.id);\n\t\tconst hardNegativeSources = negativeCandidates\n\t\t\t.slice(0, Math.max(0, Math.trunc(hardNegativePerCase)))\n\t\t\t.map((candidate) => candidate.source);\n\n\t\treturn {\n\t\t\tcorpusKey: document.corpusKey,\n\t\t\texpectedDocumentIds: [document.id],\n\t\t\texpectedSources: [document.source],\n\t\t\t...(includeGoldenSet ? { goldenSet: true } : {}),\n\t\t\t...(hardNegativeDocumentIds.length > 0\n\t\t\t\t? { hardNegativeDocumentIds }\n\t\t\t\t: {}),\n\t\t\t...(hardNegativeSources.length > 0 ? { hardNegativeSources } : {}),\n\t\t\tid: `synthetic-${document.id}`,\n\t\t\tlabel: document.title,\n\t\t\tquery: buildSyntheticEvaluationQuery(document)\n\t\t} satisfies RAGEvaluationCase;\n\t});\n\n\treturn createRAGEvaluationSuite({\n\t\tdescription,\n\t\tid: suiteId,\n\t\tinput: {\n\t\t\tcases,\n\t\t\t...(filter ? { filter: { ...filter } } : {}),\n\t\t\t...(typeof scoreThreshold === 'number' ? { scoreThreshold } : {}),\n\t\t\t...(typeof topK === 'number' ? { topK } : {}),\n\t\t\t...(retrieval ? { retrieval } : {})\n\t\t},\n\t\tlabel,\n\t\tmetadata\n\t});\n};\n\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_SUITE_ID =\n\t'rag-native-planner-larger-corpus';\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_LABEL =\n\t'Adaptive Native Planner Benchmark';\nconst DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_SUITE_ID =\n\t'rag-native-backend-larger-corpus';\nconst DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_LABEL =\n\t'Native Backend Comparison Benchmark';\nconst DEFAULT_PRESENTATION_CUE_BENCHMARK_SUITE_ID =\n\t'rag-presentation-cue-parity';\nconst DEFAULT_PRESENTATION_CUE_BENCHMARK_LABEL = 'Presentation Cue Benchmark';\nconst DEFAULT_SPREADSHEET_CUE_BENCHMARK_SUITE_ID = 'rag-spreadsheet-cue-parity';\nconst DEFAULT_SPREADSHEET_CUE_BENCHMARK_LABEL = 'Spreadsheet Cue Benchmark';\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY =\n\t'Which launch checklist phrase is exact wording?';\nconst DEFAULT_NATIVE_BACKEND_HYBRID_QUERY =\n\t'aurora promotion checklist wording';\nconst DEFAULT_NATIVE_BACKEND_FILTERED_QUERY =\n\t'focus lane launch checklist wording';\nconst DEFAULT_NATIVE_BACKEND_REORDERED_QUERY =\n\t'exact aurora focus lane checklist wording';\nconst DEFAULT_NATIVE_BACKEND_GUIDE_QUERY =\n\t'which focus lane guide contains exact aurora promotion wording';\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER = {\n\tlane: 'focus'\n} satisfies Record<string, unknown>;\nconst DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS = [\n\t'focus-distractor-0',\n\t'focus-distractor-1',\n\t'focus-distractor-2'\n] as const;\n\nexport const createRAGNativeBackendBenchmarkMockEmbedding = async (\n\ttext: string\n): Promise<number[]> => {\n\tconst normalized = text.toLowerCase();\n\tif (\n\t\tnormalized.includes(\n\t\t\t'launch checklist exact wording for aurora promotion'\n\t\t) ||\n\t\tnormalized.includes('launch checklist exact wording')\n\t) {\n\t\treturn [0.995, 0.005];\n\t}\n\n\tif (\n\t\tnormalized.includes('aurora') ||\n\t\tnormalized.includes('checklist') ||\n\t\tnormalized.includes('focus lane') ||\n\t\tnormalized.includes('exact wording') ||\n\t\tnormalized.includes('guide')\n\t) {\n\t\treturn [1, 0];\n\t}\n\n\treturn [0, 1];\n};\n\nexport const createRAGNativeBackendBenchmarkCorpus = (input?: {\n\tbackend?: 'generic' | 'sqlite-native' | 'postgres';\n\tnoiseCount?: number;\n}): RAGDocumentChunk[] => {\n\tconst noiseCount = input?.noiseCount ?? 5_001;\n\tconst backend = input?.backend ?? 'generic';\n\tconst genericChunks = [\n\t\t...Array.from({ length: noiseCount }, (_, index) => ({\n\t\t\tchunkId: `noise:${index}`,\n\t\t\tcorpusKey: 'noise',\n\t\t\tembedding: [0, 1] as number[],\n\t\t\tmetadata: {\n\t\t\t\tcorpusKey: 'noise',\n\t\t\t\tdocumentId: `noise-${index}`,\n\t\t\t\tlane: 'noise'\n\t\t\t},\n\t\t\tsource: `noise/${index}.md`,\n\t\t\ttext: `Background operations note ${index}.`\n\t\t})),\n\t\t...Array.from({ length: 3 }, (_, index) => ({\n\t\t\tchunkId: `focus:distractor:${index}`,\n\t\t\tcorpusKey: 'focus',\n\t\t\tembedding: [1, 0] as number[],\n\t\t\tmetadata: {\n\t\t\t\tcorpusKey: 'focus',\n\t\t\t\tdocumentId: `focus-distractor-${index}`,\n\t\t\t\tlane: 'focus'\n\t\t\t},\n\t\t\tsource: `focus/distractor-${index}.md`,\n\t\t\ttext:\n\t\t\t\tindex === 0\n\t\t\t\t\t? 'aurora promotion checklist overview'\n\t\t\t\t\t: index === 1\n\t\t\t\t\t\t? 'launch checklist wording draft'\n\t\t\t\t\t\t: 'focus lane promotion runbook notes'\n\t\t})),\n\t\t{\n\t\t\tchunkId: 'focus:target',\n\t\t\tcorpusKey: 'focus',\n\t\t\tembedding: [0.995, 0.005] as number[],\n\t\t\tmetadata: {\n\t\t\t\tcorpusKey: 'focus',\n\t\t\t\tdocumentId: 'focus-target',\n\t\t\t\tlane: 'focus'\n\t\t\t},\n\t\t\tsource: 'guide/planner-depth.md',\n\t\t\ttext: 'launch checklist exact wording for aurora promotion in the focus lane'\n\t\t}\n\t] satisfies RAGDocumentChunk[];\n\n\tconst backendSpecificChunks =\n\t\tbackend === 'sqlite-native'\n\t\t\t? [\n\t\t\t\t\t{\n\t\t\t\t\t\tchunkId: 'focus:sqlite:phrase-matrix',\n\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\tembedding: [1, 0] as number[],\n\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\tbackendFixture: 'sqlite-native',\n\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\tdocumentId: 'focus-sqlite-phrase-matrix',\n\t\t\t\t\t\t\tlane: 'focus'\n\t\t\t\t\t\t},\n\t\t\t\t\t\tsource: 'guide/sqlite-phrase-matrix.md',\n\t\t\t\t\t\ttext: 'exact aurora focus lane checklist wording matrix for sqlite validation'\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tchunkId: 'focus:sqlite:guide-table',\n\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\tembedding: [1, 0] as number[],\n\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\tbackendFixture: 'sqlite-native',\n\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\tdocumentId: 'focus-sqlite-guide-table',\n\t\t\t\t\t\t\tlane: 'focus'\n\t\t\t\t\t\t},\n\t\t\t\t\t\tsource: 'guide/sqlite-guide-table.md',\n\t\t\t\t\t\ttext: 'which focus lane guide contains aurora promotion wording draft table for sqlite operators'\n\t\t\t\t\t}\n\t\t\t\t]\n\t\t\t: backend === 'postgres'\n\t\t\t\t? [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tchunkId: 'focus:postgres:appendix',\n\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\tembedding: [1, 0] as number[],\n\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\tbackendFixture: 'postgres',\n\t\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\t\tdocumentId: 'focus-postgres-appendix',\n\t\t\t\t\t\t\t\tlane: 'focus'\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tsource: 'guide/postgres-appendix.md',\n\t\t\t\t\t\t\ttext: 'which focus lane guide contains exact aurora promotion wording appendix for postgres release review'\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tchunkId: 'focus:postgres:alternatives',\n\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\tembedding: [1, 0] as number[],\n\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\tbackendFixture: 'postgres',\n\t\t\t\t\t\t\t\tcorpusKey: 'focus',\n\t\t\t\t\t\t\t\tdocumentId: 'focus-postgres-alternatives',\n\t\t\t\t\t\t\t\tlane: 'focus'\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tsource: 'guide/postgres-alternatives.md',\n\t\t\t\t\t\t\ttext: 'aurora promotion checklist wording alternatives and exact focus lane phrasing for postgres audits'\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t: [];\n\n\treturn [...genericChunks, ...backendSpecificChunks];\n};\n\nexport const createRAGAdaptiveNativePlannerBenchmarkSuite = (input?: {\n\tid?: string;\n\tlabel?: string;\n\tdescription?: string;\n\ttopK?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n\tcreateRAGEvaluationSuite({\n\t\tdescription:\n\t\t\tinput?.description ??\n\t\t\t'Stress-tests larger-corpus native planner selection, candidate-budget pressure, and transformed-query recovery on filtered retrieval.',\n\t\tid: input?.id ?? DEFAULT_NATIVE_PLANNER_BENCHMARK_SUITE_ID,\n\t\tinput: {\n\t\t\tcases: [\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'focus-distractor-0',\n\t\t\t\t\t\t'focus-distractor-1',\n\t\t\t\t\t\t'focus-distractor-2'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-exact-phrase',\n\t\t\t\t\tlabel: 'Exact phrase survives larger-corpus native pressure',\n\t\t\t\t\tquery: DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t}\n\t\t\t],\n\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\tretrieval: 'vector',\n\t\t\ttopK: input?.topK ?? 1\n\t\t},\n\t\tlabel: input?.label ?? DEFAULT_NATIVE_PLANNER_BENCHMARK_LABEL,\n\t\tmetadata: {\n\t\t\tbenchmarkKind: 'adaptive_native_planner',\n\t\t\tbenchmarkScope: 'larger_corpus',\n\t\t\texpectedSignals: [\n\t\t\t\t'selected native planner profile',\n\t\t\t\t'candidate-budget exhaustion',\n\t\t\t\t'underfilled topk'\n\t\t\t],\n\t\t\trecommendedGroupKey: 'runtime-native-planner',\n\t\t\trecommendedTags: ['runtime', 'native', 'planner'],\n\t\t\t...input?.metadata\n\t\t}\n\t});\n\nexport const createRAGAdaptiveNativePlannerBenchmarkSnapshot = (input?: {\n\tsuite?: RAGEvaluationSuite;\n\tid?: string;\n\tversion?: number;\n\tcreatedAt?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n\tconst suite =\n\t\tinput?.suite ?? createRAGAdaptiveNativePlannerBenchmarkSuite();\n\n\treturn createRAGEvaluationSuiteSnapshot({\n\t\tcreatedAt: input?.createdAt,\n\t\tid: input?.id,\n\t\tmetadata: {\n\t\t\tartifactKind: 'adaptive_native_planner_benchmark',\n\t\t\tpersistForReleaseHistory: true,\n\t\t\t...input?.metadata\n\t\t},\n\t\tsuite,\n\t\tversion: input?.version\n\t});\n};\n\nexport const createRAGNativeBackendComparisonBenchmarkSuite = (input?: {\n\tid?: string;\n\tlabel?: string;\n\tdescription?: string;\n\ttopK?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n\tcreateRAGEvaluationSuite({\n\t\tdescription:\n\t\t\tinput?.description ??\n\t\t\t'Captures larger-corpus native backend parity with filtered vector pressure and harder hybrid retrieval cases so sqlite-native and postgres runs can be compared over time.',\n\t\tid: input?.id ?? DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_SUITE_ID,\n\t\tinput: {\n\t\t\tcases: [\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-exact-phrase',\n\t\t\t\t\tlabel: 'Exact phrase survives larger-corpus native pressure',\n\t\t\t\t\tquery: DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-hybrid-phrase',\n\t\t\t\t\tlabel: 'Hybrid retrieval survives filtered lexical pressure',\n\t\t\t\t\tquery: DEFAULT_NATIVE_BACKEND_HYBRID_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-filtered-lane-query',\n\t\t\t\t\tlabel: 'Filtered lane query survives broader corpus noise',\n\t\t\t\t\tquery: DEFAULT_NATIVE_BACKEND_FILTERED_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-reordered-phrase',\n\t\t\t\t\tlabel: 'Reordered phrase survives transform pressure',\n\t\t\t\t\tquery: DEFAULT_NATIVE_BACKEND_REORDERED_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['focus-target'],\n\t\t\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS\n\t\t\t\t\t],\n\t\t\t\t\tid: 'planner-pressure-guide-query',\n\t\t\t\t\tlabel: 'Guide attribution survives filtered corpus pressure',\n\t\t\t\t\tquery: DEFAULT_NATIVE_BACKEND_GUIDE_QUERY,\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t}\n\t\t\t],\n\t\t\tfilter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n\t\t\tretrieval: 'vector',\n\t\t\ttopK: input?.topK ?? 1\n\t\t},\n\t\tlabel:\n\t\t\tinput?.label ?? DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_LABEL,\n\t\tmetadata: {\n\t\t\tbenchmarkKind: 'native_backend_comparison',\n\t\t\tbenchmarkScope: 'larger_corpus',\n\t\t\texpectedSignals: [\n\t\t\t\t'backend-tagged runtime artifacts',\n\t\t\t\t'selected native planner profile',\n\t\t\t\t'hybrid filtered retrieval',\n\t\t\t\t'candidate-budget exhaustion',\n\t\t\t\t'underfilled topk',\n\t\t\t\t'query transform pressure'\n\t\t\t],\n\t\t\trecommendedGroupKey: 'runtime-native-backend-parity',\n\t\t\trecommendedTags: ['runtime', 'backend', 'native'],\n\t\t\t...input?.metadata\n\t\t}\n\t});\n\nexport const createRAGNativeBackendComparisonBenchmarkSnapshot = (input?: {\n\tsuite?: RAGEvaluationSuite;\n\tid?: string;\n\tversion?: number;\n\tcreatedAt?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n\tconst suite =\n\t\tinput?.suite ?? createRAGNativeBackendComparisonBenchmarkSuite();\n\n\treturn createRAGEvaluationSuiteSnapshot({\n\t\tcreatedAt: input?.createdAt,\n\t\tid: input?.id,\n\t\tmetadata: {\n\t\t\tartifactKind: 'native_backend_comparison_benchmark',\n\t\t\tpersistForReleaseHistory: true,\n\t\t\t...input?.metadata\n\t\t},\n\t\tsuite,\n\t\tversion: input?.version\n\t});\n};\n\nexport const createRAGPresentationCueBenchmarkSuite = (input?: {\n\tid?: string;\n\tlabel?: string;\n\tdescription?: string;\n\ttopK?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n\tcreateRAGEvaluationSuite({\n\t\tdescription:\n\t\t\tinput?.description ??\n\t\t\t'Captures repeated-title presentation retrieval parity with explicit title-led, body-led, and notes-led slide cases so presentation cue weighting can be benchmarked over time.',\n\t\tid: input?.id ?? DEFAULT_PRESENTATION_CUE_BENCHMARK_SUITE_ID,\n\t\tinput: {\n\t\t\tcases: [\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['slide-title-doc'],\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'slide-body-doc',\n\t\t\t\t\t\t'slide-notes-doc'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'presentation-title-led',\n\t\t\t\t\tlabel: 'Repeated-title deck selects title-led slide evidence',\n\t\t\t\t\tquery: 'Which presentation title covers the release handoff summary?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['slide-body-doc'],\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'slide-title-doc',\n\t\t\t\t\t\t'slide-notes-doc'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'presentation-body-led',\n\t\t\t\t\tlabel: 'Repeated-title deck selects body-led slide evidence',\n\t\t\t\t\tquery: 'Which slide mentions escalation review in the body?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['slide-notes-doc'],\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'slide-title-doc',\n\t\t\t\t\t\t'slide-body-doc'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'presentation-notes-led',\n\t\t\t\t\tlabel: 'Repeated-title deck selects notes-led slide evidence',\n\t\t\t\t\tquery: 'Which slide notes are the primary handoff evidence?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t}\n\t\t\t],\n\t\t\tretrieval: 'hybrid',\n\t\t\ttopK: input?.topK ?? 1\n\t\t},\n\t\tlabel: input?.label ?? DEFAULT_PRESENTATION_CUE_BENCHMARK_LABEL,\n\t\tmetadata: {\n\t\t\tbenchmarkKind: 'presentation_cue',\n\t\t\tbenchmarkScope: 'repeated_title_slides',\n\t\t\texpectedSignals: [\n\t\t\t\t'presentation title cue',\n\t\t\t\t'presentation body cue',\n\t\t\t\t'presentation notes cue'\n\t\t\t],\n\t\t\trecommendedGroupKey: 'presentation-cue-parity',\n\t\t\trecommendedTags: ['presentation', 'cue', 'slides'],\n\t\t\t...input?.metadata\n\t\t}\n\t});\n\nexport const createRAGPresentationCueBenchmarkSnapshot = (input?: {\n\tsuite?: RAGEvaluationSuite;\n\tid?: string;\n\tversion?: number;\n\tcreatedAt?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n\tconst suite = input?.suite ?? createRAGPresentationCueBenchmarkSuite();\n\n\treturn createRAGEvaluationSuiteSnapshot({\n\t\tcreatedAt: input?.createdAt,\n\t\tid: input?.id,\n\t\tmetadata: {\n\t\t\tartifactKind: 'presentation_cue_benchmark',\n\t\t\tpersistForReleaseHistory: true,\n\t\t\t...input?.metadata\n\t\t},\n\t\tsuite,\n\t\tversion: input?.version\n\t});\n};\n\nexport const createRAGSpreadsheetCueBenchmarkSuite = (input?: {\n\tid?: string;\n\tlabel?: string;\n\tdescription?: string;\n\ttopK?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n\tcreateRAGEvaluationSuite({\n\t\tdescription:\n\t\t\tinput?.description ??\n\t\t\t'Captures repeated spreadsheet-family retrieval parity with explicit sheet-led, table-led, and column-led workbook cases so spreadsheet cue weighting can be benchmarked over time.',\n\t\tid: input?.id ?? DEFAULT_SPREADSHEET_CUE_BENCHMARK_SUITE_ID,\n\t\tinput: {\n\t\t\tcases: [\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['sheet-led-doc'],\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'table-led-doc',\n\t\t\t\t\t\t'column-led-doc'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'spreadsheet-sheet-led',\n\t\t\t\t\tlabel: 'Workbook selects sheet-led spreadsheet evidence',\n\t\t\t\t\tquery: 'Which spreadsheet sheet lists owner status and due date?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['table-led-doc'],\n\t\t\t\t\thardNegativeDocumentIds: [\n\t\t\t\t\t\t'sheet-led-doc',\n\t\t\t\t\t\t'column-led-doc'\n\t\t\t\t\t],\n\t\t\t\t\tid: 'spreadsheet-table-led',\n\t\t\t\t\tlabel: 'Workbook selects table-led spreadsheet evidence',\n\t\t\t\t\tquery: 'Which spreadsheet table lists the escalation status rows?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\texpectedDocumentIds: ['column-led-doc'],\n\t\t\t\t\thardNegativeDocumentIds: ['sheet-led-doc', 'table-led-doc'],\n\t\t\t\t\tid: 'spreadsheet-column-led',\n\t\t\t\t\tlabel: 'Workbook selects column-led spreadsheet evidence',\n\t\t\t\t\tquery: 'Which spreadsheet columns cover owner due date?',\n\t\t\t\t\ttopK: input?.topK ?? 1\n\t\t\t\t}\n\t\t\t],\n\t\t\tretrieval: 'hybrid',\n\t\t\ttopK: input?.topK ?? 1\n\t\t},\n\t\tlabel: input?.label ?? DEFAULT_SPREADSHEET_CUE_BENCHMARK_LABEL,\n\t\tmetadata: {\n\t\t\tbenchmarkKind: 'spreadsheet_cue',\n\t\t\tbenchmarkScope: 'repeated_sheet_tables',\n\t\t\texpectedSignals: [\n\t\t\t\t'spreadsheet sheet cue',\n\t\t\t\t'spreadsheet table cue',\n\t\t\t\t'spreadsheet column cue'\n\t\t\t],\n\t\t\trecommendedGroupKey: 'spreadsheet-cue-parity',\n\t\t\trecommendedTags: ['spreadsheet', 'cue', 'workbook'],\n\t\t\t...input?.metadata\n\t\t}\n\t});\n\nexport const createRAGSpreadsheetCueBenchmarkSnapshot = (input?: {\n\tsuite?: RAGEvaluationSuite;\n\tid?: string;\n\tversion?: number;\n\tcreatedAt?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n\tconst suite = input?.suite ?? createRAGSpreadsheetCueBenchmarkSuite();\n\n\treturn createRAGEvaluationSuiteSnapshot({\n\t\tcreatedAt: input?.createdAt,\n\t\tid: input?.id,\n\t\tmetadata: {\n\t\t\tartifactKind: 'spreadsheet_cue_benchmark',\n\t\t\tpersistForReleaseHistory: true,\n\t\t\t...input?.metadata\n\t\t},\n\t\tsuite,\n\t\tversion: input?.version\n\t});\n};\n\nexport const createRAGEvaluationSuiteSnapshot = ({\n\tsuite,\n\tid,\n\tversion = 1,\n\tcreatedAt = Date.now(),\n\tmetadata\n}: {\n\tsuite: RAGEvaluationSuite;\n\tid?: string;\n\tversion?: number;\n\tcreatedAt?: number;\n\tmetadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n\tconst normalizedSuite = createRAGEvaluationSuite(suite);\n\treturn {\n\t\tcaseCount: normalizedSuite.input.cases.length,\n\t\tcreatedAt,\n\t\tid: id ?? `${normalizedSuite.id}:snapshot:${String(version)}`,\n\t\tlabel: normalizedSuite.label,\n\t\tdescription: normalizedSuite.description,\n\t\tmetadata: metadata ? { ...metadata } : undefined,\n\t\tsuite: normalizedSuite,\n\t\tsuiteId: normalizedSuite.id,\n\t\tversion\n\t};\n};\n\nconst stableStringifyEvaluationCase = (entry: RAGEvaluationCase) =>\n\tJSON.stringify({\n\t\t...entry,\n\t\texpectedChunkIds: entry.expectedChunkIds ?? [],\n\t\texpectedDocumentIds: entry.expectedDocumentIds ?? [],\n\t\texpectedSources: entry.expectedSources ?? [],\n\t\tgoldenSet: entry.goldenSet === true,\n\t\thardNegativeChunkIds: entry.hardNegativeChunkIds ?? [],\n\t\thardNegativeDocumentIds: entry.hardNegativeDocumentIds ?? [],\n\t\thardNegativeSources: entry.hardNegativeSources ?? [],\n\t\tfilter: entry.filter ?? {},\n\t\tmetadata: entry.metadata ?? {},\n\t\tretrieval: entry.retrieval ?? null\n\t});\n\nexport const buildRAGEvaluationSuiteSnapshotDiff = ({\n\tcurrent,\n\tprevious\n}: {\n\tcurrent: RAGEvaluationSuiteSnapshot;\n\tprevious?: RAGEvaluationSuiteSnapshot;\n}): RAGEvaluationSuiteSnapshotDiff => {\n\tconst currentCases = current.suite.input.cases;\n\tconst previousCases = previous?.suite.input.cases ?? [];\n\tconst currentMap = new Map<string, RAGEvaluationCase>(\n\t\tcurrentCases.map((entry: RAGEvaluationCase) => [entry.id, entry])\n\t);\n\tconst previousMap = new Map<string, RAGEvaluationCase>(\n\t\tpreviousCases.map((entry: RAGEvaluationCase) => [entry.id, entry])\n\t);\n\tconst currentIds = currentCases.map((entry: RAGEvaluationCase) => entry.id);\n\tconst previousIds = previousCases.map(\n\t\t(entry: RAGEvaluationCase) => entry.id\n\t);\n\n\tconst addedCaseIds = currentIds.filter(\n\t\t(id: string) => !previousMap.has(id)\n\t);\n\tconst removedCaseIds = previousIds.filter(\n\t\t(id: string) => !currentMap.has(id)\n\t);\n\tconst changedCaseIds = currentIds.filter((id: string) => {\n\t\tconst currentCase = currentMap.get(id);\n\t\tconst previousCase = previousMap.get(id);\n\t\tif (!currentCase || !previousCase) {\n\t\t\treturn false;\n\t\t}\n\t\treturn (\n\t\t\tstableStringifyEvaluationCase(currentCase) !==\n\t\t\tstableStringifyEvaluationCase(previousCase)\n\t\t);\n\t});\n\tconst unchangedCaseIds = currentIds.filter((id: string) => {\n\t\tconst currentCase = currentMap.get(id);\n\t\tconst previousCase = previousMap.get(id);\n\t\tif (!currentCase || !previousCase) {\n\t\t\treturn false;\n\t\t}\n\t\treturn (\n\t\t\tstableStringifyEvaluationCase(currentCase) ===\n\t\t\tstableStringifyEvaluationCase(previousCase)\n\t\t);\n\t});\n\tconst sharedIds = currentIds.filter((id: string) => previousMap.has(id));\n\tconst orderChanged =\n\t\tsharedIds.length > 0 &&\n\t\tJSON.stringify(sharedIds) !==\n\t\t\tJSON.stringify(\n\t\t\t\tpreviousIds.filter((id: string) => currentMap.has(id))\n\t\t\t);\n\n\treturn {\n\t\taddedCaseIds,\n\t\tcaseCountDelta: current.caseCount - (previous?.caseCount ?? 0),\n\t\tchangedCaseIds,\n\t\tcurrentSnapshotId: current.id,\n\t\torderChanged,\n\t\tpreviousSnapshotId: previous?.id,\n\t\tremovedCaseIds,\n\t\tsuiteId: current.suiteId,\n\t\tunchangedCaseIds\n\t};\n};\nexport const evaluateRAGCollection = async ({\n\tcollection,\n\tinput,\n\tdefaultTopK = DEFAULT_TOP_K,\n\trerank\n}: {\n\tcollection: RAGCollection;\n\tinput: RAGEvaluationInput;\n\tdefaultTopK?: number;\n\trerank?: RAGRerankerProviderLike;\n}) => {\n\tconst evaluated = await evaluateRAGCollectionCases({\n\t\tcollection,\n\t\tdefaultTopK,\n\t\tincludeTrace: false,\n\t\tinput,\n\t\trerank\n\t});\n\n\treturn buildRAGEvaluationResponse(\n\t\tevaluated.map((entry) => entry.caseResult)\n\t);\n};\nexport const executeDryRunRAGEvaluation = (\n\tinput: RAGEvaluationInput,\n\tdefaultTopK = DEFAULT_TOP_K\n): RAGEvaluationCaseResult[] =>\n\tinput.cases.map((caseInput, caseIndex) => {\n\t\tconst mode = resolveEvaluationMode(caseInput);\n\t\tconst expectedIds = normalizeExpectedIds(\n\t\t\tmode === 'chunkId'\n\t\t\t\t? (caseInput.expectedChunkIds ?? [])\n\t\t\t\t: mode === 'source'\n\t\t\t\t\t? (caseInput.expectedSources ?? [])\n\t\t\t\t\t: (caseInput.expectedDocumentIds ?? [])\n\t\t);\n\t\tconst effectiveTopK =\n\t\t\ttypeof caseInput.topK === 'number'\n\t\t\t\t? caseInput.topK\n\t\t\t\t: typeof input.topK === 'number'\n\t\t\t\t\t? input.topK\n\t\t\t\t\t: defaultTopK;\n\n\t\treturn {\n\t\t\tcaseId: caseInput.id ?? `case-${caseIndex + 1}`,\n\t\t\telapsedMs: 0,\n\t\t\texpectedCount: expectedIds.length,\n\t\t\texpectedIds,\n\t\t\tfailureClasses: classifyRAGEvaluationFailure({\n\t\t\t\texpectedCount: expectedIds.length,\n\t\t\t\tmatchedCount: 0,\n\t\t\t\tmissingIds: expectedIds,\n\t\t\t\tretrievedCount: 0,\n\t\t\t\tretrievedIds: []\n\t\t\t}),\n\t\t\tf1: 0,\n\t\t\tlabel: caseInput.label,\n\t\t\tmatchedCount: 0,\n\t\t\tmatchedIds: [],\n\t\t\tmissingIds: expectedIds,\n\t\t\tmode,\n\t\t\tprecision: 0,\n\t\t\tquery: caseInput.query,\n\t\t\trecall: 0,\n\t\t\tretrievedCount: 0,\n\t\t\tretrievedIds: [],\n\t\t\tstatus: expectedIds.length === 0 ? 'partial' : 'fail',\n\t\t\ttopK: effectiveTopK\n\t\t};\n\t});\nexport const runRAGEvaluationSuite = async ({\n\tsuite,\n\tevaluate,\n\toverrides,\n\tartifacts\n}: {\n\tsuite: RAGEvaluationSuite;\n\tevaluate: (input: RAGEvaluationInput) => Promise<RAGEvaluationResponse>;\n\toverrides?: Partial<RAGEvaluationInput>;\n\tartifacts?: Pick<\n\t\tRAGEvaluationSuiteRun,\n\t\t'traceSummary' | 'caseTraceSnapshots'\n\t>;\n}) => {\n\tconst startedAt = Date.now();\n\tconst response = await evaluate({\n\t\t...suite.input,\n\t\t...overrides,\n\t\tcases: overrides?.cases ?? suite.input.cases\n\t});\n\tconst finishedAt = Date.now();\n\n\treturn {\n\t\tcaseTraceSnapshots: artifacts?.caseTraceSnapshots,\n\t\telapsedMs: finishedAt - startedAt,\n\t\tfinishedAt,\n\t\tid: generateId(),\n\t\tlabel: suite.label ?? suite.id,\n\t\tmetadata: suite.metadata,\n\t\tresponse,\n\t\tstartedAt,\n\t\tsuiteId: suite.id,\n\t\ttraceSummary: artifacts?.traceSummary\n\t} satisfies RAGEvaluationSuiteRun;\n};\nexport const summarizeRAGEvaluationCase = ({\n\tcaseIndex,\n\tcaseInput,\n\tquery,\n\tmode,\n\tretrievedIds,\n\texpectedIds,\n\telapsedMs,\n\tretrievedSources,\n\ttrace\n}: {\n\tcaseIndex: number;\n\tcaseInput: RAGEvaluationCase;\n\tmode: 'chunkId' | 'source' | 'documentId';\n\tquery: string;\n\tretrievedIds: string[];\n\texpectedIds: string[];\n\telapsedMs: number;\n\tretrievedSources?: RAGSource[];\n\ttrace?: RAGSearchTraceRecord | RAGRetrievalTrace;\n}): RAGEvaluationCaseResult => {\n\tconst expectedSet = new Set(expectedIds);\n\tconst retrievedSet = new Set(retrievedIds);\n\tconst matchedIds = normalizeExpectedIds(\n\t\t[...expectedSet].filter((id) => retrievedSet.has(id))\n\t);\n\tconst missingIds = normalizeExpectedIds(\n\t\t[...expectedSet].filter((id) => !retrievedSet.has(id))\n\t);\n\tconst matchedCount = matchedIds.length;\n\tconst retrievedCount = retrievedIds.length;\n\tconst expectedCount = expectedIds.length;\n\tconst precision = retrievedCount > 0 ? matchedCount / retrievedCount : 0;\n\tconst recall = expectedCount > 0 ? matchedCount / expectedCount : 0;\n\tconst f1 =\n\t\tprecision + recall > 0\n\t\t\t? (2 * precision * recall) / (precision + recall)\n\t\t\t: 0;\n\tconst status: RAGEvaluationCaseResult['status'] =\n\t\texpectedCount === 0\n\t\t\t? 'partial'\n\t\t\t: matchedCount === expectedCount\n\t\t\t\t? 'pass'\n\t\t\t\t: matchedCount > 0\n\t\t\t\t\t? 'partial'\n\t\t\t\t\t: 'fail';\n\n\treturn {\n\t\tcaseId: caseInput.id ?? `case-${caseIndex + 1}`,\n\t\tcorpusKey: caseInput.corpusKey,\n\t\telapsedMs,\n\t\texpectedCount,\n\t\texpectedIds,\n\t\tfailureClasses: classifyRAGEvaluationFailure({\n\t\t\texpectedCount,\n\t\t\tmatchedCount,\n\t\t\tmissingIds,\n\t\t\tretrievedCount,\n\t\t\tretrievedIds,\n\t\t\tretrievedSources,\n\t\t\ttrace\n\t\t}),\n\t\tf1,\n\t\tlabel: caseInput.label,\n\t\tmatchedCount,\n\t\tmatchedIds,\n\t\tmetadata: caseInput.metadata,\n\t\tmissingIds,\n\t\tmode,\n\t\tprecision,\n\t\tquery,\n\t\trecall,\n\t\tretrievedCount,\n\t\tretrievedIds,\n\t\tstatus,\n\t\ttopK:\n\t\t\ttypeof caseInput.topK === 'number' ? caseInput.topK : DEFAULT_TOP_K\n\t};\n};\nexport const summarizeRAGRerankerComparison = (\n\tentries: RAGRerankerComparisonEntry[]\n): RAGRerankerComparisonSummary => {\n\treturn summarizeEvaluationResponseComparison(\n\t\tentries,\n\t\t'rerankerId'\n\t) satisfies RAGRerankerComparisonSummary;\n};\nexport const summarizeRAGRetrievalComparison = (\n\tentries: RAGRetrievalComparisonEntry[]\n): RAGRetrievalComparisonSummary => ({\n\t...summarizeEvaluationResponseComparison(entries, 'retrievalId'),\n\tbestByPresentationTitleCueCases:\n\t\tselectComparisonEntryByPresentationCueCases(\n\t\t\tentries,\n\t\t\t'retrievalId',\n\t\t\t'title'\n\t\t),\n\tbestByPresentationBodyCueCases: selectComparisonEntryByPresentationCueCases(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'body'\n\t),\n\tbestByPresentationNotesCueCases:\n\t\tselectComparisonEntryByPresentationCueCases(\n\t\t\tentries,\n\t\t\t'retrievalId',\n\t\t\t'notes'\n\t\t),\n\tbestBySpreadsheetSheetCueCases: selectComparisonEntryBySpreadsheetCueCases(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'sheet'\n\t),\n\tbestBySpreadsheetTableCueCases: selectComparisonEntryBySpreadsheetCueCases(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'table'\n\t),\n\tbestBySpreadsheetColumnCueCases: selectComparisonEntryBySpreadsheetCueCases(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'column'\n\t),\n\tbestByMultivectorCollapsedCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'multiVectorCollapsedCases'\n\t),\n\tbestByMultivectorLexicalHitCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'multiVectorLexicalHitCases'\n\t),\n\tbestByMultivectorVectorHitCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'multiVectorVectorHitCases'\n\t),\n\tbestByEvidenceReconcileCases: selectComparisonEntryByTraceStageCount(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'evidence_reconcile'\n\t),\n\tbestByOfficeEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'officeEvidenceReconcileCases'\n\t),\n\tbestByOfficeParagraphEvidenceReconcileCases:\n\t\tselectComparisonEntryByTraceMetric(\n\t\t\tentries,\n\t\t\t'retrievalId',\n\t\t\t'officeParagraphEvidenceReconcileCases'\n\t\t),\n\tbestByOfficeListEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'officeListEvidenceReconcileCases'\n\t),\n\tbestByOfficeTableEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'officeTableEvidenceReconcileCases'\n\t),\n\tbestByPDFEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n\t\tentries,\n\t\t'retrievalId',\n\t\t'pdfEvidenceReconcileCases'\n\t),\n\tbestByLowestRuntimeCandidateBudgetExhaustedCases:\n\t\tselectComparisonEntryByLowestTraceMetric(\n\t\t\tentries,\n\t\t\t'retrievalId',\n\t\t\t'runtimeCandidateBudgetExhaustedCases'\n\t\t),\n\tbestByLowestRuntimeUnderfilledTopKCases:\n\t\tselectComparisonEntryByLowestTraceMetric(\n\t\t\tentries,\n\t\t\t'retrievalId',\n\t\t\t'runtimeUnderfilledTopKCases'\n\t\t)\n});\n",
5
+ "import { computed, Injectable } from \"@angular/core\";\nimport { RAGStreamService } from \"./ai-rag-stream.service\";\n\n@Injectable({ providedIn: \"root\" })\nexport class RAGWorkflowService extends RAGStreamService {\n connect(path: string, conversationId?: string) {\n const stream = super.connect(path, conversationId);\n\n return {\n ...stream,\n state: computed(() => stream.workflow()),\n };\n }\n}\n",
6
+ "import { computed, Injectable } from \"@angular/core\";\nimport {\n buildRAGAnswerWorkflowState,\n buildRAGStreamProgress,\n} from \"../../ai/rag/workflowState\";\nimport { AIStreamService } from \"@absolutejs/ai/angular\";\n\n@Injectable({ providedIn: \"root\" })\nexport class RAGStreamService extends AIStreamService {\n connect(path: string, conversationId?: string) {\n const stream = super.connect(path, conversationId);\n\n const workflow = computed(() =>\n buildRAGAnswerWorkflowState({\n error: stream.error(),\n isStreaming: stream.isStreaming(),\n messages: stream.messages(),\n }),\n );\n const progress = computed(() =>\n buildRAGStreamProgress({\n error: stream.error(),\n isStreaming: stream.isStreaming(),\n messages: stream.messages(),\n }),\n );\n const latestAssistantMessage = computed(\n () => workflow().latestAssistantMessage,\n );\n const sources = computed(() => workflow().sources);\n const sourceGroups = computed(() => workflow().sourceGroups);\n const citations = computed(() => workflow().citations);\n const sourceSummaries = computed(() => workflow().sourceSummaries);\n const citationReferenceMap = computed(\n () => workflow().citationReferenceMap,\n );\n const retrieval = computed(() => workflow().retrieval);\n const groundedAnswer = computed(() => workflow().groundedAnswer);\n const groundingReferences = computed(() => workflow().groundingReferences);\n const hasRetrieved = computed(() => workflow().hasRetrieved);\n const hasSources = computed(() => workflow().hasSources);\n const isRetrieving = computed(() => workflow().isRetrieving);\n const isRetrieved = computed(() => workflow().isRetrieved);\n const isAnswerStreaming = computed(() => workflow().isAnswerStreaming);\n const isComplete = computed(() => workflow().isComplete);\n const isError = computed(() => workflow().isError);\n const isRunning = computed(() => workflow().isRunning);\n const stage = computed(() => workflow().stage);\n\n return {\n ...stream,\n citations,\n citationReferenceMap,\n groundedAnswer,\n groundingReferences,\n hasRetrieved,\n hasSources,\n isAnswerStreaming,\n isComplete,\n isError,\n isRetrieved,\n isRetrieving,\n isRunning,\n latestAssistantMessage,\n progress,\n query: stream.send,\n retrieval,\n sourceGroups,\n sourceSummaries,\n sources,\n stage,\n workflow,\n };\n }\n}\n",
7
+ "import type {\n RAGCitation,\n RAGCitationReferenceMap,\n RAGExcerptModeCounts,\n RAGGroundedAnswer,\n RAGGroundedAnswerCitationDetail,\n RAGGroundedAnswerSectionSummary,\n RAGGroundingReference,\n RAGSource,\n} from \"@absolutejs/ai\";\n\nconst getContextString = (value: unknown) =>\n typeof value === \"string\" && value.trim().length > 0\n ? value.trim()\n : undefined;\n\nconst getContextNumber = (value: unknown) =>\n typeof value === \"number\" && Number.isFinite(value) ? value : undefined;\n\nconst getAttachmentName = (source?: string, title?: string) => {\n const sourceAttachment = source?.split(\"/\").at(-1);\n if (sourceAttachment && sourceAttachment.includes(\".\")) {\n return sourceAttachment;\n }\n\n const titleAttachment = title?.split(\" · \").at(-1);\n if (titleAttachment && titleAttachment.includes(\".\")) {\n return titleAttachment;\n }\n\n return undefined;\n};\n\nconst buildContextLabel = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const emailKind = getContextString(metadata.emailKind);\n const officeBlockKindValue = getContextString(metadata.officeBlockKind);\n const officeBlockKind =\n officeBlockKindValue === \"table\" ||\n officeBlockKindValue === \"list\" ||\n officeBlockKindValue === \"paragraph\"\n ? officeBlockKindValue\n : undefined;\n if (emailKind === \"attachment\") {\n return \"Attachment evidence\";\n }\n\n if (emailKind === \"message\") {\n const from = getContextString(metadata.from);\n return from ? `Message from ${from}` : \"Message evidence\";\n }\n\n const page =\n getContextNumber(metadata.page) ??\n getContextNumber(metadata.pageNumber) ??\n (typeof metadata.pageIndex === \"number\"\n ? metadata.pageIndex + 1\n : undefined);\n const region =\n getContextNumber(metadata.regionNumber) ??\n (typeof metadata.regionIndex === \"number\"\n ? metadata.regionIndex + 1\n : undefined);\n if (page && region) {\n return `Page ${page} region ${region}`;\n }\n if (page) {\n return `Page ${page}`;\n }\n\n const sheet =\n getContextString(metadata.sheetName) ??\n (Array.isArray(metadata.sheetNames)\n ? getContextString(metadata.sheetNames[0])\n : undefined);\n if (sheet) {\n return `Sheet ${sheet}`;\n }\n\n const slide =\n getContextNumber(metadata.slide) ??\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n const slideTitle = getContextString(metadata.slideTitle);\n if (slide) {\n return slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n }\n\n const archiveEntry =\n getContextString(metadata.archiveEntryPath) ??\n getContextString(metadata.entryPath);\n if (archiveEntry) {\n return `Archive entry ${archiveEntry}`;\n }\n\n const threadTopic = getContextString(metadata.threadTopic);\n if (threadTopic) {\n return `Thread ${threadTopic}`;\n }\n\n const speaker = getContextString(metadata.speaker);\n if (speaker) {\n return `Speaker ${speaker}`;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n const officeSectionLabel =\n sectionPath.length > 0 ? sectionPath.join(\" > \") : sectionTitle;\n if (officeBlockKind === \"table\" && officeSectionLabel) {\n return `Office table block ${officeSectionLabel}`;\n }\n if (officeBlockKind === \"list\" && officeSectionLabel) {\n return `Office list block ${officeSectionLabel}`;\n }\n if (officeBlockKind === \"paragraph\" && officeSectionLabel) {\n return `Office paragraph block ${officeSectionLabel}`;\n }\n if (sectionTitle) {\n return `Section ${sectionTitle}`;\n }\n\n return undefined;\n};\n\nconst formatMediaTimestamp = (value: unknown) => {\n if (typeof value !== \"number\" || !Number.isFinite(value) || value < 0) {\n return undefined;\n }\n\n const totalSeconds = Math.floor(value / 1000);\n const minutes = Math.floor(totalSeconds / 60);\n const seconds = totalSeconds % 60;\n const milliseconds = Math.floor(value % 1000);\n\n return `${String(minutes).padStart(2, \"0\")}:${String(seconds).padStart(\n 2,\n \"0\",\n )}.${String(milliseconds).padStart(3, \"0\")}`;\n};\n\nconst formatMediaDurationLabel = (value: unknown) => {\n if (typeof value !== \"number\" || !Number.isFinite(value) || value < 0) {\n return undefined;\n }\n\n return formatMediaTimestamp(value);\n};\n\nconst formatOfficeListLevelsLabel = (value: unknown) => {\n if (!Array.isArray(value) || value.length === 0) {\n return undefined;\n }\n\n const levels = value\n .map((entry) => getContextNumber(entry))\n .filter((entry): entry is number => typeof entry === \"number\")\n .sort((left, right) => left - right);\n\n if (levels.length === 0) {\n return undefined;\n }\n\n const minLevel = levels[0];\n const maxLevel = levels[levels.length - 1];\n\n return minLevel === maxLevel\n ? `Office list level ${minLevel}`\n : `Office list levels ${minLevel}-${maxLevel}`;\n};\n\ntype OfficeCitationScope = {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n};\n\ntype GenericStructuredCitationScope = {\n familyPath: string[];\n kind: \"presentation_slide\" | \"spreadsheet_rows\";\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n};\n\nconst getOfficeTableCitationScope = (\n metadata?: Record<string, unknown>,\n): OfficeCitationScope | undefined => {\n if (!metadata) {\n return undefined;\n }\n\n const officeBlockKindValue = getContextString(metadata.officeBlockKind);\n const officeBlockKind =\n officeBlockKindValue === \"table\" ||\n officeBlockKindValue === \"list\" ||\n officeBlockKindValue === \"paragraph\"\n ? officeBlockKindValue\n : undefined;\n if (\n officeBlockKind !== \"table\" &&\n officeBlockKind !== \"list\" &&\n officeBlockKind !== \"paragraph\"\n ) {\n return undefined;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n const officeContextText =\n officeBlockKind === \"table\"\n ? getContextString(metadata.officeTableContextText)\n : officeBlockKind === \"list\"\n ? getContextString(metadata.officeListContextText)\n : undefined;\n\n if (!sectionTitle) {\n return undefined;\n }\n\n return {\n blockKind: officeBlockKind,\n familyPath: (() => {\n const explicitGenericFamilyPath = Array.isArray(\n metadata.sectionFamilyPath,\n )\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitGenericOrdinalPath = Array.isArray(\n metadata.sectionOrdinalPath,\n )\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n if (\n explicitGenericFamilyPath.length > 0 &&\n explicitGenericFamilyPath.length === explicitGenericOrdinalPath.length\n ) {\n return explicitGenericFamilyPath;\n }\n\n const explicitOfficeFamilyPath = Array.isArray(metadata.officeFamilyPath)\n ? metadata.officeFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n return explicitOfficeFamilyPath.length > 0\n ? explicitOfficeFamilyPath\n : sectionPath.map((value) => value.replace(/\\s+\\((\\d+)\\)$/, \"\").trim());\n })(),\n pathDepth: sectionPath.length,\n ordinalPath: (() => {\n const explicitGenericFamilyPath = Array.isArray(\n metadata.sectionFamilyPath,\n )\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitGenericOrdinalPath = Array.isArray(\n metadata.sectionOrdinalPath,\n )\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n if (\n explicitGenericFamilyPath.length > 0 &&\n explicitGenericFamilyPath.length === explicitGenericOrdinalPath.length\n ) {\n return explicitGenericOrdinalPath;\n }\n\n const explicitOfficeOrdinalPath = Array.isArray(\n metadata.officeOrdinalPath,\n )\n ? metadata.officeOrdinalPath\n .map((value) =>\n typeof value === \"number\" && Number.isFinite(value)\n ? value\n : undefined,\n )\n .filter((value): value is number => typeof value === \"number\")\n : [];\n return explicitOfficeOrdinalPath.length > 0\n ? explicitOfficeOrdinalPath\n : sectionPath.map((value) => {\n const match = value.match(/\\((\\d+)\\)$/);\n return match ? Number.parseInt(match[1] ?? \"1\", 10) : 1;\n });\n })(),\n sectionFamilyKey:\n getContextString(metadata.sectionSiblingFamilyKey) ??\n getContextString(metadata.officeSiblingFamilyKey) ??\n sectionPath\n .at(-1)\n ?.replace(/\\s+\\((\\d+)\\)$/, \"\")\n .trim() ??\n sectionTitle,\n sectionOrdinal:\n getContextNumber(metadata.sectionSiblingOrdinal) ??\n getContextNumber(metadata.officeSiblingOrdinal) ??\n (() => {\n const match = sectionTitle.match(/\\((\\d+)\\)$/);\n return match ? Number.parseInt(match[1] ?? \"1\", 10) : 1;\n })(),\n sectionTitle,\n hasContext: typeof officeContextText === \"string\",\n };\n};\n\nconst areOfficeCitationScopesComparable = (\n left:\n | {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n }\n | undefined,\n right:\n | {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n }\n | undefined,\n) => {\n if (!left || !right) {\n return false;\n }\n if (\n left.blockKind !== right.blockKind ||\n left.sectionFamilyKey !== right.sectionFamilyKey ||\n left.sectionOrdinal !== right.sectionOrdinal\n ) {\n return false;\n }\n const leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n const rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n const leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n const rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n const sharedDepth = Math.min(\n leftAncestorFamilyPath.length,\n rightAncestorFamilyPath.length,\n );\n for (let index = 0; index < sharedDepth; index += 1) {\n if (\n leftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n leftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n ) {\n return false;\n }\n }\n return true;\n};\n\nconst getGenericStructuredCitationScope = (\n metadata?: Record<string, unknown>,\n): GenericStructuredCitationScope | undefined => {\n if (!metadata || metadata.officeBlockKind || metadata.pageNumber) {\n return undefined;\n }\n\n const kind =\n metadata.sectionKind === \"spreadsheet_rows\" ||\n metadata.sectionKind === \"presentation_slide\"\n ? metadata.sectionKind\n : undefined;\n if (!kind) {\n return undefined;\n }\n\n const explicitFamilyPath = Array.isArray(metadata.sectionFamilyPath)\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitOrdinalPath = Array.isArray(metadata.sectionOrdinalPath)\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n let familyPath =\n explicitFamilyPath.length > 0 &&\n explicitFamilyPath.length === explicitOrdinalPath.length\n ? explicitFamilyPath\n : [];\n let ordinalPath =\n explicitFamilyPath.length > 0 &&\n explicitFamilyPath.length === explicitOrdinalPath.length\n ? explicitOrdinalPath\n : [];\n\n if (familyPath.length === 0) {\n if (kind === \"spreadsheet_rows\") {\n const sheetName = getContextString(metadata.sheetName) ?? \"Sheet\";\n const tableIndex = getContextNumber(metadata.spreadsheetTableIndex) ?? 1;\n familyPath = [sheetName, \"Spreadsheet Table\"];\n ordinalPath = [1, tableIndex];\n } else {\n const slideFamily = getContextString(metadata.slideTitle) ?? \"Slide\";\n const slideOrdinal =\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\" ? metadata.slideIndex + 1 : 1);\n familyPath = [slideFamily];\n ordinalPath = [slideOrdinal];\n }\n }\n\n const sectionFamilyKey =\n getContextString(metadata.sectionSiblingFamilyKey) ?? familyPath.at(-1);\n const sectionOrdinal =\n getContextNumber(metadata.sectionSiblingOrdinal) ?? ordinalPath.at(-1);\n if (!sectionFamilyKey || typeof sectionOrdinal !== \"number\") {\n return undefined;\n }\n\n return {\n familyPath,\n kind,\n ordinalPath,\n pathDepth: familyPath.length,\n sectionFamilyKey,\n sectionOrdinal,\n };\n};\n\nconst areGenericStructuredCitationScopesComparable = (\n left: GenericStructuredCitationScope | undefined,\n right: GenericStructuredCitationScope | undefined,\n) => {\n if (!left || !right) {\n return false;\n }\n if (\n left.kind !== right.kind ||\n left.sectionFamilyKey !== right.sectionFamilyKey ||\n left.sectionOrdinal !== right.sectionOrdinal\n ) {\n return false;\n }\n const leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n const rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n const leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n const rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n const sharedDepth = Math.min(\n leftAncestorFamilyPath.length,\n rightAncestorFamilyPath.length,\n );\n for (let index = 0; index < sharedDepth; index += 1) {\n if (\n leftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n leftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n ) {\n return false;\n }\n }\n return true;\n};\n\nconst getOfficeTableCitationPreference = (\n metadata?: Record<string, unknown>,\n) => {\n const scope = getOfficeTableCitationScope(metadata);\n if (!scope) {\n return 0;\n }\n\n return (\n scope.pathDepth * 10 +\n (scope.hasContext ? 1 : 0) +\n (scope.blockKind === \"list\" &&\n typeof metadata?.officeListGroupItemCount === \"number\" &&\n metadata.officeListGroupItemCount > 1\n ? 1\n : 0)\n );\n};\n\nconst getGenericStructuredCitationPreference = (\n metadata?: Record<string, unknown>,\n) => {\n const scope = getGenericStructuredCitationScope(metadata);\n if (!scope) {\n return 0;\n }\n\n return (\n scope.pathDepth * 10 +\n (scope.kind === \"spreadsheet_rows\" &&\n typeof metadata?.spreadsheetTableIndex === \"number\"\n ? 2\n : 0) +\n (Array.isArray(metadata?.spreadsheetHeaders) &&\n metadata.spreadsheetHeaders.length > 0\n ? 1\n : 0) +\n (typeof metadata?.slideNotesText === \"string\" &&\n metadata.slideNotesText.trim().length > 0\n ? 1\n : 0)\n );\n};\n\nconst buildLocatorLabel = (\n metadata?: Record<string, unknown>,\n source?: string,\n title?: string,\n) => {\n if (!metadata) {\n return undefined;\n }\n\n const page =\n getContextNumber(metadata.page) ??\n getContextNumber(metadata.pageNumber) ??\n (typeof metadata.pageIndex === \"number\"\n ? metadata.pageIndex + 1\n : undefined);\n const region =\n getContextNumber(metadata.regionNumber) ??\n (typeof metadata.regionIndex === \"number\"\n ? metadata.regionIndex + 1\n : undefined);\n if (page && region) {\n return `Page ${page} · Region ${region}`;\n }\n if (page) {\n return `Page ${page}`;\n }\n\n const sheet =\n getContextString(metadata.sheetName) ??\n (Array.isArray(metadata.sheetNames)\n ? getContextString(metadata.sheetNames[0])\n : undefined);\n if (sheet) {\n return `Sheet ${sheet}`;\n }\n\n const slide =\n getContextNumber(metadata.slide) ??\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n const slideTitle = getContextString(metadata.slideTitle);\n if (slide) {\n return slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n }\n\n const archiveEntry =\n getContextString(metadata.archiveEntryPath) ??\n getContextString(metadata.entryPath);\n if (archiveEntry) {\n return `Archive entry ${archiveEntry}`;\n }\n\n const emailKind = getContextString(metadata.emailKind);\n const officeBlockKind = getContextString(metadata.officeBlockKind);\n const officeBlockNumber = getContextNumber(metadata.officeBlockNumber);\n const officeTableBodyRowStart = getContextNumber(\n metadata.officeTableBodyRowStart,\n );\n const officeTableBodyRowEnd = getContextNumber(\n metadata.officeTableBodyRowEnd,\n );\n if (emailKind === \"attachment\") {\n const attachmentName =\n getContextString(metadata.attachmentName) ??\n getAttachmentName(source, title);\n return attachmentName ? `Attachment ${attachmentName}` : \"Attachment\";\n }\n\n const mediaStart = formatMediaTimestamp(metadata.startMs);\n const mediaEnd = formatMediaTimestamp(metadata.endMs);\n if (mediaStart && mediaEnd) {\n return `Timestamp ${mediaStart} - ${mediaEnd}`;\n }\n\n if (mediaStart) {\n return `Timestamp ${mediaStart}`;\n }\n\n if (officeBlockNumber && officeBlockKind === \"table\") {\n if (\n typeof officeTableBodyRowStart === \"number\" &&\n typeof officeTableBodyRowEnd === \"number\"\n ) {\n return officeTableBodyRowStart === officeTableBodyRowEnd\n ? `Office table block ${officeBlockNumber} · Row ${officeTableBodyRowStart}`\n : `Office table block ${officeBlockNumber} · Rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`;\n }\n return `Office table block ${officeBlockNumber}`;\n }\n if (officeBlockNumber && officeBlockKind === \"list\") {\n return `Office list block ${officeBlockNumber}`;\n }\n if (officeBlockNumber && officeBlockKind === \"paragraph\") {\n return `Office paragraph block ${officeBlockNumber}`;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n if (sectionPath.length > 0) {\n return `Section ${sectionPath.join(\" > \")}`;\n }\n\n return undefined;\n};\n\nconst formatTimestampLabel = (value: unknown) => {\n const timestamp =\n typeof value === \"number\" && Number.isFinite(value)\n ? value\n : typeof value === \"string\"\n ? Date.parse(value)\n : Number.NaN;\n if (!Number.isFinite(timestamp)) {\n return undefined;\n }\n\n return new Date(timestamp).toLocaleString(\"en-US\", {\n dateStyle: \"medium\",\n timeStyle: \"short\",\n });\n};\n\nconst buildProvenanceLabel = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const threadTopic = getContextString(metadata.threadTopic);\n const from = getContextString(metadata.from);\n const sentAt =\n formatTimestampLabel(metadata.sentAt) ??\n formatTimestampLabel(metadata.receivedAt);\n const speaker = getContextString(metadata.speaker);\n const mediaKind = getContextString(metadata.mediaKind);\n const mediaSegmentCount = getContextNumber(metadata.mediaSegmentCount);\n const mediaSegmentGroupSize = getContextNumber(\n metadata.mediaSegmentGroupSize,\n );\n const mediaSegmentGroupIndex = getContextNumber(\n metadata.mediaSegmentGroupIndex,\n );\n const mediaChannel = getContextString(metadata.mediaChannel);\n const mediaSpeakerCount = getContextNumber(metadata.mediaSpeakerCount);\n const mediaDurationLabel = formatMediaDurationLabel(metadata.mediaDurationMs);\n const transcriptSource = getContextString(metadata.transcriptSource);\n const pdfTextMode = getContextString(metadata.pdfTextMode);\n const officeBlockKind = getContextString(metadata.officeBlockKind);\n const officeListContextText = getContextString(\n metadata.officeListContextText,\n );\n const officeListGroupItemCount = getContextNumber(\n metadata.officeListGroupItemCount,\n );\n const officeListLevelsLabel = formatOfficeListLevelsLabel(\n metadata.officeListLevels,\n );\n const officeTableHeaders = Array.isArray(metadata.officeTableHeaders)\n ? metadata.officeTableHeaders\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const officeTableColumnCount = getContextNumber(\n metadata.officeTableColumnCount,\n );\n const officeTableBodyRowCount = getContextNumber(\n metadata.officeTableBodyRowCount,\n );\n const officeTableBodyRowStart = getContextNumber(\n metadata.officeTableBodyRowStart,\n );\n const officeTableBodyRowEnd = getContextNumber(\n metadata.officeTableBodyRowEnd,\n );\n const officeTableContextText = getContextString(\n metadata.officeTableContextText,\n );\n const officeTableFollowUpText = getContextString(\n metadata.officeTableFollowUpText,\n );\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const ocrEngine = getContextString(metadata.ocrEngine);\n const ocrConfidence =\n getContextNumber(metadata.ocrRegionConfidence) ??\n getContextNumber(metadata.ocrConfidence);\n\n const labels = [\n pdfTextMode ? `PDF ${pdfTextMode}` : \"\",\n officeBlockKind ? `Office ${officeBlockKind}` : \"\",\n typeof officeListGroupItemCount === \"number\"\n ? `Office list ${officeListGroupItemCount} items`\n : \"\",\n officeListLevelsLabel ?? \"\",\n sectionPath.length > 0 && officeBlockKind\n ? `Source-aware office ${officeBlockKind} block ${sectionPath.join(\" > \")}`\n : \"\",\n officeListContextText ? `Office list context ${officeListContextText}` : \"\",\n officeTableHeaders.length > 0\n ? `Office table ${officeTableHeaders.join(\", \")}`\n : \"\",\n typeof officeTableColumnCount === \"number\"\n ? `Office table ${officeTableColumnCount} cols`\n : \"\",\n typeof officeTableBodyRowCount === \"number\"\n ? `Office table ${officeTableBodyRowCount} body rows`\n : \"\",\n typeof officeTableBodyRowStart === \"number\" &&\n typeof officeTableBodyRowEnd === \"number\"\n ? officeTableBodyRowStart === officeTableBodyRowEnd\n ? `Office table row ${officeTableBodyRowStart}`\n : `Office table rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`\n : \"\",\n officeTableContextText\n ? `Office table context ${officeTableContextText}`\n : \"\",\n officeTableFollowUpText\n ? `Office table follow-up ${officeTableFollowUpText}`\n : \"\",\n ocrEngine ? `OCR ${ocrEngine}` : \"\",\n typeof ocrConfidence === \"number\"\n ? `Confidence ${ocrConfidence.toFixed(2)}`\n : \"\",\n mediaKind ? `Media ${mediaKind}` : \"\",\n mediaSegmentCount ? `${mediaSegmentCount} segments` : \"\",\n mediaSegmentGroupSize ? `${mediaSegmentGroupSize} grouped segments` : \"\",\n mediaSegmentGroupIndex !== undefined\n ? `Segment group ${mediaSegmentGroupIndex + 1}`\n : \"\",\n mediaChannel ? `Channel ${mediaChannel}` : \"\",\n mediaSpeakerCount ? `${mediaSpeakerCount} speakers` : \"\",\n mediaDurationLabel ? `Duration ${mediaDurationLabel}` : \"\",\n transcriptSource ? `Transcript ${transcriptSource}` : \"\",\n threadTopic ? `Thread ${threadTopic}` : \"\",\n speaker ? `Speaker ${speaker}` : \"\",\n from ? `Sender ${from}` : \"\",\n sentAt ? `Sent ${sentAt}` : \"\",\n ].filter((value) => value.length > 0);\n\n return labels.length > 0 ? labels.join(\" · \") : undefined;\n};\n\nconst buildSourceLabel = (source: RAGSource) =>\n source.source ?? source.title ?? source.chunkId;\n\nconst buildExcerpt = (text: string, maxLength = 160) => {\n const normalized = text.replaceAll(/\\s+/g, \" \").trim();\n if (normalized.length <= maxLength) {\n return normalized;\n }\n\n return `${normalized.slice(0, Math.max(0, maxLength - 1)).trimEnd()}…`;\n};\n\nconst selectPreferredExcerpt = (\n excerpts?: {\n chunkExcerpt?: string;\n windowExcerpt?: string;\n sectionExcerpt?: string;\n },\n sectionChunkCount?: number,\n) => {\n if (!excerpts) {\n return {\n excerpt: \"\",\n mode: \"chunk\" as const,\n reason: \"single_chunk\" as const,\n };\n }\n\n const chunkExcerpt = excerpts.chunkExcerpt?.trim() ?? \"\";\n const windowExcerpt = excerpts.windowExcerpt?.trim() ?? \"\";\n const sectionExcerpt = excerpts.sectionExcerpt?.trim() ?? \"\";\n if (\n sectionChunkCount &&\n sectionChunkCount > 1 &&\n chunkExcerpt.length > 0 &&\n chunkExcerpt.length < 72\n ) {\n if (sectionChunkCount <= 3 && sectionExcerpt) {\n return {\n excerpt: sectionExcerpt,\n mode: \"section\" as const,\n reason: \"section_small_enough\" as const,\n };\n }\n if (windowExcerpt) {\n return {\n excerpt: windowExcerpt,\n mode: \"window\" as const,\n reason: \"section_too_large_use_window\" as const,\n };\n }\n\n return {\n excerpt: chunkExcerpt,\n mode: \"chunk\" as const,\n reason: \"chunk_too_narrow\" as const,\n };\n }\n\n return {\n excerpt: chunkExcerpt || windowExcerpt || sectionExcerpt,\n mode: \"chunk\" as const,\n reason:\n (sectionChunkCount ?? 0) > 1\n ? (\"chunk_too_narrow\" as const)\n : (\"single_chunk\" as const),\n };\n};\n\nconst buildExcerptModeCounts = (\n references: Array<\n { excerptSelection?: { mode: \"chunk\" | \"window\" | \"section\" } } | undefined\n >,\n): RAGExcerptModeCounts =>\n references.reduce<RAGExcerptModeCounts>(\n (counts, reference) => {\n if (reference?.excerptSelection) {\n counts[reference.excerptSelection.mode] += 1;\n }\n return counts;\n },\n { chunk: 0, section: 0, window: 0 },\n );\n\nconst buildGroundingChunkExcerpts = (\n sources: RAGSource[],\n activeChunkId?: string,\n) => {\n if (sources.length === 0) {\n return undefined;\n }\n\n const activeSource =\n (activeChunkId\n ? sources.find((source) => source.chunkId === activeChunkId)\n : undefined) ?? sources[0];\n if (!activeSource) {\n return undefined;\n }\n\n const chunkMap = new Map(sources.map((source) => [source.chunkId, source]));\n const activeMetadata = activeSource.metadata ?? {};\n const previousChunkId = getContextString(activeMetadata.previousChunkId);\n const nextChunkId = getContextString(activeMetadata.nextChunkId);\n const sectionChunkId = getContextString(activeMetadata.sectionChunkId);\n const sectionSources = sectionChunkId\n ? sources\n .filter(\n (source) =>\n getContextString(source.metadata?.sectionChunkId) ===\n sectionChunkId,\n )\n .sort((left, right) => {\n const leftIndex =\n getContextNumber(left.metadata?.sectionChunkIndex) ??\n Number.MAX_SAFE_INTEGER;\n const rightIndex =\n getContextNumber(right.metadata?.sectionChunkIndex) ??\n Number.MAX_SAFE_INTEGER;\n if (leftIndex !== rightIndex) {\n return leftIndex - rightIndex;\n }\n return left.chunkId.localeCompare(right.chunkId);\n })\n : [activeSource];\n const collectText = (chunkIds: string[]) =>\n chunkIds\n .map((chunkId) => chunkMap.get(chunkId)?.text)\n .filter((text): text is string => typeof text === \"string\")\n .join(\"\\n\\n\");\n const orderedWindowIds = [\n previousChunkId,\n activeSource.chunkId,\n nextChunkId,\n ].filter(\n (chunkId, index, values): chunkId is string =>\n Boolean(chunkId) && values.indexOf(chunkId) === index,\n );\n\n return {\n chunkExcerpt: buildExcerpt(activeSource.text, 160),\n sectionExcerpt: buildExcerpt(\n sectionSources.map((source) => source.text).join(\"\\n\\n\"),\n 320,\n ),\n windowExcerpt: buildExcerpt(collectText(orderedWindowIds), 240),\n };\n};\n\nconst buildGroundingReferenceEvidenceLabel = (\n reference: RAGGroundingReference,\n) =>\n [reference.label, reference.locatorLabel, reference.contextLabel]\n .filter((value): value is string => Boolean(value && value.length > 0))\n .filter(\n (value, index, values) =>\n values.findIndex((entry) => entry === value) === index,\n )\n .join(\" · \");\n\nconst buildGroundingReferenceEvidenceSummary = (\n reference: RAGGroundingReference,\n) =>\n [\n reference.source ?? reference.title ?? reference.chunkId,\n reference.locatorLabel,\n reference.contextLabel,\n reference.provenanceLabel,\n ]\n .filter((value): value is string => Boolean(value && value.length > 0))\n .filter(\n (value, index, values) =>\n values.findIndex((entry) => entry === value) === index,\n )\n .join(\" · \");\n\nconst buildGroundingSectionKey = (reference: RAGGroundingReference) =>\n reference.contextLabel ??\n reference.locatorLabel ??\n reference.label ??\n reference.source ??\n reference.chunkId;\n\nconst buildGroundingSectionSummaryLine = (reference: RAGGroundingReference) =>\n [\n reference.source ?? reference.title ?? reference.chunkId,\n reference.locatorLabel,\n reference.contextLabel,\n reference.provenanceLabel,\n ]\n .filter((value): value is string => Boolean(value && value.length > 0))\n .filter(\n (value, index, values) =>\n values.findIndex((entry) => entry === value) === index,\n )\n .join(\" · \");\n\nconst buildGroundedAnswerCitationDetail = (\n reference: RAGGroundingReference,\n): RAGGroundedAnswerCitationDetail => ({\n contextLabel: reference.contextLabel,\n evidenceLabel: buildGroundingReferenceEvidenceLabel(reference),\n evidenceSummary: buildGroundingReferenceEvidenceSummary(reference),\n excerpt:\n selectPreferredExcerpt(\n reference.excerpts,\n getContextNumber(reference.metadata?.sectionChunkCount),\n ).excerpt || reference.excerpt,\n excerpts: reference.excerpts,\n excerptSelection: reference.excerptSelection,\n label: reference.label,\n locatorLabel: reference.locatorLabel,\n number: reference.number,\n provenanceLabel: reference.provenanceLabel,\n source: reference.source,\n title: reference.title,\n});\n\nexport const buildRAGCitationReferenceMap = (\n citations: RAGCitation[],\n): RAGCitationReferenceMap =>\n Object.fromEntries(\n citations.map((citation, index) => [citation.chunkId, index + 1]),\n );\n\nexport const buildRAGCitations = (sources: RAGSource[]) => {\n const unique = new Map<string, RAGCitation>();\n\n for (const source of sources) {\n const key = source.chunkId;\n const existing = unique.get(key);\n const hasBetterExisting =\n existing !== undefined && existing.score >= source.score;\n if (hasBetterExisting) continue;\n const excerpts = buildGroundingChunkExcerpts(sources, source.chunkId);\n const excerptSelection = selectPreferredExcerpt(\n excerpts,\n getContextNumber(source.metadata?.sectionChunkCount),\n );\n\n unique.set(key, {\n chunkId: source.chunkId,\n contextLabel:\n source.labels?.contextLabel ?? buildContextLabel(source.metadata),\n excerpt: excerptSelection.excerpt || buildExcerpt(source.text),\n excerpts,\n excerptSelection,\n key,\n label: buildSourceLabel(source),\n locatorLabel:\n source.labels?.locatorLabel ??\n buildLocatorLabel(source.metadata, source.source, source.title),\n metadata: source.metadata,\n provenanceLabel:\n source.labels?.provenanceLabel ?? buildProvenanceLabel(source.metadata),\n score: source.score,\n source: source.source,\n text: source.text,\n title: source.title,\n });\n }\n\n return [...unique.values()].sort((left, right) => {\n const leftOfficeScope = getOfficeTableCitationScope(left.metadata);\n const rightOfficeScope = getOfficeTableCitationScope(right.metadata);\n if (\n left.source === right.source &&\n areOfficeCitationScopesComparable(leftOfficeScope, rightOfficeScope)\n ) {\n const leftOfficePreference = getOfficeTableCitationPreference(\n left.metadata,\n );\n const rightOfficePreference = getOfficeTableCitationPreference(\n right.metadata,\n );\n if (rightOfficePreference !== leftOfficePreference) {\n return rightOfficePreference - leftOfficePreference;\n }\n }\n const leftGenericScope = getGenericStructuredCitationScope(left.metadata);\n const rightGenericScope = getGenericStructuredCitationScope(right.metadata);\n if (\n left.source === right.source &&\n areGenericStructuredCitationScopesComparable(\n leftGenericScope,\n rightGenericScope,\n )\n ) {\n const leftGenericPreference = getGenericStructuredCitationPreference(\n left.metadata,\n );\n const rightGenericPreference = getGenericStructuredCitationPreference(\n right.metadata,\n );\n if (rightGenericPreference !== leftGenericPreference) {\n return rightGenericPreference - leftGenericPreference;\n }\n }\n if (right.score !== left.score) {\n return right.score - left.score;\n }\n\n return left.label.localeCompare(right.label);\n });\n};\n\nexport const buildRAGGroundedAnswer = (\n content: string,\n sources: RAGSource[],\n): RAGGroundedAnswer => {\n const references = buildRAGGroundingReferences(sources);\n const sectionSummaries = buildRAGGroundedAnswerSectionSummaries(references);\n const referenceMap = new Map(\n references.map((reference) => [reference.number, reference]),\n );\n const parts: RAGGroundedAnswer[\"parts\"] = [];\n const ungroundedReferenceNumbers = new Set<number>();\n const citationPattern = /\\[(\\d+(?:\\s*,\\s*\\d+)*)\\]/g;\n let cursor = 0;\n\n for (const match of content.matchAll(citationPattern)) {\n const raw = match[0];\n const numbers = (match[1] ?? \"\")\n .split(\",\")\n .map((value) => Number.parseInt(value.trim(), 10))\n .filter((value) => Number.isInteger(value) && value > 0);\n const start = match.index ?? cursor;\n if (start > cursor) {\n parts.push({\n text: content.slice(cursor, start),\n type: \"text\",\n });\n }\n\n const resolvedReferences = numbers\n .map((number) => referenceMap.get(number))\n .filter((reference): reference is RAGGroundingReference =>\n Boolean(reference),\n );\n for (const number of numbers) {\n if (!referenceMap.has(number)) {\n ungroundedReferenceNumbers.add(number);\n }\n }\n const unresolvedNumbers = numbers.filter(\n (number) => !referenceMap.has(number),\n );\n\n parts.push({\n referenceNumbers: numbers,\n referenceDetails: resolvedReferences.map(\n buildGroundedAnswerCitationDetail,\n ),\n references: resolvedReferences,\n text: raw,\n type: \"citation\",\n unresolvedReferenceNumbers: unresolvedNumbers,\n });\n cursor = start + raw.length;\n }\n\n if (cursor < content.length || parts.length === 0) {\n parts.push({\n text: content.slice(cursor),\n type: \"text\",\n });\n }\n\n const hasCitations = parts.some((part) => part.type === \"citation\");\n const coverage: RAGGroundedAnswer[\"coverage\"] = !hasCitations\n ? \"ungrounded\"\n : ungroundedReferenceNumbers.size === 0\n ? \"grounded\"\n : references.length > 0\n ? \"partial\"\n : \"ungrounded\";\n\n return {\n content,\n coverage,\n excerptModeCounts: buildExcerptModeCounts([\n ...references,\n ...sectionSummaries,\n ]),\n hasCitations,\n parts,\n references,\n sectionSummaries,\n ungroundedReferenceNumbers: [...ungroundedReferenceNumbers].sort(\n (left, right) => left - right,\n ),\n };\n};\n\nexport const buildRAGGroundedAnswerSectionSummaries = (\n references: RAGGroundingReference[],\n): RAGGroundedAnswerSectionSummary[] => {\n const groups = new Map<string, RAGGroundedAnswerSectionSummary>();\n\n for (const reference of references) {\n const key = buildGroundingSectionKey(reference);\n const existing = groups.get(key);\n if (!existing) {\n const excerpts = reference.excerpts\n ? {\n chunkExcerpt: reference.excerpts.chunkExcerpt,\n sectionExcerpt: reference.excerpts.sectionExcerpt,\n windowExcerpt: reference.excerpts.windowExcerpt,\n }\n : undefined;\n groups.set(key, {\n chunkIds: [reference.chunkId],\n contextLabel: reference.contextLabel,\n count: 1,\n excerpt:\n selectPreferredExcerpt(\n excerpts,\n getContextNumber(reference.metadata?.sectionChunkCount),\n ).excerpt ||\n excerpts?.sectionExcerpt ||\n reference.excerpt,\n excerpts,\n excerptSelection: reference.excerptSelection,\n key,\n label: key,\n locatorLabel: reference.locatorLabel,\n provenanceLabel: reference.provenanceLabel,\n referenceNumbers: [reference.number],\n references: [reference],\n summary:\n buildGroundingSectionSummaryLine(reference) ||\n reference.label ||\n reference.chunkId,\n });\n continue;\n }\n\n existing.count += 1;\n if (!existing.chunkIds.includes(reference.chunkId)) {\n existing.chunkIds.push(reference.chunkId);\n }\n if (!existing.referenceNumbers.includes(reference.number)) {\n existing.referenceNumbers.push(reference.number);\n }\n existing.references.push(reference);\n if (!existing.contextLabel && reference.contextLabel) {\n existing.contextLabel = reference.contextLabel;\n }\n if (!existing.locatorLabel && reference.locatorLabel) {\n existing.locatorLabel = reference.locatorLabel;\n }\n if (!existing.provenanceLabel && reference.provenanceLabel) {\n existing.provenanceLabel = reference.provenanceLabel;\n }\n if (!existing.excerpts && reference.excerpts) {\n existing.excerpts = {\n chunkExcerpt: reference.excerpts.chunkExcerpt,\n sectionExcerpt: reference.excerpts.sectionExcerpt,\n windowExcerpt: reference.excerpts.windowExcerpt,\n };\n existing.excerpt = reference.excerpts.sectionExcerpt;\n }\n if (!existing.excerptSelection && reference.excerptSelection) {\n existing.excerptSelection = reference.excerptSelection;\n }\n }\n\n return [...groups.values()]\n .map((group) => ({\n ...group,\n referenceNumbers: [...group.referenceNumbers].sort(\n (left, right) => left - right,\n ),\n references: group.references\n .slice()\n .sort((left, right) => left.number - right.number),\n }))\n .sort((left, right) => {\n const leftFirst = left.referenceNumbers[0] ?? Number.POSITIVE_INFINITY;\n const rightFirst = right.referenceNumbers[0] ?? Number.POSITIVE_INFINITY;\n if (leftFirst !== rightFirst) {\n return leftFirst - rightFirst;\n }\n return left.label.localeCompare(right.label);\n });\n};\n\nexport const buildRAGGroundingReferences = (sources: RAGSource[]) => {\n const citations = buildRAGCitations(sources);\n const citationReferenceMap = buildRAGCitationReferenceMap(citations);\n\n return citations.map<RAGGroundingReference>((citation) => {\n const excerpts = buildGroundingChunkExcerpts(sources, citation.chunkId);\n const excerptSelection = selectPreferredExcerpt(\n excerpts,\n getContextNumber(citation.metadata?.sectionChunkCount),\n );\n return {\n chunkId: citation.chunkId,\n contextLabel:\n citation.contextLabel ?? buildContextLabel(citation.metadata),\n excerpt:\n excerptSelection.excerpt ||\n excerpts?.chunkExcerpt ||\n buildExcerpt(citation.text),\n excerpts,\n excerptSelection,\n label: citation.label,\n locatorLabel:\n citation.locatorLabel ??\n buildLocatorLabel(citation.metadata, citation.source, citation.title),\n metadata: citation.metadata,\n number: citationReferenceMap[citation.chunkId] ?? 0,\n provenanceLabel:\n citation.provenanceLabel ?? buildProvenanceLabel(citation.metadata),\n score: citation.score,\n source: citation.source,\n text: citation.text,\n title: citation.title,\n };\n });\n};\n",
8
+ "import { mkdir, readFile, writeFile } from \"node:fs/promises\";\nimport { dirname } from \"node:path\";\nimport type { Database } from \"bun:sqlite\";\nimport type {\n RAGAnswerGroundingCaseDifficultyDiffEntry,\n RAGAnswerGroundingCaseDifficultyHistory,\n RAGAnswerGroundingCaseDifficultyHistoryStore,\n RAGAnswerGroundingCaseDifficultyRun,\n RAGAnswerGroundingCaseDifficultyRunDiff,\n RAGAnswerGroundingEvaluationCaseDiff,\n RAGAnswerGroundingEvaluationCase,\n RAGAnswerGroundingEvaluationCaseDifficultyEntry,\n RAGAnswerGroundingEvaluationCaseSnapshot,\n RAGAnswerGroundingEvaluationCaseResult,\n RAGAnswerGroundingEvaluationHistory,\n RAGAnswerGroundingEvaluationLeaderboardEntry,\n RAGAnswerGroundingEvaluationHistoryStore,\n RAGAnswerGroundingEvaluationInput,\n RAGAnswerGroundingEvaluationResponse,\n RAGAnswerGroundingEvaluationRun,\n RAGAnswerGroundingEvaluationRunDiff,\n RAGCollection,\n RAGIndexedDocument,\n RAGEvaluationCase,\n RAGEvaluationCaseDiff,\n RAGEvaluationCaseTraceSnapshot,\n RAGEvaluationCaseResult,\n RAGEvaluationHistory,\n RAGEvaluationHistoryStore,\n RAGEvaluationHistoryPruneInput,\n RAGEvaluationHistoryPruneResult,\n RAGEvaluationInput,\n RAGEvaluationLeaderboardEntry,\n RAGEvaluationResponse,\n RAGEvaluationRunDiff,\n RAGLabelValueRow,\n RAGComparisonPresentation,\n RAGComparisonOverviewPresentation,\n RAGGroundingProviderPresentation,\n RAGGroundingProviderOverviewPresentation,\n RAGGroundingProviderCaseComparisonPresentation,\n RAGGroundingOverviewPresentation,\n RAGQualityOverviewPresentation,\n RAGDocumentChunk,\n RAGEvaluationSuite,\n RAGEvaluationSuiteGenerationOptions,\n RAGEvaluationSuiteDatasetSummary,\n RAGEvaluationSuiteSnapshot,\n RAGEvaluationSuiteSnapshotDiff,\n RAGEvaluationSuiteSnapshotHistory,\n RAGEvaluationSuiteSnapshotHistoryStore,\n RAGEvaluationSuiteRun,\n RAGEvaluationEntityQualitySummary,\n RAGEvaluationEntityQualityView,\n RAGAnswerGroundingEntityQualitySummary,\n RAGAnswerGroundingEntityQualityView,\n RAGRetrievalTraceSummaryRun,\n RAGHybridRetrievalMode,\n RAGSourceBalanceStrategy,\n RAGRetrievalCandidate,\n RAGRetrievalComparison,\n RAGRetrievalBaselineGatePolicy,\n RAGRetrievalBaselineGatePolicyHistoryRecord,\n RAGRetrievalBaselineGatePolicyHistoryStore,\n RAGRetrievalComparisonDecisionSummary,\n RAGRetrievalComparisonGateResult,\n RAGRetrievalReleaseVerdict,\n RAGRetrievalComparisonHistoryStore,\n RAGRetrievalBaselineRecord,\n RAGRetrievalBaselineStore,\n RAGRetrievalLaneHandoffDecisionRecord,\n RAGRetrievalLaneHandoffDecisionStore,\n RAGRetrievalLaneHandoffIncidentHistoryRecord,\n RAGRetrievalLaneHandoffIncidentHistoryStore,\n RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord,\n RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore,\n RAGRetrievalLaneHandoffIncidentRecord,\n RAGRetrievalLaneHandoffIncidentStore,\n RAGRetrievalIncidentRemediationDecisionRecord,\n RAGRetrievalIncidentRemediationDecisionStore,\n RAGRetrievalIncidentRemediationExecutionHistoryRecord,\n RAGRetrievalIncidentRemediationExecutionHistoryStore,\n RAGRetrievalReleaseDecisionRecord,\n RAGRetrievalReleaseLanePolicyHistoryRecord,\n RAGRetrievalReleaseLanePolicyHistoryStore,\n RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord,\n RAGRetrievalReleaseLaneEscalationPolicyHistoryStore,\n RAGRetrievalReleaseDecisionStore,\n RAGRetrievalReleaseIncidentRecord,\n RAGRetrievalReleaseIncidentStore,\n RAGRetrievalComparisonRun,\n RAGRetrievalComparisonEntry,\n RAGRetrievalTrace,\n RAGRetrievalTraceComparisonSummary,\n RAGRetrievalTraceComparisonSummaryDiff,\n RAGRetrievalTraceStep,\n RAGRetrievalTraceStage,\n RAGQueryResult,\n RAGTraceSummaryListTrend,\n RAGTraceSummaryTrendDirection,\n RAGTraceSummaryNumericDelta,\n RAGTraceSummaryStageTrend,\n RAGTraceSummaryStageCountsDelta,\n RAGRetrievalComparisonSummary,\n RAGRetrievalTraceHistoryWindow,\n RAGRerankerCandidate,\n RAGRerankerComparison,\n RAGRerankerComparisonEntry,\n RAGRerankerComparisonSummary,\n RAGRerankerProviderLike,\n RAGRetrievalTraceTrend,\n RAGSearchTraceDiff,\n RAGSearchTraceGroupHistory,\n RAGSearchTraceGroupHistoryEntry,\n RAGSearchTraceHistory,\n RAGChatPluginConfig,\n RAGSearchTracePruneInput,\n RAGSearchTracePruneHistoryStore,\n RAGSearchTracePruneRun,\n RAGSearchTracePrunePreview,\n RAGSearchTracePruneResult,\n RAGSearchTraceRecord,\n RAGSearchTraceResultSnapshot,\n RAGSearchTraceStats,\n RAGSearchTraceStore,\n RAGRemediationAction,\n RAGSource,\n RAGCollectionSearchParams,\n RAGSQLiteStoreMigrationInspection,\n RAGSQLiteStoreMigrationIssue,\n RAGSQLiteStoreMigrationResult,\n} from \"@absolutejs/ai\";\nimport { generateId } from \"@absolutejs/ai\";\nimport { buildRAGGroundedAnswer } from \"./grounding\";\nimport { buildRAGSourceLabels } from \"./presentation\";\n\nconst DEFAULT_TOP_K = 6;\nconst DEFAULT_HISTORY_LIMIT = 20;\nconst DEFAULT_SEARCH_TRACE_TABLE_NAME = \"rag_search_traces\";\n\nconst getTraceLabelString = (value: unknown) =>\n typeof value === \"string\" && value.trim().length > 0\n ? value.trim()\n : undefined;\n\nconst getTraceLabelNumber = (value: unknown) =>\n typeof value === \"number\" && Number.isFinite(value) ? value : undefined;\n\nconst formatTraceSpreadsheetTableLabel = (\n tableIndex?: number,\n tableCount?: number,\n) => {\n if (\n typeof tableIndex !== \"number\" ||\n !Number.isFinite(tableIndex) ||\n tableIndex < 1\n ) {\n return undefined;\n }\n\n if (\n typeof tableCount === \"number\" &&\n Number.isFinite(tableCount) &&\n tableCount >= tableIndex\n ) {\n return `Table ${tableIndex} of ${tableCount}`;\n }\n\n return `Table ${tableIndex}`;\n};\n\nconst formatTraceSourceAwareChunkReason = (value: unknown) => {\n const reason = getTraceLabelString(value);\n if (reason === \"section_boundary\") {\n return \"Chunk boundary section\";\n }\n if (reason === \"size_limit\") {\n return \"Chunk boundary size limit\";\n }\n if (reason === \"source_native_unit\") {\n return \"Chunk boundary source-native unit\";\n }\n return undefined;\n};\n\nconst buildTraceSourceAwareUnitScopeLabel = (\n metadata?: Record<string, unknown>,\n) => {\n if (!metadata) {\n return undefined;\n }\n\n const sectionKind = getTraceLabelString(metadata.sectionKind);\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getTraceLabelString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getTraceLabelString(metadata.sectionTitle) ?? sectionPath.at(-1);\n const pdfTextKind = getTraceLabelString(metadata.pdfTextKind);\n const officeBlockKind = getTraceLabelString(metadata.officeBlockKind);\n const sheetName = getTraceLabelString(metadata.sheetName);\n const spreadsheetTableLabel = formatTraceSpreadsheetTableLabel(\n getTraceLabelNumber(metadata.spreadsheetTableIndex),\n getTraceLabelNumber(metadata.spreadsheetTableCount),\n );\n const slideTitle = getTraceLabelString(metadata.slideTitle);\n const slideNumber =\n getTraceLabelNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n\n if (\n sectionPath.length > 0 &&\n (sectionKind === \"markdown_heading\" ||\n sectionKind === \"html_heading\" ||\n sectionKind === \"office_heading\" ||\n sectionKind === undefined)\n ) {\n return `Source-aware section ${sectionPath.join(\" > \")}`;\n }\n\n if (sectionKind === \"pdf_block\") {\n if (pdfTextKind === \"table_like\" && sectionTitle) {\n return `Source-aware PDF table block ${sectionTitle}`;\n }\n if (sectionTitle) {\n return `Source-aware PDF block ${sectionTitle}`;\n }\n return \"Source-aware PDF block\";\n }\n\n if (sectionKind === \"office_block\") {\n if (officeBlockKind && sectionTitle) {\n return `Source-aware office ${officeBlockKind} block ${sectionTitle}`;\n }\n if (sectionTitle) {\n return `Source-aware office block ${sectionTitle}`;\n }\n return \"Source-aware office block\";\n }\n\n if (\n sectionKind === \"spreadsheet_rows\" ||\n (sectionKind === undefined &&\n (sheetName ||\n spreadsheetTableLabel ||\n getTraceLabelNumber(metadata.spreadsheetRowStart) !== undefined ||\n getTraceLabelNumber(metadata.spreadsheetRowEnd) !== undefined))\n ) {\n if (sheetName && spreadsheetTableLabel) {\n return `Source-aware spreadsheet ${sheetName} ${spreadsheetTableLabel}`;\n }\n if (sheetName) {\n return `Source-aware spreadsheet ${sheetName}`;\n }\n return \"Source-aware spreadsheet\";\n }\n\n if (sectionKind === \"presentation_slide\") {\n if (slideNumber && slideTitle) {\n return `Source-aware slide ${slideNumber} ${slideTitle}`;\n }\n if (slideTitle) {\n return `Source-aware slide ${slideTitle}`;\n }\n if (slideNumber) {\n return `Source-aware slide ${slideNumber}`;\n }\n return \"Source-aware slide\";\n }\n\n return undefined;\n};\n\nconst buildEvaluationLeadSnapshot = (input?: {\n metadata?: Record<string, unknown>;\n source?: string;\n title?: string;\n}): Pick<\n RAGEvaluationCaseTraceSnapshot,\n | \"topContextLabel\"\n | \"topLocatorLabel\"\n | \"sourceAwareChunkReasonLabel\"\n | \"sourceAwareUnitScopeLabel\"\n> => {\n const labels = buildRAGSourceLabels({\n metadata: input?.metadata,\n source: input?.source,\n title: input?.title,\n });\n\n return {\n sourceAwareChunkReasonLabel: formatTraceSourceAwareChunkReason(\n input?.metadata?.sourceAwareChunkReason,\n ),\n sourceAwareUnitScopeLabel: buildTraceSourceAwareUnitScopeLabel(\n input?.metadata,\n ),\n topContextLabel: labels?.contextLabel,\n topLocatorLabel: labels?.locatorLabel,\n };\n};\n\nconst buildEvaluationLeadMediaCueSnapshot = (\n trace?: RAGRetrievalTrace,\n): Pick<\n RAGEvaluationCaseTraceSnapshot,\n | \"leadSpeakerCue\"\n | \"leadSpeakerAttributionCue\"\n | \"leadChannelCue\"\n | \"leadChannelAttributionCue\"\n | \"leadContinuityCue\"\n> => {\n const rerankStep = trace?.steps.find((step) => step.stage === \"rerank\");\n const metadata = rerankStep?.metadata ?? {};\n\n return {\n leadChannelAttributionCue:\n typeof metadata.leadChannelAttributionCue === \"string\"\n ? metadata.leadChannelAttributionCue\n : undefined,\n leadChannelCue:\n typeof metadata.leadChannelCue === \"string\"\n ? metadata.leadChannelCue\n : undefined,\n leadContinuityCue:\n typeof metadata.leadContinuityCue === \"string\"\n ? metadata.leadContinuityCue\n : undefined,\n leadSpeakerAttributionCue:\n typeof metadata.leadSpeakerAttributionCue === \"string\"\n ? metadata.leadSpeakerAttributionCue\n : undefined,\n leadSpeakerCue:\n typeof metadata.leadSpeakerCue === \"string\"\n ? metadata.leadSpeakerCue\n : undefined,\n };\n};\n\nconst buildEvaluationLeadPresentationCueSnapshot = (\n trace?: RAGRetrievalTrace,\n): Pick<RAGEvaluationCaseTraceSnapshot, \"leadPresentationCue\"> => {\n const rerankStep = trace?.steps.find((step) => step.stage === \"rerank\");\n const metadata = rerankStep?.metadata ?? {};\n const cue = metadata.leadPresentationCue;\n\n return {\n leadPresentationCue:\n cue === \"title\" || cue === \"body\" || cue === \"notes\" ? cue : undefined,\n };\n};\n\nconst buildEvaluationLeadSpreadsheetCueSnapshot = (\n trace?: RAGRetrievalTrace,\n): Pick<RAGEvaluationCaseTraceSnapshot, \"leadSpreadsheetCue\"> => {\n const rerankStep = trace?.steps.find((step) => step.stage === \"rerank\");\n const metadata = rerankStep?.metadata ?? {};\n const cue = metadata.leadSpreadsheetCue;\n\n return {\n leadSpreadsheetCue:\n cue === \"sheet\" || cue === \"table\" || cue === \"column\" ? cue : undefined,\n };\n};\n\nconst buildEvaluationSQLiteQueryPlanSnapshot = (\n trace?: RAGRetrievalTrace,\n): Pick<\n RAGEvaluationCaseTraceSnapshot,\n | \"sqliteQueryMode\"\n | \"sqliteQueryPushdownMode\"\n | \"sqliteQueryPushdownApplied\"\n | \"sqliteQueryPushdownClauseCount\"\n | \"sqliteQueryTotalFilterClauseCount\"\n | \"sqliteQueryJsRemainderClauseCount\"\n | \"sqliteQueryMultiplierUsed\"\n | \"sqliteQueryCandidateLimitUsed\"\n | \"sqliteQueryMaxBackfillsUsed\"\n | \"sqliteQueryMinResultsUsed\"\n | \"sqliteQueryFillPolicyUsed\"\n | \"sqliteQueryPushdownCoverageRatio\"\n | \"sqliteQueryJsRemainderRatio\"\n | \"sqliteQueryFilteredCandidates\"\n | \"sqliteQueryInitialSearchK\"\n | \"sqliteQueryFinalSearchK\"\n | \"sqliteQuerySearchExpansionRatio\"\n | \"sqliteQueryBackfillCount\"\n | \"sqliteQueryBackfillLimitReached\"\n | \"sqliteQueryMinResultsSatisfied\"\n | \"sqliteQueryReturnedCount\"\n | \"sqliteQueryCandidateYieldRatio\"\n | \"sqliteQueryTopKFillRatio\"\n | \"sqliteQueryUnderfilledTopK\"\n | \"sqliteQueryCandidateBudgetExhausted\"\n | \"sqliteQueryCandidateCoverage\"\n> => {\n const vectorStep = trace?.steps.find(\n (step) => step.stage === \"vector_search\",\n );\n const metadata = vectorStep?.metadata ?? {};\n\n return {\n sqliteQueryBackfillCount:\n typeof metadata.sqliteQueryBackfillCount === \"number\"\n ? metadata.sqliteQueryBackfillCount\n : undefined,\n sqliteQueryCandidateBudgetExhausted:\n typeof metadata.sqliteQueryCandidateBudgetExhausted === \"boolean\"\n ? metadata.sqliteQueryCandidateBudgetExhausted\n : undefined,\n sqliteQueryCandidateCoverage:\n metadata.sqliteQueryCandidateCoverage === \"empty\" ||\n metadata.sqliteQueryCandidateCoverage === \"under_target\" ||\n metadata.sqliteQueryCandidateCoverage === \"target_sized\" ||\n metadata.sqliteQueryCandidateCoverage === \"broad\"\n ? metadata.sqliteQueryCandidateCoverage\n : undefined,\n sqliteQueryFilteredCandidates:\n typeof metadata.sqliteQueryFilteredCandidates === \"number\"\n ? metadata.sqliteQueryFilteredCandidates\n : undefined,\n sqliteQueryFinalSearchK:\n typeof metadata.sqliteQueryFinalSearchK === \"number\"\n ? metadata.sqliteQueryFinalSearchK\n : undefined,\n sqliteQueryInitialSearchK:\n typeof metadata.sqliteQueryInitialSearchK === \"number\"\n ? metadata.sqliteQueryInitialSearchK\n : undefined,\n sqliteQuerySearchExpansionRatio:\n typeof metadata.sqliteQuerySearchExpansionRatio === \"number\"\n ? metadata.sqliteQuerySearchExpansionRatio\n : undefined,\n sqliteQueryMode:\n metadata.sqliteQueryMode === \"json_fallback\" ||\n metadata.sqliteQueryMode === \"native_vec0\"\n ? metadata.sqliteQueryMode\n : undefined,\n sqliteQueryPushdownMode:\n metadata.sqliteQueryPushdownMode === \"none\" ||\n metadata.sqliteQueryPushdownMode === \"partial\" ||\n metadata.sqliteQueryPushdownMode === \"full\"\n ? metadata.sqliteQueryPushdownMode\n : undefined,\n sqliteQueryPushdownApplied:\n typeof metadata.sqliteQueryPushdownApplied === \"boolean\"\n ? metadata.sqliteQueryPushdownApplied\n : undefined,\n sqliteQueryPushdownClauseCount:\n typeof metadata.sqliteQueryPushdownClauseCount === \"number\"\n ? metadata.sqliteQueryPushdownClauseCount\n : undefined,\n sqliteQueryTotalFilterClauseCount:\n typeof metadata.sqliteQueryTotalFilterClauseCount === \"number\"\n ? metadata.sqliteQueryTotalFilterClauseCount\n : undefined,\n sqliteQueryJsRemainderClauseCount:\n typeof metadata.sqliteQueryJsRemainderClauseCount === \"number\"\n ? metadata.sqliteQueryJsRemainderClauseCount\n : undefined,\n sqliteQueryMultiplierUsed:\n typeof metadata.sqliteQueryMultiplierUsed === \"number\"\n ? metadata.sqliteQueryMultiplierUsed\n : undefined,\n sqliteQueryCandidateLimitUsed:\n typeof metadata.sqliteQueryCandidateLimitUsed === \"number\"\n ? metadata.sqliteQueryCandidateLimitUsed\n : undefined,\n sqliteQueryMaxBackfillsUsed:\n typeof metadata.sqliteQueryMaxBackfillsUsed === \"number\"\n ? metadata.sqliteQueryMaxBackfillsUsed\n : undefined,\n sqliteQueryMinResultsUsed:\n typeof metadata.sqliteQueryMinResultsUsed === \"number\"\n ? metadata.sqliteQueryMinResultsUsed\n : undefined,\n sqliteQueryFillPolicyUsed:\n metadata.sqliteQueryFillPolicyUsed === \"strict_topk\" ||\n metadata.sqliteQueryFillPolicyUsed === \"satisfy_min_results\"\n ? metadata.sqliteQueryFillPolicyUsed\n : undefined,\n sqliteQueryPushdownCoverageRatio:\n typeof metadata.sqliteQueryPushdownCoverageRatio === \"number\"\n ? metadata.sqliteQueryPushdownCoverageRatio\n : undefined,\n sqliteQueryJsRemainderRatio:\n typeof metadata.sqliteQueryJsRemainderRatio === \"number\"\n ? metadata.sqliteQueryJsRemainderRatio\n : undefined,\n sqliteQueryReturnedCount:\n typeof metadata.sqliteQueryReturnedCount === \"number\"\n ? metadata.sqliteQueryReturnedCount\n : undefined,\n sqliteQueryCandidateYieldRatio:\n typeof metadata.sqliteQueryCandidateYieldRatio === \"number\"\n ? metadata.sqliteQueryCandidateYieldRatio\n : undefined,\n sqliteQueryBackfillLimitReached:\n typeof metadata.sqliteQueryBackfillLimitReached === \"boolean\"\n ? metadata.sqliteQueryBackfillLimitReached\n : undefined,\n sqliteQueryMinResultsSatisfied:\n typeof metadata.sqliteQueryMinResultsSatisfied === \"boolean\"\n ? metadata.sqliteQueryMinResultsSatisfied\n : undefined,\n sqliteQueryTopKFillRatio:\n typeof metadata.sqliteQueryTopKFillRatio === \"number\"\n ? metadata.sqliteQueryTopKFillRatio\n : undefined,\n sqliteQueryUnderfilledTopK:\n typeof metadata.sqliteQueryUnderfilledTopK === \"boolean\"\n ? metadata.sqliteQueryUnderfilledTopK\n : undefined,\n };\n};\n\nconst buildEvaluationPostgresQueryPlanSnapshot = (\n trace?: RAGRetrievalTrace,\n): Pick<\n RAGEvaluationCaseTraceSnapshot,\n | \"postgresQueryMode\"\n | \"postgresQueryPushdownMode\"\n | \"postgresQueryPushdownApplied\"\n | \"postgresQueryPushdownClauseCount\"\n | \"postgresQueryTotalFilterClauseCount\"\n | \"postgresQueryJsRemainderClauseCount\"\n | \"postgresQueryMultiplierUsed\"\n | \"postgresQueryCandidateLimitUsed\"\n | \"postgresQueryMaxBackfillsUsed\"\n | \"postgresQueryMinResultsUsed\"\n | \"postgresQueryFillPolicyUsed\"\n | \"postgresQueryPushdownCoverageRatio\"\n | \"postgresQueryJsRemainderRatio\"\n | \"postgresQueryFilteredCandidates\"\n | \"postgresQueryInitialSearchK\"\n | \"postgresQueryFinalSearchK\"\n | \"postgresQuerySearchExpansionRatio\"\n | \"postgresQueryBackfillCount\"\n | \"postgresQueryBackfillLimitReached\"\n | \"postgresQueryMinResultsSatisfied\"\n | \"postgresQueryReturnedCount\"\n | \"postgresQueryCandidateYieldRatio\"\n | \"postgresQueryTopKFillRatio\"\n | \"postgresQueryUnderfilledTopK\"\n | \"postgresQueryCandidateBudgetExhausted\"\n | \"postgresQueryCandidateCoverage\"\n> => {\n const vectorStep = trace?.steps.find(\n (step) => step.stage === \"vector_search\",\n );\n const metadata = vectorStep?.metadata ?? {};\n\n return {\n postgresQueryBackfillCount:\n typeof metadata.postgresQueryBackfillCount === \"number\"\n ? metadata.postgresQueryBackfillCount\n : undefined,\n postgresQueryCandidateBudgetExhausted:\n typeof metadata.postgresQueryCandidateBudgetExhausted === \"boolean\"\n ? metadata.postgresQueryCandidateBudgetExhausted\n : undefined,\n postgresQueryCandidateCoverage:\n metadata.postgresQueryCandidateCoverage === \"empty\" ||\n metadata.postgresQueryCandidateCoverage === \"under_target\" ||\n metadata.postgresQueryCandidateCoverage === \"target_sized\" ||\n metadata.postgresQueryCandidateCoverage === \"broad\"\n ? metadata.postgresQueryCandidateCoverage\n : undefined,\n postgresQueryFilteredCandidates:\n typeof metadata.postgresQueryFilteredCandidates === \"number\"\n ? metadata.postgresQueryFilteredCandidates\n : undefined,\n postgresQueryFinalSearchK:\n typeof metadata.postgresQueryFinalSearchK === \"number\"\n ? metadata.postgresQueryFinalSearchK\n : undefined,\n postgresQueryInitialSearchK:\n typeof metadata.postgresQueryInitialSearchK === \"number\"\n ? metadata.postgresQueryInitialSearchK\n : undefined,\n postgresQuerySearchExpansionRatio:\n typeof metadata.postgresQuerySearchExpansionRatio === \"number\"\n ? metadata.postgresQuerySearchExpansionRatio\n : undefined,\n postgresQueryMode:\n metadata.postgresQueryMode === \"native_pgvector\"\n ? metadata.postgresQueryMode\n : undefined,\n postgresQueryPushdownMode:\n metadata.postgresQueryPushdownMode === \"none\" ||\n metadata.postgresQueryPushdownMode === \"partial\" ||\n metadata.postgresQueryPushdownMode === \"full\"\n ? metadata.postgresQueryPushdownMode\n : undefined,\n postgresQueryPushdownApplied:\n typeof metadata.postgresQueryPushdownApplied === \"boolean\"\n ? metadata.postgresQueryPushdownApplied\n : undefined,\n postgresQueryPushdownClauseCount:\n typeof metadata.postgresQueryPushdownClauseCount === \"number\"\n ? metadata.postgresQueryPushdownClauseCount\n : undefined,\n postgresQueryTotalFilterClauseCount:\n typeof metadata.postgresQueryTotalFilterClauseCount === \"number\"\n ? metadata.postgresQueryTotalFilterClauseCount\n : undefined,\n postgresQueryJsRemainderClauseCount:\n typeof metadata.postgresQueryJsRemainderClauseCount === \"number\"\n ? metadata.postgresQueryJsRemainderClauseCount\n : undefined,\n postgresQueryMultiplierUsed:\n typeof metadata.postgresQueryMultiplierUsed === \"number\"\n ? metadata.postgresQueryMultiplierUsed\n : undefined,\n postgresQueryCandidateLimitUsed:\n typeof metadata.postgresQueryCandidateLimitUsed === \"number\"\n ? metadata.postgresQueryCandidateLimitUsed\n : undefined,\n postgresQueryMaxBackfillsUsed:\n typeof metadata.postgresQueryMaxBackfillsUsed === \"number\"\n ? metadata.postgresQueryMaxBackfillsUsed\n : undefined,\n postgresQueryMinResultsUsed:\n typeof metadata.postgresQueryMinResultsUsed === \"number\"\n ? metadata.postgresQueryMinResultsUsed\n : undefined,\n postgresQueryFillPolicyUsed:\n metadata.postgresQueryFillPolicyUsed === \"strict_topk\" ||\n metadata.postgresQueryFillPolicyUsed === \"satisfy_min_results\"\n ? metadata.postgresQueryFillPolicyUsed\n : undefined,\n postgresQueryPushdownCoverageRatio:\n typeof metadata.postgresQueryPushdownCoverageRatio === \"number\"\n ? metadata.postgresQueryPushdownCoverageRatio\n : undefined,\n postgresQueryJsRemainderRatio:\n typeof metadata.postgresQueryJsRemainderRatio === \"number\"\n ? metadata.postgresQueryJsRemainderRatio\n : undefined,\n postgresQueryReturnedCount:\n typeof metadata.postgresQueryReturnedCount === \"number\"\n ? metadata.postgresQueryReturnedCount\n : undefined,\n postgresQueryCandidateYieldRatio:\n typeof metadata.postgresQueryCandidateYieldRatio === \"number\"\n ? metadata.postgresQueryCandidateYieldRatio\n : undefined,\n postgresQueryBackfillLimitReached:\n typeof metadata.postgresQueryBackfillLimitReached === \"boolean\"\n ? metadata.postgresQueryBackfillLimitReached\n : undefined,\n postgresQueryMinResultsSatisfied:\n typeof metadata.postgresQueryMinResultsSatisfied === \"boolean\"\n ? metadata.postgresQueryMinResultsSatisfied\n : undefined,\n postgresQueryTopKFillRatio:\n typeof metadata.postgresQueryTopKFillRatio === \"number\"\n ? metadata.postgresQueryTopKFillRatio\n : undefined,\n postgresQueryUnderfilledTopK:\n typeof metadata.postgresQueryUnderfilledTopK === \"boolean\"\n ? metadata.postgresQueryUnderfilledTopK\n : undefined,\n };\n};\nconst DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME =\n \"rag_retrieval_comparison_history\";\nconst DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME =\n \"rag_retrieval_release_decisions\";\nconst DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME = \"rag_retrieval_baselines\";\nconst DEFAULT_RETRIEVAL_RELEASE_INCIDENT_TABLE_NAME =\n \"rag_retrieval_release_incidents\";\ntype BunSQLiteModule = {\n Database: new (path?: string) => Database;\n};\n\ntype ImportMetaWithRequire = ImportMeta & {\n require?: (specifier: string) => unknown;\n};\n\nconst loadBunSQLiteModule = (): BunSQLiteModule => {\n const runtimeRequire = (import.meta as ImportMetaWithRequire).require;\n if (typeof runtimeRequire !== \"function\") {\n throw new Error(\n \"SQLite trace storage requires Bun runtime support for import.meta.require.\",\n );\n }\n\n return runtimeRequire(\"bun:sqlite\") as BunSQLiteModule;\n};\n\nconst normalizeStringArray = (value: unknown) => {\n if (!Array.isArray(value)) {\n return [];\n }\n\n return value\n .filter((candidate) => typeof candidate === \"string\")\n .map((candidate) => candidate.trim())\n .filter((candidate) => candidate.length > 0);\n};\n\nconst normalizeLabelFilter = (value?: string) => {\n if (typeof value !== \"string\") {\n return undefined;\n }\n\n const normalized = value.trim().toLowerCase();\n return normalized.length > 0 ? normalized : undefined;\n};\n\nconst normalizeRetrievalBaselineRecords = (\n records: RAGRetrievalBaselineRecord[],\n) => [...records].sort((left, right) => right.promotedAt - left.promotedAt);\n\nconst normalizeRetrievalReleaseDecisionRecords = (\n records: RAGRetrievalReleaseDecisionRecord[],\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalLaneHandoffDecisionRecords = (\n records: RAGRetrievalLaneHandoffDecisionRecord[],\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalReleaseIncidentRecords = (\n records: RAGRetrievalReleaseIncidentRecord[],\n) => [...records].sort((left, right) => right.triggeredAt - left.triggeredAt);\n\nconst normalizeRetrievalIncidentRemediationDecisionRecords = (\n records: RAGRetrievalIncidentRemediationDecisionRecord[],\n) => [...records].sort((left, right) => right.decidedAt - left.decidedAt);\n\nconst normalizeRetrievalIncidentRemediationExecutionHistoryRecords = (\n records: RAGRetrievalIncidentRemediationExecutionHistoryRecord[],\n) => [...records].sort((left, right) => right.executedAt - left.executedAt);\n\nconst matchesWinner = (run: RAGRetrievalComparisonRun, winnerId?: string) => {\n if (!winnerId) {\n return true;\n }\n\n return (\n run.comparison.summary.bestByPassingRate === winnerId ||\n run.decisionSummary?.winnerByPassingRate === winnerId\n );\n};\n\nconst findRetrievalComparisonEntry = (\n comparison: RAGRetrievalComparison,\n retrievalId?: string,\n) => {\n if (!retrievalId) {\n return undefined;\n }\n\n return comparison.entries.find((entry) => entry.retrievalId === retrievalId);\n};\n\nconst evaluateRetrievalComparisonGate = ({\n delta,\n policy,\n}: {\n delta?: {\n passingRateDelta: number;\n averageF1Delta: number;\n elapsedMsDelta: number;\n presentationTitleCueCasesDelta?: number;\n presentationBodyCueCasesDelta?: number;\n presentationNotesCueCasesDelta?: number;\n spreadsheetSheetCueCasesDelta?: number;\n spreadsheetTableCueCasesDelta?: number;\n spreadsheetColumnCueCasesDelta?: number;\n multiVectorCollapsedCasesDelta?: number;\n multiVectorLexicalHitCasesDelta?: number;\n multiVectorVectorHitCasesDelta?: number;\n evidenceReconcileCasesDelta?: number;\n runtimeCandidateBudgetExhaustedCasesDelta?: number;\n runtimeUnderfilledTopKCasesDelta?: number;\n };\n policy?: RAGRetrievalBaselineGatePolicy;\n}): RAGRetrievalComparisonGateResult | undefined => {\n if (!delta || !policy) {\n return undefined;\n }\n\n const reasons: string[] = [];\n if (\n typeof policy.minPassingRateDelta === \"number\" &&\n delta.passingRateDelta < policy.minPassingRateDelta\n ) {\n reasons.push(\n `passing rate delta ${delta.passingRateDelta} is below ${policy.minPassingRateDelta}`,\n );\n }\n if (\n typeof policy.minAverageF1Delta === \"number\" &&\n delta.averageF1Delta < policy.minAverageF1Delta\n ) {\n reasons.push(\n `average F1 delta ${delta.averageF1Delta} is below ${policy.minAverageF1Delta}`,\n );\n }\n if (\n typeof policy.maxElapsedMsDelta === \"number\" &&\n delta.elapsedMsDelta > policy.maxElapsedMsDelta\n ) {\n reasons.push(\n `elapsed ms delta ${delta.elapsedMsDelta} exceeds ${policy.maxElapsedMsDelta}`,\n );\n }\n if (\n typeof policy.minPresentationTitleCueCasesDelta === \"number\" &&\n (delta.presentationTitleCueCasesDelta ?? 0) <\n policy.minPresentationTitleCueCasesDelta\n ) {\n reasons.push(\n `presentation title cue delta ${delta.presentationTitleCueCasesDelta ?? 0} is below ${policy.minPresentationTitleCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minPresentationBodyCueCasesDelta === \"number\" &&\n (delta.presentationBodyCueCasesDelta ?? 0) <\n policy.minPresentationBodyCueCasesDelta\n ) {\n reasons.push(\n `presentation body cue delta ${delta.presentationBodyCueCasesDelta ?? 0} is below ${policy.minPresentationBodyCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minPresentationNotesCueCasesDelta === \"number\" &&\n (delta.presentationNotesCueCasesDelta ?? 0) <\n policy.minPresentationNotesCueCasesDelta\n ) {\n reasons.push(\n `presentation notes cue delta ${delta.presentationNotesCueCasesDelta ?? 0} is below ${policy.minPresentationNotesCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minSpreadsheetSheetCueCasesDelta === \"number\" &&\n (delta.spreadsheetSheetCueCasesDelta ?? 0) <\n policy.minSpreadsheetSheetCueCasesDelta\n ) {\n reasons.push(\n `spreadsheet sheet cue delta ${delta.spreadsheetSheetCueCasesDelta ?? 0} is below ${policy.minSpreadsheetSheetCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minSpreadsheetTableCueCasesDelta === \"number\" &&\n (delta.spreadsheetTableCueCasesDelta ?? 0) <\n policy.minSpreadsheetTableCueCasesDelta\n ) {\n reasons.push(\n `spreadsheet table cue delta ${delta.spreadsheetTableCueCasesDelta ?? 0} is below ${policy.minSpreadsheetTableCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minSpreadsheetColumnCueCasesDelta === \"number\" &&\n (delta.spreadsheetColumnCueCasesDelta ?? 0) <\n policy.minSpreadsheetColumnCueCasesDelta\n ) {\n reasons.push(\n `spreadsheet column cue delta ${delta.spreadsheetColumnCueCasesDelta ?? 0} is below ${policy.minSpreadsheetColumnCueCasesDelta}`,\n );\n }\n if (\n typeof policy.minMultiVectorCollapsedCasesDelta === \"number\" &&\n (delta.multiVectorCollapsedCasesDelta ?? 0) <\n policy.minMultiVectorCollapsedCasesDelta\n ) {\n reasons.push(\n `multivector collapsed delta ${delta.multiVectorCollapsedCasesDelta ?? 0} is below ${policy.minMultiVectorCollapsedCasesDelta}`,\n );\n }\n if (\n typeof policy.minMultiVectorLexicalHitCasesDelta === \"number\" &&\n (delta.multiVectorLexicalHitCasesDelta ?? 0) <\n policy.minMultiVectorLexicalHitCasesDelta\n ) {\n reasons.push(\n `multivector lexical-hit delta ${delta.multiVectorLexicalHitCasesDelta ?? 0} is below ${policy.minMultiVectorLexicalHitCasesDelta}`,\n );\n }\n if (\n typeof policy.minMultiVectorVectorHitCasesDelta === \"number\" &&\n (delta.multiVectorVectorHitCasesDelta ?? 0) <\n policy.minMultiVectorVectorHitCasesDelta\n ) {\n reasons.push(\n `multivector vector-hit delta ${delta.multiVectorVectorHitCasesDelta ?? 0} is below ${policy.minMultiVectorVectorHitCasesDelta}`,\n );\n }\n if (\n typeof policy.minEvidenceReconcileCasesDelta === \"number\" &&\n (delta.evidenceReconcileCasesDelta ?? 0) <\n policy.minEvidenceReconcileCasesDelta\n ) {\n reasons.push(\n `evidence reconcile delta ${delta.evidenceReconcileCasesDelta ?? 0} is below ${policy.minEvidenceReconcileCasesDelta}`,\n );\n }\n if (\n typeof policy.maxRuntimeCandidateBudgetExhaustedCasesDelta === \"number\" &&\n (delta.runtimeCandidateBudgetExhaustedCasesDelta ?? 0) >\n policy.maxRuntimeCandidateBudgetExhaustedCasesDelta\n ) {\n reasons.push(\n `runtime candidate-budget-exhausted delta ${delta.runtimeCandidateBudgetExhaustedCasesDelta ?? 0} exceeds ${policy.maxRuntimeCandidateBudgetExhaustedCasesDelta}`,\n );\n }\n if (\n typeof policy.maxRuntimeUnderfilledTopKCasesDelta === \"number\" &&\n (delta.runtimeUnderfilledTopKCasesDelta ?? 0) >\n policy.maxRuntimeUnderfilledTopKCasesDelta\n ) {\n reasons.push(\n `runtime underfilled-topk delta ${delta.runtimeUnderfilledTopKCasesDelta ?? 0} exceeds ${policy.maxRuntimeUnderfilledTopKCasesDelta}`,\n );\n }\n\n if (reasons.length === 0) {\n return {\n policy,\n reasons: [],\n status: \"pass\",\n };\n }\n\n return {\n policy,\n reasons,\n status: policy.severity === \"warn\" ? \"warn\" : \"fail\",\n };\n};\n\nexport const buildRAGRetrievalReleaseVerdict = ({\n groupKey,\n decisionSummary,\n}: {\n groupKey?: string;\n decisionSummary?: RAGRetrievalComparisonDecisionSummary;\n}): RAGRetrievalReleaseVerdict | undefined => {\n if (!decisionSummary) {\n return undefined;\n }\n\n const gate = decisionSummary.gate;\n const delta = decisionSummary.delta;\n const baselineRetrievalId = decisionSummary.baselineRetrievalId;\n const candidateRetrievalId = decisionSummary.candidateRetrievalId;\n\n if (gate) {\n if (gate.status === \"pass\") {\n return {\n baselineGroupKey: groupKey,\n baselineRetrievalId,\n candidateRetrievalId,\n delta,\n gate,\n status: \"pass\",\n summary: \"Candidate passed the active baseline gate.\",\n };\n }\n\n return {\n baselineGroupKey: groupKey,\n baselineRetrievalId,\n candidateRetrievalId,\n delta,\n gate,\n status: gate.status,\n summary:\n gate.status === \"warn\"\n ? \"Candidate triggered a baseline gate warning.\"\n : \"Candidate failed the active baseline gate.\",\n };\n }\n\n if (delta) {\n const requiresReview =\n delta.passingRateDelta < 0 ||\n delta.averageF1Delta < 0 ||\n (delta.evidenceReconcileCasesDelta ?? 0) < 0 ||\n (delta.presentationTitleCueCasesDelta ?? 0) < 0 ||\n (delta.presentationBodyCueCasesDelta ?? 0) < 0 ||\n (delta.presentationNotesCueCasesDelta ?? 0) < 0 ||\n (delta.spreadsheetSheetCueCasesDelta ?? 0) < 0 ||\n (delta.spreadsheetTableCueCasesDelta ?? 0) < 0 ||\n (delta.spreadsheetColumnCueCasesDelta ?? 0) < 0;\n return {\n baselineGroupKey: groupKey,\n baselineRetrievalId,\n candidateRetrievalId,\n delta,\n status: requiresReview ? \"needs_review\" : \"pass\",\n summary: requiresReview\n ? \"Candidate should be reviewed before promotion.\"\n : \"Candidate improved or matched the baseline.\",\n };\n }\n\n return {\n baselineGroupKey: groupKey,\n baselineRetrievalId,\n candidateRetrievalId,\n status: \"needs_review\",\n summary: \"No explicit baseline verdict could be determined.\",\n };\n};\n\nconst isObjectRecord = (value: unknown): value is Record<string, unknown> =>\n Boolean(value) && typeof value === \"object\";\n\nconst parseJSONRecord = (value: string | null) => {\n if (value === null) {\n return undefined;\n }\n\n try {\n const parsed = JSON.parse(value);\n\n return isObjectRecord(parsed) ? parsed : undefined;\n } catch {\n return undefined;\n }\n};\n\nconst parseJSONArray = <T>(value: string | null, fallback: T[]): T[] => {\n if (value === null) {\n return fallback;\n }\n\n try {\n const parsed = JSON.parse(value);\n\n return Array.isArray(parsed) ? (parsed as T[]) : fallback;\n } catch {\n return fallback;\n }\n};\n\nconst normalizeExpectedIds = (input: string[]) =>\n Array.from(new Set(input.map((item) => item.trim()).filter(Boolean)));\n\nconst hasSourceExtension = (\n value: string | undefined,\n extensions: string[],\n) => {\n if (!value) {\n return false;\n }\n const normalized = value.trim().toLowerCase();\n\n return extensions.some((extension) => normalized.endsWith(extension));\n};\n\nconst hasMetadataNumber = (\n metadata: Record<string, unknown> | undefined,\n key: string,\n) => typeof metadata?.[key] === \"number\";\n\nconst hasMetadataString = (\n metadata: Record<string, unknown> | undefined,\n key: string,\n) => typeof metadata?.[key] === \"string\" && metadata[key] !== \"\";\n\nconst hasMetadataArray = (\n metadata: Record<string, unknown> | undefined,\n key: string,\n) => Array.isArray(metadata?.[key]) && metadata[key].length > 0;\n\nconst detectSectionEvidence = (\n ids: string[],\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n sources.some(\n (source) =>\n hasMetadataArray(source.metadata, \"sectionPath\") ||\n hasMetadataString(source.metadata, \"sectionTitle\") ||\n hasMetadataString(source.metadata, \"sectionKind\"),\n );\n\nconst detectSectionGraphEvidence = (\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n sources.some(\n (source) =>\n hasMetadataString(source.metadata, \"sectionChunkId\") ||\n hasMetadataNumber(source.metadata, \"sectionChunkIndex\") ||\n (hasMetadataNumber(source.metadata, \"sectionChunkCount\") &&\n Number(source.metadata?.sectionChunkCount) > 1),\n );\n\nconst detectSectionHierarchyEvidence = (\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n sources.some((source) => {\n const path = Array.isArray(source.metadata?.sectionPath)\n ? source.metadata.sectionPath.filter(\n (entry): entry is string =>\n typeof entry === \"string\" && entry.trim().length > 0,\n )\n : [];\n\n return path.length > 1;\n });\n\nconst detectSpreadsheetEvidence = (\n ids: string[],\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n ids.some((id) =>\n hasSourceExtension(id, [\".xlsx\", \".xls\", \".csv\", \".ods\", \".tsv\"]),\n ) ||\n sources.some(\n (source) =>\n hasSourceExtension(source.source, [\n \".xlsx\",\n \".xls\",\n \".csv\",\n \".ods\",\n \".tsv\",\n ]) ||\n hasMetadataString(source.metadata, \"sheetName\") ||\n hasMetadataNumber(source.metadata, \"spreadsheetRowStart\") ||\n hasMetadataNumber(source.metadata, \"spreadsheetTableIndex\"),\n );\n\nconst detectMediaEvidence = (\n ids: string[],\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n ids.some((id) =>\n hasSourceExtension(id, [\n \".mp3\",\n \".wav\",\n \".m4a\",\n \".aac\",\n \".ogg\",\n \".flac\",\n \".mp4\",\n \".mov\",\n \".mkv\",\n \".webm\",\n ]),\n ) ||\n sources.some(\n (source) =>\n hasSourceExtension(source.source, [\n \".mp3\",\n \".wav\",\n \".m4a\",\n \".aac\",\n \".ogg\",\n \".flac\",\n \".mp4\",\n \".mov\",\n \".mkv\",\n \".webm\",\n ]) ||\n hasMetadataString(source.metadata, \"mediaKind\") ||\n hasMetadataString(source.metadata, \"speaker\") ||\n hasMetadataNumber(source.metadata, \"startMs\"),\n );\n\nconst detectOCREvidence = (\n ids: string[],\n sources: Array<Pick<RAGSource, \"source\" | \"metadata\">> = [],\n) =>\n ids.some((id) =>\n hasSourceExtension(id, [\".png\", \".jpg\", \".jpeg\", \".webp\"]),\n ) ||\n sources.some(\n (source) =>\n hasSourceExtension(source.source, [\".png\", \".jpg\", \".jpeg\", \".webp\"]) ||\n hasMetadataNumber(source.metadata, \"ocrConfidence\") ||\n hasMetadataNumber(source.metadata, \"ocrRegionConfidence\") ||\n hasMetadataString(source.metadata, \"ocrEngine\") ||\n source.metadata?.pdfTextMode === \"ocr\",\n );\n\nconst getRetrievalTrace = (\n trace: RAGSearchTraceRecord | RAGRetrievalTrace | undefined,\n) => (trace && \"trace\" in trace ? trace.trace : trace);\n\nconst classifyRAGEvaluationFailure = (input: {\n expectedCount: number;\n matchedCount: number;\n missingIds: string[];\n retrievedCount: number;\n retrievedIds: string[];\n retrievedSources?: RAGSource[];\n trace?: RAGSearchTraceRecord | RAGRetrievalTrace;\n}): NonNullable<RAGEvaluationCaseResult[\"failureClasses\"]> => {\n const classes: NonNullable<RAGEvaluationCaseResult[\"failureClasses\"]> = [];\n if (input.expectedCount === 0) {\n classes.push(\"no_expected_targets\");\n }\n if (input.retrievedCount === 0) {\n classes.push(\"no_results\");\n }\n if (input.expectedCount > 0 && input.matchedCount === 0) {\n classes.push(\"no_match\");\n }\n if (\n input.expectedCount > 0 &&\n input.matchedCount > 0 &&\n input.matchedCount < input.expectedCount\n ) {\n classes.push(\"partial_recall\");\n }\n if (input.retrievedIds.length > input.matchedCount) {\n classes.push(\"extra_noise\");\n }\n const sourceSignals = input.retrievedSources ?? [];\n const relevantIds = [...input.missingIds, ...input.retrievedIds];\n if (\n (input.missingIds.length > 0 || input.matchedCount === 0) &&\n detectSectionEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"section_evidence_miss\");\n if (detectSectionGraphEvidence(sourceSignals)) {\n classes.push(\"section_graph_miss\");\n }\n if (detectSectionHierarchyEvidence(sourceSignals)) {\n classes.push(\"section_hierarchy_miss\");\n }\n }\n if (\n (input.missingIds.length > 0 || input.matchedCount === 0) &&\n detectSpreadsheetEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"spreadsheet_evidence_miss\");\n }\n if (\n (input.missingIds.length > 0 || input.matchedCount === 0) &&\n detectMediaEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"media_evidence_miss\");\n }\n if (\n (input.missingIds.length > 0 || input.matchedCount === 0) &&\n detectOCREvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"ocr_evidence_miss\");\n }\n const retrievalTrace = getRetrievalTrace(input.trace);\n if (\n (input.retrievedCount === 0 || input.matchedCount === 0) &&\n (retrievalTrace?.routingLabel || retrievalTrace?.routingReason)\n ) {\n classes.push(\"routing_miss\");\n }\n\n return classes;\n};\n\nconst classifyRAGGroundingFailure = (input: {\n expectedCount: number;\n matchedCount: number;\n missingIds: string[];\n extraIds: string[];\n citationCount: number;\n unresolvedCitationCount: number;\n availableSources?: RAGSource[];\n}): NonNullable<RAGAnswerGroundingEvaluationCaseResult[\"failureClasses\"]> => {\n const classes: NonNullable<\n RAGAnswerGroundingEvaluationCaseResult[\"failureClasses\"]\n > = [];\n if (input.expectedCount === 0) {\n classes.push(\"no_expected_targets\");\n }\n if (input.citationCount === 0) {\n classes.push(\"no_citations\");\n }\n if (input.unresolvedCitationCount > 0) {\n classes.push(\"unresolved_citations\");\n }\n if (input.missingIds.length > 0 || input.matchedCount < input.expectedCount) {\n classes.push(\"missing_expected_sources\");\n }\n if (input.extraIds.length > 0) {\n classes.push(\"extra_citations\");\n }\n const sourceSignals = input.availableSources ?? [];\n const relevantIds = [...input.missingIds, ...input.extraIds];\n if (\n (input.missingIds.length > 0 || input.citationCount === 0) &&\n detectSectionEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"section_source_miss\");\n if (detectSectionGraphEvidence(sourceSignals)) {\n classes.push(\"section_graph_source_miss\");\n }\n if (detectSectionHierarchyEvidence(sourceSignals)) {\n classes.push(\"section_hierarchy_source_miss\");\n }\n }\n if (\n (input.missingIds.length > 0 || input.citationCount === 0) &&\n detectSpreadsheetEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"spreadsheet_source_miss\");\n }\n if (\n (input.missingIds.length > 0 || input.citationCount === 0) &&\n detectMediaEvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"media_source_miss\");\n }\n if (\n (input.missingIds.length > 0 || input.citationCount === 0) &&\n detectOCREvidence(relevantIds, sourceSignals)\n ) {\n classes.push(\"ocr_source_miss\");\n }\n\n return classes;\n};\n\nconst normalizeSyntheticText = (value: string) =>\n value\n .replace(/^#+\\s*/gm, \"\")\n .replace(/`+/g, \"\")\n .replace(/\\[(.*?)\\]\\((.*?)\\)/g, \"$1\")\n .replace(/\\s+/g, \" \")\n .trim();\n\nconst buildSyntheticEvaluationQuery = (document: RAGIndexedDocument) => {\n const title = normalizeSyntheticText(document.title);\n const sourceTail = normalizeSyntheticText(\n document.source.split(\"/\").at(-1) ?? document.source,\n );\n const text = normalizeSyntheticText(document.text ?? \"\");\n const firstSentence =\n text\n .split(/(?<=[.!?])\\s+/)\n .map((entry) => entry.trim())\n .find((entry) => entry.length >= 24) ??\n text\n .split(/\\n+/)\n .map((entry) => entry.trim())\n .find((entry) => entry.length >= 24) ??\n title ??\n sourceTail;\n const prefixedSentence =\n title.length > 0 &&\n firstSentence.toLowerCase().startsWith(title.toLowerCase())\n ? firstSentence\n : [title, firstSentence].filter(Boolean).join(\" \");\n const queryTerms = normalizeSyntheticText(prefixedSentence)\n .split(/\\s+/)\n .slice(0, 12)\n .join(\" \");\n\n return queryTerms.length > 0 ? queryTerms : sourceTail;\n};\n\nconst resolveEvaluationMode = (caseInput: {\n expectedChunkIds?: string[];\n expectedSources?: string[];\n expectedDocumentIds?: string[];\n}): \"chunkId\" | \"source\" | \"documentId\" => {\n if (normalizeStringArray(caseInput.expectedChunkIds).length > 0) {\n return \"chunkId\";\n }\n if (normalizeStringArray(caseInput.expectedSources).length > 0) {\n return \"source\";\n }\n\n return \"documentId\";\n};\n\nconst getDocumentId = (source: RAGSource): string => {\n const metadataDocumentId =\n typeof source.metadata?.documentId === \"string\"\n ? source.metadata.documentId\n : undefined;\n if (metadataDocumentId) {\n return metadataDocumentId;\n }\n if (source.source) {\n return source.source;\n }\n\n const [documentId] = source.chunkId.split(\":\");\n\n return documentId ?? source.chunkId;\n};\n\nconst extractExpectedId = (\n source: RAGSource,\n mode: \"chunkId\" | \"source\" | \"documentId\",\n): string =>\n mode === \"chunkId\"\n ? source.chunkId\n : mode === \"source\"\n ? (source.source ?? source.title ?? source.chunkId)\n : getDocumentId(source);\n\nconst buildSources = (\n results: Array<{\n chunkId: string;\n chunkText: string;\n score: number;\n title?: string;\n source?: string;\n metadata?: Record<string, unknown>;\n }>,\n) =>\n results.map((result) => ({\n chunkId: result.chunkId,\n metadata: result.metadata,\n score: Number.isFinite(result.score) ? result.score : 0,\n source: result.source,\n text: result.chunkText,\n title: result.title,\n }));\n\nconst buildAnswerGroundingStatus = ({\n coverage,\n expectedCount,\n matchedCount,\n unresolvedCitationCount,\n resolvedCitationCount,\n}: {\n coverage: RAGAnswerGroundingEvaluationCaseResult[\"coverage\"];\n expectedCount: number;\n matchedCount: number;\n unresolvedCitationCount: number;\n resolvedCitationCount: number;\n}): RAGAnswerGroundingEvaluationCaseResult[\"status\"] => {\n if (expectedCount > 0) {\n if (\n matchedCount === expectedCount &&\n unresolvedCitationCount === 0 &&\n coverage !== \"ungrounded\"\n ) {\n return \"pass\";\n }\n\n if (matchedCount > 0 || resolvedCitationCount > 0) {\n return \"partial\";\n }\n\n return \"fail\";\n }\n\n if (coverage === \"grounded\" && unresolvedCitationCount === 0) {\n return \"pass\";\n }\n\n if (resolvedCitationCount > 0 || coverage === \"partial\") {\n return \"partial\";\n }\n\n return \"fail\";\n};\n\nexport const buildRAGEvaluationLeaderboard = (\n runs: RAGEvaluationSuiteRun[],\n) => {\n const sorted = [...runs].sort((left, right) => {\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n\n return sorted.map<RAGEvaluationLeaderboardEntry>((run, index) => ({\n averageF1: run.response.summary.averageF1,\n averageLatencyMs: run.response.summary.averageLatencyMs,\n label: run.label,\n passingRate: run.response.passingRate,\n rank: index + 1,\n runId: run.id,\n suiteId: run.suiteId,\n totalCases: run.response.totalCases,\n }));\n};\n\nexport const buildRAGAnswerGroundingEvaluationLeaderboard = (\n runs: RAGAnswerGroundingEvaluationRun[],\n) => {\n const sorted = [...runs].sort((left, right) => {\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (\n right.response.summary.averageCitationF1 !==\n left.response.summary.averageCitationF1\n ) {\n return (\n right.response.summary.averageCitationF1 -\n left.response.summary.averageCitationF1\n );\n }\n if (\n right.response.summary.averageResolvedCitationRate !==\n left.response.summary.averageResolvedCitationRate\n ) {\n return (\n right.response.summary.averageResolvedCitationRate -\n left.response.summary.averageResolvedCitationRate\n );\n }\n\n return left.elapsedMs - right.elapsedMs;\n });\n\n return sorted.map<RAGAnswerGroundingEvaluationLeaderboardEntry>(\n (run, index) => ({\n averageCitationF1: run.response.summary.averageCitationF1,\n averageResolvedCitationRate:\n run.response.summary.averageResolvedCitationRate,\n label: run.label,\n passingRate: run.response.passingRate,\n rank: index + 1,\n runId: run.id,\n suiteId: run.suiteId,\n totalCases: run.response.totalCases,\n }),\n );\n};\n\nconst buildTraceStageCounts = (traces: RAGRetrievalTrace[]) => {\n const counts: Partial<\n Record<RAGRetrievalTrace[\"steps\"][number][\"stage\"], number>\n > = {};\n\n for (const trace of traces) {\n for (const step of trace.steps) {\n counts[step.stage] = (counts[step.stage] ?? 0) + 1;\n }\n }\n\n return counts;\n};\n\nconst diffTraceStageCounts = ({\n current,\n previous,\n}: {\n current: Partial<Record<RAGRetrievalTrace[\"steps\"][number][\"stage\"], number>>;\n previous: Partial<\n Record<RAGRetrievalTrace[\"steps\"][number][\"stage\"], number>\n >;\n}) => {\n const next: Partial<\n Record<RAGRetrievalTrace[\"steps\"][number][\"stage\"], number>\n > = {};\n const stages = new Set([\n ...Object.keys(current),\n ...Object.keys(previous),\n ] as RAGRetrievalTrace[\"steps\"][number][\"stage\"][]);\n\n for (const stage of stages) {\n const delta = (current[stage] ?? 0) - (previous[stage] ?? 0);\n if (delta !== 0) {\n next[stage] = delta;\n }\n }\n\n return next;\n};\n\nconst normalizeSummaryList = <T extends string>(values: T[]) =>\n Array.from(new Set(values)).sort();\n\nconst buildSummaryListDelta = <T extends string>(\n current: T[],\n previous: T[],\n) => {\n const currentSet = new Set(current);\n const previousSet = new Set(previous);\n const added = current.filter((value) => !previousSet.has(value));\n const removed = previous.filter((value) => !currentSet.has(value));\n\n return {\n added: normalizeSummaryList(Array.from(new Set(added))),\n current: normalizeSummaryList(current),\n previous: normalizeSummaryList(previous),\n removed: normalizeSummaryList(Array.from(new Set(removed))),\n };\n};\n\nfunction summarizeListTurnover<T extends string>(params: {\n current: T[];\n previous: T[];\n history: T[][];\n}): RAGTraceSummaryListTrend<T> {\n const { current, previous, history } = params;\n const currentSet = new Set(current);\n const previousSet = new Set(previous);\n const frequency: Record<string, number> = {};\n\n for (const entry of history) {\n for (const value of entry) {\n frequency[value] = (frequency[value] ?? 0) + 1;\n }\n }\n\n return {\n appeared: normalizeSummaryList(\n Array.from(new Set(current.filter((value) => !previousSet.has(value)))),\n ),\n current: normalizeSummaryList(current),\n disappeared: normalizeSummaryList(\n Array.from(new Set(previous.filter((value) => !currentSet.has(value)))),\n ),\n frequency,\n previous: normalizeSummaryList(previous),\n stable: normalizeSummaryList(\n Array.from(new Set(current.filter((value) => previousSet.has(value)))),\n ),\n };\n}\n\nconst diffTraceSummaryStageCounts = ({\n current,\n previous,\n}: {\n current: RAGRetrievalTraceComparisonSummary[\"stageCounts\"];\n previous: RAGRetrievalTraceComparisonSummary[\"stageCounts\"];\n}) => {\n const stages = new Set([\n ...Object.keys(current),\n ...Object.keys(previous),\n ]) as Set<RAGRetrievalTraceStep[\"stage\"]>;\n const next: Partial<\n Record<RAGRetrievalTraceStage, RAGTraceSummaryStageCountsDelta>\n > = {};\n\n for (const stage of stages) {\n const currentCount = current[stage] ?? 0;\n const previousCount = previous[stage] ?? 0;\n const delta = currentCount - previousCount;\n if (delta !== 0 || currentCount !== 0 || previousCount !== 0) {\n next[stage] = {\n current: currentCount,\n delta,\n previous: previousCount,\n };\n }\n }\n\n return next;\n};\n\nconst roundTraceAverage = (value: number, total: number) =>\n total > 0 ? Number((value / total).toFixed(2)) : 0;\n\nconst buildTraceSummaryDirection = (\n delta: number,\n): RAGTraceSummaryTrendDirection =>\n delta > 0 ? \"up\" : delta < 0 ? \"down\" : \"flat\";\n\nconst buildTraceSummaryAggregate = ({\n summaries,\n}: {\n summaries: RAGRetrievalTraceComparisonSummary[];\n}): {\n aggregate: RAGTraceSummaryNumericDelta[];\n bestMetric: RAGTraceSummaryNumericDelta | undefined;\n worstMetric: RAGTraceSummaryNumericDelta | undefined;\n} => {\n if (summaries.length === 0) {\n const aggregate: RAGTraceSummaryNumericDelta[] = [\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"totalCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"averageFinalCount\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"averageVectorCount\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"averageLexicalCount\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"averageCandidateTopK\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"averageLexicalTopK\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"vectorCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"lexicalCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"balancedCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"roundRobinCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"transformedCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"variantCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"multiVectorCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"multiVectorVectorHitCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"multiVectorLexicalHitCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"multiVectorCollapsedCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"runtimeCandidateBudgetExhaustedCases\",\n previous: 0,\n },\n {\n current: 0,\n delta: 0,\n direction: \"flat\",\n metric: \"runtimeUnderfilledTopKCases\",\n previous: 0,\n },\n ];\n\n return {\n aggregate,\n bestMetric: undefined,\n worstMetric: undefined,\n };\n }\n\n const latest = summaries[0]!;\n const previous = summaries[summaries.length - 1]!;\n const aggregate: RAGTraceSummaryNumericDelta[] = [\n {\n current: latest.totalCases,\n delta: latest.totalCases - previous.totalCases,\n direction: buildTraceSummaryDirection(\n latest.totalCases - previous.totalCases,\n ),\n metric: \"totalCases\",\n previous: previous.totalCases,\n },\n {\n current: latest.averageFinalCount,\n delta: latest.averageFinalCount - previous.averageFinalCount,\n direction: buildTraceSummaryDirection(\n latest.averageFinalCount - previous.averageFinalCount,\n ),\n metric: \"averageFinalCount\",\n previous: previous.averageFinalCount,\n },\n {\n current: latest.averageVectorCount,\n delta: latest.averageVectorCount - previous.averageVectorCount,\n direction: buildTraceSummaryDirection(\n latest.averageVectorCount - previous.averageVectorCount,\n ),\n metric: \"averageVectorCount\",\n previous: previous.averageVectorCount,\n },\n {\n current: latest.averageLexicalCount,\n delta: latest.averageLexicalCount - previous.averageLexicalCount,\n direction: buildTraceSummaryDirection(\n latest.averageLexicalCount - previous.averageLexicalCount,\n ),\n metric: \"averageLexicalCount\",\n previous: previous.averageLexicalCount,\n },\n {\n current: latest.averageCandidateTopK,\n delta: latest.averageCandidateTopK - previous.averageCandidateTopK,\n direction: buildTraceSummaryDirection(\n latest.averageCandidateTopK - previous.averageCandidateTopK,\n ),\n metric: \"averageCandidateTopK\",\n previous: previous.averageCandidateTopK,\n },\n {\n current: latest.averageLexicalTopK,\n delta: latest.averageLexicalTopK - previous.averageLexicalTopK,\n direction: buildTraceSummaryDirection(\n latest.averageLexicalTopK - previous.averageLexicalTopK,\n ),\n metric: \"averageLexicalTopK\",\n previous: previous.averageLexicalTopK,\n },\n {\n current: latest.vectorCases,\n delta: latest.vectorCases - previous.vectorCases,\n direction: buildTraceSummaryDirection(\n latest.vectorCases - previous.vectorCases,\n ),\n metric: \"vectorCases\",\n previous: previous.vectorCases,\n },\n {\n current: latest.lexicalCases,\n delta: latest.lexicalCases - previous.lexicalCases,\n direction: buildTraceSummaryDirection(\n latest.lexicalCases - previous.lexicalCases,\n ),\n metric: \"lexicalCases\",\n previous: previous.lexicalCases,\n },\n {\n current: latest.balancedCases,\n delta: latest.balancedCases - previous.balancedCases,\n direction: buildTraceSummaryDirection(\n latest.balancedCases - previous.balancedCases,\n ),\n metric: \"balancedCases\",\n previous: previous.balancedCases,\n },\n {\n current: latest.roundRobinCases,\n delta: latest.roundRobinCases - previous.roundRobinCases,\n direction: buildTraceSummaryDirection(\n latest.roundRobinCases - previous.roundRobinCases,\n ),\n metric: \"roundRobinCases\",\n previous: previous.roundRobinCases,\n },\n {\n current: latest.transformedCases,\n delta: latest.transformedCases - previous.transformedCases,\n direction: buildTraceSummaryDirection(\n latest.transformedCases - previous.transformedCases,\n ),\n metric: \"transformedCases\",\n previous: previous.transformedCases,\n },\n {\n current: latest.variantCases,\n delta: latest.variantCases - previous.variantCases,\n direction: buildTraceSummaryDirection(\n latest.variantCases - previous.variantCases,\n ),\n metric: \"variantCases\",\n previous: previous.variantCases,\n },\n {\n current: latest.multiVectorCases,\n delta: latest.multiVectorCases - previous.multiVectorCases,\n direction: buildTraceSummaryDirection(\n latest.multiVectorCases - previous.multiVectorCases,\n ),\n metric: \"multiVectorCases\",\n previous: previous.multiVectorCases,\n },\n {\n current: latest.multiVectorVectorHitCases,\n delta:\n latest.multiVectorVectorHitCases - previous.multiVectorVectorHitCases,\n direction: buildTraceSummaryDirection(\n latest.multiVectorVectorHitCases - previous.multiVectorVectorHitCases,\n ),\n metric: \"multiVectorVectorHitCases\",\n previous: previous.multiVectorVectorHitCases,\n },\n {\n current: latest.multiVectorLexicalHitCases,\n delta:\n latest.multiVectorLexicalHitCases - previous.multiVectorLexicalHitCases,\n direction: buildTraceSummaryDirection(\n latest.multiVectorLexicalHitCases - previous.multiVectorLexicalHitCases,\n ),\n metric: \"multiVectorLexicalHitCases\",\n previous: previous.multiVectorLexicalHitCases,\n },\n {\n current: latest.multiVectorCollapsedCases,\n delta:\n latest.multiVectorCollapsedCases - previous.multiVectorCollapsedCases,\n direction: buildTraceSummaryDirection(\n latest.multiVectorCollapsedCases - previous.multiVectorCollapsedCases,\n ),\n metric: \"multiVectorCollapsedCases\",\n previous: previous.multiVectorCollapsedCases,\n },\n {\n current: latest.runtimeCandidateBudgetExhaustedCases,\n delta:\n latest.runtimeCandidateBudgetExhaustedCases -\n previous.runtimeCandidateBudgetExhaustedCases,\n direction: buildTraceSummaryDirection(\n latest.runtimeCandidateBudgetExhaustedCases -\n previous.runtimeCandidateBudgetExhaustedCases,\n ),\n metric: \"runtimeCandidateBudgetExhaustedCases\",\n previous: previous.runtimeCandidateBudgetExhaustedCases,\n },\n {\n current: latest.runtimeUnderfilledTopKCases,\n delta:\n latest.runtimeUnderfilledTopKCases -\n previous.runtimeUnderfilledTopKCases,\n direction: buildTraceSummaryDirection(\n latest.runtimeUnderfilledTopKCases -\n previous.runtimeUnderfilledTopKCases,\n ),\n metric: \"runtimeUnderfilledTopKCases\",\n previous: previous.runtimeUnderfilledTopKCases,\n },\n ];\n const absoluteSorted = [...aggregate].sort(\n (left, right) =>\n Math.abs(right.delta) - Math.abs(left.delta) ||\n left.metric.localeCompare(right.metric),\n );\n\n return {\n aggregate,\n bestMetric: absoluteSorted[0],\n worstMetric: absoluteSorted[absoluteSorted.length - 1],\n };\n};\n\nconst buildRAGRetrievalTraceStageChurn = ({\n windows,\n}: {\n windows: RAGRetrievalTraceHistoryWindow[];\n}): RAGTraceSummaryStageTrend[] => {\n const stages = new Set<RAGRetrievalTraceStep[\"stage\"]>();\n for (const window of windows) {\n for (const stage of Object.keys(window.current.stageCounts) as Array<\n RAGRetrievalTraceStep[\"stage\"]\n >) {\n stages.add(stage);\n }\n for (const stage of Object.keys(window.previous.stageCounts) as Array<\n RAGRetrievalTraceStep[\"stage\"]\n >) {\n stages.add(stage);\n }\n }\n\n return [...stages]\n .map((stage) => {\n let netDelta = 0;\n let totalChanges = 0;\n for (const window of windows) {\n const delta = window.delta?.stageCountsDelta[stage]?.delta ?? 0;\n netDelta += delta;\n totalChanges += Math.abs(delta);\n }\n return {\n latestDelta: windows[0]?.delta?.stageCountsDelta[stage]?.delta ?? 0,\n netDelta,\n stage,\n totalChanges,\n };\n })\n .sort(\n (left, right) =>\n right.totalChanges - left.totalChanges ||\n left.stage.localeCompare(right.stage),\n );\n};\n\nconst summarizeRetrievalTraces = (\n traces: RAGRetrievalTrace[],\n): RAGRetrievalTraceComparisonSummary | undefined => {\n if (traces.length === 0) {\n return undefined;\n }\n\n const totalCases = traces.length;\n const modeSet = new Set<RAGHybridRetrievalMode>();\n const sourceBalanceStrategySet = new Set<RAGSourceBalanceStrategy>();\n let vectorCases = 0;\n let lexicalCases = 0;\n let balancedCases = 0;\n let roundRobinCases = 0;\n let transformedCases = 0;\n let variantCases = 0;\n let multiVectorCases = 0;\n let multiVectorVectorHitCases = 0;\n let multiVectorLexicalHitCases = 0;\n let multiVectorCollapsedCases = 0;\n let officeEvidenceReconcileCases = 0;\n let officeParagraphEvidenceReconcileCases = 0;\n let officeListEvidenceReconcileCases = 0;\n let officeTableEvidenceReconcileCases = 0;\n let pdfEvidenceReconcileCases = 0;\n let runtimeCandidateBudgetExhaustedCases = 0;\n let runtimeUnderfilledTopKCases = 0;\n let finalCountSum = 0;\n let vectorCountSum = 0;\n let lexicalCountSum = 0;\n let candidateTopKSum = 0;\n let lexicalTopKSum = 0;\n\n for (const trace of traces) {\n const vectorSearchMetadata = trace.steps.find(\n (step) => step.stage === \"vector_search\",\n )?.metadata;\n modeSet.add(trace.mode);\n sourceBalanceStrategySet.add(trace.sourceBalanceStrategy ?? \"cap\");\n if (trace.runVector) {\n vectorCases += 1;\n }\n if (trace.runLexical) {\n lexicalCases += 1;\n }\n if (typeof trace.maxResultsPerSource === \"number\") {\n balancedCases += 1;\n if (trace.sourceBalanceStrategy === \"round_robin\") {\n roundRobinCases += 1;\n }\n }\n if (trace.transformedQuery !== trace.query) {\n transformedCases += 1;\n }\n if (trace.variantQueries.length > 0) {\n variantCases += 1;\n }\n if (trace.multiVector?.configured) {\n multiVectorCases += 1;\n }\n if ((trace.multiVector?.vectorVariantHits ?? 0) > 0) {\n multiVectorVectorHitCases += 1;\n }\n if ((trace.multiVector?.lexicalVariantHits ?? 0) > 0) {\n multiVectorLexicalHitCases += 1;\n }\n if ((trace.multiVector?.collapsedParents ?? 0) > 0) {\n multiVectorCollapsedCases += 1;\n }\n const evidenceReconcileMetadata = trace.steps.find(\n (step) => step.stage === \"evidence_reconcile\",\n )?.metadata;\n if (\n typeof evidenceReconcileMetadata?.officeAffectedScopes === \"number\" &&\n evidenceReconcileMetadata.officeAffectedScopes > 0\n ) {\n officeEvidenceReconcileCases += 1;\n }\n if (\n typeof evidenceReconcileMetadata?.officeParagraphAffectedScopes ===\n \"number\" &&\n evidenceReconcileMetadata.officeParagraphAffectedScopes > 0\n ) {\n officeParagraphEvidenceReconcileCases += 1;\n }\n if (\n typeof evidenceReconcileMetadata?.officeListAffectedScopes === \"number\" &&\n evidenceReconcileMetadata.officeListAffectedScopes > 0\n ) {\n officeListEvidenceReconcileCases += 1;\n }\n if (\n typeof evidenceReconcileMetadata?.officeTableAffectedScopes ===\n \"number\" &&\n evidenceReconcileMetadata.officeTableAffectedScopes > 0\n ) {\n officeTableEvidenceReconcileCases += 1;\n }\n if (\n typeof evidenceReconcileMetadata?.pdfAffectedScopes === \"number\" &&\n evidenceReconcileMetadata.pdfAffectedScopes > 0\n ) {\n pdfEvidenceReconcileCases += 1;\n }\n if (vectorSearchMetadata?.sqliteQueryCandidateBudgetExhausted) {\n runtimeCandidateBudgetExhaustedCases += 1;\n }\n if (vectorSearchMetadata?.postgresQueryCandidateBudgetExhausted) {\n runtimeCandidateBudgetExhaustedCases += 1;\n }\n if (vectorSearchMetadata?.sqliteQueryUnderfilledTopK) {\n runtimeUnderfilledTopKCases += 1;\n }\n if (vectorSearchMetadata?.postgresQueryUnderfilledTopK) {\n runtimeUnderfilledTopKCases += 1;\n }\n finalCountSum += trace.resultCounts.final;\n vectorCountSum += trace.resultCounts.vector;\n lexicalCountSum += trace.resultCounts.lexical;\n candidateTopKSum += trace.candidateTopK;\n lexicalTopKSum += trace.lexicalTopK;\n }\n\n return {\n averageCandidateTopK: roundTraceAverage(candidateTopKSum, totalCases),\n averageFinalCount: roundTraceAverage(finalCountSum, totalCases),\n averageLexicalCount: roundTraceAverage(lexicalCountSum, totalCases),\n averageLexicalTopK: roundTraceAverage(lexicalTopKSum, totalCases),\n balancedCases,\n averageVectorCount: roundTraceAverage(vectorCountSum, totalCases),\n lexicalCases,\n modes: Array.from(modeSet),\n roundRobinCases,\n sourceBalanceStrategies: Array.from(sourceBalanceStrategySet),\n stageCounts: buildTraceStageCounts(traces),\n totalCases,\n transformedCases,\n variantCases,\n multiVectorCases,\n multiVectorVectorHitCases,\n multiVectorLexicalHitCases,\n multiVectorCollapsedCases,\n officeEvidenceReconcileCases,\n officeParagraphEvidenceReconcileCases,\n officeListEvidenceReconcileCases,\n officeTableEvidenceReconcileCases,\n pdfEvidenceReconcileCases,\n runtimeCandidateBudgetExhaustedCases,\n runtimeUnderfilledTopKCases,\n vectorCases,\n };\n};\n\nconst evaluateRAGCollectionCases = async ({\n collection,\n input,\n defaultTopK = DEFAULT_TOP_K,\n rerank,\n includeTrace = false,\n}: {\n collection: RAGCollection;\n input: RAGEvaluationInput;\n defaultTopK?: number;\n rerank?: RAGRerankerProviderLike;\n includeTrace?: boolean;\n}): Promise<\n Array<{\n caseResult: RAGEvaluationCaseResult;\n trace?: RAGRetrievalTrace;\n filter?: Record<string, unknown>;\n retrieval?: RAGCollectionSearchParams[\"retrieval\"];\n topResult?: RAGQueryResult;\n }>\n> => {\n if (input.dryRun) {\n return executeDryRunRAGEvaluation(input, defaultTopK).map(\n (caseResult, caseIndex) => ({\n caseResult,\n filter:\n typeof input.cases?.[caseIndex]?.filter === \"object\"\n ? input.cases[caseIndex]?.filter\n : input.filter,\n retrieval: input.cases?.[caseIndex]?.retrieval ?? input.retrieval,\n topResult: undefined,\n trace: undefined,\n }),\n );\n }\n\n return Promise.all(\n input.cases.map(async (caseInput, caseIndex) => {\n const startedAt = Date.now();\n const mode = resolveEvaluationMode(caseInput);\n const query = caseInput.query.trim();\n const expectedIds = normalizeExpectedIds(\n mode === \"chunkId\"\n ? (caseInput.expectedChunkIds ?? [])\n : mode === \"source\"\n ? (caseInput.expectedSources ?? [])\n : (caseInput.expectedDocumentIds ?? []),\n );\n const topK =\n typeof caseInput.topK === \"number\"\n ? caseInput.topK\n : typeof input.topK === \"number\"\n ? input.topK\n : defaultTopK;\n const searchInput = {\n filter: caseInput.corpusKey\n ? {\n ...((typeof caseInput.filter === \"object\"\n ? caseInput.filter\n : input.filter) ?? {}),\n corpusKey: caseInput.corpusKey,\n }\n : typeof caseInput.filter === \"object\"\n ? caseInput.filter\n : input.filter,\n model: caseInput.model ?? input.model,\n query,\n rerank,\n scoreThreshold:\n typeof caseInput.scoreThreshold === \"number\"\n ? caseInput.scoreThreshold\n : input.scoreThreshold,\n retrieval: caseInput.retrieval ?? input.retrieval,\n topK,\n };\n const searchOutcome = includeTrace\n ? await collection.searchWithTrace(searchInput)\n : {\n results: await collection.search(searchInput),\n trace: undefined,\n };\n const sources = buildSources(searchOutcome.results);\n const elapsedMs = Date.now() - startedAt;\n const retrievedIds = normalizeExpectedIds(\n sources.map((source) => extractExpectedId(source, mode)),\n );\n\n return {\n caseResult: summarizeRAGEvaluationCase({\n caseIndex,\n caseInput: { ...caseInput, topK },\n elapsedMs,\n expectedIds,\n mode,\n query,\n retrievedIds,\n retrievedSources: sources,\n trace: searchOutcome.trace,\n }),\n trace: searchOutcome.trace,\n filter: searchInput.filter,\n retrieval: searchInput.retrieval,\n topResult: searchOutcome.results[0],\n };\n }),\n );\n};\n\nexport const buildRAGAnswerGroundingCaseDifficultyLeaderboard = (\n entries: Array<{\n label: string;\n response: RAGAnswerGroundingEvaluationResponse;\n }>,\n) => {\n const grouped = new Map<\n string,\n {\n caseId: string;\n label?: string;\n query?: string;\n passCount: number;\n partialCount: number;\n failCount: number;\n groundedCount: number;\n totalEvaluations: number;\n totalCitationF1: number;\n totalResolvedCitationRate: number;\n }\n >();\n\n for (const entry of entries) {\n for (const result of entry.response.cases) {\n const current = grouped.get(result.caseId) ?? {\n caseId: result.caseId,\n failCount: 0,\n groundedCount: 0,\n label: result.label,\n passCount: 0,\n partialCount: 0,\n query: result.query,\n totalCitationF1: 0,\n totalEvaluations: 0,\n totalResolvedCitationRate: 0,\n };\n current.label ??= result.label;\n current.query ??= result.query;\n current.totalEvaluations += 1;\n current.totalCitationF1 += result.citationF1;\n current.totalResolvedCitationRate += result.resolvedCitationRate;\n if (result.status === \"pass\") {\n current.passCount += 1;\n } else if (result.status === \"partial\") {\n current.partialCount += 1;\n } else {\n current.failCount += 1;\n }\n if (result.coverage === \"grounded\") {\n current.groundedCount += 1;\n }\n grouped.set(result.caseId, current);\n }\n }\n\n const ranked = Array.from(grouped.values()).sort((left, right) => {\n const leftPassRate = left.passCount / left.totalEvaluations;\n const rightPassRate = right.passCount / right.totalEvaluations;\n if (leftPassRate !== rightPassRate) {\n return leftPassRate - rightPassRate;\n }\n const leftCitationF1 = left.totalCitationF1 / left.totalEvaluations;\n const rightCitationF1 = right.totalCitationF1 / right.totalEvaluations;\n if (leftCitationF1 !== rightCitationF1) {\n return leftCitationF1 - rightCitationF1;\n }\n const leftResolved = left.totalResolvedCitationRate / left.totalEvaluations;\n const rightResolved =\n right.totalResolvedCitationRate / right.totalEvaluations;\n if (leftResolved !== rightResolved) {\n return leftResolved - rightResolved;\n }\n\n return left.caseId.localeCompare(right.caseId);\n });\n\n return ranked.map<RAGAnswerGroundingEvaluationCaseDifficultyEntry>(\n (entry, index) => ({\n averageCitationF1: entry.totalCitationF1 / entry.totalEvaluations,\n averageResolvedCitationRate:\n entry.totalResolvedCitationRate / entry.totalEvaluations,\n caseId: entry.caseId,\n failRate: (entry.failCount / entry.totalEvaluations) * 100,\n groundedRate: (entry.groundedCount / entry.totalEvaluations) * 100,\n label: entry.label,\n passRate: (entry.passCount / entry.totalEvaluations) * 100,\n partialRate: (entry.partialCount / entry.totalEvaluations) * 100,\n query: entry.query,\n rank: index + 1,\n totalEvaluations: entry.totalEvaluations,\n }),\n );\n};\n\nconst buildGroundingDifficultyDiffEntry = (\n current: RAGAnswerGroundingEvaluationCaseDifficultyEntry,\n previous?: RAGAnswerGroundingEvaluationCaseDifficultyEntry,\n): RAGAnswerGroundingCaseDifficultyDiffEntry => ({\n caseId: current.caseId,\n currentAverageCitationF1: current.averageCitationF1,\n currentFailRate: current.failRate,\n currentPassRate: current.passRate,\n currentRank: current.rank,\n label: current.label,\n previousAverageCitationF1: previous?.averageCitationF1,\n previousFailRate: previous?.failRate,\n previousPassRate: previous?.passRate,\n previousRank: previous?.rank,\n query: current.query,\n});\n\nconst buildRAGAnswerGroundingCaseDifficultyTrends = ({\n runs,\n}: {\n runs: RAGAnswerGroundingCaseDifficultyRun[];\n}) => {\n const movementCounts = new Map<\n string,\n {\n label?: string;\n harder: number;\n easier: number;\n unchanged: number;\n }\n >();\n\n for (let index = 0; index < runs.length - 1; index += 1) {\n const current = runs[index];\n const previous = runs[index + 1];\n if (!current || !previous) {\n continue;\n }\n const diff = buildRAGAnswerGroundingCaseDifficultyRunDiff({\n current,\n previous,\n });\n\n for (const entry of diff.harderCases) {\n const currentCounts = movementCounts.get(entry.caseId) ?? {\n easier: 0,\n harder: 0,\n label: entry.label,\n unchanged: 0,\n };\n currentCounts.harder += 1;\n currentCounts.label ??= entry.label;\n movementCounts.set(entry.caseId, currentCounts);\n }\n\n for (const entry of diff.easierCases) {\n const currentCounts = movementCounts.get(entry.caseId) ?? {\n easier: 0,\n harder: 0,\n label: entry.label,\n unchanged: 0,\n };\n currentCounts.easier += 1;\n currentCounts.label ??= entry.label;\n movementCounts.set(entry.caseId, currentCounts);\n }\n\n for (const entry of diff.unchangedCases) {\n const currentCounts = movementCounts.get(entry.caseId) ?? {\n easier: 0,\n harder: 0,\n label: entry.label,\n unchanged: 0,\n };\n currentCounts.unchanged += 1;\n currentCounts.label ??= entry.label;\n movementCounts.set(entry.caseId, currentCounts);\n }\n }\n\n const movementEntries = [...movementCounts.entries()];\n const mostOftenHarderCaseIds = movementEntries\n .filter(([, counts]) => counts.harder > 0)\n .sort((left, right) => {\n if (right[1].harder !== left[1].harder) {\n return right[1].harder - left[1].harder;\n }\n return left[0].localeCompare(right[0]);\n })\n .map(([caseId]) => caseId);\n const mostOftenEasierCaseIds = movementEntries\n .filter(([, counts]) => counts.easier > 0)\n .sort((left, right) => {\n if (right[1].easier !== left[1].easier) {\n return right[1].easier - left[1].easier;\n }\n return left[0].localeCompare(right[0]);\n })\n .map(([caseId]) => caseId);\n\n return {\n easiestCaseIds:\n runs[runs.length - 1]?.entries.map((entry) => entry.caseId).reverse() ??\n [],\n hardestCaseIds: runs[0]?.entries.map((entry) => entry.caseId) ?? [],\n mostOftenEasierCaseIds,\n mostOftenHarderCaseIds,\n movementCounts: Object.fromEntries(\n movementEntries.map(([caseId, counts]) => [\n caseId,\n {\n easier: counts.easier,\n harder: counts.harder,\n unchanged: counts.unchanged,\n },\n ]),\n ),\n };\n};\n\nexport const buildRAGAnswerGroundingCaseDifficultyRunDiff = ({\n current,\n previous,\n}: {\n current: RAGAnswerGroundingCaseDifficultyRun;\n previous?: RAGAnswerGroundingCaseDifficultyRun;\n}): RAGAnswerGroundingCaseDifficultyRunDiff => {\n const previousEntries = new Map(\n (previous?.entries ?? []).map((entry) => [entry.caseId, entry]),\n );\n const diffs = current.entries.map((entry) =>\n buildGroundingDifficultyDiffEntry(entry, previousEntries.get(entry.caseId)),\n );\n\n return {\n currentRunId: current.id,\n easierCases: diffs.filter((entry) => {\n const previousRank = entry.previousRank ?? entry.currentRank;\n return entry.currentRank > previousRank;\n }),\n harderCases: diffs.filter((entry) => {\n const previousRank = entry.previousRank ?? Number.MAX_SAFE_INTEGER;\n return entry.currentRank < previousRank;\n }),\n previousRunId: previous?.id,\n suiteId: current.suiteId,\n unchangedCases: diffs.filter((entry) => {\n const previousRank = entry.previousRank ?? entry.currentRank;\n return entry.currentRank === previousRank;\n }),\n };\n};\n\nconst toHistorySortOrder = (\n left: RAGEvaluationSuiteRun,\n right: RAGEvaluationSuiteRun,\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeHistoryRuns = (runs: RAGEvaluationSuiteRun[]) =>\n [...runs].sort(toHistorySortOrder);\n\nconst normalizeRetrievalComparisonRuns = (runs: RAGRetrievalComparisonRun[]) =>\n [...runs].sort((left, right) => right.finishedAt - left.finishedAt);\n\nconst toTraceSummaryRunSortOrder = (\n left: RAGRetrievalTraceSummaryRun,\n right: RAGRetrievalTraceSummaryRun,\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeTraceSummaryRuns = <TRun extends RAGRetrievalTraceSummaryRun>(\n runs: TRun[],\n) => [...runs].sort(toTraceSummaryRunSortOrder);\n\nconst applyRAGEvaluationHistoryPrunePolicy = <\n TRun extends {\n id: string;\n suiteId: string;\n finishedAt?: number;\n createdAt?: number;\n },\n>({\n input,\n runs,\n sort,\n}: {\n input?: RAGEvaluationHistoryPruneInput;\n runs: TRun[];\n sort: (runs: TRun[]) => TRun[];\n}): {\n next: TRun[];\n removed: TRun[];\n keptCount: number;\n removedCount: number;\n} => {\n const sorted = sort(runs);\n const targeted = sorted.filter(\n (run) => !input?.suiteId || run.suiteId === input.suiteId,\n );\n const untouched = sorted.filter(\n (run) => input?.suiteId && run.suiteId !== input.suiteId,\n );\n const now = input?.now ?? Date.now();\n let kept = [...targeted];\n\n if (typeof input?.maxAgeMs === \"number\" && Number.isFinite(input.maxAgeMs)) {\n const cutoff = now - input.maxAgeMs;\n kept = kept.filter((run) => {\n const timestamp = run.finishedAt ?? run.createdAt ?? 0;\n return timestamp >= cutoff;\n });\n }\n\n if (\n typeof input?.maxRunsPerSuite === \"number\" &&\n Number.isFinite(input.maxRunsPerSuite) &&\n input.maxRunsPerSuite >= 0\n ) {\n const remainingBySuite = new Map<string, number>();\n kept = kept.filter((run) => {\n const current = remainingBySuite.get(run.suiteId) ?? 0;\n if (current >= input.maxRunsPerSuite!) {\n return false;\n }\n remainingBySuite.set(run.suiteId, current + 1);\n return true;\n });\n }\n\n const keptIds = new Set(kept.map((run) => run.id));\n const removed = targeted.filter((run) => !keptIds.has(run.id));\n const next = sort([...untouched, ...kept]);\n\n return {\n keptCount: next.length,\n next,\n removed,\n removedCount: removed.length,\n };\n};\n\nconst applyRAGSearchTracePrunePolicy = ({\n input,\n traces,\n}: {\n input?: RAGSearchTracePruneInput;\n traces: RAGSearchTraceRecord[];\n}) => {\n const sorted = normalizeTraceSummaryRuns(traces);\n const matchesTag = (trace: RAGSearchTraceRecord) =>\n !input?.tag || (trace.tags ?? []).includes(input.tag);\n const targeted = sorted.filter(matchesTag);\n const untouched = sorted.filter((trace) => !matchesTag(trace));\n const now = input?.now ?? Date.now();\n let kept = [...targeted];\n\n if (typeof input?.maxAgeMs === \"number\" && Number.isFinite(input.maxAgeMs)) {\n const cutoff = now - input.maxAgeMs;\n kept = kept.filter((trace) => trace.finishedAt >= cutoff);\n }\n\n if (\n typeof input?.maxRecordsPerQuery === \"number\" &&\n Number.isFinite(input.maxRecordsPerQuery) &&\n input.maxRecordsPerQuery >= 0\n ) {\n const remainingByQuery = new Map<string, number>();\n kept = kept.filter((trace) => {\n const current = remainingByQuery.get(trace.query) ?? 0;\n if (current >= input.maxRecordsPerQuery!) {\n return false;\n }\n remainingByQuery.set(trace.query, current + 1);\n return true;\n });\n }\n\n if (\n typeof input?.maxRecordsPerGroup === \"number\" &&\n Number.isFinite(input.maxRecordsPerGroup) &&\n input.maxRecordsPerGroup >= 0\n ) {\n const remainingByGroup = new Map<string, number>();\n kept = kept.filter((trace) => {\n if (!trace.groupKey) {\n return true;\n }\n\n const current = remainingByGroup.get(trace.groupKey) ?? 0;\n if (current >= input.maxRecordsPerGroup!) {\n return false;\n }\n remainingByGroup.set(trace.groupKey, current + 1);\n return true;\n });\n }\n\n const keptIds = new Set(kept.map((trace) => trace.id));\n const removed = targeted.filter((trace) => !keptIds.has(trace.id));\n const next = normalizeTraceSummaryRuns([...untouched, ...kept]);\n\n return {\n keptCount: next.length,\n next,\n removed,\n removedCount: removed.length,\n };\n};\n\nconst buildRAGSearchTraceStatsFromTraces = (\n traces: RAGSearchTraceRecord[],\n): RAGSearchTraceStats => {\n const queryKeys = new Set<string>();\n const groupKeys = new Set<string>();\n const tagCounts = new Map<string, number>();\n let oldestFinishedAt: number | undefined;\n let newestFinishedAt: number | undefined;\n\n for (const trace of traces) {\n queryKeys.add(trace.query);\n if (trace.groupKey) {\n groupKeys.add(trace.groupKey);\n }\n for (const tag of trace.tags ?? []) {\n tagCounts.set(tag, (tagCounts.get(tag) ?? 0) + 1);\n }\n oldestFinishedAt =\n typeof oldestFinishedAt === \"number\"\n ? Math.min(oldestFinishedAt, trace.finishedAt)\n : trace.finishedAt;\n newestFinishedAt =\n typeof newestFinishedAt === \"number\"\n ? Math.max(newestFinishedAt, trace.finishedAt)\n : trace.finishedAt;\n }\n\n return {\n groupCount: groupKeys.size,\n newestFinishedAt,\n oldestFinishedAt,\n queryCount: queryKeys.size,\n tagCounts: Object.fromEntries(tagCounts.entries()),\n totalTraces: traces.length,\n };\n};\n\nconst normalizeTraceTags = (tags?: string[]) =>\n Array.from(\n new Set((tags ?? []).map((tag) => tag.trim()).filter(Boolean)),\n ).sort((left, right) => left.localeCompare(right));\n\nconst toGroundingHistorySortOrder = (\n left: RAGAnswerGroundingEvaluationRun,\n right: RAGAnswerGroundingEvaluationRun,\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeGroundingHistoryRuns = (\n runs: RAGAnswerGroundingEvaluationRun[],\n) => [...runs].sort(toGroundingHistorySortOrder);\n\nconst toSearchTracePruneRunSortOrder = (\n left: RAGSearchTracePruneRun,\n right: RAGSearchTracePruneRun,\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeSearchTracePruneRuns = (runs: RAGSearchTracePruneRun[]) =>\n [...runs].sort(toSearchTracePruneRunSortOrder);\n\nconst toGroundingDifficultyHistorySortOrder = (\n left: RAGAnswerGroundingCaseDifficultyRun,\n right: RAGAnswerGroundingCaseDifficultyRun,\n) => right.finishedAt - left.finishedAt;\n\nconst normalizeGroundingDifficultyHistoryRuns = (\n runs: RAGAnswerGroundingCaseDifficultyRun[],\n) => [...runs].sort(toGroundingDifficultyHistorySortOrder);\n\nconst buildCaseDiff = (\n currentCase: RAGEvaluationCaseResult,\n previousCase?: RAGEvaluationCaseResult,\n): RAGEvaluationCaseDiff => ({\n caseId: currentCase.caseId,\n currentF1: currentCase.f1,\n currentMatchedIds: currentCase.matchedIds,\n currentMissingIds: currentCase.missingIds,\n currentStatus: currentCase.status,\n label: currentCase.label,\n previousF1: previousCase?.f1,\n previousMatchedIds: previousCase?.matchedIds ?? [],\n previousMissingIds: previousCase?.missingIds ?? [],\n previousStatus: previousCase?.status,\n previousFailureClasses: previousCase?.failureClasses ?? [],\n query: currentCase.query,\n currentFailureClasses: currentCase.failureClasses ?? [],\n});\n\nconst buildGroundingCaseDiff = (\n currentCase: RAGAnswerGroundingEvaluationCaseResult,\n previousCase?: RAGAnswerGroundingEvaluationCaseResult,\n): RAGAnswerGroundingEvaluationCaseDiff => ({\n answerChanged:\n typeof previousCase?.answer === \"string\"\n ? previousCase.answer !== currentCase.answer\n : true,\n caseId: currentCase.caseId,\n currentCitationF1: currentCase.citationF1,\n currentCitedIds: currentCase.citedIds,\n currentCoverage: currentCase.coverage,\n currentExtraIds: currentCase.extraIds,\n currentMatchedIds: currentCase.matchedIds,\n currentMissingIds: currentCase.missingIds,\n currentReferenceCount: currentCase.referenceCount,\n currentResolvedCitationCount: currentCase.resolvedCitationCount,\n currentAnswer: currentCase.answer,\n currentStatus: currentCase.status,\n currentUngroundedReferenceNumbers:\n currentCase.groundedAnswer.ungroundedReferenceNumbers,\n currentUnresolvedCitationCount: currentCase.unresolvedCitationCount,\n label: currentCase.label,\n previousAnswer: previousCase?.answer,\n previousCitationF1: previousCase?.citationF1,\n previousCitedIds: previousCase?.citedIds ?? [],\n previousCoverage: previousCase?.coverage,\n previousExtraIds: previousCase?.extraIds ?? [],\n previousFailureClasses: previousCase?.failureClasses ?? [],\n previousMatchedIds: previousCase?.matchedIds ?? [],\n previousMissingIds: previousCase?.missingIds ?? [],\n previousReferenceCount: previousCase?.referenceCount,\n previousResolvedCitationCount: previousCase?.resolvedCitationCount,\n previousStatus: previousCase?.status,\n previousUngroundedReferenceNumbers:\n previousCase?.groundedAnswer.ungroundedReferenceNumbers ?? [],\n previousUnresolvedCitationCount: previousCase?.unresolvedCitationCount,\n query: currentCase.query,\n currentFailureClasses: currentCase.failureClasses ?? [],\n});\n\nconst buildGroundingCaseSnapshots = ({\n current,\n previous,\n}: {\n current?: RAGAnswerGroundingEvaluationRun;\n previous?: RAGAnswerGroundingEvaluationRun;\n}): RAGAnswerGroundingEvaluationCaseSnapshot[] => {\n if (!current) {\n return [];\n }\n\n const previousCases = new Map(\n (previous?.response.cases ?? []).map((entry) => [entry.caseId, entry]),\n );\n\n return current.response.cases.map((entry) => {\n const previousCase = previousCases.get(entry.caseId);\n return {\n answer: entry.answer,\n answerChange:\n typeof previousCase?.answer === \"string\"\n ? previousCase.answer === entry.answer\n ? \"unchanged\"\n : \"changed\"\n : \"new\",\n caseId: entry.caseId,\n citationCount: entry.citationCount,\n citationF1: entry.citationF1,\n citedIds: entry.citedIds,\n coverage: entry.coverage,\n extraIds: entry.extraIds,\n failureClasses: entry.failureClasses,\n label: entry.label,\n matchedIds: entry.matchedIds,\n missingIds: entry.missingIds,\n previousAnswer: previousCase?.answer,\n query: entry.query,\n referenceCount: entry.referenceCount,\n resolvedCitationCount: entry.resolvedCitationCount,\n resolvedCitationRate: entry.resolvedCitationRate,\n status: entry.status,\n ungroundedReferenceNumbers:\n entry.groundedAnswer.ungroundedReferenceNumbers,\n unresolvedCitationCount: entry.unresolvedCitationCount,\n };\n });\n};\n\nconst areStageCountsEqual = (\n left: Partial<Record<RAGRetrievalTraceStage, number>>,\n right: Partial<Record<RAGRetrievalTraceStage, number>>,\n) => {\n const keys = new Set([\n ...Object.keys(left),\n ...Object.keys(right),\n ]) as Set<RAGRetrievalTraceStage>;\n\n for (const key of keys) {\n if ((left[key] ?? 0) !== (right[key] ?? 0)) {\n return false;\n }\n }\n\n return true;\n};\n\nconst buildEvaluationCaseTraceSnapshot = ({\n caseResult,\n filter,\n retrieval,\n currentTrace,\n previousTrace,\n currentSnapshot,\n topResult,\n}: {\n caseResult: RAGEvaluationCaseResult;\n filter?: Record<string, unknown>;\n retrieval?: RAGCollectionSearchParams[\"retrieval\"];\n currentTrace?: RAGRetrievalTrace;\n previousTrace?: RAGEvaluationCaseTraceSnapshot;\n currentSnapshot?: RAGEvaluationCaseTraceSnapshot;\n topResult?: RAGQueryResult;\n}): RAGEvaluationCaseTraceSnapshot => {\n const stageCounts = currentTrace ? buildTraceStageCounts([currentTrace]) : {};\n const previousStageCounts = previousTrace?.stageCounts ?? {};\n const currentLeadSnapshot =\n topResult || currentSnapshot\n ? buildEvaluationLeadSnapshot({\n metadata: topResult?.metadata,\n source: topResult?.source,\n title: topResult?.title,\n })\n : {};\n const topContextLabel =\n currentLeadSnapshot.topContextLabel ?? currentSnapshot?.topContextLabel;\n const topLocatorLabel =\n currentLeadSnapshot.topLocatorLabel ?? currentSnapshot?.topLocatorLabel;\n const sourceAwareChunkReasonLabel =\n currentLeadSnapshot.sourceAwareChunkReasonLabel ??\n currentSnapshot?.sourceAwareChunkReasonLabel;\n const sourceAwareUnitScopeLabel =\n currentLeadSnapshot.sourceAwareUnitScopeLabel ??\n currentSnapshot?.sourceAwareUnitScopeLabel;\n const currentLeadMediaCueSnapshot = currentTrace\n ? buildEvaluationLeadMediaCueSnapshot(currentTrace)\n : {};\n const currentLeadPresentationCueSnapshot = currentTrace\n ? buildEvaluationLeadPresentationCueSnapshot(currentTrace)\n : {};\n const currentLeadSpreadsheetCueSnapshot = currentTrace\n ? buildEvaluationLeadSpreadsheetCueSnapshot(currentTrace)\n : {};\n const currentSQLiteQueryPlanSnapshot = currentTrace\n ? buildEvaluationSQLiteQueryPlanSnapshot(currentTrace)\n : {};\n const currentPostgresQueryPlanSnapshot = currentTrace\n ? buildEvaluationPostgresQueryPlanSnapshot(currentTrace)\n : {};\n const leadSpeakerCue =\n currentLeadMediaCueSnapshot.leadSpeakerCue ??\n currentSnapshot?.leadSpeakerCue;\n const leadPresentationCue =\n currentLeadPresentationCueSnapshot.leadPresentationCue ??\n currentSnapshot?.leadPresentationCue;\n const leadSpreadsheetCue =\n currentLeadSpreadsheetCueSnapshot.leadSpreadsheetCue ??\n currentSnapshot?.leadSpreadsheetCue;\n const leadSpeakerAttributionCue =\n currentLeadMediaCueSnapshot.leadSpeakerAttributionCue ??\n currentSnapshot?.leadSpeakerAttributionCue;\n const leadChannelCue =\n currentLeadMediaCueSnapshot.leadChannelCue ??\n currentSnapshot?.leadChannelCue;\n const leadChannelAttributionCue =\n currentLeadMediaCueSnapshot.leadChannelAttributionCue ??\n currentSnapshot?.leadChannelAttributionCue;\n const leadContinuityCue =\n currentLeadMediaCueSnapshot.leadContinuityCue ??\n currentSnapshot?.leadContinuityCue;\n const sqliteQueryMode =\n currentSQLiteQueryPlanSnapshot.sqliteQueryMode ??\n currentSnapshot?.sqliteQueryMode;\n const sqliteQueryPushdownMode =\n currentSQLiteQueryPlanSnapshot.sqliteQueryPushdownMode ??\n currentSnapshot?.sqliteQueryPushdownMode;\n const sqliteQueryPushdownApplied =\n currentSQLiteQueryPlanSnapshot.sqliteQueryPushdownApplied ??\n currentSnapshot?.sqliteQueryPushdownApplied;\n const sqliteQueryPushdownClauseCount =\n currentSQLiteQueryPlanSnapshot.sqliteQueryPushdownClauseCount ??\n currentSnapshot?.sqliteQueryPushdownClauseCount;\n const sqliteQueryTotalFilterClauseCount =\n currentSQLiteQueryPlanSnapshot.sqliteQueryTotalFilterClauseCount ??\n currentSnapshot?.sqliteQueryTotalFilterClauseCount;\n const sqliteQueryJsRemainderClauseCount =\n currentSQLiteQueryPlanSnapshot.sqliteQueryJsRemainderClauseCount ??\n currentSnapshot?.sqliteQueryJsRemainderClauseCount;\n const sqliteQueryMultiplierUsed =\n currentSQLiteQueryPlanSnapshot.sqliteQueryMultiplierUsed ??\n currentSnapshot?.sqliteQueryMultiplierUsed;\n const sqliteQueryCandidateLimitUsed =\n currentSQLiteQueryPlanSnapshot.sqliteQueryCandidateLimitUsed ??\n currentSnapshot?.sqliteQueryCandidateLimitUsed;\n const sqliteQueryMaxBackfillsUsed =\n currentSQLiteQueryPlanSnapshot.sqliteQueryMaxBackfillsUsed ??\n currentSnapshot?.sqliteQueryMaxBackfillsUsed;\n const sqliteQueryMinResultsUsed =\n currentSQLiteQueryPlanSnapshot.sqliteQueryMinResultsUsed ??\n currentSnapshot?.sqliteQueryMinResultsUsed;\n const sqliteQueryFillPolicyUsed =\n currentSQLiteQueryPlanSnapshot.sqliteQueryFillPolicyUsed ??\n currentSnapshot?.sqliteQueryFillPolicyUsed;\n const sqliteQueryPushdownCoverageRatio =\n currentSQLiteQueryPlanSnapshot.sqliteQueryPushdownCoverageRatio ??\n currentSnapshot?.sqliteQueryPushdownCoverageRatio;\n const sqliteQueryJsRemainderRatio =\n currentSQLiteQueryPlanSnapshot.sqliteQueryJsRemainderRatio ??\n currentSnapshot?.sqliteQueryJsRemainderRatio;\n const sqliteQueryFilteredCandidates =\n currentSQLiteQueryPlanSnapshot.sqliteQueryFilteredCandidates ??\n currentSnapshot?.sqliteQueryFilteredCandidates;\n const sqliteQueryInitialSearchK =\n currentSQLiteQueryPlanSnapshot.sqliteQueryInitialSearchK ??\n currentSnapshot?.sqliteQueryInitialSearchK;\n const sqliteQueryFinalSearchK =\n currentSQLiteQueryPlanSnapshot.sqliteQueryFinalSearchK ??\n currentSnapshot?.sqliteQueryFinalSearchK;\n const sqliteQuerySearchExpansionRatio =\n currentSQLiteQueryPlanSnapshot.sqliteQuerySearchExpansionRatio ??\n currentSnapshot?.sqliteQuerySearchExpansionRatio;\n const sqliteQueryBackfillCount =\n currentSQLiteQueryPlanSnapshot.sqliteQueryBackfillCount ??\n currentSnapshot?.sqliteQueryBackfillCount;\n const sqliteQueryBackfillLimitReached =\n currentSQLiteQueryPlanSnapshot.sqliteQueryBackfillLimitReached ??\n currentSnapshot?.sqliteQueryBackfillLimitReached;\n const sqliteQueryMinResultsSatisfied =\n currentSQLiteQueryPlanSnapshot.sqliteQueryMinResultsSatisfied ??\n currentSnapshot?.sqliteQueryMinResultsSatisfied;\n const sqliteQueryReturnedCount =\n currentSQLiteQueryPlanSnapshot.sqliteQueryReturnedCount ??\n currentSnapshot?.sqliteQueryReturnedCount;\n const sqliteQueryCandidateYieldRatio =\n currentSQLiteQueryPlanSnapshot.sqliteQueryCandidateYieldRatio ??\n currentSnapshot?.sqliteQueryCandidateYieldRatio;\n const sqliteQueryTopKFillRatio =\n currentSQLiteQueryPlanSnapshot.sqliteQueryTopKFillRatio ??\n currentSnapshot?.sqliteQueryTopKFillRatio;\n const sqliteQueryUnderfilledTopK =\n currentSQLiteQueryPlanSnapshot.sqliteQueryUnderfilledTopK ??\n currentSnapshot?.sqliteQueryUnderfilledTopK;\n const sqliteQueryCandidateBudgetExhausted =\n currentSQLiteQueryPlanSnapshot.sqliteQueryCandidateBudgetExhausted ??\n currentSnapshot?.sqliteQueryCandidateBudgetExhausted;\n const sqliteQueryCandidateCoverage =\n currentSQLiteQueryPlanSnapshot.sqliteQueryCandidateCoverage ??\n currentSnapshot?.sqliteQueryCandidateCoverage;\n const postgresQueryMode =\n currentPostgresQueryPlanSnapshot.postgresQueryMode ??\n currentSnapshot?.postgresQueryMode;\n const postgresQueryPushdownMode =\n currentPostgresQueryPlanSnapshot.postgresQueryPushdownMode ??\n currentSnapshot?.postgresQueryPushdownMode;\n const postgresQueryPushdownApplied =\n currentPostgresQueryPlanSnapshot.postgresQueryPushdownApplied ??\n currentSnapshot?.postgresQueryPushdownApplied;\n const postgresQueryPushdownClauseCount =\n currentPostgresQueryPlanSnapshot.postgresQueryPushdownClauseCount ??\n currentSnapshot?.postgresQueryPushdownClauseCount;\n const postgresQueryTotalFilterClauseCount =\n currentPostgresQueryPlanSnapshot.postgresQueryTotalFilterClauseCount ??\n currentSnapshot?.postgresQueryTotalFilterClauseCount;\n const postgresQueryJsRemainderClauseCount =\n currentPostgresQueryPlanSnapshot.postgresQueryJsRemainderClauseCount ??\n currentSnapshot?.postgresQueryJsRemainderClauseCount;\n const postgresQueryMultiplierUsed =\n currentPostgresQueryPlanSnapshot.postgresQueryMultiplierUsed ??\n currentSnapshot?.postgresQueryMultiplierUsed;\n const postgresQueryCandidateLimitUsed =\n currentPostgresQueryPlanSnapshot.postgresQueryCandidateLimitUsed ??\n currentSnapshot?.postgresQueryCandidateLimitUsed;\n const postgresQueryMaxBackfillsUsed =\n currentPostgresQueryPlanSnapshot.postgresQueryMaxBackfillsUsed ??\n currentSnapshot?.postgresQueryMaxBackfillsUsed;\n const postgresQueryMinResultsUsed =\n currentPostgresQueryPlanSnapshot.postgresQueryMinResultsUsed ??\n currentSnapshot?.postgresQueryMinResultsUsed;\n const postgresQueryFillPolicyUsed =\n currentPostgresQueryPlanSnapshot.postgresQueryFillPolicyUsed ??\n currentSnapshot?.postgresQueryFillPolicyUsed;\n const postgresQueryPushdownCoverageRatio =\n currentPostgresQueryPlanSnapshot.postgresQueryPushdownCoverageRatio ??\n currentSnapshot?.postgresQueryPushdownCoverageRatio;\n const postgresQueryJsRemainderRatio =\n currentPostgresQueryPlanSnapshot.postgresQueryJsRemainderRatio ??\n currentSnapshot?.postgresQueryJsRemainderRatio;\n const postgresQueryFilteredCandidates =\n currentPostgresQueryPlanSnapshot.postgresQueryFilteredCandidates ??\n currentSnapshot?.postgresQueryFilteredCandidates;\n const postgresQueryInitialSearchK =\n currentPostgresQueryPlanSnapshot.postgresQueryInitialSearchK ??\n currentSnapshot?.postgresQueryInitialSearchK;\n const postgresQueryFinalSearchK =\n currentPostgresQueryPlanSnapshot.postgresQueryFinalSearchK ??\n currentSnapshot?.postgresQueryFinalSearchK;\n const postgresQuerySearchExpansionRatio =\n currentPostgresQueryPlanSnapshot.postgresQuerySearchExpansionRatio ??\n currentSnapshot?.postgresQuerySearchExpansionRatio;\n const postgresQueryBackfillCount =\n currentPostgresQueryPlanSnapshot.postgresQueryBackfillCount ??\n currentSnapshot?.postgresQueryBackfillCount;\n const postgresQueryBackfillLimitReached =\n currentPostgresQueryPlanSnapshot.postgresQueryBackfillLimitReached ??\n currentSnapshot?.postgresQueryBackfillLimitReached;\n const postgresQueryMinResultsSatisfied =\n currentPostgresQueryPlanSnapshot.postgresQueryMinResultsSatisfied ??\n currentSnapshot?.postgresQueryMinResultsSatisfied;\n const postgresQueryReturnedCount =\n currentPostgresQueryPlanSnapshot.postgresQueryReturnedCount ??\n currentSnapshot?.postgresQueryReturnedCount;\n const postgresQueryCandidateYieldRatio =\n currentPostgresQueryPlanSnapshot.postgresQueryCandidateYieldRatio ??\n currentSnapshot?.postgresQueryCandidateYieldRatio;\n const postgresQueryTopKFillRatio =\n currentPostgresQueryPlanSnapshot.postgresQueryTopKFillRatio ??\n currentSnapshot?.postgresQueryTopKFillRatio;\n const postgresQueryUnderfilledTopK =\n currentPostgresQueryPlanSnapshot.postgresQueryUnderfilledTopK ??\n currentSnapshot?.postgresQueryUnderfilledTopK;\n const postgresQueryCandidateBudgetExhausted =\n currentPostgresQueryPlanSnapshot.postgresQueryCandidateBudgetExhausted ??\n currentSnapshot?.postgresQueryCandidateBudgetExhausted;\n const postgresQueryCandidateCoverage =\n currentPostgresQueryPlanSnapshot.postgresQueryCandidateCoverage ??\n currentSnapshot?.postgresQueryCandidateCoverage;\n const currentFilterSignature = JSON.stringify(filter ?? undefined);\n const previousFilterSignature = JSON.stringify(\n previousTrace?.inputFilter ?? undefined,\n );\n const currentRetrievalSignature = JSON.stringify(retrieval ?? undefined);\n const previousRetrievalSignature = JSON.stringify(\n previousTrace?.inputRetrieval ?? undefined,\n );\n const traceChange = !previousTrace\n ? currentTrace\n ? \"new\"\n : \"unchanged\"\n : previousTrace.traceMode !== currentTrace?.mode ||\n previousFilterSignature !== currentFilterSignature ||\n previousRetrievalSignature !== currentRetrievalSignature ||\n previousTrace.sourceBalanceStrategy !==\n currentTrace?.sourceBalanceStrategy ||\n previousTrace.transformedQuery !==\n (currentTrace?.transformedQuery || undefined) ||\n previousTrace.variantQueries.join(\"|\") !==\n (currentTrace?.variantQueries ?? []).join(\"|\") ||\n previousTrace.finalCount !== (currentTrace?.resultCounts.final ?? 0) ||\n previousTrace.vectorCount !==\n (currentTrace?.resultCounts.vector ?? 0) ||\n previousTrace.lexicalCount !==\n (currentTrace?.resultCounts.lexical ?? 0) ||\n previousTrace.candidateTopK !== (currentTrace?.candidateTopK ?? 0) ||\n previousTrace.lexicalTopK !== (currentTrace?.lexicalTopK ?? 0) ||\n previousTrace.topContextLabel !== topContextLabel ||\n previousTrace.topLocatorLabel !== topLocatorLabel ||\n previousTrace.sourceAwareChunkReasonLabel !==\n sourceAwareChunkReasonLabel ||\n previousTrace.sourceAwareUnitScopeLabel !== sourceAwareUnitScopeLabel ||\n previousTrace.leadSpeakerCue !== leadSpeakerCue ||\n previousTrace.leadPresentationCue !== leadPresentationCue ||\n previousTrace.leadSpreadsheetCue !== leadSpreadsheetCue ||\n previousTrace.leadSpeakerAttributionCue !== leadSpeakerAttributionCue ||\n previousTrace.leadChannelCue !== leadChannelCue ||\n previousTrace.leadChannelAttributionCue !== leadChannelAttributionCue ||\n previousTrace.leadContinuityCue !== leadContinuityCue ||\n previousTrace.sqliteQueryMode !== sqliteQueryMode ||\n previousTrace.sqliteQueryPushdownMode !== sqliteQueryPushdownMode ||\n previousTrace.sqliteQueryPushdownApplied !==\n sqliteQueryPushdownApplied ||\n previousTrace.sqliteQueryPushdownClauseCount !==\n sqliteQueryPushdownClauseCount ||\n previousTrace.sqliteQueryTotalFilterClauseCount !==\n sqliteQueryTotalFilterClauseCount ||\n previousTrace.sqliteQueryJsRemainderClauseCount !==\n sqliteQueryJsRemainderClauseCount ||\n previousTrace.sqliteQueryMultiplierUsed !== sqliteQueryMultiplierUsed ||\n previousTrace.sqliteQueryCandidateLimitUsed !==\n sqliteQueryCandidateLimitUsed ||\n previousTrace.sqliteQueryMaxBackfillsUsed !==\n sqliteQueryMaxBackfillsUsed ||\n previousTrace.sqliteQueryMinResultsUsed !== sqliteQueryMinResultsUsed ||\n previousTrace.sqliteQueryFillPolicyUsed !== sqliteQueryFillPolicyUsed ||\n previousTrace.sqliteQueryPushdownCoverageRatio !==\n sqliteQueryPushdownCoverageRatio ||\n previousTrace.sqliteQueryJsRemainderRatio !==\n sqliteQueryJsRemainderRatio ||\n previousTrace.sqliteQueryFilteredCandidates !==\n sqliteQueryFilteredCandidates ||\n previousTrace.sqliteQueryInitialSearchK !== sqliteQueryInitialSearchK ||\n previousTrace.sqliteQueryFinalSearchK !== sqliteQueryFinalSearchK ||\n previousTrace.sqliteQuerySearchExpansionRatio !==\n sqliteQuerySearchExpansionRatio ||\n previousTrace.sqliteQueryBackfillCount !== sqliteQueryBackfillCount ||\n previousTrace.sqliteQueryBackfillLimitReached !==\n sqliteQueryBackfillLimitReached ||\n previousTrace.sqliteQueryMinResultsSatisfied !==\n sqliteQueryMinResultsSatisfied ||\n previousTrace.sqliteQueryReturnedCount !== sqliteQueryReturnedCount ||\n previousTrace.sqliteQueryCandidateYieldRatio !==\n sqliteQueryCandidateYieldRatio ||\n previousTrace.sqliteQueryTopKFillRatio !== sqliteQueryTopKFillRatio ||\n previousTrace.sqliteQueryUnderfilledTopK !==\n sqliteQueryUnderfilledTopK ||\n previousTrace.sqliteQueryCandidateBudgetExhausted !==\n sqliteQueryCandidateBudgetExhausted ||\n previousTrace.sqliteQueryCandidateCoverage !==\n sqliteQueryCandidateCoverage ||\n previousTrace.postgresQueryMode !== postgresQueryMode ||\n previousTrace.postgresQueryPushdownMode !== postgresQueryPushdownMode ||\n previousTrace.postgresQueryPushdownApplied !==\n postgresQueryPushdownApplied ||\n previousTrace.postgresQueryPushdownClauseCount !==\n postgresQueryPushdownClauseCount ||\n previousTrace.postgresQueryTotalFilterClauseCount !==\n postgresQueryTotalFilterClauseCount ||\n previousTrace.postgresQueryJsRemainderClauseCount !==\n postgresQueryJsRemainderClauseCount ||\n previousTrace.postgresQueryMultiplierUsed !==\n postgresQueryMultiplierUsed ||\n previousTrace.postgresQueryCandidateLimitUsed !==\n postgresQueryCandidateLimitUsed ||\n previousTrace.postgresQueryMaxBackfillsUsed !==\n postgresQueryMaxBackfillsUsed ||\n previousTrace.postgresQueryMinResultsUsed !==\n postgresQueryMinResultsUsed ||\n previousTrace.postgresQueryFillPolicyUsed !==\n postgresQueryFillPolicyUsed ||\n previousTrace.postgresQueryPushdownCoverageRatio !==\n postgresQueryPushdownCoverageRatio ||\n previousTrace.postgresQueryJsRemainderRatio !==\n postgresQueryJsRemainderRatio ||\n previousTrace.postgresQueryFilteredCandidates !==\n postgresQueryFilteredCandidates ||\n previousTrace.postgresQueryInitialSearchK !==\n postgresQueryInitialSearchK ||\n previousTrace.postgresQueryFinalSearchK !== postgresQueryFinalSearchK ||\n previousTrace.postgresQuerySearchExpansionRatio !==\n postgresQuerySearchExpansionRatio ||\n previousTrace.postgresQueryBackfillCount !==\n postgresQueryBackfillCount ||\n previousTrace.postgresQueryBackfillLimitReached !==\n postgresQueryBackfillLimitReached ||\n previousTrace.postgresQueryMinResultsSatisfied !==\n postgresQueryMinResultsSatisfied ||\n previousTrace.postgresQueryReturnedCount !==\n postgresQueryReturnedCount ||\n previousTrace.postgresQueryCandidateYieldRatio !==\n postgresQueryCandidateYieldRatio ||\n previousTrace.postgresQueryTopKFillRatio !==\n postgresQueryTopKFillRatio ||\n previousTrace.postgresQueryUnderfilledTopK !==\n postgresQueryUnderfilledTopK ||\n previousTrace.postgresQueryCandidateBudgetExhausted !==\n postgresQueryCandidateBudgetExhausted ||\n previousTrace.postgresQueryCandidateCoverage !==\n postgresQueryCandidateCoverage ||\n !areStageCountsEqual(previousStageCounts, stageCounts)\n ? \"changed\"\n : \"unchanged\";\n\n return {\n candidateTopK: currentTrace?.candidateTopK ?? 0,\n caseId: caseResult.caseId,\n corpusKey: caseResult.corpusKey,\n inputFilter: filter,\n finalCount: currentTrace?.resultCounts.final ?? 0,\n label: caseResult.label,\n lexicalCount: currentTrace?.resultCounts.lexical ?? 0,\n lexicalTopK: currentTrace?.lexicalTopK ?? 0,\n inputRetrieval: retrieval,\n previousCandidateTopK: previousTrace?.candidateTopK,\n previousFinalCount: previousTrace?.finalCount,\n previousLexicalCount: previousTrace?.lexicalCount,\n previousLexicalTopK: previousTrace?.lexicalTopK,\n previousInputFilter: previousTrace?.inputFilter,\n previousInputRetrieval: previousTrace?.inputRetrieval,\n previousLeadChannelAttributionCue: previousTrace?.leadChannelAttributionCue,\n previousLeadChannelCue: previousTrace?.leadChannelCue,\n previousLeadContinuityCue: previousTrace?.leadContinuityCue,\n previousLeadPresentationCue: previousTrace?.leadPresentationCue,\n previousLeadSpreadsheetCue: previousTrace?.leadSpreadsheetCue,\n previousLeadSpeakerAttributionCue: previousTrace?.leadSpeakerAttributionCue,\n previousLeadSpeakerCue: previousTrace?.leadSpeakerCue,\n previousSqliteQueryBackfillCount: previousTrace?.sqliteQueryBackfillCount,\n previousSqliteQueryBackfillLimitReached:\n previousTrace?.sqliteQueryBackfillLimitReached,\n previousSqliteQueryMinResultsSatisfied:\n previousTrace?.sqliteQueryMinResultsSatisfied,\n previousSqliteQueryCandidateBudgetExhausted:\n previousTrace?.sqliteQueryCandidateBudgetExhausted,\n previousSqliteQueryCandidateCoverage:\n previousTrace?.sqliteQueryCandidateCoverage,\n previousSqliteQueryFilteredCandidates:\n previousTrace?.sqliteQueryFilteredCandidates,\n previousSqliteQueryFinalSearchK: previousTrace?.sqliteQueryFinalSearchK,\n previousSqliteQueryInitialSearchK: previousTrace?.sqliteQueryInitialSearchK,\n previousSqliteQuerySearchExpansionRatio:\n previousTrace?.sqliteQuerySearchExpansionRatio,\n previousSqliteQueryMode: previousTrace?.sqliteQueryMode,\n previousSqliteQueryPushdownMode: previousTrace?.sqliteQueryPushdownMode,\n previousSqliteQueryPushdownApplied:\n previousTrace?.sqliteQueryPushdownApplied,\n previousSqliteQueryPushdownClauseCount:\n previousTrace?.sqliteQueryPushdownClauseCount,\n previousSqliteQueryTotalFilterClauseCount:\n previousTrace?.sqliteQueryTotalFilterClauseCount,\n previousSqliteQueryJsRemainderClauseCount:\n previousTrace?.sqliteQueryJsRemainderClauseCount,\n previousSqliteQueryMultiplierUsed: previousTrace?.sqliteQueryMultiplierUsed,\n previousSqliteQueryCandidateLimitUsed:\n previousTrace?.sqliteQueryCandidateLimitUsed,\n previousSqliteQueryMaxBackfillsUsed:\n previousTrace?.sqliteQueryMaxBackfillsUsed,\n previousSqliteQueryMinResultsUsed: previousTrace?.sqliteQueryMinResultsUsed,\n previousSqliteQueryFillPolicyUsed: previousTrace?.sqliteQueryFillPolicyUsed,\n previousSqliteQueryPushdownCoverageRatio:\n previousTrace?.sqliteQueryPushdownCoverageRatio,\n previousSqliteQueryJsRemainderRatio:\n previousTrace?.sqliteQueryJsRemainderRatio,\n previousSqliteQueryReturnedCount: previousTrace?.sqliteQueryReturnedCount,\n previousSqliteQueryCandidateYieldRatio:\n previousTrace?.sqliteQueryCandidateYieldRatio,\n previousSqliteQueryTopKFillRatio: previousTrace?.sqliteQueryTopKFillRatio,\n previousSqliteQueryUnderfilledTopK:\n previousTrace?.sqliteQueryUnderfilledTopK,\n previousPostgresQueryBackfillCount:\n previousTrace?.postgresQueryBackfillCount,\n previousPostgresQueryBackfillLimitReached:\n previousTrace?.postgresQueryBackfillLimitReached,\n previousPostgresQueryMinResultsSatisfied:\n previousTrace?.postgresQueryMinResultsSatisfied,\n previousPostgresQueryCandidateBudgetExhausted:\n previousTrace?.postgresQueryCandidateBudgetExhausted,\n previousPostgresQueryCandidateCoverage:\n previousTrace?.postgresQueryCandidateCoverage,\n previousPostgresQueryFilteredCandidates:\n previousTrace?.postgresQueryFilteredCandidates,\n previousPostgresQueryFinalSearchK: previousTrace?.postgresQueryFinalSearchK,\n previousPostgresQueryInitialSearchK:\n previousTrace?.postgresQueryInitialSearchK,\n previousPostgresQuerySearchExpansionRatio:\n previousTrace?.postgresQuerySearchExpansionRatio,\n previousPostgresQueryMode: previousTrace?.postgresQueryMode,\n previousPostgresQueryPushdownMode: previousTrace?.postgresQueryPushdownMode,\n previousPostgresQueryPushdownApplied:\n previousTrace?.postgresQueryPushdownApplied,\n previousPostgresQueryPushdownClauseCount:\n previousTrace?.postgresQueryPushdownClauseCount,\n previousPostgresQueryTotalFilterClauseCount:\n previousTrace?.postgresQueryTotalFilterClauseCount,\n previousPostgresQueryJsRemainderClauseCount:\n previousTrace?.postgresQueryJsRemainderClauseCount,\n previousPostgresQueryMultiplierUsed:\n previousTrace?.postgresQueryMultiplierUsed,\n previousPostgresQueryCandidateLimitUsed:\n previousTrace?.postgresQueryCandidateLimitUsed,\n previousPostgresQueryMaxBackfillsUsed:\n previousTrace?.postgresQueryMaxBackfillsUsed,\n previousPostgresQueryMinResultsUsed:\n previousTrace?.postgresQueryMinResultsUsed,\n previousPostgresQueryFillPolicyUsed:\n previousTrace?.postgresQueryFillPolicyUsed,\n previousPostgresQueryPushdownCoverageRatio:\n previousTrace?.postgresQueryPushdownCoverageRatio,\n previousPostgresQueryJsRemainderRatio:\n previousTrace?.postgresQueryJsRemainderRatio,\n previousPostgresQueryReturnedCount:\n previousTrace?.postgresQueryReturnedCount,\n previousPostgresQueryCandidateYieldRatio:\n previousTrace?.postgresQueryCandidateYieldRatio,\n previousPostgresQueryTopKFillRatio:\n previousTrace?.postgresQueryTopKFillRatio,\n previousPostgresQueryUnderfilledTopK:\n previousTrace?.postgresQueryUnderfilledTopK,\n previousSourceBalanceStrategy: previousTrace?.sourceBalanceStrategy,\n previousSourceAwareChunkReasonLabel:\n previousTrace?.sourceAwareChunkReasonLabel,\n previousStageCounts,\n previousTopContextLabel: previousTrace?.topContextLabel,\n previousTopLocatorLabel: previousTrace?.topLocatorLabel,\n previousTraceMode: previousTrace?.traceMode,\n previousTransformedQuery: previousTrace?.transformedQuery,\n previousSourceAwareUnitScopeLabel: previousTrace?.sourceAwareUnitScopeLabel,\n previousVariantQueries: previousTrace?.variantQueries ?? [],\n previousVectorCount: previousTrace?.vectorCount,\n query: caseResult.query,\n leadChannelAttributionCue,\n leadChannelCue,\n leadContinuityCue,\n leadPresentationCue,\n leadSpreadsheetCue,\n leadSpeakerAttributionCue,\n leadSpeakerCue,\n sqliteQueryBackfillCount,\n sqliteQueryBackfillLimitReached,\n sqliteQueryMinResultsSatisfied,\n sqliteQueryCandidateBudgetExhausted,\n sqliteQueryCandidateCoverage,\n sqliteQueryFilteredCandidates,\n sqliteQueryFinalSearchK,\n sqliteQueryInitialSearchK,\n sqliteQuerySearchExpansionRatio,\n sqliteQueryMode,\n sqliteQueryPushdownMode,\n sqliteQueryPushdownApplied,\n sqliteQueryPushdownClauseCount,\n sqliteQueryTotalFilterClauseCount,\n sqliteQueryJsRemainderClauseCount,\n sqliteQueryMultiplierUsed,\n sqliteQueryCandidateLimitUsed,\n sqliteQueryMaxBackfillsUsed,\n sqliteQueryMinResultsUsed,\n sqliteQueryFillPolicyUsed,\n sqliteQueryPushdownCoverageRatio,\n sqliteQueryJsRemainderRatio,\n sqliteQueryReturnedCount,\n sqliteQueryCandidateYieldRatio,\n sqliteQueryTopKFillRatio,\n sqliteQueryUnderfilledTopK,\n postgresQueryBackfillCount,\n postgresQueryBackfillLimitReached,\n postgresQueryMinResultsSatisfied,\n postgresQueryCandidateBudgetExhausted,\n postgresQueryCandidateCoverage,\n postgresQueryFilteredCandidates,\n postgresQueryFinalSearchK,\n postgresQueryInitialSearchK,\n postgresQuerySearchExpansionRatio,\n postgresQueryMode,\n postgresQueryPushdownMode,\n postgresQueryPushdownApplied,\n postgresQueryPushdownClauseCount,\n postgresQueryTotalFilterClauseCount,\n postgresQueryJsRemainderClauseCount,\n postgresQueryMultiplierUsed,\n postgresQueryCandidateLimitUsed,\n postgresQueryMaxBackfillsUsed,\n postgresQueryMinResultsUsed,\n postgresQueryFillPolicyUsed,\n postgresQueryPushdownCoverageRatio,\n postgresQueryJsRemainderRatio,\n postgresQueryReturnedCount,\n postgresQueryCandidateYieldRatio,\n postgresQueryTopKFillRatio,\n postgresQueryUnderfilledTopK,\n sourceAwareChunkReasonLabel,\n sourceAwareUnitScopeLabel,\n stageCounts,\n status: caseResult.status,\n sourceBalanceStrategy: currentTrace?.sourceBalanceStrategy,\n topContextLabel,\n topLocatorLabel,\n traceChange,\n traceMode: currentTrace?.mode,\n transformedQuery: currentTrace?.transformedQuery || undefined,\n variantQueries: currentTrace?.variantQueries ?? [],\n vectorCount: currentTrace?.resultCounts.vector ?? 0,\n };\n};\n\nconst buildEvaluationCaseTraceSnapshotsFromEvaluated = (\n evaluated: Array<{\n caseResult: RAGEvaluationCaseResult;\n trace?: RAGRetrievalTrace;\n filter?: Record<string, unknown>;\n retrieval?: RAGCollectionSearchParams[\"retrieval\"];\n topResult?: RAGQueryResult;\n }>,\n): RAGEvaluationCaseTraceSnapshot[] =>\n evaluated.map(({ caseResult, filter, retrieval, trace, topResult }) =>\n buildEvaluationCaseTraceSnapshot({\n caseResult,\n filter,\n retrieval,\n currentTrace: trace,\n topResult,\n }),\n );\n\nconst buildEvaluationCaseTraceSnapshots = ({\n current,\n previous,\n}: {\n current?: RAGEvaluationSuiteRun;\n previous?: RAGEvaluationSuiteRun;\n}): RAGEvaluationCaseTraceSnapshot[] => {\n if (!current) {\n return [];\n }\n\n const currentTraces = new Map(\n (current.caseTraceSnapshots ?? []).map((entry) => [entry.caseId, entry]),\n );\n const previousTraces = new Map(\n (previous?.caseTraceSnapshots ?? []).map((entry) => [entry.caseId, entry]),\n );\n\n return current.response.cases.map((caseResult) =>\n buildEvaluationCaseTraceSnapshot({\n caseResult,\n currentSnapshot: currentTraces.get(caseResult.caseId),\n currentTrace: (() => {\n const currentSnapshot = currentTraces.get(caseResult.caseId);\n if (!currentSnapshot) {\n return undefined;\n }\n\n return {\n candidateTopK: currentSnapshot.candidateTopK,\n lexicalTopK: currentSnapshot.lexicalTopK,\n mode: currentSnapshot.traceMode ?? \"vector\",\n query: caseResult.query,\n resultCounts: {\n final: currentSnapshot.finalCount,\n fused: currentSnapshot.finalCount,\n lexical: currentSnapshot.lexicalCount,\n reranked: currentSnapshot.finalCount,\n vector: currentSnapshot.vectorCount,\n },\n runLexical: currentSnapshot.lexicalCount > 0,\n runVector: currentSnapshot.vectorCount > 0,\n sourceBalanceStrategy: currentSnapshot.sourceBalanceStrategy ?? \"cap\",\n steps: [],\n topK: caseResult.topK,\n transformedQuery:\n currentSnapshot.transformedQuery ?? caseResult.query,\n variantQueries: currentSnapshot.variantQueries,\n } satisfies RAGRetrievalTrace;\n })(),\n previousTrace: previousTraces.get(caseResult.caseId),\n }),\n );\n};\n\nconst getStatusRank = (status: RAGEvaluationCaseResult[\"status\"]) =>\n status === \"pass\" ? 2 : status === \"partial\" ? 1 : 0;\n\nconst buildCaseTraceLeadLabel = (\n trace?: Pick<\n RAGEvaluationCaseTraceSnapshot,\n | \"topLocatorLabel\"\n | \"topContextLabel\"\n | \"sourceAwareUnitScopeLabel\"\n | \"sourceAwareChunkReasonLabel\"\n >,\n) =>\n trace?.topLocatorLabel ??\n trace?.topContextLabel ??\n trace?.sourceAwareUnitScopeLabel ??\n trace?.sourceAwareChunkReasonLabel;\n\nexport const buildRAGEvaluationRunDiff = ({\n current,\n previous,\n}: {\n current: RAGEvaluationSuiteRun;\n previous?: RAGEvaluationSuiteRun;\n}): RAGEvaluationRunDiff => {\n const previousCases = new Map(\n (previous?.response.cases ?? []).map((entry) => [entry.caseId, entry]),\n );\n const diffs = current.response.cases.map((entry) =>\n buildCaseDiff(entry, previousCases.get(entry.caseId)),\n );\n const regressedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) <\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n const improvedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) >\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n const unchangedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) ===\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n const previousCaseTraces = new Map(\n (previous?.caseTraceSnapshots ?? []).map((entry) => [entry.caseId, entry]),\n );\n const traceLeadChanges = (current.caseTraceSnapshots ?? [])\n .map((entry) => {\n const previousEntry = previousCaseTraces.get(entry.caseId);\n const currentLead = buildCaseTraceLeadLabel(entry);\n const previousLead = buildCaseTraceLeadLabel(previousEntry);\n if (!currentLead || currentLead === previousLead) {\n return undefined;\n }\n\n return {\n caseId: entry.caseId,\n currentLead,\n label: entry.label,\n previousLead,\n };\n })\n .filter(\n (entry): entry is NonNullable<typeof entry> =>\n typeof entry !== \"undefined\",\n );\n\n return {\n currentRunId: current.id,\n improvedCases,\n previousRunId: previous?.id,\n regressedCases,\n suiteId: current.suiteId,\n traceLeadChanges:\n traceLeadChanges.length > 0 ? traceLeadChanges : undefined,\n summaryDelta: {\n averageF1:\n current.response.summary.averageF1 -\n (previous?.response.summary.averageF1 ?? 0),\n averageLatencyMs:\n current.response.summary.averageLatencyMs -\n (previous?.response.summary.averageLatencyMs ?? 0),\n failedCases:\n current.response.summary.failedCases -\n (previous?.response.summary.failedCases ?? 0),\n passedCases:\n current.response.summary.passedCases -\n (previous?.response.summary.passedCases ?? 0),\n passingRate:\n current.response.passingRate - (previous?.response.passingRate ?? 0),\n partialCases:\n current.response.summary.partialCases -\n (previous?.response.summary.partialCases ?? 0),\n },\n traceSummaryDelta:\n current.traceSummary || previous?.traceSummary\n ? {\n averageCandidateTopK:\n (current.traceSummary?.averageCandidateTopK ?? 0) -\n (previous?.traceSummary?.averageCandidateTopK ?? 0),\n averageFinalCount:\n (current.traceSummary?.averageFinalCount ?? 0) -\n (previous?.traceSummary?.averageFinalCount ?? 0),\n averageLexicalCount:\n (current.traceSummary?.averageLexicalCount ?? 0) -\n (previous?.traceSummary?.averageLexicalCount ?? 0),\n averageLexicalTopK:\n (current.traceSummary?.averageLexicalTopK ?? 0) -\n (previous?.traceSummary?.averageLexicalTopK ?? 0),\n averageVectorCount:\n (current.traceSummary?.averageVectorCount ?? 0) -\n (previous?.traceSummary?.averageVectorCount ?? 0),\n balancedCases:\n (current.traceSummary?.balancedCases ?? 0) -\n (previous?.traceSummary?.balancedCases ?? 0),\n officeEvidenceReconcileCasesDelta:\n (current.traceSummary?.officeEvidenceReconcileCases ?? 0) -\n (previous?.traceSummary?.officeEvidenceReconcileCases ?? 0),\n officeParagraphEvidenceReconcileCasesDelta:\n (current.traceSummary?.officeParagraphEvidenceReconcileCases ??\n 0) -\n (previous?.traceSummary?.officeParagraphEvidenceReconcileCases ??\n 0),\n officeListEvidenceReconcileCasesDelta:\n (current.traceSummary?.officeListEvidenceReconcileCases ?? 0) -\n (previous?.traceSummary?.officeListEvidenceReconcileCases ?? 0),\n officeTableEvidenceReconcileCasesDelta:\n (current.traceSummary?.officeTableEvidenceReconcileCases ?? 0) -\n (previous?.traceSummary?.officeTableEvidenceReconcileCases ?? 0),\n pdfEvidenceReconcileCasesDelta:\n (current.traceSummary?.pdfEvidenceReconcileCases ?? 0) -\n (previous?.traceSummary?.pdfEvidenceReconcileCases ?? 0),\n lexicalCases:\n (current.traceSummary?.lexicalCases ?? 0) -\n (previous?.traceSummary?.lexicalCases ?? 0),\n modesChanged:\n (current.traceSummary?.modes ?? []).join(\"|\") !==\n (previous?.traceSummary?.modes ?? []).join(\"|\"),\n roundRobinCases:\n (current.traceSummary?.roundRobinCases ?? 0) -\n (previous?.traceSummary?.roundRobinCases ?? 0),\n stageCounts: diffTraceStageCounts({\n current: current.traceSummary?.stageCounts ?? {},\n previous: previous?.traceSummary?.stageCounts ?? {},\n }),\n sourceBalanceStrategiesChanged:\n (current.traceSummary?.sourceBalanceStrategies ?? []).join(\n \"|\",\n ) !==\n (previous?.traceSummary?.sourceBalanceStrategies ?? []).join(\"|\"),\n transformedCases:\n (current.traceSummary?.transformedCases ?? 0) -\n (previous?.traceSummary?.transformedCases ?? 0),\n variantCases:\n (current.traceSummary?.variantCases ?? 0) -\n (previous?.traceSummary?.variantCases ?? 0),\n vectorCases:\n (current.traceSummary?.vectorCases ?? 0) -\n (previous?.traceSummary?.vectorCases ?? 0),\n }\n : undefined,\n unchangedCases,\n };\n};\n\nexport const buildRAGAnswerGroundingEvaluationRunDiff = ({\n current,\n previous,\n}: {\n current: RAGAnswerGroundingEvaluationRun;\n previous?: RAGAnswerGroundingEvaluationRun;\n}): RAGAnswerGroundingEvaluationRunDiff => {\n const previousCases = new Map(\n (previous?.response.cases ?? []).map((entry) => [entry.caseId, entry]),\n );\n const diffs = current.response.cases.map((entry) =>\n buildGroundingCaseDiff(entry, previousCases.get(entry.caseId)),\n );\n const regressedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) <\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n const improvedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) >\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n const unchangedCases = diffs.filter(\n (entry) =>\n getStatusRank(entry.currentStatus) ===\n getStatusRank(entry.previousStatus ?? \"fail\"),\n );\n\n return {\n currentRunId: current.id,\n improvedCases,\n previousRunId: previous?.id,\n regressedCases,\n suiteId: current.suiteId,\n summaryDelta: {\n averageCitationF1:\n current.response.summary.averageCitationF1 -\n (previous?.response.summary.averageCitationF1 ?? 0),\n averageResolvedCitationRate:\n current.response.summary.averageResolvedCitationRate -\n (previous?.response.summary.averageResolvedCitationRate ?? 0),\n failedCases:\n current.response.summary.failedCases -\n (previous?.response.summary.failedCases ?? 0),\n passedCases:\n current.response.summary.passedCases -\n (previous?.response.summary.passedCases ?? 0),\n passingRate:\n current.response.passingRate - (previous?.response.passingRate ?? 0),\n partialCases:\n current.response.summary.partialCases -\n (previous?.response.summary.partialCases ?? 0),\n },\n unchangedCases,\n };\n};\n\nexport const createRAGFileEvaluationHistoryStore = (\n path: string,\n): RAGEvaluationHistoryStore => ({\n listRuns: async ({ limit, suiteId } = {}) => {\n let parsed: RAGEvaluationSuiteRun[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) => !suiteId || entry.suiteId === suiteId,\n );\n const sorted = normalizeHistoryRuns(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveRun: async (run) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeHistoryRuns([\n run,\n ...existing.filter((entry: RAGEvaluationSuiteRun) => entry.id !== run.id),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n pruneRuns: async (input) => {\n let existing: RAGEvaluationSuiteRun[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n existing = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs: existing,\n sort: normalizeHistoryRuns,\n });\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(pruned.next, null, \"\\t\") + \"\\n\",\n \"utf8\",\n );\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n});\n\nconst normalizeEvaluationSuiteSnapshots = (\n snapshots: RAGEvaluationSuiteSnapshot[],\n) =>\n [...snapshots].sort((left, right) => {\n if (right.createdAt !== left.createdAt) {\n return right.createdAt - left.createdAt;\n }\n if (right.version !== left.version) {\n return right.version - left.version;\n }\n return right.id.localeCompare(left.id);\n });\n\nexport const createRAGFileEvaluationSuiteSnapshotHistoryStore = (\n path: string,\n): RAGEvaluationSuiteSnapshotHistoryStore => ({\n listSnapshots: async ({ limit, suiteId } = {}) => {\n let parsed: RAGEvaluationSuiteSnapshot[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) => !suiteId || entry.suiteId === suiteId,\n );\n const sorted = normalizeEvaluationSuiteSnapshots(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveSnapshot: async (snapshot) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeEvaluationSuiteSnapshots([\n snapshot,\n ...existing.filter(\n (entry: RAGEvaluationSuiteSnapshot) => entry.id !== snapshot.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n pruneSnapshots: async (input) => {\n let existing: RAGEvaluationSuiteSnapshot[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n existing = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs: existing,\n sort: normalizeEvaluationSuiteSnapshots,\n });\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(pruned.next, null, \"\\t\") + \"\\n\",\n \"utf8\",\n );\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n});\n\nexport const createRAGFileRetrievalComparisonHistoryStore = (\n path: string,\n): RAGRetrievalComparisonHistoryStore => ({\n listRuns: async ({ groupKey, label, limit, suiteId, tag, winnerId } = {}) => {\n let parsed: RAGRetrievalComparisonRun[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const normalizedLabel = normalizeLabelFilter(label);\n const filtered = parsed.filter(\n (entry) =>\n (!suiteId || entry.suiteId === suiteId) &&\n (!groupKey || entry.groupKey === groupKey) &&\n (!tag || (entry.tags ?? []).includes(tag)) &&\n (!normalizedLabel ||\n entry.label.toLowerCase().includes(normalizedLabel) ||\n entry.suiteLabel.toLowerCase().includes(normalizedLabel)) &&\n matchesWinner(entry, winnerId),\n );\n const sorted = normalizeRetrievalComparisonRuns(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveRun: async (run) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalComparisonRuns([\n run,\n ...existing.filter(\n (entry: RAGRetrievalComparisonRun) => entry.id !== run.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalBaselineStore = (\n path: string,\n): RAGRetrievalBaselineStore => {\n const listBaselines: RAGRetrievalBaselineStore[\"listBaselines\"] = async ({\n groupKey,\n limit,\n tag,\n status,\n } = {}) => {\n let parsed: RAGRetrievalBaselineRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!tag || (entry.tags ?? []).includes(tag)) &&\n (!status || entry.status === status),\n );\n const sorted = normalizeRetrievalBaselineRecords(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n };\n\n return {\n getBaseline: async (groupKey) => {\n const baselines = await Promise.resolve(\n listBaselines({ groupKey, limit: 1 }),\n );\n return baselines[0] ?? null;\n },\n listBaselines,\n saveBaseline: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const currentVersion =\n existing\n .filter(\n (entry: RAGRetrievalBaselineRecord) =>\n entry.groupKey === record.groupKey,\n )\n .reduce((max, entry) => Math.max(max, entry.version ?? 0), 0) ?? 0;\n const next = normalizeRetrievalBaselineRecords([\n {\n ...record,\n status: \"active\",\n version:\n typeof record.version === \"number\"\n ? record.version\n : currentVersion + 1,\n },\n ...existing.map((entry: RAGRetrievalBaselineRecord) =>\n entry.groupKey === record.groupKey &&\n (entry.rolloutLabel ?? undefined) ===\n (record.rolloutLabel ?? undefined)\n ? { ...entry, status: \"superseded\" as const }\n : entry,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n };\n};\n\nexport const createRAGFileRetrievalReleaseDecisionStore = (\n path: string,\n): RAGRetrievalReleaseDecisionStore => ({\n listDecisions: async ({ groupKey, kind, limit } = {}) => {\n let parsed: RAGRetrievalReleaseDecisionRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!kind || entry.kind === kind),\n );\n const sorted = normalizeRetrievalReleaseDecisionRecords(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveDecision: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalReleaseDecisionRecords([\n record,\n ...existing.filter(\n (entry: RAGRetrievalReleaseDecisionRecord) => entry.id !== record.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalLaneHandoffDecisionStore = (\n path: string,\n): RAGRetrievalLaneHandoffDecisionStore => ({\n listDecisions: async ({\n groupKey,\n kind,\n limit,\n sourceRolloutLabel,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalLaneHandoffDecisionRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!kind || entry.kind === kind) &&\n (!sourceRolloutLabel ||\n entry.sourceRolloutLabel === sourceRolloutLabel) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n );\n const sorted = normalizeRetrievalLaneHandoffDecisionRecords(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveDecision: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalLaneHandoffDecisionRecords([\n record,\n ...existing.filter(\n (entry: RAGRetrievalLaneHandoffDecisionRecord) =>\n entry.id !== record.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalReleaseIncidentStore = (\n path: string,\n): RAGRetrievalReleaseIncidentStore => ({\n listIncidents: async ({\n corpusGroupKey,\n groupKey,\n limit,\n severity,\n status,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalReleaseIncidentRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) =>\n (!corpusGroupKey || entry.corpusGroupKey === corpusGroupKey) &&\n (!groupKey || entry.groupKey === groupKey) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel) &&\n (!severity || entry.severity === severity) &&\n (!status || entry.status === status),\n );\n const sorted = normalizeRetrievalReleaseIncidentRecords(filtered);\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveIncident: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalReleaseIncidentRecords([\n record,\n ...existing.filter(\n (entry: RAGRetrievalReleaseIncidentRecord) => entry.id !== record.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalLaneHandoffIncidentStore = (\n path: string,\n): RAGRetrievalLaneHandoffIncidentStore => ({\n listIncidents: async ({\n groupKey,\n limit,\n severity,\n status,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalLaneHandoffIncidentRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel) &&\n (!severity || entry.severity === severity) &&\n (!status || entry.status === status),\n );\n const sorted = normalizeRetrievalReleaseIncidentRecords(\n filtered as RAGRetrievalReleaseIncidentRecord[],\n ) as RAGRetrievalLaneHandoffIncidentRecord[];\n return typeof limit === \"number\" ? sorted.slice(0, limit) : sorted;\n },\n saveIncident: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalReleaseIncidentRecords([\n record as RAGRetrievalReleaseIncidentRecord,\n ...existing.filter(\n (entry: RAGRetrievalLaneHandoffIncidentRecord) =>\n entry.id !== record.id,\n ),\n ]) as RAGRetrievalLaneHandoffIncidentRecord[];\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalLaneHandoffIncidentHistoryStore = (\n path: string,\n): RAGRetrievalLaneHandoffIncidentHistoryStore => ({\n listRecords: async ({\n action,\n groupKey,\n incidentId,\n limit,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalLaneHandoffIncidentHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed\n .filter(\n (entry) =>\n (!action || entry.action === action) &&\n (!groupKey || entry.groupKey === groupKey) &&\n (!incidentId || entry.incidentId === incidentId) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n )\n .sort((left, right) => right.recordedAt - left.recordedAt);\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = [record, ...existing].sort(\n (\n left: RAGRetrievalLaneHandoffIncidentHistoryRecord,\n right: RAGRetrievalLaneHandoffIncidentHistoryRecord,\n ) => right.recordedAt - left.recordedAt,\n );\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalIncidentRemediationDecisionStore = (\n path: string,\n): RAGRetrievalIncidentRemediationDecisionStore => ({\n listRecords: async ({\n groupKey,\n incidentId,\n limit,\n remediationKind,\n status,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalIncidentRemediationDecisionRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered = normalizeRetrievalIncidentRemediationDecisionRecords(\n parsed,\n ).filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!incidentId || entry.incidentId === incidentId) &&\n (!remediationKind || entry.remediationKind === remediationKind) &&\n (!status || entry.status === status) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n );\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalIncidentRemediationDecisionRecords([\n record,\n ...existing,\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalIncidentRemediationExecutionHistoryStore = (\n path: string,\n): RAGRetrievalIncidentRemediationExecutionHistoryStore => ({\n listRecords: async ({\n actionKind,\n blockedByGuardrail,\n code,\n groupKey,\n idempotentReplay,\n incidentId,\n limit,\n targetRolloutLabel,\n } = {}) => {\n let parsed: RAGRetrievalIncidentRemediationExecutionHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered =\n normalizeRetrievalIncidentRemediationExecutionHistoryRecords(\n parsed,\n ).filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!incidentId || entry.incidentId === incidentId) &&\n (!actionKind || entry.action.kind === actionKind) &&\n (!code || entry.code === code) &&\n (typeof blockedByGuardrail !== \"boolean\" ||\n entry.blockedByGuardrail === blockedByGuardrail) &&\n (typeof idempotentReplay !== \"boolean\" ||\n entry.idempotentReplay === idempotentReplay) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n );\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeRetrievalIncidentRemediationExecutionHistoryRecords([\n record,\n ...existing,\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalLaneHandoffAutoCompletePolicyHistoryStore = (\n path: string,\n): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore => ({\n listRecords: async ({ groupKey, limit, targetRolloutLabel } = {}) => {\n let parsed: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered = parsed\n .filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n )\n .sort((left, right) => right.recordedAt - left.recordedAt);\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = [record, ...existing].sort(\n (\n left: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord,\n right: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord,\n ) => right.recordedAt - left.recordedAt,\n );\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalReleaseLanePolicyHistoryStore = (\n path: string,\n): RAGRetrievalReleaseLanePolicyHistoryStore => ({\n listRecords: async ({ groupKey, limit, rolloutLabel, scope } = {}) => {\n let parsed: RAGRetrievalReleaseLanePolicyHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered = parsed\n .filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!rolloutLabel || entry.rolloutLabel === rolloutLabel) &&\n (!scope || entry.scope === scope),\n )\n .sort((left, right) => right.recordedAt - left.recordedAt);\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = [record, ...existing].sort(\n (\n left: RAGRetrievalReleaseLanePolicyHistoryRecord,\n right: RAGRetrievalReleaseLanePolicyHistoryRecord,\n ) => right.recordedAt - left.recordedAt,\n );\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalBaselineGatePolicyHistoryStore = (\n path: string,\n): RAGRetrievalBaselineGatePolicyHistoryStore => ({\n listRecords: async ({ groupKey, limit, rolloutLabel, scope } = {}) => {\n let parsed: RAGRetrievalBaselineGatePolicyHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered = parsed\n .filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!rolloutLabel || entry.rolloutLabel === rolloutLabel) &&\n (!scope || entry.scope === scope),\n )\n .sort((left, right) => right.recordedAt - left.recordedAt);\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = [record, ...existing].sort(\n (\n left: RAGRetrievalBaselineGatePolicyHistoryRecord,\n right: RAGRetrievalBaselineGatePolicyHistoryRecord,\n ) => right.recordedAt - left.recordedAt,\n );\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileRetrievalReleaseLaneEscalationPolicyHistoryStore = (\n path: string,\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryStore => ({\n listRecords: async ({ groupKey, limit, targetRolloutLabel } = {}) => {\n let parsed: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n const filtered = parsed\n .filter(\n (entry) =>\n (!groupKey || entry.groupKey === groupKey) &&\n (!targetRolloutLabel ||\n entry.targetRolloutLabel === targetRolloutLabel),\n )\n .sort((left, right) => right.recordedAt - left.recordedAt);\n return typeof limit === \"number\" ? filtered.slice(0, limit) : filtered;\n },\n saveRecord: async (record) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = [record, ...existing].sort(\n (\n left: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord,\n right: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord,\n ) => right.recordedAt - left.recordedAt,\n );\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport const createRAGFileSearchTraceStore = (\n path: string,\n): RAGSearchTraceStore => ({\n async listTraces(input) {\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n traces?: RAGSearchTraceRecord[];\n };\n const traces = Array.isArray(data.traces) ? data.traces : [];\n const filtered = traces.filter((trace) => {\n if (input?.query && trace.query !== input.query) {\n return false;\n }\n if (input?.groupKey && trace.groupKey !== input.groupKey) {\n return false;\n }\n if (input?.tag && !(trace.tags ?? []).includes(input.tag)) {\n return false;\n }\n return true;\n });\n\n return normalizeTraceSummaryRuns(filtered).slice(\n 0,\n input?.limit ?? DEFAULT_HISTORY_LIMIT,\n );\n } catch (error) {\n if (\n error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n error.code === \"ENOENT\"\n ) {\n return [];\n }\n\n throw error;\n }\n },\n async saveTrace(trace) {\n let traces: RAGSearchTraceRecord[] = [];\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n traces?: RAGSearchTraceRecord[];\n };\n traces = Array.isArray(data.traces) ? data.traces : [];\n } catch (error) {\n if (\n !error ||\n typeof error !== \"object\" ||\n !(\"code\" in error) ||\n error.code !== \"ENOENT\"\n ) {\n throw error;\n }\n }\n\n const nextTraces = normalizeTraceSummaryRuns([\n trace,\n ...traces.filter((entry) => entry.id !== trace.id),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(\n {\n traces: nextTraces,\n },\n null,\n 2,\n ),\n );\n },\n async pruneTraces(input) {\n let traces: RAGSearchTraceRecord[] = [];\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n traces?: RAGSearchTraceRecord[];\n };\n traces = Array.isArray(data.traces) ? data.traces : [];\n } catch (error) {\n if (\n !error ||\n typeof error !== \"object\" ||\n !(\"code\" in error) ||\n error.code !== \"ENOENT\"\n ) {\n throw error;\n }\n }\n\n const pruned = applyRAGSearchTracePrunePolicy({\n input,\n traces,\n });\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(\n {\n traces: pruned.next,\n },\n null,\n 2,\n ),\n );\n\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n };\n },\n});\n\nexport const createRAGFileSearchTracePruneHistoryStore = (\n path: string,\n): RAGSearchTracePruneHistoryStore => ({\n listRuns: async (input) => {\n let parsed: RAGSearchTracePruneRun[] = [];\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n parsed = Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n }\n\n const filtered = parsed.filter(\n (entry) => !input?.trigger || entry.trigger === input.trigger,\n );\n const sorted = normalizeSearchTracePruneRuns(filtered);\n return typeof input?.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveRun: async (run) => {\n const existing = await (async () => {\n try {\n const content = await readFile(path, \"utf8\");\n const value = JSON.parse(content);\n return Array.isArray(value) ? value : [];\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code !== \"ENOENT\") {\n throw error;\n }\n return [];\n }\n })();\n const next = normalizeSearchTracePruneRuns([\n run,\n ...existing.filter(\n (entry: RAGSearchTracePruneRun) => entry.id !== run.id,\n ),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(path, JSON.stringify(next, null, \"\\t\") + \"\\n\", \"utf8\");\n },\n});\n\nexport type SQLiteRAGSearchTraceStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGEvaluationHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGEvaluationSuiteSnapshotHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGAnswerGroundingEvaluationHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGSearchTracePruneHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalComparisonHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseDecisionStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalBaselineStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseIncidentStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffDecisionStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffIncidentStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalLaneHandoffIncidentHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalIncidentRemediationDecisionStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalIncidentRemediationExecutionHistoryStoreOptions =\n {\n db?: Database;\n path?: string;\n tableName?: string;\n };\n\nexport type SQLiteRAGRetrievalLaneHandoffAutoCompletePolicyHistoryStoreOptions =\n {\n db?: Database;\n path?: string;\n tableName?: string;\n };\n\nexport type SQLiteRAGRetrievalReleaseLanePolicyHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalBaselineGatePolicyHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGRetrievalReleaseLaneEscalationPolicyHistoryStoreOptions = {\n db?: Database;\n path?: string;\n tableName?: string;\n};\n\nexport type SQLiteRAGGovernanceStoreBundleOptions = {\n db?: Database;\n path?: string;\n tablePrefix?: string;\n};\n\nexport const createRAGSQLiteEvaluationHistoryStore = (\n options: SQLiteRAGEvaluationHistoryStoreOptions,\n): RAGEvaluationHistoryStore => {\n const tableName = options.tableName ?? \"rag_evaluation_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`,\n );\n\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tfinished_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRuns(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n if (input.suiteId) {\n where.push(\"suite_id = ?\");\n params.push(input.suiteId);\n }\n const sql =\n `SELECT record_json FROM ${tableName}` +\n `${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY finished_at DESC\";\n const rows = db.prepare(sql).all(...params) as Array<{\n record_json: string;\n }>;\n const runs = normalizeHistoryRuns(\n rows.map((row) => JSON.parse(row.record_json) as RAGEvaluationSuiteRun),\n );\n\n return typeof input.limit === \"number\"\n ? runs.slice(0, input.limit)\n : runs;\n },\n saveRun(run) {\n insert.run(run.id, run.suiteId, run.finishedAt, JSON.stringify(run));\n },\n pruneRuns(input) {\n const allRows = db\n .prepare(`SELECT record_json FROM ${tableName}`)\n .all() as Array<{\n record_json: string;\n }>;\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs: allRows.map(\n (row) => JSON.parse(row.record_json) as RAGEvaluationSuiteRun,\n ),\n sort: normalizeHistoryRuns,\n });\n for (const run of pruned.removed) {\n db.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(run.id);\n }\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n };\n};\n\nexport const createRAGSQLiteEvaluationSuiteSnapshotHistoryStore = (\n options: SQLiteRAGEvaluationSuiteSnapshotHistoryStoreOptions,\n): RAGEvaluationSuiteSnapshotHistoryStore => {\n const tableName =\n options.tableName ?? \"rag_evaluation_suite_snapshot_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tversion INTEGER NOT NULL,\n\t\t\tcreated_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_suite_created_at_idx ON ${tableName} (suite_id, created_at DESC, version DESC)`,\n );\n\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tversion,\n\t\t\tcreated_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tversion = excluded.version,\n\t\t\tcreated_at = excluded.created_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listSnapshots(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n if (input.suiteId) {\n where.push(\"suite_id = ?\");\n params.push(input.suiteId);\n }\n const sql =\n `SELECT record_json FROM ${tableName}` +\n `${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY created_at DESC, version DESC\";\n const rows = db.prepare(sql).all(...params) as Array<{\n record_json: string;\n }>;\n const snapshots = normalizeEvaluationSuiteSnapshots(\n rows.map(\n (row) => JSON.parse(row.record_json) as RAGEvaluationSuiteSnapshot,\n ),\n );\n\n return typeof input.limit === \"number\"\n ? snapshots.slice(0, input.limit)\n : snapshots;\n },\n saveSnapshot(snapshot) {\n insert.run(\n snapshot.id,\n snapshot.suiteId,\n snapshot.version,\n snapshot.createdAt,\n JSON.stringify(snapshot),\n );\n },\n pruneSnapshots(input) {\n const allRows = db\n .prepare(`SELECT record_json FROM ${tableName}`)\n .all() as Array<{\n record_json: string;\n }>;\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs: allRows.map(\n (row) => JSON.parse(row.record_json) as RAGEvaluationSuiteSnapshot,\n ),\n sort: normalizeEvaluationSuiteSnapshots,\n });\n for (const snapshot of pruned.removed) {\n db.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(snapshot.id);\n }\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n };\n};\n\nexport const createRAGSQLiteAnswerGroundingEvaluationHistoryStore = (\n options: SQLiteRAGAnswerGroundingEvaluationHistoryStoreOptions,\n): RAGAnswerGroundingEvaluationHistoryStore => {\n const tableName = options.tableName ?? \"rag_answer_grounding_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`,\n );\n\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tfinished_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRuns(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n if (input.suiteId) {\n where.push(\"suite_id = ?\");\n params.push(input.suiteId);\n }\n const sql =\n `SELECT record_json FROM ${tableName}` +\n `${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY finished_at DESC\";\n const rows = db.prepare(sql).all(...params) as Array<{\n record_json: string;\n }>;\n const runs = normalizeGroundingHistoryRuns(\n rows.map(\n (row) =>\n JSON.parse(row.record_json) as RAGAnswerGroundingEvaluationRun,\n ),\n );\n\n return typeof input.limit === \"number\"\n ? runs.slice(0, input.limit)\n : runs;\n },\n saveRun(run) {\n insert.run(run.id, run.suiteId, run.finishedAt, JSON.stringify(run));\n },\n pruneRuns(input) {\n const allRows = db\n .prepare(`SELECT record_json FROM ${tableName}`)\n .all() as Array<{\n record_json: string;\n }>;\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs: allRows.map(\n (row) =>\n JSON.parse(row.record_json) as RAGAnswerGroundingEvaluationRun,\n ),\n sort: normalizeGroundingHistoryRuns,\n });\n for (const run of pruned.removed) {\n db.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(run.id);\n }\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n };\n};\n\ntype SQLiteSearchTraceRow = {\n id: string;\n query: string;\n label: string;\n group_key: string | null;\n tags_json: string | null;\n started_at: number;\n finished_at: number;\n elapsed_ms: number;\n trace_json: string;\n summary_json: string;\n results_json: string;\n metadata_json: string | null;\n};\n\ntype SQLiteSearchTracePruneHistoryRow = {\n id: string;\n trigger: string;\n started_at: number;\n finished_at: number;\n elapsed_ms: number;\n run_json: string;\n};\n\nconst isSQLiteSearchTraceRow = (\n value: unknown,\n): value is SQLiteSearchTraceRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.query === \"string\" &&\n typeof value.label === \"string\" &&\n (typeof value.group_key === \"string\" || value.group_key === null) &&\n (typeof value.tags_json === \"string\" || value.tags_json === null) &&\n typeof value.started_at === \"number\" &&\n typeof value.finished_at === \"number\" &&\n typeof value.elapsed_ms === \"number\" &&\n typeof value.trace_json === \"string\" &&\n typeof value.summary_json === \"string\" &&\n typeof value.results_json === \"string\" &&\n (typeof value.metadata_json === \"string\" || value.metadata_json === null);\n\nconst isSQLiteSearchTracePruneHistoryRow = (\n value: unknown,\n): value is SQLiteSearchTracePruneHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.trigger === \"string\" &&\n typeof value.started_at === \"number\" &&\n typeof value.finished_at === \"number\" &&\n typeof value.elapsed_ms === \"number\" &&\n typeof value.run_json === \"string\";\n\ntype SQLiteRetrievalComparisonHistoryRow = {\n id: string;\n suite_id: string;\n suite_label: string;\n label: string;\n corpus_group_key: string | null;\n group_key: string | null;\n tags_json: string | null;\n started_at: number;\n finished_at: number;\n elapsed_ms: number;\n comparison_json: string;\n decision_summary_json: string | null;\n};\n\nconst isSQLiteRetrievalComparisonHistoryRow = (\n value: unknown,\n): value is SQLiteRetrievalComparisonHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.suite_id === \"string\" &&\n typeof value.suite_label === \"string\" &&\n typeof value.label === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n (typeof value.group_key === \"string\" || value.group_key === null) &&\n (typeof value.tags_json === \"string\" || value.tags_json === null) &&\n typeof value.started_at === \"number\" &&\n typeof value.finished_at === \"number\" &&\n typeof value.elapsed_ms === \"number\" &&\n typeof value.comparison_json === \"string\" &&\n (typeof value.decision_summary_json === \"string\" ||\n value.decision_summary_json === null);\n\ntype SQLiteRetrievalReleaseDecisionRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n kind: string;\n decided_at: number;\n record_json: string;\n};\n\nconst isSQLiteRetrievalReleaseDecisionRow = (\n value: unknown,\n): value is SQLiteRetrievalReleaseDecisionRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n typeof value.kind === \"string\" &&\n typeof value.decided_at === \"number\" &&\n typeof value.record_json === \"string\";\n\ntype SQLiteRetrievalBaselineRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n rollout_label: string | null;\n promoted_at: number;\n status: string;\n version: number;\n tags_json: string | null;\n record_json: string;\n};\n\nconst isSQLiteRetrievalBaselineRow = (\n value: unknown,\n): value is SQLiteRetrievalBaselineRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n (typeof value.rollout_label === \"string\" || value.rollout_label === null) &&\n typeof value.promoted_at === \"number\" &&\n typeof value.status === \"string\" &&\n typeof value.version === \"number\" &&\n (typeof value.tags_json === \"string\" || value.tags_json === null) &&\n typeof value.record_json === \"string\";\n\ntype SQLiteRetrievalReleaseIncidentRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n target_rollout_label: string | null;\n severity: string;\n status: string;\n triggered_at: number;\n record_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffDecisionRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n source_rollout_label: string;\n target_rollout_label: string;\n kind: string;\n decided_at: number;\n record_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffIncidentRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n target_rollout_label: string | null;\n source_rollout_label: string | null;\n severity: string;\n status: string;\n triggered_at: number;\n record_json: string;\n};\n\ntype SQLiteRetrievalLaneHandoffIncidentHistoryRow = {\n id: string;\n incident_id: string;\n corpus_group_key: string | null;\n group_key: string;\n target_rollout_label: string | null;\n action: string;\n recorded_at: number;\n record_json: string;\n};\n\ntype SQLiteRetrievalIncidentRemediationDecisionRow = {\n id: string;\n incident_id: string;\n group_key: string;\n target_rollout_label: string | null;\n remediation_kind: string;\n status: string;\n decided_at: number;\n record_json: string;\n};\n\ntype SQLiteRetrievalIncidentRemediationExecutionHistoryRow = {\n id: string;\n incident_id: string | null;\n group_key: string | null;\n target_rollout_label: string | null;\n action_kind: string;\n code: string;\n blocked_by_guardrail: number;\n idempotent_replay: number;\n executed_at: number;\n record_json: string;\n};\n\ntype SQLiteLaneHandoffAutoCompletePolicyHistoryRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n target_rollout_label: string;\n recorded_at: number;\n record_json: string;\n};\n\ntype SQLiteReleaseLanePolicyHistoryRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string | null;\n rollout_label: string;\n scope: string;\n recorded_at: number;\n record_json: string;\n};\n\ntype SQLiteBaselineGatePolicyHistoryRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string | null;\n rollout_label: string;\n scope: string;\n recorded_at: number;\n record_json: string;\n};\n\ntype SQLiteReleaseLaneEscalationPolicyHistoryRow = {\n id: string;\n corpus_group_key: string | null;\n group_key: string;\n target_rollout_label: string;\n recorded_at: number;\n record_json: string;\n};\n\nconst isSQLiteRetrievalReleaseIncidentRow = (\n value: unknown,\n): value is SQLiteRetrievalReleaseIncidentRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n (typeof value.target_rollout_label === \"string\" ||\n value.target_rollout_label === null) &&\n typeof value.severity === \"string\" &&\n typeof value.status === \"string\" &&\n typeof value.triggered_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteRetrievalLaneHandoffDecisionRow = (\n value: unknown,\n): value is SQLiteRetrievalLaneHandoffDecisionRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n typeof value.source_rollout_label === \"string\" &&\n typeof value.target_rollout_label === \"string\" &&\n typeof value.kind === \"string\" &&\n typeof value.decided_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteRetrievalLaneHandoffIncidentRow = (\n value: unknown,\n): value is SQLiteRetrievalLaneHandoffIncidentRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n (typeof value.target_rollout_label === \"string\" ||\n value.target_rollout_label === null) &&\n (typeof value.source_rollout_label === \"string\" ||\n value.source_rollout_label === null) &&\n typeof value.severity === \"string\" &&\n typeof value.status === \"string\" &&\n typeof value.triggered_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteRetrievalLaneHandoffIncidentHistoryRow = (\n value: unknown,\n): value is SQLiteRetrievalLaneHandoffIncidentHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.incident_id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n (typeof value.target_rollout_label === \"string\" ||\n value.target_rollout_label === null) &&\n typeof value.action === \"string\" &&\n typeof value.recorded_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteRetrievalIncidentRemediationDecisionRow = (\n value: unknown,\n): value is SQLiteRetrievalIncidentRemediationDecisionRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.incident_id === \"string\" &&\n typeof value.group_key === \"string\" &&\n (typeof value.target_rollout_label === \"string\" ||\n value.target_rollout_label === null) &&\n typeof value.remediation_kind === \"string\" &&\n typeof value.status === \"string\" &&\n typeof value.decided_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteRetrievalIncidentRemediationExecutionHistoryRow = (\n value: unknown,\n): value is SQLiteRetrievalIncidentRemediationExecutionHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.incident_id === \"string\" || value.incident_id === null) &&\n (typeof value.group_key === \"string\" || value.group_key === null) &&\n (typeof value.target_rollout_label === \"string\" ||\n value.target_rollout_label === null) &&\n typeof value.action_kind === \"string\" &&\n typeof value.code === \"string\" &&\n typeof value.blocked_by_guardrail === \"number\" &&\n typeof value.idempotent_replay === \"number\" &&\n typeof value.executed_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteLaneHandoffAutoCompletePolicyHistoryRow = (\n value: unknown,\n): value is SQLiteLaneHandoffAutoCompletePolicyHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n typeof value.target_rollout_label === \"string\" &&\n typeof value.recorded_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteReleaseLanePolicyHistoryRow = (\n value: unknown,\n): value is SQLiteReleaseLanePolicyHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n (typeof value.group_key === \"string\" || value.group_key === null) &&\n typeof value.rollout_label === \"string\" &&\n typeof value.scope === \"string\" &&\n typeof value.recorded_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteBaselineGatePolicyHistoryRow = (\n value: unknown,\n): value is SQLiteBaselineGatePolicyHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n (typeof value.group_key === \"string\" || value.group_key === null) &&\n typeof value.rollout_label === \"string\" &&\n typeof value.scope === \"string\" &&\n typeof value.recorded_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst isSQLiteReleaseLaneEscalationPolicyHistoryRow = (\n value: unknown,\n): value is SQLiteReleaseLaneEscalationPolicyHistoryRow =>\n isObjectRecord(value) &&\n typeof value.id === \"string\" &&\n (typeof value.corpus_group_key === \"string\" ||\n value.corpus_group_key === null) &&\n typeof value.group_key === \"string\" &&\n typeof value.target_rollout_label === \"string\" &&\n typeof value.recorded_at === \"number\" &&\n typeof value.record_json === \"string\";\n\nconst assertSupportedIdentifier = (name: string) => {\n if (!/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(name)) {\n throw new Error(\n `Invalid SQLite search trace table name \"${name}\". Only alphanumeric and underscore names are allowed.`,\n );\n }\n};\n\nconst ensureSQLiteColumns = (\n db: Database,\n tableName: string,\n columns: Array<{ name: string; definition: string }>,\n) => {\n const pragma = db.prepare(`PRAGMA table_info(${tableName})`).all();\n const existing = new Set(\n Array.isArray(pragma)\n ? pragma\n .filter(\n (row): row is { name?: unknown } =>\n isObjectRecord(row) && \"name\" in row,\n )\n .map((row) => (typeof row.name === \"string\" ? row.name : undefined))\n .filter((name): name is string => typeof name === \"string\")\n : [],\n );\n\n for (const column of columns) {\n if (existing.has(column.name)) {\n continue;\n }\n db.exec(\n `ALTER TABLE ${tableName} ADD COLUMN ${column.name} ${column.definition}`,\n );\n }\n};\n\nconst getMissingSQLiteColumns = (\n db: Database,\n tableName: string,\n columns: Array<{ name: string; definition: string }>,\n): RAGSQLiteStoreMigrationIssue[] => {\n const pragma = db.prepare(`PRAGMA table_info(${tableName})`).all();\n const existing = new Set(\n Array.isArray(pragma)\n ? pragma\n .filter(\n (row): row is { name?: unknown } =>\n isObjectRecord(row) && \"name\" in row,\n )\n .map((row) => (typeof row.name === \"string\" ? row.name : undefined))\n .filter((name): name is string => typeof name === \"string\")\n : [],\n );\n\n return columns\n .filter((column) => !existing.has(column.name))\n .map((column) => ({\n columnName: column.name,\n definition: column.definition,\n tableName,\n }));\n};\n\ntype SQLiteStoreMigrationDescriptor = {\n tableName: string;\n columns: Array<{ name: string; definition: string }>;\n};\n\nconst getDefaultSQLiteStoreMigrationDescriptors =\n (): SQLiteStoreMigrationDescriptor[] => [\n {\n tableName: DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME,\n columns: [{ definition: \"TEXT\", name: \"corpus_group_key\" }],\n },\n {\n tableName: DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME,\n columns: [{ definition: \"TEXT\", name: \"corpus_group_key\" }],\n },\n {\n tableName: DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME,\n columns: [\n { definition: \"TEXT\", name: \"group_key\" },\n { definition: \"TEXT\", name: \"corpus_group_key\" },\n ],\n },\n ];\n\nconst summarizeSQLiteStoreMigrationIssues = (\n issues: RAGSQLiteStoreMigrationIssue[],\n) =>\n issues.length > 0\n ? `${issues.length} SQLite schema migration issue${issues.length === 1 ? \"\" : \"s\"} detected`\n : undefined;\n\nexport type SQLiteRAGStoreMigrationOptions = {\n db?: Database;\n path?: string;\n descriptors?: SQLiteStoreMigrationDescriptor[];\n};\n\nexport const inspectRAGSQLiteStoreMigrations = (\n options: SQLiteRAGStoreMigrationOptions = {},\n): RAGSQLiteStoreMigrationInspection => {\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n const descriptors =\n options.descriptors ?? getDefaultSQLiteStoreMigrationDescriptors();\n const issues = descriptors.flatMap((descriptor) =>\n getMissingSQLiteColumns(db, descriptor.tableName, descriptor.columns),\n );\n\n return {\n issues,\n summary: summarizeSQLiteStoreMigrationIssues(issues),\n };\n};\n\nexport const applyRAGSQLiteStoreMigrations = (\n options: SQLiteRAGStoreMigrationOptions = {},\n): RAGSQLiteStoreMigrationResult => {\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n const descriptors =\n options.descriptors ?? getDefaultSQLiteStoreMigrationDescriptors();\n const inspection = inspectRAGSQLiteStoreMigrations({\n db,\n descriptors,\n });\n\n for (const descriptor of descriptors) {\n ensureSQLiteColumns(db, descriptor.tableName, descriptor.columns);\n }\n\n return {\n ...inspection,\n applied: inspection.issues,\n };\n};\n\nconst mapSQLiteSearchTraceRow = (\n row: SQLiteSearchTraceRow,\n): RAGSearchTraceRecord => ({\n elapsedMs: row.elapsed_ms,\n finishedAt: row.finished_at,\n groupKey: row.group_key ?? undefined,\n id: row.id,\n label: row.label,\n metadata: parseJSONRecord(row.metadata_json),\n query: row.query,\n results: parseJSONArray(row.results_json, []),\n startedAt: row.started_at,\n summary: JSON.parse(row.summary_json),\n tags: normalizeStringArray(parseJSONArray(row.tags_json, [])),\n trace: JSON.parse(row.trace_json),\n});\n\nconst mapSQLiteSearchTracePruneHistoryRow = (\n row: SQLiteSearchTracePruneHistoryRow,\n): RAGSearchTracePruneRun => JSON.parse(row.run_json);\n\nconst mapSQLiteRetrievalComparisonHistoryRow = (\n row: SQLiteRetrievalComparisonHistoryRow,\n): RAGRetrievalComparisonRun => ({\n comparison: JSON.parse(row.comparison_json),\n corpusGroupKey: row.corpus_group_key ?? undefined,\n decisionSummary: row.decision_summary_json\n ? JSON.parse(row.decision_summary_json)\n : undefined,\n elapsedMs: row.elapsed_ms,\n finishedAt: row.finished_at,\n groupKey: row.group_key ?? undefined,\n id: row.id,\n label: row.label,\n startedAt: row.started_at,\n suiteId: row.suite_id,\n suiteLabel: row.suite_label,\n tags: normalizeStringArray(parseJSONArray(row.tags_json, [])),\n});\n\nconst mapSQLiteRetrievalReleaseDecisionRow = (\n row: SQLiteRetrievalReleaseDecisionRow,\n): RAGRetrievalReleaseDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalBaselineRow = (\n row: SQLiteRetrievalBaselineRow,\n): RAGRetrievalBaselineRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalReleaseIncidentRow = (\n row: SQLiteRetrievalReleaseIncidentRow,\n): RAGRetrievalReleaseIncidentRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffDecisionRow = (\n row: SQLiteRetrievalLaneHandoffDecisionRow,\n): RAGRetrievalLaneHandoffDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffIncidentRow = (\n row: SQLiteRetrievalLaneHandoffIncidentRow,\n): RAGRetrievalLaneHandoffIncidentRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalLaneHandoffIncidentHistoryRow = (\n row: SQLiteRetrievalLaneHandoffIncidentHistoryRow,\n): RAGRetrievalLaneHandoffIncidentHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalIncidentRemediationDecisionRow = (\n row: SQLiteRetrievalIncidentRemediationDecisionRow,\n): RAGRetrievalIncidentRemediationDecisionRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteRetrievalIncidentRemediationExecutionHistoryRow = (\n row: SQLiteRetrievalIncidentRemediationExecutionHistoryRow,\n): RAGRetrievalIncidentRemediationExecutionHistoryRecord =>\n JSON.parse(row.record_json);\n\nconst mapSQLiteLaneHandoffAutoCompletePolicyHistoryRow = (\n row: SQLiteLaneHandoffAutoCompletePolicyHistoryRow,\n): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord =>\n JSON.parse(row.record_json);\n\nconst mapSQLiteReleaseLanePolicyHistoryRow = (\n row: SQLiteReleaseLanePolicyHistoryRow,\n): RAGRetrievalReleaseLanePolicyHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteBaselineGatePolicyHistoryRow = (\n row: SQLiteBaselineGatePolicyHistoryRow,\n): RAGRetrievalBaselineGatePolicyHistoryRecord => JSON.parse(row.record_json);\n\nconst mapSQLiteReleaseLaneEscalationPolicyHistoryRow = (\n row: SQLiteReleaseLaneEscalationPolicyHistoryRow,\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord =>\n JSON.parse(row.record_json);\n\nexport const createRAGSQLiteSearchTraceStore = (\n options: SQLiteRAGSearchTraceStoreOptions,\n): RAGSearchTraceStore => {\n const tableName = options.tableName ?? DEFAULT_SEARCH_TRACE_TABLE_NAME;\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tquery TEXT NOT NULL,\n\t\t\tlabel TEXT NOT NULL,\n\t\t\tgroup_key TEXT,\n\t\t\ttags_json TEXT,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\ttrace_json TEXT NOT NULL,\n\t\t\tsummary_json TEXT NOT NULL,\n\t\t\tresults_json TEXT NOT NULL,\n\t\t\tmetadata_json TEXT\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_query_finished_at_idx ON ${tableName} (query, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_finished_at_idx ON ${tableName} (group_key, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tquery,\n\t\t\tlabel,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\ttrace_json,\n\t\t\tsummary_json,\n\t\t\tresults_json,\n\t\t\tmetadata_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tquery,\n\t\t\tlabel,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\ttrace_json,\n\t\t\tsummary_json,\n\t\t\tresults_json,\n\t\t\tmetadata_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tquery = excluded.query,\n\t\t\tlabel = excluded.label,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\ttrace_json = excluded.trace_json,\n\t\t\tsummary_json = excluded.summary_json,\n\t\t\tresults_json = excluded.results_json,\n\t\t\tmetadata_json = excluded.metadata_json\n\t`);\n const remove = db.prepare(`DELETE FROM ${tableName} WHERE id = ?`);\n\n return {\n listTraces(input) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input?.query) {\n where.push(\"query = ?\");\n params.push(input.query);\n }\n\n if (input?.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY finished_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const traces = Array.isArray(rows)\n ? rows.filter(isSQLiteSearchTraceRow).map(mapSQLiteSearchTraceRow)\n : [];\n const filtered = input?.tag\n ? traces.filter((trace) =>\n (trace.tags ?? []).includes(input.tag as string),\n )\n : traces;\n\n return normalizeTraceSummaryRuns(filtered).slice(\n 0,\n input?.limit ?? DEFAULT_HISTORY_LIMIT,\n );\n },\n saveTrace(trace) {\n insert.run(\n trace.id,\n trace.query,\n trace.label,\n trace.groupKey ?? null,\n JSON.stringify(trace.tags ?? []),\n trace.startedAt,\n trace.finishedAt,\n trace.elapsedMs,\n JSON.stringify(trace.trace),\n JSON.stringify(trace.summary),\n JSON.stringify(trace.results),\n trace.metadata === undefined ? null : JSON.stringify(trace.metadata),\n );\n },\n pruneTraces(input) {\n const rows = db.prepare(`${listBase} ORDER BY finished_at DESC`).all();\n const traces = Array.isArray(rows)\n ? rows.filter(isSQLiteSearchTraceRow).map(mapSQLiteSearchTraceRow)\n : [];\n const pruned = applyRAGSearchTracePrunePolicy({\n input,\n traces,\n });\n\n for (const trace of pruned.removed) {\n remove.run(trace.id);\n }\n\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n };\n },\n };\n};\n\nexport const createRAGSQLiteSearchTracePruneHistoryStore = (\n options: SQLiteRAGSearchTracePruneHistoryStoreOptions,\n): RAGSearchTracePruneHistoryStore => {\n const tableName = options.tableName ?? \"rag_search_trace_prune_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\ttrigger TEXT NOT NULL,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\trun_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_trigger_finished_at_idx ON ${tableName} (trigger, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\ttrigger,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\trun_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\ttrigger,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\trun_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\ttrigger = excluded.trigger,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\trun_json = excluded.run_json\n\t`);\n\n return {\n listRuns(input) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input?.trigger) {\n where.push(\"trigger = ?\");\n params.push(input.trigger);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY finished_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const runs = Array.isArray(rows)\n ? rows\n .filter(isSQLiteSearchTracePruneHistoryRow)\n .map(mapSQLiteSearchTracePruneHistoryRow)\n : [];\n const sorted = normalizeSearchTracePruneRuns(runs);\n return typeof input?.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveRun(run) {\n insert.run(\n run.id,\n run.trigger,\n run.startedAt,\n run.finishedAt,\n run.elapsedMs,\n JSON.stringify(run),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalComparisonHistoryStore = (\n options: SQLiteRAGRetrievalComparisonHistoryStoreOptions,\n): RAGRetrievalComparisonHistoryStore => {\n const tableName =\n options.tableName ?? DEFAULT_RETRIEVAL_COMPARISON_HISTORY_TABLE_NAME;\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tsuite_id TEXT NOT NULL,\n\t\t\tsuite_label TEXT NOT NULL,\n\t\t\tlabel TEXT NOT NULL,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\ttags_json TEXT,\n\t\t\tstarted_at INTEGER NOT NULL,\n\t\t\tfinished_at INTEGER NOT NULL,\n\t\t\telapsed_ms INTEGER NOT NULL,\n\t\t\tcomparison_json TEXT NOT NULL,\n\t\t\tdecision_summary_json TEXT\n\t\t)\n\t`);\n ensureSQLiteColumns(db, tableName, [\n { definition: \"TEXT\", name: \"corpus_group_key\" },\n ]);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_suite_finished_at_idx ON ${tableName} (suite_id, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_finished_at_idx ON ${tableName} (group_key, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_finished_at_idx ON ${tableName} (corpus_group_key, finished_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_finished_at_idx ON ${tableName} (finished_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tsuite_label,\n\t\t\tlabel,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\tcomparison_json,\n\t\t\tdecision_summary_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tsuite_id,\n\t\t\tsuite_label,\n\t\t\tlabel,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttags_json,\n\t\t\tstarted_at,\n\t\t\tfinished_at,\n\t\t\telapsed_ms,\n\t\t\tcomparison_json,\n\t\t\tdecision_summary_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tsuite_id = excluded.suite_id,\n\t\t\tsuite_label = excluded.suite_label,\n\t\t\tlabel = excluded.label,\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\tstarted_at = excluded.started_at,\n\t\t\tfinished_at = excluded.finished_at,\n\t\t\telapsed_ms = excluded.elapsed_ms,\n\t\t\tcomparison_json = excluded.comparison_json,\n\t\t\tdecision_summary_json = excluded.decision_summary_json\n\t`);\n\n return {\n listRuns(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.suiteId) {\n where.push(\"suite_id = ?\");\n params.push(input.suiteId);\n }\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY finished_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const runs = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalComparisonHistoryRow)\n .map(mapSQLiteRetrievalComparisonHistoryRow)\n : [];\n const normalizedLabel = normalizeLabelFilter(input.label);\n const filtered = normalizeRetrievalComparisonRuns(\n runs.filter(\n (entry) =>\n (!input.tag || (entry.tags ?? []).includes(input.tag)) &&\n (!normalizedLabel ||\n entry.label.toLowerCase().includes(normalizedLabel) ||\n entry.suiteLabel.toLowerCase().includes(normalizedLabel)) &&\n matchesWinner(entry, input.winnerId),\n ),\n );\n\n return typeof input.limit === \"number\"\n ? filtered.slice(0, input.limit)\n : filtered;\n },\n saveRun(run) {\n insert.run(\n run.id,\n run.suiteId,\n run.suiteLabel,\n run.label,\n run.corpusGroupKey ?? null,\n run.groupKey ?? null,\n JSON.stringify(run.tags ?? []),\n run.startedAt,\n run.finishedAt,\n run.elapsedMs,\n JSON.stringify(run.comparison),\n run.decisionSummary === undefined\n ? null\n : JSON.stringify(run.decisionSummary),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalReleaseDecisionStore = (\n options: SQLiteRAGRetrievalReleaseDecisionStoreOptions,\n): RAGRetrievalReleaseDecisionStore => {\n const tableName =\n options.tableName ?? DEFAULT_RETRIEVAL_RELEASE_DECISION_TABLE_NAME;\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\tkind TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n ensureSQLiteColumns(db, tableName, [\n { definition: \"TEXT\", name: \"corpus_group_key\" },\n ]);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_decided_at_idx ON ${tableName} (corpus_group_key, decided_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_kind_decided_at_idx ON ${tableName} (kind, decided_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\tkind = excluded.kind,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listDecisions(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.kind) {\n where.push(\"kind = ?\");\n params.push(input.kind);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY decided_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const decisions = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalReleaseDecisionRow)\n .map(mapSQLiteRetrievalReleaseDecisionRow)\n : [];\n const sorted = normalizeRetrievalReleaseDecisionRecords(decisions);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveDecision(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.kind,\n record.decidedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalBaselineStore = (\n options: SQLiteRAGRetrievalBaselineStoreOptions,\n): RAGRetrievalBaselineStore => {\n const tableName = options.tableName ?? DEFAULT_RETRIEVAL_BASELINE_TABLE_NAME;\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\trollout_label TEXT,\n\t\t\tpromoted_at INTEGER NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\tversion INTEGER NOT NULL,\n\t\t\ttags_json TEXT,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n ensureSQLiteColumns(db, tableName, [\n { definition: \"TEXT\", name: \"corpus_group_key\" },\n ]);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_promoted_at_idx ON ${tableName} (group_key, promoted_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_promoted_at_idx ON ${tableName} (corpus_group_key, promoted_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_rollout_status_idx ON ${tableName} (group_key, rollout_label, status)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tpromoted_at = excluded.promoted_at,\n\t\t\tstatus = excluded.status,\n\t\t\tversion = excluded.version,\n\t\t\ttags_json = excluded.tags_json,\n\t\t\trecord_json = excluded.record_json\n\t`);\n const updateExisting = db.prepare(`\n\t\tUPDATE ${tableName}\n\t\tSET\n\t\t\tstatus = ?,\n\t\t\trecord_json = ?\n\t\tWHERE id = ?\n\t`);\n const currentVersion = db.prepare(`\n\t\tSELECT COALESCE(MAX(version), 0) AS max_version\n\t\tFROM ${tableName}\n\t\tWHERE group_key = ?\n\t`);\n const matchingRolloutRows = db.prepare(`\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tpromoted_at,\n\t\t\tstatus,\n\t\t\tversion,\n\t\t\ttags_json,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t\tWHERE group_key = ?\n\t\t\tAND (\n\t\t\t\t(rollout_label IS NULL AND ? IS NULL) OR\n\t\t\t\trollout_label = ?\n\t\t\t)\n\t`);\n\n const listBaselinesSync = (\n input: Parameters<RAGRetrievalBaselineStore[\"listBaselines\"]>[0] = {},\n ): RAGRetrievalBaselineRecord[] => {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.status) {\n where.push(\"status = ?\");\n params.push(input.status);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY promoted_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const baselines = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalBaselineRow)\n .map(mapSQLiteRetrievalBaselineRow)\n : [];\n const tag = typeof input.tag === \"string\" ? input.tag : undefined;\n const filtered = tag\n ? baselines.filter((entry) => (entry.tags ?? []).includes(tag))\n : baselines;\n const sorted = normalizeRetrievalBaselineRecords(filtered);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n };\n\n return {\n getBaseline(groupKey) {\n const baselines = listBaselinesSync({ groupKey, limit: 1 });\n return Promise.resolve(baselines[0] ?? null);\n },\n listBaselines(input) {\n return Promise.resolve(listBaselinesSync(input));\n },\n saveBaseline(record) {\n const versionRow = currentVersion.get(record.groupKey) as\n | { max_version?: number }\n | undefined;\n const nextVersion =\n typeof record.version === \"number\"\n ? record.version\n : (versionRow?.max_version ?? 0) + 1;\n const nextRecord: RAGRetrievalBaselineRecord = {\n ...record,\n status: \"active\",\n version: nextVersion,\n };\n\n const rows = matchingRolloutRows.all(\n record.groupKey,\n record.rolloutLabel ?? null,\n record.rolloutLabel ?? null,\n );\n const existing = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalBaselineRow)\n .map(mapSQLiteRetrievalBaselineRow)\n : [];\n\n for (const entry of existing) {\n updateExisting.run(\n \"superseded\",\n JSON.stringify({\n ...entry,\n status: \"superseded\",\n }),\n entry.id,\n );\n }\n\n insert.run(\n nextRecord.id,\n nextRecord.corpusGroupKey ?? null,\n nextRecord.groupKey,\n nextRecord.rolloutLabel ?? null,\n nextRecord.promotedAt,\n nextRecord.status,\n nextRecord.version,\n JSON.stringify(nextRecord.tags ?? []),\n JSON.stringify(nextRecord),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalReleaseIncidentStore = (\n options: SQLiteRAGRetrievalReleaseIncidentStoreOptions,\n): RAGRetrievalReleaseIncidentStore => {\n const tableName =\n options.tableName ?? DEFAULT_RETRIEVAL_RELEASE_INCIDENT_TABLE_NAME;\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tseverity TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\ttriggered_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_triggered_at_idx ON ${tableName} (group_key, triggered_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_status_idx ON ${tableName} (corpus_group_key, status, triggered_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tseverity = excluded.severity,\n\t\t\tstatus = excluded.status,\n\t\t\ttriggered_at = excluded.triggered_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listIncidents(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n if (input.severity) {\n where.push(\"severity = ?\");\n params.push(input.severity);\n }\n\n if (input.status) {\n where.push(\"status = ?\");\n params.push(input.status);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY triggered_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const incidents = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalReleaseIncidentRow)\n .map(mapSQLiteRetrievalReleaseIncidentRow)\n : [];\n const sorted = normalizeRetrievalReleaseIncidentRecords(incidents);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveIncident(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.targetRolloutLabel ?? null,\n record.severity,\n record.status,\n record.triggeredAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffDecisionStore = (\n options: SQLiteRAGRetrievalLaneHandoffDecisionStoreOptions,\n): RAGRetrievalLaneHandoffDecisionStore => {\n const tableName = options.tableName ?? \"rag_retrieval_lane_handoff_decisions\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\tsource_rollout_label TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\tkind TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_rollout_idx ON ${tableName} (corpus_group_key, source_rollout_label, target_rollout_label, decided_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tsource_rollout_label,\n\t\t\ttarget_rollout_label,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\tsource_rollout_label,\n\t\t\ttarget_rollout_label,\n\t\t\tkind,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\tsource_rollout_label = excluded.source_rollout_label,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tkind = excluded.kind,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listDecisions(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.kind) {\n where.push(\"kind = ?\");\n params.push(input.kind);\n }\n\n if (input.sourceRolloutLabel) {\n where.push(\"source_rollout_label = ?\");\n params.push(input.sourceRolloutLabel);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY decided_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const decisions = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalLaneHandoffDecisionRow)\n .map(mapSQLiteRetrievalLaneHandoffDecisionRow)\n : [];\n const sorted = normalizeRetrievalLaneHandoffDecisionRecords(decisions);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveDecision(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.sourceRolloutLabel,\n record.targetRolloutLabel,\n record.kind,\n record.decidedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffIncidentStore = (\n options: SQLiteRAGRetrievalLaneHandoffIncidentStoreOptions,\n): RAGRetrievalLaneHandoffIncidentStore => {\n const tableName = options.tableName ?? \"rag_retrieval_lane_handoff_incidents\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tsource_rollout_label TEXT,\n\t\t\tseverity TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\ttriggered_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_triggered_at_idx ON ${tableName} (group_key, triggered_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_status_idx ON ${tableName} (corpus_group_key, status, triggered_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tsource_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tsource_rollout_label,\n\t\t\tseverity,\n\t\t\tstatus,\n\t\t\ttriggered_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tsource_rollout_label = excluded.source_rollout_label,\n\t\t\tseverity = excluded.severity,\n\t\t\tstatus = excluded.status,\n\t\t\ttriggered_at = excluded.triggered_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listIncidents(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n if (input.severity) {\n where.push(\"severity = ?\");\n params.push(input.severity);\n }\n\n if (input.status) {\n where.push(\"status = ?\");\n params.push(input.status);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY triggered_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const incidents = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalLaneHandoffIncidentRow)\n .map(mapSQLiteRetrievalLaneHandoffIncidentRow)\n : [];\n const sorted = normalizeRetrievalReleaseIncidentRecords(\n incidents as RAGRetrievalReleaseIncidentRecord[],\n ) as RAGRetrievalLaneHandoffIncidentRecord[];\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveIncident(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.targetRolloutLabel ?? null,\n record.sourceRolloutLabel ?? null,\n record.severity,\n record.status,\n record.triggeredAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalLaneHandoffIncidentHistoryStore = (\n options: SQLiteRAGRetrievalLaneHandoffIncidentHistoryStoreOptions,\n): RAGRetrievalLaneHandoffIncidentHistoryStore => {\n const tableName =\n options.tableName ?? \"rag_retrieval_lane_handoff_incident_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT NOT NULL,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\taction TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_incident_recorded_at_idx ON ${tableName} (incident_id, recorded_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\taction = excluded.action,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.incidentId) {\n where.push(\"incident_id = ?\");\n params.push(input.incidentId);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n if (input.action) {\n where.push(\"action = ?\");\n params.push(input.action);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY recorded_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalLaneHandoffIncidentHistoryRow)\n .map(mapSQLiteRetrievalLaneHandoffIncidentHistoryRow)\n : [];\n\n return typeof input.limit === \"number\"\n ? records.slice(0, input.limit)\n : records;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.incidentId,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.targetRolloutLabel ?? null,\n record.action,\n record.recordedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalIncidentRemediationDecisionStore = (\n options: SQLiteRAGRetrievalIncidentRemediationDecisionStoreOptions,\n): RAGRetrievalIncidentRemediationDecisionStore => {\n const tableName =\n options.tableName ?? \"rag_retrieval_incident_remediation_decisions\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT NOT NULL,\n\t\t\tgroup_key TEXT NOT NULL,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\tremediation_kind TEXT NOT NULL,\n\t\t\tstatus TEXT NOT NULL,\n\t\t\tdecided_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_decided_at_idx ON ${tableName} (group_key, decided_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_incident_status_idx ON ${tableName} (incident_id, status, decided_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tremediation_kind,\n\t\t\tstatus,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\tremediation_kind,\n\t\t\tstatus,\n\t\t\tdecided_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\tremediation_kind = excluded.remediation_kind,\n\t\t\tstatus = excluded.status,\n\t\t\tdecided_at = excluded.decided_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.incidentId) {\n where.push(\"incident_id = ?\");\n params.push(input.incidentId);\n }\n\n if (input.remediationKind) {\n where.push(\"remediation_kind = ?\");\n params.push(input.remediationKind);\n }\n\n if (input.status) {\n where.push(\"status = ?\");\n params.push(input.status);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY decided_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalIncidentRemediationDecisionRow)\n .map(mapSQLiteRetrievalIncidentRemediationDecisionRow)\n : [];\n const sorted =\n normalizeRetrievalIncidentRemediationDecisionRecords(records);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.incidentId,\n record.groupKey,\n record.targetRolloutLabel ?? null,\n record.remediationKind,\n record.status,\n record.decidedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalIncidentRemediationExecutionHistoryStore =\n (\n options: SQLiteRAGRetrievalIncidentRemediationExecutionHistoryStoreOptions,\n ): RAGRetrievalIncidentRemediationExecutionHistoryStore => {\n const tableName =\n options.tableName ??\n \"rag_retrieval_incident_remediation_execution_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tincident_id TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\ttarget_rollout_label TEXT,\n\t\t\taction_kind TEXT NOT NULL,\n\t\t\tcode TEXT NOT NULL,\n\t\t\tblocked_by_guardrail INTEGER NOT NULL,\n\t\t\tidempotent_replay INTEGER NOT NULL,\n\t\t\texecuted_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_executed_at_idx ON ${tableName} (group_key, executed_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_incident_code_idx ON ${tableName} (incident_id, code, executed_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction_kind,\n\t\t\tcode,\n\t\t\tblocked_by_guardrail,\n\t\t\tidempotent_replay,\n\t\t\texecuted_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tincident_id,\n\t\t\tgroup_key,\n\t\t\ttarget_rollout_label,\n\t\t\taction_kind,\n\t\t\tcode,\n\t\t\tblocked_by_guardrail,\n\t\t\tidempotent_replay,\n\t\t\texecuted_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tincident_id = excluded.incident_id,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\taction_kind = excluded.action_kind,\n\t\t\tcode = excluded.code,\n\t\t\tblocked_by_guardrail = excluded.blocked_by_guardrail,\n\t\t\tidempotent_replay = excluded.idempotent_replay,\n\t\t\texecuted_at = excluded.executed_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n\n if (input.incidentId) {\n where.push(\"incident_id = ?\");\n params.push(input.incidentId);\n }\n\n if (input.actionKind) {\n where.push(\"action_kind = ?\");\n params.push(input.actionKind);\n }\n\n if (input.code) {\n where.push(\"code = ?\");\n params.push(input.code);\n }\n\n if (typeof input.blockedByGuardrail === \"boolean\") {\n where.push(\"blocked_by_guardrail = ?\");\n params.push(input.blockedByGuardrail ? 1 : 0);\n }\n\n if (typeof input.idempotentReplay === \"boolean\") {\n where.push(\"idempotent_replay = ?\");\n params.push(input.idempotentReplay ? 1 : 0);\n }\n\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY executed_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteRetrievalIncidentRemediationExecutionHistoryRow)\n .map(mapSQLiteRetrievalIncidentRemediationExecutionHistoryRow)\n : [];\n const sorted =\n normalizeRetrievalIncidentRemediationExecutionHistoryRecords(records);\n\n return typeof input.limit === \"number\"\n ? sorted.slice(0, input.limit)\n : sorted;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.incidentId ?? null,\n record.groupKey ?? null,\n record.targetRolloutLabel ?? null,\n record.action.kind,\n record.code,\n record.blockedByGuardrail ? 1 : 0,\n record.idempotentReplay ? 1 : 0,\n record.executedAt,\n JSON.stringify(record),\n );\n },\n };\n };\n\nexport const createRAGSQLiteRetrievalLaneHandoffAutoCompletePolicyHistoryStore =\n (\n options: SQLiteRAGRetrievalLaneHandoffAutoCompletePolicyHistoryStoreOptions,\n ): RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore => {\n const tableName =\n options.tableName ??\n \"rag_retrieval_lane_handoff_auto_complete_policy_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\t\tid TEXT PRIMARY KEY,\n\t\t\t\tcorpus_group_key TEXT,\n\t\t\t\tgroup_key TEXT NOT NULL,\n\t\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\t\trecord_json TEXT NOT NULL\n\t\t\t)\n\t\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_target_idx ON ${tableName} (corpus_group_key, target_rollout_label, recorded_at DESC)`,\n );\n\n const listBase = `\n\t\t\tSELECT\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\tFROM ${tableName}\n\t\t`;\n const insert = db.prepare(`\n\t\t\tINSERT INTO ${tableName} (\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\t\tgroup_key = excluded.group_key,\n\t\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\t\trecorded_at = excluded.recorded_at,\n\t\t\t\trecord_json = excluded.record_json\n\t\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY recorded_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteLaneHandoffAutoCompletePolicyHistoryRow)\n .map(mapSQLiteLaneHandoffAutoCompletePolicyHistoryRow)\n : [];\n return typeof input.limit === \"number\"\n ? records.slice(0, input.limit)\n : records;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.targetRolloutLabel,\n record.recordedAt,\n JSON.stringify(record),\n );\n },\n };\n };\n\nexport const createRAGSQLiteRetrievalReleaseLanePolicyHistoryStore = (\n options: SQLiteRAGRetrievalReleaseLanePolicyHistoryStoreOptions,\n): RAGRetrievalReleaseLanePolicyHistoryStore => {\n const tableName =\n options.tableName ?? \"rag_retrieval_release_lane_policy_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\trollout_label TEXT NOT NULL,\n\t\t\tscope TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_rollout_recorded_at_idx ON ${tableName} (rollout_label, recorded_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_scope_idx ON ${tableName} (group_key, scope, recorded_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tscope = excluded.scope,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n if (input.rolloutLabel) {\n where.push(\"rollout_label = ?\");\n params.push(input.rolloutLabel);\n }\n if (input.scope) {\n where.push(\"scope = ?\");\n params.push(input.scope);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY recorded_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteReleaseLanePolicyHistoryRow)\n .map(mapSQLiteReleaseLanePolicyHistoryRow)\n : [];\n return typeof input.limit === \"number\"\n ? records.slice(0, input.limit)\n : records;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey ?? null,\n record.rolloutLabel,\n record.scope,\n record.recordedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalBaselineGatePolicyHistoryStore = (\n options: SQLiteRAGRetrievalBaselineGatePolicyHistoryStoreOptions,\n): RAGRetrievalBaselineGatePolicyHistoryStore => {\n const tableName =\n options.tableName ?? \"rag_retrieval_baseline_gate_policy_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\tid TEXT PRIMARY KEY,\n\t\t\tcorpus_group_key TEXT,\n\t\t\tgroup_key TEXT,\n\t\t\trollout_label TEXT NOT NULL,\n\t\t\tscope TEXT NOT NULL,\n\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\trecord_json TEXT NOT NULL\n\t\t)\n\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_rollout_recorded_at_idx ON ${tableName} (rollout_label, recorded_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_scope_idx ON ${tableName} (group_key, scope, recorded_at DESC)`,\n );\n\n const listBase = `\n\t\tSELECT\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\tFROM ${tableName}\n\t`;\n const insert = db.prepare(`\n\t\tINSERT INTO ${tableName} (\n\t\t\tid,\n\t\t\tcorpus_group_key,\n\t\t\tgroup_key,\n\t\t\trollout_label,\n\t\t\tscope,\n\t\t\trecorded_at,\n\t\t\trecord_json\n\t\t) VALUES (?, ?, ?, ?, ?, ?, ?)\n\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\tgroup_key = excluded.group_key,\n\t\t\trollout_label = excluded.rollout_label,\n\t\t\tscope = excluded.scope,\n\t\t\trecorded_at = excluded.recorded_at,\n\t\t\trecord_json = excluded.record_json\n\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n if (input.rolloutLabel) {\n where.push(\"rollout_label = ?\");\n params.push(input.rolloutLabel);\n }\n if (input.scope) {\n where.push(\"scope = ?\");\n params.push(input.scope);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY recorded_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteBaselineGatePolicyHistoryRow)\n .map(mapSQLiteBaselineGatePolicyHistoryRow)\n : [];\n return typeof input.limit === \"number\"\n ? records.slice(0, input.limit)\n : records;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey ?? null,\n record.rolloutLabel,\n record.scope,\n record.recordedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGSQLiteRetrievalReleaseLaneEscalationPolicyHistoryStore = (\n options: SQLiteRAGRetrievalReleaseLaneEscalationPolicyHistoryStoreOptions,\n): RAGRetrievalReleaseLaneEscalationPolicyHistoryStore => {\n const tableName =\n options.tableName ?? \"rag_retrieval_release_lane_escalation_policy_history\";\n assertSupportedIdentifier(tableName);\n\n const db =\n options.db ??\n new (loadBunSQLiteModule().Database)(options.path ?? \":memory:\");\n\n db.exec(`\n\t\t\tCREATE TABLE IF NOT EXISTS ${tableName} (\n\t\t\t\tid TEXT PRIMARY KEY,\n\t\t\t\tcorpus_group_key TEXT,\n\t\t\t\tgroup_key TEXT NOT NULL,\n\t\t\t\ttarget_rollout_label TEXT NOT NULL,\n\t\t\t\trecorded_at INTEGER NOT NULL,\n\t\t\t\trecord_json TEXT NOT NULL\n\t\t\t)\n\t\t`);\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_group_recorded_at_idx ON ${tableName} (group_key, recorded_at DESC)`,\n );\n db.exec(\n `CREATE INDEX IF NOT EXISTS ${tableName}_corpus_target_idx ON ${tableName} (corpus_group_key, target_rollout_label, recorded_at DESC)`,\n );\n\n const listBase = `\n\t\t\tSELECT\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\tFROM ${tableName}\n\t\t`;\n const insert = db.prepare(`\n\t\t\tINSERT INTO ${tableName} (\n\t\t\t\tid,\n\t\t\t\tcorpus_group_key,\n\t\t\t\tgroup_key,\n\t\t\t\ttarget_rollout_label,\n\t\t\t\trecorded_at,\n\t\t\t\trecord_json\n\t\t\t) VALUES (?, ?, ?, ?, ?, ?)\n\t\t\tON CONFLICT(id) DO UPDATE SET\n\t\t\t\tcorpus_group_key = excluded.corpus_group_key,\n\t\t\t\tgroup_key = excluded.group_key,\n\t\t\t\ttarget_rollout_label = excluded.target_rollout_label,\n\t\t\t\trecorded_at = excluded.recorded_at,\n\t\t\t\trecord_json = excluded.record_json\n\t\t`);\n\n return {\n listRecords(input = {}) {\n const where: string[] = [];\n const params: Array<string | number> = [];\n\n if (input.corpusGroupKey) {\n where.push(\"corpus_group_key = ?\");\n params.push(input.corpusGroupKey);\n }\n if (input.groupKey) {\n where.push(\"group_key = ?\");\n params.push(input.groupKey);\n }\n if (input.targetRolloutLabel) {\n where.push(\"target_rollout_label = ?\");\n params.push(input.targetRolloutLabel);\n }\n\n const sql =\n `${listBase}${where.length > 0 ? ` WHERE ${where.join(\" AND \")}` : \"\"} ` +\n \"ORDER BY recorded_at DESC\";\n const rows = db.prepare(sql).all(...params);\n const records = Array.isArray(rows)\n ? rows\n .filter(isSQLiteReleaseLaneEscalationPolicyHistoryRow)\n .map(mapSQLiteReleaseLaneEscalationPolicyHistoryRow)\n : [];\n return typeof input.limit === \"number\"\n ? records.slice(0, input.limit)\n : records;\n },\n saveRecord(record) {\n insert.run(\n record.id,\n record.corpusGroupKey ?? null,\n record.groupKey,\n record.targetRolloutLabel,\n record.recordedAt,\n JSON.stringify(record),\n );\n },\n };\n};\n\nexport const createRAGFileAnswerGroundingEvaluationHistoryStore = (\n path: string,\n): RAGAnswerGroundingEvaluationHistoryStore => ({\n async listRuns(input) {\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n runs?: RAGAnswerGroundingEvaluationRun[];\n };\n const runs = Array.isArray(data.runs) ? data.runs : [];\n const filtered = input?.suiteId\n ? runs.filter((run) => run.suiteId === input.suiteId)\n : runs;\n\n return filtered\n .sort(toGroundingHistorySortOrder)\n .slice(0, input?.limit ?? DEFAULT_HISTORY_LIMIT);\n } catch (error) {\n if (\n error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n error.code === \"ENOENT\"\n ) {\n return [];\n }\n\n throw error;\n }\n },\n async saveRun(run) {\n let runs: RAGAnswerGroundingEvaluationRun[] = [];\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n runs?: RAGAnswerGroundingEvaluationRun[];\n };\n runs = Array.isArray(data.runs) ? data.runs : [];\n } catch (error) {\n if (\n !error ||\n typeof error !== \"object\" ||\n !(\"code\" in error) ||\n error.code !== \"ENOENT\"\n ) {\n throw error;\n }\n }\n\n const nextRuns = normalizeGroundingHistoryRuns([\n run,\n ...runs.filter((entry) => entry.id !== run.id),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(\n {\n runs: nextRuns,\n },\n null,\n 2,\n ),\n );\n },\n async pruneRuns(input) {\n let runs: RAGAnswerGroundingEvaluationRun[] = [];\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n runs?: RAGAnswerGroundingEvaluationRun[];\n };\n runs = Array.isArray(data.runs) ? data.runs : [];\n } catch (error) {\n if (\n !error ||\n typeof error !== \"object\" ||\n !(\"code\" in error) ||\n error.code !== \"ENOENT\"\n ) {\n throw error;\n }\n }\n\n const pruned = applyRAGEvaluationHistoryPrunePolicy({\n input,\n runs,\n sort: normalizeGroundingHistoryRuns,\n });\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(\n {\n runs: pruned.next,\n },\n null,\n 2,\n ),\n );\n return {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n } satisfies RAGEvaluationHistoryPruneResult;\n },\n});\n\nexport const createRAGFileAnswerGroundingCaseDifficultyHistoryStore = (\n path: string,\n): RAGAnswerGroundingCaseDifficultyHistoryStore => ({\n async listRuns(input) {\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n runs?: RAGAnswerGroundingCaseDifficultyRun[];\n };\n const runs = Array.isArray(data.runs) ? data.runs : [];\n const filtered = input?.suiteId\n ? runs.filter((run) => run.suiteId === input.suiteId)\n : runs;\n\n return normalizeGroundingDifficultyHistoryRuns(filtered).slice(\n 0,\n input?.limit ?? DEFAULT_HISTORY_LIMIT,\n );\n } catch (error) {\n if (\n error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n error.code === \"ENOENT\"\n ) {\n return [];\n }\n\n throw error;\n }\n },\n async saveRun(run) {\n let runs: RAGAnswerGroundingCaseDifficultyRun[] = [];\n try {\n const raw = await readFile(path, \"utf8\");\n const data = JSON.parse(raw) as {\n runs?: RAGAnswerGroundingCaseDifficultyRun[];\n };\n runs = Array.isArray(data.runs) ? data.runs : [];\n } catch (error) {\n if (\n !error ||\n typeof error !== \"object\" ||\n !(\"code\" in error) ||\n error.code !== \"ENOENT\"\n ) {\n throw error;\n }\n }\n\n const nextRuns = normalizeGroundingDifficultyHistoryRuns([\n run,\n ...runs.filter((entry) => entry.id !== run.id),\n ]);\n await mkdir(dirname(path), { recursive: true });\n await writeFile(\n path,\n JSON.stringify(\n {\n runs: nextRuns,\n },\n null,\n 2,\n ),\n );\n },\n});\n\nexport const loadRAGEvaluationHistory = async ({\n store,\n suite,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGEvaluationHistoryStore;\n suite: RAGEvaluationSuite;\n limit?: number;\n}): Promise<RAGEvaluationHistory> => {\n const runs = normalizeHistoryRuns(\n await Promise.resolve(store.listRuns({ limit, suiteId: suite.id })),\n );\n const latestRun = runs[0];\n const previousRun = runs[1];\n\n return {\n caseTraceSnapshots: buildEvaluationCaseTraceSnapshots({\n current: latestRun,\n previous: previousRun,\n }),\n retrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n runs,\n }),\n diff:\n latestRun && previousRun\n ? buildRAGEvaluationRunDiff({\n current: latestRun,\n previous: previousRun,\n })\n : undefined,\n latestRun,\n leaderboard: buildRAGEvaluationLeaderboard(runs),\n previousRun,\n runs,\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n };\n};\n\nexport const loadRAGEvaluationSuiteSnapshotHistory = async ({\n store,\n suite,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGEvaluationSuiteSnapshotHistoryStore;\n suite: Pick<RAGEvaluationSuite, \"id\" | \"label\">;\n limit?: number;\n}): Promise<RAGEvaluationSuiteSnapshotHistory> => {\n const snapshots = normalizeEvaluationSuiteSnapshots(\n await Promise.resolve(\n store.listSnapshots({\n limit,\n suiteId: suite.id,\n }),\n ),\n );\n const latestSnapshot = snapshots[0];\n const previousSnapshot = snapshots[1];\n\n return {\n diff:\n latestSnapshot && previousSnapshot\n ? buildRAGEvaluationSuiteSnapshotDiff({\n current: latestSnapshot,\n previous: previousSnapshot,\n })\n : undefined,\n latestSnapshot,\n previousSnapshot,\n snapshots,\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n };\n};\n\nexport const loadRAGSearchTraceHistory = async ({\n store,\n query,\n groupKey,\n tag,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGSearchTraceStore;\n query?: string;\n groupKey?: string;\n tag?: string;\n limit?: number;\n}): Promise<RAGSearchTraceHistory> => {\n const traces = normalizeTraceSummaryRuns(\n await Promise.resolve(store.listTraces({ groupKey, limit, query, tag })),\n );\n const latestTrace = traces[0];\n const previousTrace = traces[1];\n\n return {\n diff:\n latestTrace && previousTrace\n ? buildRAGSearchTraceDiff({\n current: latestTrace,\n previous: previousTrace,\n })\n : undefined,\n latestTrace,\n previousTrace,\n groupKey,\n query,\n tag,\n retrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n runs: traces.map((trace) => ({\n finishedAt: trace.finishedAt,\n id: trace.id,\n label: trace.label,\n traceSummary: trace.summary,\n })),\n }),\n traces,\n };\n};\n\nexport const loadRAGSearchTraceGroupHistory = async ({\n store,\n tag,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGSearchTraceStore;\n tag?: string;\n limit?: number;\n}): Promise<RAGSearchTraceGroupHistory> => {\n const traces = normalizeTraceSummaryRuns(\n await Promise.resolve(store.listTraces({ limit, tag })),\n );\n const grouped = new Map<string, RAGSearchTraceRecord[]>();\n\n for (const trace of traces) {\n const groupKey = trace.groupKey ?? trace.query;\n const existing = grouped.get(groupKey);\n if (existing) {\n existing.push(trace);\n continue;\n }\n grouped.set(groupKey, [trace]);\n }\n\n const groups = Array.from(grouped.entries())\n .map(([groupKey, entries]): RAGSearchTraceGroupHistoryEntry => {\n const normalizedEntries = normalizeTraceSummaryRuns(entries);\n const latestTrace = normalizedEntries[0];\n const previousTrace = normalizedEntries[1];\n\n return {\n diff:\n latestTrace && previousTrace\n ? buildRAGSearchTraceDiff({\n current: latestTrace,\n previous: previousTrace,\n })\n : undefined,\n groupKey,\n latestTrace,\n previousTrace,\n retrievalTraceTrend: buildRAGRetrievalTraceHistoryTrend({\n runs: normalizedEntries.map((trace) => ({\n finishedAt: trace.finishedAt,\n id: trace.id,\n label: trace.label,\n traceSummary: trace.summary,\n })),\n }),\n traceCount: normalizedEntries.length,\n };\n })\n .sort((left, right) => {\n const leftFinishedAt = left.latestTrace?.finishedAt ?? 0;\n const rightFinishedAt = right.latestTrace?.finishedAt ?? 0;\n return rightFinishedAt - leftFinishedAt;\n });\n\n return {\n groups,\n tag,\n };\n};\n\nexport const summarizeRAGSearchTraceStore = async ({\n store,\n tag,\n}: {\n store: RAGSearchTraceStore;\n tag?: string;\n}): Promise<RAGSearchTraceStats> => {\n const traces = normalizeTraceSummaryRuns(\n await Promise.resolve(store.listTraces({ tag })),\n );\n\n return buildRAGSearchTraceStatsFromTraces(traces);\n};\n\nexport const previewRAGSearchTraceStorePrune = async ({\n store,\n input,\n}: {\n store: RAGSearchTraceStore;\n input?: RAGSearchTracePruneInput;\n}): Promise<RAGSearchTracePrunePreview> => {\n const traces = normalizeTraceSummaryRuns(\n await Promise.resolve(store.listTraces({ tag: input?.tag })),\n );\n const pruned = applyRAGSearchTracePrunePolicy({\n input,\n traces,\n });\n\n return {\n input,\n result: {\n keptCount: pruned.keptCount,\n removedCount: pruned.removedCount,\n },\n statsAfter: buildRAGSearchTraceStatsFromTraces(pruned.next),\n statsBefore: buildRAGSearchTraceStatsFromTraces(traces),\n };\n};\n\nexport const loadRAGAnswerGroundingEvaluationHistory = async ({\n store,\n suite,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGAnswerGroundingEvaluationHistoryStore;\n suite: Pick<RAGEvaluationSuite, \"id\" | \"label\">;\n limit?: number;\n}): Promise<RAGAnswerGroundingEvaluationHistory> => {\n const runs = normalizeGroundingHistoryRuns(\n await Promise.resolve(\n store.listRuns({\n limit,\n suiteId: suite.id,\n }),\n ),\n );\n const latestRun = runs[0];\n const previousRun = runs[1];\n\n return {\n caseSnapshots: buildGroundingCaseSnapshots({\n current: latestRun,\n previous: previousRun,\n }),\n diff:\n latestRun && previousRun\n ? buildRAGAnswerGroundingEvaluationRunDiff({\n current: latestRun,\n previous: previousRun,\n })\n : undefined,\n latestRun,\n leaderboard: buildRAGAnswerGroundingEvaluationLeaderboard(runs),\n previousRun,\n runs,\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n };\n};\n\nexport const loadRAGAnswerGroundingCaseDifficultyHistory = async ({\n store,\n suite,\n limit = DEFAULT_HISTORY_LIMIT,\n}: {\n store: RAGAnswerGroundingCaseDifficultyHistoryStore;\n suite: Pick<RAGEvaluationSuite, \"id\" | \"label\">;\n limit?: number;\n}): Promise<RAGAnswerGroundingCaseDifficultyHistory> => {\n const runs = normalizeGroundingDifficultyHistoryRuns(\n await Promise.resolve(\n store.listRuns({\n limit,\n suiteId: suite.id,\n }),\n ),\n );\n const latestRun = runs[0];\n const previousRun = runs[1];\n\n return {\n diff:\n latestRun && previousRun\n ? buildRAGAnswerGroundingCaseDifficultyRunDiff({\n current: latestRun,\n previous: previousRun,\n })\n : undefined,\n latestRun,\n previousRun,\n runs,\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n trends: buildRAGAnswerGroundingCaseDifficultyTrends({ runs }),\n };\n};\n\nexport const persistRAGEvaluationSuiteRun = async ({\n store,\n run,\n}: {\n store: RAGEvaluationHistoryStore;\n run: RAGEvaluationSuiteRun;\n}) => {\n await Promise.resolve(store.saveRun(run));\n return run;\n};\n\nexport const persistRAGAnswerGroundingEvaluationRun = async ({\n store,\n run,\n}: {\n store: RAGAnswerGroundingEvaluationHistoryStore;\n run: RAGAnswerGroundingEvaluationRun;\n}) => {\n await Promise.resolve(store.saveRun(run));\n return run;\n};\n\nexport const persistRAGAnswerGroundingCaseDifficultyRun = async ({\n store,\n run,\n}: {\n store: RAGAnswerGroundingCaseDifficultyHistoryStore;\n run: RAGAnswerGroundingCaseDifficultyRun;\n}) => {\n await Promise.resolve(store.saveRun(run));\n return run;\n};\n\nexport const persistRAGSearchTraceRecord = async ({\n store,\n record,\n}: {\n store: RAGSearchTraceStore;\n record: RAGSearchTraceRecord;\n}) => {\n await Promise.resolve(store.saveTrace(record));\n return record;\n};\n\nexport const pruneRAGSearchTraceStore = async ({\n store,\n input,\n}: {\n store: RAGSearchTraceStore;\n input?: RAGSearchTracePruneInput;\n}): Promise<RAGSearchTracePruneResult> =>\n Promise.resolve(store.pruneTraces(input));\n\nexport const persistRAGSearchTracePruneRun = async ({\n store,\n run,\n}: {\n store: RAGSearchTracePruneHistoryStore;\n run: RAGSearchTracePruneRun;\n}) => {\n await Promise.resolve(store.saveRun(run));\n return run;\n};\n\nexport const persistRAGRetrievalComparisonRun = async ({\n store,\n run,\n}: {\n store: RAGRetrievalComparisonHistoryStore;\n run: RAGRetrievalComparisonRun;\n}) => {\n await Promise.resolve(store.saveRun(run));\n return run;\n};\n\nexport const buildRAGRetrievalComparisonDecisionSummary = ({\n comparison,\n baselineRetrievalId,\n candidateRetrievalId,\n policy,\n}: {\n comparison: RAGRetrievalComparison;\n baselineRetrievalId?: string;\n candidateRetrievalId?: string;\n policy?: RAGRetrievalBaselineGatePolicy;\n}): RAGRetrievalComparisonDecisionSummary | undefined => {\n const baselineEntry =\n findRetrievalComparisonEntry(comparison, baselineRetrievalId) ??\n comparison.entries[0];\n const candidateEntry =\n findRetrievalComparisonEntry(comparison, candidateRetrievalId) ??\n comparison.entries.find(\n (entry) => entry.retrievalId !== baselineEntry?.retrievalId,\n ) ??\n comparison.entries[1];\n\n if (!baselineEntry && !candidateEntry) {\n return undefined;\n }\n\n const delta =\n baselineEntry && candidateEntry\n ? {\n averageF1Delta:\n candidateEntry.response.summary.averageF1 -\n baselineEntry.response.summary.averageF1,\n elapsedMsDelta:\n candidateEntry.response.elapsedMs -\n baselineEntry.response.elapsedMs,\n passingRateDelta:\n candidateEntry.response.passingRate -\n baselineEntry.response.passingRate,\n ...(countPresentationCueCases(baselineEntry, \"title\") > 0 ||\n countPresentationCueCases(candidateEntry, \"title\") > 0\n ? {\n presentationTitleCueCasesDelta:\n countPresentationCueCases(candidateEntry, \"title\") -\n countPresentationCueCases(baselineEntry, \"title\"),\n }\n : {}),\n ...(countPresentationCueCases(baselineEntry, \"body\") > 0 ||\n countPresentationCueCases(candidateEntry, \"body\") > 0\n ? {\n presentationBodyCueCasesDelta:\n countPresentationCueCases(candidateEntry, \"body\") -\n countPresentationCueCases(baselineEntry, \"body\"),\n }\n : {}),\n ...(countPresentationCueCases(baselineEntry, \"notes\") > 0 ||\n countPresentationCueCases(candidateEntry, \"notes\") > 0\n ? {\n presentationNotesCueCasesDelta:\n countPresentationCueCases(candidateEntry, \"notes\") -\n countPresentationCueCases(baselineEntry, \"notes\"),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"sheet\") > 0 ||\n countSpreadsheetCueCases(candidateEntry, \"sheet\") > 0\n ? {\n spreadsheetSheetCueCasesDelta:\n countSpreadsheetCueCases(candidateEntry, \"sheet\") -\n countSpreadsheetCueCases(baselineEntry, \"sheet\"),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"table\") > 0 ||\n countSpreadsheetCueCases(candidateEntry, \"table\") > 0\n ? {\n spreadsheetTableCueCasesDelta:\n countSpreadsheetCueCases(candidateEntry, \"table\") -\n countSpreadsheetCueCases(baselineEntry, \"table\"),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"column\") > 0 ||\n countSpreadsheetCueCases(candidateEntry, \"column\") > 0\n ? {\n spreadsheetColumnCueCasesDelta:\n countSpreadsheetCueCases(candidateEntry, \"column\") -\n countSpreadsheetCueCases(baselineEntry, \"column\"),\n }\n : {}),\n multiVectorCollapsedCasesDelta:\n (candidateEntry.traceSummary?.multiVectorCollapsedCases ?? 0) -\n (baselineEntry.traceSummary?.multiVectorCollapsedCases ?? 0),\n multiVectorLexicalHitCasesDelta:\n (candidateEntry.traceSummary?.multiVectorLexicalHitCases ?? 0) -\n (baselineEntry.traceSummary?.multiVectorLexicalHitCases ?? 0),\n multiVectorVectorHitCasesDelta:\n (candidateEntry.traceSummary?.multiVectorVectorHitCases ?? 0) -\n (baselineEntry.traceSummary?.multiVectorVectorHitCases ?? 0),\n evidenceReconcileCasesDelta:\n (candidateEntry.traceSummary?.stageCounts?.evidence_reconcile ??\n 0) -\n (baselineEntry.traceSummary?.stageCounts?.evidence_reconcile ?? 0),\n officeEvidenceReconcileCasesDelta:\n (candidateEntry.traceSummary?.officeEvidenceReconcileCases ?? 0) -\n (baselineEntry.traceSummary?.officeEvidenceReconcileCases ?? 0),\n pdfEvidenceReconcileCasesDelta:\n (candidateEntry.traceSummary?.pdfEvidenceReconcileCases ?? 0) -\n (baselineEntry.traceSummary?.pdfEvidenceReconcileCases ?? 0),\n runtimeCandidateBudgetExhaustedCasesDelta:\n (candidateEntry.traceSummary\n ?.runtimeCandidateBudgetExhaustedCases ?? 0) -\n (baselineEntry.traceSummary?.runtimeCandidateBudgetExhaustedCases ??\n 0),\n runtimeUnderfilledTopKCasesDelta:\n (candidateEntry.traceSummary?.runtimeUnderfilledTopKCases ?? 0) -\n (baselineEntry.traceSummary?.runtimeUnderfilledTopKCases ?? 0),\n }\n : undefined;\n\n return {\n baseline: baselineEntry\n ? {\n averageF1: baselineEntry.response.summary.averageF1,\n elapsedMs: baselineEntry.response.elapsedMs,\n label: baselineEntry.label,\n ...(countPresentationCueCases(baselineEntry, \"title\") > 0\n ? {\n presentationTitleCueCases: countPresentationCueCases(\n baselineEntry,\n \"title\",\n ),\n }\n : {}),\n ...(countPresentationCueCases(baselineEntry, \"body\") > 0\n ? {\n presentationBodyCueCases: countPresentationCueCases(\n baselineEntry,\n \"body\",\n ),\n }\n : {}),\n ...(countPresentationCueCases(baselineEntry, \"notes\") > 0\n ? {\n presentationNotesCueCases: countPresentationCueCases(\n baselineEntry,\n \"notes\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"sheet\") > 0\n ? {\n spreadsheetSheetCueCases: countSpreadsheetCueCases(\n baselineEntry,\n \"sheet\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"table\") > 0\n ? {\n spreadsheetTableCueCases: countSpreadsheetCueCases(\n baselineEntry,\n \"table\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(baselineEntry, \"column\") > 0\n ? {\n spreadsheetColumnCueCases: countSpreadsheetCueCases(\n baselineEntry,\n \"column\",\n ),\n }\n : {}),\n multiVectorCollapsedCases:\n baselineEntry.traceSummary?.multiVectorCollapsedCases,\n multiVectorLexicalHitCases:\n baselineEntry.traceSummary?.multiVectorLexicalHitCases,\n multiVectorVectorHitCases:\n baselineEntry.traceSummary?.multiVectorVectorHitCases,\n evidenceReconcileCases:\n baselineEntry.traceSummary?.stageCounts?.evidence_reconcile,\n officeEvidenceReconcileCases:\n baselineEntry.traceSummary?.officeEvidenceReconcileCases,\n pdfEvidenceReconcileCases:\n baselineEntry.traceSummary?.pdfEvidenceReconcileCases,\n runtimeCandidateBudgetExhaustedCases:\n baselineEntry.traceSummary?.runtimeCandidateBudgetExhaustedCases,\n runtimeUnderfilledTopKCases:\n baselineEntry.traceSummary?.runtimeUnderfilledTopKCases,\n passingRate: baselineEntry.response.passingRate,\n retrievalId: baselineEntry.retrievalId,\n }\n : undefined,\n baselineRetrievalId: baselineEntry?.retrievalId,\n candidate: candidateEntry\n ? {\n averageF1: candidateEntry.response.summary.averageF1,\n elapsedMs: candidateEntry.response.elapsedMs,\n label: candidateEntry.label,\n ...(countPresentationCueCases(candidateEntry, \"title\") > 0\n ? {\n presentationTitleCueCases: countPresentationCueCases(\n candidateEntry,\n \"title\",\n ),\n }\n : {}),\n ...(countPresentationCueCases(candidateEntry, \"body\") > 0\n ? {\n presentationBodyCueCases: countPresentationCueCases(\n candidateEntry,\n \"body\",\n ),\n }\n : {}),\n ...(countPresentationCueCases(candidateEntry, \"notes\") > 0\n ? {\n presentationNotesCueCases: countPresentationCueCases(\n candidateEntry,\n \"notes\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(candidateEntry, \"sheet\") > 0\n ? {\n spreadsheetSheetCueCases: countSpreadsheetCueCases(\n candidateEntry,\n \"sheet\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(candidateEntry, \"table\") > 0\n ? {\n spreadsheetTableCueCases: countSpreadsheetCueCases(\n candidateEntry,\n \"table\",\n ),\n }\n : {}),\n ...(countSpreadsheetCueCases(candidateEntry, \"column\") > 0\n ? {\n spreadsheetColumnCueCases: countSpreadsheetCueCases(\n candidateEntry,\n \"column\",\n ),\n }\n : {}),\n multiVectorCollapsedCases:\n candidateEntry.traceSummary?.multiVectorCollapsedCases,\n multiVectorLexicalHitCases:\n candidateEntry.traceSummary?.multiVectorLexicalHitCases,\n multiVectorVectorHitCases:\n candidateEntry.traceSummary?.multiVectorVectorHitCases,\n evidenceReconcileCases:\n candidateEntry.traceSummary?.stageCounts?.evidence_reconcile,\n officeEvidenceReconcileCases:\n candidateEntry.traceSummary?.officeEvidenceReconcileCases,\n pdfEvidenceReconcileCases:\n candidateEntry.traceSummary?.pdfEvidenceReconcileCases,\n runtimeCandidateBudgetExhaustedCases:\n candidateEntry.traceSummary?.runtimeCandidateBudgetExhaustedCases,\n runtimeUnderfilledTopKCases:\n candidateEntry.traceSummary?.runtimeUnderfilledTopKCases,\n passingRate: candidateEntry.response.passingRate,\n retrievalId: candidateEntry.retrievalId,\n }\n : undefined,\n candidateRetrievalId: candidateEntry?.retrievalId,\n delta,\n fastest: comparison.summary.fastest,\n gate: evaluateRetrievalComparisonGate({ delta, policy }),\n winnerByAverageF1: comparison.summary.bestByAverageF1,\n winnerByPassingRate: comparison.summary.bestByPassingRate,\n ...(comparison.summary.bestByPresentationTitleCueCases\n ? {\n winnerByPresentationTitleCueCases:\n comparison.summary.bestByPresentationTitleCueCases,\n }\n : {}),\n ...(comparison.summary.bestByPresentationBodyCueCases\n ? {\n winnerByPresentationBodyCueCases:\n comparison.summary.bestByPresentationBodyCueCases,\n }\n : {}),\n ...(comparison.summary.bestByPresentationNotesCueCases\n ? {\n winnerByPresentationNotesCueCases:\n comparison.summary.bestByPresentationNotesCueCases,\n }\n : {}),\n ...(comparison.summary.bestBySpreadsheetSheetCueCases\n ? {\n winnerBySpreadsheetSheetCueCases:\n comparison.summary.bestBySpreadsheetSheetCueCases,\n }\n : {}),\n ...(comparison.summary.bestBySpreadsheetTableCueCases\n ? {\n winnerBySpreadsheetTableCueCases:\n comparison.summary.bestBySpreadsheetTableCueCases,\n }\n : {}),\n ...(comparison.summary.bestBySpreadsheetColumnCueCases\n ? {\n winnerBySpreadsheetColumnCueCases:\n comparison.summary.bestBySpreadsheetColumnCueCases,\n }\n : {}),\n winnerByMultivectorCollapsedCases:\n comparison.summary.bestByMultivectorCollapsedCases,\n winnerByMultivectorLexicalHitCases:\n comparison.summary.bestByMultivectorLexicalHitCases,\n winnerByMultivectorVectorHitCases:\n comparison.summary.bestByMultivectorVectorHitCases,\n winnerByEvidenceReconcileCases:\n comparison.summary.bestByEvidenceReconcileCases,\n winnerByOfficeEvidenceReconcileCases:\n comparison.summary.bestByOfficeEvidenceReconcileCases,\n winnerByPDFEvidenceReconcileCases:\n comparison.summary.bestByPDFEvidenceReconcileCases,\n winnerByLowestRuntimeCandidateBudgetExhaustedCases:\n comparison.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases,\n winnerByLowestRuntimeUnderfilledTopKCases:\n comparison.summary.bestByLowestRuntimeUnderfilledTopKCases,\n };\n};\n\nexport const loadRAGSearchTracePruneHistory = async ({\n store,\n limit,\n trigger,\n}: {\n store: RAGSearchTracePruneHistoryStore;\n limit?: number;\n trigger?: RAGSearchTracePruneRun[\"trigger\"];\n}) =>\n normalizeSearchTracePruneRuns(\n await Promise.resolve(store.listRuns({ limit, trigger })),\n );\n\nexport const loadRAGRetrievalComparisonHistory = async ({\n store,\n limit,\n suiteId,\n label,\n winnerId,\n corpusGroupKey,\n groupKey,\n tag,\n}: {\n store: RAGRetrievalComparisonHistoryStore;\n limit?: number;\n suiteId?: string;\n label?: string;\n winnerId?: string;\n corpusGroupKey?: string;\n groupKey?: string;\n tag?: string;\n}) =>\n normalizeRetrievalComparisonRuns(\n await Promise.resolve(\n store.listRuns({\n corpusGroupKey,\n groupKey,\n label,\n limit,\n suiteId,\n tag,\n winnerId,\n }),\n ),\n );\n\nexport const loadRAGRetrievalBaselines = async ({\n store,\n corpusGroupKey,\n groupKey,\n tag,\n limit,\n status,\n}: {\n store: RAGRetrievalBaselineStore;\n corpusGroupKey?: string;\n groupKey?: string;\n tag?: string;\n limit?: number;\n status?: RAGRetrievalBaselineRecord[\"status\"];\n}) =>\n normalizeRetrievalBaselineRecords(\n await Promise.resolve(\n store.listBaselines({\n corpusGroupKey,\n groupKey,\n limit,\n status,\n tag,\n }),\n ),\n );\n\nexport const persistRAGRetrievalBaseline = async ({\n store,\n record,\n}: {\n store: RAGRetrievalBaselineStore;\n record: RAGRetrievalBaselineRecord;\n}) => {\n await Promise.resolve(store.saveBaseline(record));\n return record;\n};\n\nexport const loadRAGRetrievalReleaseDecisions = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n kind,\n}: {\n store: RAGRetrievalReleaseDecisionStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n kind?: RAGRetrievalReleaseDecisionRecord[\"kind\"];\n}) =>\n normalizeRetrievalReleaseDecisionRecords(\n await Promise.resolve(\n store.listDecisions({ corpusGroupKey, groupKey, kind, limit }),\n ),\n );\n\nexport const loadRAGRetrievalLaneHandoffDecisions = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n kind,\n sourceRolloutLabel,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalLaneHandoffDecisionStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n kind?: RAGRetrievalLaneHandoffDecisionRecord[\"kind\"];\n sourceRolloutLabel?: RAGRetrievalLaneHandoffDecisionRecord[\"sourceRolloutLabel\"];\n targetRolloutLabel?: RAGRetrievalLaneHandoffDecisionRecord[\"targetRolloutLabel\"];\n}) =>\n normalizeRetrievalLaneHandoffDecisionRecords(\n await Promise.resolve(\n store.listDecisions({\n corpusGroupKey,\n groupKey,\n kind,\n limit,\n sourceRolloutLabel,\n targetRolloutLabel,\n }),\n ),\n );\n\nexport const loadRAGRetrievalReleaseIncidents = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n targetRolloutLabel,\n status,\n severity,\n}: {\n store: RAGRetrievalReleaseIncidentStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalReleaseIncidentRecord[\"targetRolloutLabel\"];\n status?: RAGRetrievalReleaseIncidentRecord[\"status\"];\n severity?: RAGRetrievalReleaseIncidentRecord[\"severity\"];\n}) =>\n normalizeRetrievalReleaseIncidentRecords(\n await Promise.resolve(\n store.listIncidents({\n corpusGroupKey,\n groupKey,\n limit,\n severity,\n status,\n targetRolloutLabel,\n }),\n ),\n );\n\nexport const loadRAGRetrievalLaneHandoffIncidents = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n targetRolloutLabel,\n status,\n severity,\n}: {\n store: RAGRetrievalLaneHandoffIncidentStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalLaneHandoffIncidentRecord[\"targetRolloutLabel\"];\n status?: RAGRetrievalLaneHandoffIncidentRecord[\"status\"];\n severity?: RAGRetrievalLaneHandoffIncidentRecord[\"severity\"];\n}) =>\n normalizeRetrievalReleaseIncidentRecords(\n (await Promise.resolve(\n store.listIncidents({\n corpusGroupKey,\n groupKey,\n limit,\n severity,\n status,\n targetRolloutLabel,\n }),\n )) as RAGRetrievalReleaseIncidentRecord[],\n ) as RAGRetrievalLaneHandoffIncidentRecord[];\n\nexport const loadRAGRetrievalLaneHandoffIncidentHistory = async ({\n store,\n corpusGroupKey,\n action,\n groupKey,\n incidentId,\n limit,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalLaneHandoffIncidentHistoryStore;\n corpusGroupKey?: string;\n action?: RAGRetrievalLaneHandoffIncidentHistoryRecord[\"action\"];\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalLaneHandoffIncidentRecord[\"targetRolloutLabel\"];\n}) =>\n (await Promise.resolve(\n store.listRecords({\n corpusGroupKey,\n action,\n groupKey,\n incidentId,\n limit,\n targetRolloutLabel,\n }),\n )) as RAGRetrievalLaneHandoffIncidentHistoryRecord[];\n\nexport const loadRAGRetrievalIncidentRemediationDecisions = async ({\n store,\n groupKey,\n incidentId,\n limit,\n remediationKind,\n status,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalIncidentRemediationDecisionStore;\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n remediationKind?: RAGRetrievalIncidentRemediationDecisionRecord[\"remediationKind\"];\n status?: RAGRetrievalIncidentRemediationDecisionRecord[\"status\"];\n targetRolloutLabel?: RAGRetrievalIncidentRemediationDecisionRecord[\"targetRolloutLabel\"];\n}) =>\n normalizeRetrievalIncidentRemediationDecisionRecords(\n await Promise.resolve(\n store.listRecords({\n groupKey,\n incidentId,\n limit,\n remediationKind,\n status,\n targetRolloutLabel,\n }),\n ),\n );\n\nexport const loadRAGRetrievalIncidentRemediationExecutionHistory = async ({\n store,\n actionKind,\n blockedByGuardrail,\n code,\n groupKey,\n idempotentReplay,\n incidentId,\n limit,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalIncidentRemediationExecutionHistoryStore;\n actionKind?: RAGRemediationAction[\"kind\"];\n blockedByGuardrail?: boolean;\n code?: RAGRetrievalIncidentRemediationExecutionHistoryRecord[\"code\"];\n groupKey?: string;\n idempotentReplay?: boolean;\n incidentId?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalIncidentRemediationExecutionHistoryRecord[\"targetRolloutLabel\"];\n}) =>\n normalizeRetrievalIncidentRemediationExecutionHistoryRecords(\n await Promise.resolve(\n store.listRecords({\n actionKind,\n blockedByGuardrail,\n code,\n groupKey,\n idempotentReplay,\n incidentId,\n limit,\n targetRolloutLabel,\n }),\n ),\n );\n\nexport const loadRAGRetrievalLaneHandoffAutoCompletePolicyHistory = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord[\"targetRolloutLabel\"];\n}) =>\n (await Promise.resolve(\n store.listRecords({\n corpusGroupKey,\n groupKey,\n limit,\n targetRolloutLabel,\n }),\n )) as RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalReleaseLanePolicyHistory = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n rolloutLabel,\n scope,\n}: {\n store: RAGRetrievalReleaseLanePolicyHistoryStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n rolloutLabel?: RAGRetrievalReleaseLanePolicyHistoryRecord[\"rolloutLabel\"];\n scope?: RAGRetrievalReleaseLanePolicyHistoryRecord[\"scope\"];\n}) =>\n (await Promise.resolve(\n store.listRecords({\n corpusGroupKey,\n groupKey,\n limit,\n rolloutLabel,\n scope,\n }),\n )) as RAGRetrievalReleaseLanePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalBaselineGatePolicyHistory = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n rolloutLabel,\n scope,\n}: {\n store: RAGRetrievalBaselineGatePolicyHistoryStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n rolloutLabel?: RAGRetrievalBaselineGatePolicyHistoryRecord[\"rolloutLabel\"];\n scope?: RAGRetrievalBaselineGatePolicyHistoryRecord[\"scope\"];\n}) =>\n (await Promise.resolve(\n store.listRecords({\n corpusGroupKey,\n groupKey,\n limit,\n rolloutLabel,\n scope,\n }),\n )) as RAGRetrievalBaselineGatePolicyHistoryRecord[];\n\nexport const loadRAGRetrievalReleaseLaneEscalationPolicyHistory = async ({\n store,\n corpusGroupKey,\n groupKey,\n limit,\n targetRolloutLabel,\n}: {\n store: RAGRetrievalReleaseLaneEscalationPolicyHistoryStore;\n corpusGroupKey?: string;\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord[\"targetRolloutLabel\"];\n}) =>\n (await Promise.resolve(\n store.listRecords({\n groupKey,\n limit,\n targetRolloutLabel,\n }),\n )) as RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord[];\n\nexport const persistRAGRetrievalReleaseDecision = async ({\n store,\n record,\n}: {\n store: RAGRetrievalReleaseDecisionStore;\n record: RAGRetrievalReleaseDecisionRecord;\n}) => {\n await Promise.resolve(store.saveDecision(record));\n return record;\n};\n\nexport const persistRAGRetrievalLaneHandoffDecision = async ({\n store,\n record,\n}: {\n store: RAGRetrievalLaneHandoffDecisionStore;\n record: RAGRetrievalLaneHandoffDecisionRecord;\n}) => {\n await Promise.resolve(store.saveDecision(record));\n return record;\n};\n\nexport const persistRAGRetrievalReleaseIncident = async ({\n store,\n record,\n}: {\n store: RAGRetrievalReleaseIncidentStore;\n record: RAGRetrievalReleaseIncidentRecord;\n}) => {\n await Promise.resolve(store.saveIncident(record));\n return record;\n};\n\nexport const persistRAGRetrievalLaneHandoffIncident = async ({\n store,\n record,\n}: {\n store: RAGRetrievalLaneHandoffIncidentStore;\n record: RAGRetrievalLaneHandoffIncidentRecord;\n}) => {\n await Promise.resolve(store.saveIncident(record));\n return record;\n};\n\nexport const persistRAGRetrievalIncidentRemediationDecision = async ({\n store,\n record,\n}: {\n store: RAGRetrievalIncidentRemediationDecisionStore;\n record: RAGRetrievalIncidentRemediationDecisionRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalIncidentRemediationExecutionHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalIncidentRemediationExecutionHistoryStore;\n record: RAGRetrievalIncidentRemediationExecutionHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalLaneHandoffIncidentHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalLaneHandoffIncidentHistoryStore;\n record: RAGRetrievalLaneHandoffIncidentHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalLaneHandoffAutoCompletePolicyHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryStore;\n record: RAGRetrievalLaneHandoffAutoCompletePolicyHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalReleaseLanePolicyHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalReleaseLanePolicyHistoryStore;\n record: RAGRetrievalReleaseLanePolicyHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalBaselineGatePolicyHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalBaselineGatePolicyHistoryStore;\n record: RAGRetrievalBaselineGatePolicyHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const persistRAGRetrievalReleaseLaneEscalationPolicyHistory = async ({\n store,\n record,\n}: {\n store: RAGRetrievalReleaseLaneEscalationPolicyHistoryStore;\n record: RAGRetrievalReleaseLaneEscalationPolicyHistoryRecord;\n}) => {\n await Promise.resolve(store.saveRecord(record));\n return record;\n};\n\nexport const createRAGSQLiteGovernanceStores = (\n options: SQLiteRAGGovernanceStoreBundleOptions = {},\n): Pick<\n RAGChatPluginConfig,\n | \"searchTraceStore\"\n | \"searchTracePruneHistoryStore\"\n | \"retrievalComparisonHistoryStore\"\n | \"retrievalBaselineStore\"\n | \"retrievalReleaseDecisionStore\"\n | \"retrievalLaneHandoffDecisionStore\"\n | \"retrievalLaneHandoffIncidentStore\"\n | \"retrievalLaneHandoffIncidentHistoryStore\"\n | \"retrievalLaneHandoffAutoCompletePolicyHistoryStore\"\n | \"retrievalReleaseLanePolicyHistoryStore\"\n | \"retrievalBaselineGatePolicyHistoryStore\"\n | \"retrievalReleaseLaneEscalationPolicyHistoryStore\"\n | \"retrievalReleaseIncidentStore\"\n | \"retrievalIncidentRemediationDecisionStore\"\n | \"retrievalIncidentRemediationExecutionHistoryStore\"\n> => {\n const prefix = options.tablePrefix?.trim();\n const table = (suffix: string) =>\n prefix && prefix.length > 0 ? `${prefix}_${suffix}` : suffix;\n\n return {\n searchTraceStore: createRAGSQLiteSearchTraceStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_search_traces\"),\n }),\n searchTracePruneHistoryStore: createRAGSQLiteSearchTracePruneHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_search_trace_prune_history\"),\n }),\n retrievalComparisonHistoryStore:\n createRAGSQLiteRetrievalComparisonHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_comparison_history\"),\n }),\n retrievalBaselineStore: createRAGSQLiteRetrievalBaselineStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_baselines\"),\n }),\n retrievalReleaseDecisionStore: createRAGSQLiteRetrievalReleaseDecisionStore(\n {\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_release_decisions\"),\n },\n ),\n retrievalLaneHandoffDecisionStore:\n createRAGSQLiteRetrievalLaneHandoffDecisionStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_lane_handoff_decisions\"),\n }),\n retrievalLaneHandoffIncidentStore:\n createRAGSQLiteRetrievalLaneHandoffIncidentStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_lane_handoff_incidents\"),\n }),\n retrievalLaneHandoffIncidentHistoryStore:\n createRAGSQLiteRetrievalLaneHandoffIncidentHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_lane_handoff_incident_history\"),\n }),\n retrievalLaneHandoffAutoCompletePolicyHistoryStore:\n createRAGSQLiteRetrievalLaneHandoffAutoCompletePolicyHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\n \"rag_retrieval_lane_handoff_auto_complete_policy_history\",\n ),\n }),\n retrievalReleaseLanePolicyHistoryStore:\n createRAGSQLiteRetrievalReleaseLanePolicyHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_release_lane_policy_history\"),\n }),\n retrievalBaselineGatePolicyHistoryStore:\n createRAGSQLiteRetrievalBaselineGatePolicyHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_baseline_gate_policy_history\"),\n }),\n retrievalReleaseLaneEscalationPolicyHistoryStore:\n createRAGSQLiteRetrievalReleaseLaneEscalationPolicyHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\n \"rag_retrieval_release_lane_escalation_policy_history\",\n ),\n }),\n retrievalReleaseIncidentStore: createRAGSQLiteRetrievalReleaseIncidentStore(\n {\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_release_incidents\"),\n },\n ),\n retrievalIncidentRemediationDecisionStore:\n createRAGSQLiteRetrievalIncidentRemediationDecisionStore({\n db: options.db,\n path: options.path,\n tableName: table(\"rag_retrieval_incident_remediation_decisions\"),\n }),\n retrievalIncidentRemediationExecutionHistoryStore:\n createRAGSQLiteRetrievalIncidentRemediationExecutionHistoryStore({\n db: options.db,\n path: options.path,\n tableName: table(\n \"rag_retrieval_incident_remediation_execution_history\",\n ),\n }),\n };\n};\n\nexport const buildRAGEvaluationResponse = (\n cases: RAGEvaluationCaseResult[],\n): RAGEvaluationResponse => {\n const totalCases = cases.length;\n const corpusKeys = [\n ...new Set(cases.flatMap((entry) => entry.corpusKey ?? [])),\n ];\n const passedCases = cases.filter((entry) => entry.status === \"pass\").length;\n const partialCases = cases.filter(\n (entry) => entry.status === \"partial\",\n ).length;\n const failedCases = cases.filter((entry) => entry.status === \"fail\").length;\n\n return {\n cases,\n ...(corpusKeys.length > 0 ? { corpusKeys } : {}),\n elapsedMs: cases.reduce((sum, result) => sum + result.elapsedMs, 0),\n ok: true,\n passingRate: totalCases > 0 ? (passedCases / totalCases) * 100 : 0,\n summary: {\n averageF1:\n cases.reduce((sum, result) => sum + result.f1, 0) / (totalCases || 1),\n averageLatencyMs:\n cases.reduce((sum, result) => sum + result.elapsedMs, 0) /\n (totalCases || 1),\n averagePrecision:\n cases.reduce((sum, result) => sum + result.precision, 0) /\n (totalCases || 1),\n averageRecall:\n cases.reduce((sum, result) => sum + result.recall, 0) /\n (totalCases || 1),\n failedCases,\n partialCases,\n passedCases,\n totalCases,\n },\n totalCases,\n };\n};\n\nconst incrementFailureCounts = (\n target: Record<string, number>,\n failureClasses: string[] | undefined,\n) => {\n for (const failureClass of failureClasses ?? []) {\n target[failureClass] = (target[failureClass] ?? 0) + 1;\n }\n};\n\nconst sortEntityQualitySummaries = <\n T extends { passingRate: number; totalCases: number; label: string },\n>(\n entries: T[],\n) =>\n entries.sort((left, right) => {\n if (right.passingRate !== left.passingRate) {\n return right.passingRate - left.passingRate;\n }\n if (right.totalCases !== left.totalCases) {\n return right.totalCases - left.totalCases;\n }\n\n return left.label.localeCompare(right.label);\n });\n\nexport const buildRAGEvaluationEntityQualityView = (\n response: RAGEvaluationResponse,\n): RAGEvaluationEntityQualityView => {\n const bySource = new Map<string, RAGEvaluationEntityQualitySummary>();\n const byDocument = new Map<string, RAGEvaluationEntityQualitySummary>();\n for (const entry of response.cases) {\n const targets =\n entry.mode === \"source\"\n ? entry.expectedIds\n : entry.mode === \"documentId\"\n ? entry.expectedIds\n : [];\n const targetMap =\n entry.mode === \"source\"\n ? bySource\n : entry.mode === \"documentId\"\n ? byDocument\n : undefined;\n if (!targetMap) {\n continue;\n }\n for (const target of targets) {\n const current =\n targetMap.get(target) ??\n ({\n averageF1: 0,\n caseIds: [],\n entityType: entry.mode === \"source\" ? \"source\" : \"document\",\n failedCases: 0,\n failureCounts: {},\n key: target,\n label: target,\n passedCases: 0,\n passingRate: 0,\n partialCases: 0,\n totalCases: 0,\n } satisfies RAGEvaluationEntityQualitySummary);\n current.totalCases += 1;\n current.averageF1 += entry.f1;\n current.caseIds.push(entry.caseId);\n if (entry.status === \"pass\") {\n current.passedCases += 1;\n } else if (entry.status === \"partial\") {\n current.partialCases += 1;\n } else {\n current.failedCases += 1;\n }\n incrementFailureCounts(current.failureCounts, entry.failureClasses);\n targetMap.set(target, current);\n }\n }\n\n for (const map of [bySource, byDocument]) {\n for (const entry of map.values()) {\n entry.averageF1 =\n entry.totalCases > 0 ? entry.averageF1 / entry.totalCases : 0;\n entry.passingRate =\n entry.totalCases > 0 ? (entry.passedCases / entry.totalCases) * 100 : 0;\n }\n }\n\n return {\n byDocument: sortEntityQualitySummaries([...byDocument.values()]),\n bySource: sortEntityQualitySummaries([...bySource.values()]),\n };\n};\n\nexport const buildRAGAnswerGroundingEntityQualityView = (\n response: RAGAnswerGroundingEvaluationResponse,\n): RAGAnswerGroundingEntityQualityView => {\n const bySource = new Map<string, RAGAnswerGroundingEntityQualitySummary>();\n const byDocument = new Map<string, RAGAnswerGroundingEntityQualitySummary>();\n for (const entry of response.cases) {\n const targetMap =\n entry.mode === \"source\"\n ? bySource\n : entry.mode === \"documentId\"\n ? byDocument\n : undefined;\n if (!targetMap) {\n continue;\n }\n for (const target of entry.expectedIds) {\n const current =\n targetMap.get(target) ??\n ({\n averageCitationF1: 0,\n averageResolvedCitationRate: 0,\n caseIds: [],\n entityType: entry.mode === \"source\" ? \"source\" : \"document\",\n failedCases: 0,\n failureCounts: {},\n key: target,\n label: target,\n passedCases: 0,\n passingRate: 0,\n partialCases: 0,\n totalCases: 0,\n } satisfies RAGAnswerGroundingEntityQualitySummary);\n current.totalCases += 1;\n current.averageCitationF1 += entry.citationF1;\n current.averageResolvedCitationRate += entry.resolvedCitationRate;\n current.caseIds.push(entry.caseId);\n if (entry.status === \"pass\") {\n current.passedCases += 1;\n } else if (entry.status === \"partial\") {\n current.partialCases += 1;\n } else {\n current.failedCases += 1;\n }\n incrementFailureCounts(current.failureCounts, entry.failureClasses);\n targetMap.set(target, current);\n }\n }\n\n for (const map of [bySource, byDocument]) {\n for (const entry of map.values()) {\n entry.averageCitationF1 =\n entry.totalCases > 0 ? entry.averageCitationF1 / entry.totalCases : 0;\n entry.averageResolvedCitationRate =\n entry.totalCases > 0\n ? entry.averageResolvedCitationRate / entry.totalCases\n : 0;\n entry.passingRate =\n entry.totalCases > 0 ? (entry.passedCases / entry.totalCases) * 100 : 0;\n }\n }\n\n return {\n byDocument: sortEntityQualitySummaries([...byDocument.values()]),\n bySource: sortEntityQualitySummaries([...bySource.values()]),\n };\n};\n\nexport const evaluateRAGAnswerGroundingCase = ({\n caseIndex,\n caseInput,\n}: {\n caseIndex: number;\n caseInput: RAGAnswerGroundingEvaluationCase;\n}): RAGAnswerGroundingEvaluationCaseResult => {\n const mode = resolveEvaluationMode(caseInput);\n const expectedIds = normalizeExpectedIds(\n mode === \"chunkId\"\n ? (caseInput.expectedChunkIds ?? [])\n : mode === \"source\"\n ? (caseInput.expectedSources ?? [])\n : (caseInput.expectedDocumentIds ?? []),\n );\n const groundedAnswer = buildRAGGroundedAnswer(\n caseInput.answer,\n caseInput.sources,\n );\n const citedReferences = groundedAnswer.parts.flatMap((part) =>\n part.type === \"citation\" ? part.references : [],\n );\n const citedIds = normalizeExpectedIds(\n citedReferences.map((reference) => extractExpectedId(reference, mode)),\n );\n const expectedSet = new Set(expectedIds);\n const citedSet = new Set(citedIds);\n const matchedIds = normalizeExpectedIds(\n [...expectedSet].filter((id) => citedSet.has(id)),\n );\n const missingIds = normalizeExpectedIds(\n [...expectedSet].filter((id) => !citedSet.has(id)),\n );\n const extraIds = normalizeExpectedIds(\n [...citedSet].filter((id) => !expectedSet.has(id)),\n );\n const matchedCount = matchedIds.length;\n const expectedCount = expectedIds.length;\n const citedCount = citedIds.length;\n const precision = citedCount > 0 ? matchedCount / citedCount : 0;\n const recall = expectedCount > 0 ? matchedCount / expectedCount : 0;\n const citationF1 =\n precision + recall > 0\n ? (2 * precision * recall) / (precision + recall)\n : 0;\n const citationCount = groundedAnswer.parts.filter(\n (part) => part.type === \"citation\",\n ).length;\n const unresolvedCitationCount = new Set(\n groundedAnswer.ungroundedReferenceNumbers,\n ).size;\n const resolvedCitationCount = citedReferences.length;\n const resolvedCitationRate =\n citationCount > 0 ? Math.min(1, resolvedCitationCount / citationCount) : 0;\n\n return {\n answer: caseInput.answer,\n caseId: caseInput.id ?? `case-${caseIndex + 1}`,\n citationCount,\n citationF1,\n citationPrecision: precision,\n citationRecall: recall,\n citedIds,\n coverage: groundedAnswer.coverage,\n expectedCount,\n expectedIds,\n extraIds,\n groundedAnswer,\n hasCitations: groundedAnswer.hasCitations,\n label: caseInput.label,\n matchedCount,\n matchedIds,\n failureClasses: classifyRAGGroundingFailure({\n availableSources: caseInput.sources,\n citationCount,\n expectedCount,\n extraIds,\n matchedCount,\n missingIds,\n unresolvedCitationCount,\n }),\n metadata: caseInput.metadata,\n missingIds,\n mode,\n query: caseInput.query,\n referenceCount: groundedAnswer.references.length,\n resolvedCitationCount,\n resolvedCitationRate,\n status: buildAnswerGroundingStatus({\n coverage: groundedAnswer.coverage,\n expectedCount,\n matchedCount,\n resolvedCitationCount,\n unresolvedCitationCount,\n }),\n unresolvedCitationCount,\n };\n};\n\nexport const buildRAGAnswerGroundingEvaluationResponse = (\n cases: RAGAnswerGroundingEvaluationCaseResult[],\n): RAGAnswerGroundingEvaluationResponse => {\n const totalCases = cases.length;\n const passedCases = cases.filter((entry) => entry.status === \"pass\").length;\n const partialCases = cases.filter(\n (entry) => entry.status === \"partial\",\n ).length;\n const failedCases = cases.filter((entry) => entry.status === \"fail\").length;\n const groundedCases = cases.filter(\n (entry) => entry.coverage === \"grounded\",\n ).length;\n const partiallyGroundedCases = cases.filter(\n (entry) => entry.coverage === \"partial\",\n ).length;\n const ungroundedCases = cases.filter(\n (entry) => entry.coverage === \"ungrounded\",\n ).length;\n\n return {\n cases,\n ok: true,\n passingRate: totalCases > 0 ? (passedCases / totalCases) * 100 : 0,\n summary: {\n averageCitationF1:\n cases.reduce((sum, result) => sum + result.citationF1, 0) /\n (totalCases || 1),\n averageCitationPrecision:\n cases.reduce((sum, result) => sum + result.citationPrecision, 0) /\n (totalCases || 1),\n averageCitationRecall:\n cases.reduce((sum, result) => sum + result.citationRecall, 0) /\n (totalCases || 1),\n averageResolvedCitationRate:\n cases.reduce((sum, result) => sum + result.resolvedCitationRate, 0) /\n (totalCases || 1),\n failedCases,\n groundedCases,\n partiallyGroundedCases,\n passedCases,\n partialCases,\n totalCases,\n ungroundedCases,\n },\n totalCases,\n };\n};\n\nexport const evaluateRAGAnswerGrounding = (\n input: RAGAnswerGroundingEvaluationInput,\n): RAGAnswerGroundingEvaluationResponse =>\n buildRAGAnswerGroundingEvaluationResponse(\n input.cases.map((caseInput, caseIndex) =>\n evaluateRAGAnswerGroundingCase({ caseIndex, caseInput }),\n ),\n );\nexport const compareRAGRerankers = async ({\n collection,\n suite,\n rerankers,\n defaultTopK = DEFAULT_TOP_K,\n}: {\n collection: RAGCollection;\n suite: RAGEvaluationSuite;\n rerankers: RAGRerankerCandidate[];\n defaultTopK?: number;\n}): Promise<RAGRerankerComparison> => {\n const entries = await Promise.all(\n rerankers.map(async (candidate) => {\n const evaluated = await evaluateRAGCollectionCases({\n collection,\n defaultTopK,\n input: suite.input,\n includeTrace: true,\n rerank: candidate.rerank,\n });\n const response = buildRAGEvaluationResponse(\n evaluated.map((entry) => entry.caseResult),\n );\n\n return {\n caseTraceSnapshots:\n buildEvaluationCaseTraceSnapshotsFromEvaluated(evaluated),\n label: candidate.label ?? candidate.id,\n providerName:\n typeof candidate.rerank === \"function\"\n ? undefined\n : candidate.rerank?.providerName,\n response,\n rerankerId: candidate.id,\n traceSummary: summarizeRetrievalTraces(\n evaluated\n .map((entry) => entry.trace)\n .filter((trace): trace is RAGRetrievalTrace => Boolean(trace)),\n ),\n } satisfies RAGRerankerComparisonEntry;\n }),\n );\n\n const leaderboard = buildRAGEvaluationLeaderboard(\n entries.map((entry) => ({\n elapsedMs: entry.response.elapsedMs,\n finishedAt: 0,\n id: entry.rerankerId,\n label: entry.label,\n response: entry.response,\n startedAt: 0,\n suiteId: suite.id,\n traceSummary: entry.traceSummary,\n })),\n );\n\n return {\n entries,\n leaderboard,\n summary: summarizeRAGRerankerComparison(entries),\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n };\n};\nconst summarizeEvaluationResponseComparison = <\n TEntry extends {\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n) => {\n if (entries.length === 0) {\n return {};\n }\n\n const byPassingRate = [...entries].sort((left, right) => {\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const byAverageF1 = [...entries].sort(\n (left, right) =>\n right.response.summary.averageF1 - left.response.summary.averageF1,\n );\n const byLatency = [...entries].sort(\n (left, right) =>\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs,\n );\n const getId = (entry: TEntry) =>\n typeof entry[idKey] === \"string\" ? (entry[idKey] as string) : undefined;\n\n return {\n bestByAverageF1: getId(byAverageF1[0] as TEntry),\n bestByPassingRate: getId(byPassingRate[0] as TEntry),\n fastest: getId(byLatency[0] as TEntry),\n };\n};\n\nconst selectComparisonEntryByTraceMetric = <\n TEntry extends {\n traceSummary?: RAGRetrievalTraceComparisonSummary;\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n metric: keyof Pick<\n RAGRetrievalTraceComparisonSummary,\n | \"multiVectorCollapsedCases\"\n | \"multiVectorLexicalHitCases\"\n | \"multiVectorVectorHitCases\"\n | \"officeEvidenceReconcileCases\"\n | \"officeParagraphEvidenceReconcileCases\"\n | \"officeListEvidenceReconcileCases\"\n | \"officeTableEvidenceReconcileCases\"\n | \"pdfEvidenceReconcileCases\"\n >,\n) => {\n const ranked = [...entries].sort((left, right) => {\n const leftMetric = left.traceSummary?.[metric] ?? 0;\n const rightMetric = right.traceSummary?.[metric] ?? 0;\n if (rightMetric !== leftMetric) {\n return rightMetric - leftMetric;\n }\n const leftEvidenceScore =\n (left.traceSummary?.multiVectorCollapsedCases ?? 0) +\n (left.traceSummary?.multiVectorLexicalHitCases ?? 0) +\n (left.traceSummary?.multiVectorVectorHitCases ?? 0);\n const rightEvidenceScore =\n (right.traceSummary?.multiVectorCollapsedCases ?? 0) +\n (right.traceSummary?.multiVectorLexicalHitCases ?? 0) +\n (right.traceSummary?.multiVectorVectorHitCases ?? 0);\n if (rightEvidenceScore !== leftEvidenceScore) {\n return rightEvidenceScore - leftEvidenceScore;\n }\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const winner = ranked[0];\n if (!winner || (winner.traceSummary?.[metric] ?? 0) === 0) {\n return undefined;\n }\n\n return typeof winner[idKey] === \"string\"\n ? (winner[idKey] as string)\n : undefined;\n};\n\nconst selectComparisonEntryByLowestTraceMetric = <\n TEntry extends {\n traceSummary?: RAGRetrievalTraceComparisonSummary;\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n metric: keyof Pick<\n RAGRetrievalTraceComparisonSummary,\n \"runtimeCandidateBudgetExhaustedCases\" | \"runtimeUnderfilledTopKCases\"\n >,\n) => {\n const ranked = [...entries].sort((left, right) => {\n const leftMetric = left.traceSummary?.[metric] ?? 0;\n const rightMetric = right.traceSummary?.[metric] ?? 0;\n if (leftMetric !== rightMetric) {\n return leftMetric - rightMetric;\n }\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const winner = ranked[0];\n return typeof winner?.[idKey] === \"string\"\n ? (winner[idKey] as string)\n : undefined;\n};\n\nconst selectComparisonEntryByTraceStageCount = <\n TEntry extends {\n traceSummary?: RAGRetrievalTraceComparisonSummary;\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n stage: RAGRetrievalTraceStage,\n) => {\n const ranked = [...entries].sort((left, right) => {\n const leftMetric = left.traceSummary?.stageCounts?.[stage] ?? 0;\n const rightMetric = right.traceSummary?.stageCounts?.[stage] ?? 0;\n if (rightMetric !== leftMetric) {\n return rightMetric - leftMetric;\n }\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const winner = ranked[0];\n if (!winner || (winner.traceSummary?.stageCounts?.[stage] ?? 0) === 0) {\n return undefined;\n }\n\n return typeof winner?.[idKey] === \"string\"\n ? (winner[idKey] as string)\n : undefined;\n};\n\nconst countPresentationCueCases = <\n TEntry extends { caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[] },\n>(\n entry: TEntry,\n cue: \"body\" | \"notes\" | \"title\",\n) =>\n (entry.caseTraceSnapshots ?? []).filter(\n (snapshot) => snapshot.leadPresentationCue === cue,\n ).length;\n\nconst selectComparisonEntryByPresentationCueCases = <\n TEntry extends {\n caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[];\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n cue: \"body\" | \"notes\" | \"title\",\n) => {\n const ranked = [...entries].sort((left, right) => {\n const leftMetric = countPresentationCueCases(left, cue);\n const rightMetric = countPresentationCueCases(right, cue);\n if (rightMetric !== leftMetric) {\n return rightMetric - leftMetric;\n }\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const winner = ranked[0];\n if (!winner || countPresentationCueCases(winner, cue) === 0) {\n return undefined;\n }\n\n return typeof winner?.[idKey] === \"string\"\n ? (winner[idKey] as string)\n : undefined;\n};\n\nconst countSpreadsheetCueCases = <\n TEntry extends { caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[] },\n>(\n entry: TEntry,\n cue: \"column\" | \"sheet\" | \"table\",\n) =>\n (entry.caseTraceSnapshots ?? []).filter(\n (snapshot) => snapshot.leadSpreadsheetCue === cue,\n ).length;\n\nconst selectComparisonEntryBySpreadsheetCueCases = <\n TEntry extends {\n caseTraceSnapshots?: RAGEvaluationCaseTraceSnapshot[];\n response: RAGEvaluationResponse;\n [key: string]: unknown;\n },\n>(\n entries: TEntry[],\n idKey: keyof TEntry,\n cue: \"column\" | \"sheet\" | \"table\",\n) => {\n const ranked = [...entries].sort((left, right) => {\n const leftMetric = countSpreadsheetCueCases(left, cue);\n const rightMetric = countSpreadsheetCueCases(right, cue);\n if (rightMetric !== leftMetric) {\n return rightMetric - leftMetric;\n }\n if (right.response.passingRate !== left.response.passingRate) {\n return right.response.passingRate - left.response.passingRate;\n }\n if (right.response.summary.averageF1 !== left.response.summary.averageF1) {\n return right.response.summary.averageF1 - left.response.summary.averageF1;\n }\n\n return (\n left.response.summary.averageLatencyMs -\n right.response.summary.averageLatencyMs\n );\n });\n const winner = ranked[0];\n if (!winner || countSpreadsheetCueCases(winner, cue) === 0) {\n return undefined;\n }\n\n return typeof winner?.[idKey] === \"string\"\n ? (winner[idKey] as string)\n : undefined;\n};\n\nconst resolveRetrievalMode = (\n candidate: RAGRetrievalCandidate,\n): RAGHybridRetrievalMode => {\n if (!candidate.retrieval) {\n return \"vector\";\n }\n\n return typeof candidate.retrieval === \"string\"\n ? candidate.retrieval\n : (candidate.retrieval.mode ?? \"vector\");\n};\nexport const compareRAGRetrievalStrategies = async ({\n collection,\n suite,\n retrievals,\n defaultTopK = DEFAULT_TOP_K,\n}: {\n collection: RAGCollection;\n suite: RAGEvaluationSuite;\n retrievals: RAGRetrievalCandidate[];\n defaultTopK?: number;\n}): Promise<RAGRetrievalComparison> => {\n const entries = await Promise.all(\n retrievals.map(async (candidate) => {\n const tracedCollection = {\n ...collection,\n search: (input) =>\n collection.search({\n ...input,\n queryTransform: candidate.queryTransform ?? input.queryTransform,\n rerank: candidate.rerank ?? input.rerank,\n retrieval: candidate.retrieval ?? input.retrieval,\n }),\n searchWithTrace: (input) =>\n collection.searchWithTrace({\n ...input,\n queryTransform: candidate.queryTransform ?? input.queryTransform,\n rerank: candidate.rerank ?? input.rerank,\n retrieval: candidate.retrieval ?? input.retrieval,\n }),\n } satisfies RAGCollection;\n const evaluated = await evaluateRAGCollectionCases({\n collection: {\n ...tracedCollection,\n },\n defaultTopK,\n input: suite.input,\n includeTrace: true,\n rerank: candidate.rerank,\n });\n const response = buildRAGEvaluationResponse(\n evaluated.map((entry) => entry.caseResult),\n );\n\n return {\n caseTraceSnapshots:\n buildEvaluationCaseTraceSnapshotsFromEvaluated(evaluated),\n label: candidate.label ?? candidate.id,\n response,\n retrievalId: candidate.id,\n retrievalMode: resolveRetrievalMode(candidate),\n traceSummary: summarizeRetrievalTraces(\n evaluated\n .map((entry) => entry.trace)\n .filter((trace): trace is RAGRetrievalTrace => Boolean(trace)),\n ),\n } satisfies RAGRetrievalComparisonEntry;\n }),\n );\n\n const leaderboard = buildRAGEvaluationLeaderboard(\n entries.map((entry) => ({\n elapsedMs: entry.response.elapsedMs,\n finishedAt: 0,\n id: entry.retrievalId,\n label: entry.label,\n response: entry.response,\n startedAt: 0,\n suiteId: suite.id,\n traceSummary: entry.traceSummary,\n })),\n );\n\n return {\n corpusKeys: [\n ...new Set(entries.flatMap((entry) => entry.response.corpusKeys ?? [])),\n ],\n entries,\n leaderboard,\n summary: summarizeRAGRetrievalComparison(entries),\n suiteId: suite.id,\n suiteLabel: suite.label ?? suite.id,\n };\n};\n\nexport const summarizeRAGRetrievalTraces = (\n traces: RAGRetrievalTrace[],\n): RAGRetrievalTraceComparisonSummary | undefined =>\n summarizeRetrievalTraces(traces);\n\nexport const compareRAGRetrievalTraceSummaries = (\n current: RAGRetrievalTraceComparisonSummary,\n previous: RAGRetrievalTraceComparisonSummary,\n): RAGRetrievalTraceComparisonSummaryDiff => ({\n averageCandidateTopKDelta:\n current.averageCandidateTopK - previous.averageCandidateTopK,\n averageFinalCountDelta:\n current.averageFinalCount - previous.averageFinalCount,\n averageLexicalCountDelta:\n current.averageLexicalCount - previous.averageLexicalCount,\n averageLexicalTopKDelta:\n current.averageLexicalTopK - previous.averageLexicalTopK,\n averageVectorCountDelta:\n current.averageVectorCount - previous.averageVectorCount,\n balancedCasesDelta: current.balancedCases - previous.balancedCases,\n current,\n lexicalCasesDelta: current.lexicalCases - previous.lexicalCases,\n modeDelta: buildSummaryListDelta(current.modes, previous.modes),\n previous,\n roundRobinCasesDelta: current.roundRobinCases - previous.roundRobinCases,\n sourceBalanceStrategyDelta: buildSummaryListDelta(\n current.sourceBalanceStrategies,\n previous.sourceBalanceStrategies,\n ),\n stageCountsDelta: diffTraceSummaryStageCounts({\n current: current.stageCounts,\n previous: previous.stageCounts,\n }),\n totalCasesDelta: current.totalCases - previous.totalCases,\n transformedCasesDelta: current.transformedCases - previous.transformedCases,\n vectorCasesDelta: current.vectorCases - previous.vectorCases,\n variantCasesDelta: current.variantCases - previous.variantCases,\n multiVectorCasesDelta: current.multiVectorCases - previous.multiVectorCases,\n multiVectorVectorHitCasesDelta:\n current.multiVectorVectorHitCases - previous.multiVectorVectorHitCases,\n multiVectorLexicalHitCasesDelta:\n current.multiVectorLexicalHitCases - previous.multiVectorLexicalHitCases,\n multiVectorCollapsedCasesDelta:\n current.multiVectorCollapsedCases - previous.multiVectorCollapsedCases,\n officeEvidenceReconcileCasesDelta:\n current.officeEvidenceReconcileCases -\n previous.officeEvidenceReconcileCases,\n officeParagraphEvidenceReconcileCasesDelta:\n (current.officeParagraphEvidenceReconcileCases ?? 0) -\n (previous.officeParagraphEvidenceReconcileCases ?? 0),\n officeListEvidenceReconcileCasesDelta:\n (current.officeListEvidenceReconcileCases ?? 0) -\n (previous.officeListEvidenceReconcileCases ?? 0),\n officeTableEvidenceReconcileCasesDelta:\n (current.officeTableEvidenceReconcileCases ?? 0) -\n (previous.officeTableEvidenceReconcileCases ?? 0),\n pdfEvidenceReconcileCasesDelta:\n current.pdfEvidenceReconcileCases - previous.pdfEvidenceReconcileCases,\n runtimeCandidateBudgetExhaustedCasesDelta:\n current.runtimeCandidateBudgetExhaustedCases -\n previous.runtimeCandidateBudgetExhaustedCases,\n runtimeUnderfilledTopKCasesDelta:\n current.runtimeUnderfilledTopKCases - previous.runtimeUnderfilledTopKCases,\n});\n\nconst buildSearchTraceResultSnapshots = (\n results: Array<{\n chunkId: string;\n corpusKey?: string;\n score: number;\n source?: string;\n title?: string;\n metadata?: Record<string, unknown>;\n }>,\n): RAGSearchTraceResultSnapshot[] =>\n results.map((result) => ({\n chunkId: result.chunkId,\n corpusKey:\n result.corpusKey ??\n (typeof result.metadata?.corpusKey === \"string\"\n ? result.metadata.corpusKey\n : undefined),\n documentId:\n typeof result.metadata?.documentId === \"string\"\n ? result.metadata.documentId\n : undefined,\n score: result.score,\n source: result.source,\n title: result.title,\n }));\n\nexport const buildRAGSearchTraceRecord = (input: {\n trace: RAGRetrievalTrace;\n results?: Array<{\n chunkId: string;\n score: number;\n source?: string;\n title?: string;\n metadata?: Record<string, unknown>;\n }>;\n id?: string;\n label?: string;\n groupKey?: string;\n tags?: string[];\n startedAt?: number;\n finishedAt?: number;\n elapsedMs?: number;\n metadata?: Record<string, unknown>;\n}): RAGSearchTraceRecord => {\n const startedAt = input.startedAt ?? Date.now();\n const finishedAt = input.finishedAt ?? startedAt;\n const elapsedMs = input.elapsedMs ?? Math.max(0, finishedAt - startedAt);\n const summary =\n summarizeRetrievalTraces([input.trace]) ??\n summarizeRetrievalTraces([\n {\n ...input.trace,\n steps: [...input.trace.steps],\n },\n ]);\n\n if (!summary) {\n throw new Error(\"Failed to summarize retrieval trace\");\n }\n\n return {\n elapsedMs,\n finishedAt,\n groupKey: input.groupKey,\n id: input.id ?? generateId(),\n label: input.label ?? input.trace.query,\n metadata: input.metadata,\n query: input.trace.query,\n results: buildSearchTraceResultSnapshots(input.results ?? []),\n startedAt,\n summary,\n tags: normalizeTraceTags(input.tags),\n trace: input.trace,\n };\n};\n\nexport const buildRAGSearchTraceDiff = ({\n current,\n previous,\n}: {\n current: RAGSearchTraceRecord;\n previous?: RAGSearchTraceRecord;\n}): RAGSearchTraceDiff => {\n const currentChunkIds = current.results.map((entry) => entry.chunkId);\n const previousChunkIds =\n previous?.results.map((entry) => entry.chunkId) ?? [];\n const previousSet = new Set(previousChunkIds);\n const currentSet = new Set(currentChunkIds);\n\n return {\n addedChunkIds: currentChunkIds.filter(\n (chunkId) => !previousSet.has(chunkId),\n ),\n currentTraceId: current.id,\n previousTraceId: previous?.id,\n removedChunkIds: previousChunkIds.filter(\n (chunkId) => !currentSet.has(chunkId),\n ),\n retainedChunkIds: currentChunkIds.filter((chunkId) =>\n previousSet.has(chunkId),\n ),\n summaryDelta: previous?.summary\n ? compareRAGRetrievalTraceSummaries(current.summary, previous.summary)\n : undefined,\n topResultChanged:\n (current.results[0]?.chunkId ?? undefined) !==\n (previous?.results[0]?.chunkId ?? undefined),\n };\n};\n\nexport const buildRAGRetrievalTraceHistoryTrend = ({\n runs,\n}: {\n runs: RAGRetrievalTraceSummaryRun[];\n}): RAGRetrievalTraceTrend => {\n const sortedRuns = normalizeTraceSummaryRuns(runs);\n const runsWithSummary = sortedRuns.filter(\n (run) => run.traceSummary && run.label,\n );\n const traceSummaries = runsWithSummary\n .map((run) => run.traceSummary)\n .filter((summary): summary is RAGRetrievalTraceComparisonSummary =>\n Boolean(summary),\n );\n const summaryTrendWindows: RAGRetrievalTraceHistoryWindow[] = [];\n\n for (let index = 0; index < runsWithSummary.length - 1; index += 1) {\n const currentRun = runsWithSummary[index]!;\n const previousRun = runsWithSummary[index + 1]!;\n if (!currentRun.traceSummary || !previousRun.traceSummary) {\n continue;\n }\n const current = currentRun.traceSummary;\n const previous = previousRun.traceSummary;\n const delta = compareRAGRetrievalTraceSummaries(current, previous);\n summaryTrendWindows.push({\n current,\n currentRunId: currentRun.id,\n currentRunLabel: currentRun.label,\n delta,\n previous,\n previousRunId: previousRun.id,\n previousRunLabel: previousRun.label,\n });\n }\n\n const latest = runsWithSummary[0]?.traceSummary;\n const previous = runsWithSummary[1]?.traceSummary;\n const latestToPrevious =\n latest && previous\n ? compareRAGRetrievalTraceSummaries(latest, previous)\n : undefined;\n const listHistoryModes = traceSummaries.map((summary) => summary.modes);\n const listHistorySourceStrategies = traceSummaries.map(\n (summary) => summary.sourceBalanceStrategies,\n );\n const modes = summarizeListTurnover<RAGHybridRetrievalMode>({\n current: normalizeSummaryList(latest?.modes ?? []),\n history: listHistoryModes,\n previous: normalizeSummaryList(previous?.modes ?? []),\n });\n const sourceBalanceStrategies =\n summarizeListTurnover<RAGSourceBalanceStrategy>({\n current: normalizeSummaryList(latest?.sourceBalanceStrategies ?? []),\n history: listHistorySourceStrategies,\n previous: normalizeSummaryList(previous?.sourceBalanceStrategies ?? []),\n });\n const { aggregate, bestMetric, worstMetric } = buildTraceSummaryAggregate({\n summaries: traceSummaries,\n });\n const stageChurn = buildRAGRetrievalTraceStageChurn({\n windows: summaryTrendWindows,\n });\n\n return {\n aggregate,\n bestMetric,\n modeTurnover: modes,\n runsWithTraceSummary: traceSummaries.length,\n sourceBalanceStrategyTurnover: sourceBalanceStrategies,\n stageChurn,\n summaryTrendWindows,\n worstMetric,\n worstVolatileStage: stageChurn.find((entry) => entry.totalChanges > 0),\n latestToPrevious,\n };\n};\nexport const createRAGEvaluationSuite = (\n suite: RAGEvaluationSuite,\n): RAGEvaluationSuite => {\n const cases = suite.input.cases.map((entry) => ({\n ...entry,\n ...(entry.goldenSet === true ? { goldenSet: true } : {}),\n ...(entry.expectedChunkIds\n ? { expectedChunkIds: [...entry.expectedChunkIds] }\n : {}),\n ...(entry.expectedSources\n ? { expectedSources: [...entry.expectedSources] }\n : {}),\n ...(entry.expectedDocumentIds\n ? { expectedDocumentIds: [...entry.expectedDocumentIds] }\n : {}),\n ...(entry.hardNegativeChunkIds\n ? {\n hardNegativeChunkIds: normalizeExpectedIds(\n entry.hardNegativeChunkIds,\n ),\n }\n : {}),\n ...(entry.hardNegativeSources\n ? {\n hardNegativeSources: normalizeExpectedIds(entry.hardNegativeSources),\n }\n : {}),\n ...(entry.hardNegativeDocumentIds\n ? {\n hardNegativeDocumentIds: normalizeExpectedIds(\n entry.hardNegativeDocumentIds,\n ),\n }\n : {}),\n ...(entry.filter ? { filter: { ...entry.filter } } : {}),\n ...(entry.metadata ? { metadata: { ...entry.metadata } } : {}),\n ...(entry.retrieval ? { retrieval: entry.retrieval } : {}),\n }));\n const duplicateCaseIds = Array.from(\n new Set(\n cases\n .map((entry) => entry.id)\n .filter(\n (id, index, ids) =>\n typeof id === \"string\" && ids.indexOf(id) !== index,\n ),\n ),\n );\n if (duplicateCaseIds.length > 0) {\n throw new Error(\n `RAG evaluation suite contains duplicate case ids: ${duplicateCaseIds.join(\", \")}`,\n );\n }\n\n return {\n ...suite,\n input: {\n ...suite.input,\n cases,\n ...(suite.input.filter ? { filter: { ...suite.input.filter } } : {}),\n ...(suite.input.retrieval ? { retrieval: suite.input.retrieval } : {}),\n },\n ...(suite.metadata ? { metadata: { ...suite.metadata } } : {}),\n };\n};\n\nexport const addRAGEvaluationSuiteCase = ({\n suite,\n caseInput,\n index,\n}: {\n suite: RAGEvaluationSuite;\n caseInput: RAGEvaluationCase;\n index?: number;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n if (normalizedSuite.input.cases.some((entry) => entry.id === caseInput.id)) {\n throw new Error(\n `RAG evaluation suite already contains case id ${caseInput.id}`,\n );\n }\n\n const nextCases = [...normalizedSuite.input.cases];\n const insertAt =\n typeof index === \"number\" && Number.isFinite(index)\n ? Math.max(0, Math.min(nextCases.length, Math.trunc(index)))\n : nextCases.length;\n nextCases.splice(insertAt, 0, caseInput);\n\n return createRAGEvaluationSuite({\n ...normalizedSuite,\n input: {\n ...normalizedSuite.input,\n cases: nextCases,\n },\n });\n};\n\nexport const updateRAGEvaluationSuiteCase = ({\n suite,\n caseId,\n caseInput,\n}: {\n suite: RAGEvaluationSuite;\n caseId: string;\n caseInput: RAGEvaluationCase;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const targetIndex = normalizedSuite.input.cases.findIndex(\n (entry) => entry.id === caseId,\n );\n if (targetIndex < 0) {\n throw new Error(`RAG evaluation suite does not contain case id ${caseId}`);\n }\n if (\n caseInput.id !== caseId &&\n normalizedSuite.input.cases.some((entry) => entry.id === caseInput.id)\n ) {\n throw new Error(\n `RAG evaluation suite already contains case id ${caseInput.id}`,\n );\n }\n\n const nextCases = [...normalizedSuite.input.cases];\n nextCases[targetIndex] = caseInput;\n\n return createRAGEvaluationSuite({\n ...normalizedSuite,\n input: {\n ...normalizedSuite.input,\n cases: nextCases,\n },\n });\n};\n\nexport const removeRAGEvaluationSuiteCase = ({\n suite,\n caseId,\n}: {\n suite: RAGEvaluationSuite;\n caseId: string;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const nextCases = normalizedSuite.input.cases.filter(\n (entry) => entry.id !== caseId,\n );\n if (nextCases.length === normalizedSuite.input.cases.length) {\n throw new Error(`RAG evaluation suite does not contain case id ${caseId}`);\n }\n\n return {\n ...normalizedSuite,\n input: {\n ...normalizedSuite.input,\n cases: nextCases,\n },\n };\n};\n\nexport const reorderRAGEvaluationSuiteCases = ({\n suite,\n caseIds,\n}: {\n suite: RAGEvaluationSuite;\n caseIds: string[];\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const caseMap = new Map(\n normalizedSuite.input.cases.map((entry) => [entry.id, entry]),\n );\n if (caseIds.length !== normalizedSuite.input.cases.length) {\n throw new Error(\n \"RAG evaluation suite reorder requires exactly one id per case\",\n );\n }\n const unknownCaseIds = caseIds.filter((id) => !caseMap.has(id));\n if (unknownCaseIds.length > 0) {\n throw new Error(\n `RAG evaluation suite reorder contains unknown case ids: ${unknownCaseIds.join(\", \")}`,\n );\n }\n if (new Set(caseIds).size !== caseIds.length) {\n throw new Error(\"RAG evaluation suite reorder contains duplicate case ids\");\n }\n\n return {\n ...normalizedSuite,\n input: {\n ...normalizedSuite.input,\n cases: caseIds.map((id) => caseMap.get(id)!),\n },\n };\n};\n\nexport const setRAGEvaluationSuiteCaseGoldenSet = ({\n suite,\n caseId,\n goldenSet,\n}: {\n suite: RAGEvaluationSuite;\n caseId: string;\n goldenSet: boolean;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const target = normalizedSuite.input.cases.find(\n (entry) => entry.id === caseId,\n );\n if (!target) {\n throw new Error(`RAG evaluation suite does not contain case id ${caseId}`);\n }\n\n return updateRAGEvaluationSuiteCase({\n caseId,\n caseInput: {\n ...target,\n ...(goldenSet ? { goldenSet: true } : { goldenSet: undefined }),\n },\n suite: normalizedSuite,\n });\n};\n\nconst resolveHardNegativeCaseField = (\n kind: \"chunkId\" | \"source\" | \"documentId\",\n) =>\n kind === \"chunkId\"\n ? \"hardNegativeChunkIds\"\n : kind === \"source\"\n ? \"hardNegativeSources\"\n : \"hardNegativeDocumentIds\";\n\nexport const addRAGEvaluationSuiteCaseHardNegative = ({\n suite,\n caseId,\n kind,\n value,\n}: {\n suite: RAGEvaluationSuite;\n caseId: string;\n kind: \"chunkId\" | \"source\" | \"documentId\";\n value: string;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const target = normalizedSuite.input.cases.find(\n (entry) => entry.id === caseId,\n );\n if (!target) {\n throw new Error(`RAG evaluation suite does not contain case id ${caseId}`);\n }\n\n const field = resolveHardNegativeCaseField(kind);\n const nextValues = normalizeExpectedIds([\n ...normalizeStringArray(target[field]),\n value,\n ]);\n\n return updateRAGEvaluationSuiteCase({\n caseId,\n caseInput: {\n ...target,\n [field]: nextValues,\n },\n suite: normalizedSuite,\n });\n};\n\nexport const removeRAGEvaluationSuiteCaseHardNegative = ({\n suite,\n caseId,\n kind,\n value,\n}: {\n suite: RAGEvaluationSuite;\n caseId: string;\n kind: \"chunkId\" | \"source\" | \"documentId\";\n value: string;\n}): RAGEvaluationSuite => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const target = normalizedSuite.input.cases.find(\n (entry) => entry.id === caseId,\n );\n if (!target) {\n throw new Error(`RAG evaluation suite does not contain case id ${caseId}`);\n }\n\n const field = resolveHardNegativeCaseField(kind);\n const nextValues = normalizeStringArray(target[field]).filter(\n (entry) => entry !== value.trim(),\n );\n\n return updateRAGEvaluationSuiteCase({\n caseId,\n caseInput: {\n ...target,\n [field]: nextValues.length > 0 ? nextValues : undefined,\n },\n suite: normalizedSuite,\n });\n};\n\nexport const summarizeRAGEvaluationSuiteDataset = ({\n suite,\n}: {\n suite: RAGEvaluationSuite;\n}): RAGEvaluationSuiteDatasetSummary => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n const cases = normalizedSuite.input.cases;\n\n return {\n caseCount: cases.length,\n goldenSetCount: cases.filter((entry) => entry.goldenSet === true).length,\n hardNegativeCaseCount: cases.filter(\n (entry) =>\n normalizeStringArray(entry.hardNegativeChunkIds).length > 0 ||\n normalizeStringArray(entry.hardNegativeSources).length > 0 ||\n normalizeStringArray(entry.hardNegativeDocumentIds).length > 0,\n ).length,\n hardNegativeChunkIdCount: cases.reduce(\n (sum, entry) =>\n sum + normalizeStringArray(entry.hardNegativeChunkIds).length,\n 0,\n ),\n hardNegativeDocumentIdCount: cases.reduce(\n (sum, entry) =>\n sum + normalizeStringArray(entry.hardNegativeDocumentIds).length,\n 0,\n ),\n hardNegativeSourceCount: cases.reduce(\n (sum, entry) =>\n sum + normalizeStringArray(entry.hardNegativeSources).length,\n 0,\n ),\n suiteId: normalizedSuite.id,\n };\n};\n\nexport const generateRAGEvaluationSuiteFromDocuments = ({\n suiteId,\n documents,\n label,\n description,\n maxCases = 20,\n topK = 5,\n scoreThreshold,\n filter,\n retrieval,\n includeGoldenSet = true,\n hardNegativePerCase = 1,\n metadata,\n}: RAGEvaluationSuiteGenerationOptions): RAGEvaluationSuite => {\n const normalizedDocuments = documents\n .filter(\n (document) =>\n typeof document.id === \"string\" &&\n document.id.trim().length > 0 &&\n typeof document.source === \"string\" &&\n document.source.trim().length > 0 &&\n typeof document.title === \"string\" &&\n document.title.trim().length > 0,\n )\n .sort((left, right) =>\n `${left.source}\\u0000${left.title}\\u0000${left.id}`.localeCompare(\n `${right.source}\\u0000${right.title}\\u0000${right.id}`,\n ),\n )\n .slice(0, Math.max(0, Math.trunc(maxCases)));\n\n const cases = normalizedDocuments.map((document, index) => {\n const negativeCandidates = normalizedDocuments\n .slice(index + 1)\n .concat(normalizedDocuments.slice(0, index))\n .filter((candidate) => candidate.id !== document.id);\n const hardNegativeDocumentIds = negativeCandidates\n .slice(0, Math.max(0, Math.trunc(hardNegativePerCase)))\n .map((candidate) => candidate.id);\n const hardNegativeSources = negativeCandidates\n .slice(0, Math.max(0, Math.trunc(hardNegativePerCase)))\n .map((candidate) => candidate.source);\n\n return {\n corpusKey: document.corpusKey,\n expectedDocumentIds: [document.id],\n expectedSources: [document.source],\n ...(includeGoldenSet ? { goldenSet: true } : {}),\n ...(hardNegativeDocumentIds.length > 0\n ? { hardNegativeDocumentIds }\n : {}),\n ...(hardNegativeSources.length > 0 ? { hardNegativeSources } : {}),\n id: `synthetic-${document.id}`,\n label: document.title,\n query: buildSyntheticEvaluationQuery(document),\n } satisfies RAGEvaluationCase;\n });\n\n return createRAGEvaluationSuite({\n description,\n id: suiteId,\n input: {\n cases,\n ...(filter ? { filter: { ...filter } } : {}),\n ...(typeof scoreThreshold === \"number\" ? { scoreThreshold } : {}),\n ...(typeof topK === \"number\" ? { topK } : {}),\n ...(retrieval ? { retrieval } : {}),\n },\n label,\n metadata,\n });\n};\n\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_SUITE_ID =\n \"rag-native-planner-larger-corpus\";\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_LABEL =\n \"Adaptive Native Planner Benchmark\";\nconst DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_SUITE_ID =\n \"rag-native-backend-larger-corpus\";\nconst DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_LABEL =\n \"Native Backend Comparison Benchmark\";\nconst DEFAULT_PRESENTATION_CUE_BENCHMARK_SUITE_ID =\n \"rag-presentation-cue-parity\";\nconst DEFAULT_PRESENTATION_CUE_BENCHMARK_LABEL = \"Presentation Cue Benchmark\";\nconst DEFAULT_SPREADSHEET_CUE_BENCHMARK_SUITE_ID = \"rag-spreadsheet-cue-parity\";\nconst DEFAULT_SPREADSHEET_CUE_BENCHMARK_LABEL = \"Spreadsheet Cue Benchmark\";\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY =\n \"Which launch checklist phrase is exact wording?\";\nconst DEFAULT_NATIVE_BACKEND_HYBRID_QUERY =\n \"aurora promotion checklist wording\";\nconst DEFAULT_NATIVE_BACKEND_FILTERED_QUERY =\n \"focus lane launch checklist wording\";\nconst DEFAULT_NATIVE_BACKEND_REORDERED_QUERY =\n \"exact aurora focus lane checklist wording\";\nconst DEFAULT_NATIVE_BACKEND_GUIDE_QUERY =\n \"which focus lane guide contains exact aurora promotion wording\";\nconst DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER = {\n lane: \"focus\",\n} satisfies Record<string, unknown>;\nconst DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS = [\n \"focus-distractor-0\",\n \"focus-distractor-1\",\n \"focus-distractor-2\",\n] as const;\n\nexport const createRAGNativeBackendBenchmarkMockEmbedding = async (\n text: string,\n): Promise<number[]> => {\n const normalized = text.toLowerCase();\n if (\n normalized.includes(\n \"launch checklist exact wording for aurora promotion\",\n ) ||\n normalized.includes(\"launch checklist exact wording\")\n ) {\n return [0.995, 0.005];\n }\n\n if (\n normalized.includes(\"aurora\") ||\n normalized.includes(\"checklist\") ||\n normalized.includes(\"focus lane\") ||\n normalized.includes(\"exact wording\") ||\n normalized.includes(\"guide\")\n ) {\n return [1, 0];\n }\n\n return [0, 1];\n};\n\nexport const createRAGNativeBackendBenchmarkCorpus = (input?: {\n backend?: \"generic\" | \"sqlite-native\" | \"postgres\";\n noiseCount?: number;\n}): RAGDocumentChunk[] => {\n const noiseCount = input?.noiseCount ?? 5_001;\n const backend = input?.backend ?? \"generic\";\n const genericChunks = [\n ...Array.from({ length: noiseCount }, (_, index) => ({\n chunkId: `noise:${index}`,\n corpusKey: \"noise\",\n embedding: [0, 1] as number[],\n metadata: {\n corpusKey: \"noise\",\n documentId: `noise-${index}`,\n lane: \"noise\",\n },\n source: `noise/${index}.md`,\n text: `Background operations note ${index}.`,\n })),\n ...Array.from({ length: 3 }, (_, index) => ({\n chunkId: `focus:distractor:${index}`,\n corpusKey: \"focus\",\n embedding: [1, 0] as number[],\n metadata: {\n corpusKey: \"focus\",\n documentId: `focus-distractor-${index}`,\n lane: \"focus\",\n },\n source: `focus/distractor-${index}.md`,\n text:\n index === 0\n ? \"aurora promotion checklist overview\"\n : index === 1\n ? \"launch checklist wording draft\"\n : \"focus lane promotion runbook notes\",\n })),\n {\n chunkId: \"focus:target\",\n corpusKey: \"focus\",\n embedding: [0.995, 0.005] as number[],\n metadata: {\n corpusKey: \"focus\",\n documentId: \"focus-target\",\n lane: \"focus\",\n },\n source: \"guide/planner-depth.md\",\n text: \"launch checklist exact wording for aurora promotion in the focus lane\",\n },\n ] satisfies RAGDocumentChunk[];\n\n const backendSpecificChunks =\n backend === \"sqlite-native\"\n ? [\n {\n chunkId: \"focus:sqlite:phrase-matrix\",\n corpusKey: \"focus\",\n embedding: [1, 0] as number[],\n metadata: {\n backendFixture: \"sqlite-native\",\n corpusKey: \"focus\",\n documentId: \"focus-sqlite-phrase-matrix\",\n lane: \"focus\",\n },\n source: \"guide/sqlite-phrase-matrix.md\",\n text: \"exact aurora focus lane checklist wording matrix for sqlite validation\",\n },\n {\n chunkId: \"focus:sqlite:guide-table\",\n corpusKey: \"focus\",\n embedding: [1, 0] as number[],\n metadata: {\n backendFixture: \"sqlite-native\",\n corpusKey: \"focus\",\n documentId: \"focus-sqlite-guide-table\",\n lane: \"focus\",\n },\n source: \"guide/sqlite-guide-table.md\",\n text: \"which focus lane guide contains aurora promotion wording draft table for sqlite operators\",\n },\n ]\n : backend === \"postgres\"\n ? [\n {\n chunkId: \"focus:postgres:appendix\",\n corpusKey: \"focus\",\n embedding: [1, 0] as number[],\n metadata: {\n backendFixture: \"postgres\",\n corpusKey: \"focus\",\n documentId: \"focus-postgres-appendix\",\n lane: \"focus\",\n },\n source: \"guide/postgres-appendix.md\",\n text: \"which focus lane guide contains exact aurora promotion wording appendix for postgres release review\",\n },\n {\n chunkId: \"focus:postgres:alternatives\",\n corpusKey: \"focus\",\n embedding: [1, 0] as number[],\n metadata: {\n backendFixture: \"postgres\",\n corpusKey: \"focus\",\n documentId: \"focus-postgres-alternatives\",\n lane: \"focus\",\n },\n source: \"guide/postgres-alternatives.md\",\n text: \"aurora promotion checklist wording alternatives and exact focus lane phrasing for postgres audits\",\n },\n ]\n : [];\n\n return [...genericChunks, ...backendSpecificChunks];\n};\n\nexport const createRAGAdaptiveNativePlannerBenchmarkSuite = (input?: {\n id?: string;\n label?: string;\n description?: string;\n topK?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n createRAGEvaluationSuite({\n description:\n input?.description ??\n \"Stress-tests larger-corpus native planner selection, candidate-budget pressure, and transformed-query recovery on filtered retrieval.\",\n id: input?.id ?? DEFAULT_NATIVE_PLANNER_BENCHMARK_SUITE_ID,\n input: {\n cases: [\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n \"focus-distractor-0\",\n \"focus-distractor-1\",\n \"focus-distractor-2\",\n ],\n id: \"planner-pressure-exact-phrase\",\n label: \"Exact phrase survives larger-corpus native pressure\",\n query: DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY,\n topK: input?.topK ?? 1,\n },\n ],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n retrieval: \"vector\",\n topK: input?.topK ?? 1,\n },\n label: input?.label ?? DEFAULT_NATIVE_PLANNER_BENCHMARK_LABEL,\n metadata: {\n benchmarkKind: \"adaptive_native_planner\",\n benchmarkScope: \"larger_corpus\",\n expectedSignals: [\n \"selected native planner profile\",\n \"candidate-budget exhaustion\",\n \"underfilled topk\",\n ],\n recommendedGroupKey: \"runtime-native-planner\",\n recommendedTags: [\"runtime\", \"native\", \"planner\"],\n ...input?.metadata,\n },\n });\n\nexport const createRAGAdaptiveNativePlannerBenchmarkSnapshot = (input?: {\n suite?: RAGEvaluationSuite;\n id?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n const suite = input?.suite ?? createRAGAdaptiveNativePlannerBenchmarkSuite();\n\n return createRAGEvaluationSuiteSnapshot({\n createdAt: input?.createdAt,\n id: input?.id,\n metadata: {\n artifactKind: \"adaptive_native_planner_benchmark\",\n persistForReleaseHistory: true,\n ...input?.metadata,\n },\n suite,\n version: input?.version,\n });\n};\n\nexport const createRAGNativeBackendComparisonBenchmarkSuite = (input?: {\n id?: string;\n label?: string;\n description?: string;\n topK?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n createRAGEvaluationSuite({\n description:\n input?.description ??\n \"Captures larger-corpus native backend parity with filtered vector pressure and harder hybrid retrieval cases so sqlite-native and postgres runs can be compared over time.\",\n id: input?.id ?? DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_SUITE_ID,\n input: {\n cases: [\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n ...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS,\n ],\n id: \"planner-pressure-exact-phrase\",\n label: \"Exact phrase survives larger-corpus native pressure\",\n query: DEFAULT_NATIVE_PLANNER_BENCHMARK_QUERY,\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n ...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS,\n ],\n id: \"planner-pressure-hybrid-phrase\",\n label: \"Hybrid retrieval survives filtered lexical pressure\",\n query: DEFAULT_NATIVE_BACKEND_HYBRID_QUERY,\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n ...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS,\n ],\n id: \"planner-pressure-filtered-lane-query\",\n label: \"Filtered lane query survives broader corpus noise\",\n query: DEFAULT_NATIVE_BACKEND_FILTERED_QUERY,\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n ...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS,\n ],\n id: \"planner-pressure-reordered-phrase\",\n label: \"Reordered phrase survives transform pressure\",\n query: DEFAULT_NATIVE_BACKEND_REORDERED_QUERY,\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"focus-target\"],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n hardNegativeDocumentIds: [\n ...DEFAULT_NATIVE_PLANNER_HARD_NEGATIVE_DOCUMENT_IDS,\n ],\n id: \"planner-pressure-guide-query\",\n label: \"Guide attribution survives filtered corpus pressure\",\n query: DEFAULT_NATIVE_BACKEND_GUIDE_QUERY,\n topK: input?.topK ?? 1,\n },\n ],\n filter: { ...DEFAULT_NATIVE_PLANNER_BENCHMARK_FILTER },\n retrieval: \"vector\",\n topK: input?.topK ?? 1,\n },\n label: input?.label ?? DEFAULT_NATIVE_BACKEND_COMPARISON_BENCHMARK_LABEL,\n metadata: {\n benchmarkKind: \"native_backend_comparison\",\n benchmarkScope: \"larger_corpus\",\n expectedSignals: [\n \"backend-tagged runtime artifacts\",\n \"selected native planner profile\",\n \"hybrid filtered retrieval\",\n \"candidate-budget exhaustion\",\n \"underfilled topk\",\n \"query transform pressure\",\n ],\n recommendedGroupKey: \"runtime-native-backend-parity\",\n recommendedTags: [\"runtime\", \"backend\", \"native\"],\n ...input?.metadata,\n },\n });\n\nexport const createRAGNativeBackendComparisonBenchmarkSnapshot = (input?: {\n suite?: RAGEvaluationSuite;\n id?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n const suite =\n input?.suite ?? createRAGNativeBackendComparisonBenchmarkSuite();\n\n return createRAGEvaluationSuiteSnapshot({\n createdAt: input?.createdAt,\n id: input?.id,\n metadata: {\n artifactKind: \"native_backend_comparison_benchmark\",\n persistForReleaseHistory: true,\n ...input?.metadata,\n },\n suite,\n version: input?.version,\n });\n};\n\nexport const createRAGPresentationCueBenchmarkSuite = (input?: {\n id?: string;\n label?: string;\n description?: string;\n topK?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n createRAGEvaluationSuite({\n description:\n input?.description ??\n \"Captures repeated-title presentation retrieval parity with explicit title-led, body-led, and notes-led slide cases so presentation cue weighting can be benchmarked over time.\",\n id: input?.id ?? DEFAULT_PRESENTATION_CUE_BENCHMARK_SUITE_ID,\n input: {\n cases: [\n {\n expectedDocumentIds: [\"slide-title-doc\"],\n hardNegativeDocumentIds: [\"slide-body-doc\", \"slide-notes-doc\"],\n id: \"presentation-title-led\",\n label: \"Repeated-title deck selects title-led slide evidence\",\n query: \"Which presentation title covers the release handoff summary?\",\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"slide-body-doc\"],\n hardNegativeDocumentIds: [\"slide-title-doc\", \"slide-notes-doc\"],\n id: \"presentation-body-led\",\n label: \"Repeated-title deck selects body-led slide evidence\",\n query: \"Which slide mentions escalation review in the body?\",\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"slide-notes-doc\"],\n hardNegativeDocumentIds: [\"slide-title-doc\", \"slide-body-doc\"],\n id: \"presentation-notes-led\",\n label: \"Repeated-title deck selects notes-led slide evidence\",\n query: \"Which slide notes are the primary handoff evidence?\",\n topK: input?.topK ?? 1,\n },\n ],\n retrieval: \"hybrid\",\n topK: input?.topK ?? 1,\n },\n label: input?.label ?? DEFAULT_PRESENTATION_CUE_BENCHMARK_LABEL,\n metadata: {\n benchmarkKind: \"presentation_cue\",\n benchmarkScope: \"repeated_title_slides\",\n expectedSignals: [\n \"presentation title cue\",\n \"presentation body cue\",\n \"presentation notes cue\",\n ],\n recommendedGroupKey: \"presentation-cue-parity\",\n recommendedTags: [\"presentation\", \"cue\", \"slides\"],\n ...input?.metadata,\n },\n });\n\nexport const createRAGPresentationCueBenchmarkSnapshot = (input?: {\n suite?: RAGEvaluationSuite;\n id?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n const suite = input?.suite ?? createRAGPresentationCueBenchmarkSuite();\n\n return createRAGEvaluationSuiteSnapshot({\n createdAt: input?.createdAt,\n id: input?.id,\n metadata: {\n artifactKind: \"presentation_cue_benchmark\",\n persistForReleaseHistory: true,\n ...input?.metadata,\n },\n suite,\n version: input?.version,\n });\n};\n\nexport const createRAGSpreadsheetCueBenchmarkSuite = (input?: {\n id?: string;\n label?: string;\n description?: string;\n topK?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuite =>\n createRAGEvaluationSuite({\n description:\n input?.description ??\n \"Captures repeated spreadsheet-family retrieval parity with explicit sheet-led, table-led, and column-led workbook cases so spreadsheet cue weighting can be benchmarked over time.\",\n id: input?.id ?? DEFAULT_SPREADSHEET_CUE_BENCHMARK_SUITE_ID,\n input: {\n cases: [\n {\n expectedDocumentIds: [\"sheet-led-doc\"],\n hardNegativeDocumentIds: [\"table-led-doc\", \"column-led-doc\"],\n id: \"spreadsheet-sheet-led\",\n label: \"Workbook selects sheet-led spreadsheet evidence\",\n query: \"Which spreadsheet sheet lists owner status and due date?\",\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"table-led-doc\"],\n hardNegativeDocumentIds: [\"sheet-led-doc\", \"column-led-doc\"],\n id: \"spreadsheet-table-led\",\n label: \"Workbook selects table-led spreadsheet evidence\",\n query: \"Which spreadsheet table lists the escalation status rows?\",\n topK: input?.topK ?? 1,\n },\n {\n expectedDocumentIds: [\"column-led-doc\"],\n hardNegativeDocumentIds: [\"sheet-led-doc\", \"table-led-doc\"],\n id: \"spreadsheet-column-led\",\n label: \"Workbook selects column-led spreadsheet evidence\",\n query: \"Which spreadsheet columns cover owner due date?\",\n topK: input?.topK ?? 1,\n },\n ],\n retrieval: \"hybrid\",\n topK: input?.topK ?? 1,\n },\n label: input?.label ?? DEFAULT_SPREADSHEET_CUE_BENCHMARK_LABEL,\n metadata: {\n benchmarkKind: \"spreadsheet_cue\",\n benchmarkScope: \"repeated_sheet_tables\",\n expectedSignals: [\n \"spreadsheet sheet cue\",\n \"spreadsheet table cue\",\n \"spreadsheet column cue\",\n ],\n recommendedGroupKey: \"spreadsheet-cue-parity\",\n recommendedTags: [\"spreadsheet\", \"cue\", \"workbook\"],\n ...input?.metadata,\n },\n });\n\nexport const createRAGSpreadsheetCueBenchmarkSnapshot = (input?: {\n suite?: RAGEvaluationSuite;\n id?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n const suite = input?.suite ?? createRAGSpreadsheetCueBenchmarkSuite();\n\n return createRAGEvaluationSuiteSnapshot({\n createdAt: input?.createdAt,\n id: input?.id,\n metadata: {\n artifactKind: \"spreadsheet_cue_benchmark\",\n persistForReleaseHistory: true,\n ...input?.metadata,\n },\n suite,\n version: input?.version,\n });\n};\n\nexport const createRAGEvaluationSuiteSnapshot = ({\n suite,\n id,\n version = 1,\n createdAt = Date.now(),\n metadata,\n}: {\n suite: RAGEvaluationSuite;\n id?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n}): RAGEvaluationSuiteSnapshot => {\n const normalizedSuite = createRAGEvaluationSuite(suite);\n return {\n caseCount: normalizedSuite.input.cases.length,\n createdAt,\n id: id ?? `${normalizedSuite.id}:snapshot:${String(version)}`,\n label: normalizedSuite.label,\n description: normalizedSuite.description,\n metadata: metadata ? { ...metadata } : undefined,\n suite: normalizedSuite,\n suiteId: normalizedSuite.id,\n version,\n };\n};\n\nconst stableStringifyEvaluationCase = (entry: RAGEvaluationCase) =>\n JSON.stringify({\n ...entry,\n expectedChunkIds: entry.expectedChunkIds ?? [],\n expectedDocumentIds: entry.expectedDocumentIds ?? [],\n expectedSources: entry.expectedSources ?? [],\n goldenSet: entry.goldenSet === true,\n hardNegativeChunkIds: entry.hardNegativeChunkIds ?? [],\n hardNegativeDocumentIds: entry.hardNegativeDocumentIds ?? [],\n hardNegativeSources: entry.hardNegativeSources ?? [],\n filter: entry.filter ?? {},\n metadata: entry.metadata ?? {},\n retrieval: entry.retrieval ?? null,\n });\n\nexport const buildRAGEvaluationSuiteSnapshotDiff = ({\n current,\n previous,\n}: {\n current: RAGEvaluationSuiteSnapshot;\n previous?: RAGEvaluationSuiteSnapshot;\n}): RAGEvaluationSuiteSnapshotDiff => {\n const currentCases = current.suite.input.cases;\n const previousCases = previous?.suite.input.cases ?? [];\n const currentMap = new Map<string, RAGEvaluationCase>(\n currentCases.map((entry: RAGEvaluationCase) => [entry.id, entry]),\n );\n const previousMap = new Map<string, RAGEvaluationCase>(\n previousCases.map((entry: RAGEvaluationCase) => [entry.id, entry]),\n );\n const currentIds = currentCases.map((entry: RAGEvaluationCase) => entry.id);\n const previousIds = previousCases.map((entry: RAGEvaluationCase) => entry.id);\n\n const addedCaseIds = currentIds.filter((id: string) => !previousMap.has(id));\n const removedCaseIds = previousIds.filter(\n (id: string) => !currentMap.has(id),\n );\n const changedCaseIds = currentIds.filter((id: string) => {\n const currentCase = currentMap.get(id);\n const previousCase = previousMap.get(id);\n if (!currentCase || !previousCase) {\n return false;\n }\n return (\n stableStringifyEvaluationCase(currentCase) !==\n stableStringifyEvaluationCase(previousCase)\n );\n });\n const unchangedCaseIds = currentIds.filter((id: string) => {\n const currentCase = currentMap.get(id);\n const previousCase = previousMap.get(id);\n if (!currentCase || !previousCase) {\n return false;\n }\n return (\n stableStringifyEvaluationCase(currentCase) ===\n stableStringifyEvaluationCase(previousCase)\n );\n });\n const sharedIds = currentIds.filter((id: string) => previousMap.has(id));\n const orderChanged =\n sharedIds.length > 0 &&\n JSON.stringify(sharedIds) !==\n JSON.stringify(previousIds.filter((id: string) => currentMap.has(id)));\n\n return {\n addedCaseIds,\n caseCountDelta: current.caseCount - (previous?.caseCount ?? 0),\n changedCaseIds,\n currentSnapshotId: current.id,\n orderChanged,\n previousSnapshotId: previous?.id,\n removedCaseIds,\n suiteId: current.suiteId,\n unchangedCaseIds,\n };\n};\nexport const evaluateRAGCollection = async ({\n collection,\n input,\n defaultTopK = DEFAULT_TOP_K,\n rerank,\n}: {\n collection: RAGCollection;\n input: RAGEvaluationInput;\n defaultTopK?: number;\n rerank?: RAGRerankerProviderLike;\n}) => {\n const evaluated = await evaluateRAGCollectionCases({\n collection,\n defaultTopK,\n includeTrace: false,\n input,\n rerank,\n });\n\n return buildRAGEvaluationResponse(evaluated.map((entry) => entry.caseResult));\n};\nexport const executeDryRunRAGEvaluation = (\n input: RAGEvaluationInput,\n defaultTopK = DEFAULT_TOP_K,\n): RAGEvaluationCaseResult[] =>\n input.cases.map((caseInput, caseIndex) => {\n const mode = resolveEvaluationMode(caseInput);\n const expectedIds = normalizeExpectedIds(\n mode === \"chunkId\"\n ? (caseInput.expectedChunkIds ?? [])\n : mode === \"source\"\n ? (caseInput.expectedSources ?? [])\n : (caseInput.expectedDocumentIds ?? []),\n );\n const effectiveTopK =\n typeof caseInput.topK === \"number\"\n ? caseInput.topK\n : typeof input.topK === \"number\"\n ? input.topK\n : defaultTopK;\n\n return {\n caseId: caseInput.id ?? `case-${caseIndex + 1}`,\n elapsedMs: 0,\n expectedCount: expectedIds.length,\n expectedIds,\n failureClasses: classifyRAGEvaluationFailure({\n expectedCount: expectedIds.length,\n matchedCount: 0,\n missingIds: expectedIds,\n retrievedCount: 0,\n retrievedIds: [],\n }),\n f1: 0,\n label: caseInput.label,\n matchedCount: 0,\n matchedIds: [],\n missingIds: expectedIds,\n mode,\n precision: 0,\n query: caseInput.query,\n recall: 0,\n retrievedCount: 0,\n retrievedIds: [],\n status: expectedIds.length === 0 ? \"partial\" : \"fail\",\n topK: effectiveTopK,\n };\n });\nexport const runRAGEvaluationSuite = async ({\n suite,\n evaluate,\n overrides,\n artifacts,\n}: {\n suite: RAGEvaluationSuite;\n evaluate: (input: RAGEvaluationInput) => Promise<RAGEvaluationResponse>;\n overrides?: Partial<RAGEvaluationInput>;\n artifacts?: Pick<\n RAGEvaluationSuiteRun,\n \"traceSummary\" | \"caseTraceSnapshots\"\n >;\n}) => {\n const startedAt = Date.now();\n const response = await evaluate({\n ...suite.input,\n ...overrides,\n cases: overrides?.cases ?? suite.input.cases,\n });\n const finishedAt = Date.now();\n\n return {\n caseTraceSnapshots: artifacts?.caseTraceSnapshots,\n elapsedMs: finishedAt - startedAt,\n finishedAt,\n id: generateId(),\n label: suite.label ?? suite.id,\n metadata: suite.metadata,\n response,\n startedAt,\n suiteId: suite.id,\n traceSummary: artifacts?.traceSummary,\n } satisfies RAGEvaluationSuiteRun;\n};\nexport const summarizeRAGEvaluationCase = ({\n caseIndex,\n caseInput,\n query,\n mode,\n retrievedIds,\n expectedIds,\n elapsedMs,\n retrievedSources,\n trace,\n}: {\n caseIndex: number;\n caseInput: RAGEvaluationCase;\n mode: \"chunkId\" | \"source\" | \"documentId\";\n query: string;\n retrievedIds: string[];\n expectedIds: string[];\n elapsedMs: number;\n retrievedSources?: RAGSource[];\n trace?: RAGSearchTraceRecord | RAGRetrievalTrace;\n}): RAGEvaluationCaseResult => {\n const expectedSet = new Set(expectedIds);\n const retrievedSet = new Set(retrievedIds);\n const matchedIds = normalizeExpectedIds(\n [...expectedSet].filter((id) => retrievedSet.has(id)),\n );\n const missingIds = normalizeExpectedIds(\n [...expectedSet].filter((id) => !retrievedSet.has(id)),\n );\n const matchedCount = matchedIds.length;\n const retrievedCount = retrievedIds.length;\n const expectedCount = expectedIds.length;\n const precision = retrievedCount > 0 ? matchedCount / retrievedCount : 0;\n const recall = expectedCount > 0 ? matchedCount / expectedCount : 0;\n const f1 =\n precision + recall > 0\n ? (2 * precision * recall) / (precision + recall)\n : 0;\n const status: RAGEvaluationCaseResult[\"status\"] =\n expectedCount === 0\n ? \"partial\"\n : matchedCount === expectedCount\n ? \"pass\"\n : matchedCount > 0\n ? \"partial\"\n : \"fail\";\n\n return {\n caseId: caseInput.id ?? `case-${caseIndex + 1}`,\n corpusKey: caseInput.corpusKey,\n elapsedMs,\n expectedCount,\n expectedIds,\n failureClasses: classifyRAGEvaluationFailure({\n expectedCount,\n matchedCount,\n missingIds,\n retrievedCount,\n retrievedIds,\n retrievedSources,\n trace,\n }),\n f1,\n label: caseInput.label,\n matchedCount,\n matchedIds,\n metadata: caseInput.metadata,\n missingIds,\n mode,\n precision,\n query,\n recall,\n retrievedCount,\n retrievedIds,\n status,\n topK: typeof caseInput.topK === \"number\" ? caseInput.topK : DEFAULT_TOP_K,\n };\n};\nexport const summarizeRAGRerankerComparison = (\n entries: RAGRerankerComparisonEntry[],\n): RAGRerankerComparisonSummary => {\n return summarizeEvaluationResponseComparison(\n entries,\n \"rerankerId\",\n ) satisfies RAGRerankerComparisonSummary;\n};\nexport const summarizeRAGRetrievalComparison = (\n entries: RAGRetrievalComparisonEntry[],\n): RAGRetrievalComparisonSummary => ({\n ...summarizeEvaluationResponseComparison(entries, \"retrievalId\"),\n bestByPresentationTitleCueCases: selectComparisonEntryByPresentationCueCases(\n entries,\n \"retrievalId\",\n \"title\",\n ),\n bestByPresentationBodyCueCases: selectComparisonEntryByPresentationCueCases(\n entries,\n \"retrievalId\",\n \"body\",\n ),\n bestByPresentationNotesCueCases: selectComparisonEntryByPresentationCueCases(\n entries,\n \"retrievalId\",\n \"notes\",\n ),\n bestBySpreadsheetSheetCueCases: selectComparisonEntryBySpreadsheetCueCases(\n entries,\n \"retrievalId\",\n \"sheet\",\n ),\n bestBySpreadsheetTableCueCases: selectComparisonEntryBySpreadsheetCueCases(\n entries,\n \"retrievalId\",\n \"table\",\n ),\n bestBySpreadsheetColumnCueCases: selectComparisonEntryBySpreadsheetCueCases(\n entries,\n \"retrievalId\",\n \"column\",\n ),\n bestByMultivectorCollapsedCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"multiVectorCollapsedCases\",\n ),\n bestByMultivectorLexicalHitCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"multiVectorLexicalHitCases\",\n ),\n bestByMultivectorVectorHitCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"multiVectorVectorHitCases\",\n ),\n bestByEvidenceReconcileCases: selectComparisonEntryByTraceStageCount(\n entries,\n \"retrievalId\",\n \"evidence_reconcile\",\n ),\n bestByOfficeEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"officeEvidenceReconcileCases\",\n ),\n bestByOfficeParagraphEvidenceReconcileCases:\n selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"officeParagraphEvidenceReconcileCases\",\n ),\n bestByOfficeListEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"officeListEvidenceReconcileCases\",\n ),\n bestByOfficeTableEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"officeTableEvidenceReconcileCases\",\n ),\n bestByPDFEvidenceReconcileCases: selectComparisonEntryByTraceMetric(\n entries,\n \"retrievalId\",\n \"pdfEvidenceReconcileCases\",\n ),\n bestByLowestRuntimeCandidateBudgetExhaustedCases:\n selectComparisonEntryByLowestTraceMetric(\n entries,\n \"retrievalId\",\n \"runtimeCandidateBudgetExhaustedCases\",\n ),\n bestByLowestRuntimeUnderfilledTopKCases:\n selectComparisonEntryByLowestTraceMetric(\n entries,\n \"retrievalId\",\n \"runtimeUnderfilledTopKCases\",\n ),\n});\n",
9
9
  "function assertPath(path){if(typeof path!==\"string\")throw TypeError(\"Path must be a string. Received \"+JSON.stringify(path))}function normalizeStringPosix(path,allowAboveRoot){var res=\"\",lastSegmentLength=0,lastSlash=-1,dots=0,code;for(var i=0;i<=path.length;++i){if(i<path.length)code=path.charCodeAt(i);else if(code===47)break;else code=47;if(code===47){if(lastSlash===i-1||dots===1);else if(lastSlash!==i-1&&dots===2){if(res.length<2||lastSegmentLength!==2||res.charCodeAt(res.length-1)!==46||res.charCodeAt(res.length-2)!==46){if(res.length>2){var lastSlashIndex=res.lastIndexOf(\"/\");if(lastSlashIndex!==res.length-1){if(lastSlashIndex===-1)res=\"\",lastSegmentLength=0;else res=res.slice(0,lastSlashIndex),lastSegmentLength=res.length-1-res.lastIndexOf(\"/\");lastSlash=i,dots=0;continue}}else if(res.length===2||res.length===1){res=\"\",lastSegmentLength=0,lastSlash=i,dots=0;continue}}if(allowAboveRoot){if(res.length>0)res+=\"/..\";else res=\"..\";lastSegmentLength=2}}else{if(res.length>0)res+=\"/\"+path.slice(lastSlash+1,i);else res=path.slice(lastSlash+1,i);lastSegmentLength=i-lastSlash-1}lastSlash=i,dots=0}else if(code===46&&dots!==-1)++dots;else dots=-1}return res}function _format(sep,pathObject){var dir=pathObject.dir||pathObject.root,base=pathObject.base||(pathObject.name||\"\")+(pathObject.ext||\"\");if(!dir)return base;if(dir===pathObject.root)return dir+base;return dir+sep+base}function resolve(){var resolvedPath=\"\",resolvedAbsolute=!1,cwd;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path;if(i>=0)path=arguments[i];else{if(cwd===void 0)cwd=process.cwd();path=cwd}if(assertPath(path),path.length===0)continue;resolvedPath=path+\"/\"+resolvedPath,resolvedAbsolute=path.charCodeAt(0)===47}if(resolvedPath=normalizeStringPosix(resolvedPath,!resolvedAbsolute),resolvedAbsolute)if(resolvedPath.length>0)return\"/\"+resolvedPath;else return\"/\";else if(resolvedPath.length>0)return resolvedPath;else return\".\"}function normalize(path){if(assertPath(path),path.length===0)return\".\";var isAbsolute=path.charCodeAt(0)===47,trailingSeparator=path.charCodeAt(path.length-1)===47;if(path=normalizeStringPosix(path,!isAbsolute),path.length===0&&!isAbsolute)path=\".\";if(path.length>0&&trailingSeparator)path+=\"/\";if(isAbsolute)return\"/\"+path;return path}function isAbsolute(path){return assertPath(path),path.length>0&&path.charCodeAt(0)===47}function join(){if(arguments.length===0)return\".\";var joined;for(var i=0;i<arguments.length;++i){var arg=arguments[i];if(assertPath(arg),arg.length>0)if(joined===void 0)joined=arg;else joined+=\"/\"+arg}if(joined===void 0)return\".\";return normalize(joined)}function relative(from,to){if(assertPath(from),assertPath(to),from===to)return\"\";if(from=resolve(from),to=resolve(to),from===to)return\"\";var fromStart=1;for(;fromStart<from.length;++fromStart)if(from.charCodeAt(fromStart)!==47)break;var fromEnd=from.length,fromLen=fromEnd-fromStart,toStart=1;for(;toStart<to.length;++toStart)if(to.charCodeAt(toStart)!==47)break;var toEnd=to.length,toLen=toEnd-toStart,length=fromLen<toLen?fromLen:toLen,lastCommonSep=-1,i=0;for(;i<=length;++i){if(i===length){if(toLen>length){if(to.charCodeAt(toStart+i)===47)return to.slice(toStart+i+1);else if(i===0)return to.slice(toStart+i)}else if(fromLen>length){if(from.charCodeAt(fromStart+i)===47)lastCommonSep=i;else if(i===0)lastCommonSep=0}break}var fromCode=from.charCodeAt(fromStart+i),toCode=to.charCodeAt(toStart+i);if(fromCode!==toCode)break;else if(fromCode===47)lastCommonSep=i}var out=\"\";for(i=fromStart+lastCommonSep+1;i<=fromEnd;++i)if(i===fromEnd||from.charCodeAt(i)===47)if(out.length===0)out+=\"..\";else out+=\"/..\";if(out.length>0)return out+to.slice(toStart+lastCommonSep);else{if(toStart+=lastCommonSep,to.charCodeAt(toStart)===47)++toStart;return to.slice(toStart)}}function _makeLong(path){return path}function dirname(path){if(assertPath(path),path.length===0)return\".\";var code=path.charCodeAt(0),hasRoot=code===47,end=-1,matchedSlash=!0;for(var i=path.length-1;i>=1;--i)if(code=path.charCodeAt(i),code===47){if(!matchedSlash){end=i;break}}else matchedSlash=!1;if(end===-1)return hasRoot?\"/\":\".\";if(hasRoot&&end===1)return\"//\";return path.slice(0,end)}function basename(path,ext){if(ext!==void 0&&typeof ext!==\"string\")throw TypeError('\"ext\" argument must be a string');assertPath(path);var start=0,end=-1,matchedSlash=!0,i;if(ext!==void 0&&ext.length>0&&ext.length<=path.length){if(ext.length===path.length&&ext===path)return\"\";var extIdx=ext.length-1,firstNonSlashEnd=-1;for(i=path.length-1;i>=0;--i){var code=path.charCodeAt(i);if(code===47){if(!matchedSlash){start=i+1;break}}else{if(firstNonSlashEnd===-1)matchedSlash=!1,firstNonSlashEnd=i+1;if(extIdx>=0)if(code===ext.charCodeAt(extIdx)){if(--extIdx===-1)end=i}else extIdx=-1,end=firstNonSlashEnd}}if(start===end)end=firstNonSlashEnd;else if(end===-1)end=path.length;return path.slice(start,end)}else{for(i=path.length-1;i>=0;--i)if(path.charCodeAt(i)===47){if(!matchedSlash){start=i+1;break}}else if(end===-1)matchedSlash=!1,end=i+1;if(end===-1)return\"\";return path.slice(start,end)}}function extname(path){assertPath(path);var startDot=-1,startPart=0,end=-1,matchedSlash=!0,preDotState=0;for(var i=path.length-1;i>=0;--i){var code=path.charCodeAt(i);if(code===47){if(!matchedSlash){startPart=i+1;break}continue}if(end===-1)matchedSlash=!1,end=i+1;if(code===46){if(startDot===-1)startDot=i;else if(preDotState!==1)preDotState=1}else if(startDot!==-1)preDotState=-1}if(startDot===-1||end===-1||preDotState===0||preDotState===1&&startDot===end-1&&startDot===startPart+1)return\"\";return path.slice(startDot,end)}function format(pathObject){if(pathObject===null||typeof pathObject!==\"object\")throw TypeError('The \"pathObject\" argument must be of type Object. Received type '+typeof pathObject);return _format(\"/\",pathObject)}function parse(path){assertPath(path);var ret={root:\"\",dir:\"\",base:\"\",ext:\"\",name:\"\"};if(path.length===0)return ret;var code=path.charCodeAt(0),isAbsolute2=code===47,start;if(isAbsolute2)ret.root=\"/\",start=1;else start=0;var startDot=-1,startPart=0,end=-1,matchedSlash=!0,i=path.length-1,preDotState=0;for(;i>=start;--i){if(code=path.charCodeAt(i),code===47){if(!matchedSlash){startPart=i+1;break}continue}if(end===-1)matchedSlash=!1,end=i+1;if(code===46){if(startDot===-1)startDot=i;else if(preDotState!==1)preDotState=1}else if(startDot!==-1)preDotState=-1}if(startDot===-1||end===-1||preDotState===0||preDotState===1&&startDot===end-1&&startDot===startPart+1){if(end!==-1)if(startPart===0&&isAbsolute2)ret.base=ret.name=path.slice(1,end);else ret.base=ret.name=path.slice(startPart,end)}else{if(startPart===0&&isAbsolute2)ret.name=path.slice(1,startDot),ret.base=path.slice(1,end);else ret.name=path.slice(startPart,startDot),ret.base=path.slice(startPart,end);ret.ext=path.slice(startDot,end)}if(startPart>0)ret.dir=path.slice(0,startPart-1);else if(isAbsolute2)ret.dir=\"/\";return ret}var sep=\"/\",delimiter=\":\",posix=((p)=>(p.posix=p,p))({resolve,normalize,isAbsolute,join,relative,_makeLong,dirname,basename,extname,format,parse,sep,delimiter,win32:null,posix:null});var path_default=posix;export{sep,resolve,relative,posix,parse,normalize,join,isAbsolute,format,extname,dirname,delimiter,path_default as default,basename,_makeLong};",
10
- "import type {\n\tRAGAdminActionPresentation,\n\tRAGAdminActionRecord,\n\tRAGAdminJobPresentation,\n\tRAGAdminJobRecord,\n\tAIMessage,\n\tRAGAnswerGroundingCaseSnapshotPresentation,\n\tRAGAnswerGroundingEvaluationCaseDiff,\n\tRAGAnswerGroundingEvaluationHistory,\n\tRAGAnswerGroundingEntityQualitySummary,\n\tRAGAnswerGroundingEntityQualityView,\n\tRAGAnswerGroundingEvaluationResponse,\n\tRAGCorpusHealth,\n\tRAGCorpusHealthPresentation,\n\tRAGExtractorReadiness,\n\tRAGReadinessPresentation,\n\tRAGGroundingOverviewPresentation,\n\tRAGGroundingProviderCaseComparisonPresentation,\n\tRAGGroundingProviderOverviewPresentation,\n\tRAGGroundingProviderPresentation,\n\tRAGComparisonOverviewPresentation,\n\tRAGComparisonPresentation,\n\tRAGChunkGraph,\n\tRAGChunkExcerpts,\n\tRAGExcerptModeCounts,\n\tRAGExcerptPromotionReason,\n\tRAGExcerptSelection,\n\tRAGChunkGraphEdge,\n\tRAGChunkGraphNavigation,\n\tRAGChunkGraphNode,\n\tRAGChunkGraphSectionGroup,\n\tRAGChunkStructure,\n\tRAGDocumentChunkPreview,\n\tRAGLabelValueRow,\n\tRAGRerankerComparisonEntry,\n\tRAGRetrievalComparison,\n\tRAGRetrievalComparisonEntry,\n\tRAGRetrievalComparisonRun,\n\tRAGRetrievalReleaseGroupHistoryPresentation,\n\tRAGRetrievalReleaseHistoryRunPresentation,\n\tRAGRetrievalReleaseTimelineSummary,\n\tRAGRetrievalTraceHistoryWindow,\n\tRAGRetrievalTraceStep,\n\tRAGRetrievalTrace,\n\tRAGHybridRetrievalMode,\n\tRAGSourceBalanceStrategy,\n\tRAGQualityOverviewPresentation,\n\tRAGSectionRetrievalDiagnostic,\n\tRAGEvaluationCaseDiff,\n\tRAGEvaluationCaseTracePresentation,\n\tRAGEvaluationEntityQualitySummary,\n\tRAGEvaluationEntityQualityView,\n\tRAGEvaluationHistory,\n\tRAGAnswerGroundingHistoryPresentation,\n\tRAGEvaluationResponse,\n\tRAGEvaluationHistoryPresentation,\n\tRAGEvaluationHistoryStore,\n\tRAGEvaluationSuiteSnapshotHistory,\n\tRAGEvaluationSuiteSnapshotHistoryPresentation,\n\tRAGEvaluationSuiteSnapshotPresentation,\n\tRAGEntityQualityPresentation,\n\tRAGEntityQualityViewPresentation,\n\tRAGRerankerComparison,\n\tRAGAnswerWorkflowState,\n\tRAGRetrievalTracePresentation,\n\tRAGSource,\n\tRAGSourceLabels,\n\tRAGSourceGroup,\n\tRAGSourceSummary,\n\tRAGStreamStage,\n\tRAGSyncOverviewPresentation,\n\tRAGSyncSourcePresentation,\n\tRAGSyncSourceRecord,\n\tRAGSyncSourceRunPresentation\n} from '@absolutejs/ai';\nimport {\n\tbuildRAGCitationReferenceMap,\n\tbuildRAGCitations,\n\tbuildRAGGroundedAnswer,\n\tbuildRAGGroundedAnswerSectionSummaries,\n\tbuildRAGGroundingReferences\n} from './grounding';\nimport {\n\tbuildRAGAnswerGroundingEntityQualityView,\n\tbuildRAGEvaluationEntityQualityView\n} from './quality';\n\nexport {\n\tbuildRAGCitationReferenceMap,\n\tbuildRAGCitations,\n\tbuildRAGGroundedAnswer,\n\tbuildRAGGroundedAnswerSectionSummaries,\n\tbuildRAGGroundingReferences\n};\n\nconst buildSourceGroupKey = (source: RAGSource) =>\n\tsource.source ?? source.title ?? source.chunkId;\n\nconst buildSourceLabel = (source: RAGSource) =>\n\tsource.source ?? source.title ?? source.chunkId;\n\nconst getContextNumber = (value: unknown) =>\n\ttypeof value === 'number' && Number.isFinite(value) ? value : undefined;\n\nconst getContextString = (value: unknown) =>\n\ttypeof value === 'string' && value.trim().length > 0\n\t\t? value.trim()\n\t\t: undefined;\n\nconst isRAGRetrievalTrace = (value: unknown): value is RAGRetrievalTrace => {\n\tif (!value || typeof value !== 'object') {\n\t\treturn false;\n\t}\n\n\tconst candidate = value as Record<string, unknown>;\n\n\treturn (\n\t\ttypeof candidate.query === 'string' &&\n\t\ttypeof candidate.transformedQuery === 'string' &&\n\t\tArray.isArray(candidate.variantQueries) &&\n\t\tArray.isArray(candidate.steps)\n\t);\n};\n\nconst formatTimestampLabel = (value: unknown) => {\n\tconst timestamp =\n\t\ttypeof value === 'number' && Number.isFinite(value)\n\t\t\t? value\n\t\t\t: typeof value === 'string'\n\t\t\t\t? Date.parse(value)\n\t\t\t\t: Number.NaN;\n\tif (!Number.isFinite(timestamp)) {\n\t\treturn undefined;\n\t}\n\n\treturn new Date(timestamp).toLocaleString('en-US', {\n\t\tdateStyle: 'medium',\n\t\ttimeStyle: 'short'\n\t});\n};\n\nconst formatRAGTraceValue = (value: unknown): string => {\n\tif (typeof value === 'string') return value;\n\tif (typeof value === 'number' || typeof value === 'boolean') {\n\t\treturn String(value);\n\t}\n\tif (Array.isArray(value)) {\n\t\treturn value.join(', ');\n\t}\n\tif (value && typeof value === 'object') {\n\t\treturn JSON.stringify(value);\n\t}\n\treturn 'n/a';\n};\n\nconst formatLeadContinuityCue = (value: unknown) => {\n\tconst cue = getContextString(value);\n\tswitch (cue) {\n\t\tcase 'immediate_follow_up':\n\t\t\treturn 'Immediate follow-up';\n\t\tcase 'near_follow_up':\n\t\t\treturn 'Near follow-up';\n\t\tcase 'close_follow_up':\n\t\t\treturn 'Close follow-up';\n\t\tcase 'delayed_follow_up':\n\t\t\treturn 'Delayed follow-up';\n\t\tcase 'immediate_prior':\n\t\t\treturn 'Immediate prior segment';\n\t\tcase 'near_prior':\n\t\t\treturn 'Near prior segment';\n\t\tcase 'close_prior':\n\t\t\treturn 'Close prior segment';\n\t\tcase 'delayed_prior':\n\t\t\treturn 'Delayed prior segment';\n\t\tdefault:\n\t\t\treturn undefined;\n\t}\n};\n\nconst formatLeadSpeakerAttributionCue = (value: unknown) => {\n\tconst cue = getContextString(value);\n\tswitch (cue) {\n\t\tcase 'quoted_match':\n\t\t\treturn 'Quoted speaker match';\n\t\tdefault:\n\t\t\treturn undefined;\n\t}\n};\n\nconst formatLeadChannelAttributionCue = (value: unknown) => {\n\tconst cue = getContextString(value);\n\tswitch (cue) {\n\t\tcase 'quoted_match':\n\t\t\treturn 'Quoted channel match';\n\t\tdefault:\n\t\t\treturn undefined;\n\t}\n};\n\nconst formatLeadMediaCueSummary = (input?: {\n\tleadSpeakerCue?: string;\n\tleadSpeakerAttributionCue?: string;\n\tleadChannelCue?: string;\n\tleadChannelAttributionCue?: string;\n\tleadContinuityCue?: string;\n}) => {\n\tconst parts = [\n\t\tinput?.leadSpeakerCue ? `speaker ${input.leadSpeakerCue}` : undefined,\n\t\tinput?.leadSpeakerAttributionCue === 'quoted_match'\n\t\t\t? 'quoted speaker match'\n\t\t\t: undefined,\n\t\tinput?.leadChannelCue ? `channel ${input.leadChannelCue}` : undefined,\n\t\tinput?.leadChannelAttributionCue === 'quoted_match'\n\t\t\t? 'quoted channel match'\n\t\t\t: undefined,\n\t\tformatLeadContinuityCue(input?.leadContinuityCue)\n\t].filter(\n\t\t(value): value is string =>\n\t\t\ttypeof value === 'string' && value.length > 0\n\t);\n\n\treturn parts.length > 0 ? parts.join(' · ') : 'none';\n};\n\nconst formatRAGTraceMetadataRow = (\n\tkey: string,\n\tvalue: unknown\n): RAGLabelValueRow => ({\n\tlabel:\n\t\tkey === 'sqliteQueryMode'\n\t\t\t? 'SQLite query mode'\n\t\t\t: key === 'postgresQueryMode'\n\t\t\t\t? 'Postgres query mode'\n\t\t\t\t: key === 'sqliteQueryPushdownMode'\n\t\t\t\t\t? 'SQLite pushdown mode'\n\t\t\t\t\t: key === 'postgresQueryPushdownMode'\n\t\t\t\t\t\t? 'Postgres pushdown mode'\n\t\t\t\t\t\t: key === 'sqliteQueryPushdownApplied'\n\t\t\t\t\t\t\t? 'SQLite pushdown applied'\n\t\t\t\t\t\t\t: key === 'postgresQueryPushdownApplied'\n\t\t\t\t\t\t\t\t? 'Postgres pushdown applied'\n\t\t\t\t\t\t\t\t: key === 'sqliteQueryPushdownClauseCount'\n\t\t\t\t\t\t\t\t\t? 'SQLite pushdown clauses'\n\t\t\t\t\t\t\t\t\t: key === 'postgresQueryPushdownClauseCount'\n\t\t\t\t\t\t\t\t\t\t? 'Postgres pushdown clauses'\n\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryPushdownCoverageRatio'\n\t\t\t\t\t\t\t\t\t\t\t? 'SQLite pushdown coverage'\n\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryPushdownCoverageRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres pushdown coverage'\n\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryTotalFilterClauseCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite total filter clauses'\n\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryTotalFilterClauseCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres total filter clauses'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryJsRemainderClauseCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite JS remainder clauses'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryMultiplierUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite query multiplier'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryPlannerProfileUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite query profile'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryCandidateLimitUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite candidate limit'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryMaxBackfillsUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite max backfills'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryMinResultsUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite min results'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryFillPolicyUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite fill policy'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryJsRemainderClauseCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres JS remainder clauses'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryMultiplierUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres query multiplier'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryPlannerProfileUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres query profile'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryCandidateLimitUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres candidate limit'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryMaxBackfillsUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres max backfills'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryMinResultsUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres min results'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryFillPolicyUsed'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres fill policy'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryJsRemainderRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite JS remainder share'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryJsRemainderRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres JS remainder share'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryFilteredCandidates'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite filtered candidates'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryFilteredCandidates'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres filtered candidates'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryInitialSearchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite initial searchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryInitialSearchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres initial searchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryFinalSearchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite final searchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryFinalSearchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres final searchK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQuerySearchExpansionRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite search expansion'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQuerySearchExpansionRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres search expansion'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryBackfillCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite backfill count'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryBackfillLimitReached'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite backfill limit reached'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryMinResultsSatisfied'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite min results satisfied'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryBackfillCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres backfill count'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryBackfillLimitReached'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres backfill limit reached'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryMinResultsSatisfied'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres min results satisfied'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryReturnedCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite returned hits'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryReturnedCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres returned hits'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryCandidateYieldRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite candidate yield'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryCandidateYieldRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres candidate yield'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryTopKFillRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite topK fill rate'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryTopKFillRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres topK fill rate'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryUnderfilledTopK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite underfilled topK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryUnderfilledTopK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres underfilled topK'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryCandidateBudgetExhausted'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite candidate budget exhausted'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryCandidateBudgetExhausted'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres candidate budget exhausted'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'sqliteQueryCandidateCoverage'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'SQLite candidate coverage'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresQueryCandidateCoverage'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres candidate coverage'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresIndexType'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres index type'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresIndexName'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres index name'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresIndexPresent'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres index present'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresEstimatedRowCount'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres estimated rows'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresTableBytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres table bytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresIndexBytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres index bytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresTotalBytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres total bytes'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'postgresIndexStorageRatio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Postgres index storage ratio'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'leadSpeakerCue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Lead speaker cue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'leadSpeakerAttributionCue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Lead speaker attribution'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'leadChannelAttributionCue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Lead channel attribution'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'leadChannelCue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Lead channel cue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key ===\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t 'leadContinuityCue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? 'Lead continuity cue'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: key,\n\tvalue:\n\t\tkey === 'sourceAwareChunkReason'\n\t\t\t? (formatSourceAwareChunkReason(value) ??\n\t\t\t\tformatRAGTraceValue(value))\n\t\t\t: key === 'leadSpeakerAttributionCue'\n\t\t\t\t? (formatLeadSpeakerAttributionCue(value) ??\n\t\t\t\t\tformatRAGTraceValue(value))\n\t\t\t\t: key === 'leadChannelAttributionCue'\n\t\t\t\t\t? (formatLeadChannelAttributionCue(value) ??\n\t\t\t\t\t\tformatRAGTraceValue(value))\n\t\t\t\t\t: key === 'leadContinuityCue'\n\t\t\t\t\t\t? (formatLeadContinuityCue(value) ??\n\t\t\t\t\t\t\tformatRAGTraceValue(value))\n\t\t\t\t\t\t: formatRAGTraceValue(value)\n});\n\nexport const buildRAGRetrievalTracePresentation = (\n\ttrace?: RAGRetrievalTrace\n): RAGRetrievalTracePresentation => {\n\tif (!trace) {\n\t\treturn {\n\t\t\tdetails: [],\n\t\t\tstats: [],\n\t\t\tsteps: []\n\t\t};\n\t}\n\n\tconst stats: RAGLabelValueRow[] = [\n\t\t{ label: 'Mode', value: trace.mode },\n\t\t{ label: 'Final Results', value: String(trace.resultCounts.final) },\n\t\t{\n\t\t\tlabel: 'Vector Candidates',\n\t\t\tvalue: String(trace.resultCounts.vector)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Lexical Candidates',\n\t\t\tvalue: String(trace.resultCounts.lexical)\n\t\t}\n\t];\n\tconst details: RAGLabelValueRow[] = [\n\t\t{ label: 'Transformed query', value: trace.transformedQuery },\n\t\t...(trace.queryTransformLabel || trace.queryTransformProvider\n\t\t\t? [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Query transform',\n\t\t\t\t\t\tvalue:\n\t\t\t\t\t\t\ttrace.queryTransformLabel ??\n\t\t\t\t\t\t\ttrace.queryTransformProvider ??\n\t\t\t\t\t\t\t'configured'\n\t\t\t\t\t},\n\t\t\t\t\t...(trace.queryTransformReason\n\t\t\t\t\t\t? [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlabel: 'Query transform reason',\n\t\t\t\t\t\t\t\t\tvalue: trace.queryTransformReason\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t]\n\t\t\t\t\t\t: [])\n\t\t\t\t]\n\t\t\t: []),\n\t\t{\n\t\t\tlabel: 'Variant queries',\n\t\t\tvalue:\n\t\t\t\ttrace.variantQueries.length > 0\n\t\t\t\t\t? trace.variantQueries.join(' · ')\n\t\t\t\t\t: 'none'\n\t\t},\n\t\t...(trace.requestedMode && trace.requestedMode !== trace.mode\n\t\t\t? [{ label: 'Requested mode', value: trace.requestedMode }]\n\t\t\t: []),\n\t\t...(trace.routingLabel || trace.routingProvider\n\t\t\t? [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Routing decision',\n\t\t\t\t\t\tvalue:\n\t\t\t\t\t\t\ttrace.routingLabel ??\n\t\t\t\t\t\t\ttrace.routingProvider ??\n\t\t\t\t\t\t\t'configured'\n\t\t\t\t\t},\n\t\t\t\t\t...(trace.routingReason\n\t\t\t\t\t\t? [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlabel: 'Routing reason',\n\t\t\t\t\t\t\t\t\tvalue: trace.routingReason\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t]\n\t\t\t\t\t\t: [])\n\t\t\t\t]\n\t\t\t: []),\n\t\t{ label: 'Candidate topK', value: String(trace.candidateTopK) },\n\t\t{ label: 'Lexical topK', value: String(trace.lexicalTopK) }\n\t];\n\tconst steps = trace.steps.map((step) => {\n\t\tconst sqlitePlannerCues = formatSQLitePlannerCueSummary(step.metadata);\n\t\tconst postgresPlannerCues = formatPostgresPlannerCueSummary(\n\t\t\tstep.metadata\n\t\t);\n\n\t\treturn {\n\t\t\tcount: step.count,\n\t\t\tlabel: step.label,\n\t\t\trows: [\n\t\t\t\t{ label: 'stage', value: step.stage },\n\t\t\t\t...(typeof step.count === 'number'\n\t\t\t\t\t? [{ label: 'count', value: String(step.count) }]\n\t\t\t\t\t: []),\n\t\t\t\t...(typeof step.durationMs === 'number'\n\t\t\t\t\t? [{ label: 'durationMs', value: String(step.durationMs) }]\n\t\t\t\t\t: []),\n\t\t\t\t...(sqlitePlannerCues !== 'none'\n\t\t\t\t\t? [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlabel: 'SQLite planner cues',\n\t\t\t\t\t\t\t\tvalue: sqlitePlannerCues\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t]\n\t\t\t\t\t: []),\n\t\t\t\t...(postgresPlannerCues !== 'none'\n\t\t\t\t\t? [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlabel: 'Postgres planner cues',\n\t\t\t\t\t\t\t\tvalue: postgresPlannerCues\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t]\n\t\t\t\t\t: []),\n\t\t\t\t...Object.entries(step.metadata ?? {}).map(([key, value]) =>\n\t\t\t\t\tformatRAGTraceMetadataRow(key, value)\n\t\t\t\t)\n\t\t\t],\n\t\t\tstage: step.stage\n\t\t};\n\t});\n\n\treturn {\n\t\tdetails,\n\t\tstats,\n\t\tsteps\n\t};\n};\n\nconst formatCompactList = (values?: string[]) =>\n\tvalues && values.length > 0 ? values.join(', ') : 'none';\n\nconst formatCoverageMap = (entries?: Record<string, number>) => {\n\tif (!entries) {\n\t\treturn 'none';\n\t}\n\n\tconst values = Object.entries(entries);\n\treturn values.length > 0\n\t\t? values.map(([key, value]) => `${key} ${value}`).join(' · ')\n\t\t: 'none';\n};\n\nconst formatByteSizeLabel = (value?: number) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value) || value < 0) {\n\t\treturn 'n/a';\n\t}\n\n\tif (value < 1024) {\n\t\treturn `${Math.round(value)} B`;\n\t}\n\n\tif (value < 1024 * 1024) {\n\t\treturn `${(value / 1024).toFixed(value >= 10 * 1024 ? 0 : 1)} KiB`;\n\t}\n\n\tif (value < 1024 * 1024 * 1024) {\n\t\treturn `${(value / (1024 * 1024)).toFixed(\n\t\t\tvalue >= 10 * 1024 * 1024 ? 0 : 1\n\t\t)} MiB`;\n\t}\n\n\treturn `${(value / (1024 * 1024 * 1024)).toFixed(\n\t\tvalue >= 10 * 1024 * 1024 * 1024 ? 0 : 1\n\t)} GiB`;\n};\n\nconst formatDurationLabel = (value?: number) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value)) {\n\t\treturn 'n/a';\n\t}\n\n\tif (value < 1000) {\n\t\treturn `${value}ms`;\n\t}\n\n\tif (value < 60000) {\n\t\treturn `${(value / 1000).toFixed(value >= 10000 ? 0 : 1)}s`;\n\t}\n\n\tif (value < 3600000) {\n\t\treturn `${(value / 60000).toFixed(value >= 600000 ? 0 : 1)}m`;\n\t}\n\n\treturn `${(value / 3600000).toFixed(value >= 36000000 ? 0 : 1)}h`;\n};\n\nconst formatDateLabel = (value?: number) =>\n\ttypeof value === 'number' && Number.isFinite(value)\n\t\t? new Date(value).toLocaleString('en-US')\n\t\t: 'n/a';\n\nconst formatAgeLabel = (value?: number) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value)) {\n\t\treturn 'n/a';\n\t}\n\n\tif (value < 1000) {\n\t\treturn `${Math.round(value)}ms`;\n\t}\n\n\tif (value < 60000) {\n\t\treturn `${(value / 1000).toFixed(value >= 10000 ? 0 : 1)}s`;\n\t}\n\n\tif (value < 3600000) {\n\t\treturn `${(value / 60000).toFixed(value >= 600000 ? 0 : 1)}m`;\n\t}\n\n\tif (value < 86400000) {\n\t\treturn `${(value / 3600000).toFixed(value >= 36000000 ? 0 : 1)}h`;\n\t}\n\n\treturn `${(value / 86400000).toFixed(value >= 864000000 ? 0 : 1)}d`;\n};\n\nconst formatSourceAwareChunkReason = (value: unknown) => {\n\tconst reason = getContextString(value);\n\tif (reason === 'section_boundary') {\n\t\treturn 'Chunk boundary section';\n\t}\n\tif (reason === 'size_limit') {\n\t\treturn 'Chunk boundary size limit';\n\t}\n\tif (reason === 'source_native_unit') {\n\t\treturn 'Chunk boundary source-native unit';\n\t}\n\treturn undefined;\n};\n\nconst buildSourceAwareUnitScopeLabel = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst sectionKind = getContextString(metadata.sectionKind);\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tconst pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n\tconst pdfTextKind = getContextString(metadata.pdfTextKind);\n\tconst officeBlockKindValue = getContextString(metadata.officeBlockKind);\n\tconst officeBlockKind =\n\t\tofficeBlockKindValue === 'table' ||\n\t\tofficeBlockKindValue === 'list' ||\n\t\tofficeBlockKindValue === 'paragraph'\n\t\t\t? officeBlockKindValue\n\t\t\t: undefined;\n\tconst sheetName = getContextString(metadata.sheetName);\n\tconst spreadsheetTableLabel = formatSpreadsheetTableLabel(\n\t\tgetContextNumber(metadata.spreadsheetTableIndex),\n\t\tgetContextNumber(metadata.spreadsheetTableCount)\n\t);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\tconst slideNumber =\n\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\n\tif (\n\t\tsectionPath.length > 0 &&\n\t\t(sectionKind === 'markdown_heading' ||\n\t\t\tsectionKind === 'html_heading' ||\n\t\t\tsectionKind === 'office_heading' ||\n\t\t\tsectionKind === undefined)\n\t) {\n\t\treturn `Source-aware section ${sectionPath.join(' > ')}`;\n\t}\n\n\tif (sectionKind === 'pdf_block') {\n\t\tif (pdfSemanticRole === 'figure_caption' && sectionTitle) {\n\t\t\treturn `Source-aware PDF figure caption ${sectionTitle}`;\n\t\t}\n\t\tif (pdfSemanticRole === 'figure_body' && sectionTitle) {\n\t\t\treturn `Source-aware PDF figure body ${sectionTitle}`;\n\t\t}\n\t\tif (pdfTextKind === 'table_like' && sectionTitle) {\n\t\t\treturn `Source-aware PDF table block ${sectionTitle}`;\n\t\t}\n\t\tif (sectionTitle) {\n\t\t\treturn `Source-aware PDF block ${sectionTitle}`;\n\t\t}\n\t\treturn 'Source-aware PDF block';\n\t}\n\n\tif (sectionKind === 'office_block') {\n\t\tconst officeSectionLabel =\n\t\t\tsectionPath.length > 0 ? sectionPath.join(' > ') : sectionTitle;\n\t\tif (officeBlockKind && officeSectionLabel) {\n\t\t\treturn `Source-aware office ${officeBlockKind} block ${officeSectionLabel}`;\n\t\t}\n\t\tif (officeSectionLabel) {\n\t\t\treturn `Source-aware office block ${officeSectionLabel}`;\n\t\t}\n\t\treturn 'Source-aware office block';\n\t}\n\n\tif (\n\t\tsectionKind === 'spreadsheet_rows' ||\n\t\t(sectionKind === undefined &&\n\t\t\t(sheetName ||\n\t\t\t\tspreadsheetTableLabel ||\n\t\t\t\tgetContextNumber(metadata.spreadsheetRowStart) !== undefined ||\n\t\t\t\tgetContextNumber(metadata.spreadsheetRowEnd) !== undefined))\n\t) {\n\t\tif (sheetName && spreadsheetTableLabel) {\n\t\t\treturn `Source-aware spreadsheet ${sheetName} ${spreadsheetTableLabel}`;\n\t\t}\n\t\tif (sheetName) {\n\t\t\treturn `Source-aware spreadsheet ${sheetName}`;\n\t\t}\n\t\treturn 'Source-aware spreadsheet';\n\t}\n\n\tif (sectionKind === 'presentation_slide') {\n\t\tif (slideNumber && slideTitle) {\n\t\t\treturn `Source-aware slide ${slideNumber} ${slideTitle}`;\n\t\t}\n\t\tif (slideTitle) {\n\t\t\treturn `Source-aware slide ${slideTitle}`;\n\t\t}\n\t\tif (slideNumber) {\n\t\t\treturn `Source-aware slide ${slideNumber}`;\n\t\t}\n\t\treturn 'Source-aware slide';\n\t}\n\n\treturn undefined;\n};\n\nconst buildSyncOverviewLatestRow = (sources: RAGSyncSourceRecord[]) => {\n\tconst latest = [...sources]\n\t\t.filter(\n\t\t\t(record) =>\n\t\t\t\ttypeof record.lastSuccessfulSyncAt === 'number' ||\n\t\t\t\ttypeof record.lastSyncedAt === 'number'\n\t\t)\n\t\t.sort(\n\t\t\t(left, right) =>\n\t\t\t\t(right.lastSuccessfulSyncAt ?? right.lastSyncedAt ?? 0) -\n\t\t\t\t(left.lastSuccessfulSyncAt ?? left.lastSyncedAt ?? 0)\n\t\t)[0];\n\n\tif (!latest) {\n\t\treturn {\n\t\t\tlabel: 'Latest sync',\n\t\t\tvalue: 'No completed run yet'\n\t\t};\n\t}\n\n\treturn {\n\t\tlabel: 'Latest sync',\n\t\tvalue: [\n\t\t\tlatest.label,\n\t\t\ttypeof latest.documentCount === 'number'\n\t\t\t\t? `${latest.documentCount} docs`\n\t\t\t\t: '',\n\t\t\ttypeof latest.chunkCount === 'number'\n\t\t\t\t? `${latest.chunkCount} chunks`\n\t\t\t\t: '',\n\t\t\ttypeof latest.lastSyncDurationMs === 'number'\n\t\t\t\t? formatDurationLabel(latest.lastSyncDurationMs)\n\t\t\t\t: '',\n\t\t\ttypeof latest.lastSuccessfulSyncAt === 'number'\n\t\t\t\t? formatDateLabel(latest.lastSuccessfulSyncAt)\n\t\t\t\t: typeof latest.lastSyncedAt === 'number'\n\t\t\t\t\t? formatDateLabel(latest.lastSyncedAt)\n\t\t\t\t\t: ''\n\t\t]\n\t\t\t.filter(Boolean)\n\t\t\t.join(' · ')\n\t};\n};\n\nconst formatAdminActionLabel = (\n\tvalue: RAGAdminActionRecord['action'] | RAGAdminJobRecord['action']\n) => value.replaceAll('_', ' ');\n\nconst buildAdminTimingLabel = (input: {\n\telapsedMs?: number;\n\tstartedAt: number;\n}) =>\n\ttypeof input.elapsedMs === 'number'\n\t\t? formatDurationLabel(input.elapsedMs)\n\t\t: formatDateLabel(input.startedAt);\n\nexport const buildRAGAdminJobPresentation = (\n\tjob: RAGAdminJobRecord\n): RAGAdminJobPresentation => ({\n\tid: job.id,\n\taction: job.action,\n\tstatus: job.status,\n\tsummary: [\n\t\tjob.status.toUpperCase(),\n\t\tformatAdminActionLabel(job.action),\n\t\tjob.target,\n\t\tbuildAdminTimingLabel(job)\n\t]\n\t\t.filter(Boolean)\n\t\t.join(' · '),\n\trows: [\n\t\t{ label: 'Action', value: formatAdminActionLabel(job.action) },\n\t\t{ label: 'Status', value: job.status },\n\t\t...(job.target ? [{ label: 'Target', value: job.target }] : []),\n\t\t{ label: 'Timing', value: buildAdminTimingLabel(job) },\n\t\t...(job.error ? [{ label: 'Error', value: job.error }] : [])\n\t]\n});\n\nexport const buildRAGAdminJobPresentations = (\n\tjobs?: RAGAdminJobRecord[]\n): RAGAdminJobPresentation[] =>\n\t(jobs ?? []).slice(0, 3).map(buildRAGAdminJobPresentation);\n\nexport const buildRAGAdminActionPresentation = (\n\taction: RAGAdminActionRecord\n): RAGAdminActionPresentation => ({\n\tid: action.id,\n\taction: action.action,\n\tstatus: action.status,\n\tsummary: [\n\t\taction.status.toUpperCase(),\n\t\tformatAdminActionLabel(action.action),\n\t\taction.documentId ?? action.target,\n\t\tbuildAdminTimingLabel(action)\n\t]\n\t\t.filter(Boolean)\n\t\t.join(' · '),\n\trows: [\n\t\t{ label: 'Action', value: formatAdminActionLabel(action.action) },\n\t\t{ label: 'Status', value: action.status },\n\t\t...(action.documentId\n\t\t\t? [{ label: 'Document', value: action.documentId }]\n\t\t\t: action.target\n\t\t\t\t? [{ label: 'Target', value: action.target }]\n\t\t\t\t: []),\n\t\t{ label: 'Timing', value: buildAdminTimingLabel(action) },\n\t\t...(action.error ? [{ label: 'Error', value: action.error }] : [])\n\t]\n});\n\nexport const buildRAGAdminActionPresentations = (\n\tactions?: RAGAdminActionRecord[]\n): RAGAdminActionPresentation[] =>\n\t(actions ?? []).slice(0, 3).map(buildRAGAdminActionPresentation);\n\nconst buildRAGSyncSourceRunPresentations = (\n\tsource: RAGSyncSourceRecord\n): RAGSyncSourceRunPresentation[] => {\n\tif (!Array.isArray(source.metadata?.recentRuns)) {\n\t\treturn [];\n\t}\n\n\treturn (source.metadata.recentRuns as Array<Record<string, unknown>>)\n\t\t.slice(0, 3)\n\t\t.map((entry, index) => {\n\t\t\tconst trigger =\n\t\t\t\ttypeof entry.trigger === 'string' ? entry.trigger : 'sync';\n\t\t\tconst status =\n\t\t\t\ttypeof entry.status === 'string' ? entry.status : 'unknown';\n\t\t\tconst finishedAt =\n\t\t\t\ttypeof entry.finishedAt === 'number'\n\t\t\t\t\t? formatDateLabel(entry.finishedAt)\n\t\t\t\t\t: 'n/a';\n\t\t\tconst duration =\n\t\t\t\ttypeof entry.durationMs === 'number'\n\t\t\t\t\t? formatDurationLabel(entry.durationMs)\n\t\t\t\t\t: 'n/a';\n\t\t\tconst docs =\n\t\t\t\ttypeof entry.documentCount === 'number'\n\t\t\t\t\t? `${entry.documentCount} docs`\n\t\t\t\t\t: 'n/a';\n\t\t\tconst chunks =\n\t\t\t\ttypeof entry.chunkCount === 'number'\n\t\t\t\t\t? `${entry.chunkCount} chunks`\n\t\t\t\t\t: 'n/a';\n\t\t\tconst error =\n\t\t\t\ttypeof entry.error === 'string' && entry.error.length > 0\n\t\t\t\t\t? entry.error\n\t\t\t\t\t: undefined;\n\n\t\t\treturn {\n\t\t\t\tlabel: `Run ${index + 1}`,\n\t\t\t\tstatus,\n\t\t\t\tsummary: `${trigger} · ${status} · ${docs} · ${chunks} · ${duration} · ${finishedAt}`,\n\t\t\t\trows: [\n\t\t\t\t\t{ label: 'Trigger', value: trigger },\n\t\t\t\t\t{ label: 'Status', value: status },\n\t\t\t\t\t{ label: 'Output', value: `${docs} · ${chunks}` },\n\t\t\t\t\t{ label: 'Duration', value: duration },\n\t\t\t\t\t{ label: 'Finished', value: finishedAt },\n\t\t\t\t\t...(error ? [{ label: 'Error', value: error }] : [])\n\t\t\t\t]\n\t\t\t};\n\t\t});\n};\n\nexport const buildRAGSyncSourcePresentation = (\n\tsource: RAGSyncSourceRecord\n): RAGSyncSourcePresentation => {\n\tconst provider =\n\t\ttypeof source.metadata?.provider === 'string'\n\t\t\t? source.metadata.provider\n\t\t\t: undefined;\n\tconst accountMode =\n\t\ttypeof source.metadata?.accountMode === 'string'\n\t\t\t? source.metadata.accountMode\n\t\t\t: undefined;\n\tconst schedule =\n\t\ttypeof source.metadata?.schedule === 'string'\n\t\t\t? source.metadata.schedule\n\t\t\t: undefined;\n\tconst lastTrigger =\n\t\ttypeof source.metadata?.lastTrigger === 'string'\n\t\t\t? source.metadata.lastTrigger\n\t\t\t: undefined;\n\tconst liveReady =\n\t\ttypeof source.metadata?.liveReady === 'string'\n\t\t\t? source.metadata.liveReady\n\t\t\t: undefined;\n\tconst diagnosticSummary = source.diagnostics?.summary;\n\tconst diagnosticTags =\n\t\tsource.diagnostics?.entries.map((entry) =>\n\t\t\tentry.code\n\t\t\t\t.replace(/_/g, ' ')\n\t\t\t\t.replace(/\\b\\w/g, (letter) => letter.toUpperCase())\n\t\t) ?? [];\n\tconst retryGuidance = source.diagnostics?.retryGuidance;\n\n\treturn {\n\t\tid: source.id,\n\t\tlabel: source.label,\n\t\tkind: source.kind,\n\t\tstatus: source.status,\n\t\tsummary: [\n\t\t\tsource.kind,\n\t\t\tsource.status,\n\t\t\ttypeof source.documentCount === 'number'\n\t\t\t\t? `${source.documentCount} docs`\n\t\t\t\t: '',\n\t\t\ttypeof source.chunkCount === 'number'\n\t\t\t\t? `${source.chunkCount} chunks`\n\t\t\t\t: '',\n\t\t\ttypeof source.lastSyncDurationMs === 'number'\n\t\t\t\t? formatDurationLabel(source.lastSyncDurationMs)\n\t\t\t\t: '',\n\t\t\ttypeof source.lastSuccessfulSyncAt === 'number'\n\t\t\t\t? `last success ${formatDateLabel(source.lastSuccessfulSyncAt)}`\n\t\t\t\t: typeof source.lastSyncedAt === 'number'\n\t\t\t\t\t? `last sync ${formatDateLabel(source.lastSyncedAt)}`\n\t\t\t\t\t: ''\n\t\t]\n\t\t\t.filter(Boolean)\n\t\t\t.join(' · '),\n\t\trows: [\n\t\t\t...(source.target\n\t\t\t\t? [{ label: 'Target', value: source.target }]\n\t\t\t\t: []),\n\t\t\t...(provider ? [{ label: 'Provider', value: provider }] : []),\n\t\t\t...(accountMode\n\t\t\t\t? [{ label: 'Account mode', value: accountMode }]\n\t\t\t\t: []),\n\t\t\t...(schedule ? [{ label: 'Schedule', value: schedule }] : []),\n\t\t\t...(lastTrigger\n\t\t\t\t? [{ label: 'Last trigger', value: lastTrigger }]\n\t\t\t\t: []),\n\t\t\t...(typeof source.lastSuccessfulSyncAt === 'number'\n\t\t\t\t? [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: 'Last success',\n\t\t\t\t\t\t\tvalue: formatDateLabel(source.lastSuccessfulSyncAt)\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t: []),\n\t\t\t...(typeof source.nextRetryAt === 'number'\n\t\t\t\t? [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: 'Next retry',\n\t\t\t\t\t\t\tvalue: formatDateLabel(source.nextRetryAt)\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t: []),\n\t\t\t...(source.lastError\n\t\t\t\t? [{ label: 'Last error', value: source.lastError }]\n\t\t\t\t: []),\n\t\t\t...(diagnosticSummary\n\t\t\t\t? [{ label: 'Diagnostics', value: diagnosticSummary }]\n\t\t\t\t: []),\n\t\t\t...(retryGuidance\n\t\t\t\t? [{ label: 'Retry guidance', value: retryGuidance.reason }]\n\t\t\t\t: [])\n\t\t],\n\t\ttags: [\n\t\t\tprovider,\n\t\t\taccountMode ? `mode ${accountMode}` : undefined,\n\t\t\tliveReady,\n\t\t\t...diagnosticTags\n\t\t].filter((value): value is string => Boolean(value)),\n\t\textendedSummary: diagnosticSummary ?? source.description ?? liveReady,\n\t\truns: buildRAGSyncSourceRunPresentations(source)\n\t};\n};\n\nexport const buildRAGSyncSourcePresentations = (\n\tsources?: RAGSyncSourceRecord[]\n): RAGSyncSourcePresentation[] =>\n\t(sources ?? []).map(buildRAGSyncSourcePresentation);\n\nexport const buildRAGReadinessPresentation = (\n\treadiness?: RAGExtractorReadiness\n): RAGReadinessPresentation => {\n\tif (!readiness) {\n\t\treturn {\n\t\t\tsections: [\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Provider',\n\t\t\t\t\ttitle: 'Unavailable',\n\t\t\t\t\tsummary: 'Readiness data is not available yet.'\n\t\t\t\t}\n\t\t\t]\n\t\t};\n\t}\n\n\treturn {\n\t\tsections: [\n\t\t\t{\n\t\t\t\tlabel: 'Provider',\n\t\t\t\ttitle: readiness.providerConfigured\n\t\t\t\t\t? (readiness.providerName ?? 'Runtime provider routing')\n\t\t\t\t\t: 'Not configured',\n\t\t\t\tsummary: readiness.providerConfigured\n\t\t\t\t\t? readiness.model\n\t\t\t\t\t\t? `Requests route through ${readiness.providerName ?? 'the runtime provider registry'} with default model ${readiness.model}.`\n\t\t\t\t\t\t: `Requests route through ${readiness.providerName ?? 'the runtime provider registry'}.`\n\t\t\t\t\t: 'Provider-backed retrieval is not configured yet.'\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Embeddings',\n\t\t\t\ttitle: readiness.embeddingConfigured\n\t\t\t\t\t? readiness.embeddingModel ===\n\t\t\t\t\t\t'collection-managed embeddings'\n\t\t\t\t\t\t? 'Collection-managed'\n\t\t\t\t\t\t: 'Configured'\n\t\t\t\t\t: 'Missing',\n\t\t\t\tsummary: readiness.embeddingConfigured\n\t\t\t\t\t? readiness.embeddingModel ===\n\t\t\t\t\t\t'collection-managed embeddings'\n\t\t\t\t\t\t? 'Embeddings come from the collection and vector store layer, so retrieval stays vector-backed without a separate top-level embedding provider.'\n\t\t\t\t\t\t: (readiness.embeddingModel ??\n\t\t\t\t\t\t\t'Embedding model configured.')\n\t\t\t\t\t: 'Embeddings are not configured yet.'\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Retrieval Stack',\n\t\t\t\ttitle: readiness.rerankerConfigured\n\t\t\t\t\t? 'Reranker ready'\n\t\t\t\t\t: 'Vector only',\n\t\t\t\tsummary: readiness.indexManagerConfigured\n\t\t\t\t\t? 'Index manager configured.'\n\t\t\t\t\t: 'Index manager not configured.'\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Extractors',\n\t\t\t\ttitle: readiness.extractorsConfigured\n\t\t\t\t\t? `${readiness.extractorNames.length} configured`\n\t\t\t\t\t: 'None configured',\n\t\t\t\tsummary: readiness.extractorsConfigured\n\t\t\t\t\t? `Configured extractors: ${formatCompactList(readiness.extractorNames)}`\n\t\t\t\t\t: 'No extractors configured.',\n\t\t\t\ttags:\n\t\t\t\t\treadiness.extractorNames.length > 0\n\t\t\t\t\t\t? readiness.extractorNames\n\t\t\t\t\t\t: ['No extractors configured']\n\t\t\t}\n\t\t]\n\t};\n};\n\nexport const buildRAGCorpusHealthPresentation = (\n\thealth?: RAGCorpusHealth\n): RAGCorpusHealthPresentation => {\n\tif (!health) {\n\t\treturn {\n\t\t\tsections: [\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Corpus health',\n\t\t\t\t\ttitle: 'Unavailable',\n\t\t\t\t\tsummary: 'Corpus health is not available yet.'\n\t\t\t\t}\n\t\t\t]\n\t\t};\n\t}\n\n\treturn {\n\t\tsections: [\n\t\t\t{\n\t\t\t\tlabel: 'Corpus coverage',\n\t\t\t\ttitle: `Formats: ${formatCoverageMap(health.coverageByFormat)}`,\n\t\t\t\tsummary: `Kinds: ${formatCoverageMap(health.coverageByKind)}`,\n\t\t\t\trows: [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Average chunks per document',\n\t\t\t\t\t\tvalue: health.averageChunksPerDocument.toFixed(2)\n\t\t\t\t\t}\n\t\t\t\t]\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Chunk quality',\n\t\t\t\ttitle: `${health.averageChunksPerDocument.toFixed(2)} avg chunks/doc`,\n\t\t\t\tsummary: `Empty docs ${health.emptyDocuments} · empty chunks ${health.emptyChunks} · low signal ${health.lowSignalChunks}`,\n\t\t\t\trows: [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Missing source',\n\t\t\t\t\t\tvalue: String(health.documentsMissingSource)\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Missing title',\n\t\t\t\t\t\tvalue: String(health.documentsMissingTitle)\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Missing metadata',\n\t\t\t\t\t\tvalue: String(health.documentsMissingMetadata)\n\t\t\t\t\t}\n\t\t\t\t]\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Freshness',\n\t\t\t\ttitle: `${health.staleDocuments.length} stale docs`,\n\t\t\t\tsummary: `Stale threshold ${formatAgeLabel(health.staleAfterMs)}`,\n\t\t\t\trows: [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Oldest age',\n\t\t\t\t\t\tvalue: formatAgeLabel(health.oldestDocumentAgeMs)\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Newest age',\n\t\t\t\t\t\tvalue: formatAgeLabel(health.newestDocumentAgeMs)\n\t\t\t\t\t}\n\t\t\t\t]\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Failures',\n\t\t\t\ttitle: `${health.failedIngestJobs} ingest · ${health.failedAdminJobs} admin`,\n\t\t\t\tsummary: `Duplicate sources ${health.duplicateSourceGroups.length} · duplicate ids ${health.duplicateDocumentIdGroups.length}`,\n\t\t\t\trows: [\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Failures by input',\n\t\t\t\t\t\tvalue: formatCoverageMap(health.failuresByInputKind)\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Failures by extractor',\n\t\t\t\t\t\tvalue: formatCoverageMap(health.failuresByExtractor)\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tlabel: 'Failures by admin action',\n\t\t\t\t\t\tvalue: formatCoverageMap(health.failuresByAdminAction)\n\t\t\t\t\t}\n\t\t\t\t]\n\t\t\t}\n\t\t]\n\t};\n};\n\nexport const buildRAGSyncOverviewPresentation = (\n\tsources?: RAGSyncSourceRecord[]\n): RAGSyncOverviewPresentation => {\n\tconst records = sources ?? [];\n\tif (records.length === 0) {\n\t\treturn {\n\t\t\trows: [\n\t\t\t\t{ label: 'Configured sync sources', value: '0' },\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Latest sync',\n\t\t\t\t\tvalue: 'No sync sources configured yet.'\n\t\t\t\t}\n\t\t\t],\n\t\t\tsections: [\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Sync overview',\n\t\t\t\t\ttitle: 'No sync sources configured',\n\t\t\t\t\tsummary:\n\t\t\t\t\t\t'Add sync sources to monitor directories, URLs, storage, or mailboxes.'\n\t\t\t\t}\n\t\t\t]\n\t\t};\n\t}\n\n\tconst countByStatus = (status: RAGSyncSourceRecord['status']) =>\n\t\trecords.filter((record) => record.status === status).length;\n\n\treturn {\n\t\trows: [\n\t\t\t{ label: 'Configured sync sources', value: String(records.length) },\n\t\t\t{ label: 'Completed', value: String(countByStatus('completed')) },\n\t\t\t{ label: 'Running', value: String(countByStatus('running')) },\n\t\t\t{\n\t\t\t\tlabel: 'Failed',\n\t\t\t\tvalue: String(countByStatus('failed'))\n\t\t\t},\n\t\t\tbuildSyncOverviewLatestRow(records)\n\t\t],\n\t\tsections: [\n\t\t\t{\n\t\t\t\tlabel: 'Sync overview',\n\t\t\t\ttitle: `${records.length} configured`,\n\t\t\t\tsummary: `${countByStatus('completed')} completed · ${countByStatus('running')} running · ${countByStatus('failed')} failed`\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Latest sync',\n\t\t\t\ttitle: buildSyncOverviewLatestRow(records).value,\n\t\t\t\tsummary: 'Most recent completed or last-known sync activity.'\n\t\t\t}\n\t\t]\n\t};\n};\n\nconst formatMediaTimestamp = (value: unknown) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value) || value < 0) {\n\t\treturn undefined;\n\t}\n\n\tconst totalSeconds = Math.floor(value / 1000);\n\tconst minutes = Math.floor(totalSeconds / 60);\n\tconst seconds = totalSeconds % 60;\n\tconst milliseconds = Math.floor(value % 1000);\n\n\treturn `${String(minutes).padStart(2, '0')}:${String(seconds).padStart(\n\t\t2,\n\t\t'0'\n\t)}.${String(milliseconds).padStart(3, '0')}`;\n};\n\nconst getAttachmentName = (source?: string, title?: string) => {\n\tconst sourceAttachment = source?.split('/').at(-1);\n\tif (sourceAttachment && sourceAttachment.includes('.')) {\n\t\treturn sourceAttachment;\n\t}\n\n\tconst titleAttachment = title?.split(' · ').at(-1);\n\tif (titleAttachment && titleAttachment.includes('.')) {\n\t\treturn titleAttachment;\n\t}\n\n\treturn undefined;\n};\n\nconst getSpreadsheetHeaders = (metadata?: Record<string, unknown>) =>\n\tArray.isArray(metadata?.spreadsheetHeaders)\n\t\t? metadata.spreadsheetHeaders\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\nconst formatSpreadsheetColumnRange = (\n\tcolumnStart?: string,\n\tcolumnEnd?: string\n) => {\n\tif (typeof columnStart !== 'string' || columnStart.length === 0) {\n\t\treturn undefined;\n\t}\n\tif (typeof columnEnd !== 'string' || columnEnd.length === 0) {\n\t\treturn `Columns ${columnStart}`;\n\t}\n\tif (columnStart === columnEnd) {\n\t\treturn `Columns ${columnStart}`;\n\t}\n\n\treturn `Columns ${columnStart}-${columnEnd}`;\n};\n\nconst formatSpreadsheetRowRange = (rowStart?: number, rowEnd?: number) => {\n\tif (typeof rowStart !== 'number' || !Number.isFinite(rowStart)) {\n\t\treturn undefined;\n\t}\n\tif (\n\t\ttypeof rowEnd !== 'number' &&\n\t\ttypeof rowStart === 'number' &&\n\t\tNumber.isFinite(rowStart)\n\t) {\n\t\treturn `Rows ${rowStart}`;\n\t}\n\tif (rowStart === rowEnd) {\n\t\treturn `Rows ${rowStart}`;\n\t}\n\n\treturn `Rows ${rowStart}-${rowEnd}`;\n};\n\nconst formatSpreadsheetTableLabel = (\n\ttableIndex?: number,\n\ttableCount?: number\n) => {\n\tif (\n\t\ttypeof tableIndex !== 'number' ||\n\t\t!Number.isFinite(tableIndex) ||\n\t\ttableIndex < 1\n\t) {\n\t\treturn undefined;\n\t}\n\n\tif (\n\t\ttypeof tableCount === 'number' &&\n\t\tNumber.isFinite(tableCount) &&\n\t\ttableCount >= tableIndex\n\t) {\n\t\treturn `Table ${tableIndex} of ${tableCount}`;\n\t}\n\n\treturn `Table ${tableIndex}`;\n};\n\nconst formatOfficeListLevelsLabel = (value: unknown) => {\n\tif (!Array.isArray(value) || value.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst levels = value\n\t\t.map((entry) => getContextNumber(entry))\n\t\t.filter((entry): entry is number => typeof entry === 'number')\n\t\t.sort((left, right) => left - right);\n\n\tif (levels.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst minLevel = levels[0];\n\tconst maxLevel = levels[levels.length - 1];\n\n\treturn minLevel === maxLevel\n\t\t? `Office list level ${minLevel}`\n\t\t: `Office list levels ${minLevel}-${maxLevel}`;\n};\n\nconst formatMediaDurationLabel = (value: unknown) => {\n\tif (typeof value !== 'number' || !Number.isFinite(value) || value < 0) {\n\t\treturn undefined;\n\t}\n\n\treturn formatMediaTimestamp(value);\n};\n\nconst buildContextLabel = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst pdfTextKind = getContextString(metadata.pdfTextKind);\n\tconst pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n\tconst pdfTableBodyRowStart = getContextNumber(\n\t\tmetadata.pdfTableBodyRowStart\n\t);\n\tconst pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n\tconst officeBlockKindValue = getContextString(metadata.officeBlockKind);\n\tconst officeBlockKind =\n\t\tofficeBlockKindValue === 'table' ||\n\t\tofficeBlockKindValue === 'list' ||\n\t\tofficeBlockKindValue === 'paragraph'\n\t\t\t? officeBlockKindValue\n\t\t\t: undefined;\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tif (pdfSemanticRole === 'figure_caption' && sectionTitle) {\n\t\treturn `PDF figure caption ${sectionTitle}`;\n\t}\n\tif (pdfSemanticRole === 'figure_body' && sectionTitle) {\n\t\treturn `PDF figure body ${sectionTitle}`;\n\t}\n\tif (pdfTextKind === 'table_like' && sectionTitle) {\n\t\treturn `PDF table block ${sectionTitle}`;\n\t}\n\tif (pdfTextKind === 'paragraph' && sectionTitle) {\n\t\treturn `PDF text block ${sectionTitle}`;\n\t}\n\tif (officeBlockKind === 'table' && sectionTitle) {\n\t\treturn `Office table block ${sectionPath.join(' > ') || sectionTitle}`;\n\t}\n\tif (officeBlockKind === 'list' && sectionTitle) {\n\t\treturn `Office list block ${sectionPath.join(' > ') || sectionTitle}`;\n\t}\n\tif (officeBlockKind === 'paragraph' && sectionTitle) {\n\t\treturn `Office paragraph block ${sectionPath.join(' > ') || sectionTitle}`;\n\t}\n\n\tconst emailKind = getContextString(metadata.emailKind);\n\tif (emailKind === 'attachment') {\n\t\tconst attachmentName = getContextString(metadata.attachmentName);\n\t\tconst threadTopic = getContextString(metadata.threadTopic);\n\t\treturn attachmentName\n\t\t\t? threadTopic\n\t\t\t\t? `Attachment evidence ${attachmentName} in ${threadTopic}`\n\t\t\t\t: `Attachment evidence ${attachmentName}`\n\t\t\t: 'Attachment evidence';\n\t}\n\n\tif (emailKind === 'message') {\n\t\tconst threadTopic = getContextString(metadata.threadTopic);\n\t\tconst from = getContextString(metadata.from);\n\t\tif (threadTopic) {\n\t\t\treturn from\n\t\t\t\t? `Message in ${threadTopic} from ${from}`\n\t\t\t\t: `Message in ${threadTopic}`;\n\t\t}\n\t\treturn from ? `Message from ${from}` : 'Message evidence';\n\t}\n\n\tconst page =\n\t\tgetContextNumber(metadata.page) ??\n\t\tgetContextNumber(metadata.pageNumber) ??\n\t\t(typeof metadata.pageIndex === 'number'\n\t\t\t? metadata.pageIndex + 1\n\t\t\t: undefined);\n\tconst region =\n\t\tgetContextNumber(metadata.regionNumber) ??\n\t\t(typeof metadata.regionIndex === 'number'\n\t\t\t? metadata.regionIndex + 1\n\t\t\t: undefined);\n\tconst hasOCRTrace =\n\t\ttypeof metadata.ocrRegionConfidence === 'number' ||\n\t\ttypeof metadata.ocrConfidence === 'number' ||\n\t\tgetContextString(metadata.pdfTextMode) === 'ocr' ||\n\t\ttypeof metadata.ocrRegionCount === 'number';\n\tconst ocrPageStart = getContextNumber(metadata.ocrPageStart);\n\tconst ocrPageEnd = getContextNumber(metadata.ocrPageEnd);\n\tif (page && region) {\n\t\tif (hasOCRTrace) {\n\t\t\treturn `OCR page ${page} region ${region}`;\n\t\t}\n\t\treturn `Page ${page} region ${region}`;\n\t}\n\tif (page) {\n\t\tif (hasOCRTrace) {\n\t\t\treturn `OCR page ${page}`;\n\t\t}\n\t\treturn `Page ${page}`;\n\t}\n\tif (\n\t\thasOCRTrace &&\n\t\ttypeof ocrPageStart === 'number' &&\n\t\ttypeof ocrPageEnd === 'number'\n\t) {\n\t\treturn ocrPageStart === ocrPageEnd\n\t\t\t? `OCR page ${ocrPageStart}`\n\t\t\t: `OCR pages ${ocrPageStart}-${ocrPageEnd}`;\n\t}\n\n\tconst sheet =\n\t\tgetContextString(metadata.sheetName) ??\n\t\t(Array.isArray(metadata.sheetNames)\n\t\t\t? getContextString(metadata.sheetNames[0])\n\t\t\t: undefined);\n\tif (sheet) {\n\t\tconst tableLabel = formatSpreadsheetTableLabel(\n\t\t\tgetContextNumber(metadata.spreadsheetTableIndex),\n\t\t\tgetContextNumber(metadata.spreadsheetTableCount)\n\t\t);\n\t\tconst columnRange = formatSpreadsheetColumnRange(\n\t\t\tgetContextString(metadata.spreadsheetColumnStart),\n\t\t\tgetContextString(metadata.spreadsheetColumnEnd)\n\t\t);\n\t\tconst rowRange = formatSpreadsheetRowRange(\n\t\t\tgetContextNumber(metadata.spreadsheetRowStart),\n\t\t\tgetContextNumber(metadata.spreadsheetRowEnd)\n\t\t);\n\t\tconst headers = getSpreadsheetHeaders(metadata);\n\t\tif (tableLabel && rowRange && columnRange) {\n\t\t\treturn `Sheet ${sheet} ${tableLabel} ${rowRange} ${columnRange}`;\n\t\t}\n\t\tif (tableLabel && rowRange) {\n\t\t\treturn `Sheet ${sheet} ${tableLabel} ${rowRange}`;\n\t\t}\n\t\tif (tableLabel && columnRange) {\n\t\t\treturn `Sheet ${sheet} ${tableLabel} ${columnRange}`;\n\t\t}\n\t\tif (tableLabel) {\n\t\t\treturn `Sheet ${sheet} ${tableLabel}`;\n\t\t}\n\t\tif (rowRange && columnRange) {\n\t\t\treturn `Sheet ${sheet} ${rowRange} ${columnRange}`;\n\t\t}\n\t\tif (rowRange) {\n\t\t\treturn `Sheet ${sheet} ${rowRange}`;\n\t\t}\n\t\tif (columnRange) {\n\t\t\treturn `Sheet ${sheet} ${columnRange}`;\n\t\t}\n\t\tif (headers.length > 0) {\n\t\t\treturn `Sheet ${sheet} by ${headers.slice(0, 2).join(', ')}`;\n\t\t}\n\t\treturn `Sheet ${sheet}`;\n\t}\n\n\tconst slide =\n\t\tgetContextNumber(metadata.slide) ??\n\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\tif (slide) {\n\t\tif (slideTitle) {\n\t\t\treturn `Slide ${slide} ${slideTitle}`;\n\t\t}\n\t\treturn `Slide ${slide}`;\n\t}\n\n\tconst archiveEntry =\n\t\tgetContextString(metadata.archiveFullPath) ??\n\t\tgetContextString(metadata.archivePath) ??\n\t\tgetContextString(metadata.archiveEntryPath) ??\n\t\tgetContextString(metadata.entryPath);\n\tif (archiveEntry) {\n\t\treturn `Archive entry ${archiveEntry}`;\n\t}\n\n\tconst threadTopic = getContextString(metadata.threadTopic);\n\tif (threadTopic) {\n\t\treturn `Thread ${threadTopic}`;\n\t}\n\n\tconst speaker = getContextString(metadata.speaker);\n\tif (speaker) {\n\t\treturn `Speaker ${speaker}`;\n\t}\n\tif (sectionTitle) {\n\t\treturn `Section ${sectionTitle}`;\n\t}\n\n\treturn undefined;\n};\n\nconst buildLocatorLabel = (\n\tmetadata?: Record<string, unknown>,\n\tsource?: string,\n\ttitle?: string\n) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst pdfTextKind = getContextString(metadata.pdfTextKind);\n\tconst pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n\tconst officeBlockKind = getContextString(metadata.officeBlockKind);\n\tconst pdfBlockNumber = getContextNumber(metadata.pdfBlockNumber);\n\tconst pdfTableBodyRowStart = getContextNumber(\n\t\tmetadata.pdfTableBodyRowStart\n\t);\n\tconst pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n\tconst officeBlockNumber = getContextNumber(metadata.officeBlockNumber);\n\tconst officeTableBodyRowStart = getContextNumber(\n\t\tmetadata.officeTableBodyRowStart\n\t);\n\tconst officeTableBodyRowEnd = getContextNumber(\n\t\tmetadata.officeTableBodyRowEnd\n\t);\n\tconst spreadsheetRowStart = getContextNumber(metadata.spreadsheetRowStart);\n\tconst spreadsheetRowEnd = getContextNumber(metadata.spreadsheetRowEnd);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\n\tconst page =\n\t\tgetContextNumber(metadata.page) ??\n\t\tgetContextNumber(metadata.pageNumber) ??\n\t\t(typeof metadata.pageIndex === 'number'\n\t\t\t? metadata.pageIndex + 1\n\t\t\t: undefined);\n\tconst region =\n\t\tgetContextNumber(metadata.regionNumber) ??\n\t\t(typeof metadata.regionIndex === 'number'\n\t\t\t? metadata.regionIndex + 1\n\t\t\t: undefined);\n\tconst ocrPageStart = getContextNumber(metadata.ocrPageStart);\n\tconst ocrPageEnd = getContextNumber(metadata.ocrPageEnd);\n\tif (page && region) {\n\t\treturn `Page ${page} · Region ${region}`;\n\t}\n\tif (page && pdfBlockNumber && pdfSemanticRole === 'figure_caption') {\n\t\treturn `Page ${page} · Figure Caption ${pdfBlockNumber}`;\n\t}\n\tif (page && pdfBlockNumber && pdfSemanticRole === 'figure_body') {\n\t\treturn `Page ${page} · Figure Body ${pdfBlockNumber}`;\n\t}\n\tif (page && pdfBlockNumber && pdfTextKind === 'table_like') {\n\t\tif (\n\t\t\ttypeof pdfTableBodyRowStart === 'number' &&\n\t\t\ttypeof pdfTableBodyRowEnd === 'number'\n\t\t) {\n\t\t\treturn pdfTableBodyRowStart === pdfTableBodyRowEnd\n\t\t\t\t? `Page ${page} · Table Block ${pdfBlockNumber} · Row ${pdfTableBodyRowStart}`\n\t\t\t\t: `Page ${page} · Table Block ${pdfBlockNumber} · Rows ${pdfTableBodyRowStart}-${pdfTableBodyRowEnd}`;\n\t\t}\n\t\treturn `Page ${page} · Table Block ${pdfBlockNumber}`;\n\t}\n\tif (page && pdfBlockNumber) {\n\t\treturn `Page ${page} · Text Block ${pdfBlockNumber}`;\n\t}\n\tif (page) {\n\t\treturn `Page ${page}`;\n\t}\n\tif (typeof ocrPageStart === 'number' && typeof ocrPageEnd === 'number') {\n\t\treturn ocrPageStart === ocrPageEnd\n\t\t\t? `Page ${ocrPageStart}`\n\t\t\t: `Pages ${ocrPageStart}-${ocrPageEnd}`;\n\t}\n\n\tconst sheet =\n\t\tgetContextString(metadata.sheetName) ??\n\t\t(Array.isArray(metadata.sheetNames)\n\t\t\t? getContextString(metadata.sheetNames[0])\n\t\t\t: undefined);\n\tif (sheet) {\n\t\tconst tableLabel = formatSpreadsheetTableLabel(\n\t\t\tgetContextNumber(metadata.spreadsheetTableIndex),\n\t\t\tgetContextNumber(metadata.spreadsheetTableCount)\n\t\t);\n\t\tconst columnRange = formatSpreadsheetColumnRange(\n\t\t\tgetContextString(metadata.spreadsheetColumnStart),\n\t\t\tgetContextString(metadata.spreadsheetColumnEnd)\n\t\t);\n\t\tconst rowRange = formatSpreadsheetRowRange(\n\t\t\tspreadsheetRowStart,\n\t\t\tspreadsheetRowEnd\n\t\t);\n\t\tif (tableLabel && rowRange && columnRange) {\n\t\t\treturn `Sheet ${sheet} · ${tableLabel} · ${rowRange} · ${columnRange}`;\n\t\t}\n\t\tif (tableLabel && rowRange) {\n\t\t\treturn `Sheet ${sheet} · ${tableLabel} · ${rowRange}`;\n\t\t}\n\t\tif (tableLabel && columnRange) {\n\t\t\treturn `Sheet ${sheet} · ${tableLabel} · ${columnRange}`;\n\t\t}\n\t\tif (tableLabel) {\n\t\t\treturn `Sheet ${sheet} · ${tableLabel}`;\n\t\t}\n\t\tif (rowRange && columnRange) {\n\t\t\treturn `Sheet ${sheet} · ${rowRange} · ${columnRange}`;\n\t\t}\n\t\tif (rowRange) {\n\t\t\treturn `Sheet ${sheet} · ${rowRange}`;\n\t\t}\n\t\treturn columnRange\n\t\t\t? `Sheet ${sheet} · ${columnRange}`\n\t\t\t: `Sheet ${sheet}`;\n\t}\n\n\tconst slide =\n\t\tgetContextNumber(metadata.slide) ??\n\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t? metadata.slideIndex + 1\n\t\t\t: undefined);\n\tif (slide) {\n\t\treturn slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n\t}\n\n\tconst archiveEntry =\n\t\tgetContextString(metadata.archiveFullPath) ??\n\t\tgetContextString(metadata.archivePath) ??\n\t\tgetContextString(metadata.archiveEntryPath) ??\n\t\tgetContextString(metadata.entryPath);\n\tif (archiveEntry) {\n\t\treturn `Archive entry ${archiveEntry}`;\n\t}\n\n\tconst emailKind = getContextString(metadata.emailKind);\n\tif (emailKind === 'attachment') {\n\t\tconst attachmentName =\n\t\t\tgetContextString(metadata.attachmentName) ??\n\t\t\tgetAttachmentName(source, title);\n\t\tconst replyDepth = getContextNumber(metadata.replyDepth);\n\t\tif (attachmentName && replyDepth && replyDepth > 0) {\n\t\t\treturn `Attachment ${attachmentName} · Reply depth ${replyDepth}`;\n\t\t}\n\t\treturn attachmentName ? `Attachment ${attachmentName}` : 'Attachment';\n\t}\n\n\tconst mediaStart = formatMediaTimestamp(metadata.startMs);\n\tconst mediaEnd = formatMediaTimestamp(metadata.endMs);\n\tif (mediaStart && mediaEnd) {\n\t\treturn `Timestamp ${mediaStart} - ${mediaEnd}`;\n\t}\n\n\tif (mediaStart) {\n\t\treturn `Timestamp ${mediaStart}`;\n\t}\n\n\tif (officeBlockNumber && officeBlockKind === 'table') {\n\t\tif (\n\t\t\ttypeof officeTableBodyRowStart === 'number' &&\n\t\t\ttypeof officeTableBodyRowEnd === 'number'\n\t\t) {\n\t\t\treturn officeTableBodyRowStart === officeTableBodyRowEnd\n\t\t\t\t? `Office table block ${officeBlockNumber} · Row ${officeTableBodyRowStart}`\n\t\t\t\t: `Office table block ${officeBlockNumber} · Rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`;\n\t\t}\n\t\treturn `Office table block ${officeBlockNumber}`;\n\t}\n\tif (officeBlockNumber && officeBlockKind === 'list') {\n\t\treturn `Office list block ${officeBlockNumber}`;\n\t}\n\tif (officeBlockNumber && officeBlockKind === 'paragraph') {\n\t\treturn `Office paragraph block ${officeBlockNumber}`;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tif (sectionPath.length > 0) {\n\t\treturn `Section ${sectionPath.join(' > ')}`;\n\t}\n\n\treturn undefined;\n};\n\nconst buildProvenanceLabel = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst threadTopic = getContextString(metadata.threadTopic);\n\tconst replyDepth = getContextNumber(metadata.replyDepth);\n\tconst threadMessageCount = getContextNumber(metadata.threadMessageCount);\n\tconst threadRootMessageId = getContextString(metadata.threadRootMessageId);\n\tconst from = getContextString(metadata.from);\n\tconst sentAt =\n\t\tformatTimestampLabel(metadata.sentAt) ??\n\t\tformatTimestampLabel(metadata.receivedAt);\n\tconst speaker = getContextString(metadata.speaker);\n\tconst mediaKind = getContextString(metadata.mediaKind);\n\tconst transcriptSource = getContextString(metadata.transcriptSource);\n\tconst mediaSpeakerCount = getContextNumber(metadata.mediaSpeakerCount);\n\tconst mediaSegmentCount = getContextNumber(metadata.mediaSegmentCount);\n\tconst mediaSegmentGroupSize = getContextNumber(\n\t\tmetadata.mediaSegmentGroupSize\n\t);\n\tconst mediaSegmentGroupIndex = getContextNumber(\n\t\tmetadata.mediaSegmentGroupIndex\n\t);\n\tconst mediaChannel = getContextString(metadata.mediaChannel);\n\tconst mediaDurationLabel = formatMediaDurationLabel(\n\t\tmetadata.mediaDurationMs\n\t);\n\tconst mediaSegmentWindowDurationLabel = formatMediaDurationLabel(\n\t\tmetadata.mediaSegmentGroupDurationMs\n\t);\n\tconst mediaSegmentGapLabel = formatMediaDurationLabel(\n\t\tmetadata.mediaSegmentGapFromPreviousMs\n\t);\n\tconst spreadsheetHeaders = getSpreadsheetHeaders(metadata);\n\tconst pdfTableHeaders = Array.isArray(metadata.pdfTableHeaders)\n\t\t? metadata.pdfTableHeaders\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst pdfTableColumnCount = getContextNumber(metadata.pdfTableColumnCount);\n\tconst pdfTableBodyRowCount = getContextNumber(\n\t\tmetadata.pdfTableBodyRowCount\n\t);\n\tconst spreadsheetColumnRange = formatSpreadsheetColumnRange(\n\t\tgetContextString(metadata.spreadsheetColumnStart),\n\t\tgetContextString(metadata.spreadsheetColumnEnd)\n\t);\n\tconst slideNotesText = getContextString(metadata.slideNotesText);\n\tconst pdfTextMode = getContextString(metadata.pdfTextMode);\n\tconst pdfEvidenceMode = getContextString(metadata.pdfEvidenceMode);\n\tconst pdfEvidenceOrigin = getContextString(metadata.pdfEvidenceOrigin);\n\tconst pdfEvidenceSupplement = getContextString(\n\t\tmetadata.pdfEvidenceSupplement\n\t);\n\tconst pdfTextKind = getContextString(metadata.pdfTextKind);\n\tconst pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n\tconst officeBlockKind = getContextString(metadata.officeBlockKind);\n\tconst officeListContextText = getContextString(\n\t\tmetadata.officeListContextText\n\t);\n\tconst officeListGroupItemCount = getContextNumber(\n\t\tmetadata.officeListGroupItemCount\n\t);\n\tconst officeListLevelsLabel = formatOfficeListLevelsLabel(\n\t\tmetadata.officeListLevels\n\t);\n\tconst officeTableHeaders = Array.isArray(metadata.officeTableHeaders)\n\t\t? metadata.officeTableHeaders\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst officeTableColumnCount = getContextNumber(\n\t\tmetadata.officeTableColumnCount\n\t);\n\tconst officeTableBodyRowCount = getContextNumber(\n\t\tmetadata.officeTableBodyRowCount\n\t);\n\tconst officeTableBodyRowStart = getContextNumber(\n\t\tmetadata.officeTableBodyRowStart\n\t);\n\tconst officeTableBodyRowEnd = getContextNumber(\n\t\tmetadata.officeTableBodyRowEnd\n\t);\n\tconst officeTableContextText = getContextString(\n\t\tmetadata.officeTableContextText\n\t);\n\tconst officeTableFollowUpText = getContextString(\n\t\tmetadata.officeTableFollowUpText\n\t);\n\tconst ocrEngine = getContextString(metadata.ocrEngine);\n\tconst extractorRegistryMatch = getContextString(\n\t\tmetadata.extractorRegistryMatch\n\t);\n\tconst chunkingProfile = getContextString(metadata.chunkingProfile);\n\tconst archiveDepth = getContextNumber(metadata.archiveDepth);\n\tconst archiveNestedDepth = getContextNumber(metadata.archiveNestedDepth);\n\tconst archiveContainerPath = getContextString(\n\t\tmetadata.archiveContainerPath\n\t);\n\tconst archiveRootName = getContextString(metadata.archiveRootName);\n\tconst sourceAwareChunkReason = formatSourceAwareChunkReason(\n\t\tmetadata.sourceAwareChunkReason\n\t);\n\tconst sourceAwareUnitScope = buildSourceAwareUnitScopeLabel(metadata);\n\tconst spreadsheetTableLabel = formatSpreadsheetTableLabel(\n\t\tgetContextNumber(metadata.spreadsheetTableIndex),\n\t\tgetContextNumber(metadata.spreadsheetTableCount)\n\t);\n\tconst ocrConfidence =\n\t\tgetContextNumber(metadata.ocrRegionConfidence) ??\n\t\tgetContextNumber(metadata.ocrConfidence);\n\tconst ocrAverageConfidence =\n\t\tgetContextNumber(metadata.ocrPageAverageConfidence) ??\n\t\tgetContextNumber(metadata.ocrAverageConfidence);\n\tconst ocrMinConfidence =\n\t\tgetContextNumber(metadata.ocrPageMinConfidence) ??\n\t\tgetContextNumber(metadata.ocrMinConfidence);\n\tconst ocrMaxConfidence =\n\t\tgetContextNumber(metadata.ocrPageMaxConfidence) ??\n\t\tgetContextNumber(metadata.ocrMaxConfidence);\n\tconst ocrRegionCount = getContextNumber(metadata.ocrRegionCount);\n\tconst pdfTableBodyRowStart = getContextNumber(\n\t\tmetadata.pdfTableBodyRowStart\n\t);\n\tconst pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n\n\tconst labels = [\n\t\tpdfTextMode ? `PDF ${pdfTextMode}` : '',\n\t\tpdfEvidenceMode ? `PDF evidence ${pdfEvidenceMode}` : '',\n\t\tpdfEvidenceOrigin ? `PDF origin ${pdfEvidenceOrigin}` : '',\n\t\tpdfEvidenceSupplement ? `PDF supplement ${pdfEvidenceSupplement}` : '',\n\t\tpdfSemanticRole === 'figure_caption' ? 'PDF figure caption' : '',\n\t\tpdfSemanticRole === 'figure_body' ? 'PDF figure body' : '',\n\t\tpdfSemanticRole === 'figure_caption'\n\t\t\t? ''\n\t\t\t: pdfSemanticRole === 'figure_body'\n\t\t\t\t? ''\n\t\t\t\t: pdfTextKind === 'table_like'\n\t\t\t\t\t? 'PDF table block'\n\t\t\t\t\t: pdfTextKind === 'paragraph'\n\t\t\t\t\t\t? 'PDF text block'\n\t\t\t\t\t\t: '',\n\t\tofficeBlockKind ? `Office ${officeBlockKind}` : '',\n\t\ttypeof officeListGroupItemCount === 'number'\n\t\t\t? `Office list ${officeListGroupItemCount} items`\n\t\t\t: '',\n\t\tofficeListLevelsLabel ?? '',\n\t\tocrEngine ? `OCR ${ocrEngine}` : '',\n\t\textractorRegistryMatch ? `Extractor ${extractorRegistryMatch}` : '',\n\t\tchunkingProfile ? `Chunking ${chunkingProfile}` : '',\n\t\tsourceAwareChunkReason ?? '',\n\t\tsourceAwareUnitScope ?? '',\n\t\ttypeof ocrConfidence === 'number'\n\t\t\t? `Confidence ${ocrConfidence.toFixed(2)}`\n\t\t\t: '',\n\t\ttypeof ocrAverageConfidence === 'number' &&\n\t\tocrAverageConfidence !== ocrConfidence\n\t\t\t? `Average ${ocrAverageConfidence.toFixed(2)}`\n\t\t\t: '',\n\t\ttypeof ocrMinConfidence === 'number' &&\n\t\ttypeof ocrMaxConfidence === 'number' &&\n\t\tocrMinConfidence !== ocrMaxConfidence\n\t\t\t? `Range ${ocrMinConfidence.toFixed(2)}-${ocrMaxConfidence.toFixed(\n\t\t\t\t\t2\n\t\t\t\t)}`\n\t\t\t: '',\n\t\ttypeof ocrRegionCount === 'number' ? `${ocrRegionCount} regions` : '',\n\t\tpdfTableHeaders.length > 0\n\t\t\t? `PDF table ${pdfTableHeaders.join(', ')}`\n\t\t\t: '',\n\t\ttypeof pdfTableColumnCount === 'number'\n\t\t\t? `PDF table ${pdfTableColumnCount} cols`\n\t\t\t: '',\n\t\ttypeof pdfTableBodyRowCount === 'number'\n\t\t\t? `PDF table ${pdfTableBodyRowCount} body rows`\n\t\t\t: '',\n\t\ttypeof pdfTableBodyRowStart === 'number' &&\n\t\ttypeof pdfTableBodyRowEnd === 'number'\n\t\t\t? pdfTableBodyRowStart === pdfTableBodyRowEnd\n\t\t\t\t? `PDF table row ${pdfTableBodyRowStart}`\n\t\t\t\t: `PDF table rows ${pdfTableBodyRowStart}-${pdfTableBodyRowEnd}`\n\t\t\t: '',\n\t\tofficeListContextText\n\t\t\t? `Office list context ${officeListContextText}`\n\t\t\t: '',\n\t\tofficeTableHeaders.length > 0\n\t\t\t? `Office table ${officeTableHeaders.join(', ')}`\n\t\t\t: '',\n\t\ttypeof officeTableColumnCount === 'number'\n\t\t\t? `Office table ${officeTableColumnCount} cols`\n\t\t\t: '',\n\t\ttypeof officeTableBodyRowCount === 'number'\n\t\t\t? `Office table ${officeTableBodyRowCount} body rows`\n\t\t\t: '',\n\t\ttypeof officeTableBodyRowStart === 'number' &&\n\t\ttypeof officeTableBodyRowEnd === 'number'\n\t\t\t? officeTableBodyRowStart === officeTableBodyRowEnd\n\t\t\t\t? `Office table row ${officeTableBodyRowStart}`\n\t\t\t\t: `Office table rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`\n\t\t\t: '',\n\t\tofficeTableContextText\n\t\t\t? `Office table context ${officeTableContextText}`\n\t\t\t: '',\n\t\tofficeTableFollowUpText\n\t\t\t? `Office table follow-up ${officeTableFollowUpText}`\n\t\t\t: '',\n\t\tspreadsheetHeaders.length > 0\n\t\t\t? `Spreadsheet ${spreadsheetHeaders.join(', ')}`\n\t\t\t: '',\n\t\tspreadsheetColumnRange ? `Spreadsheet ${spreadsheetColumnRange}` : '',\n\t\tspreadsheetTableLabel ? `Spreadsheet ${spreadsheetTableLabel}` : '',\n\t\tmediaKind ? `Media ${mediaKind}` : '',\n\t\tmediaSegmentCount ? `${mediaSegmentCount} segments` : '',\n\t\tmediaSegmentGroupSize\n\t\t\t? `${mediaSegmentGroupSize} grouped segments`\n\t\t\t: '',\n\t\tmediaSegmentGroupIndex !== undefined\n\t\t\t? `Segment group ${mediaSegmentGroupIndex + 1}`\n\t\t\t: '',\n\t\tmediaChannel ? `Channel ${mediaChannel}` : '',\n\t\tmediaSpeakerCount ? `${mediaSpeakerCount} speakers` : '',\n\t\tmediaDurationLabel ? `Duration ${mediaDurationLabel}` : '',\n\t\tmediaSegmentWindowDurationLabel\n\t\t\t? `Segment window ${mediaSegmentWindowDurationLabel}`\n\t\t\t: '',\n\t\tmediaSegmentGapLabel\n\t\t\t? `Gap ${mediaSegmentGapLabel} from previous window`\n\t\t\t: '',\n\t\ttranscriptSource ? `Transcript ${transcriptSource}` : '',\n\t\tthreadTopic ? `Thread ${threadTopic}` : '',\n\t\tthreadRootMessageId ? `Thread root ${threadRootMessageId}` : '',\n\t\tthreadMessageCount ? `${threadMessageCount} thread messages` : '',\n\t\treplyDepth ? `Reply depth ${replyDepth}` : '',\n\t\tslideNotesText ? 'Speaker notes' : '',\n\t\tarchiveDepth ? `Archive depth ${archiveDepth}` : '',\n\t\tarchiveNestedDepth ? `Archive nested depth ${archiveNestedDepth}` : '',\n\t\tarchiveContainerPath ? `Archive container ${archiveContainerPath}` : '',\n\t\tarchiveRootName ? `Archive root ${archiveRootName}` : '',\n\t\tspeaker ? `Speaker ${speaker}` : '',\n\t\tfrom ? `Sender ${from}` : '',\n\t\tsentAt ? `Sent ${sentAt}` : ''\n\t].filter((value) => value.length > 0);\n\n\treturn labels.length > 0 ? labels.join(' · ') : undefined;\n};\n\nexport const buildRAGSourceLabels = ({\n\tmetadata,\n\tsource,\n\ttitle\n}: {\n\tmetadata?: Record<string, unknown>;\n\tsource?: string;\n\ttitle?: string;\n}): RAGSourceLabels | undefined => {\n\tconst contextLabel = buildContextLabel(metadata);\n\tconst locatorLabel = buildLocatorLabel(metadata, source, title);\n\tconst provenanceLabel = buildProvenanceLabel(metadata);\n\n\tif (!contextLabel && !locatorLabel && !provenanceLabel) {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tcontextLabel,\n\t\tlocatorLabel,\n\t\tprovenanceLabel\n\t};\n};\n\nexport const buildRAGChunkStructure = (\n\tmetadata?: Record<string, unknown>\n): RAGChunkStructure | undefined => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath.filter(\n\t\t\t\t(value): value is string =>\n\t\t\t\t\ttypeof value === 'string' && value.trim().length > 0\n\t\t\t)\n\t\t: undefined;\n\tconst sectionKind =\n\t\tmetadata.sectionKind === 'markdown_heading' ||\n\t\tmetadata.sectionKind === 'html_heading' ||\n\t\tmetadata.sectionKind === 'office_heading' ||\n\t\tmetadata.sectionKind === 'office_block' ||\n\t\tmetadata.sectionKind === 'pdf_block' ||\n\t\tmetadata.sectionKind === 'spreadsheet_rows' ||\n\t\tmetadata.sectionKind === 'presentation_slide'\n\t\t\t? metadata.sectionKind\n\t\t\t: undefined;\n\tconst section: NonNullable<RAGChunkStructure['section']> = {\n\t\tdepth: getContextNumber(metadata.sectionDepth),\n\t\tkind: sectionKind,\n\t\tpath: sectionPath && sectionPath.length > 0 ? sectionPath : undefined,\n\t\ttitle: getContextString(metadata.sectionTitle)\n\t};\n\tconst sequence: NonNullable<RAGChunkStructure['sequence']> = {\n\t\tnextChunkId: getContextString(metadata.nextChunkId),\n\t\tpreviousChunkId: getContextString(metadata.previousChunkId),\n\t\tsectionChunkCount: getContextNumber(metadata.sectionChunkCount),\n\t\tsectionChunkId: getContextString(metadata.sectionChunkId),\n\t\tsectionChunkIndex: getContextNumber(metadata.sectionChunkIndex)\n\t};\n\n\tif (\n\t\t!section.title &&\n\t\t(!section.path || section.path.length === 0) &&\n\t\ttypeof section.depth !== 'number' &&\n\t\t!section.kind &&\n\t\t!sequence.nextChunkId &&\n\t\t!sequence.previousChunkId &&\n\t\ttypeof sequence.sectionChunkCount !== 'number' &&\n\t\t!sequence.sectionChunkId &&\n\t\ttypeof sequence.sectionChunkIndex !== 'number'\n\t) {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tsection:\n\t\t\tsection.title ||\n\t\t\t(section.path && section.path.length > 0) ||\n\t\t\ttypeof section.depth === 'number' ||\n\t\t\tsection.kind\n\t\t\t\t? section\n\t\t\t\t: undefined,\n\t\tsequence:\n\t\t\tsequence.nextChunkId ||\n\t\t\tsequence.previousChunkId ||\n\t\t\ttypeof sequence.sectionChunkCount === 'number' ||\n\t\t\tsequence.sectionChunkId ||\n\t\t\ttypeof sequence.sectionChunkIndex === 'number'\n\t\t\t\t? sequence\n\t\t\t\t: undefined\n\t};\n};\n\nconst buildExcerpt = (text: string, maxLength = 160) => {\n\tconst normalized = text.replaceAll(/\\s+/g, ' ').trim();\n\tif (normalized.length <= maxLength) {\n\t\treturn normalized;\n\t}\n\n\treturn `${normalized.slice(0, Math.max(0, maxLength - 1)).trimEnd()}…`;\n};\n\ntype ExcerptChunkInput = Pick<\n\tRAGSource,\n\t'chunkId' | 'metadata' | 'structure' | 'text'\n>;\n\nexport const buildRAGChunkExcerpts = (\n\tchunks: ExcerptChunkInput[],\n\tactiveChunkId?: string\n): RAGChunkExcerpts | undefined => {\n\tif (chunks.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tconst graph = buildRAGChunkGraph(\n\t\tchunks.map((chunk) => ({\n\t\t\tchunkId: chunk.chunkId,\n\t\t\tmetadata: chunk.metadata,\n\t\t\tstructure: chunk.structure\n\t\t}))\n\t);\n\tconst navigation = buildRAGChunkGraphNavigation(graph, activeChunkId);\n\tconst activeChunk =\n\t\tchunks.find((chunk) => chunk.chunkId === navigation.activeChunkId) ??\n\t\tchunks[0];\n\tif (!activeChunk) {\n\t\treturn undefined;\n\t}\n\n\tconst chunkMap = new Map(chunks.map((chunk) => [chunk.chunkId, chunk]));\n\tconst orderedSectionIds =\n\t\tnavigation.sectionNodes.length > 0\n\t\t\t? navigation.sectionNodes.map((node) => node.chunkId)\n\t\t\t: [activeChunk.chunkId];\n\tconst orderedWindowIds =\n\t\tnavigation.sectionNodes.length > 0\n\t\t\t? (() => {\n\t\t\t\t\tconst activeIndex = navigation.sectionNodes.findIndex(\n\t\t\t\t\t\t(node) => node.chunkId === activeChunk.chunkId\n\t\t\t\t\t);\n\t\t\t\t\tconst startIndex = Math.max(0, activeIndex - 2);\n\t\t\t\t\tconst endIndex = Math.min(\n\t\t\t\t\t\tnavigation.sectionNodes.length,\n\t\t\t\t\t\tactiveIndex + 3\n\t\t\t\t\t);\n\t\t\t\t\treturn navigation.sectionNodes\n\t\t\t\t\t\t.slice(startIndex, endIndex)\n\t\t\t\t\t\t.map((node) => node.chunkId);\n\t\t\t\t})()\n\t\t\t: [\n\t\t\t\t\tnavigation.previousNode?.chunkId,\n\t\t\t\t\tactiveChunk.chunkId,\n\t\t\t\t\tnavigation.nextNode?.chunkId\n\t\t\t\t].filter(\n\t\t\t\t\t(chunkId, index, ids): chunkId is string =>\n\t\t\t\t\t\tBoolean(chunkId) && ids.indexOf(chunkId) === index\n\t\t\t\t);\n\n\tconst collectText = (chunkIds: string[]) =>\n\t\tchunkIds\n\t\t\t.map((chunkId) => chunkMap.get(chunkId)?.text)\n\t\t\t.filter((text): text is string => typeof text === 'string')\n\t\t\t.join('\\n\\n');\n\n\treturn {\n\t\tchunkExcerpt: buildExcerpt(activeChunk.text, 160),\n\t\tsectionExcerpt: buildExcerpt(collectText(orderedSectionIds), 320),\n\t\twindowExcerpt: buildExcerpt(collectText(orderedWindowIds), 240)\n\t};\n};\n\nexport const buildRAGPreferredExcerpt = (\n\texcerpts?: RAGChunkExcerpts,\n\tstructure?: RAGChunkStructure\n) => {\n\tconst selection = buildRAGExcerptSelection(excerpts, structure);\n\treturn selection.excerpt;\n};\n\nexport const buildRAGExcerptSelection = (\n\texcerpts?: RAGChunkExcerpts,\n\tstructure?: RAGChunkStructure\n): RAGExcerptSelection & { excerpt: string } => {\n\tif (!excerpts) {\n\t\treturn {\n\t\t\texcerpt: '',\n\t\t\tmode: 'chunk',\n\t\t\treason: 'single_chunk'\n\t\t};\n\t}\n\n\tconst chunkLength = excerpts.chunkExcerpt.trim().length;\n\tconst sectionChunkCount = structure?.sequence?.sectionChunkCount ?? 1;\n\tif (sectionChunkCount > 1 && chunkLength > 0 && chunkLength < 72) {\n\t\tif (\n\t\t\tsectionChunkCount <= 3 &&\n\t\t\texcerpts.sectionExcerpt.trim().length > 0\n\t\t) {\n\t\t\treturn {\n\t\t\t\texcerpt: excerpts.sectionExcerpt,\n\t\t\t\tmode: 'section',\n\t\t\t\treason: 'section_small_enough'\n\t\t\t};\n\t\t}\n\t\tif (excerpts.windowExcerpt.trim().length > 0) {\n\t\t\treturn {\n\t\t\t\texcerpt: excerpts.windowExcerpt,\n\t\t\t\tmode: 'window',\n\t\t\t\treason: 'section_too_large_use_window'\n\t\t\t};\n\t\t}\n\n\t\treturn {\n\t\t\texcerpt: excerpts.chunkExcerpt,\n\t\t\tmode: 'chunk',\n\t\t\treason: 'chunk_too_narrow'\n\t\t};\n\t}\n\n\treturn {\n\t\texcerpt: excerpts.chunkExcerpt,\n\t\tmode: 'chunk',\n\t\treason: sectionChunkCount > 1 ? 'chunk_too_narrow' : 'single_chunk'\n\t};\n};\n\nexport const buildRAGExcerptModeCounts = (\n\tselections: Array<RAGExcerptSelection | undefined>\n): RAGExcerptModeCounts =>\n\tselections.reduce<RAGExcerptModeCounts>(\n\t\t(counts, selection) => {\n\t\t\tif (selection) {\n\t\t\t\tcounts[selection.mode] += 1;\n\t\t\t}\n\t\t\treturn counts;\n\t\t},\n\t\t{ chunk: 0, section: 0, window: 0 }\n\t);\n\ntype GraphChunkInput = Pick<\n\tRAGSource,\n\t'chunkId' | 'metadata' | 'source' | 'title' | 'labels' | 'structure'\n> &\n\tPartial<Pick<RAGSource, 'score'>>;\n\nexport const buildRAGChunkGraph = (\n\tchunks: GraphChunkInput[]\n): RAGChunkGraph => {\n\tconst nodes: RAGChunkGraphNode[] = [];\n\tconst edges: RAGChunkGraphEdge[] = [];\n\tconst edgeKeys = new Set<string>();\n\tconst sections = new Map<string, RAGChunkGraphSectionGroup>();\n\n\tfor (const chunk of chunks) {\n\t\tconst labels =\n\t\t\tchunk.labels ??\n\t\t\tbuildRAGSourceLabels({\n\t\t\t\tmetadata: chunk.metadata,\n\t\t\t\tsource: chunk.source,\n\t\t\t\ttitle: chunk.title\n\t\t\t});\n\t\tconst structure =\n\t\t\tchunk.structure ?? buildRAGChunkStructure(chunk.metadata);\n\n\t\tnodes.push({\n\t\t\tchunkId: chunk.chunkId,\n\t\t\tcontextLabel: labels?.contextLabel,\n\t\t\tlabel: chunk.source ?? chunk.title ?? chunk.chunkId,\n\t\t\tlocatorLabel: labels?.locatorLabel,\n\t\t\tprovenanceLabel: labels?.provenanceLabel,\n\t\t\tscore: chunk.score,\n\t\t\tsource: chunk.source,\n\t\t\tstructure,\n\t\t\ttitle: chunk.title\n\t\t});\n\n\t\tconst previousChunkId = structure?.sequence?.previousChunkId;\n\t\tif (previousChunkId) {\n\t\t\tconst key = `previous:${previousChunkId}:${chunk.chunkId}`;\n\t\t\tif (!edgeKeys.has(key)) {\n\t\t\t\tedgeKeys.add(key);\n\t\t\t\tedges.push({\n\t\t\t\t\tfromChunkId: previousChunkId,\n\t\t\t\t\trelation: 'previous',\n\t\t\t\t\ttoChunkId: chunk.chunkId\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tconst nextChunkId = structure?.sequence?.nextChunkId;\n\t\tif (nextChunkId) {\n\t\t\tconst key = `next:${chunk.chunkId}:${nextChunkId}`;\n\t\t\tif (!edgeKeys.has(key)) {\n\t\t\t\tedgeKeys.add(key);\n\t\t\t\tedges.push({\n\t\t\t\t\tfromChunkId: chunk.chunkId,\n\t\t\t\t\trelation: 'next',\n\t\t\t\t\ttoChunkId: nextChunkId\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tconst sectionId = structure?.sequence?.sectionChunkId;\n\t\tif (sectionId) {\n\t\t\tconst existing = sections.get(sectionId);\n\t\t\tif (!existing) {\n\t\t\t\tsections.set(sectionId, {\n\t\t\t\t\tchildSectionIds: [],\n\t\t\t\t\tchunkCount: structure.sequence?.sectionChunkCount ?? 1,\n\t\t\t\t\tchunkIds: [chunk.chunkId],\n\t\t\t\t\tdepth: structure.section?.depth,\n\t\t\t\t\tid: sectionId,\n\t\t\t\t\tkind: structure.section?.kind,\n\t\t\t\t\tleadChunkId: chunk.chunkId,\n\t\t\t\t\tpath: structure.section?.path,\n\t\t\t\t\ttitle: structure.section?.title\n\t\t\t\t});\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (!existing.chunkIds.includes(chunk.chunkId)) {\n\t\t\t\texisting.chunkIds.push(chunk.chunkId);\n\t\t\t}\n\t\t\texisting.chunkCount = Math.max(\n\t\t\t\texisting.chunkCount,\n\t\t\t\tstructure.sequence?.sectionChunkCount ?? existing.chunkCount\n\t\t\t);\n\t\t}\n\t}\n\n\tfor (const section of sections.values()) {\n\t\tsection.chunkIds.sort((left, right) => {\n\t\t\tconst leftNode = nodes.find((node) => node.chunkId === left);\n\t\t\tconst rightNode = nodes.find((node) => node.chunkId === right);\n\t\t\tconst leftIndex =\n\t\t\t\tleftNode?.structure?.sequence?.sectionChunkIndex ??\n\t\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\t\tconst rightIndex =\n\t\t\t\trightNode?.structure?.sequence?.sectionChunkIndex ??\n\t\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\t\tif (leftIndex !== rightIndex) {\n\t\t\t\treturn leftIndex - rightIndex;\n\t\t\t}\n\n\t\t\treturn left.localeCompare(right);\n\t\t});\n\t\tsection.leadChunkId = section.chunkIds[0];\n\t}\n\n\tconst sectionPathIndex = new Map<string, RAGChunkGraphSectionGroup>();\n\tfor (const section of sections.values()) {\n\t\tconst path =\n\t\t\tsection.path && section.path.length > 0\n\t\t\t\t? section.path\n\t\t\t\t: section.title\n\t\t\t\t\t? [section.title]\n\t\t\t\t\t: undefined;\n\t\tif (path && path.length > 0) {\n\t\t\tsectionPathIndex.set(path.join('\\u0000'), section);\n\t\t}\n\t}\n\n\tfor (const section of sections.values()) {\n\t\tconst path =\n\t\t\tsection.path && section.path.length > 0\n\t\t\t\t? section.path\n\t\t\t\t: section.title\n\t\t\t\t\t? [section.title]\n\t\t\t\t\t: undefined;\n\t\tif (!path || path.length < 2) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst parent = sectionPathIndex.get(path.slice(0, -1).join('\\u0000'));\n\t\tif (!parent || parent.id === section.id) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tsection.parentSectionId = parent.id;\n\t\tif (!parent.childSectionIds.includes(section.id)) {\n\t\t\tparent.childSectionIds.push(section.id);\n\t\t}\n\n\t\tif (parent.leadChunkId && section.leadChunkId) {\n\t\t\tconst parentKey = `section_parent:${section.leadChunkId}:${parent.leadChunkId}`;\n\t\t\tif (!edgeKeys.has(parentKey)) {\n\t\t\t\tedgeKeys.add(parentKey);\n\t\t\t\tedges.push({\n\t\t\t\t\tfromChunkId: section.leadChunkId,\n\t\t\t\t\trelation: 'section_parent',\n\t\t\t\t\ttoChunkId: parent.leadChunkId\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst childKey = `section_child:${parent.leadChunkId}:${section.leadChunkId}`;\n\t\t\tif (!edgeKeys.has(childKey)) {\n\t\t\t\tedgeKeys.add(childKey);\n\t\t\t\tedges.push({\n\t\t\t\t\tfromChunkId: parent.leadChunkId,\n\t\t\t\t\trelation: 'section_child',\n\t\t\t\t\ttoChunkId: section.leadChunkId\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\tnodes.sort((left, right) => {\n\t\tconst leftSection =\n\t\t\tleft.structure?.sequence?.sectionChunkIndex ??\n\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\tconst rightSection =\n\t\t\tright.structure?.sequence?.sectionChunkIndex ??\n\t\t\tNumber.MAX_SAFE_INTEGER;\n\t\tif (leftSection !== rightSection) {\n\t\t\treturn leftSection - rightSection;\n\t\t}\n\n\t\tconst leftScore = left.score ?? Number.NEGATIVE_INFINITY;\n\t\tconst rightScore = right.score ?? Number.NEGATIVE_INFINITY;\n\t\tif (leftScore !== rightScore) {\n\t\t\treturn rightScore - leftScore;\n\t\t}\n\n\t\treturn left.label.localeCompare(right.label);\n\t});\n\n\treturn {\n\t\tedges,\n\t\tnodes,\n\t\tsections: [...sections.values()].sort((left, right) =>\n\t\t\t(left.title ?? left.id).localeCompare(right.title ?? right.id)\n\t\t)\n\t};\n};\n\nexport const buildRAGChunkPreviewGraph = (\n\tpreview: Pick<RAGDocumentChunkPreview, 'chunks' | 'document'>\n): RAGChunkGraph =>\n\tbuildRAGChunkGraph(\n\t\tpreview.chunks.map((chunk) => ({\n\t\t\tchunkId: chunk.chunkId,\n\t\t\tlabels: chunk.labels,\n\t\t\tmetadata: chunk.metadata,\n\t\t\tsource: chunk.source ?? preview.document.source,\n\t\t\tstructure: chunk.structure,\n\t\t\ttitle: chunk.title ?? preview.document.title\n\t\t}))\n\t);\n\nexport const buildRAGChunkPreviewNavigation = (\n\tpreview: Pick<RAGDocumentChunkPreview, 'chunks' | 'document'>,\n\tactiveChunkId?: string\n): RAGChunkGraphNavigation =>\n\tbuildRAGChunkGraphNavigation(\n\t\tbuildRAGChunkPreviewGraph(preview),\n\t\tactiveChunkId\n\t);\n\nexport const buildRAGChunkGraphNavigation = (\n\tgraph: RAGChunkGraph,\n\tactiveChunkId?: string\n): RAGChunkGraphNavigation => {\n\tif (graph.nodes.length === 0) {\n\t\treturn {\n\t\t\tactiveChunkId,\n\t\t\tchildSections: [],\n\t\t\tsiblingSections: [],\n\t\t\tsectionNodes: []\n\t\t};\n\t}\n\n\tconst activeNode =\n\t\t(activeChunkId\n\t\t\t? graph.nodes.find((node) => node.chunkId === activeChunkId)\n\t\t\t: undefined) ?? graph.nodes[0];\n\tconst resolvedActiveChunkId = activeNode?.chunkId;\n\tconst previousNode = activeNode?.structure?.sequence?.previousChunkId\n\t\t? graph.nodes.find(\n\t\t\t\t(node) =>\n\t\t\t\t\tnode.chunkId ===\n\t\t\t\t\tactiveNode.structure?.sequence?.previousChunkId\n\t\t\t)\n\t\t: undefined;\n\tconst nextNode = activeNode?.structure?.sequence?.nextChunkId\n\t\t? graph.nodes.find(\n\t\t\t\t(node) =>\n\t\t\t\t\tnode.chunkId === activeNode.structure?.sequence?.nextChunkId\n\t\t\t)\n\t\t: undefined;\n\tconst section = activeNode?.structure?.sequence?.sectionChunkId\n\t\t? graph.sections.find(\n\t\t\t\t(entry) =>\n\t\t\t\t\tentry.id === activeNode.structure?.sequence?.sectionChunkId\n\t\t\t)\n\t\t: undefined;\n\tconst parentSection = section?.parentSectionId\n\t\t? graph.sections.find((entry) => entry.id === section.parentSectionId)\n\t\t: undefined;\n\tconst childSections = section\n\t\t? section.childSectionIds\n\t\t\t\t.map((sectionId) =>\n\t\t\t\t\tgraph.sections.find((entry) => entry.id === sectionId)\n\t\t\t\t)\n\t\t\t\t.filter((entry): entry is RAGChunkGraphSectionGroup =>\n\t\t\t\t\tBoolean(entry)\n\t\t\t\t)\n\t\t: [];\n\tconst siblingSections = section?.parentSectionId\n\t\t? graph.sections.filter(\n\t\t\t\t(entry) =>\n\t\t\t\t\tentry.parentSectionId === section.parentSectionId &&\n\t\t\t\t\tentry.id !== section.id\n\t\t\t)\n\t\t: [];\n\tconst sectionNodes = section\n\t\t? section.chunkIds\n\t\t\t\t.map((chunkId) =>\n\t\t\t\t\tgraph.nodes.find((node) => node.chunkId === chunkId)\n\t\t\t\t)\n\t\t\t\t.filter((node): node is RAGChunkGraphNode => Boolean(node))\n\t\t: activeNode\n\t\t\t? [activeNode]\n\t\t\t: [];\n\n\treturn {\n\t\tactiveChunkId: resolvedActiveChunkId,\n\t\tactiveNode,\n\t\tchildSections,\n\t\tnextNode,\n\t\tparentSection,\n\t\tpreviousNode,\n\t\tsection,\n\t\tsiblingSections,\n\t\tsectionNodes\n\t};\n};\nexport const buildRAGRetrievedState = (messages: AIMessage[]) => {\n\tconst message = getLatestRetrievedMessage(messages);\n\n\tif (!message) {\n\t\treturn null;\n\t}\n\n\tconst sources = message.sources ?? [];\n\tconst citations = buildRAGCitations(sources);\n\tconst sectionDiagnostics = buildRAGSectionRetrievalDiagnostics(\n\t\tsources,\n\t\tisRAGRetrievalTrace(message.retrievalTrace)\n\t\t\t? message.retrievalTrace\n\t\t\t: undefined\n\t);\n\tconst sourceSummaries = buildRAGSourceSummaries(sources);\n\tconst groundedAnswer = buildRAGGroundedAnswer(message.content, sources);\n\n\treturn {\n\t\tcitationReferenceMap: buildRAGCitationReferenceMap(citations),\n\t\tcitations,\n\t\tconversationId: message.conversationId,\n\t\texcerptModeCounts: buildRAGExcerptModeCounts([\n\t\t\t...citations.map((citation) => citation.excerptSelection),\n\t\t\t...sourceSummaries.map((summary) => summary.excerptSelection)\n\t\t]),\n\t\tgroundedAnswer,\n\t\tmessageId: message.id,\n\t\tretrievalDurationMs: message.retrievalDurationMs,\n\t\tretrievalStartedAt: message.retrievalStartedAt,\n\t\tretrievedAt: message.retrievedAt,\n\t\ttrace: isRAGRetrievalTrace(message.retrievalTrace)\n\t\t\t? message.retrievalTrace\n\t\t\t: undefined,\n\t\tsectionDiagnostics,\n\t\tsourceGroups: buildRAGSourceGroups(sources),\n\t\tsourceSummaries,\n\t\tsources\n\t};\n};\nexport const buildRAGSourceSummaries = (sources: RAGSource[]) => {\n\tconst sourceGroups = buildRAGSourceGroups(sources);\n\tconst citations = buildRAGCitations(sources);\n\tconst citationReferenceMap = buildRAGCitationReferenceMap(citations);\n\n\treturn sourceGroups.map<RAGSourceSummary>((group) => {\n\t\tconst groupCitations = citations.filter((citation) =>\n\t\t\tgroup.chunks.some((chunk) => chunk.chunkId === citation.chunkId)\n\t\t);\n\t\tconst leadChunk = getPreferredSourceLeadChunk(group.chunks);\n\t\tconst excerpts = leadChunk\n\t\t\t? buildRAGChunkExcerpts(group.chunks, leadChunk.chunkId)\n\t\t\t: undefined;\n\t\tconst structure =\n\t\t\tleadChunk?.structure ?? buildRAGChunkStructure(leadChunk?.metadata);\n\t\tconst excerptSelection = buildRAGExcerptSelection(excerpts, structure);\n\n\t\treturn {\n\t\t\tbestScore: group.bestScore,\n\t\t\tcitationNumbers: groupCitations.map(\n\t\t\t\t(citation) => citationReferenceMap[citation.chunkId] ?? 0\n\t\t\t),\n\t\t\tcitations: groupCitations,\n\t\t\tchunkIds: group.chunks.map((chunk) => chunk.chunkId),\n\t\t\tcontextLabel:\n\t\t\t\tleadChunk?.labels?.contextLabel ??\n\t\t\t\tbuildContextLabel(leadChunk?.metadata),\n\t\t\tcount: group.count,\n\t\t\texcerpt:\n\t\t\t\texcerptSelection.excerpt || buildExcerpt(leadChunk?.text ?? ''),\n\t\t\texcerpts,\n\t\t\texcerptSelection,\n\t\t\tkey: group.key,\n\t\t\tlabel: group.label,\n\t\t\tlocatorLabel:\n\t\t\t\tleadChunk?.labels?.locatorLabel ??\n\t\t\t\tbuildLocatorLabel(\n\t\t\t\t\tleadChunk?.metadata,\n\t\t\t\t\tleadChunk?.source,\n\t\t\t\t\tleadChunk?.title\n\t\t\t\t),\n\t\t\tprovenanceLabel:\n\t\t\t\tleadChunk?.labels?.provenanceLabel ??\n\t\t\t\tbuildProvenanceLabel(leadChunk?.metadata),\n\t\t\tstructure,\n\t\t\tsource: group.source,\n\t\t\ttitle: group.title\n\t\t};\n\t});\n};\n\nconst getSectionPathFromSource = (source: RAGSource) => {\n\tconst path =\n\t\tsource.structure?.section?.path ??\n\t\t(Array.isArray(source.metadata?.sectionPath)\n\t\t\t? source.metadata.sectionPath\n\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t.filter(\n\t\t\t\t\t\t(value): value is string => typeof value === 'string'\n\t\t\t\t\t)\n\t\t\t: []);\n\n\treturn path.length > 0 ? path : undefined;\n};\n\nconst isBlockAwareContextLabel = (value?: string) =>\n\ttypeof value === 'string' &&\n\t(value.startsWith('PDF ') ||\n\t\tvalue.startsWith('Office ') ||\n\t\tvalue.startsWith('Slide '));\n\nconst getStructuredSectionScoreWeight = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tif (!metadata) {\n\t\treturn 1;\n\t}\n\n\tconst pdfTextKind = getContextString(metadata.pdfTextKind);\n\tconst officeBlockKind = getContextString(metadata.officeBlockKind);\n\tconst sectionKind = getContextString(metadata.sectionKind);\n\tconst slideTitle = getContextString(metadata.slideTitle);\n\tconst slideNotesText = getContextString(metadata.slideNotesText);\n\n\tif (pdfTextKind === 'table_like') {\n\t\treturn 1.28;\n\t}\n\tif (officeBlockKind === 'table' || officeBlockKind === 'list') {\n\t\treturn 1.24;\n\t}\n\tif (\n\t\tsectionKind === 'pdf_block' ||\n\t\tsectionKind === 'office_block' ||\n\t\tofficeBlockKind === 'paragraph' ||\n\t\tpdfTextKind === 'paragraph'\n\t) {\n\t\treturn 1.12;\n\t}\n\tif (sectionKind === 'presentation_slide' && slideNotesText) {\n\t\treturn 1.2;\n\t}\n\tif (sectionKind === 'presentation_slide' && slideTitle) {\n\t\treturn 1.14;\n\t}\n\n\treturn 1;\n};\n\nconst getStructuredSourceLeadScore = (source: RAGSource) =>\n\tsource.score * getStructuredSectionScoreWeight(source.metadata);\n\nconst getPDFLeadEvidencePreference = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn 0;\n\t}\n\n\tconst pdfEvidenceMode = getContextString(metadata.pdfEvidenceMode);\n\tconst pdfEvidenceOrigin = getContextString(metadata.pdfEvidenceOrigin);\n\tconst pdfEvidenceSupplement = getContextString(\n\t\tmetadata.pdfEvidenceSupplement\n\t);\n\n\tif (\n\t\tpdfEvidenceMode === 'hybrid' &&\n\t\tpdfEvidenceOrigin === 'native' &&\n\t\tpdfEvidenceSupplement === 'ocr'\n\t) {\n\t\treturn 3;\n\t}\n\tif (pdfEvidenceMode === 'native' && pdfEvidenceOrigin === 'native') {\n\t\treturn 2;\n\t}\n\tif (pdfEvidenceMode === 'ocr' && pdfEvidenceOrigin === 'ocr') {\n\t\treturn 1;\n\t}\n\n\treturn 0;\n};\n\nconst getPDFLeadScope = (metadata?: Record<string, unknown>) => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst pageNumber =\n\t\tgetContextNumber(metadata.pageNumber) ??\n\t\tgetContextNumber(metadata.page) ??\n\t\t(typeof metadata.pageIndex === 'number'\n\t\t\t? metadata.pageIndex + 1\n\t\t\t: undefined);\n\tconst sectionTitle = getContextString(metadata.sectionTitle);\n\tconst sourceNativeKind = getContextString(metadata.sourceNativeKind);\n\n\tif (typeof pageNumber !== 'number' && !sectionTitle && !sourceNativeKind) {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tpageNumber,\n\t\tsectionTitle,\n\t\tsourceNativeKind\n\t};\n};\n\ntype OfficeLeadScope = {\n\tblockKind: 'list' | 'paragraph' | 'table';\n\tfamilyPath: string[];\n\thasContext: boolean;\n\tordinalPath: number[];\n\tpathDepth: number;\n\tsectionFamilyKey: string;\n\tsectionOrdinal: number;\n\tsectionTitle: string;\n};\n\ntype GenericStructuredLeadScope = {\n\tfamilyPath: string[];\n\tkind: 'presentation_slide' | 'spreadsheet_rows';\n\tordinalPath: number[];\n\tpathDepth: number;\n\tsectionFamilyKey: string;\n\tsectionOrdinal: number;\n};\n\nconst getOfficeLeadScope = (\n\tmetadata?: Record<string, unknown>\n): OfficeLeadScope | undefined => {\n\tif (!metadata) {\n\t\treturn undefined;\n\t}\n\n\tconst officeBlockKindValue = getContextString(metadata.officeBlockKind);\n\tconst officeBlockKind =\n\t\tofficeBlockKindValue === 'table' ||\n\t\tofficeBlockKindValue === 'list' ||\n\t\tofficeBlockKindValue === 'paragraph'\n\t\t\t? officeBlockKindValue\n\t\t\t: undefined;\n\tif (\n\t\tofficeBlockKind !== 'table' &&\n\t\tofficeBlockKind !== 'list' &&\n\t\tofficeBlockKind !== 'paragraph'\n\t) {\n\t\treturn undefined;\n\t}\n\n\tconst sectionPath = Array.isArray(metadata.sectionPath)\n\t\t? metadata.sectionPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst sectionTitle =\n\t\tgetContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n\tconst officeContextText =\n\t\tofficeBlockKind === 'table'\n\t\t\t? getContextString(metadata.officeTableContextText)\n\t\t\t: officeBlockKind === 'list'\n\t\t\t\t? getContextString(metadata.officeListContextText)\n\t\t\t\t: undefined;\n\n\tif (!sectionTitle) {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tblockKind: officeBlockKind,\n\t\tfamilyPath: (() => {\n\t\t\tconst explicitGenericFamilyPath = Array.isArray(\n\t\t\t\tmetadata.sectionFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.sectionFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tconst explicitGenericOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.sectionOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.sectionOrdinalPath\n\t\t\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tif (\n\t\t\t\texplicitGenericFamilyPath.length > 0 &&\n\t\t\t\texplicitGenericFamilyPath.length ===\n\t\t\t\t\texplicitGenericOrdinalPath.length\n\t\t\t) {\n\t\t\t\treturn explicitGenericFamilyPath;\n\t\t\t}\n\n\t\t\tconst explicitOfficeFamilyPath = Array.isArray(\n\t\t\t\tmetadata.officeFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.officeFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\treturn explicitOfficeFamilyPath.length > 0\n\t\t\t\t? explicitOfficeFamilyPath\n\t\t\t\t: sectionPath.map((value) =>\n\t\t\t\t\t\tvalue.replace(/\\s+\\((\\d+)\\)$/, '').trim()\n\t\t\t\t\t);\n\t\t})(),\n\t\tpathDepth: sectionPath.length,\n\t\tordinalPath: (() => {\n\t\t\tconst explicitGenericFamilyPath = Array.isArray(\n\t\t\t\tmetadata.sectionFamilyPath\n\t\t\t)\n\t\t\t\t? metadata.sectionFamilyPath\n\t\t\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\t\t\ttypeof value === 'string'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tconst explicitGenericOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.sectionOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.sectionOrdinalPath\n\t\t\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\tif (\n\t\t\t\texplicitGenericFamilyPath.length > 0 &&\n\t\t\t\texplicitGenericFamilyPath.length ===\n\t\t\t\t\texplicitGenericOrdinalPath.length\n\t\t\t) {\n\t\t\t\treturn explicitGenericOrdinalPath;\n\t\t\t}\n\n\t\t\tconst explicitOfficeOrdinalPath = Array.isArray(\n\t\t\t\tmetadata.officeOrdinalPath\n\t\t\t)\n\t\t\t\t? metadata.officeOrdinalPath\n\t\t\t\t\t\t.map((value) =>\n\t\t\t\t\t\t\ttypeof value === 'number' && Number.isFinite(value)\n\t\t\t\t\t\t\t\t? value\n\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.filter(\n\t\t\t\t\t\t\t(value): value is number =>\n\t\t\t\t\t\t\t\ttypeof value === 'number'\n\t\t\t\t\t\t)\n\t\t\t\t: [];\n\t\t\treturn explicitOfficeOrdinalPath.length > 0\n\t\t\t\t? explicitOfficeOrdinalPath\n\t\t\t\t: sectionPath.map((value) => {\n\t\t\t\t\t\tconst match = value.match(/\\((\\d+)\\)$/);\n\t\t\t\t\t\treturn match ? Number.parseInt(match[1] ?? '1', 10) : 1;\n\t\t\t\t\t});\n\t\t})(),\n\t\tsectionFamilyKey:\n\t\t\tgetContextString(metadata.sectionSiblingFamilyKey) ??\n\t\t\tgetContextString(metadata.officeSiblingFamilyKey) ??\n\t\t\tsectionPath\n\t\t\t\t.at(-1)\n\t\t\t\t?.replace(/\\s+\\((\\d+)\\)$/, '')\n\t\t\t\t.trim() ??\n\t\t\tsectionTitle,\n\t\tsectionOrdinal:\n\t\t\tgetContextNumber(metadata.sectionSiblingOrdinal) ??\n\t\t\tgetContextNumber(metadata.officeSiblingOrdinal) ??\n\t\t\t(() => {\n\t\t\t\tconst match = sectionTitle.match(/\\((\\d+)\\)$/);\n\t\t\t\treturn match ? Number.parseInt(match[1] ?? '1', 10) : 1;\n\t\t\t})(),\n\t\tsectionTitle,\n\t\thasContext: typeof officeContextText === 'string'\n\t};\n};\n\nconst areOfficeLeadScopesComparable = (\n\tleft:\n\t\t| {\n\t\t\t\tblockKind: 'list' | 'paragraph' | 'table';\n\t\t\t\tfamilyPath: string[];\n\t\t\t\thasContext: boolean;\n\t\t\t\tordinalPath: number[];\n\t\t\t\tpathDepth: number;\n\t\t\t\tsectionFamilyKey: string;\n\t\t\t\tsectionOrdinal: number;\n\t\t\t\tsectionTitle: string;\n\t\t }\n\t\t| undefined,\n\tright:\n\t\t| {\n\t\t\t\tblockKind: 'list' | 'paragraph' | 'table';\n\t\t\t\tfamilyPath: string[];\n\t\t\t\thasContext: boolean;\n\t\t\t\tordinalPath: number[];\n\t\t\t\tpathDepth: number;\n\t\t\t\tsectionFamilyKey: string;\n\t\t\t\tsectionOrdinal: number;\n\t\t\t\tsectionTitle: string;\n\t\t }\n\t\t| undefined\n) => {\n\tif (!left || !right) {\n\t\treturn false;\n\t}\n\tif (\n\t\tleft.blockKind !== right.blockKind ||\n\t\tleft.sectionFamilyKey !== right.sectionFamilyKey ||\n\t\tleft.sectionOrdinal !== right.sectionOrdinal\n\t) {\n\t\treturn false;\n\t}\n\tconst leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n\tconst rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n\tconst leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n\tconst rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n\tconst sharedDepth = Math.min(\n\t\tleftAncestorFamilyPath.length,\n\t\trightAncestorFamilyPath.length\n\t);\n\tfor (let index = 0; index < sharedDepth; index += 1) {\n\t\tif (\n\t\t\tleftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n\t\t\tleftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn true;\n};\n\nconst getGenericStructuredLeadScope = (\n\tmetadata?: Record<string, unknown>\n): GenericStructuredLeadScope | undefined => {\n\tif (!metadata || metadata.officeBlockKind || metadata.pageNumber) {\n\t\treturn undefined;\n\t}\n\n\tconst kind =\n\t\tmetadata.sectionKind === 'spreadsheet_rows' ||\n\t\tmetadata.sectionKind === 'presentation_slide'\n\t\t\t? metadata.sectionKind\n\t\t\t: undefined;\n\tif (!kind) {\n\t\treturn undefined;\n\t}\n\n\tconst explicitFamilyPath = Array.isArray(metadata.sectionFamilyPath)\n\t\t? metadata.sectionFamilyPath\n\t\t\t\t.map((value) => getContextString(value))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t: [];\n\tconst explicitOrdinalPath = Array.isArray(metadata.sectionOrdinalPath)\n\t\t? metadata.sectionOrdinalPath\n\t\t\t\t.map((value) => getContextNumber(value))\n\t\t\t\t.filter((value): value is number => typeof value === 'number')\n\t\t: [];\n\tlet familyPath =\n\t\texplicitFamilyPath.length > 0 &&\n\t\texplicitFamilyPath.length === explicitOrdinalPath.length\n\t\t\t? explicitFamilyPath\n\t\t\t: [];\n\tlet ordinalPath =\n\t\texplicitFamilyPath.length > 0 &&\n\t\texplicitFamilyPath.length === explicitOrdinalPath.length\n\t\t\t? explicitOrdinalPath\n\t\t\t: [];\n\n\tif (familyPath.length === 0) {\n\t\tif (kind === 'spreadsheet_rows') {\n\t\t\tconst sheetName = getContextString(metadata.sheetName) ?? 'Sheet';\n\t\t\tconst tableIndex =\n\t\t\t\tgetContextNumber(metadata.spreadsheetTableIndex) ?? 1;\n\t\t\tfamilyPath = [sheetName, 'Spreadsheet Table'];\n\t\t\tordinalPath = [1, tableIndex];\n\t\t} else {\n\t\t\tconst slideFamily =\n\t\t\t\tgetContextString(metadata.slideTitle) ?? 'Slide';\n\t\t\tconst slideOrdinal =\n\t\t\t\tgetContextNumber(metadata.slideNumber) ??\n\t\t\t\t(typeof metadata.slideIndex === 'number'\n\t\t\t\t\t? metadata.slideIndex + 1\n\t\t\t\t\t: 1);\n\t\t\tfamilyPath = [slideFamily];\n\t\t\tordinalPath = [slideOrdinal];\n\t\t}\n\t}\n\n\tconst sectionFamilyKey =\n\t\tgetContextString(metadata.sectionSiblingFamilyKey) ?? familyPath.at(-1);\n\tconst sectionOrdinal =\n\t\tgetContextNumber(metadata.sectionSiblingOrdinal) ?? ordinalPath.at(-1);\n\tif (!sectionFamilyKey || typeof sectionOrdinal !== 'number') {\n\t\treturn undefined;\n\t}\n\n\treturn {\n\t\tfamilyPath,\n\t\tkind,\n\t\tordinalPath,\n\t\tpathDepth: familyPath.length,\n\t\tsectionFamilyKey,\n\t\tsectionOrdinal\n\t};\n};\n\nconst areGenericStructuredLeadScopesComparable = (\n\tleft: GenericStructuredLeadScope | undefined,\n\tright: GenericStructuredLeadScope | undefined\n) => {\n\tif (!left || !right) {\n\t\treturn false;\n\t}\n\tif (\n\t\tleft.kind !== right.kind ||\n\t\tleft.sectionFamilyKey !== right.sectionFamilyKey ||\n\t\tleft.sectionOrdinal !== right.sectionOrdinal\n\t) {\n\t\treturn false;\n\t}\n\tconst leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n\tconst rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n\tconst leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n\tconst rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n\tconst sharedDepth = Math.min(\n\t\tleftAncestorFamilyPath.length,\n\t\trightAncestorFamilyPath.length\n\t);\n\tfor (let index = 0; index < sharedDepth; index += 1) {\n\t\tif (\n\t\t\tleftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n\t\t\tleftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn true;\n};\n\nconst getOfficeLeadEvidencePreference = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tconst scope = getOfficeLeadScope(metadata);\n\tif (!scope) {\n\t\treturn 0;\n\t}\n\n\treturn (\n\t\tscope.pathDepth * 10 +\n\t\t(scope.hasContext ? 1 : 0) +\n\t\t(scope.blockKind === 'list' &&\n\t\ttypeof metadata?.officeListGroupItemCount === 'number' &&\n\t\tmetadata.officeListGroupItemCount > 1\n\t\t\t? 1\n\t\t\t: 0)\n\t);\n};\n\nconst getGenericStructuredLeadPreference = (\n\tmetadata?: Record<string, unknown>\n) => {\n\tconst scope = getGenericStructuredLeadScope(metadata);\n\tif (!scope) {\n\t\treturn 0;\n\t}\n\n\treturn (\n\t\tscope.pathDepth * 10 +\n\t\t(scope.kind === 'spreadsheet_rows' &&\n\t\ttypeof metadata?.spreadsheetTableIndex === 'number'\n\t\t\t? 2\n\t\t\t: 0) +\n\t\t(Array.isArray(metadata?.spreadsheetHeaders) &&\n\t\tmetadata.spreadsheetHeaders.length > 0\n\t\t\t? 1\n\t\t\t: 0) +\n\t\t(typeof metadata?.slideNotesText === 'string' &&\n\t\tmetadata.slideNotesText.trim().length > 0\n\t\t\t? 1\n\t\t\t: 0)\n\t);\n};\n\nconst getPreferredSourceLeadChunk = (chunks: RAGSource[]) =>\n\tchunks.slice().sort((left, right) => {\n\t\tconst leftOfficeScope = getOfficeLeadScope(left.metadata);\n\t\tconst rightOfficeScope = getOfficeLeadScope(right.metadata);\n\t\tif (\n\t\t\tleft.source === right.source &&\n\t\t\tareOfficeLeadScopesComparable(leftOfficeScope, rightOfficeScope)\n\t\t) {\n\t\t\tconst leftOfficePreference = getOfficeLeadEvidencePreference(\n\t\t\t\tleft.metadata\n\t\t\t);\n\t\t\tconst rightOfficePreference = getOfficeLeadEvidencePreference(\n\t\t\t\tright.metadata\n\t\t\t);\n\t\t\tif (rightOfficePreference !== leftOfficePreference) {\n\t\t\t\treturn rightOfficePreference - leftOfficePreference;\n\t\t\t}\n\t\t}\n\t\tconst leftGenericScope = getGenericStructuredLeadScope(left.metadata);\n\t\tconst rightGenericScope = getGenericStructuredLeadScope(right.metadata);\n\t\tif (\n\t\t\tleft.source === right.source &&\n\t\t\tareGenericStructuredLeadScopesComparable(\n\t\t\t\tleftGenericScope,\n\t\t\t\trightGenericScope\n\t\t\t)\n\t\t) {\n\t\t\tconst leftGenericPreference = getGenericStructuredLeadPreference(\n\t\t\t\tleft.metadata\n\t\t\t);\n\t\t\tconst rightGenericPreference = getGenericStructuredLeadPreference(\n\t\t\t\tright.metadata\n\t\t\t);\n\t\t\tif (rightGenericPreference !== leftGenericPreference) {\n\t\t\t\treturn rightGenericPreference - leftGenericPreference;\n\t\t\t}\n\t\t}\n\t\tconst leftWeightedScore = getStructuredSourceLeadScore(left);\n\t\tconst rightWeightedScore = getStructuredSourceLeadScore(right);\n\t\tif (rightWeightedScore !== leftWeightedScore) {\n\t\t\treturn rightWeightedScore - leftWeightedScore;\n\t\t}\n\t\tconst leftScope = getPDFLeadScope(left.metadata);\n\t\tconst rightScope = getPDFLeadScope(right.metadata);\n\t\tif (\n\t\t\tleft.source === right.source &&\n\t\t\tleftScope &&\n\t\t\trightScope &&\n\t\t\t((leftScope.sectionTitle &&\n\t\t\t\trightScope.sectionTitle &&\n\t\t\t\tleftScope.sectionTitle === rightScope.sectionTitle) ||\n\t\t\t\t(typeof leftScope.pageNumber === 'number' &&\n\t\t\t\t\ttypeof rightScope.pageNumber === 'number' &&\n\t\t\t\t\tleftScope.pageNumber === rightScope.pageNumber))\n\t\t) {\n\t\t\tconst leftEvidencePreference = getPDFLeadEvidencePreference(\n\t\t\t\tleft.metadata\n\t\t\t);\n\t\t\tconst rightEvidencePreference = getPDFLeadEvidencePreference(\n\t\t\t\tright.metadata\n\t\t\t);\n\t\t\tif (rightEvidencePreference !== leftEvidencePreference) {\n\t\t\t\treturn rightEvidencePreference - leftEvidencePreference;\n\t\t\t}\n\t\t}\n\t\tif (right.score !== left.score) {\n\t\t\treturn right.score - left.score;\n\t\t}\n\n\t\treturn left.chunkId.localeCompare(right.chunkId);\n\t})[0];\n\nexport const buildRAGSectionRetrievalDiagnostics = (\n\tsources: RAGSource[],\n\ttrace?: RAGRetrievalTrace\n): RAGSectionRetrievalDiagnostic[] => {\n\tconst totalScore = sources.reduce(\n\t\t(sum, source) =>\n\t\t\tsum +\n\t\t\tsource.score * getStructuredSectionScoreWeight(source.metadata),\n\t\t0\n\t);\n\tif (sources.length === 0 || totalScore <= 0) {\n\t\treturn [];\n\t}\n\n\tconst sections = new Map<\n\t\tstring,\n\t\t{\n\t\t\tkey: string;\n\t\t\tlabel: string;\n\t\t\tpath?: string[];\n\t\t\tparentLabel?: string;\n\t\t\tcount: number;\n\t\t\tbestScore: number;\n\t\t\ttotalScore: number;\n\t\t\ttopChunkId?: string;\n\t\t\ttopSource?: string;\n\t\t\tvectorHits: number;\n\t\t\tlexicalHits: number;\n\t\t\thybridHits: number;\n\t\t\tprimaryHits: number;\n\t\t\ttransformedHits: number;\n\t\t\tvariantHits: number;\n\t\t\tsourceSet: Set<string>;\n\t\t}\n\t>();\n\n\tfor (const source of sources) {\n\t\tconst structuredScore =\n\t\t\tsource.score * getStructuredSectionScoreWeight(source.metadata);\n\t\tconst path = getSectionPathFromSource(source);\n\t\tif (!path) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst key = path.join(' > ');\n\t\tconst label = path.at(-1) ?? key;\n\t\tconst parentLabel =\n\t\t\tpath.length > 1 ? path.slice(0, -1).join(' > ') : undefined;\n\t\tconst existing = sections.get(key);\n\t\tconst channels = Array.isArray(source.metadata?.retrievalChannels)\n\t\t\t? source.metadata.retrievalChannels.filter(\n\t\t\t\t\t(value): value is 'vector' | 'lexical' =>\n\t\t\t\t\t\tvalue === 'vector' || value === 'lexical'\n\t\t\t\t)\n\t\t\t: [];\n\t\tconst isHybrid =\n\t\t\tchannels.includes('vector') && channels.includes('lexical');\n\t\tconst vectorHits = channels.includes('vector') ? 1 : 0;\n\t\tconst lexicalHits = channels.includes('lexical') ? 1 : 0;\n\t\tconst hybridHits = isHybrid ? 1 : 0;\n\t\tconst queryOrigins = Array.isArray(\n\t\t\tsource.metadata?.retrievalQueryOrigins\n\t\t)\n\t\t\t? source.metadata.retrievalQueryOrigins.filter(\n\t\t\t\t\t(value): value is 'primary' | 'transformed' | 'variant' =>\n\t\t\t\t\t\tvalue === 'primary' ||\n\t\t\t\t\t\tvalue === 'transformed' ||\n\t\t\t\t\t\tvalue === 'variant'\n\t\t\t\t)\n\t\t\t: source.metadata?.retrievalQueryOrigin === 'primary' ||\n\t\t\t\t source.metadata?.retrievalQueryOrigin === 'transformed' ||\n\t\t\t\t source.metadata?.retrievalQueryOrigin === 'variant'\n\t\t\t\t? [source.metadata.retrievalQueryOrigin]\n\t\t\t\t: [];\n\t\tconst primaryHits = queryOrigins.includes('primary') ? 1 : 0;\n\t\tconst transformedHits = queryOrigins.includes('transformed') ? 1 : 0;\n\t\tconst variantHits = queryOrigins.includes('variant') ? 1 : 0;\n\t\tif (!existing) {\n\t\t\tsections.set(key, {\n\t\t\t\tbestScore: source.score,\n\t\t\t\tcount: 1,\n\t\t\t\thybridHits,\n\t\t\t\tkey,\n\t\t\t\tlabel,\n\t\t\t\tlexicalHits,\n\t\t\t\tparentLabel,\n\t\t\t\tpath,\n\t\t\t\tprimaryHits,\n\t\t\t\tsourceSet: new Set(source.source ? [source.source] : []),\n\t\t\t\ttopChunkId: source.chunkId,\n\t\t\t\ttopSource: source.source,\n\t\t\t\ttotalScore: structuredScore,\n\t\t\t\ttransformedHits,\n\t\t\t\tvariantHits,\n\t\t\t\tvectorHits\n\t\t\t});\n\t\t\tcontinue;\n\t\t}\n\n\t\texisting.count += 1;\n\t\texisting.totalScore += structuredScore;\n\t\tif (source.source) {\n\t\t\texisting.sourceSet.add(source.source);\n\t\t}\n\t\texisting.vectorHits += vectorHits;\n\t\texisting.lexicalHits += lexicalHits;\n\t\texisting.hybridHits += hybridHits;\n\t\texisting.primaryHits += primaryHits;\n\t\texisting.transformedHits += transformedHits;\n\t\texisting.variantHits += variantHits;\n\t\tif (source.score > existing.bestScore) {\n\t\t\texisting.bestScore = source.score;\n\t\t\texisting.topChunkId = source.chunkId;\n\t\t\texisting.topSource = source.source;\n\t\t}\n\t}\n\n\tconst diagnostics = [...sections.values()];\n\tconst strongestBestHit = diagnostics.reduce(\n\t\t(highest, section) => Math.max(highest, section.bestScore),\n\t\t0\n\t);\n\tconst parentLabelByKey = new Map(\n\t\tdiagnostics.map(\n\t\t\t(section) => [section.key, section.parentLabel] as const\n\t\t)\n\t);\n\tconst stageSectionCounts = new Map(\n\t\t(trace?.steps ?? [])\n\t\t\t.filter(\n\t\t\t\t(step) =>\n\t\t\t\t\tArray.isArray(step.sectionCounts) &&\n\t\t\t\t\tstep.sectionCounts.length > 0\n\t\t\t)\n\t\t\t.map((step) => [step.stage, step.sectionCounts ?? []] as const)\n\t);\n\tconst stageSectionScores = new Map(\n\t\t(trace?.steps ?? [])\n\t\t\t.filter(\n\t\t\t\t(step) =>\n\t\t\t\t\tArray.isArray(step.sectionScores) &&\n\t\t\t\t\tstep.sectionScores.length > 0\n\t\t\t)\n\t\t\t.map((step) => [step.stage, step.sectionScores ?? []] as const)\n\t);\n\n\treturn diagnostics\n\t\t.map<RAGSectionRetrievalDiagnostic>((section) => {\n\t\t\tconst siblingPool = diagnostics.filter(\n\t\t\t\t(entry) => entry.parentLabel === section.parentLabel\n\t\t\t);\n\t\t\tconst siblings = siblingPool.filter(\n\t\t\t\t(entry) => entry.key !== section.key\n\t\t\t);\n\t\t\tconst strongestSibling = siblings\n\t\t\t\t.slice()\n\t\t\t\t.sort((left, right) => right.totalScore - left.totalScore)[0];\n\t\t\tconst parentTotal = siblingPool.reduce(\n\t\t\t\t(sum, entry) => sum + entry.totalScore,\n\t\t\t\t0\n\t\t\t);\n\t\t\tconst scoreShare = section.totalScore / totalScore;\n\t\t\tconst parentShare =\n\t\t\t\tparentTotal > 0 ? section.totalScore / parentTotal : undefined;\n\t\t\tconst topChunk = sources.find(\n\t\t\t\t(source) => source.chunkId === section.topChunkId\n\t\t\t);\n\t\t\tconst topContextLabel =\n\t\t\t\ttopChunk?.labels?.contextLabel ??\n\t\t\t\tbuildContextLabel(topChunk?.metadata);\n\t\t\tconst topLocatorLabel =\n\t\t\t\ttopChunk?.labels?.locatorLabel ??\n\t\t\t\tbuildLocatorLabel(\n\t\t\t\t\ttopChunk?.metadata,\n\t\t\t\t\ttopChunk?.source,\n\t\t\t\t\ttopChunk?.title\n\t\t\t\t);\n\t\t\tconst sourceAwareChunkReason = formatSourceAwareChunkReason(\n\t\t\t\ttopChunk?.metadata?.sourceAwareChunkReason\n\t\t\t);\n\t\t\tconst sourceAwareUnitScopeLabel = buildSourceAwareUnitScopeLabel(\n\t\t\t\ttopChunk?.metadata\n\t\t\t);\n\t\t\tconst parentDistribution =\n\t\t\t\tparentTotal > 0\n\t\t\t\t\t? siblingPool\n\t\t\t\t\t\t\t.map((entry) => ({\n\t\t\t\t\t\t\t\tcount: entry.count,\n\t\t\t\t\t\t\t\tisActive: entry.key === section.key,\n\t\t\t\t\t\t\t\tkey: entry.key,\n\t\t\t\t\t\t\t\tlabel: entry.label,\n\t\t\t\t\t\t\t\tparentShare: entry.totalScore / parentTotal,\n\t\t\t\t\t\t\t\ttotalScore: entry.totalScore\n\t\t\t\t\t\t\t}))\n\t\t\t\t\t\t\t.sort(\n\t\t\t\t\t\t\t\t(left, right) =>\n\t\t\t\t\t\t\t\t\tright.totalScore - left.totalScore\n\t\t\t\t\t\t\t)\n\t\t\t\t\t: [];\n\t\t\tconst reasons: RAGSectionRetrievalDiagnostic['reasons'] = [];\n\t\t\tconst stageCounts =\n\t\t\t\ttrace?.steps\n\t\t\t\t\t.map((step) => ({\n\t\t\t\t\t\tcount:\n\t\t\t\t\t\t\tstep.sectionCounts?.find(\n\t\t\t\t\t\t\t\t(entry) => entry.key === section.key\n\t\t\t\t\t\t\t)?.count ?? 0,\n\t\t\t\t\t\tstage: step.stage\n\t\t\t\t\t}))\n\t\t\t\t\t.filter((entry) => entry.count > 0) ?? [];\n\t\t\tconst stageWeights = stageCounts.map((entry) => {\n\t\t\t\tconst previousStageEntry =\n\t\t\t\t\tstageCounts[\n\t\t\t\t\t\tstageCounts.findIndex(\n\t\t\t\t\t\t\t(candidate) => candidate.stage === entry.stage\n\t\t\t\t\t\t) - 1\n\t\t\t\t\t];\n\t\t\t\tconst stageEntries =\n\t\t\t\t\tstageSectionCounts\n\t\t\t\t\t\t.get(entry.stage)\n\t\t\t\t\t\t?.filter((candidate) => candidate.count > 0) ?? [];\n\t\t\t\tconst stageScoreEntries =\n\t\t\t\t\tstageSectionScores\n\t\t\t\t\t\t.get(entry.stage)\n\t\t\t\t\t\t?.filter((candidate) => candidate.totalScore > 0) ?? [];\n\t\t\t\tconst stageTotal = stageEntries.reduce(\n\t\t\t\t\t(sum, candidate) => sum + candidate.count,\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t\tconst stageScoreTotal = stageScoreEntries.reduce(\n\t\t\t\t\t(sum, candidate) => sum + candidate.totalScore,\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t\tconst siblingStageEntries = stageEntries.filter(\n\t\t\t\t\t(candidate) =>\n\t\t\t\t\t\tcandidate.key !== section.key &&\n\t\t\t\t\t\tparentLabelByKey.get(candidate.key) ===\n\t\t\t\t\t\t\tsection.parentLabel\n\t\t\t\t);\n\t\t\t\tconst parentStageEntries = stageEntries.filter(\n\t\t\t\t\t(candidate) =>\n\t\t\t\t\t\tparentLabelByKey.get(candidate.key) ===\n\t\t\t\t\t\tsection.parentLabel\n\t\t\t\t);\n\t\t\t\tconst siblingStageScoreEntries = stageScoreEntries.filter(\n\t\t\t\t\t(candidate) =>\n\t\t\t\t\t\tcandidate.key !== section.key &&\n\t\t\t\t\t\tparentLabelByKey.get(candidate.key) ===\n\t\t\t\t\t\t\tsection.parentLabel\n\t\t\t\t);\n\t\t\t\tconst parentStageScoreEntries = stageScoreEntries.filter(\n\t\t\t\t\t(candidate) =>\n\t\t\t\t\t\tparentLabelByKey.get(candidate.key) ===\n\t\t\t\t\t\tsection.parentLabel\n\t\t\t\t);\n\t\t\t\tconst strongestStageSibling = siblingStageEntries\n\t\t\t\t\t.slice()\n\t\t\t\t\t.sort((left, right) => right.count - left.count)[0];\n\t\t\t\tconst parentStageTotal = parentStageEntries.reduce(\n\t\t\t\t\t(sum, candidate) => sum + candidate.count,\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t\tconst activeStageScore = stageScoreEntries.find(\n\t\t\t\t\t(candidate) => candidate.key === section.key\n\t\t\t\t)?.totalScore;\n\t\t\t\tconst strongestStageScoreSibling = siblingStageScoreEntries\n\t\t\t\t\t.slice()\n\t\t\t\t\t.sort(\n\t\t\t\t\t\t(left, right) => right.totalScore - left.totalScore\n\t\t\t\t\t)[0];\n\t\t\t\tconst parentStageScoreTotal = parentStageScoreEntries.reduce(\n\t\t\t\t\t(sum, candidate) => sum + candidate.totalScore,\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t\tconst stageShare =\n\t\t\t\t\tstageTotal > 0 ? entry.count / stageTotal : 0;\n\t\t\t\tconst retentionRate =\n\t\t\t\t\ttypeof previousStageEntry?.count === 'number' &&\n\t\t\t\t\tpreviousStageEntry.count > 0\n\t\t\t\t\t\t? entry.count / previousStageEntry.count\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst countDelta =\n\t\t\t\t\ttypeof previousStageEntry?.count === 'number'\n\t\t\t\t\t\t? entry.count - previousStageEntry.count\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst parentStageShare =\n\t\t\t\t\tparentStageTotal > 0\n\t\t\t\t\t\t? entry.count / parentStageTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst stageScoreShare =\n\t\t\t\t\ttypeof activeStageScore === 'number' && stageScoreTotal > 0\n\t\t\t\t\t\t? activeStageScore / stageScoreTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst parentStageScoreShare =\n\t\t\t\t\ttypeof activeStageScore === 'number' &&\n\t\t\t\t\tparentStageScoreTotal > 0\n\t\t\t\t\t\t? activeStageScore / parentStageScoreTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst stageShareGap =\n\t\t\t\t\tstageTotal > 0 && strongestStageSibling\n\t\t\t\t\t\t? entry.count / stageTotal -\n\t\t\t\t\t\t\tstrongestStageSibling.count / stageTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst parentStageShareGap =\n\t\t\t\t\tparentStageTotal > 0 && strongestStageSibling\n\t\t\t\t\t\t? entry.count / parentStageTotal -\n\t\t\t\t\t\t\tstrongestStageSibling.count / parentStageTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst stageScoreShareGap =\n\t\t\t\t\ttypeof activeStageScore === 'number' &&\n\t\t\t\t\tstageScoreTotal > 0 &&\n\t\t\t\t\tstrongestStageScoreSibling\n\t\t\t\t\t\t? activeStageScore / stageScoreTotal -\n\t\t\t\t\t\t\tstrongestStageScoreSibling.totalScore /\n\t\t\t\t\t\t\t\tstageScoreTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst parentStageScoreShareGap =\n\t\t\t\t\ttypeof activeStageScore === 'number' &&\n\t\t\t\t\tparentStageScoreTotal > 0 &&\n\t\t\t\t\tstrongestStageScoreSibling\n\t\t\t\t\t\t? activeStageScore / parentStageScoreTotal -\n\t\t\t\t\t\t\tstrongestStageScoreSibling.totalScore /\n\t\t\t\t\t\t\t\tparentStageScoreTotal\n\t\t\t\t\t\t: undefined;\n\t\t\t\tconst reasons: RAGSectionRetrievalDiagnostic['stageWeights'][number]['reasons'] =\n\t\t\t\t\t[];\n\t\t\t\tif (\n\t\t\t\t\tentry.stage === 'rerank' &&\n\t\t\t\t\tstageShare > 0.5 &&\n\t\t\t\t\t(typeof stageShareGap !== 'number' || stageShareGap > 0)\n\t\t\t\t) {\n\t\t\t\t\treasons.push('rerank_preserved_lead');\n\t\t\t\t}\n\t\t\t\tif (entry.stage === 'finalize' && stageShare >= 0.5) {\n\t\t\t\t\treasons.push('final_stage_concentration');\n\t\t\t\t}\n\t\t\t\tif (\n\t\t\t\t\tentry.stage === 'finalize' &&\n\t\t\t\t\ttypeof parentStageShare === 'number' &&\n\t\t\t\t\tparentStageShare >= 0.6 &&\n\t\t\t\t\t(typeof parentStageShareGap !== 'number' ||\n\t\t\t\t\t\tparentStageShareGap > 0)\n\t\t\t\t) {\n\t\t\t\t\treasons.push('final_stage_dominant_within_parent');\n\t\t\t\t}\n\t\t\t\tif (\n\t\t\t\t\tstrongestStageSibling &&\n\t\t\t\t\t((typeof stageShareGap === 'number' &&\n\t\t\t\t\t\tstageShareGap <= 0.1) ||\n\t\t\t\t\t\t(typeof parentStageShareGap === 'number' &&\n\t\t\t\t\t\t\tparentStageShareGap <= 0.1))\n\t\t\t\t) {\n\t\t\t\t\treasons.push('stage_runner_up_pressure');\n\t\t\t\t}\n\t\t\t\tif (typeof countDelta === 'number') {\n\t\t\t\t\tif (countDelta > 0) {\n\t\t\t\t\t\treasons.push('stage_expanded');\n\t\t\t\t\t} else if (countDelta < 0) {\n\t\t\t\t\t\treasons.push('stage_narrowed');\n\t\t\t\t\t} else {\n\t\t\t\t\t\treasons.push('stage_held');\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn {\n\t\t\t\t\tcount: entry.count,\n\t\t\t\t\tcountDelta,\n\t\t\t\t\tparentStageScoreShare,\n\t\t\t\t\tparentStageShare,\n\t\t\t\t\tparentStageShareGap,\n\t\t\t\t\tpreviousCount: previousStageEntry?.count,\n\t\t\t\t\tpreviousStage: previousStageEntry?.stage,\n\t\t\t\t\treasons,\n\t\t\t\t\tretentionRate,\n\t\t\t\t\tstage: entry.stage,\n\t\t\t\t\tstageScoreShare,\n\t\t\t\t\tstageScoreShareGap,\n\t\t\t\t\tstageShare,\n\t\t\t\t\tstageShareGap,\n\t\t\t\t\ttotalScore: activeStageScore,\n\t\t\t\t\tstrongestSiblingCount: strongestStageSibling?.count,\n\t\t\t\t\tstrongestSiblingLabel: strongestStageSibling\n\t\t\t\t\t\t? (diagnostics.find(\n\t\t\t\t\t\t\t\t(candidate) =>\n\t\t\t\t\t\t\t\t\tcandidate.key === strongestStageSibling.key\n\t\t\t\t\t\t\t)?.label ?? strongestStageSibling.key)\n\t\t\t\t\t\t: undefined\n\t\t\t\t};\n\t\t\t});\n\t\t\tconst firstSeenStage = stageCounts[0]?.stage;\n\t\t\tconst lastSeenStage = stageCounts.at(-1)?.stage;\n\t\t\tconst peakStageEntry = stageCounts.reduce<\n\t\t\t\t(typeof stageCounts)[number] | undefined\n\t\t\t>(\n\t\t\t\t(highest, entry) =>\n\t\t\t\t\t!highest || entry.count > highest.count ? entry : highest,\n\t\t\t\tundefined\n\t\t\t);\n\t\t\tconst finalStageEntry = stageCounts.at(-1);\n\t\t\tconst peakCount = peakStageEntry?.count ?? section.count;\n\t\t\tconst finalCount = finalStageEntry?.count;\n\t\t\tconst finalRetentionRate =\n\t\t\t\ttypeof finalCount === 'number' && peakCount > 0\n\t\t\t\t\t? finalCount / peakCount\n\t\t\t\t\t: undefined;\n\t\t\tconst dropFromPeak =\n\t\t\t\ttypeof finalCount === 'number'\n\t\t\t\t\t? peakCount - finalCount\n\t\t\t\t\t: undefined;\n\t\t\tconst queryAttributionReasons: RAGSectionRetrievalDiagnostic['queryAttribution']['reasons'] =\n\t\t\t\t[];\n\t\t\tconst queryAttributionMode =\n\t\t\t\tsection.primaryHits > 0 &&\n\t\t\t\tsection.transformedHits === 0 &&\n\t\t\t\tsection.variantHits === 0\n\t\t\t\t\t? 'primary'\n\t\t\t\t\t: section.transformedHits > 0 &&\n\t\t\t\t\t\t section.primaryHits === 0 &&\n\t\t\t\t\t\t section.variantHits === 0\n\t\t\t\t\t\t? 'transformed'\n\t\t\t\t\t\t: section.variantHits > 0 &&\n\t\t\t\t\t\t\t section.primaryHits === 0 &&\n\t\t\t\t\t\t\t section.transformedHits === 0\n\t\t\t\t\t\t\t? 'variant'\n\t\t\t\t\t\t\t: 'mixed';\n\t\t\tif (queryAttributionMode === 'primary') {\n\t\t\t\tqueryAttributionReasons.push('base_query_only');\n\t\t\t}\n\t\t\tif (queryAttributionMode === 'transformed') {\n\t\t\t\tqueryAttributionReasons.push('transformed_query_only');\n\t\t\t\tqueryAttributionReasons.push('transform_introduced');\n\t\t\t}\n\t\t\tif (queryAttributionMode === 'variant') {\n\t\t\t\tqueryAttributionReasons.push('variant_only');\n\t\t\t\tqueryAttributionReasons.push('variant_supported');\n\t\t\t}\n\t\t\tif (queryAttributionMode === 'mixed') {\n\t\t\t\tqueryAttributionReasons.push('mixed_query_sources');\n\t\t\t\tif (section.variantHits > 0) {\n\t\t\t\t\tqueryAttributionReasons.push('variant_supported');\n\t\t\t\t}\n\t\t\t\tif (section.transformedHits > 0 && section.primaryHits === 0) {\n\t\t\t\t\tqueryAttributionReasons.push('transform_introduced');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (section.bestScore >= strongestBestHit) {\n\t\t\t\treasons.push('best_hit');\n\t\t\t}\n\t\t\tif (section.count > 1) {\n\t\t\t\treasons.push('multi_hit_section');\n\t\t\t}\n\t\t\tif (siblings.length === 0) {\n\t\t\t\treasons.push('only_section_in_parent');\n\t\t\t} else if (\n\t\t\t\t!strongestSibling ||\n\t\t\t\tsection.totalScore >= strongestSibling.totalScore\n\t\t\t) {\n\t\t\t\treasons.push('dominant_within_parent');\n\t\t\t}\n\t\t\tif (scoreShare >= 0.5 || (parentShare ?? 0) >= 0.6) {\n\t\t\t\treasons.push('concentrated_evidence');\n\t\t\t}\n\n\t\t\tconst summaryParts = [\n\t\t\t\tisBlockAwareContextLabel(topContextLabel)\n\t\t\t\t\t? topContextLabel\n\t\t\t\t\t: '',\n\t\t\t\t`${section.count} hit${section.count === 1 ? '' : 's'}`,\n\t\t\t\t`${(scoreShare * 100).toFixed(0)}% score share`,\n\t\t\t\t`vector ${section.vectorHits} · lexical ${section.lexicalHits} · hybrid ${section.hybridHits}`,\n\t\t\t\ttypeof parentShare === 'number'\n\t\t\t\t\t? `${(parentShare * 100).toFixed(0)}% of parent section set`\n\t\t\t\t\t: '',\n\t\t\t\tsourceAwareChunkReason\n\t\t\t\t\t? `boundary ${sourceAwareChunkReason}`\n\t\t\t\t\t: '',\n\t\t\t\tsourceAwareUnitScopeLabel\n\t\t\t\t\t? `scope ${sourceAwareUnitScopeLabel}`\n\t\t\t\t\t: '',\n\t\t\t\tstrongestSibling\n\t\t\t\t\t? `ahead of ${strongestSibling.label} by ${(section.totalScore - strongestSibling.totalScore).toFixed(2)}`\n\t\t\t\t\t: 'no sibling competition'\n\t\t\t].filter(Boolean);\n\n\t\t\treturn {\n\t\t\t\taverageScore: section.totalScore / section.count,\n\t\t\t\tbestScore: section.bestScore,\n\t\t\t\tcount: section.count,\n\t\t\t\tkey: section.key,\n\t\t\t\tlabel: section.label,\n\t\t\t\tparentLabel: section.parentLabel,\n\t\t\t\tparentDistribution,\n\t\t\t\tparentShare,\n\t\t\t\tparentShareGap:\n\t\t\t\t\ttypeof parentShare === 'number' &&\n\t\t\t\t\tstrongestSibling &&\n\t\t\t\t\tparentTotal > 0\n\t\t\t\t\t\t? parentShare -\n\t\t\t\t\t\t\tstrongestSibling.totalScore / parentTotal\n\t\t\t\t\t\t: undefined,\n\t\t\t\tpath: section.path,\n\t\t\t\tfirstSeenStage,\n\t\t\t\tfinalCount,\n\t\t\t\tfinalRetentionRate,\n\t\t\t\tlastSeenStage,\n\t\t\t\tdropFromPeak,\n\t\t\t\tpeakCount,\n\t\t\t\tpeakStage: peakStageEntry?.stage,\n\t\t\t\tqueryAttribution: {\n\t\t\t\t\tmode: queryAttributionMode,\n\t\t\t\t\tprimaryHits: section.primaryHits,\n\t\t\t\t\treasons: queryAttributionReasons,\n\t\t\t\t\ttransformedHits: section.transformedHits,\n\t\t\t\t\tvariantHits: section.variantHits\n\t\t\t\t},\n\t\t\t\trequestedMode: trace?.requestedMode,\n\t\t\t\tretrievalMode: trace?.mode,\n\t\t\t\troutingLabel: trace?.routingLabel,\n\t\t\t\troutingProvider: trace?.routingProvider,\n\t\t\t\troutingReason: trace?.routingReason,\n\t\t\t\tqueryTransformLabel: trace?.queryTransformLabel,\n\t\t\t\tqueryTransformProvider: trace?.queryTransformProvider,\n\t\t\t\tqueryTransformReason: trace?.queryTransformReason,\n\t\t\t\treasons,\n\t\t\t\tevidenceReconcileApplied: trace?.steps.some(\n\t\t\t\t\t(step) => step.stage === 'evidence_reconcile'\n\t\t\t\t),\n\t\t\t\trerankApplied: trace?.steps.some(\n\t\t\t\t\t(step) =>\n\t\t\t\t\t\tstep.stage === 'rerank' &&\n\t\t\t\t\t\tstep.metadata?.applied === true\n\t\t\t\t),\n\t\t\t\tscoreShare,\n\t\t\t\tscoreThresholdApplied: trace?.steps.some(\n\t\t\t\t\t(step) => step.stage === 'score_filter'\n\t\t\t\t),\n\t\t\t\tstageCounts,\n\t\t\t\tstageWeights,\n\t\t\t\tsiblingCount: siblings.length,\n\t\t\t\tsiblingScoreGap: strongestSibling\n\t\t\t\t\t? section.totalScore - strongestSibling.totalScore\n\t\t\t\t\t: undefined,\n\t\t\t\tsourceCount: section.sourceSet.size,\n\t\t\t\tsourceAwareChunkReasonLabel: sourceAwareChunkReason,\n\t\t\t\tsourceAwareUnitScopeLabel,\n\t\t\t\ttopContextLabel,\n\t\t\t\ttopLocatorLabel,\n\t\t\t\tsourceBalanceApplied: trace?.steps.some(\n\t\t\t\t\t(step) => step.stage === 'source_balance'\n\t\t\t\t),\n\t\t\t\tstrongestSiblingLabel: strongestSibling?.label,\n\t\t\t\tstrongestSiblingScore: strongestSibling?.totalScore,\n\t\t\t\tsummary: summaryParts.join(' · '),\n\t\t\t\ttopChunkId: section.topChunkId,\n\t\t\t\ttopSource: section.topSource,\n\t\t\t\ttotalScore: section.totalScore,\n\t\t\t\thybridHits: section.hybridHits,\n\t\t\t\tlexicalHits: section.lexicalHits,\n\t\t\t\tvectorHits: section.vectorHits\n\t\t\t};\n\t\t})\n\t\t.sort((left, right) => {\n\t\t\tif (right.totalScore !== left.totalScore) {\n\t\t\t\treturn right.totalScore - left.totalScore;\n\t\t\t}\n\t\t\tif (right.bestScore !== left.bestScore) {\n\t\t\t\treturn right.bestScore - left.bestScore;\n\t\t\t}\n\t\t\treturn left.label.localeCompare(right.label);\n\t\t});\n};\n\nexport type RAGStreamProgress = {\n\tstage: RAGStreamStage;\n\tconversationId?: string;\n\tmessageId?: string;\n\tretrievalStartedAt?: number;\n\tretrievedAt?: number;\n\tretrievalDurationMs?: number;\n\thasContent: boolean;\n\thasRetrieved: boolean;\n\thasSources: boolean;\n\thasThinking: boolean;\n\thasToolCalls: boolean;\n\tisComplete: boolean;\n\tisError: boolean;\n\tisIdle: boolean;\n\tisRetrieving: boolean;\n\tisRetrieved: boolean;\n\tisStreaming: boolean;\n\tisSubmitting: boolean;\n\tsourceCount: number;\n\tlatestMessage: AIMessage | undefined;\n};\n\nconst buildStreamProgressState = (messages: AIMessage[]) => {\n\tconst latestMessage = getLatestAssistantMessage(messages);\n\tconst retrieved = latestMessage\n\t\t? buildRAGRetrievedState(messages)\n\t\t: undefined;\n\n\treturn {\n\t\tconversationId: latestMessage?.conversationId,\n\t\tlatestMessage,\n\t\tmessageId: latestMessage?.id,\n\t\tretrieved,\n\t\tsourceCount:\n\t\t\tretrieved?.sources.length ?? latestMessage?.sources?.length ?? 0\n\t};\n};\n\nexport const buildRAGStreamProgress = ({\n\terror,\n\tisStreaming,\n\tmessages\n}: {\n\terror: string | null;\n\tisStreaming: boolean;\n\tmessages: AIMessage[];\n}): RAGStreamProgress => {\n\tconst stage = resolveRAGStreamStage({\n\t\terror,\n\t\tisStreaming,\n\t\tmessages\n\t});\n\tconst state = buildStreamProgressState(messages);\n\tconst hasSources = state.sourceCount > 0;\n\tconst hasRetrieved =\n\t\tstage === 'retrieved' ||\n\t\tstate.retrieved !== undefined ||\n\t\tstate.latestMessage?.retrievedAt !== undefined;\n\tconst hasThinking =\n\t\ttypeof state.latestMessage?.thinking === 'string' &&\n\t\tstate.latestMessage.thinking.length > 0;\n\tconst hasToolCalls = (state.latestMessage?.toolCalls?.length ?? 0) > 0;\n\n\treturn {\n\t\tconversationId: state.conversationId,\n\t\thasContent:\n\t\t\ttypeof state.latestMessage?.content === 'string' &&\n\t\t\tstate.latestMessage.content.length > 0,\n\t\thasRetrieved,\n\t\thasSources,\n\t\thasThinking,\n\t\thasToolCalls,\n\t\tisComplete: stage === 'complete',\n\t\tisError: stage === 'error',\n\t\tisIdle: stage === 'idle',\n\t\tisRetrieved: stage === 'retrieved',\n\t\tisRetrieving: stage === 'submitting' || stage === 'retrieving',\n\t\tisStreaming: stage === 'streaming',\n\t\tisSubmitting: stage === 'submitting',\n\t\tlatestMessage: state.latestMessage,\n\t\tmessageId: state.messageId,\n\t\tretrievalDurationMs: state.retrieved?.retrievalDurationMs,\n\t\tretrievalStartedAt: state.retrieved?.retrievalStartedAt,\n\t\tretrievedAt: state.retrieved?.retrievedAt,\n\t\tsourceCount: state.sourceCount,\n\t\tstage\n\t};\n};\n\nexport type RAGStreamProgressState = ReturnType<typeof buildRAGStreamProgress>;\nexport const buildRAGAnswerWorkflowState = ({\n\terror,\n\tisStreaming,\n\tmessages\n}: {\n\terror: string | null;\n\tisStreaming: boolean;\n\tmessages: AIMessage[];\n}): RAGAnswerWorkflowState => {\n\tconst latestAssistantMessage = getLatestAssistantMessage(messages);\n\tconst sources = getLatestRAGSources(messages);\n\tconst sourceGroups = buildRAGSourceGroups(sources);\n\tconst citations = buildRAGCitations(sources);\n\tconst citationReferenceMap = buildRAGCitationReferenceMap(citations);\n\tconst sourceSummaries = buildRAGSourceSummaries(sources);\n\tconst groundingReferences = buildRAGGroundingReferences(sources);\n\tconst groundedAnswer = buildRAGGroundedAnswer(\n\t\tlatestAssistantMessage?.content ?? '',\n\t\tsources\n\t);\n\tconst retrieval = buildRAGRetrievedState(messages);\n\tconst sectionDiagnostics = buildRAGSectionRetrievalDiagnostics(\n\t\tsources,\n\t\tretrieval?.trace\n\t);\n\tconst progress = buildRAGStreamProgress({\n\t\terror,\n\t\tisStreaming,\n\t\tmessages\n\t});\n\n\treturn {\n\t\texcerptModeCounts: buildRAGExcerptModeCounts([\n\t\t\t...citations.map((citation) => citation.excerptSelection),\n\t\t\t...sourceSummaries.map((summary) => summary.excerptSelection),\n\t\t\t...groundingReferences.map(\n\t\t\t\t(reference) => reference.excerptSelection\n\t\t\t),\n\t\t\t...groundedAnswer.sectionSummaries.map(\n\t\t\t\t(summary) => summary.excerptSelection\n\t\t\t)\n\t\t]),\n\t\tcitationReferenceMap,\n\t\tcitations,\n\t\tcoverage: groundedAnswer.coverage,\n\t\terror,\n\t\tgroundedAnswer,\n\t\tgroundingReferences,\n\t\thasCitations: groundedAnswer.hasCitations,\n\t\thasGrounding: groundingReferences.length > 0,\n\t\thasRetrieved: progress.hasRetrieved,\n\t\thasSources: sources.length > 0,\n\t\tisAnswerStreaming: progress.isStreaming,\n\t\tisComplete: progress.isComplete,\n\t\tisError: progress.isError,\n\t\tisIdle: progress.isIdle,\n\t\tisRetrieved: progress.isRetrieved,\n\t\tisRetrieving: progress.isRetrieving,\n\t\tisRunning:\n\t\t\tprogress.isSubmitting ||\n\t\t\tprogress.isRetrieving ||\n\t\t\tprogress.isStreaming,\n\t\tisSubmitting: progress.isSubmitting,\n\t\tlatestAssistantMessage,\n\t\tmessages,\n\t\tretrieval,\n\t\tretrievalDurationMs: retrieval?.retrievalDurationMs,\n\t\tretrievalStartedAt: retrieval?.retrievalStartedAt,\n\t\tretrievedAt: retrieval?.retrievedAt,\n\t\tsectionDiagnostics,\n\t\tsourceGroups,\n\t\tsourceSummaries,\n\t\tsources,\n\t\tstage: progress.stage,\n\t\tungroundedReferenceNumbers: groundedAnswer.ungroundedReferenceNumbers\n\t};\n};\n\nexport const buildRAGSourceGroups = (sources: RAGSource[]) => {\n\tconst groups = new Map<string, RAGSourceGroup>();\n\n\tfor (const source of sources) {\n\t\tupdateSourceGroup(groups, source);\n\t}\n\n\treturn [...groups.values()].sort((left, right) => {\n\t\tif (right.bestScore !== left.bestScore) {\n\t\t\treturn right.bestScore - left.bestScore;\n\t\t}\n\n\t\treturn left.label.localeCompare(right.label);\n\t});\n};\n\nconst buildSourceGroup = (source: RAGSource, key: string): RAGSourceGroup => ({\n\tbestScore: source.score,\n\tchunks: [source],\n\tcount: 1,\n\tkey,\n\tlabel: buildSourceLabel(source),\n\tlabels:\n\t\tsource.labels ??\n\t\tbuildRAGSourceLabels({\n\t\t\tmetadata: source.metadata,\n\t\t\tsource: source.source,\n\t\t\ttitle: source.title\n\t\t}),\n\tstructure: source.structure ?? buildRAGChunkStructure(source.metadata),\n\tsource: source.source,\n\ttitle: source.title\n});\n\nconst updateSourceGroup = (\n\tgroups: Map<string, RAGSourceGroup>,\n\tsource: RAGSource\n) => {\n\tconst key = buildSourceGroupKey(source);\n\tconst existing = groups.get(key);\n\tif (!existing) {\n\t\tgroups.set(key, buildSourceGroup(source, key));\n\n\t\treturn;\n\t}\n\n\texisting.bestScore = Math.max(existing.bestScore, source.score);\n\texisting.count += 1;\n\texisting.chunks.push(source);\n\tconst leadChunk = getPreferredSourceLeadChunk(existing.chunks);\n\tif (leadChunk) {\n\t\texisting.label = buildSourceLabel(leadChunk);\n\t\texisting.labels =\n\t\t\tleadChunk.labels ??\n\t\t\tbuildRAGSourceLabels({\n\t\t\t\tmetadata: leadChunk.metadata,\n\t\t\t\tsource: leadChunk.source,\n\t\t\t\ttitle: leadChunk.title\n\t\t\t});\n\t\texisting.structure =\n\t\t\tleadChunk.structure ?? buildRAGChunkStructure(leadChunk.metadata);\n\t\texisting.source = leadChunk.source;\n\t\texisting.title = leadChunk.title;\n\t}\n};\nexport const getLatestAssistantMessage = (messages: AIMessage[]) => {\n\tfor (let index = messages.length - 1; index >= 0; index -= 1) {\n\t\tconst message = messages[index];\n\t\tif (message?.role === 'assistant') {\n\t\t\treturn message;\n\t\t}\n\t}\n\n\treturn undefined;\n};\nexport const getLatestRAGSources = (messages: AIMessage[]) =>\n\tgetLatestAssistantMessage(messages)?.sources ?? [];\nexport const getLatestRetrievedMessage = (messages: AIMessage[]) => {\n\tfor (let index = messages.length - 1; index >= 0; index -= 1) {\n\t\tconst message = messages[index];\n\t\tif (\n\t\t\tmessage?.role === 'assistant' &&\n\t\t\t(typeof message.retrievedAt === 'number' ||\n\t\t\t\t(message.sources?.length ?? 0) > 0)\n\t\t) {\n\t\t\treturn message;\n\t\t}\n\t}\n\n\treturn undefined;\n};\nexport const resolveRAGStreamStage = ({\n\terror,\n\tisStreaming,\n\tmessages\n}: {\n\terror: string | null;\n\tisStreaming: boolean;\n\tmessages: AIMessage[];\n}) => {\n\tif (error) {\n\t\treturn 'error';\n\t}\n\n\tconst assistantMessage = getLatestAssistantMessage(messages);\n\tif (!assistantMessage) {\n\t\treturn isStreaming ? 'submitting' : 'idle';\n\t}\n\n\tconst isRetrieving =\n\t\ttypeof assistantMessage.retrievalStartedAt === 'number' &&\n\t\ttypeof assistantMessage.retrievedAt !== 'number';\n\n\tif (isRetrieving) {\n\t\treturn 'retrieving';\n\t}\n\n\tif (!isStreaming) {\n\t\treturn 'complete';\n\t}\n\n\tconst hasRetrieved = typeof assistantMessage.retrievedAt === 'number';\n\tconst hasContent =\n\t\tassistantMessage.content.trim().length > 0 ||\n\t\tassistantMessage.thinking?.trim().length ||\n\t\t(assistantMessage.toolCalls?.length ?? 0) > 0 ||\n\t\t(assistantMessage.images?.length ?? 0) > 0;\n\n\tif (hasRetrieved && !hasContent) {\n\t\treturn 'retrieved';\n\t}\n\n\treturn 'streaming';\n};\n\nconst formatSignedDelta = (value: number, decimals = 0, suffix = '') =>\n\t`${value >= 0 ? '+' : ''}${value.toFixed(decimals)}${suffix}`;\n\nconst formatEvaluationPassingRate = (value: number) => `${value.toFixed(1)}%`;\n\nconst formatEvaluationSummary = (response: RAGEvaluationResponse) =>\n\t`${response.summary.totalCases} total · f1 ${response.summary.averageF1.toFixed(\n\t\t3\n\t)} · latency ${response.summary.averageLatencyMs.toFixed(1)}ms`;\n\nconst formatGroundingHistorySummaryValue = (response: {\n\tsummary: {\n\t\tpassedCases: number;\n\t\ttotalCases: number;\n\t\tgroundedCases: number;\n\t\tpartialCases: number;\n\t\tungroundedCases: number;\n\t\taverageResolvedCitationRate: number;\n\t\taverageCitationF1: number;\n\t};\n}) =>\n\t`${response.summary.passedCases}/${response.summary.totalCases} pass · grounded ${response.summary.groundedCases} · partial ${response.summary.partialCases} · ungrounded ${response.summary.ungroundedCases} · resolved citations ${(response.summary.averageResolvedCitationRate * 100).toFixed(1)}% · citation f1 ${response.summary.averageCitationF1.toFixed(3)}`;\n\nconst formatHistoryCaseLabels = (cases: RAGEvaluationCaseDiff[]) =>\n\tcases.length > 0\n\t\t? cases.map((entry) => entry.label ?? entry.caseId).join(', ')\n\t\t: 'none';\n\nconst buildComparisonCaseLeadLabel = (snapshot?: {\n\ttopLocatorLabel?: string;\n\ttopContextLabel?: string;\n\tsourceAwareUnitScopeLabel?: string;\n\tsourceAwareChunkReasonLabel?: string;\n}) =>\n\tsnapshot?.topLocatorLabel ??\n\tsnapshot?.topContextLabel ??\n\tsnapshot?.sourceAwareUnitScopeLabel ??\n\tsnapshot?.sourceAwareChunkReasonLabel;\n\nconst formatComparisonLeadCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst labels = Array.from(\n\t\tnew Set(\n\t\t\t(entry.caseTraceSnapshots ?? [])\n\t\t\t\t.map((snapshot) => buildComparisonCaseLeadLabel(snapshot))\n\t\t\t\t.filter((value): value is string => typeof value === 'string')\n\t\t)\n\t).slice(0, 3);\n\n\treturn labels.length > 0 ? labels.join(' · ') : 'none';\n};\n\nconst formatComparisonLeadMediaCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst labels = Array.from(\n\t\tnew Set(\n\t\t\t(entry.caseTraceSnapshots ?? [])\n\t\t\t\t.map((snapshot) =>\n\t\t\t\t\tformatLeadMediaCueSummary({\n\t\t\t\t\t\tleadSpeakerCue: snapshot.leadSpeakerCue,\n\t\t\t\t\t\tleadSpeakerAttributionCue:\n\t\t\t\t\t\t\tsnapshot.leadSpeakerAttributionCue,\n\t\t\t\t\t\tleadChannelCue: snapshot.leadChannelCue,\n\t\t\t\t\t\tleadChannelAttributionCue:\n\t\t\t\t\t\t\tsnapshot.leadChannelAttributionCue,\n\t\t\t\t\t\tleadContinuityCue: snapshot.leadContinuityCue\n\t\t\t\t\t})\n\t\t\t\t)\n\t\t\t\t.filter(\n\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\ttypeof value === 'string' && value !== 'none'\n\t\t\t\t)\n\t\t)\n\t).slice(0, 3);\n\n\treturn labels.length > 0 ? labels.join(' · ') : 'none';\n};\n\nconst formatComparisonPresentationCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst labels = Array.from(\n\t\tnew Set(\n\t\t\t(entry.caseTraceSnapshots ?? [])\n\t\t\t\t.map((snapshot) => snapshot.leadPresentationCue)\n\t\t\t\t.filter(\n\t\t\t\t\t(value): value is 'body' | 'notes' | 'title' =>\n\t\t\t\t\t\tvalue === 'body' ||\n\t\t\t\t\t\tvalue === 'notes' ||\n\t\t\t\t\t\tvalue === 'title'\n\t\t\t\t)\n\t\t)\n\t).map((value) =>\n\t\tvalue === 'notes' ? 'notes' : value === 'title' ? 'title' : 'body'\n\t);\n\n\treturn labels.length > 0 ? labels.join(' / ') : 'none';\n};\n\nconst formatLeadPresentationCue = (\n\tcue?: 'body' | 'notes' | 'title'\n): string => {\n\tif (cue === 'notes' || cue === 'title' || cue === 'body') {\n\t\treturn cue;\n\t}\n\n\treturn 'none';\n};\n\nconst formatSQLitePlannerCueSummary = (input?: {\n\tsqliteQueryMode?: string;\n\tsqliteQueryPushdownMode?: string;\n\tsqliteQueryPushdownApplied?: boolean;\n\tsqliteQueryPushdownClauseCount?: number;\n\tsqliteQueryPushdownCoverageRatio?: number;\n\tsqliteQueryTotalFilterClauseCount?: number;\n\tsqliteQueryJsRemainderClauseCount?: number;\n\tsqliteQueryPlannerProfileUsed?: string;\n\tsqliteQueryMultiplierUsed?: number;\n\tsqliteQueryCandidateLimitUsed?: number;\n\tsqliteQueryMaxBackfillsUsed?: number;\n\tsqliteQueryMinResultsUsed?: number;\n\tsqliteQueryFillPolicyUsed?: string;\n\tsqliteQueryJsRemainderRatio?: number;\n\tsqliteQueryFilteredCandidates?: number;\n\tsqliteQueryInitialSearchK?: number;\n\tsqliteQueryFinalSearchK?: number;\n\tsqliteQuerySearchExpansionRatio?: number;\n\tsqliteQueryBackfillCount?: number;\n\tsqliteQueryBackfillLimitReached?: boolean;\n\tsqliteQueryMinResultsSatisfied?: boolean;\n\tsqliteQueryReturnedCount?: number;\n\tsqliteQueryCandidateYieldRatio?: number;\n\tsqliteQueryTopKFillRatio?: number;\n\tsqliteQueryUnderfilledTopK?: boolean;\n\tsqliteQueryCandidateBudgetExhausted?: boolean;\n\tsqliteQueryCandidateCoverage?: string;\n}) => {\n\tconst plannerJudgment =\n\t\ttypeof input?.sqliteQuerySearchExpansionRatio === 'number' &&\n\t\ttypeof input?.sqliteQueryCandidateYieldRatio === 'number' &&\n\t\tinput.sqliteQuerySearchExpansionRatio >= 2 &&\n\t\tinput.sqliteQueryCandidateYieldRatio < 0.25\n\t\t\t? 'expensive backfill'\n\t\t\t: typeof input?.sqliteQueryTopKFillRatio === 'number' &&\n\t\t\t\t typeof input?.sqliteQueryCandidateYieldRatio === 'number' &&\n\t\t\t\t input.sqliteQueryTopKFillRatio >= 1 &&\n\t\t\t\t input.sqliteQueryCandidateYieldRatio >= 0.5\n\t\t\t\t? 'efficient fill'\n\t\t\t\t: input?.sqliteQueryPushdownMode === 'full' &&\n\t\t\t\t\t typeof input?.sqliteQueryPushdownCoverageRatio ===\n\t\t\t\t\t\t\t'number' &&\n\t\t\t\t\t input.sqliteQueryPushdownCoverageRatio >= 1\n\t\t\t\t\t? 'full pushdown'\n\t\t\t\t\t: input?.sqliteQueryPushdownMode === 'partial' &&\n\t\t\t\t\t\t typeof input?.sqliteQueryJsRemainderRatio ===\n\t\t\t\t\t\t\t\t'number' &&\n\t\t\t\t\t\t input.sqliteQueryJsRemainderRatio >= 0.5\n\t\t\t\t\t\t? 'heavy js remainder'\n\t\t\t\t\t\t: undefined;\n\n\tconst parts = [\n\t\tinput?.sqliteQueryMode ? `mode ${input.sqliteQueryMode}` : undefined,\n\t\tinput?.sqliteQueryPushdownMode\n\t\t\t? `pushdown ${input.sqliteQueryPushdownMode}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryPushdownApplied === 'boolean'\n\t\t\t? input.sqliteQueryPushdownApplied\n\t\t\t\t? 'pushdown applied'\n\t\t\t\t: 'pushdown skipped'\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryPushdownClauseCount === 'number'\n\t\t\t? `clauses ${input.sqliteQueryPushdownClauseCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryPushdownCoverageRatio === 'number'\n\t\t\t? `pushdown ${(input.sqliteQueryPushdownCoverageRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryJsRemainderClauseCount === 'number'\n\t\t\t? `js remainder ${input.sqliteQueryJsRemainderClauseCount}`\n\t\t\t: undefined,\n\t\tinput?.sqliteQueryPlannerProfileUsed\n\t\t\t? `profile ${input.sqliteQueryPlannerProfileUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryMultiplierUsed === 'number'\n\t\t\t? `x${input.sqliteQueryMultiplierUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryCandidateLimitUsed === 'number'\n\t\t\t? `cap ${input.sqliteQueryCandidateLimitUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryMaxBackfillsUsed === 'number'\n\t\t\t? `backfills ${input.sqliteQueryMaxBackfillsUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryMinResultsUsed === 'number'\n\t\t\t? `min ${input.sqliteQueryMinResultsUsed}`\n\t\t\t: undefined,\n\t\tinput?.sqliteQueryFillPolicyUsed\n\t\t\t? `fill ${input.sqliteQueryFillPolicyUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryJsRemainderRatio === 'number'\n\t\t\t? `js ${(input.sqliteQueryJsRemainderRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryTotalFilterClauseCount === 'number'\n\t\t\t? `total clauses ${input.sqliteQueryTotalFilterClauseCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryFilteredCandidates === 'number'\n\t\t\t? `filtered ${input.sqliteQueryFilteredCandidates}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryInitialSearchK === 'number' &&\n\t\ttypeof input?.sqliteQueryFinalSearchK === 'number'\n\t\t\t? `searchK ${input.sqliteQueryInitialSearchK}->${input.sqliteQueryFinalSearchK}`\n\t\t\t: typeof input?.sqliteQueryFinalSearchK === 'number'\n\t\t\t\t? `searchK ${input.sqliteQueryFinalSearchK}`\n\t\t\t\t: undefined,\n\t\ttypeof input?.sqliteQuerySearchExpansionRatio === 'number'\n\t\t\t? `expand ${(input.sqliteQuerySearchExpansionRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryBackfillCount === 'number'\n\t\t\t? `backfill ${input.sqliteQueryBackfillCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryBackfillLimitReached === 'boolean' &&\n\t\tinput.sqliteQueryBackfillLimitReached\n\t\t\t? 'backfill limit reached'\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryMinResultsSatisfied === 'boolean' &&\n\t\tinput.sqliteQueryMinResultsSatisfied\n\t\t\t? 'min satisfied'\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryReturnedCount === 'number'\n\t\t\t? `returned ${input.sqliteQueryReturnedCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryCandidateYieldRatio === 'number'\n\t\t\t? `yield ${(input.sqliteQueryCandidateYieldRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryTopKFillRatio === 'number'\n\t\t\t? `fill ${(input.sqliteQueryTopKFillRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\tinput?.sqliteQueryCandidateCoverage\n\t\t\t? `coverage ${input.sqliteQueryCandidateCoverage}`\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryUnderfilledTopK === 'boolean' &&\n\t\tinput.sqliteQueryUnderfilledTopK\n\t\t\t? 'underfilled topK'\n\t\t\t: undefined,\n\t\ttypeof input?.sqliteQueryCandidateBudgetExhausted === 'boolean' &&\n\t\tinput.sqliteQueryCandidateBudgetExhausted\n\t\t\t? 'budget exhausted'\n\t\t\t: undefined,\n\t\tplannerJudgment\n\t].filter((value): value is string => typeof value === 'string');\n\n\treturn parts.length > 0 ? parts.join(' · ') : 'none';\n};\n\nconst formatPostgresPlannerCueSummary = (input?: {\n\tpostgresQueryMode?: string;\n\tpostgresQueryPushdownMode?: string;\n\tpostgresQueryPushdownApplied?: boolean;\n\tpostgresQueryPushdownClauseCount?: number;\n\tpostgresQueryPushdownCoverageRatio?: number;\n\tpostgresQueryTotalFilterClauseCount?: number;\n\tpostgresQueryJsRemainderClauseCount?: number;\n\tpostgresQueryPlannerProfileUsed?: string;\n\tpostgresQueryMultiplierUsed?: number;\n\tpostgresQueryCandidateLimitUsed?: number;\n\tpostgresQueryMaxBackfillsUsed?: number;\n\tpostgresQueryMinResultsUsed?: number;\n\tpostgresQueryFillPolicyUsed?: string;\n\tpostgresQueryJsRemainderRatio?: number;\n\tpostgresQueryFilteredCandidates?: number;\n\tpostgresQueryInitialSearchK?: number;\n\tpostgresQueryFinalSearchK?: number;\n\tpostgresQuerySearchExpansionRatio?: number;\n\tpostgresQueryBackfillCount?: number;\n\tpostgresQueryBackfillLimitReached?: boolean;\n\tpostgresQueryMinResultsSatisfied?: boolean;\n\tpostgresQueryReturnedCount?: number;\n\tpostgresQueryCandidateYieldRatio?: number;\n\tpostgresQueryTopKFillRatio?: number;\n\tpostgresQueryUnderfilledTopK?: boolean;\n\tpostgresQueryCandidateBudgetExhausted?: boolean;\n\tpostgresQueryCandidateCoverage?: string;\n\tpostgresIndexType?: string;\n\tpostgresIndexName?: string;\n\tpostgresIndexPresent?: boolean;\n\tpostgresEstimatedRowCount?: number;\n\tpostgresTableBytes?: number;\n\tpostgresIndexBytes?: number;\n\tpostgresTotalBytes?: number;\n\tpostgresIndexStorageRatio?: number;\n}) => {\n\tconst plannerJudgment =\n\t\ttypeof input?.postgresQuerySearchExpansionRatio === 'number' &&\n\t\ttypeof input?.postgresQueryCandidateYieldRatio === 'number' &&\n\t\tinput.postgresQuerySearchExpansionRatio >= 2 &&\n\t\tinput.postgresQueryCandidateYieldRatio < 0.25\n\t\t\t? 'expensive backfill'\n\t\t\t: typeof input?.postgresQueryTopKFillRatio === 'number' &&\n\t\t\t\t typeof input?.postgresQueryCandidateYieldRatio === 'number' &&\n\t\t\t\t input.postgresQueryTopKFillRatio >= 1 &&\n\t\t\t\t input.postgresQueryCandidateYieldRatio >= 0.5\n\t\t\t\t? 'efficient fill'\n\t\t\t\t: input?.postgresQueryPushdownMode === 'full' &&\n\t\t\t\t\t typeof input?.postgresQueryPushdownCoverageRatio ===\n\t\t\t\t\t\t\t'number' &&\n\t\t\t\t\t input.postgresQueryPushdownCoverageRatio >= 1\n\t\t\t\t\t? 'full pushdown'\n\t\t\t\t\t: input?.postgresQueryPushdownMode === 'partial' &&\n\t\t\t\t\t\t typeof input?.postgresQueryJsRemainderRatio ===\n\t\t\t\t\t\t\t\t'number' &&\n\t\t\t\t\t\t input.postgresQueryJsRemainderRatio >= 0.5\n\t\t\t\t\t\t? 'heavy js remainder'\n\t\t\t\t\t\t: undefined;\n\tconst healthJudgment =\n\t\tinput?.postgresIndexPresent === false\n\t\t\t? 'index missing'\n\t\t\t: typeof input?.postgresIndexStorageRatio === 'number' &&\n\t\t\t\t input.postgresIndexStorageRatio >= 0.7\n\t\t\t\t? 'index-heavy storage'\n\t\t\t\t: typeof input?.postgresEstimatedRowCount === 'number' &&\n\t\t\t\t\t input.postgresEstimatedRowCount >= 1000 &&\n\t\t\t\t\t input.postgresIndexPresent === true\n\t\t\t\t\t? 'indexed larger corpus'\n\t\t\t\t\t: undefined;\n\n\tconst parts = [\n\t\tinput?.postgresQueryMode\n\t\t\t? `mode ${input.postgresQueryMode}`\n\t\t\t: undefined,\n\t\tinput?.postgresIndexType\n\t\t\t? `index ${input.postgresIndexType}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresIndexPresent === 'boolean'\n\t\t\t? input.postgresIndexPresent\n\t\t\t\t? 'index present'\n\t\t\t\t: 'index missing'\n\t\t\t: undefined,\n\t\ttypeof input?.postgresEstimatedRowCount === 'number'\n\t\t\t? `rows ${input.postgresEstimatedRowCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresTableBytes === 'number'\n\t\t\t? `table ${formatByteSizeLabel(input.postgresTableBytes)}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresIndexBytes === 'number'\n\t\t\t? `index ${formatByteSizeLabel(input.postgresIndexBytes)}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresIndexStorageRatio === 'number'\n\t\t\t? `index share ${(input.postgresIndexStorageRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\tinput?.postgresQueryPushdownMode\n\t\t\t? `pushdown ${input.postgresQueryPushdownMode}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryPushdownApplied === 'boolean'\n\t\t\t? input.postgresQueryPushdownApplied\n\t\t\t\t? 'pushdown on'\n\t\t\t\t: 'pushdown off'\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryPushdownClauseCount === 'number'\n\t\t\t? `clauses ${input.postgresQueryPushdownClauseCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryPushdownCoverageRatio === 'number'\n\t\t\t? `pushdown ${(input.postgresQueryPushdownCoverageRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryJsRemainderClauseCount === 'number'\n\t\t\t? `js remainder ${input.postgresQueryJsRemainderClauseCount}`\n\t\t\t: undefined,\n\t\tinput?.postgresQueryPlannerProfileUsed\n\t\t\t? `profile ${input.postgresQueryPlannerProfileUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryMultiplierUsed === 'number'\n\t\t\t? `x${input.postgresQueryMultiplierUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryCandidateLimitUsed === 'number'\n\t\t\t? `cap ${input.postgresQueryCandidateLimitUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryMaxBackfillsUsed === 'number'\n\t\t\t? `backfills ${input.postgresQueryMaxBackfillsUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryMinResultsUsed === 'number'\n\t\t\t? `min ${input.postgresQueryMinResultsUsed}`\n\t\t\t: undefined,\n\t\tinput?.postgresQueryFillPolicyUsed\n\t\t\t? `fill ${input.postgresQueryFillPolicyUsed}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryJsRemainderRatio === 'number'\n\t\t\t? `js ${(input.postgresQueryJsRemainderRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryTotalFilterClauseCount === 'number'\n\t\t\t? `total clauses ${input.postgresQueryTotalFilterClauseCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryFilteredCandidates === 'number'\n\t\t\t? `filtered ${input.postgresQueryFilteredCandidates}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryInitialSearchK === 'number' &&\n\t\ttypeof input?.postgresQueryFinalSearchK === 'number'\n\t\t\t? `searchK ${input.postgresQueryInitialSearchK}->${input.postgresQueryFinalSearchK}`\n\t\t\t: typeof input?.postgresQueryFinalSearchK === 'number'\n\t\t\t\t? `searchK ${input.postgresQueryFinalSearchK}`\n\t\t\t\t: undefined,\n\t\ttypeof input?.postgresQuerySearchExpansionRatio === 'number'\n\t\t\t? `expand ${(input.postgresQuerySearchExpansionRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryBackfillCount === 'number'\n\t\t\t? `backfill ${input.postgresQueryBackfillCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryBackfillLimitReached === 'boolean' &&\n\t\tinput.postgresQueryBackfillLimitReached\n\t\t\t? 'backfill limit reached'\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryMinResultsSatisfied === 'boolean' &&\n\t\tinput.postgresQueryMinResultsSatisfied\n\t\t\t? 'min satisfied'\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryReturnedCount === 'number'\n\t\t\t? `returned ${input.postgresQueryReturnedCount}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryCandidateYieldRatio === 'number'\n\t\t\t? `yield ${(input.postgresQueryCandidateYieldRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryTopKFillRatio === 'number'\n\t\t\t? `fill ${(input.postgresQueryTopKFillRatio * 100).toFixed(0)}%`\n\t\t\t: undefined,\n\t\tinput?.postgresQueryCandidateCoverage\n\t\t\t? `coverage ${input.postgresQueryCandidateCoverage}`\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryUnderfilledTopK === 'boolean' &&\n\t\tinput.postgresQueryUnderfilledTopK\n\t\t\t? 'underfilled topK'\n\t\t\t: undefined,\n\t\ttypeof input?.postgresQueryCandidateBudgetExhausted === 'boolean' &&\n\t\tinput.postgresQueryCandidateBudgetExhausted\n\t\t\t? 'budget exhausted'\n\t\t\t: undefined,\n\t\tplannerJudgment,\n\t\thealthJudgment\n\t].filter((value): value is string => typeof value === 'string');\n\n\treturn parts.length > 0 ? parts.join(' · ') : 'none';\n};\n\nconst formatComparisonSQLitePlannerCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst labels = Array.from(\n\t\tnew Set(\n\t\t\t(entry.caseTraceSnapshots ?? [])\n\t\t\t\t.map((snapshot) =>\n\t\t\t\t\tformatSQLitePlannerCueSummary({\n\t\t\t\t\t\tsqliteQueryBackfillCount:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryBackfillCount,\n\t\t\t\t\t\tsqliteQueryCandidateBudgetExhausted:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryCandidateBudgetExhausted,\n\t\t\t\t\t\tsqliteQueryCandidateCoverage:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryCandidateCoverage,\n\t\t\t\t\t\tsqliteQueryFilteredCandidates:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryFilteredCandidates,\n\t\t\t\t\t\tsqliteQueryFinalSearchK:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryFinalSearchK,\n\t\t\t\t\t\tsqliteQueryInitialSearchK:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryInitialSearchK,\n\t\t\t\t\t\tsqliteQuerySearchExpansionRatio:\n\t\t\t\t\t\t\tsnapshot.sqliteQuerySearchExpansionRatio,\n\t\t\t\t\t\tsqliteQueryJsRemainderClauseCount:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryJsRemainderClauseCount,\n\t\t\t\t\t\tsqliteQueryCandidateLimitUsed:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryCandidateLimitUsed,\n\t\t\t\t\t\tsqliteQueryMaxBackfillsUsed:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryMaxBackfillsUsed,\n\t\t\t\t\t\tsqliteQueryMinResultsUsed:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryMinResultsUsed,\n\t\t\t\t\t\tsqliteQueryFillPolicyUsed:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryFillPolicyUsed,\n\t\t\t\t\t\tsqliteQueryMode: snapshot.sqliteQueryMode,\n\t\t\t\t\t\tsqliteQueryPushdownApplied:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryPushdownApplied,\n\t\t\t\t\t\tsqliteQueryPushdownClauseCount:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryPushdownClauseCount,\n\t\t\t\t\t\tsqliteQueryPushdownCoverageRatio:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryPushdownCoverageRatio,\n\t\t\t\t\t\tsqliteQueryPushdownMode:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryPushdownMode,\n\t\t\t\t\t\tsqliteQueryTotalFilterClauseCount:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryTotalFilterClauseCount,\n\t\t\t\t\t\tsqliteQueryReturnedCount:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryReturnedCount,\n\t\t\t\t\t\tsqliteQueryBackfillLimitReached:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryBackfillLimitReached,\n\t\t\t\t\t\tsqliteQueryMinResultsSatisfied:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryMinResultsSatisfied,\n\t\t\t\t\t\tsqliteQueryCandidateYieldRatio:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryCandidateYieldRatio,\n\t\t\t\t\t\tsqliteQueryTopKFillRatio:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryTopKFillRatio,\n\t\t\t\t\t\tsqliteQueryJsRemainderRatio:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryJsRemainderRatio,\n\t\t\t\t\t\tsqliteQueryUnderfilledTopK:\n\t\t\t\t\t\t\tsnapshot.sqliteQueryUnderfilledTopK\n\t\t\t\t\t})\n\t\t\t\t)\n\t\t\t\t.filter(\n\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\ttypeof value === 'string' && value !== 'none'\n\t\t\t\t)\n\t\t)\n\t).slice(0, 3);\n\n\treturn labels.length > 0 ? labels.join(' · ') : 'none';\n};\n\nconst formatComparisonPostgresPlannerCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst labels = Array.from(\n\t\tnew Set(\n\t\t\t(entry.caseTraceSnapshots ?? [])\n\t\t\t\t.map((snapshot) =>\n\t\t\t\t\tformatPostgresPlannerCueSummary({\n\t\t\t\t\t\tpostgresQueryBackfillCount:\n\t\t\t\t\t\t\tsnapshot.postgresQueryBackfillCount,\n\t\t\t\t\t\tpostgresQueryCandidateBudgetExhausted:\n\t\t\t\t\t\t\tsnapshot.postgresQueryCandidateBudgetExhausted,\n\t\t\t\t\t\tpostgresQueryCandidateCoverage:\n\t\t\t\t\t\t\tsnapshot.postgresQueryCandidateCoverage,\n\t\t\t\t\t\tpostgresQueryFilteredCandidates:\n\t\t\t\t\t\t\tsnapshot.postgresQueryFilteredCandidates,\n\t\t\t\t\t\tpostgresQueryFinalSearchK:\n\t\t\t\t\t\t\tsnapshot.postgresQueryFinalSearchK,\n\t\t\t\t\t\tpostgresQueryInitialSearchK:\n\t\t\t\t\t\t\tsnapshot.postgresQueryInitialSearchK,\n\t\t\t\t\t\tpostgresQuerySearchExpansionRatio:\n\t\t\t\t\t\t\tsnapshot.postgresQuerySearchExpansionRatio,\n\t\t\t\t\t\tpostgresQueryJsRemainderClauseCount:\n\t\t\t\t\t\t\tsnapshot.postgresQueryJsRemainderClauseCount,\n\t\t\t\t\t\tpostgresQueryCandidateLimitUsed:\n\t\t\t\t\t\t\tsnapshot.postgresQueryCandidateLimitUsed,\n\t\t\t\t\t\tpostgresQueryMaxBackfillsUsed:\n\t\t\t\t\t\t\tsnapshot.postgresQueryMaxBackfillsUsed,\n\t\t\t\t\t\tpostgresQueryMinResultsUsed:\n\t\t\t\t\t\t\tsnapshot.postgresQueryMinResultsUsed,\n\t\t\t\t\t\tpostgresQueryFillPolicyUsed:\n\t\t\t\t\t\t\tsnapshot.postgresQueryFillPolicyUsed,\n\t\t\t\t\t\tpostgresQueryMultiplierUsed:\n\t\t\t\t\t\t\tsnapshot.postgresQueryMultiplierUsed,\n\t\t\t\t\t\tpostgresQueryMode: snapshot.postgresQueryMode,\n\t\t\t\t\t\tpostgresQueryPushdownApplied:\n\t\t\t\t\t\t\tsnapshot.postgresQueryPushdownApplied,\n\t\t\t\t\t\tpostgresQueryPushdownClauseCount:\n\t\t\t\t\t\t\tsnapshot.postgresQueryPushdownClauseCount,\n\t\t\t\t\t\tpostgresQueryPushdownCoverageRatio:\n\t\t\t\t\t\t\tsnapshot.postgresQueryPushdownCoverageRatio,\n\t\t\t\t\t\tpostgresQueryPushdownMode:\n\t\t\t\t\t\t\tsnapshot.postgresQueryPushdownMode,\n\t\t\t\t\t\tpostgresQueryTotalFilterClauseCount:\n\t\t\t\t\t\t\tsnapshot.postgresQueryTotalFilterClauseCount,\n\t\t\t\t\t\tpostgresQueryReturnedCount:\n\t\t\t\t\t\t\tsnapshot.postgresQueryReturnedCount,\n\t\t\t\t\t\tpostgresQueryBackfillLimitReached:\n\t\t\t\t\t\t\tsnapshot.postgresQueryBackfillLimitReached,\n\t\t\t\t\t\tpostgresQueryMinResultsSatisfied:\n\t\t\t\t\t\t\tsnapshot.postgresQueryMinResultsSatisfied,\n\t\t\t\t\t\tpostgresQueryCandidateYieldRatio:\n\t\t\t\t\t\t\tsnapshot.postgresQueryCandidateYieldRatio,\n\t\t\t\t\t\tpostgresQueryTopKFillRatio:\n\t\t\t\t\t\t\tsnapshot.postgresQueryTopKFillRatio,\n\t\t\t\t\t\tpostgresQueryJsRemainderRatio:\n\t\t\t\t\t\t\tsnapshot.postgresQueryJsRemainderRatio,\n\t\t\t\t\t\tpostgresEstimatedRowCount:\n\t\t\t\t\t\t\tsnapshot.postgresEstimatedRowCount,\n\t\t\t\t\t\tpostgresIndexBytes: snapshot.postgresIndexBytes,\n\t\t\t\t\t\tpostgresIndexName: snapshot.postgresIndexName,\n\t\t\t\t\t\tpostgresIndexPresent: snapshot.postgresIndexPresent,\n\t\t\t\t\t\tpostgresIndexStorageRatio:\n\t\t\t\t\t\t\tsnapshot.postgresIndexStorageRatio,\n\t\t\t\t\t\tpostgresIndexType: snapshot.postgresIndexType,\n\t\t\t\t\t\tpostgresTableBytes: snapshot.postgresTableBytes,\n\t\t\t\t\t\tpostgresTotalBytes: snapshot.postgresTotalBytes,\n\t\t\t\t\t\tpostgresQueryUnderfilledTopK:\n\t\t\t\t\t\t\tsnapshot.postgresQueryUnderfilledTopK\n\t\t\t\t\t})\n\t\t\t\t)\n\t\t\t\t.filter(\n\t\t\t\t\t(value): value is string =>\n\t\t\t\t\t\ttypeof value === 'string' && value !== 'none'\n\t\t\t\t)\n\t\t)\n\t).slice(0, 3);\n\n\treturn labels.length > 0 ? labels.join(' · ') : 'none';\n};\n\nconst formatComparisonLeadDrift = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tif (\n\t\t!leader?.caseTraceSnapshots?.length ||\n\t\t!entry.caseTraceSnapshots?.length\n\t) {\n\t\treturn 'none';\n\t}\n\n\tconst leaderCases = new Map(\n\t\tleader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot])\n\t);\n\n\tconst drift = entry.caseTraceSnapshots\n\t\t.map((snapshot) => {\n\t\t\tconst leaderSnapshot = leaderCases.get(snapshot.caseId);\n\t\t\tconst currentLead = buildComparisonCaseLeadLabel(snapshot);\n\t\t\tconst leaderLead = buildComparisonCaseLeadLabel(leaderSnapshot);\n\t\t\tif (!currentLead || !leaderLead || currentLead === leaderLead) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${snapshot.label ?? snapshot.caseId} ${leaderLead}→${currentLead}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn drift.length > 0 ? drift.join(' · ') : 'none';\n};\n\nconst formatComparisonLeadMediaDrift = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tif (\n\t\t!leader?.caseTraceSnapshots?.length ||\n\t\t!entry.caseTraceSnapshots?.length\n\t) {\n\t\treturn 'none';\n\t}\n\n\tconst leaderCases = new Map(\n\t\tleader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot])\n\t);\n\n\tconst drift = entry.caseTraceSnapshots\n\t\t.map((snapshot) => {\n\t\t\tconst leaderSnapshot = leaderCases.get(snapshot.caseId);\n\t\t\tconst currentMediaCues = formatLeadMediaCueSummary({\n\t\t\t\tleadSpeakerCue: snapshot.leadSpeakerCue,\n\t\t\t\tleadSpeakerAttributionCue: snapshot.leadSpeakerAttributionCue,\n\t\t\t\tleadChannelCue: snapshot.leadChannelCue,\n\t\t\t\tleadChannelAttributionCue: snapshot.leadChannelAttributionCue,\n\t\t\t\tleadContinuityCue: snapshot.leadContinuityCue\n\t\t\t});\n\t\t\tconst leaderMediaCues = formatLeadMediaCueSummary({\n\t\t\t\tleadSpeakerCue: leaderSnapshot?.leadSpeakerCue,\n\t\t\t\tleadSpeakerAttributionCue:\n\t\t\t\t\tleaderSnapshot?.leadSpeakerAttributionCue,\n\t\t\t\tleadChannelCue: leaderSnapshot?.leadChannelCue,\n\t\t\t\tleadChannelAttributionCue:\n\t\t\t\t\tleaderSnapshot?.leadChannelAttributionCue,\n\t\t\t\tleadContinuityCue: leaderSnapshot?.leadContinuityCue\n\t\t\t});\n\t\t\tif (\n\t\t\t\tcurrentMediaCues === 'none' ||\n\t\t\t\tleaderMediaCues === 'none' ||\n\t\t\t\tcurrentMediaCues === leaderMediaCues\n\t\t\t) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${snapshot.label ?? snapshot.caseId} ${leaderMediaCues}→${currentMediaCues}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn drift.length > 0 ? drift.join(' · ') : 'none';\n};\n\nconst formatComparisonSQLitePlannerDrift = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tif (\n\t\t!leader?.caseTraceSnapshots?.length ||\n\t\t!entry.caseTraceSnapshots?.length\n\t) {\n\t\treturn 'none';\n\t}\n\n\tconst leaderCases = new Map(\n\t\tleader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot])\n\t);\n\n\tconst drift = entry.caseTraceSnapshots\n\t\t.map((snapshot) => {\n\t\t\tconst leaderSnapshot = leaderCases.get(snapshot.caseId);\n\t\t\tconst currentPlanner = formatSQLitePlannerCueSummary(snapshot);\n\t\t\tconst leaderPlanner = formatSQLitePlannerCueSummary(leaderSnapshot);\n\t\t\tif (\n\t\t\t\tcurrentPlanner === 'none' ||\n\t\t\t\tleaderPlanner === 'none' ||\n\t\t\t\tcurrentPlanner === leaderPlanner\n\t\t\t) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${snapshot.label ?? snapshot.caseId} ${leaderPlanner}→${currentPlanner}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn drift.length > 0 ? drift.join(' · ') : 'none';\n};\n\nconst formatComparisonPostgresPlannerDrift = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tif (\n\t\t!leader?.caseTraceSnapshots?.length ||\n\t\t!entry.caseTraceSnapshots?.length\n\t) {\n\t\treturn 'none';\n\t}\n\n\tconst leaderCases = new Map(\n\t\tleader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot])\n\t);\n\n\tconst drift = entry.caseTraceSnapshots\n\t\t.map((snapshot) => {\n\t\t\tconst leaderSnapshot = leaderCases.get(snapshot.caseId);\n\t\t\tconst currentPlanner = formatPostgresPlannerCueSummary(snapshot);\n\t\t\tconst leaderPlanner =\n\t\t\t\tformatPostgresPlannerCueSummary(leaderSnapshot);\n\t\t\tif (\n\t\t\t\tcurrentPlanner === 'none' ||\n\t\t\t\tleaderPlanner === 'none' ||\n\t\t\t\tcurrentPlanner === leaderPlanner\n\t\t\t) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${snapshot.label ?? snapshot.caseId} ${leaderPlanner}→${currentPlanner}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn drift.length > 0 ? drift.join(' · ') : 'none';\n};\n\nconst formatComparisonRoutingCueSummary = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst trace = entry.traceSummary;\n\tif (!trace) {\n\t\treturn 'none';\n\t}\n\n\tconst parts = [\n\t\t`modes ${formatTraceModes(trace.modes)}`,\n\t\t`balance ${formatSourceBalanceStrategies(trace.sourceBalanceStrategies)}`,\n\t\t`rewrites ${formatTraceRatio(trace.transformedCases, trace.totalCases)}`,\n\t\t`variants ${formatTraceRatio(trace.variantCases, trace.totalCases)}`\n\t].filter((value) => !value.endsWith('n/a'));\n\n\treturn parts.length > 0 ? parts.join(' · ') : 'none';\n};\n\nconst formatComparisonRoutingDrift = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n) => {\n\tconst trace = entry.traceSummary;\n\tconst leaderTrace = leader?.traceSummary;\n\tif (!trace || !leaderTrace || entry === leader) {\n\t\treturn 'none';\n\t}\n\n\tconst deltas: string[] = [];\n\tconst currentModes = formatTraceModes(trace.modes);\n\tconst previousModes = formatTraceModes(leaderTrace.modes);\n\tif (currentModes !== previousModes) {\n\t\tdeltas.push(`modes ${previousModes}→${currentModes}`);\n\t}\n\n\tconst currentBalance = formatSourceBalanceStrategies(\n\t\ttrace.sourceBalanceStrategies\n\t);\n\tconst previousBalance = formatSourceBalanceStrategies(\n\t\tleaderTrace.sourceBalanceStrategies\n\t);\n\tif (currentBalance !== previousBalance) {\n\t\tdeltas.push(`balance ${previousBalance}→${currentBalance}`);\n\t}\n\n\tconst transformedDelta =\n\t\ttrace.transformedCases - leaderTrace.transformedCases;\n\tif (transformedDelta !== 0) {\n\t\tdeltas.push(`rewrites ${formatTraceCountDelta(transformedDelta)}`);\n\t}\n\n\tconst variantDelta = trace.variantCases - leaderTrace.variantCases;\n\tif (variantDelta !== 0) {\n\t\tdeltas.push(`variants ${formatTraceCountDelta(variantDelta)}`);\n\t}\n\n\treturn deltas.length > 0 ? deltas.slice(0, 3).join(' · ') : 'none';\n};\n\nconst formatHistoryRoutingShift = (history?: RAGEvaluationHistory) => {\n\tconst delta = history?.diff?.traceSummaryDelta;\n\tif (!delta) {\n\t\treturn 'none';\n\t}\n\n\tconst shifts: string[] = [];\n\tif (delta.modesChanged) {\n\t\tshifts.push('modes changed');\n\t}\n\tif (delta.sourceBalanceStrategiesChanged) {\n\t\tshifts.push('balance changed');\n\t}\n\tif (delta.transformedCases !== 0) {\n\t\tshifts.push(\n\t\t\t`rewrites ${formatTraceCountDelta(delta.transformedCases)}`\n\t\t);\n\t}\n\tif (delta.variantCases !== 0) {\n\t\tshifts.push(`variants ${formatTraceCountDelta(delta.variantCases)}`);\n\t}\n\n\treturn shifts.length > 0 ? shifts.join(' · ') : 'none';\n};\n\nconst formatHistorySQLitePlannerShift = (history?: RAGEvaluationHistory) => {\n\tif (!history?.caseTraceSnapshots.length) {\n\t\treturn 'none';\n\t}\n\n\tconst shifts = history.caseTraceSnapshots\n\t\t.map((entry) => {\n\t\t\tconst previousPlanner = formatSQLitePlannerCueSummary({\n\t\t\t\tsqliteQueryBackfillCount:\n\t\t\t\t\tentry.previousSqliteQueryBackfillCount,\n\t\t\t\tsqliteQueryCandidateBudgetExhausted:\n\t\t\t\t\tentry.previousSqliteQueryCandidateBudgetExhausted,\n\t\t\t\tsqliteQueryCandidateCoverage:\n\t\t\t\t\tentry.previousSqliteQueryCandidateCoverage,\n\t\t\t\tsqliteQueryFilteredCandidates:\n\t\t\t\t\tentry.previousSqliteQueryFilteredCandidates,\n\t\t\t\tsqliteQueryFinalSearchK: entry.previousSqliteQueryFinalSearchK,\n\t\t\t\tsqliteQueryInitialSearchK:\n\t\t\t\t\tentry.previousSqliteQueryInitialSearchK,\n\t\t\t\tsqliteQuerySearchExpansionRatio:\n\t\t\t\t\tentry.previousSqliteQuerySearchExpansionRatio,\n\t\t\t\tsqliteQueryJsRemainderClauseCount:\n\t\t\t\t\tentry.previousSqliteQueryJsRemainderClauseCount,\n\t\t\t\tsqliteQueryCandidateLimitUsed:\n\t\t\t\t\tentry.previousSqliteQueryCandidateLimitUsed,\n\t\t\t\tsqliteQueryMaxBackfillsUsed:\n\t\t\t\t\tentry.previousSqliteQueryMaxBackfillsUsed,\n\t\t\t\tsqliteQueryMinResultsUsed:\n\t\t\t\t\tentry.previousSqliteQueryMinResultsUsed,\n\t\t\t\tsqliteQueryFillPolicyUsed:\n\t\t\t\t\tentry.previousSqliteQueryFillPolicyUsed,\n\t\t\t\tsqliteQueryMode: entry.previousSqliteQueryMode,\n\t\t\t\tsqliteQueryPushdownApplied:\n\t\t\t\t\tentry.previousSqliteQueryPushdownApplied,\n\t\t\t\tsqliteQueryPushdownClauseCount:\n\t\t\t\t\tentry.previousSqliteQueryPushdownClauseCount,\n\t\t\t\tsqliteQueryPushdownCoverageRatio:\n\t\t\t\t\tentry.previousSqliteQueryPushdownCoverageRatio,\n\t\t\t\tsqliteQueryPushdownMode: entry.previousSqliteQueryPushdownMode,\n\t\t\t\tsqliteQueryTotalFilterClauseCount:\n\t\t\t\t\tentry.previousSqliteQueryTotalFilterClauseCount,\n\t\t\t\tsqliteQueryJsRemainderRatio:\n\t\t\t\t\tentry.previousSqliteQueryJsRemainderRatio,\n\t\t\t\tsqliteQueryReturnedCount:\n\t\t\t\t\tentry.previousSqliteQueryReturnedCount,\n\t\t\t\tsqliteQueryBackfillLimitReached:\n\t\t\t\t\tentry.previousSqliteQueryBackfillLimitReached,\n\t\t\t\tsqliteQueryMinResultsSatisfied:\n\t\t\t\t\tentry.previousSqliteQueryMinResultsSatisfied,\n\t\t\t\tsqliteQueryCandidateYieldRatio:\n\t\t\t\t\tentry.previousSqliteQueryCandidateYieldRatio,\n\t\t\t\tsqliteQueryTopKFillRatio:\n\t\t\t\t\tentry.previousSqliteQueryTopKFillRatio,\n\t\t\t\tsqliteQueryUnderfilledTopK:\n\t\t\t\t\tentry.previousSqliteQueryUnderfilledTopK\n\t\t\t});\n\t\t\tconst currentPlanner = formatSQLitePlannerCueSummary(entry);\n\n\t\t\tif (\n\t\t\t\tpreviousPlanner === 'none' ||\n\t\t\t\tcurrentPlanner === 'none' ||\n\t\t\t\tpreviousPlanner === currentPlanner\n\t\t\t) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${entry.label ?? entry.caseId} ${previousPlanner}→${currentPlanner}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn shifts.length > 0 ? shifts.join(' · ') : 'none';\n};\n\nconst formatHistoryPostgresPlannerShift = (history?: RAGEvaluationHistory) => {\n\tif (!history?.caseTraceSnapshots.length) {\n\t\treturn 'none';\n\t}\n\n\tconst shifts = history.caseTraceSnapshots\n\t\t.map((entry) => {\n\t\t\tconst previousPlanner = formatPostgresPlannerCueSummary({\n\t\t\t\tpostgresQueryBackfillCount:\n\t\t\t\t\tentry.previousPostgresQueryBackfillCount,\n\t\t\t\tpostgresQueryCandidateBudgetExhausted:\n\t\t\t\t\tentry.previousPostgresQueryCandidateBudgetExhausted,\n\t\t\t\tpostgresQueryCandidateCoverage:\n\t\t\t\t\tentry.previousPostgresQueryCandidateCoverage,\n\t\t\t\tpostgresQueryFilteredCandidates:\n\t\t\t\t\tentry.previousPostgresQueryFilteredCandidates,\n\t\t\t\tpostgresQueryFinalSearchK:\n\t\t\t\t\tentry.previousPostgresQueryFinalSearchK,\n\t\t\t\tpostgresQueryInitialSearchK:\n\t\t\t\t\tentry.previousPostgresQueryInitialSearchK,\n\t\t\t\tpostgresQuerySearchExpansionRatio:\n\t\t\t\t\tentry.previousPostgresQuerySearchExpansionRatio,\n\t\t\t\tpostgresQueryJsRemainderClauseCount:\n\t\t\t\t\tentry.previousPostgresQueryJsRemainderClauseCount,\n\t\t\t\tpostgresQueryCandidateLimitUsed:\n\t\t\t\t\tentry.previousPostgresQueryCandidateLimitUsed,\n\t\t\t\tpostgresQueryMaxBackfillsUsed:\n\t\t\t\t\tentry.previousPostgresQueryMaxBackfillsUsed,\n\t\t\t\tpostgresQueryMinResultsUsed:\n\t\t\t\t\tentry.previousPostgresQueryMinResultsUsed,\n\t\t\t\tpostgresQueryFillPolicyUsed:\n\t\t\t\t\tentry.previousPostgresQueryFillPolicyUsed,\n\t\t\t\tpostgresQueryMultiplierUsed:\n\t\t\t\t\tentry.previousPostgresQueryMultiplierUsed,\n\t\t\t\tpostgresQueryMode: entry.previousPostgresQueryMode,\n\t\t\t\tpostgresQueryPushdownApplied:\n\t\t\t\t\tentry.previousPostgresQueryPushdownApplied,\n\t\t\t\tpostgresQueryPushdownClauseCount:\n\t\t\t\t\tentry.previousPostgresQueryPushdownClauseCount,\n\t\t\t\tpostgresQueryPushdownCoverageRatio:\n\t\t\t\t\tentry.previousPostgresQueryPushdownCoverageRatio,\n\t\t\t\tpostgresQueryPushdownMode:\n\t\t\t\t\tentry.previousPostgresQueryPushdownMode,\n\t\t\t\tpostgresQueryTotalFilterClauseCount:\n\t\t\t\t\tentry.previousPostgresQueryTotalFilterClauseCount,\n\t\t\t\tpostgresQueryJsRemainderRatio:\n\t\t\t\t\tentry.previousPostgresQueryJsRemainderRatio,\n\t\t\t\tpostgresQueryReturnedCount:\n\t\t\t\t\tentry.previousPostgresQueryReturnedCount,\n\t\t\t\tpostgresQueryBackfillLimitReached:\n\t\t\t\t\tentry.previousPostgresQueryBackfillLimitReached,\n\t\t\t\tpostgresQueryMinResultsSatisfied:\n\t\t\t\t\tentry.previousPostgresQueryMinResultsSatisfied,\n\t\t\t\tpostgresQueryCandidateYieldRatio:\n\t\t\t\t\tentry.previousPostgresQueryCandidateYieldRatio,\n\t\t\t\tpostgresQueryTopKFillRatio:\n\t\t\t\t\tentry.previousPostgresQueryTopKFillRatio,\n\t\t\t\tpostgresQueryUnderfilledTopK:\n\t\t\t\t\tentry.previousPostgresQueryUnderfilledTopK\n\t\t\t});\n\t\t\tconst currentPlanner = formatPostgresPlannerCueSummary(entry);\n\t\t\tif (\n\t\t\t\tpreviousPlanner === 'none' ||\n\t\t\t\tcurrentPlanner === 'none' ||\n\t\t\t\tpreviousPlanner === currentPlanner\n\t\t\t) {\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\treturn `${entry.label ?? entry.caseId} ${previousPlanner}→${currentPlanner}`;\n\t\t})\n\t\t.filter((value): value is string => typeof value === 'string')\n\t\t.slice(0, 3);\n\n\treturn shifts.length > 0 ? shifts.join(' · ') : 'none';\n};\n\nconst formatTraceLeadChanges = (\n\tchanges?: Array<{\n\t\tcaseId: string;\n\t\tlabel?: string;\n\t\tpreviousLead?: string;\n\t\tcurrentLead: string;\n\t}>\n) =>\n\tchanges && changes.length > 0\n\t\t? changes\n\t\t\t\t.slice(0, 3)\n\t\t\t\t.map((entry) => {\n\t\t\t\t\tconst label = entry.label ?? entry.caseId;\n\t\t\t\t\tconst previousLead = entry.previousLead ?? 'n/a';\n\t\t\t\t\treturn `${label} ${previousLead}→${entry.currentLead}`;\n\t\t\t\t})\n\t\t\t\t.join(' · ')\n\t\t: 'none';\n\nconst formatGroundingHistoryCaseLabels = (\n\tcases: RAGAnswerGroundingEvaluationCaseDiff[]\n) =>\n\tcases.length > 0\n\t\t? cases.map((entry) => entry.label ?? entry.caseId).join(', ')\n\t\t: 'none';\n\nconst formatRerankerComparisonHeadline = (entry: RAGRerankerComparisonEntry) =>\n\t[\n\t\tentry.label,\n\t\t`passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n\t\t`f1 ${entry.response.summary.averageF1.toFixed(3)}`,\n\t\t`latency ${entry.response.summary.averageLatencyMs.toFixed(1)}ms`\n\t].join(' · ');\n\nconst formatRetrievalComparisonHeadline = (\n\tentry: RAGRetrievalComparisonEntry\n) =>\n\t[\n\t\tentry.label,\n\t\t`mode ${entry.retrievalMode}`,\n\t\t`passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n\t\t`f1 ${entry.response.summary.averageF1.toFixed(3)}`,\n\t\t`latency ${entry.response.summary.averageLatencyMs.toFixed(1)}ms`\n\t].join(' · ');\n\nconst formatTraceModes = (modes: RAGHybridRetrievalMode[]) =>\n\tmodes.length > 0 ? modes.join(' / ') : 'n/a';\n\nconst formatSourceBalanceStrategies = (\n\tstrategies: RAGSourceBalanceStrategy[]\n) => (strategies.length > 0 ? strategies.join(' / ') : 'n/a');\n\nconst formatTraceStageSummary = (\n\tstageCounts: Partial<\n\t\tRecord<RAGRetrievalTrace['steps'][number]['stage'], number>\n\t>\n) => {\n\tconst topStages = Object.entries(stageCounts)\n\t\t.sort((left, right) => right[1] - left[1])\n\t\t.slice(0, 3);\n\n\treturn topStages.length > 0\n\t\t? topStages.map(([stage, count]) => `${stage} ${count}`).join(' · ')\n\t\t: 'n/a';\n};\n\nconst formatTraceRatio = (count: number, total: number) => `${count}/${total}`;\n\nconst formatTraceCountDelta = (value: number) =>\n\t`${value >= 0 ? '+' : ''}${value}`;\n\nconst buildComparisonOverviewPresentation = <\n\tTEntry extends {\n\t\tlabel: string;\n\t\tresponse: {\n\t\t\tpassingRate: number;\n\t\t\tsummary: {\n\t\t\t\taverageF1: number;\n\t\t\t\taverageLatencyMs: number;\n\t\t\t};\n\t\t};\n\t}\n>(input: {\n\tentries: TEntry[];\n\tsummary: {\n\t\tbestByPassingRate?: string;\n\t\tbestByAverageF1?: string;\n\t\tfastest?: string;\n\t\tbestByPresentationTitleCueCases?: string;\n\t\tbestByPresentationBodyCueCases?: string;\n\t\tbestByPresentationNotesCueCases?: string;\n\t\tbestBySpreadsheetSheetCueCases?: string;\n\t\tbestBySpreadsheetTableCueCases?: string;\n\t\tbestBySpreadsheetColumnCueCases?: string;\n\t\tbestByMultivectorCollapsedCases?: string;\n\t\tbestByMultivectorLexicalHitCases?: string;\n\t\tbestByMultivectorVectorHitCases?: string;\n\t\tbestByEvidenceReconcileCases?: string;\n\t\tbestByOfficeEvidenceReconcileCases?: string;\n\t\tbestByOfficeParagraphEvidenceReconcileCases?: string;\n\t\tbestByOfficeListEvidenceReconcileCases?: string;\n\t\tbestByOfficeTableEvidenceReconcileCases?: string;\n\t\tbestByPDFEvidenceReconcileCases?: string;\n\t\tbestByLowestRuntimeCandidateBudgetExhaustedCases?: string;\n\t\tbestByLowestRuntimeUnderfilledTopKCases?: string;\n\t};\n\tresolveLabel: (id?: string) => string;\n\tresolveEntry: (id?: string) => TEntry | undefined;\n}): RAGComparisonOverviewPresentation => {\n\tconst winnerLabel = input.resolveLabel(input.summary.bestByPassingRate);\n\tconst winnerEntry = input.resolveEntry(input.summary.bestByPassingRate);\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{\n\t\t\tlabel: 'Best passing rate',\n\t\t\tvalue: input.resolveLabel(input.summary.bestByPassingRate)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Best average F1',\n\t\t\tvalue: input.resolveLabel(input.summary.bestByAverageF1)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Fastest',\n\t\t\tvalue: input.resolveLabel(input.summary.fastest)\n\t\t}\n\t];\n\n\tif (input.summary.bestByMultivectorCollapsedCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best multivector collapse',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByMultivectorCollapsedCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByMultivectorLexicalHitCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best multivector lexical hits',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByMultivectorLexicalHitCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByMultivectorVectorHitCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best multivector vector hits',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByMultivectorVectorHitCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best evidence reconcile',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByPresentationTitleCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation title cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByPresentationTitleCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByPresentationBodyCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation body cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByPresentationBodyCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByPresentationNotesCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation notes cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByPresentationNotesCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestBySpreadsheetSheetCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet sheet cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestBySpreadsheetSheetCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestBySpreadsheetTableCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet table cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestBySpreadsheetTableCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestBySpreadsheetColumnCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet column cue',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestBySpreadsheetColumnCueCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByOfficeEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office structure reconcile (docx/xlsx/pptx)',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByOfficeEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByOfficeParagraphEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office narrative reconcile',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByOfficeParagraphEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByOfficeListEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office checklist reconcile',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByOfficeListEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByOfficeTableEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office table reconcile',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByOfficeTableEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByPDFEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best PDF native evidence',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByPDFEvidenceReconcileCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases) {\n\t\trows.push({\n\t\t\tlabel: 'Lowest runtime budget exhaustion',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases\n\t\t\t)\n\t\t});\n\t}\n\tif (input.summary.bestByLowestRuntimeUnderfilledTopKCases) {\n\t\trows.push({\n\t\t\tlabel: 'Lowest runtime underfilled TopK',\n\t\t\tvalue: input.resolveLabel(\n\t\t\t\tinput.summary.bestByLowestRuntimeUnderfilledTopKCases\n\t\t\t)\n\t\t});\n\t}\n\n\treturn {\n\t\trows,\n\t\twinnerLabel,\n\t\tsummary: winnerEntry\n\t\t\t? `passing ${formatEvaluationPassingRate(winnerEntry.response.passingRate)} · f1 ${winnerEntry.response.summary.averageF1.toFixed(3)} · latency ${winnerEntry.response.summary.averageLatencyMs.toFixed(1)}ms`\n\t\t\t: 'Stored benchmark comparison'\n\t};\n};\n\nexport const buildRAGComparisonTraceSummaryRows = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n): RAGLabelValueRow[] => {\n\tconst trace = entry.traceSummary;\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{\n\t\t\tlabel: 'Lead cues',\n\t\t\tvalue: formatComparisonLeadCueSummary(entry)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Lead media cues',\n\t\t\tvalue: formatComparisonLeadMediaCueSummary(entry)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Presentation cues',\n\t\t\tvalue: formatComparisonPresentationCueSummary(entry)\n\t\t},\n\t\t{\n\t\t\tlabel: 'SQLite planner cues',\n\t\t\tvalue: formatComparisonSQLitePlannerCueSummary(entry)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Postgres planner cues',\n\t\t\tvalue: formatComparisonPostgresPlannerCueSummary(entry)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Routing cues',\n\t\t\tvalue: formatComparisonRoutingCueSummary(entry)\n\t\t}\n\t];\n\n\tif (!trace) {\n\t\trows.unshift({ label: 'Trace', value: 'Unavailable' });\n\t\treturn rows;\n\t}\n\n\trows.push(\n\t\t{ label: 'Modes', value: formatTraceModes(trace.modes) },\n\t\t{\n\t\t\tlabel: 'Balance',\n\t\t\tvalue: formatSourceBalanceStrategies(trace.sourceBalanceStrategies)\n\t\t},\n\t\t{ label: 'Avg final', value: trace.averageFinalCount.toFixed(1) },\n\t\t{ label: 'Avg vector', value: trace.averageVectorCount.toFixed(1) },\n\t\t{ label: 'Avg lexical', value: trace.averageLexicalCount.toFixed(1) },\n\t\t{\n\t\t\tlabel: 'Balanced',\n\t\t\tvalue: formatTraceRatio(trace.balancedCases, trace.totalCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Round robin',\n\t\t\tvalue: formatTraceRatio(trace.roundRobinCases, trace.totalCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Transforms',\n\t\t\tvalue: formatTraceRatio(trace.transformedCases, trace.totalCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Variants',\n\t\t\tvalue: formatTraceRatio(trace.variantCases, trace.totalCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Multivector',\n\t\t\tvalue: `${formatTraceRatio(\n\t\t\t\ttrace.multiVectorCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · collapse ${formatTraceRatio(\n\t\t\t\ttrace.multiVectorCollapsedCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · lexical ${formatTraceRatio(\n\t\t\t\ttrace.multiVectorLexicalHitCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · vector ${formatTraceRatio(\n\t\t\t\ttrace.multiVectorVectorHitCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)}`\n\t\t},\n\t\t{\n\t\t\tlabel: 'Runtime',\n\t\t\tvalue: `budget ${formatTraceRatio(\n\t\t\t\ttrace.runtimeCandidateBudgetExhaustedCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · underfilled ${formatTraceRatio(\n\t\t\t\ttrace.runtimeUnderfilledTopKCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)}`\n\t\t},\n\t\t{\n\t\t\tlabel: 'Evidence reconcile (office/pdf)',\n\t\t\tvalue: `all ${formatTraceRatio(\n\t\t\t\ttrace.stageCounts.evidence_reconcile ?? 0,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · office structure ${formatTraceRatio(\n\t\t\t\ttrace.officeEvidenceReconcileCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · narrative ${formatTraceRatio(\n\t\t\t\ttrace.officeParagraphEvidenceReconcileCases ?? 0,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · checklist ${formatTraceRatio(\n\t\t\t\ttrace.officeListEvidenceReconcileCases ?? 0,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · table ${formatTraceRatio(\n\t\t\t\ttrace.officeTableEvidenceReconcileCases ?? 0,\n\t\t\t\ttrace.totalCases\n\t\t\t)} · pdf native ${formatTraceRatio(\n\t\t\t\ttrace.pdfEvidenceReconcileCases,\n\t\t\t\ttrace.totalCases\n\t\t\t)}`\n\t\t},\n\t\t{\n\t\t\tlabel: 'TopK',\n\t\t\tvalue: `${trace.averageCandidateTopK.toFixed(\n\t\t\t\t1\n\t\t\t)} / ${trace.averageLexicalTopK.toFixed(1)}`\n\t\t},\n\t\t{\n\t\t\tlabel: 'Stages',\n\t\t\tvalue: formatTraceStageSummary(trace.stageCounts)\n\t\t}\n\t);\n\n\treturn rows;\n};\n\nexport const buildRAGComparisonTraceDiffRows = (\n\tentry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n\tleader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry\n): RAGLabelValueRow[] => {\n\tconst trace = entry.traceSummary;\n\tconst leadDriftRow = {\n\t\tlabel: 'Lead drift vs leader',\n\t\tvalue: formatComparisonLeadDrift(entry, leader)\n\t} satisfies RAGLabelValueRow;\n\tconst leadMediaDriftRow = {\n\t\tlabel: 'Lead media shift vs leader',\n\t\tvalue: formatComparisonLeadMediaDrift(entry, leader)\n\t} satisfies RAGLabelValueRow;\n\tconst sqlitePlannerDriftRow = {\n\t\tlabel: 'SQLite planner shift vs leader',\n\t\tvalue: formatComparisonSQLitePlannerDrift(entry, leader)\n\t} satisfies RAGLabelValueRow;\n\tconst postgresPlannerDriftRow = {\n\t\tlabel: 'Postgres planner shift vs leader',\n\t\tvalue: formatComparisonPostgresPlannerDrift(entry, leader)\n\t} satisfies RAGLabelValueRow;\n\tconst routingDriftRow = {\n\t\tlabel: 'Routing shift vs leader',\n\t\tvalue: formatComparisonRoutingDrift(entry, leader)\n\t} satisfies RAGLabelValueRow;\n\n\tif (!trace) {\n\t\treturn [\n\t\t\t{ label: 'Trace', value: 'Unavailable for comparison' },\n\t\t\tleadDriftRow,\n\t\t\tleadMediaDriftRow,\n\t\t\tsqlitePlannerDriftRow,\n\t\t\tpostgresPlannerDriftRow,\n\t\t\troutingDriftRow\n\t\t];\n\t}\n\n\tconst leaderTrace = leader?.traceSummary;\n\tif (!leaderTrace) {\n\t\treturn [\n\t\t\t{ label: 'Baseline', value: 'Leader trace unavailable' },\n\t\t\tleadDriftRow,\n\t\t\tleadMediaDriftRow,\n\t\t\tsqlitePlannerDriftRow,\n\t\t\tpostgresPlannerDriftRow,\n\t\t\troutingDriftRow\n\t\t];\n\t}\n\n\tif (entry === leader) {\n\t\treturn [\n\t\t\t{ label: 'Baseline', value: 'Leader strategy' },\n\t\t\tleadDriftRow,\n\t\t\tleadMediaDriftRow,\n\t\t\tsqlitePlannerDriftRow,\n\t\t\tpostgresPlannerDriftRow,\n\t\t\troutingDriftRow\n\t\t];\n\t}\n\n\tconst stageDelta = Object.keys({\n\t\t...leaderTrace.stageCounts,\n\t\t...trace.stageCounts\n\t})\n\t\t.map((stage) => {\n\t\t\tconst typedStage = stage as RAGRetrievalTraceStep['stage'];\n\t\t\tconst delta =\n\t\t\t\t(trace.stageCounts[typedStage] ?? 0) -\n\t\t\t\t(leaderTrace.stageCounts[typedStage] ?? 0);\n\t\t\treturn delta === 0\n\t\t\t\t? null\n\t\t\t\t: `${typedStage} ${formatTraceCountDelta(delta)}`;\n\t\t})\n\t\t.filter((value): value is string => Boolean(value))\n\t\t.slice(0, 3)\n\t\t.join(' · ');\n\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{ label: 'Baseline', value: leader.label }\n\t];\n\n\tif (formatTraceModes(trace.modes) !== formatTraceModes(leaderTrace.modes)) {\n\t\trows.push({\n\t\t\tlabel: 'Modes vs leader',\n\t\t\tvalue: `${formatTraceModes(trace.modes)} vs ${formatTraceModes(\n\t\t\t\tleaderTrace.modes\n\t\t\t)}`\n\t\t});\n\t}\n\n\tif (\n\t\tformatSourceBalanceStrategies(trace.sourceBalanceStrategies) !==\n\t\tformatSourceBalanceStrategies(leaderTrace.sourceBalanceStrategies)\n\t) {\n\t\trows.push({\n\t\t\tlabel: 'Balance vs leader',\n\t\t\tvalue: `${formatSourceBalanceStrategies(\n\t\t\t\ttrace.sourceBalanceStrategies\n\t\t\t)} vs ${formatSourceBalanceStrategies(\n\t\t\t\tleaderTrace.sourceBalanceStrategies\n\t\t\t)}`\n\t\t});\n\t}\n\n\trows.push(\n\t\tleadDriftRow,\n\t\tleadMediaDriftRow,\n\t\tsqlitePlannerDriftRow,\n\t\tpostgresPlannerDriftRow,\n\t\troutingDriftRow\n\t);\n\n\trows.push(\n\t\t{\n\t\t\tlabel: 'Final delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\ttrace.averageFinalCount - leaderTrace.averageFinalCount,\n\t\t\t\t1\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Vector delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\ttrace.averageVectorCount - leaderTrace.averageVectorCount,\n\t\t\t\t1\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Lexical delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\ttrace.averageLexicalCount - leaderTrace.averageLexicalCount,\n\t\t\t\t1\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Transform delta',\n\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\ttrace.transformedCases - leaderTrace.transformedCases\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Balanced delta',\n\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\ttrace.balancedCases - leaderTrace.balancedCases\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Round robin delta',\n\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\ttrace.roundRobinCases - leaderTrace.roundRobinCases\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Runtime budget delta',\n\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\ttrace.runtimeCandidateBudgetExhaustedCases -\n\t\t\t\t\tleaderTrace.runtimeCandidateBudgetExhaustedCases\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Runtime underfilled delta',\n\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\ttrace.runtimeUnderfilledTopKCases -\n\t\t\t\t\tleaderTrace.runtimeUnderfilledTopKCases\n\t\t\t)\n\t\t}\n\t);\n\n\tif (stageDelta) {\n\t\trows.push({ label: 'Stage delta', value: stageDelta });\n\t}\n\n\treturn rows;\n};\n\nexport const buildRAGRetrievalComparisonPresentations = (\n\tcomparison: RAGRetrievalComparison\n): RAGComparisonPresentation[] => {\n\tconst leader = comparison.entries[0];\n\treturn comparison.entries.map((entry) => ({\n\t\tdiffLabel: leader?.label ?? 'Leader',\n\t\tdiffRows: buildRAGComparisonTraceDiffRows(entry, leader),\n\t\tsummary: formatRetrievalComparisonHeadline(entry),\n\t\tid: entry.retrievalId,\n\t\tlabel: entry.label,\n\t\ttraceSummaryRows: buildRAGComparisonTraceSummaryRows(entry)\n\t}));\n};\n\nexport const buildRAGRetrievalComparisonOverviewPresentation = (\n\tcomparison: RAGRetrievalComparison\n): RAGComparisonOverviewPresentation =>\n\tbuildComparisonOverviewPresentation({\n\t\tentries: comparison.entries,\n\t\tresolveEntry: (id?: string) =>\n\t\t\tcomparison.entries.find((entry) => entry.retrievalId === id),\n\t\tresolveLabel: (id?: string) =>\n\t\t\tcomparison.entries.find((entry) => entry.retrievalId === id)\n\t\t\t\t?.label ??\n\t\t\tid ??\n\t\t\t'n/a',\n\t\tsummary: comparison.summary\n\t});\n\nexport const buildRAGRerankerComparisonPresentations = (\n\tcomparison: RAGRerankerComparison\n): RAGComparisonPresentation[] => {\n\tconst leader = comparison.entries[0];\n\treturn comparison.entries.map((entry) => ({\n\t\tdiffLabel: leader?.label ?? 'Leader',\n\t\tdiffRows: buildRAGComparisonTraceDiffRows(entry, leader),\n\t\tsummary: formatRerankerComparisonHeadline(entry),\n\t\tid: entry.rerankerId,\n\t\tlabel: entry.label,\n\t\ttraceSummaryRows: buildRAGComparisonTraceSummaryRows(entry)\n\t}));\n};\n\nexport const buildRAGRerankerComparisonOverviewPresentation = (\n\tcomparison: RAGRerankerComparison\n): RAGComparisonOverviewPresentation =>\n\tbuildComparisonOverviewPresentation({\n\t\tentries: comparison.entries,\n\t\tresolveEntry: (id?: string) =>\n\t\t\tcomparison.entries.find((entry) => entry.rerankerId === id),\n\t\tresolveLabel: (id?: string) =>\n\t\t\tcomparison.entries.find((entry) => entry.rerankerId === id)\n\t\t\t\t?.label ??\n\t\t\tid ??\n\t\t\t'n/a',\n\t\tsummary: comparison.summary\n\t});\n\nexport const buildRAGGroundingProviderPresentations = (\n\tentries: Array<{\n\t\tproviderKey: string;\n\t\tlabel: string;\n\t\telapsedMs: number;\n\t\tresponse: RAGAnswerGroundingEvaluationResponse;\n\t}>\n): RAGGroundingProviderPresentation[] =>\n\tentries.map((entry) => ({\n\t\tsummary: [\n\t\t\tentry.label,\n\t\t\t`passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n\t\t\t`citation f1 ${entry.response.summary.averageCitationF1.toFixed(3)}`,\n\t\t\t`resolved ${formatEvaluationPassingRate(\n\t\t\t\tentry.response.summary.averageResolvedCitationRate\n\t\t\t)}`,\n\t\t\t`latency ${entry.elapsedMs.toFixed(1)}ms`\n\t\t].join(' · '),\n\t\tid: entry.providerKey,\n\t\tlabel: entry.label\n\t}));\n\nexport const buildRAGGroundingProviderOverviewPresentation = (input: {\n\tentries: Array<{\n\t\tproviderKey: string;\n\t\tlabel: string;\n\t\telapsedMs: number;\n\t\tresponse: RAGAnswerGroundingEvaluationResponse;\n\t}>;\n\tsummary: {\n\t\tbestByPassingRate?: string;\n\t\tbestByAverageCitationF1?: string;\n\t\tbestByResolvedCitationRate?: string;\n\t\tfastest?: string;\n\t};\n}): RAGGroundingProviderOverviewPresentation => {\n\tconst resolveLabel = (key?: string) =>\n\t\tinput.entries.find((entry) => entry.providerKey === key)?.label ??\n\t\tkey ??\n\t\t'n/a';\n\tconst winnerLabel = resolveLabel(input.summary.bestByPassingRate);\n\tconst winnerEntry = input.entries.find(\n\t\t(entry) => entry.providerKey === input.summary.bestByPassingRate\n\t);\n\n\treturn {\n\t\trows: [\n\t\t\t{\n\t\t\t\tlabel: 'Best passing rate',\n\t\t\t\tvalue: resolveLabel(input.summary.bestByPassingRate)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Best citation F1',\n\t\t\t\tvalue: resolveLabel(input.summary.bestByAverageCitationF1)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Best resolved citations',\n\t\t\t\tvalue: resolveLabel(input.summary.bestByResolvedCitationRate)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Fastest',\n\t\t\t\tvalue: resolveLabel(input.summary.fastest)\n\t\t\t}\n\t\t],\n\t\twinnerLabel,\n\t\tsummary: winnerEntry\n\t\t\t? `passing ${formatEvaluationPassingRate(winnerEntry.response.passingRate)} · citation f1 ${winnerEntry.response.summary.averageCitationF1.toFixed(3)} · resolved ${formatEvaluationPassingRate(winnerEntry.response.summary.averageResolvedCitationRate)}`\n\t\t\t: 'Stored workflow evaluation'\n\t};\n};\n\nexport const buildRAGRetrievalOverviewPresentation = (\n\tcomparison: RAGRetrievalComparison\n): RAGQualityOverviewPresentation => ({\n\trows: buildRAGRetrievalComparisonOverviewPresentation(comparison).rows\n});\n\nexport const buildRAGRerankerOverviewPresentation = (\n\tcomparison: RAGRerankerComparison\n): RAGQualityOverviewPresentation => ({\n\trows: buildRAGRerankerComparisonOverviewPresentation(comparison).rows\n});\n\nexport const buildRAGGroundingOverviewPresentation = (input: {\n\tgroundingEvaluation: RAGAnswerGroundingEvaluationResponse;\n\tgroundingProviderOverview?: RAGGroundingProviderOverviewPresentation | null;\n}): RAGGroundingOverviewPresentation => ({\n\trows: [\n\t\t{\n\t\t\tlabel: 'Grounding',\n\t\t\tvalue: formatGroundingHistorySummaryValue(input.groundingEvaluation)\n\t\t},\n\t\t...(input.groundingProviderOverview?.rows ?? [\n\t\t\t{\n\t\t\t\tlabel: 'Grounding providers',\n\t\t\t\tvalue: 'Configure an AI provider to compare grounded answers.'\n\t\t\t}\n\t\t])\n\t]\n});\n\nexport const buildRAGQualityOverviewPresentation = (input: {\n\tretrievalComparison: RAGRetrievalComparison;\n\trerankerComparison: RAGRerankerComparison;\n\tgroundingEvaluation: RAGAnswerGroundingEvaluationResponse;\n\tgroundingProviderOverview?: RAGGroundingProviderOverviewPresentation | null;\n}): RAGQualityOverviewPresentation => ({\n\trows: [\n\t\t...buildRAGRetrievalOverviewPresentation(input.retrievalComparison)\n\t\t\t.rows,\n\t\t...buildRAGRerankerOverviewPresentation(input.rerankerComparison).rows,\n\t\t...buildRAGGroundingOverviewPresentation({\n\t\t\tgroundingEvaluation: input.groundingEvaluation,\n\t\t\tgroundingProviderOverview: input.groundingProviderOverview\n\t\t}).rows\n\t]\n});\n\nexport const buildRAGGroundingProviderCaseComparisonPresentations = (\n\tcomparisons: Array<{\n\t\tcaseId: string;\n\t\tlabel: string;\n\t\tentries: Array<{\n\t\t\tproviderKey: string;\n\t\t\tlabel: string;\n\t\t\tstatus: string;\n\t\t\tcoverage: string;\n\t\t\tcitationF1: number;\n\t\t\tresolvedCitationRate: number;\n\t\t\tmatchedIds: string[];\n\t\t\tmissingIds: string[];\n\t\t\textraIds: string[];\n\t\t\tanswerExcerpt: string;\n\t\t}>;\n\t\tsummary: {\n\t\t\tbestByStatus?: string;\n\t\t\tbestByCitationF1?: string;\n\t\t\tbestByResolvedCitationRate?: string;\n\t\t};\n\t}>\n): RAGGroundingProviderCaseComparisonPresentation[] =>\n\tcomparisons.map((comparison) => {\n\t\tconst resolveLabel = (key?: string) =>\n\t\t\tcomparison.entries.find((entry) => entry.providerKey === key)\n\t\t\t\t?.label ??\n\t\t\tkey ??\n\t\t\t'n/a';\n\n\t\treturn {\n\t\t\tcaseId: comparison.caseId,\n\t\t\tlabel: comparison.label,\n\t\t\trows: [\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Best grounded',\n\t\t\t\t\tvalue: resolveLabel(comparison.summary.bestByStatus)\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Best citation F1',\n\t\t\t\t\tvalue: resolveLabel(comparison.summary.bestByCitationF1)\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Best resolved citations',\n\t\t\t\t\tvalue: resolveLabel(\n\t\t\t\t\t\tcomparison.summary.bestByResolvedCitationRate\n\t\t\t\t\t)\n\t\t\t\t},\n\t\t\t\t...comparison.entries.map((entry) => ({\n\t\t\t\t\tlabel: entry.label,\n\t\t\t\t\tvalue: [\n\t\t\t\t\t\tentry.status.toUpperCase(),\n\t\t\t\t\t\t`coverage ${entry.coverage}`,\n\t\t\t\t\t\t`f1 ${entry.citationF1.toFixed(3)}`,\n\t\t\t\t\t\t`resolved ${formatEvaluationPassingRate(\n\t\t\t\t\t\t\tentry.resolvedCitationRate\n\t\t\t\t\t\t)}`,\n\t\t\t\t\t\t`matched ${entry.matchedIds.join(', ') || 'none'}`,\n\t\t\t\t\t\t`missing ${entry.missingIds.join(', ') || 'none'}`,\n\t\t\t\t\t\t`extra ${entry.extraIds.join(', ') || 'none'}`,\n\t\t\t\t\t\t`answer ${entry.answerExcerpt || 'n/a'}`\n\t\t\t\t\t].join(' · ')\n\t\t\t\t}))\n\t\t\t],\n\t\t\tsummary: [\n\t\t\t\t`Best grounded: ${resolveLabel(comparison.summary.bestByStatus)}`,\n\t\t\t\t`Best citation F1: ${resolveLabel(\n\t\t\t\t\tcomparison.summary.bestByCitationF1\n\t\t\t\t)}`,\n\t\t\t\t`Best resolved citations: ${resolveLabel(\n\t\t\t\t\tcomparison.summary.bestByResolvedCitationRate\n\t\t\t\t)}`\n\t\t\t].join(' · ')\n\t\t};\n\t});\n\nexport const buildRAGEvaluationHistoryRows = (\n\thistory?: RAGEvaluationHistory\n): RAGLabelValueRow[] => {\n\tif (!history?.latestRun) {\n\t\treturn [\n\t\t\t{ label: 'History', value: 'No persisted benchmark runs yet.' }\n\t\t];\n\t}\n\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{ label: 'Runs recorded', value: String(history.runs.length) },\n\t\t{\n\t\t\tlabel: 'Latest',\n\t\t\tvalue: `${history.latestRun.label} · ${formatEvaluationSummary(\n\t\t\t\thistory.latestRun.response\n\t\t\t)}`\n\t\t}\n\t];\n\n\tif (history.latestRun.traceSummary) {\n\t\trows.push({\n\t\t\tlabel: 'Latest trace',\n\t\t\tvalue: `${formatTraceModes(\n\t\t\t\thistory.latestRun.traceSummary.modes\n\t\t\t)} · balance ${formatSourceBalanceStrategies(\n\t\t\t\thistory.latestRun.traceSummary.sourceBalanceStrategies\n\t\t\t)} · final ${history.latestRun.traceSummary.averageFinalCount.toFixed(\n\t\t\t\t1\n\t\t\t)} · vector ${history.latestRun.traceSummary.averageVectorCount.toFixed(\n\t\t\t\t1\n\t\t\t)} · lexical ${history.latestRun.traceSummary.averageLexicalCount.toFixed(\n\t\t\t\t1\n\t\t\t)}`\n\t\t});\n\t}\n\n\tif (history.previousRun) {\n\t\trows.push({\n\t\t\tlabel: 'Previous',\n\t\t\tvalue: `${history.previousRun.label} · ${formatEvaluationSummary(\n\t\t\t\thistory.previousRun.response\n\t\t\t)}`\n\t\t});\n\t}\n\n\tif (!history.diff) {\n\t\trows.push({\n\t\t\tlabel: 'History diff',\n\t\t\tvalue: 'Run the benchmark again to diff regressions over time.'\n\t\t});\n\t\treturn rows;\n\t}\n\n\trows.push(\n\t\t{\n\t\t\tlabel: 'Passing delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\thistory.diff.summaryDelta.passingRate,\n\t\t\t\t1,\n\t\t\t\t'%'\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Average F1 delta',\n\t\t\tvalue: formatSignedDelta(history.diff.summaryDelta.averageF1, 3)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Latency delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\thistory.diff.summaryDelta.averageLatencyMs,\n\t\t\t\t1,\n\t\t\t\t'ms'\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Improved',\n\t\t\tvalue: formatHistoryCaseLabels(history.diff.improvedCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Regressed',\n\t\t\tvalue: formatHistoryCaseLabels(history.diff.regressedCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Lead drift',\n\t\t\tvalue: formatTraceLeadChanges(history.diff.traceLeadChanges)\n\t\t},\n\t\t{\n\t\t\tlabel: 'SQLite planner shift',\n\t\t\tvalue: formatHistorySQLitePlannerShift(history)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Postgres planner shift',\n\t\t\tvalue: formatHistoryPostgresPlannerShift(history)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Trace routing shift',\n\t\t\tvalue: formatHistoryRoutingShift(history)\n\t\t}\n\t);\n\n\tif (history.previousRun) {\n\t\tconst currentEntityView = buildRAGEvaluationEntityQualityView(\n\t\t\thistory.latestRun.response\n\t\t);\n\t\tconst previousEntityView = buildRAGEvaluationEntityQualityView(\n\t\t\thistory.previousRun.response\n\t\t);\n\t\trows.push(\n\t\t\t{\n\t\t\t\tlabel: 'Source regression hotspots',\n\t\t\t\tvalue: formatEntityRegressionHotspots(\n\t\t\t\t\tcurrentEntityView.bySource,\n\t\t\t\t\tpreviousEntityView.bySource,\n\t\t\t\t\t(entry) => entry.averageF1,\n\t\t\t\t\t'f1'\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Document regression hotspots',\n\t\t\t\tvalue: formatEntityRegressionHotspots(\n\t\t\t\t\tcurrentEntityView.byDocument,\n\t\t\t\t\tpreviousEntityView.byDocument,\n\t\t\t\t\t(entry) => entry.averageF1,\n\t\t\t\t\t'f1'\n\t\t\t\t)\n\t\t\t}\n\t\t);\n\t}\n\n\tif (history.diff.traceSummaryDelta) {\n\t\trows.push(\n\t\t\t{\n\t\t\t\tlabel: 'Trace mode shift',\n\t\t\t\tvalue: history.diff.traceSummaryDelta.modesChanged\n\t\t\t\t\t? 'changed'\n\t\t\t\t\t: 'stable'\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace balance shift',\n\t\t\t\tvalue: history.diff.traceSummaryDelta\n\t\t\t\t\t.sourceBalanceStrategiesChanged\n\t\t\t\t\t? 'changed'\n\t\t\t\t\t: 'stable'\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace final delta',\n\t\t\t\tvalue: formatSignedDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.averageFinalCount,\n\t\t\t\t\t1\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace vector delta',\n\t\t\t\tvalue: formatSignedDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.averageVectorCount,\n\t\t\t\t\t1\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace lexical delta',\n\t\t\t\tvalue: formatSignedDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.averageLexicalCount,\n\t\t\t\t\t1\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace balanced delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.balancedCases\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace round robin delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.roundRobinCases\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace transform delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.transformedCases\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Trace variant delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta.variantCases\n\t\t\t\t)\n\t\t\t}\n\t\t);\n\n\t\tconst evidenceReconcileDelta =\n\t\t\thistory.diff.traceSummaryDelta.stageCounts?.evidence_reconcile;\n\t\tif (typeof evidenceReconcileDelta === 'number') {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace evidence reconcile delta (all)',\n\t\t\t\tvalue: formatTraceCountDelta(evidenceReconcileDelta)\n\t\t\t});\n\t\t}\n\t\tif (\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeEvidenceReconcileCasesDelta === 'number'\n\t\t) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace office structure evidence reconcile delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t.officeEvidenceReconcileCasesDelta\n\t\t\t\t)\n\t\t\t});\n\t\t}\n\t\tif (\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeParagraphEvidenceReconcileCasesDelta === 'number'\n\t\t) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace office narrative evidence reconcile delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t.officeParagraphEvidenceReconcileCasesDelta\n\t\t\t\t)\n\t\t\t});\n\t\t}\n\t\tif (\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeListEvidenceReconcileCasesDelta === 'number'\n\t\t) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace office checklist evidence reconcile delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t.officeListEvidenceReconcileCasesDelta\n\t\t\t\t)\n\t\t\t});\n\t\t}\n\t\tif (\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeTableEvidenceReconcileCasesDelta === 'number'\n\t\t) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace office table evidence reconcile delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t.officeTableEvidenceReconcileCasesDelta\n\t\t\t\t)\n\t\t\t});\n\t\t}\n\t\tconst officeReconcileDeltas = [\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeParagraphEvidenceReconcileCasesDelta === 'number'\n\t\t\t\t? `narrative=${formatTraceCountDelta(\n\t\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t\t.officeParagraphEvidenceReconcileCasesDelta\n\t\t\t\t\t)}`\n\t\t\t\t: null,\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeListEvidenceReconcileCasesDelta === 'number'\n\t\t\t\t? `checklist=${formatTraceCountDelta(\n\t\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t\t.officeListEvidenceReconcileCasesDelta\n\t\t\t\t\t)}`\n\t\t\t\t: null,\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.officeTableEvidenceReconcileCasesDelta === 'number'\n\t\t\t\t? `table=${formatTraceCountDelta(\n\t\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t\t.officeTableEvidenceReconcileCasesDelta\n\t\t\t\t\t)}`\n\t\t\t\t: null\n\t\t].filter((value): value is string => Boolean(value));\n\t\tif (officeReconcileDeltas.length > 0) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace office reconcile deltas',\n\t\t\t\tvalue: officeReconcileDeltas.join(', ')\n\t\t\t});\n\t\t}\n\t\tif (\n\t\t\ttypeof history.diff.traceSummaryDelta\n\t\t\t\t.pdfEvidenceReconcileCasesDelta === 'number'\n\t\t) {\n\t\t\trows.push({\n\t\t\t\tlabel: 'Trace PDF native evidence reconcile delta',\n\t\t\t\tvalue: formatTraceCountDelta(\n\t\t\t\t\thistory.diff.traceSummaryDelta\n\t\t\t\t\t\t.pdfEvidenceReconcileCasesDelta\n\t\t\t\t)\n\t\t\t});\n\t\t}\n\n\t\tconst stageDelta = Object.entries(\n\t\t\thistory.diff.traceSummaryDelta.stageCounts ?? {}\n\t\t)\n\t\t\t.map(([stage, count]) => `${stage} ${formatTraceCountDelta(count)}`)\n\t\t\t.join(', ');\n\n\t\tif (stageDelta) {\n\t\t\trows.push({ label: 'Trace stage delta', value: stageDelta });\n\t\t}\n\t}\n\n\tif (history.caseTraceSnapshots.length > 0) {\n\t\tconst changedCases = history.caseTraceSnapshots.filter(\n\t\t\t(entry) => entry.traceChange === 'changed'\n\t\t);\n\t\trows.push({\n\t\t\tlabel: 'Trace drift cases',\n\t\t\tvalue:\n\t\t\t\tchangedCases.length > 0\n\t\t\t\t\t? changedCases\n\t\t\t\t\t\t\t.map((entry) => entry.label ?? entry.caseId)\n\t\t\t\t\t\t\t.slice(0, 4)\n\t\t\t\t\t\t\t.join(', ')\n\t\t\t\t\t: 'none'\n\t\t});\n\t\trows.push({\n\t\t\tlabel: 'Lead media cues',\n\t\t\tvalue:\n\t\t\t\tArray.from(\n\t\t\t\t\tnew Set(\n\t\t\t\t\t\thistory.caseTraceSnapshots\n\t\t\t\t\t\t\t.map((entry) =>\n\t\t\t\t\t\t\t\tformatLeadMediaCueSummary({\n\t\t\t\t\t\t\t\t\tleadChannelAttributionCue:\n\t\t\t\t\t\t\t\t\t\tentry.leadChannelAttributionCue,\n\t\t\t\t\t\t\t\t\tleadChannelCue: entry.leadChannelCue,\n\t\t\t\t\t\t\t\t\tleadContinuityCue: entry.leadContinuityCue,\n\t\t\t\t\t\t\t\t\tleadSpeakerAttributionCue:\n\t\t\t\t\t\t\t\t\t\tentry.leadSpeakerAttributionCue,\n\t\t\t\t\t\t\t\t\tleadSpeakerCue: entry.leadSpeakerCue\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t.filter((value) => value !== 'none')\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\t\t.slice(0, 3)\n\t\t\t\t\t.join(' · ') || 'none'\n\t\t});\n\t\trows.push({\n\t\t\tlabel: 'Presentation cues',\n\t\t\tvalue:\n\t\t\t\tArray.from(\n\t\t\t\t\tnew Set(\n\t\t\t\t\t\thistory.caseTraceSnapshots\n\t\t\t\t\t\t\t.map((entry) =>\n\t\t\t\t\t\t\t\tformatLeadPresentationCue(\n\t\t\t\t\t\t\t\t\tentry.leadPresentationCue\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t.filter((value) => value !== 'none')\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\t\t.slice(0, 3)\n\t\t\t\t\t.join(' / ') || 'none'\n\t\t});\n\t}\n\n\treturn rows;\n};\n\nexport const buildRAGEvaluationCaseTracePresentations = (\n\thistory?: RAGEvaluationHistory\n): RAGEvaluationCaseTracePresentation[] => {\n\tif (!history?.caseTraceSnapshots.length) {\n\t\treturn [];\n\t}\n\n\treturn history.caseTraceSnapshots.map((entry) => {\n\t\tconst label = entry.label ?? entry.caseId;\n\t\tconst currentMode = entry.traceMode ?? 'no-trace';\n\t\tconst previousMode = entry.previousTraceMode ?? 'n/a';\n\t\tconst currentBalance = entry.sourceBalanceStrategy ?? 'cap';\n\t\tconst previousBalance = entry.previousSourceBalanceStrategy ?? 'n/a';\n\t\tconst currentVariants =\n\t\t\tentry.variantQueries.length > 0\n\t\t\t\t? entry.variantQueries.join(', ')\n\t\t\t\t: 'none';\n\t\tconst previousVariants =\n\t\t\tentry.previousVariantQueries.length > 0\n\t\t\t\t? entry.previousVariantQueries.join(', ')\n\t\t\t\t: 'none';\n\t\tconst currentStages =\n\t\t\tObject.keys(entry.stageCounts).length > 0\n\t\t\t\t? Object.entries(entry.stageCounts)\n\t\t\t\t\t\t.map(([stage, count]) => `${stage} ${count}`)\n\t\t\t\t\t\t.join(', ')\n\t\t\t\t: 'none';\n\t\tconst previousStages =\n\t\t\tObject.keys(entry.previousStageCounts).length > 0\n\t\t\t\t? Object.entries(entry.previousStageCounts)\n\t\t\t\t\t\t.map(([stage, count]) => `${stage} ${count}`)\n\t\t\t\t\t\t.join(', ')\n\t\t\t\t: 'none';\n\t\tconst currentLeadContext = entry.topContextLabel ?? 'n/a';\n\t\tconst previousLeadContext = entry.previousTopContextLabel ?? 'n/a';\n\t\tconst currentLeadLocation = entry.topLocatorLabel ?? 'n/a';\n\t\tconst previousLeadLocation = entry.previousTopLocatorLabel ?? 'n/a';\n\t\tconst currentBoundary = entry.sourceAwareChunkReasonLabel ?? 'n/a';\n\t\tconst previousBoundary =\n\t\t\tentry.previousSourceAwareChunkReasonLabel ?? 'n/a';\n\t\tconst currentScope = entry.sourceAwareUnitScopeLabel ?? 'n/a';\n\t\tconst previousScope = entry.previousSourceAwareUnitScopeLabel ?? 'n/a';\n\t\tconst currentMediaCues = formatLeadMediaCueSummary({\n\t\t\tleadChannelAttributionCue: entry.leadChannelAttributionCue,\n\t\t\tleadChannelCue: entry.leadChannelCue,\n\t\t\tleadContinuityCue: entry.leadContinuityCue,\n\t\t\tleadSpeakerAttributionCue: entry.leadSpeakerAttributionCue,\n\t\t\tleadSpeakerCue: entry.leadSpeakerCue\n\t\t});\n\t\tconst previousMediaCues = formatLeadMediaCueSummary({\n\t\t\tleadChannelAttributionCue: entry.previousLeadChannelAttributionCue,\n\t\t\tleadChannelCue: entry.previousLeadChannelCue,\n\t\t\tleadContinuityCue: entry.previousLeadContinuityCue,\n\t\t\tleadSpeakerAttributionCue: entry.previousLeadSpeakerAttributionCue,\n\t\t\tleadSpeakerCue: entry.previousLeadSpeakerCue\n\t\t});\n\t\tconst currentPresentationCue = formatLeadPresentationCue(\n\t\t\tentry.leadPresentationCue\n\t\t);\n\t\tconst previousPresentationCue = formatLeadPresentationCue(\n\t\t\tentry.previousLeadPresentationCue\n\t\t);\n\t\tconst leadSummary =\n\t\t\tentry.topLocatorLabel ??\n\t\t\tentry.topContextLabel ??\n\t\t\tentry.sourceAwareUnitScopeLabel ??\n\t\t\t'n/a';\n\t\tconst previousLeadSummary =\n\t\t\tentry.previousTopLocatorLabel ??\n\t\t\tentry.previousTopContextLabel ??\n\t\t\tentry.previousSourceAwareUnitScopeLabel ??\n\t\t\t'n/a';\n\n\t\treturn {\n\t\t\tcaseId: entry.caseId,\n\t\t\tlabel,\n\t\t\tsummary: `${entry.traceChange} · ${previousMode}→${currentMode} · ${previousBalance}→${currentBalance} · lead ${previousLeadSummary}→${leadSummary} · final ${\n\t\t\t\tentry.previousFinalCount ?? 0\n\t\t\t}→${entry.finalCount}`,\n\t\t\ttraceChange: entry.traceChange,\n\t\t\trows: [\n\t\t\t\t{ label: 'Query', value: entry.query },\n\t\t\t\t{ label: 'Trace change', value: entry.traceChange },\n\t\t\t\t{ label: 'Mode', value: `${previousMode}→${currentMode}` },\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Balance',\n\t\t\t\t\tvalue: `${previousBalance}→${currentBalance}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Transformed query',\n\t\t\t\t\tvalue: `${\n\t\t\t\t\t\tentry.previousTransformedQuery?.trim() || 'n/a'\n\t\t\t\t\t}→${entry.transformedQuery?.trim() || 'n/a'}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Final',\n\t\t\t\t\tvalue: `${entry.previousFinalCount ?? 0}→${entry.finalCount}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Vector',\n\t\t\t\t\tvalue: `${entry.previousVectorCount ?? 0}→${entry.vectorCount}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lexical',\n\t\t\t\t\tvalue: `${entry.previousLexicalCount ?? 0}→${entry.lexicalCount}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Candidate topK',\n\t\t\t\t\tvalue: `${entry.previousCandidateTopK ?? 0}→${entry.candidateTopK}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lexical topK',\n\t\t\t\t\tvalue: `${entry.previousLexicalTopK ?? 0}→${entry.lexicalTopK}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Variants',\n\t\t\t\t\tvalue: `${previousVariants}→${currentVariants}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lead context',\n\t\t\t\t\tvalue: `${previousLeadContext}→${currentLeadContext}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lead location',\n\t\t\t\t\tvalue: `${previousLeadLocation}→${currentLeadLocation}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Chunk boundary',\n\t\t\t\t\tvalue: `${previousBoundary}→${currentBoundary}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Source-aware scope',\n\t\t\t\t\tvalue: `${previousScope}→${currentScope}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lead media cues',\n\t\t\t\t\tvalue: `${previousMediaCues}→${currentMediaCues}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Lead presentation cues',\n\t\t\t\t\tvalue: `${previousPresentationCue}→${currentPresentationCue}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Stages',\n\t\t\t\t\tvalue: `${previousStages}→${currentStages}`\n\t\t\t\t},\n\t\t\t\t{ label: 'Status', value: entry.status }\n\t\t\t]\n\t\t};\n\t});\n};\n\nexport const buildRAGEvaluationHistoryPresentation = (\n\thistory?: RAGEvaluationHistory\n): RAGEvaluationHistoryPresentation => ({\n\tcaseTraces: buildRAGEvaluationCaseTracePresentations(history),\n\trows: buildRAGEvaluationHistoryRows(history),\n\tsummary: history?.latestRun\n\t\t? history.latestRun.label\n\t\t: 'No persisted benchmark runs yet.'\n});\n\nexport const buildRAGEvaluationSuiteSnapshotRows = (\n\thistory?: RAGEvaluationSuiteSnapshotHistory\n): RAGLabelValueRow[] => {\n\tif (!history?.latestSnapshot) {\n\t\treturn [\n\t\t\t{ label: 'Suite snapshots', value: 'No saved suite snapshots yet.' }\n\t\t];\n\t}\n\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{\n\t\t\tlabel: 'Snapshots recorded',\n\t\t\tvalue: String(history.snapshots.length)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Latest snapshot',\n\t\t\tvalue: `v${history.latestSnapshot.version} · ${history.latestSnapshot.caseCount} cases`\n\t\t}\n\t];\n\n\tif (history.previousSnapshot) {\n\t\trows.push({\n\t\t\tlabel: 'Previous snapshot',\n\t\t\tvalue: `v${history.previousSnapshot.version} · ${history.previousSnapshot.caseCount} cases`\n\t\t});\n\t}\n\n\tif (!history.diff) {\n\t\trows.push({\n\t\t\tlabel: 'Snapshot diff',\n\t\t\tvalue: 'Save another suite snapshot to compare dataset changes.'\n\t\t});\n\t\treturn rows;\n\t}\n\n\trows.push(\n\t\t{\n\t\t\tlabel: 'Case count change',\n\t\t\tvalue: formatSignedDelta(history.diff.caseCountDelta)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Added cases',\n\t\t\tvalue:\n\t\t\t\thistory.diff.addedCaseIds.length > 0\n\t\t\t\t\t? history.diff.addedCaseIds.join(', ')\n\t\t\t\t\t: 'none'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Removed cases',\n\t\t\tvalue:\n\t\t\t\thistory.diff.removedCaseIds.length > 0\n\t\t\t\t\t? history.diff.removedCaseIds.join(', ')\n\t\t\t\t\t: 'none'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Changed cases',\n\t\t\tvalue:\n\t\t\t\thistory.diff.changedCaseIds.length > 0\n\t\t\t\t\t? history.diff.changedCaseIds.join(', ')\n\t\t\t\t\t: 'none'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Order changed',\n\t\t\tvalue: history.diff.orderChanged ? 'changed' : 'stable'\n\t\t}\n\t);\n\n\treturn rows;\n};\n\nexport const buildRAGEvaluationSuiteSnapshotPresentations = (\n\thistory?: RAGEvaluationSuiteSnapshotHistory\n): RAGEvaluationSuiteSnapshotPresentation[] =>\n\t(history?.snapshots ?? []).map((snapshot) => ({\n\t\tid: snapshot.id,\n\t\tlabel: snapshot.label ?? snapshot.suiteId,\n\t\trows: [\n\t\t\t{ label: 'Version', value: `v${snapshot.version}` },\n\t\t\t{ label: 'Created', value: formatDateLabel(snapshot.createdAt) },\n\t\t\t{ label: 'Cases', value: String(snapshot.caseCount) },\n\t\t\t{\n\t\t\t\tlabel: 'Case ids',\n\t\t\t\tvalue:\n\t\t\t\t\tsnapshot.suite.input.cases\n\t\t\t\t\t\t.map((entry) => entry.id)\n\t\t\t\t\t\t.join(', ') || 'none'\n\t\t\t}\n\t\t],\n\t\tsummary: `v${snapshot.version} · ${snapshot.caseCount} cases`,\n\t\tversion: snapshot.version\n\t}));\n\nexport const buildRAGEvaluationSuiteSnapshotHistoryPresentation = (\n\thistory?: RAGEvaluationSuiteSnapshotHistory\n): RAGEvaluationSuiteSnapshotHistoryPresentation => ({\n\trows: buildRAGEvaluationSuiteSnapshotRows(history),\n\tsnapshots: buildRAGEvaluationSuiteSnapshotPresentations(history),\n\tsummary: history?.latestSnapshot\n\t\t? `v${history.latestSnapshot.version}`\n\t\t: 'No saved suite snapshots yet.'\n});\n\nconst isRuntimeGateReason = (reason: string) =>\n\t/runtime|candidate-budget|underfilled/i.test(reason);\n\nconst getFixtureVariantsFromRunTags = (tags?: string[]): string[] =>\n\t(tags ?? [])\n\t\t.filter((tag) => tag.startsWith('fixture:'))\n\t\t.map((tag) => tag.slice('fixture:'.length))\n\t\t.filter(\n\t\t\t(tag, index, all) => tag.length > 0 && all.indexOf(tag) === index\n\t\t);\n\nconst buildRAGRetrievalReleaseHistoryRunPresentation = (\n\trun: RAGRetrievalComparisonRun\n): RAGRetrievalReleaseHistoryRunPresentation => {\n\tconst runtimeGateReasons = (\n\t\trun.decisionSummary?.gate?.reasons ??\n\t\trun.releaseVerdict?.gate?.reasons ??\n\t\t[]\n\t).filter(isRuntimeGateReason);\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{ label: 'Finished', value: formatDateLabel(run.finishedAt) },\n\t\t{\n\t\t\tlabel: 'Passing-rate winner',\n\t\t\tvalue: run.comparison.summary.bestByPassingRate ?? 'n/a'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Average F1 winner',\n\t\t\tvalue: run.comparison.summary.bestByAverageF1 ?? 'n/a'\n\t\t}\n\t];\n\tconst fixtureVariants = getFixtureVariantsFromRunTags(run.tags);\n\n\tif (fixtureVariants.length > 0) {\n\t\trows.push({\n\t\t\tlabel: 'Fixture variant',\n\t\t\tvalue: fixtureVariants.join(', ')\n\t\t});\n\t}\n\tconst officeWinnerSummaries = [\n\t\trun.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases\n\t\t\t? `narrative=${run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestByOfficeListEvidenceReconcileCases\n\t\t\t? `checklist=${run.comparison.summary.bestByOfficeListEvidenceReconcileCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestByOfficeTableEvidenceReconcileCases\n\t\t\t? `table=${run.comparison.summary.bestByOfficeTableEvidenceReconcileCases}`\n\t\t\t: null\n\t].filter((value): value is string => Boolean(value));\n\tif (officeWinnerSummaries.length > 0) {\n\t\trows.push({\n\t\t\tlabel: 'Office reconcile winners (docx/xlsx/pptx)',\n\t\t\tvalue: officeWinnerSummaries.join(', ')\n\t\t});\n\t}\n\tconst presentationCueWinners = [\n\t\trun.comparison.summary.bestByPresentationTitleCueCases\n\t\t\t? `title=${run.comparison.summary.bestByPresentationTitleCueCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestByPresentationBodyCueCases\n\t\t\t? `body=${run.comparison.summary.bestByPresentationBodyCueCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestByPresentationNotesCueCases\n\t\t\t? `notes=${run.comparison.summary.bestByPresentationNotesCueCases}`\n\t\t\t: null\n\t].filter((value): value is string => Boolean(value));\n\tif (presentationCueWinners.length > 0) {\n\t\trows.push({\n\t\t\tlabel: 'Presentation cue winners',\n\t\t\tvalue: presentationCueWinners.join(', ')\n\t\t});\n\t}\n\tconst spreadsheetCueWinners = [\n\t\trun.comparison.summary.bestBySpreadsheetSheetCueCases\n\t\t\t? `sheet=${run.comparison.summary.bestBySpreadsheetSheetCueCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestBySpreadsheetTableCueCases\n\t\t\t? `table=${run.comparison.summary.bestBySpreadsheetTableCueCases}`\n\t\t\t: null,\n\t\trun.comparison.summary.bestBySpreadsheetColumnCueCases\n\t\t\t? `column=${run.comparison.summary.bestBySpreadsheetColumnCueCases}`\n\t\t\t: null\n\t].filter((value): value is string => Boolean(value));\n\tif (spreadsheetCueWinners.length > 0) {\n\t\trows.push({\n\t\t\tlabel: 'Spreadsheet cue winners',\n\t\t\tvalue: spreadsheetCueWinners.join(', ')\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByPresentationTitleCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation title cue',\n\t\t\tvalue: run.comparison.summary.bestByPresentationTitleCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByPresentationBodyCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation body cue',\n\t\t\tvalue: run.comparison.summary.bestByPresentationBodyCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByPresentationNotesCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best presentation notes cue',\n\t\t\tvalue: run.comparison.summary.bestByPresentationNotesCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestBySpreadsheetSheetCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet sheet cue',\n\t\t\tvalue: run.comparison.summary.bestBySpreadsheetSheetCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestBySpreadsheetTableCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet table cue',\n\t\t\tvalue: run.comparison.summary.bestBySpreadsheetTableCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestBySpreadsheetColumnCueCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best spreadsheet column cue',\n\t\t\tvalue: run.comparison.summary.bestBySpreadsheetColumnCueCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office narrative reconcile',\n\t\t\tvalue: run.comparison.summary\n\t\t\t\t.bestByOfficeParagraphEvidenceReconcileCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByOfficeListEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office checklist reconcile',\n\t\t\tvalue: run.comparison.summary.bestByOfficeListEvidenceReconcileCases\n\t\t});\n\t}\n\tif (run.comparison.summary.bestByOfficeTableEvidenceReconcileCases) {\n\t\trows.push({\n\t\t\tlabel: 'Best office table reconcile',\n\t\t\tvalue: run.comparison.summary\n\t\t\t\t.bestByOfficeTableEvidenceReconcileCases\n\t\t});\n\t}\n\n\tif (\n\t\trun.comparison.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases\n\t) {\n\t\trows.push({\n\t\t\tlabel: 'Lowest runtime budget exhaustion',\n\t\t\tvalue: run.comparison.summary\n\t\t\t\t.bestByLowestRuntimeCandidateBudgetExhaustedCases\n\t\t});\n\t}\n\n\tif (run.comparison.summary.bestByLowestRuntimeUnderfilledTopKCases) {\n\t\trows.push({\n\t\t\tlabel: 'Lowest runtime underfilled TopK',\n\t\t\tvalue: run.comparison.summary\n\t\t\t\t.bestByLowestRuntimeUnderfilledTopKCases\n\t\t});\n\t}\n\n\trows.push(\n\t\t{\n\t\t\tlabel: 'Gate status',\n\t\t\tvalue:\n\t\t\t\trun.decisionSummary?.gate?.status ??\n\t\t\t\trun.releaseVerdict?.gate?.status ??\n\t\t\t\t'n/a'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Runtime gate failures',\n\t\t\tvalue:\n\t\t\t\truntimeGateReasons.length > 0\n\t\t\t\t\t? runtimeGateReasons.join('; ')\n\t\t\t\t\t: 'none'\n\t\t}\n\t);\n\n\treturn {\n\t\tlabel: run.label,\n\t\trows,\n\t\trunId: run.id,\n\t\tsummary:\n\t\t\truntimeGateReasons.length > 0\n\t\t\t\t? `${run.label} · runtime gate blocked`\n\t\t\t\t: `${run.label} · ${run.comparison.summary.bestByPassingRate ?? 'n/a'} leads passing rate`\n\t};\n};\n\nexport const buildRAGRetrievalReleaseGroupHistoryPresentation = (input: {\n\ttimeline?: RAGRetrievalReleaseTimelineSummary;\n\truns?: RAGRetrievalComparisonRun[];\n}): RAGRetrievalReleaseGroupHistoryPresentation => {\n\tconst recentRuns = (input.runs ?? []).map(\n\t\tbuildRAGRetrievalReleaseHistoryRunPresentation\n\t);\n\tconst fixtureVariants = (input.runs ?? [])\n\t\t.flatMap((run) => getFixtureVariantsFromRunTags(run.tags))\n\t\t.filter((tag, index, all) => all.indexOf(tag) === index);\n\tconst runtimeBlockedRuns = recentRuns.filter((entry) =>\n\t\tentry.rows.some(\n\t\t\t(row) =>\n\t\t\t\trow.label === 'Runtime gate failures' && row.value !== 'none'\n\t\t)\n\t).length;\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{\n\t\t\tlabel: 'Latest decision',\n\t\t\tvalue: input.timeline?.latestDecisionKind ?? 'none'\n\t\t},\n\t\t{\n\t\t\tlabel: 'Latest decision at',\n\t\t\tvalue: formatDateLabel(input.timeline?.latestDecisionAt)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Last promoted',\n\t\t\tvalue: formatDateLabel(input.timeline?.lastPromotedAt)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Last reverted',\n\t\t\tvalue: formatDateLabel(input.timeline?.lastRevertedAt)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Recent runtime-blocked runs',\n\t\t\tvalue: String(runtimeBlockedRuns)\n\t\t}\n\t];\n\n\tif (fixtureVariants.length > 0) {\n\t\trows.push({\n\t\t\tlabel: 'Fixture variants',\n\t\t\tvalue: fixtureVariants.join(', ')\n\t\t});\n\t}\n\n\treturn {\n\t\trecentRuns,\n\t\trows,\n\t\tsummary: input.timeline?.latestDecisionKind\n\t\t\t? `${input.timeline.latestDecisionKind} · ${recentRuns.length} recent runs`\n\t\t\t: recentRuns.length > 0\n\t\t\t\t? `${recentRuns.length} recent runs`\n\t\t\t\t: 'No release history yet.'\n\t};\n};\n\nexport const buildRAGAnswerGroundingCaseSnapshotPresentations = (\n\thistory?: RAGAnswerGroundingEvaluationHistory\n): RAGAnswerGroundingCaseSnapshotPresentation[] => {\n\tif (!history?.caseSnapshots.length) {\n\t\treturn [];\n\t}\n\n\treturn history.caseSnapshots.map((entry) => {\n\t\tconst label = entry.label ?? entry.caseId;\n\t\treturn {\n\t\t\tanswerChange: entry.answerChange,\n\t\t\tcaseId: entry.caseId,\n\t\t\tlabel,\n\t\t\trows: [\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Query',\n\t\t\t\t\tvalue: entry.query?.trim().length ? entry.query : 'n/a'\n\t\t\t\t},\n\t\t\t\t{ label: 'Answer change', value: entry.answerChange },\n\t\t\t\t{ label: 'Coverage', value: entry.coverage },\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Resolved citations',\n\t\t\t\t\tvalue: `${entry.resolvedCitationCount}/${entry.citationCount}`\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Resolved citation rate',\n\t\t\t\t\tvalue: entry.resolvedCitationRate.toFixed(3)\n\t\t\t\t},\n\t\t\t\t{ label: 'Citation F1', value: entry.citationF1.toFixed(3) },\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Reference count',\n\t\t\t\t\tvalue: String(entry.referenceCount)\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Cited IDs',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.citedIds.length > 0\n\t\t\t\t\t\t\t? entry.citedIds.join(', ')\n\t\t\t\t\t\t\t: 'none'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Matched IDs',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.matchedIds.length > 0\n\t\t\t\t\t\t\t? entry.matchedIds.join(', ')\n\t\t\t\t\t\t\t: 'none'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Missing IDs',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.missingIds.length > 0\n\t\t\t\t\t\t\t? entry.missingIds.join(', ')\n\t\t\t\t\t\t\t: 'none'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Extra IDs',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.extraIds.length > 0\n\t\t\t\t\t\t\t? entry.extraIds.join(', ')\n\t\t\t\t\t\t\t: 'none'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Unresolved refs',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.ungroundedReferenceNumbers.length > 0\n\t\t\t\t\t\t\t? entry.ungroundedReferenceNumbers.join(', ')\n\t\t\t\t\t\t\t: 'none'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Answer',\n\t\t\t\t\tvalue: entry.answer.trim().length > 0 ? entry.answer : 'n/a'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tlabel: 'Previous answer',\n\t\t\t\t\tvalue:\n\t\t\t\t\t\tentry.previousAnswer &&\n\t\t\t\t\t\tentry.previousAnswer.trim().length > 0\n\t\t\t\t\t\t\t? entry.previousAnswer\n\t\t\t\t\t\t\t: 'n/a'\n\t\t\t\t}\n\t\t\t],\n\t\t\tsummary: `${entry.answerChange} · ${entry.coverage} · resolved ${entry.resolvedCitationCount}/${entry.citationCount} · refs ${entry.referenceCount}`\n\t\t};\n\t});\n};\n\nexport const buildRAGAnswerGroundingHistoryRows = (\n\thistory?: RAGAnswerGroundingEvaluationHistory\n): RAGLabelValueRow[] => {\n\tif (!history?.latestRun) {\n\t\treturn [{ label: 'History', value: 'No persisted provider runs yet.' }];\n\t}\n\n\tconst rows: RAGLabelValueRow[] = [\n\t\t{ label: 'Runs recorded', value: String(history.runs.length) },\n\t\t{\n\t\t\tlabel: 'Latest',\n\t\t\tvalue: `${history.latestRun.label} · ${formatGroundingHistorySummaryValue(\n\t\t\t\thistory.latestRun.response\n\t\t\t)}`\n\t\t}\n\t];\n\n\tif (history.previousRun) {\n\t\trows.push({\n\t\t\tlabel: 'Previous',\n\t\t\tvalue: `${history.previousRun.label} · ${formatGroundingHistorySummaryValue(\n\t\t\t\thistory.previousRun.response\n\t\t\t)}`\n\t\t});\n\t}\n\n\tif (history.leaderboard[0]) {\n\t\trows.push({\n\t\t\tlabel: 'Best recorded',\n\t\t\tvalue: `#${history.leaderboard[0].rank} · ${history.leaderboard[0].label} · passing ${formatEvaluationPassingRate(\n\t\t\t\thistory.leaderboard[0].passingRate\n\t\t\t)} · citation f1 ${history.leaderboard[0].averageCitationF1.toFixed(\n\t\t\t\t3\n\t\t\t)} · resolved ${formatEvaluationPassingRate(\n\t\t\t\thistory.leaderboard[0].averageResolvedCitationRate\n\t\t\t)}`\n\t\t});\n\t}\n\n\tif (history.caseSnapshots.length > 0) {\n\t\tconst changedAnswers = history.caseSnapshots.filter(\n\t\t\t(entry) => entry.answerChange === 'changed'\n\t\t).length;\n\t\trows.push({\n\t\t\tlabel: 'Answer drift',\n\t\t\tvalue: `${changedAnswers}/${history.caseSnapshots.length} changed`\n\t\t});\n\t}\n\n\tif (!history.diff) {\n\t\trows.push({\n\t\t\tlabel: 'History diff',\n\t\t\tvalue: 'Run the provider comparison again to diff grounding regressions over time.'\n\t\t});\n\t\treturn rows;\n\t}\n\n\trows.push(\n\t\t{\n\t\t\tlabel: 'Passing delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\thistory.diff.summaryDelta.passingRate,\n\t\t\t\t1,\n\t\t\t\t'%'\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Citation F1 delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\thistory.diff.summaryDelta.averageCitationF1,\n\t\t\t\t3\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Resolved citation delta',\n\t\t\tvalue: formatSignedDelta(\n\t\t\t\thistory.diff.summaryDelta.averageResolvedCitationRate * 100,\n\t\t\t\t1,\n\t\t\t\t'%'\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Improved',\n\t\t\tvalue: formatGroundingHistoryCaseLabels(history.diff.improvedCases)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Regressed',\n\t\t\tvalue: formatGroundingHistoryCaseLabels(history.diff.regressedCases)\n\t\t}\n\t);\n\n\tif (history.previousRun) {\n\t\tconst currentEntityView = buildRAGAnswerGroundingEntityQualityView(\n\t\t\thistory.latestRun.response\n\t\t);\n\t\tconst previousEntityView = buildRAGAnswerGroundingEntityQualityView(\n\t\t\thistory.previousRun.response\n\t\t);\n\t\trows.push(\n\t\t\t{\n\t\t\t\tlabel: 'Source regression hotspots',\n\t\t\t\tvalue: formatEntityRegressionHotspots(\n\t\t\t\t\tcurrentEntityView.bySource,\n\t\t\t\t\tpreviousEntityView.bySource,\n\t\t\t\t\t(entry) => entry.averageCitationF1,\n\t\t\t\t\t'citation f1'\n\t\t\t\t)\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: 'Document regression hotspots',\n\t\t\t\tvalue: formatEntityRegressionHotspots(\n\t\t\t\t\tcurrentEntityView.byDocument,\n\t\t\t\t\tpreviousEntityView.byDocument,\n\t\t\t\t\t(entry) => entry.averageCitationF1,\n\t\t\t\t\t'citation f1'\n\t\t\t\t)\n\t\t\t}\n\t\t);\n\t}\n\n\treturn rows;\n};\n\nexport const buildRAGAnswerGroundingHistoryPresentation = (\n\thistory?: RAGAnswerGroundingEvaluationHistory\n): RAGAnswerGroundingHistoryPresentation => ({\n\tcaseSnapshots: buildRAGAnswerGroundingCaseSnapshotPresentations(history),\n\trows: buildRAGAnswerGroundingHistoryRows(history),\n\tsummary: history?.latestRun\n\t\t? history.latestRun.label\n\t\t: 'No persisted provider runs yet.'\n});\n\nconst formatFailureCounts = (failureCounts: Record<string, number>) => {\n\tconst entries = Object.entries(failureCounts).sort((left, right) => {\n\t\tif (right[1] !== left[1]) {\n\t\t\treturn right[1] - left[1];\n\t\t}\n\n\t\treturn left[0].localeCompare(right[0]);\n\t});\n\n\treturn entries.length > 0\n\t\t? entries.map(([key, count]) => `${key} ${count}`).join(' · ')\n\t\t: 'none';\n};\n\nconst formatFailureCountDelta = (\n\tcurrent: Record<string, number>,\n\tprevious: Record<string, number>\n) => {\n\tconst deltas = Object.keys({ ...current, ...previous })\n\t\t.map((key) => ({\n\t\t\tdelta: (current[key] ?? 0) - (previous[key] ?? 0),\n\t\t\tkey\n\t\t}))\n\t\t.filter((entry) => entry.delta > 0)\n\t\t.sort((left, right) => {\n\t\t\tif (right.delta !== left.delta) {\n\t\t\t\treturn right.delta - left.delta;\n\t\t\t}\n\n\t\t\treturn left.key.localeCompare(right.key);\n\t\t});\n\n\treturn deltas.length > 0\n\t\t? deltas\n\t\t\t\t.slice(0, 3)\n\t\t\t\t.map((entry) => `${entry.key} +${entry.delta}`)\n\t\t\t\t.join(' · ')\n\t\t: 'stable';\n};\n\nconst formatEntityRegressionHotspots = <\n\tT extends {\n\t\tkey: string;\n\t\tlabel: string;\n\t\tpassingRate: number;\n\t\tfailureCounts: Record<string, number>;\n\t}\n>(\n\tcurrentEntries: T[],\n\tpreviousEntries: T[],\n\tmetricSelector: (entry: T) => number,\n\tmetricLabel: string\n) => {\n\tconst previousMap = new Map(\n\t\tpreviousEntries.map((entry) => [entry.key, entry])\n\t);\n\tconst regressions = currentEntries\n\t\t.map((entry) => {\n\t\t\tconst previous = previousMap.get(entry.key);\n\t\t\tconst passDelta = entry.passingRate - (previous?.passingRate ?? 0);\n\t\t\tconst metricDelta =\n\t\t\t\tmetricSelector(entry) -\n\t\t\t\t(previous ? metricSelector(previous) : 0);\n\t\t\tconst failureDelta = formatFailureCountDelta(\n\t\t\t\tentry.failureCounts,\n\t\t\t\tprevious?.failureCounts ?? {}\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\tentry,\n\t\t\t\tfailureDelta,\n\t\t\t\tmetricDelta,\n\t\t\t\tpassDelta\n\t\t\t};\n\t\t})\n\t\t.filter(\n\t\t\t(entry) =>\n\t\t\t\tentry.passDelta < 0 ||\n\t\t\t\tentry.metricDelta < 0 ||\n\t\t\t\tentry.failureDelta !== 'stable'\n\t\t)\n\t\t.sort((left, right) => {\n\t\t\tif (left.passDelta !== right.passDelta) {\n\t\t\t\treturn left.passDelta - right.passDelta;\n\t\t\t}\n\t\t\tif (left.metricDelta !== right.metricDelta) {\n\t\t\t\treturn left.metricDelta - right.metricDelta;\n\t\t\t}\n\n\t\t\treturn left.entry.label.localeCompare(right.entry.label);\n\t\t});\n\n\treturn regressions.length > 0\n\t\t? regressions\n\t\t\t\t.slice(0, 3)\n\t\t\t\t.map(\n\t\t\t\t\t({ entry, failureDelta, metricDelta, passDelta }) =>\n\t\t\t\t\t\t`${entry.label} pass ${formatSignedDelta(\n\t\t\t\t\t\t\tpassDelta,\n\t\t\t\t\t\t\t1,\n\t\t\t\t\t\t\t'%'\n\t\t\t\t\t\t)} · ${metricLabel} ${formatSignedDelta(\n\t\t\t\t\t\t\tmetricDelta,\n\t\t\t\t\t\t\t3\n\t\t\t\t\t\t)} · ${failureDelta}`\n\t\t\t\t)\n\t\t\t\t.join(' | ')\n\t\t: 'none';\n};\n\nconst buildEvaluationEntityPresentation = (\n\tentry: RAGEvaluationEntityQualitySummary\n): RAGEntityQualityPresentation => ({\n\tkey: entry.key,\n\tlabel: entry.label,\n\trows: [\n\t\t{ label: 'Entity type', value: entry.entityType },\n\t\t{ label: 'Cases', value: String(entry.totalCases) },\n\t\t{\n\t\t\tlabel: 'Status mix',\n\t\t\tvalue: `${entry.passedCases} pass · ${entry.partialCases} partial · ${entry.failedCases} fail`\n\t\t},\n\t\t{\n\t\t\tlabel: 'Passing rate',\n\t\t\tvalue: formatEvaluationPassingRate(entry.passingRate)\n\t\t},\n\t\t{ label: 'Average F1', value: entry.averageF1.toFixed(3) },\n\t\t{\n\t\t\tlabel: 'Failure classes',\n\t\t\tvalue: formatFailureCounts(entry.failureCounts)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Cases',\n\t\t\tvalue: entry.caseIds.length > 0 ? entry.caseIds.join(', ') : 'none'\n\t\t}\n\t],\n\tsummary: `${entry.entityType} · passing ${formatEvaluationPassingRate(\n\t\tentry.passingRate\n\t)} · f1 ${entry.averageF1.toFixed(3)} · failures ${formatFailureCounts(\n\t\tentry.failureCounts\n\t)}`\n});\n\nconst buildGroundingEntityPresentation = (\n\tentry: RAGAnswerGroundingEntityQualitySummary\n): RAGEntityQualityPresentation => ({\n\tkey: entry.key,\n\tlabel: entry.label,\n\trows: [\n\t\t{ label: 'Entity type', value: entry.entityType },\n\t\t{ label: 'Cases', value: String(entry.totalCases) },\n\t\t{\n\t\t\tlabel: 'Status mix',\n\t\t\tvalue: `${entry.passedCases} pass · ${entry.partialCases} partial · ${entry.failedCases} fail`\n\t\t},\n\t\t{\n\t\t\tlabel: 'Passing rate',\n\t\t\tvalue: formatEvaluationPassingRate(entry.passingRate)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Average citation F1',\n\t\t\tvalue: entry.averageCitationF1.toFixed(3)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Average resolved citation rate',\n\t\t\tvalue: formatEvaluationPassingRate(\n\t\t\t\tentry.averageResolvedCitationRate * 100\n\t\t\t)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Failure classes',\n\t\t\tvalue: formatFailureCounts(entry.failureCounts)\n\t\t},\n\t\t{\n\t\t\tlabel: 'Cases',\n\t\t\tvalue: entry.caseIds.length > 0 ? entry.caseIds.join(', ') : 'none'\n\t\t}\n\t],\n\tsummary: `${entry.entityType} · passing ${formatEvaluationPassingRate(\n\t\tentry.passingRate\n\t)} · citation f1 ${entry.averageCitationF1.toFixed(\n\t\t3\n\t)} · failures ${formatFailureCounts(entry.failureCounts)}`\n});\n\nexport const buildRAGEvaluationEntityQualityPresentation = (\n\tview: RAGEvaluationEntityQualityView,\n\tentityType: 'source' | 'document'\n): RAGEntityQualityViewPresentation => {\n\tconst entities =\n\t\tentityType === 'source'\n\t\t\t? view.bySource.map(buildEvaluationEntityPresentation)\n\t\t\t: view.byDocument.map(buildEvaluationEntityPresentation);\n\n\treturn {\n\t\tentities,\n\t\trows: [\n\t\t\t{ label: 'Entity type', value: entityType },\n\t\t\t{ label: 'Entities tracked', value: String(entities.length) },\n\t\t\t{\n\t\t\t\tlabel: 'Best coverage',\n\t\t\t\tvalue: entities[0]?.summary ?? 'No entity quality data yet.'\n\t\t\t}\n\t\t],\n\t\tsummary:\n\t\t\tentities[0]?.label ??\n\t\t\t`No ${entityType === 'source' ? 'source' : 'document'} quality data yet.`\n\t};\n};\n\nexport const buildRAGAnswerGroundingEntityQualityPresentation = (\n\tview: RAGAnswerGroundingEntityQualityView,\n\tentityType: 'source' | 'document'\n): RAGEntityQualityViewPresentation => {\n\tconst entities =\n\t\tentityType === 'source'\n\t\t\t? view.bySource.map(buildGroundingEntityPresentation)\n\t\t\t: view.byDocument.map(buildGroundingEntityPresentation);\n\n\treturn {\n\t\tentities,\n\t\trows: [\n\t\t\t{ label: 'Entity type', value: entityType },\n\t\t\t{ label: 'Entities tracked', value: String(entities.length) },\n\t\t\t{\n\t\t\t\tlabel: 'Best coverage',\n\t\t\t\tvalue: entities[0]?.summary ?? 'No entity quality data yet.'\n\t\t\t}\n\t\t],\n\t\tsummary:\n\t\t\tentities[0]?.label ??\n\t\t\t`No ${entityType === 'source' ? 'source' : 'document'} quality data yet.`\n\t};\n};\n",
11
- "import { Injectable } from '@angular/core';\nimport type {\n\tRAGEvaluationInput,\n\tRAGRetrievalBaselineResponse,\n\tRAGRetrievalLaneHandoffDecisionRequest,\n\tRAGRetrievalBaselinePromotionFromRunRequest,\n\tRAGRetrievalBaselinePromotionRequest,\n\tRAGRetrievalBaselineRevertRequest,\n\tRAGRetrievalReleaseDecisionActionRequest,\n\tRAGRetrievalComparisonRequest,\n\tRAGDocumentChunk,\n\tRAGDocumentIngestInput,\n\tRAGDocumentUploadIngestInput,\n\tRAGDocumentUrlIngestInput,\n\tRAGRetrievalIncidentRemediationDecisionRequest,\n\tRAGRetrievalIncidentRemediationBulkExecutionRequest,\n\tRAGRetrievalIncidentRemediationExecutionRequest,\n\tRAGSearchRequest,\n\tRAGSyncRunOptions\n} from '@absolutejs/ai';\nimport { createRAGClient } from '../../ai/client/ragClient';\n\n@Injectable({ providedIn: 'root' })\nexport class RAGClientService {\n\tprivate clients = new Map<string, ReturnType<typeof createRAGClient>>();\n\n\tprivate client(path: string) {\n\t\tconst existing = this.clients.get(path);\n\t\tif (existing) {\n\t\t\treturn existing;\n\t\t}\n\n\t\tconst created = createRAGClient({ path });\n\t\tthis.clients.set(path, created);\n\n\t\treturn created;\n\t}\n\n\tingest(path: string, chunks: RAGDocumentChunk[]) {\n\t\treturn this.client(path).ingest(chunks);\n\t}\n\n\tingestDocuments(path: string, input: RAGDocumentIngestInput) {\n\t\treturn this.client(path).ingestDocuments(input);\n\t}\n\n\tingestUrls(path: string, input: RAGDocumentUrlIngestInput) {\n\t\treturn this.client(path).ingestUrls(input);\n\t}\n\n\tingestUploads(path: string, input: RAGDocumentUploadIngestInput) {\n\t\treturn this.client(path).ingestUploads(input);\n\t}\n\n\tsearch(path: string, input: RAGSearchRequest) {\n\t\treturn this.client(path).search(input);\n\t}\n\n\tsearchWithTrace(path: string, input: RAGSearchRequest) {\n\t\treturn this.client(path).searchWithTrace(input);\n\t}\n\n\tevaluate(path: string, input: RAGEvaluationInput) {\n\t\treturn this.client(path).evaluate(input);\n\t}\n\n\tcompareRetrievals(path: string, input: RAGRetrievalComparisonRequest) {\n\t\treturn this.client(path).compareRetrievals(input);\n\t}\n\n\tretrievalComparisonHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tlimit?: number;\n\t\t\tsuiteId?: string;\n\t\t\tlabel?: string;\n\t\t\twinnerId?: string;\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalComparisonHistory(input);\n\t}\n\n\tretrievalBaselines(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'active' | 'superseded';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalBaselines(input);\n\t}\n\n\tpromoteRetrievalBaseline(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionRequest\n\t) {\n\t\treturn this.client(path).promoteRetrievalBaseline(input);\n\t}\n\n\tpromoteRetrievalBaselineDetailed(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionRequest\n\t): Promise<RAGRetrievalBaselineResponse> {\n\t\treturn this.client(path).promoteRetrievalBaselineDetailed(input);\n\t}\n\n\tpromoteRetrievalBaselineToLane(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionRequest & {\n\t\t\trolloutLabel: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).promoteRetrievalBaselineToLane(input);\n\t}\n\n\tpromoteRetrievalBaselineToLaneDetailed(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionRequest & {\n\t\t\trolloutLabel: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t): Promise<RAGRetrievalBaselineResponse> {\n\t\treturn this.client(path).promoteRetrievalBaselineToLaneDetailed(input);\n\t}\n\n\tpromoteRetrievalBaselineFromRun(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionFromRunRequest\n\t) {\n\t\treturn this.client(path).promoteRetrievalBaselineFromRun(input);\n\t}\n\n\tpromoteRetrievalBaselineFromRunDetailed(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselinePromotionFromRunRequest\n\t): Promise<RAGRetrievalBaselineResponse> {\n\t\treturn this.client(path).promoteRetrievalBaselineFromRunDetailed(input);\n\t}\n\n\trevertRetrievalBaseline(\n\t\tpath: string,\n\t\tinput: RAGRetrievalBaselineRevertRequest\n\t) {\n\t\treturn this.client(path).revertRetrievalBaseline(input);\n\t}\n\n\tretrievalBaselineDecisions(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tkind?: 'approve' | 'promote' | 'reject' | 'revert';\n\t\t\tfreshnessStatus?: 'fresh' | 'expired' | 'not_applicable';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalBaselineDecisions(input);\n\t}\n\n\tretrievalReleaseGroupHistory(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tgroupKey: string;\n\t\t\tdecisionLimit?: number;\n\t\t\tbaselineLimit?: number;\n\t\t\trunLimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalReleaseGroupHistory(input);\n\t}\n\n\tretrievalLaneHandoffs(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tsourceRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tlimit?: number;\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalLaneHandoffs(input);\n\t}\n\n\tretrievalLaneHandoffDecisions(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tsourceRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tkind?: 'approve' | 'reject' | 'complete';\n\t\t\tlimit?: number;\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalLaneHandoffDecisions(input);\n\t}\n\n\tretrievalLaneHandoffIncidents(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'open' | 'resolved';\n\t\t\tseverity?: 'warning' | 'critical';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalLaneHandoffIncidents(input);\n\t}\n\n\tretrievalLaneHandoffIncidentHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\taction?: 'opened' | 'acknowledged' | 'unacknowledged' | 'resolved';\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalLaneHandoffIncidentHistory(input);\n\t}\n\n\tretrievalLaneHandoffAutoCompletePolicyHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalLaneHandoffAutoCompletePolicyHistory(\n\t\t\tinput\n\t\t);\n\t}\n\n\tretrievalReleaseLanePolicyHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\trolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tscope?: 'rollout_label' | 'group_rollout_label';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalReleaseLanePolicyHistory(input);\n\t}\n\n\tretrievalBaselineGatePolicyHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\trolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tscope?: 'rollout_label' | 'group_rollout_label';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalBaselineGatePolicyHistory(input);\n\t}\n\n\tretrievalReleaseLaneEscalationPolicyHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalReleaseLaneEscalationPolicyHistory(\n\t\t\tinput\n\t\t);\n\t}\n\n\tretrievalReleaseIncidentPolicyHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalReleaseIncidentPolicyHistory(input);\n\t}\n\n\tdecideRetrievalLaneHandoff(\n\t\tpath: string,\n\t\tinput: RAGRetrievalLaneHandoffDecisionRequest\n\t) {\n\t\treturn this.client(path).decideRetrievalLaneHandoff(input);\n\t}\n\n\tdecideRetrievalLaneHandoffDetailed(\n\t\tpath: string,\n\t\tinput: RAGRetrievalLaneHandoffDecisionRequest\n\t) {\n\t\treturn this.client(path).decideRetrievalLaneHandoffDetailed(input);\n\t}\n\n\tretrievalReleaseIncidents(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'open' | 'resolved';\n\t\t\tseverity?: 'warning' | 'critical';\n\t\t\tkind?:\n\t\t\t\t| 'approval_expired'\n\t\t\t\t| 'baseline_regression'\n\t\t\t\t| 'gate_failure'\n\t\t\t\t| 'handoff_stale';\n\t\t\tacknowledged?: boolean;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalReleaseIncidents(input);\n\t}\n\n\tretrievalIncidentRemediationDecisions(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\tremediationKind?:\n\t\t\t\t| 'renew_approval'\n\t\t\t\t| 'record_approval'\n\t\t\t\t| 'inspect_gate'\n\t\t\t\t| 'rerun_comparison'\n\t\t\t\t| 'restore_source_lane'\n\t\t\t\t| 'review_readiness'\n\t\t\t\t| 'monitor_lane';\n\t\t\tstatus?: 'planned' | 'applied' | 'dismissed';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalIncidentRemediationDecisions(input);\n\t}\n\n\tretrievalIncidentRemediationExecutions(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\tactionKind?: RAGRetrievalIncidentRemediationExecutionRequest['action']['kind'];\n\t\t\tcode?:\n\t\t\t\t| 'approval_recorded'\n\t\t\t\t| 'incident_acknowledged'\n\t\t\t\t| 'incident_resolved'\n\t\t\t\t| 'release_status_loaded'\n\t\t\t\t| 'release_drift_loaded'\n\t\t\t\t| 'handoff_status_loaded'\n\t\t\t\t| 'guardrail_blocked'\n\t\t\t\t| 'idempotent_replay';\n\t\t\tblockedByGuardrail?: boolean;\n\t\t\tidempotentReplay?: boolean;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalIncidentRemediationExecutions(input);\n\t}\n\n\trecordRetrievalIncidentRemediationDecision(\n\t\tpath: string,\n\t\tinput: RAGRetrievalIncidentRemediationDecisionRequest\n\t) {\n\t\treturn this.client(path).recordRetrievalIncidentRemediationDecision(\n\t\t\tinput\n\t\t);\n\t}\n\n\texecuteRetrievalIncidentRemediation(\n\t\tpath: string,\n\t\tinput: RAGRetrievalIncidentRemediationExecutionRequest\n\t) {\n\t\treturn this.client(path).executeRetrievalIncidentRemediation(input);\n\t}\n\n\tbulkExecuteRetrievalIncidentRemediations(\n\t\tpath: string,\n\t\tinput: RAGRetrievalIncidentRemediationBulkExecutionRequest\n\t) {\n\t\treturn this.client(path).bulkExecuteRetrievalIncidentRemediations(\n\t\t\tinput\n\t\t);\n\t}\n\n\tretrievalReleaseStatus(path: string) {\n\t\treturn this.client(path).retrievalReleaseStatus();\n\t}\n\n\tretrievalReleaseIncidentStatus(path: string) {\n\t\treturn this.client(path).retrievalReleaseIncidentStatus();\n\t}\n\n\tretrievalIncidentRemediationStatus(path: string) {\n\t\treturn this.client(path).retrievalIncidentRemediationStatus();\n\t}\n\n\tretrievalReleaseDriftStatus(path: string) {\n\t\treturn this.client(path).retrievalReleaseDriftStatus();\n\t}\n\n\tretrievalLaneHandoffStatus(path: string) {\n\t\treturn this.client(path).retrievalLaneHandoffStatus();\n\t}\n\n\tretrievalLaneHandoffIncidentStatus(path: string) {\n\t\treturn this.client(path).retrievalLaneHandoffIncidentStatus();\n\t}\n\n\tacknowledgeRetrievalLaneHandoffIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t\tacknowledgedAt?: number;\n\t\t\tacknowledgedBy?: string;\n\t\t\tacknowledgementNotes?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).acknowledgeRetrievalLaneHandoffIncident(input);\n\t}\n\n\tunacknowledgeRetrievalLaneHandoffIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).unacknowledgeRetrievalLaneHandoffIncident(\n\t\t\tinput\n\t\t);\n\t}\n\n\tresolveRetrievalLaneHandoffIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t\tresolvedAt?: number;\n\t\t\tresolvedBy?: string;\n\t\t\tresolutionNotes?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).resolveRetrievalLaneHandoffIncident(input);\n\t}\n\n\tacknowledgeRetrievalReleaseIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t\tacknowledgedAt?: number;\n\t\t\tacknowledgedBy?: string;\n\t\t\tacknowledgementNotes?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).acknowledgeRetrievalReleaseIncident(input);\n\t}\n\n\tunacknowledgeRetrievalReleaseIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).unacknowledgeRetrievalReleaseIncident(input);\n\t}\n\n\tresolveRetrievalReleaseIncident(\n\t\tpath: string,\n\t\tinput: {\n\t\t\tincidentId: string;\n\t\t\tresolvedAt?: number;\n\t\t\tresolvedBy?: string;\n\t\t\tresolutionNotes?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).resolveRetrievalReleaseIncident(input);\n\t}\n\n\tretrievalPromotionCandidates(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttag?: string;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tapproved?: boolean;\n\t\t\tready?: boolean;\n\t\t\tblocked?: boolean;\n\t\t\treviewStatus?: 'approved' | 'blocked' | 'needs_review' | 'ready';\n\t\t\tfreshnessStatus?: 'fresh' | 'expired' | 'not_applicable';\n\t\t\tsortBy?:\n\t\t\t\t| 'approvalFreshness'\n\t\t\t\t| 'finishedAt'\n\t\t\t\t| 'gateSeverity'\n\t\t\t\t| 'priority';\n\t\t\tsortDirection?: 'asc' | 'desc';\n\t\t}\n\t) {\n\t\treturn this.client(path).retrievalPromotionCandidates(input);\n\t}\n\n\tapproveRetrievalCandidate(\n\t\tpath: string,\n\t\tinput: RAGRetrievalReleaseDecisionActionRequest\n\t) {\n\t\treturn this.client(path).approveRetrievalCandidate(input);\n\t}\n\n\trejectRetrievalCandidate(\n\t\tpath: string,\n\t\tinput: RAGRetrievalReleaseDecisionActionRequest\n\t) {\n\t\treturn this.client(path).rejectRetrievalCandidate(input);\n\t}\n\n\tstatus(path: string) {\n\t\treturn this.client(path).status();\n\t}\n\n\tops(path: string) {\n\t\treturn this.client(path).ops();\n\t}\n\n\tsearchTraceHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tquery?: string;\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t\tlimit?: number;\n\t\t}\n\t) {\n\t\treturn this.client(path).searchTraceHistory(input);\n\t}\n\n\tsearchTraceGroups(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\ttag?: string;\n\t\t\tlimit?: number;\n\t\t}\n\t) {\n\t\treturn this.client(path).searchTraceGroups(input);\n\t}\n\n\tsearchTraceStats(path: string, input?: { tag?: string }) {\n\t\treturn this.client(path).searchTraceStats(input);\n\t}\n\n\tpreviewSearchTracePrune(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tmaxAgeMs?: number;\n\t\t\tmaxRecordsPerQuery?: number;\n\t\t\tmaxRecordsPerGroup?: number;\n\t\t\tnow?: number;\n\t\t\ttag?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).previewSearchTracePrune(input);\n\t}\n\n\tpruneSearchTraces(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tmaxAgeMs?: number;\n\t\t\tmaxRecordsPerQuery?: number;\n\t\t\tmaxRecordsPerGroup?: number;\n\t\t\tnow?: number;\n\t\t\ttag?: string;\n\t\t}\n\t) {\n\t\treturn this.client(path).pruneSearchTraces(input);\n\t}\n\n\tsearchTracePruneHistory(\n\t\tpath: string,\n\t\tinput?: {\n\t\t\tlimit?: number;\n\t\t\ttrigger?: 'manual' | 'write' | 'schedule';\n\t\t}\n\t) {\n\t\treturn this.client(path).searchTracePruneHistory(input);\n\t}\n\n\tsyncSources(path: string) {\n\t\treturn this.client(path).syncSources();\n\t}\n\n\tsyncAllSources(path: string, options?: RAGSyncRunOptions) {\n\t\treturn this.client(path).syncAllSources(options);\n\t}\n\n\tsyncSource(path: string, id: string, options?: RAGSyncRunOptions) {\n\t\treturn this.client(path).syncSource(id, options);\n\t}\n\n\tdocuments(path: string, kind?: string) {\n\t\treturn this.client(path).documents(kind);\n\t}\n\n\tdocumentChunks(path: string, id: string) {\n\t\treturn this.client(path).documentChunks(id);\n\t}\n\n\tcreateDocument(\n\t\tpath: string,\n\t\tinput: RAGDocumentIngestInput['documents'][number]\n\t) {\n\t\treturn this.client(path).createDocument(input);\n\t}\n\n\tdeleteDocument(path: string, id: string) {\n\t\treturn this.client(path).deleteDocument(id);\n\t}\n\n\treseed(path: string) {\n\t\treturn this.client(path).reseed();\n\t}\n\n\treset(path: string) {\n\t\treturn this.client(path).reset();\n\t}\n\n\treindexDocument(path: string, id: string) {\n\t\treturn this.client(path).reindexDocument(id);\n\t}\n\n\treindexSource(path: string, source: string) {\n\t\treturn this.client(path).reindexSource(source);\n\t}\n\n\tbackends(path: string) {\n\t\treturn this.client(path).backends();\n\t}\n\n\tclearIndex(path: string) {\n\t\treturn this.client(path).clearIndex();\n\t}\n}\n",
12
- "import type {\n\tRAGAdminCapabilities,\n\tRAGBackendsResponse,\n\tRAGBackendMaintenanceRecommendation,\n\tRAGBackendMaintenanceSummary,\n\tRAGDocumentChunksResponse,\n\tRAGEvaluationInput,\n\tRAGEvaluationResponse,\n\tRAGRetrievalBaselineListResponse,\n\tRAGRetrievalBaselinePromotionFromRunRequest,\n\tRAGRetrievalBaselinePromotionRequest,\n\tRAGRetrievalBaselineRevertRequest,\n\tRAGRetrievalReleaseIncidentAcknowledgeRequest,\n\tRAGRetrievalReleaseDecisionActionRequest,\n\tRAGRetrievalBaselineResponse,\n\tRAGRetrievalPromotionCandidateListResponse,\n\tRAGRetrievalReleaseDecisionListResponse,\n\tRAGRetrievalLaneHandoffDecisionListResponse,\n\tRAGRetrievalLaneHandoffDecisionRequest,\n\tRAGRetrievalLaneHandoffDecisionResponse,\n\tRAGRetrievalLaneHandoffAutoCompletePolicyHistoryResponse,\n\tRAGRetrievalReleaseLanePolicyHistoryResponse,\n\tRAGRetrievalBaselineGatePolicyHistoryResponse,\n\tRAGRetrievalReleaseLaneEscalationPolicyHistoryResponse,\n\tRAGRetrievalLaneHandoffIncidentHistoryResponse,\n\tRAGRetrievalLaneHandoffIncidentListResponse,\n\tRAGRetrievalLaneHandoffIncidentStatusResponse,\n\tRAGRetrievalLaneHandoffListResponse,\n\tRAGRetrievalLaneHandoffStatusResponse,\n\tRAGRetrievalIncidentRemediationDecisionListResponse,\n\tRAGRetrievalIncidentRemediationDecisionRequest,\n\tRAGRetrievalIncidentRemediationExecutionHistoryResponse,\n\tRAGRetrievalIncidentRemediationBulkExecutionRequest,\n\tRAGRetrievalIncidentRemediationBulkExecutionResponse,\n\tRAGRetrievalIncidentRemediationExecutionRequest,\n\tRAGRetrievalIncidentRemediationExecutionResponse,\n\tRAGRetrievalIncidentRemediationStatusResponse,\n\tRAGRetrievalReleaseGroupHistoryResponse,\n\tRAGRetrievalReleaseIncidentListResponse,\n\tRAGRetrievalReleaseIncidentStatusResponse,\n\tRAGRetrievalReleaseDriftStatusResponse,\n\tRAGRetrievalReleaseStatusResponse,\n\tRAGRetrievalComparisonHistoryResponse,\n\tRAGRetrievalComparisonRequest,\n\tRAGRetrievalComparisonResponse,\n\tRAGAdaptiveNativePlannerBenchmarkResponse,\n\tRAGAdaptiveNativePlannerBenchmarkSnapshotResponse,\n\tRAGNativeBackendComparisonBenchmarkResponse,\n\tRAGNativeBackendComparisonBenchmarkSnapshotResponse,\n\tRAGDocumentIngestInput,\n\tRAGDocumentChunk,\n\tRAGDocumentsResponse,\n\tRAGDocumentUrlIngestInput,\n\tRAGDocumentUploadIngestInput,\n\tRAGIngestResponse,\n\tRAGMutationResponse,\n\tRAGOperationsResponse,\n\tRAGSearchRequest,\n\tRAGSearchResponse,\n\tRAGSearchTracePrunePreviewResponse,\n\tRAGSearchTracePruneHistoryResponse,\n\tRAGSearchTracePruneResponse,\n\tRAGSearchTraceGroupHistoryResponse,\n\tRAGSearchTraceHistoryResponse,\n\tRAGSearchTraceStatsResponse,\n\tRAGSource,\n\tRAGStatusResponse,\n\tRAGSyncRunOptions,\n\tRAGSyncResponse\n} from '@absolutejs/ai';\nconst UNFOUND_INDEX = -1;\n\ntype FetchLike = typeof fetch;\n\nexport type RAGClientOptions = {\n\tpath: string;\n\tfetch?: FetchLike;\n};\n\nexport type RAGDetailedSearchResponse = {\n\tresults: RAGSource[];\n\ttrace?: RAGSearchResponse['trace'];\n};\n\nexport type RAGMaintenancePayload =\n\t| Pick<RAGMutationResponse, 'maintenance' | 'admin' | 'workflowStatus'>\n\t| Pick<RAGOperationsResponse, 'maintenance' | 'admin' | 'status'>\n\t| Pick<RAGStatusResponse, 'maintenance' | 'admin' | 'status'>\n\t| null\n\t| undefined;\n\nexport type RAGMaintenanceActionDescriptor = {\n\tkind: 'analyze_backend' | 'rebuild_native_index';\n\tlabel: string;\n\tavailable: boolean;\n\trecommended: boolean;\n\treason?: string;\n};\n\nexport type RAGMaintenanceOverview = {\n\tactiveJobCount: number;\n\tactions: RAGMaintenanceActionDescriptor[];\n\tavailableActions: RAGMaintenanceActionDescriptor[];\n\tbackend?: RAGBackendMaintenanceSummary['backend'];\n\tblockingRecommendations: RAGBackendMaintenanceRecommendation[];\n\tcriticalCount: number;\n\thasBlockingIssue: boolean;\n\tinfoCount: number;\n\tprimaryRecommendation?: RAGBackendMaintenanceRecommendation;\n\trecentlyCompletedActions: NonNullable<RAGBackendMaintenanceSummary>['recentActions'];\n\trecommendationCount: number;\n\trecommendations: RAGBackendMaintenanceRecommendation[];\n\trecommendedNow: RAGBackendMaintenanceRecommendation[];\n\twarningCount: number;\n};\n\nconst jsonHeaders: { 'Content-Type': string } = {\n\t'Content-Type': 'application/json'\n};\n\nconst normalizeBasePath = (path: string) =>\n\tpath.endsWith('/') ? path.slice(0, UNFOUND_INDEX) : path;\n\nconst parseJson = async <T>(response: Response) => {\n\tconst payload: T = JSON.parse(await response.text());\n\n\treturn payload;\n};\n\nconst isErrorPayload = (value: unknown): value is { error?: string } => {\n\tif (!value || typeof value !== 'object') {\n\t\treturn false;\n\t}\n\n\treturn !('error' in value) || typeof value.error === 'string';\n};\n\nconst toErrorMessage = async (response: Response) => {\n\ttry {\n\t\tconst payload = JSON.parse(await response.text());\n\t\tif (\n\t\t\tisErrorPayload(payload) &&\n\t\t\ttypeof payload.error === 'string' &&\n\t\t\tpayload.error\n\t\t) {\n\t\t\treturn payload.error;\n\t\t}\n\t} catch {\n\t\t// fall through\n\t}\n\n\treturn `Request failed with status ${response.status}`;\n};\n\nconst getMaintenanceSummary = (\n\tpayload: RAGMaintenancePayload\n): RAGBackendMaintenanceSummary | undefined => payload?.maintenance;\n\nconst getMaintenanceAdmin = (\n\tpayload: RAGMaintenancePayload\n): RAGAdminCapabilities | undefined => payload?.admin;\n\nexport const buildRAGMaintenanceOverview = (\n\tpayload: RAGMaintenancePayload\n): RAGMaintenanceOverview => {\n\tconst summary = getMaintenanceSummary(payload);\n\tconst admin = getMaintenanceAdmin(payload);\n\tconst recommendations = summary?.recommendations ?? [];\n\tconst blockingRecommendations = recommendations.filter(\n\t\t(entry) => entry.severity === 'error'\n\t);\n\tconst recommendedNow = recommendations.filter(\n\t\t(entry) => entry.severity !== 'info'\n\t);\n\tconst recommendedActions = new Set(\n\t\trecommendations.flatMap((entry) => (entry.action ? [entry.action] : []))\n\t);\n\tconst actionReason = (kind: 'analyze_backend' | 'rebuild_native_index') =>\n\t\trecommendations.find((entry) => entry.action === kind)?.message;\n\n\tconst actions: RAGMaintenanceActionDescriptor[] = [\n\t\t{\n\t\t\tavailable: admin?.canAnalyzeBackend ?? false,\n\t\t\tkind: 'analyze_backend',\n\t\t\tlabel: 'Analyze backend',\n\t\t\treason: actionReason('analyze_backend'),\n\t\t\trecommended: recommendedActions.has('analyze_backend')\n\t\t},\n\t\t{\n\t\t\tavailable: admin?.canRebuildNativeIndex ?? false,\n\t\t\tkind: 'rebuild_native_index',\n\t\t\tlabel: 'Rebuild native index',\n\t\t\treason: actionReason('rebuild_native_index'),\n\t\t\trecommended: recommendedActions.has('rebuild_native_index')\n\t\t}\n\t];\n\n\treturn {\n\t\tactiveJobCount: summary?.activeJobs.length ?? 0,\n\t\tactions,\n\t\tavailableActions: actions.filter((action) => action.available),\n\t\tbackend: summary?.backend,\n\t\tblockingRecommendations,\n\t\tcriticalCount: blockingRecommendations.length,\n\t\thasBlockingIssue: blockingRecommendations.length > 0,\n\t\tinfoCount: recommendations.filter((entry) => entry.severity === 'info')\n\t\t\t.length,\n\t\tprimaryRecommendation: [...recommendations].sort((left, right) => {\n\t\t\tconst severityRank = { error: 0, warning: 1, info: 2 } as const;\n\t\t\treturn severityRank[left.severity] - severityRank[right.severity];\n\t\t})[0],\n\t\trecentlyCompletedActions: (summary?.recentActions ?? []).filter(\n\t\t\t(action) => action.status === 'completed'\n\t\t),\n\t\trecommendationCount: recommendations.length,\n\t\trecommendations,\n\t\trecommendedNow,\n\t\twarningCount: recommendations.filter(\n\t\t\t(entry) => entry.severity === 'warning'\n\t\t).length\n\t};\n};\n\nexport const createRAGClient = (options: RAGClientOptions) => {\n\tconst basePath = normalizeBasePath(options.path);\n\tconst fetchImpl = options.fetch ?? fetch;\n\n\tconst search = async <IncludeTrace extends boolean | undefined = undefined>(\n\t\tinput: RAGSearchRequest & { includeTrace?: IncludeTrace }\n\t): Promise<\n\t\tIncludeTrace extends true ? RAGDetailedSearchResponse : RAGSource[]\n\t> => {\n\t\tconst response = await fetchImpl(`${basePath}/search`, {\n\t\t\tbody: JSON.stringify(input),\n\t\t\theaders: jsonHeaders,\n\t\t\tmethod: 'POST'\n\t\t});\n\n\t\tif (!response.ok) {\n\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t}\n\n\t\tconst payload = await parseJson<RAGSearchResponse>(response);\n\n\t\tif (!payload.ok) {\n\t\t\tthrow new Error(payload.error ?? 'RAG search failed');\n\t\t}\n\n\t\tif (input.includeTrace === true) {\n\t\t\treturn {\n\t\t\t\tresults: payload.results ?? [],\n\t\t\t\ttrace: payload.trace\n\t\t\t} as IncludeTrace extends true\n\t\t\t\t? RAGDetailedSearchResponse\n\t\t\t\t: RAGSource[];\n\t\t}\n\n\t\treturn (payload.results ?? []) as IncludeTrace extends true\n\t\t\t? RAGDetailedSearchResponse\n\t\t\t: RAGSource[];\n\t};\n\n\treturn {\n\t\tasync backends() {\n\t\t\tconst response = await fetchImpl(`${basePath}/backends`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGBackendsResponse>(response);\n\t\t},\n\t\tasync clearIndex() {\n\t\t\tconst response = await fetchImpl(`${basePath}/index`, {\n\t\t\t\tmethod: 'DELETE'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<{ ok: boolean }>(response);\n\t\t},\n\t\tasync createDocument(\n\t\t\tinput: RAGDocumentIngestInput['documents'][number]\n\t\t) {\n\t\t\tconst response = await fetchImpl(`${basePath}/documents`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync deleteDocument(id: string) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/documents/${encodeURIComponent(id)}`,\n\t\t\t\t{\n\t\t\t\t\tmethod: 'DELETE'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync documentChunks(id: string) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/documents/${encodeURIComponent(id)}/chunks`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tconst error = await toErrorMessage(response);\n\n\t\t\t\tconst errorResponse: RAGDocumentChunksResponse = {\n\t\t\t\t\terror,\n\t\t\t\t\tok: false\n\t\t\t\t};\n\n\t\t\t\treturn errorResponse;\n\t\t\t}\n\n\t\t\treturn parseJson<RAGDocumentChunksResponse>(response);\n\t\t},\n\t\tasync documents(kind?: string) {\n\t\t\tconst query = kind ? `?kind=${encodeURIComponent(kind)}` : '';\n\t\t\tconst response = await fetchImpl(`${basePath}/documents${query}`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGDocumentsResponse>(response);\n\t\t},\n\t\tasync evaluate(input: RAGEvaluationInput) {\n\t\t\tconst response = await fetchImpl(`${basePath}/evaluate`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGEvaluationResponse>(response);\n\t\t},\n\t\tasync compareRetrievals(input: RAGRetrievalComparisonRequest) {\n\t\t\tconst response = await fetchImpl(`${basePath}/compare/retrieval`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalComparisonResponse>(response);\n\t\t\tif (!payload.ok || !payload.comparison) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval comparison failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.comparison;\n\t\t},\n\t\tasync retrievalComparisonHistory(input?: {\n\t\t\tlimit?: number;\n\t\t\tsuiteId?: string;\n\t\t\tlabel?: string;\n\t\t\twinnerId?: string;\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.suiteId) {\n\t\t\t\tsearchParams.set('suiteId', input.suiteId);\n\t\t\t}\n\t\t\tif (input?.label) {\n\t\t\t\tsearchParams.set('label', input.label);\n\t\t\t}\n\t\t\tif (input?.winnerId) {\n\t\t\t\tsearchParams.set('winnerId', input.winnerId);\n\t\t\t}\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalComparisonHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.runs) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval comparison history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.runs;\n\t\t},\n\t\tasync retrievalBaselines(input?: {\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'active' | 'superseded';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.status) {\n\t\t\t\tsearchParams.set('status', input.status);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineListResponse>(response);\n\t\t\tif (!payload.ok || !payload.baselines) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval baseline list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.baselines;\n\t\t},\n\t\tasync promoteRetrievalBaseline(\n\t\t\tinput: RAGRetrievalBaselinePromotionRequest\n\t\t) {\n\t\t\tconst payload = await this.promoteRetrievalBaselineDetailed(input);\n\t\t\treturn payload.baseline!;\n\t\t},\n\t\tasync promoteRetrievalBaselineDetailed(\n\t\t\tinput: RAGRetrievalBaselinePromotionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/promote`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineResponse>(response);\n\t\t\tif (!payload.ok || !payload.baseline) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval baseline promotion failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync promoteRetrievalBaselineToLane(\n\t\t\tinput: RAGRetrievalBaselinePromotionRequest & {\n\t\t\t\trolloutLabel: 'canary' | 'stable' | 'rollback_target';\n\t\t\t}\n\t\t) {\n\t\t\tconst payload =\n\t\t\t\tawait this.promoteRetrievalBaselineToLaneDetailed(input);\n\t\t\treturn payload.baseline!;\n\t\t},\n\t\tasync promoteRetrievalBaselineToLaneDetailed(\n\t\t\tinput: RAGRetrievalBaselinePromotionRequest & {\n\t\t\t\trolloutLabel: 'canary' | 'stable' | 'rollback_target';\n\t\t\t}\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/promote-lane`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineResponse>(response);\n\t\t\tif (!payload.ok || !payload.baseline) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval rollout-lane promotion failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync promoteRetrievalBaselineFromRun(\n\t\t\tinput: RAGRetrievalBaselinePromotionFromRunRequest\n\t\t) {\n\t\t\tconst payload =\n\t\t\t\tawait this.promoteRetrievalBaselineFromRunDetailed(input);\n\t\t\treturn payload.baseline!;\n\t\t},\n\t\tasync promoteRetrievalBaselineFromRunDetailed(\n\t\t\tinput: RAGRetrievalBaselinePromotionFromRunRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/promote-run`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineResponse>(response);\n\t\t\tif (!payload.ok || !payload.baseline) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval baseline promotion from run failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync revertRetrievalBaseline(\n\t\t\tinput: RAGRetrievalBaselineRevertRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/revert`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineResponse>(response);\n\t\t\tif (!payload.ok || !payload.baseline) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval baseline revert failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.baseline;\n\t\t},\n\t\tasync retrievalBaselineDecisions(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tkind?: 'approve' | 'promote' | 'reject' | 'revert';\n\t\t\tfreshnessStatus?: 'fresh' | 'expired' | 'not_applicable';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.kind) {\n\t\t\t\tsearchParams.set('kind', input.kind);\n\t\t\t}\n\t\t\tif (input?.freshnessStatus) {\n\t\t\t\tsearchParams.set('freshnessStatus', input.freshnessStatus);\n\t\t\t}\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/decisions${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.decisions) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release decision list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.decisions;\n\t\t},\n\t\tasync retrievalReleaseGroupHistory(input: {\n\t\t\tgroupKey: string;\n\t\t\tdecisionLimit?: number;\n\t\t\tbaselineLimit?: number;\n\t\t\tbenchmarkLimit?: number;\n\t\t\trunLimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\tif (typeof input.decisionLimit === 'number') {\n\t\t\t\tsearchParams.set('decisionLimit', String(input.decisionLimit));\n\t\t\t}\n\t\t\tif (typeof input.baselineLimit === 'number') {\n\t\t\t\tsearchParams.set('baselineLimit', String(input.baselineLimit));\n\t\t\t}\n\t\t\tif (typeof input.runLimit === 'number') {\n\t\t\t\tsearchParams.set('runLimit', String(input.runLimit));\n\t\t\t}\n\t\t\tif (typeof input.benchmarkLimit === 'number') {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'benchmarkLimit',\n\t\t\t\t\tString(input.benchmarkLimit)\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (input.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/release-history?${searchParams}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseGroupHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release group history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync adaptiveNativePlannerBenchmark(input?: {\n\t\t\tlimit?: number;\n\t\t\trunLimit?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tgroupKey?: string;\n\t\t\tcorpusGroupKey?: string;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (typeof input?.runLimit === 'number') {\n\t\t\t\tsearchParams.set('runLimit', String(input.runLimit));\n\t\t\t}\n\t\t\tif (input?.label) {\n\t\t\t\tsearchParams.set('label', input.label);\n\t\t\t}\n\t\t\tif (input?.description) {\n\t\t\t\tsearchParams.set('description', input.description);\n\t\t\t}\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('benchmarkGroupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.corpusGroupKey) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'benchmarkCorpusGroupKey',\n\t\t\t\t\tinput.corpusGroupKey\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/adaptive-native-planner${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGAdaptiveNativePlannerBenchmarkResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Adaptive native planner benchmark history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync runAdaptiveNativePlannerBenchmark(input?: {\n\t\t\tlimit?: number;\n\t\t\trunLimit?: number;\n\t\t\ttopK?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tgroupKey?: string;\n\t\t\tcorpusGroupKey?: string;\n\t\t\tpersistRun?: boolean;\n\t\t\tbaselineRetrievalId?: string;\n\t\t\tcandidateRetrievalId?: string;\n\t\t\tretrievals?: Array<{\n\t\t\t\tid: string;\n\t\t\t\tlabel?: string;\n\t\t\t\tretrieval?: Record<string, unknown> | string;\n\t\t\t}>;\n\t\t\ttags?: string[];\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/adaptive-native-planner/run`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify({\n\t\t\t\t\t\tbaselineRetrievalId: input?.baselineRetrievalId,\n\t\t\t\t\t\tcandidateRetrievalId: input?.candidateRetrievalId,\n\t\t\t\t\t\tcorpusGroupKey: input?.corpusGroupKey,\n\t\t\t\t\t\tdescription: input?.description,\n\t\t\t\t\t\tgroupKey: input?.groupKey,\n\t\t\t\t\t\tlabel: input?.label,\n\t\t\t\t\t\tlimit: input?.limit,\n\t\t\t\t\t\tmetadata: input?.metadata,\n\t\t\t\t\t\tpersistRun: input?.persistRun,\n\t\t\t\t\t\tretrievals: input?.retrievals,\n\t\t\t\t\t\trunLimit: input?.runLimit,\n\t\t\t\t\t\ttags: input?.tags,\n\t\t\t\t\t\ttopK: input?.topK\n\t\t\t\t\t}),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGAdaptiveNativePlannerBenchmarkResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Adaptive native planner benchmark run failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync saveAdaptiveNativePlannerBenchmarkSnapshot(input?: {\n\t\t\tlimit?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tversion?: number;\n\t\t\tcreatedAt?: number;\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t\tsnapshotMetadata?: Record<string, unknown>;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/adaptive-native-planner/snapshots`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify({\n\t\t\t\t\t\tcreatedAt: input?.createdAt,\n\t\t\t\t\t\tdescription: input?.description,\n\t\t\t\t\t\tlabel: input?.label,\n\t\t\t\t\t\tlimit: input?.limit,\n\t\t\t\t\t\tmetadata: input?.metadata,\n\t\t\t\t\t\tsnapshotMetadata: input?.snapshotMetadata,\n\t\t\t\t\t\tversion: input?.version\n\t\t\t\t\t}),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGAdaptiveNativePlannerBenchmarkSnapshotResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Adaptive native planner benchmark snapshot failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync nativeBackendComparisonBenchmark(input?: {\n\t\t\tlimit?: number;\n\t\t\trunLimit?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tgroupKey?: string;\n\t\t\tcorpusGroupKey?: string;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (typeof input?.runLimit === 'number') {\n\t\t\t\tsearchParams.set('runLimit', String(input.runLimit));\n\t\t\t}\n\t\t\tif (input?.label) {\n\t\t\t\tsearchParams.set('label', input.label);\n\t\t\t}\n\t\t\tif (input?.description) {\n\t\t\t\tsearchParams.set('description', input.description);\n\t\t\t}\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('benchmarkGroupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.corpusGroupKey) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'benchmarkCorpusGroupKey',\n\t\t\t\t\tinput.corpusGroupKey\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/native-backend-comparison${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGNativeBackendComparisonBenchmarkResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Native backend comparison benchmark history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync runNativeBackendComparisonBenchmark(input?: {\n\t\t\tlimit?: number;\n\t\t\trunLimit?: number;\n\t\t\ttopK?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tgroupKey?: string;\n\t\t\tcorpusGroupKey?: string;\n\t\t\tpersistRun?: boolean;\n\t\t\tbaselineRetrievalId?: string;\n\t\t\tcandidateRetrievalId?: string;\n\t\t\tretrievals?: Array<{\n\t\t\t\tid: string;\n\t\t\t\tlabel?: string;\n\t\t\t\tretrieval?: Record<string, unknown> | string;\n\t\t\t}>;\n\t\t\ttags?: string[];\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/native-backend-comparison/run`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify({\n\t\t\t\t\t\tbaselineRetrievalId: input?.baselineRetrievalId,\n\t\t\t\t\t\tcandidateRetrievalId: input?.candidateRetrievalId,\n\t\t\t\t\t\tcorpusGroupKey: input?.corpusGroupKey,\n\t\t\t\t\t\tdescription: input?.description,\n\t\t\t\t\t\tgroupKey: input?.groupKey,\n\t\t\t\t\t\tlabel: input?.label,\n\t\t\t\t\t\tlimit: input?.limit,\n\t\t\t\t\t\tmetadata: input?.metadata,\n\t\t\t\t\t\tpersistRun: input?.persistRun,\n\t\t\t\t\t\tretrievals: input?.retrievals,\n\t\t\t\t\t\trunLimit: input?.runLimit,\n\t\t\t\t\t\ttags: input?.tags,\n\t\t\t\t\t\ttopK: input?.topK\n\t\t\t\t\t}),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGNativeBackendComparisonBenchmarkResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Native backend comparison benchmark run failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync saveNativeBackendComparisonBenchmarkSnapshot(input?: {\n\t\t\tlimit?: number;\n\t\t\tlabel?: string;\n\t\t\tdescription?: string;\n\t\t\tversion?: number;\n\t\t\tcreatedAt?: number;\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t\tsnapshotMetadata?: Record<string, unknown>;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/benchmarks/native-backend-comparison/snapshots`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify({\n\t\t\t\t\t\tcreatedAt: input?.createdAt,\n\t\t\t\t\t\tdescription: input?.description,\n\t\t\t\t\t\tlabel: input?.label,\n\t\t\t\t\t\tlimit: input?.limit,\n\t\t\t\t\t\tmetadata: input?.metadata,\n\t\t\t\t\t\tsnapshotMetadata: input?.snapshotMetadata,\n\t\t\t\t\t\tversion: input?.version\n\t\t\t\t\t}),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGNativeBackendComparisonBenchmarkSnapshotResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Native backend comparison benchmark snapshot failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync retrievalLaneHandoffs(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tsourceRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tlimit?: number;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.sourceRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'sourceRolloutLabel',\n\t\t\t\t\tinput.sourceRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffListResponse>(response);\n\t\t\tif (!payload.ok || !payload.handoffs) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval lane handoff list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.handoffs;\n\t\t},\n\t\tasync retrievalLaneHandoffDecisions(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tsourceRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tkind?: 'approve' | 'reject' | 'complete';\n\t\t\tlimit?: number;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.sourceRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'sourceRolloutLabel',\n\t\t\t\t\tinput.sourceRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (input?.kind) {\n\t\t\t\tsearchParams.set('kind', input.kind);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/decisions${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.decisions) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff decision list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.decisions;\n\t\t},\n\t\tasync retrievalLaneHandoffIncidents(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'open' | 'resolved';\n\t\t\tseverity?: 'warning' | 'critical';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) searchParams.set('groupKey', input.groupKey);\n\t\t\tif (typeof input?.limit === 'number')\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\tif (input?.status) searchParams.set('status', input.status);\n\t\t\tif (input?.severity) searchParams.set('severity', input.severity);\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/incidents${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff incident list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync retrievalLaneHandoffIncidentHistory(input?: {\n\t\t\taction?: 'opened' | 'acknowledged' | 'unacknowledged' | 'resolved';\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/incidents/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffIncidentHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff incident history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalLaneHandoffAutoCompletePolicyHistory(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/policies/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffAutoCompletePolicyHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff auto-complete policy history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalReleaseLanePolicyHistory(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\trolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tscope?: 'rollout_label' | 'group_rollout_label';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/release-policies/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseLanePolicyHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release lane policy history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalBaselineGatePolicyHistory(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\trolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tscope?: 'rollout_label' | 'group_rollout_label';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/gate-policies/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalBaselineGatePolicyHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval baseline gate policy history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalReleaseLaneEscalationPolicyHistory(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/escalation-policies/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseLaneEscalationPolicyHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release lane escalation policy history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalReleaseIncidentPolicyHistory(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incident-policies/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseLaneEscalationPolicyHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release incident policy history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalReleaseIncidentStatus() {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/status/release/incidents`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalReleaseIncidentStatusResponse>(\n\t\t\t\tresponse\n\t\t\t);\n\t\t},\n\t\tasync retrievalIncidentRemediationStatus() {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/status/release/remediations`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalIncidentRemediationStatusResponse>(\n\t\t\t\tresponse\n\t\t\t);\n\t\t},\n\t\tasync retrievalLaneHandoffIncidentStatus() {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/status/handoffs/incidents`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalLaneHandoffIncidentStatusResponse>(\n\t\t\t\tresponse\n\t\t\t);\n\t\t},\n\t\tasync acknowledgeRetrievalLaneHandoffIncident(\n\t\t\tinput: RAGRetrievalReleaseIncidentAcknowledgeRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/incidents/acknowledge`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff incident acknowledgement failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync unacknowledgeRetrievalLaneHandoffIncident(input: {\n\t\t\tincidentId: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/incidents/unacknowledge`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff incident unacknowledge failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync resolveRetrievalLaneHandoffIncident(input: {\n\t\t\tincidentId: string;\n\t\t\tresolvedAt?: number;\n\t\t\tresolvedBy?: string;\n\t\t\tresolutionNotes?: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/incidents/resolve`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff incident resolve failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync decideRetrievalLaneHandoff(\n\t\t\tinput: RAGRetrievalLaneHandoffDecisionRequest\n\t\t) {\n\t\t\tconst payload =\n\t\t\t\tawait this.decideRetrievalLaneHandoffDetailed(input);\n\t\t\tif (!payload.decision) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval lane handoff decision failed'\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn payload.decision;\n\t\t},\n\t\tasync decideRetrievalLaneHandoffDetailed(\n\t\t\tinput: RAGRetrievalLaneHandoffDecisionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/handoffs/decide`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalLaneHandoffDecisionResponse>(response);\n\t\t},\n\t\tasync retrievalReleaseIncidents(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\tstatus?: 'open' | 'resolved';\n\t\t\tseverity?: 'warning' | 'critical';\n\t\t\tkind?:\n\t\t\t\t| 'approval_expired'\n\t\t\t\t| 'baseline_regression'\n\t\t\t\t| 'gate_failure'\n\t\t\t\t| 'handoff_stale';\n\t\t\tacknowledged?: boolean;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.status) {\n\t\t\t\tsearchParams.set('status', input.status);\n\t\t\t}\n\t\t\tif (input?.severity) {\n\t\t\t\tsearchParams.set('severity', input.severity);\n\t\t\t}\n\t\t\tif (input?.kind) {\n\t\t\t\tsearchParams.set('kind', input.kind);\n\t\t\t}\n\t\t\tif (typeof input?.acknowledged === 'boolean') {\n\t\t\t\tsearchParams.set('acknowledged', String(input.acknowledged));\n\t\t\t}\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release incident list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync retrievalIncidentRemediationDecisions(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\tremediationKind?: RAGRetrievalIncidentRemediationDecisionRequest['remediationKind'];\n\t\t\tstatus?: 'planned' | 'applied' | 'dismissed';\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/remediations${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalIncidentRemediationDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval incident remediation decision list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync retrievalIncidentRemediationExecutions(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tincidentId?: string;\n\t\t\tlimit?: number;\n\t\t\tactionKind?: RAGRetrievalIncidentRemediationExecutionRequest['action']['kind'];\n\t\t\tcode?: NonNullable<\n\t\t\t\tRAGRetrievalIncidentRemediationExecutionResponse['execution']\n\t\t\t>['code'];\n\t\t\tblockedByGuardrail?: boolean;\n\t\t\tidempotentReplay?: boolean;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t}) {\n\t\t\tconst suffix = input\n\t\t\t\t? `?${new URLSearchParams(\n\t\t\t\t\t\tObject.entries(input)\n\t\t\t\t\t\t\t.filter(([, value]) => value !== undefined)\n\t\t\t\t\t\t\t.map(([key, value]) => [key, String(value)])\n\t\t\t\t\t).toString()}`\n\t\t\t\t: '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/remediations/executions${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalIncidentRemediationExecutionHistoryResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval incident remediation execution history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync recordRetrievalIncidentRemediationDecision(\n\t\t\tinput: RAGRetrievalIncidentRemediationDecisionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/remediations`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalIncidentRemediationDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.records) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval incident remediation decision record failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.records;\n\t\t},\n\t\tasync executeRetrievalIncidentRemediation(\n\t\t\tinput: RAGRetrievalIncidentRemediationExecutionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/remediations/execute`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalIncidentRemediationExecutionResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.execution) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval incident remediation execution failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync bulkExecuteRetrievalIncidentRemediations(\n\t\t\tinput: RAGRetrievalIncidentRemediationBulkExecutionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/remediations/execute/bulk`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalIncidentRemediationBulkExecutionResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.results) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'Bulk RAG retrieval incident remediation execution failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.results;\n\t\t},\n\t\tasync acknowledgeRetrievalReleaseIncident(\n\t\t\tinput: RAGRetrievalReleaseIncidentAcknowledgeRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/acknowledge`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release incident acknowledgement failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync unacknowledgeRetrievalReleaseIncident(input: {\n\t\t\tincidentId: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/unacknowledge`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release incident unacknowledge failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync resolveRetrievalReleaseIncident(input: {\n\t\t\tincidentId: string;\n\t\t\tresolvedAt?: number;\n\t\t\tresolvedBy?: string;\n\t\t\tresolutionNotes?: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/incidents/resolve`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseIncidentListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.incidents) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval release incident resolve failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.incidents;\n\t\t},\n\t\tasync retrievalPromotionCandidates(input?: {\n\t\t\tgroupKey?: string;\n\t\t\tlimit?: number;\n\t\t\ttag?: string;\n\t\t\ttargetRolloutLabel?: 'canary' | 'stable' | 'rollback_target';\n\t\t\tapproved?: boolean;\n\t\t\tready?: boolean;\n\t\t\tblocked?: boolean;\n\t\t\treviewStatus?: 'approved' | 'blocked' | 'needs_review' | 'ready';\n\t\t\tfreshnessStatus?: 'fresh' | 'expired' | 'not_applicable';\n\t\t\tsortBy?:\n\t\t\t\t| 'approvalFreshness'\n\t\t\t\t| 'finishedAt'\n\t\t\t\t| 'gateSeverity'\n\t\t\t\t| 'priority';\n\t\t\tsortDirection?: 'asc' | 'desc';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tif (input?.targetRolloutLabel) {\n\t\t\t\tsearchParams.set(\n\t\t\t\t\t'targetRolloutLabel',\n\t\t\t\t\tinput.targetRolloutLabel\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (typeof input?.approved === 'boolean') {\n\t\t\t\tsearchParams.set('approved', String(input.approved));\n\t\t\t}\n\t\t\tif (typeof input?.ready === 'boolean') {\n\t\t\t\tsearchParams.set('ready', String(input.ready));\n\t\t\t}\n\t\t\tif (typeof input?.blocked === 'boolean') {\n\t\t\t\tsearchParams.set('blocked', String(input.blocked));\n\t\t\t}\n\t\t\tif (input?.reviewStatus) {\n\t\t\t\tsearchParams.set('reviewStatus', input.reviewStatus);\n\t\t\t}\n\t\t\tif (input?.freshnessStatus) {\n\t\t\t\tsearchParams.set('freshnessStatus', input.freshnessStatus);\n\t\t\t}\n\t\t\tif (input?.sortBy) {\n\t\t\t\tsearchParams.set('sortBy', input.sortBy);\n\t\t\t}\n\t\t\tif (input?.sortDirection) {\n\t\t\t\tsearchParams.set('sortDirection', input.sortDirection);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/candidates${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalPromotionCandidateListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.candidates) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ??\n\t\t\t\t\t\t'RAG retrieval promotion candidate list failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.candidates;\n\t\t},\n\t\tasync approveRetrievalCandidate(\n\t\t\tinput: RAGRetrievalReleaseDecisionActionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/approve`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.decisions) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval approval failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.decisions;\n\t\t},\n\t\tasync rejectRetrievalCandidate(\n\t\t\tinput: RAGRetrievalReleaseDecisionActionRequest\n\t\t) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/compare/retrieval/baselines/reject`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseDecisionListResponse>(\n\t\t\t\t\tresponse\n\t\t\t\t);\n\t\t\tif (!payload.ok || !payload.decisions) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG retrieval rejection failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.decisions;\n\t\t},\n\t\tasync ingest(chunks: RAGDocumentChunk[]) {\n\t\t\tconst response = await fetchImpl(`${basePath}/ingest`, {\n\t\t\t\tbody: JSON.stringify({ chunks }),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGIngestResponse>(response);\n\t\t},\n\t\tasync ingestDocuments(input: RAGDocumentIngestInput) {\n\t\t\tconst response = await fetchImpl(`${basePath}/ingest`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGIngestResponse>(response);\n\t\t},\n\t\tasync ingestUploads(input: RAGDocumentUploadIngestInput) {\n\t\t\tconst response = await fetchImpl(`${basePath}/ingest`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGIngestResponse>(response);\n\t\t},\n\t\tasync ingestUrls(input: RAGDocumentUrlIngestInput) {\n\t\t\tconst response = await fetchImpl(`${basePath}/ingest`, {\n\t\t\t\tbody: JSON.stringify(input),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGIngestResponse>(response);\n\t\t},\n\t\tasync analyzeBackend() {\n\t\t\tconst response = await fetchImpl(`${basePath}/backend/analyze`, {\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync ops() {\n\t\t\tconst response = await fetchImpl(`${basePath}/ops`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGOperationsResponse>(response);\n\t\t},\n\t\tasync searchTraceHistory(input?: {\n\t\t\tquery?: string;\n\t\t\tgroupKey?: string;\n\t\t\ttag?: string;\n\t\t\tlimit?: number;\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.query) {\n\t\t\t\tsearchParams.set('query', input.query);\n\t\t\t}\n\t\t\tif (input?.groupKey) {\n\t\t\t\tsearchParams.set('groupKey', input.groupKey);\n\t\t\t}\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(`${basePath}/traces${suffix}`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTraceHistoryResponse>(response);\n\t\t\tif (!payload.ok || !payload.history) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.history;\n\t\t},\n\t\tasync searchTraceGroups(input?: { tag?: string; limit?: number }) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/traces/groups${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTraceGroupHistoryResponse>(response);\n\t\t\tif (!payload.ok || !payload.history) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace group history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.history;\n\t\t},\n\t\tasync searchTraceStats(input?: { tag?: string }) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (input?.tag) {\n\t\t\t\tsearchParams.set('tag', input.tag);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/traces/stats${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTraceStatsResponse>(response);\n\t\t\tif (!payload.ok || !payload.stats) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace stats failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.stats;\n\t\t},\n\t\tasync previewSearchTracePrune(input?: {\n\t\t\tmaxAgeMs?: number;\n\t\t\tmaxRecordsPerQuery?: number;\n\t\t\tmaxRecordsPerGroup?: number;\n\t\t\tnow?: number;\n\t\t\ttag?: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/traces/prune/preview`,\n\t\t\t\t{\n\t\t\t\t\tbody: JSON.stringify(input ?? {}),\n\t\t\t\t\theaders: jsonHeaders,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTracePrunePreviewResponse>(response);\n\t\t\tif (!payload.ok || !payload.preview) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace prune preview failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.preview;\n\t\t},\n\t\tasync pruneSearchTraces(input?: {\n\t\t\tmaxAgeMs?: number;\n\t\t\tmaxRecordsPerQuery?: number;\n\t\t\tmaxRecordsPerGroup?: number;\n\t\t\tnow?: number;\n\t\t\ttag?: string;\n\t\t}) {\n\t\t\tconst response = await fetchImpl(`${basePath}/traces/prune`, {\n\t\t\t\tbody: JSON.stringify(input ?? {}),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTracePruneResponse>(response);\n\t\t\tif (!payload.ok || !payload.result) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace prune failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload;\n\t\t},\n\t\tasync searchTracePruneHistory(input?: {\n\t\t\tlimit?: number;\n\t\t\ttrigger?: 'manual' | 'write' | 'schedule';\n\t\t}) {\n\t\t\tconst searchParams = new URLSearchParams();\n\t\t\tif (typeof input?.limit === 'number') {\n\t\t\t\tsearchParams.set('limit', String(input.limit));\n\t\t\t}\n\t\t\tif (input?.trigger) {\n\t\t\t\tsearchParams.set('trigger', input.trigger);\n\t\t\t}\n\t\t\tconst suffix = searchParams.size > 0 ? `?${searchParams}` : '';\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/traces/prune/history${suffix}`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGSearchTracePruneHistoryResponse>(response);\n\t\t\tif (!payload.ok || !payload.runs) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\tpayload.error ?? 'RAG search trace prune history failed'\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn payload.runs;\n\t\t},\n\t\tasync syncSources() {\n\t\t\tconst response = await fetchImpl(`${basePath}/sync`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGSyncResponse>(response);\n\t\t},\n\t\tasync syncAllSources(options?: RAGSyncRunOptions) {\n\t\t\tconst response = await fetchImpl(`${basePath}/sync`, {\n\t\t\t\tbody:\n\t\t\t\t\toptions?.background === true\n\t\t\t\t\t\t? JSON.stringify({ background: true })\n\t\t\t\t\t\t: undefined,\n\t\t\t\theaders: options?.background === true ? jsonHeaders : undefined,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t} satisfies RAGSyncResponse;\n\t\t\t}\n\n\t\t\treturn parseJson<RAGSyncResponse>(response);\n\t\t},\n\t\tasync syncSource(id: string, options?: RAGSyncRunOptions) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/sync/${encodeURIComponent(id)}`,\n\t\t\t\t{\n\t\t\t\t\tbody:\n\t\t\t\t\t\toptions?.background === true\n\t\t\t\t\t\t\t? JSON.stringify({ background: true })\n\t\t\t\t\t\t\t: undefined,\n\t\t\t\t\theaders:\n\t\t\t\t\t\toptions?.background === true ? jsonHeaders : undefined,\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t} satisfies RAGSyncResponse;\n\t\t\t}\n\n\t\t\treturn parseJson<RAGSyncResponse>(response);\n\t\t},\n\t\tasync reindexDocument(id: string) {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/reindex/documents/${encodeURIComponent(id)}`,\n\t\t\t\t{\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync reindexSource(source: string) {\n\t\t\tconst response = await fetchImpl(`${basePath}/reindex/source`, {\n\t\t\t\tbody: JSON.stringify({ source }),\n\t\t\t\theaders: jsonHeaders,\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync reseed() {\n\t\t\tconst response = await fetchImpl(`${basePath}/reseed`, {\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync reset() {\n\t\t\tconst response = await fetchImpl(`${basePath}/reset`, {\n\t\t\t\tmethod: 'POST'\n\t\t\t});\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tasync rebuildNativeIndex() {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/backend/reindex-native`,\n\t\t\t\t{\n\t\t\t\t\tmethod: 'POST'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\treturn {\n\t\t\t\t\terror: await toErrorMessage(response),\n\t\t\t\t\tok: false\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn parseJson<RAGMutationResponse>(response);\n\t\t},\n\t\tsearch,\n\t\tasync searchWithTrace(input: RAGSearchRequest) {\n\t\t\treturn search({ ...input, includeTrace: true });\n\t\t},\n\t\t/**\n\t\t * @deprecated Use `searchWithTrace` for trace-aware search responses.\n\t\t */\n\t\tasync searchDetailed(input: RAGSearchRequest) {\n\t\t\treturn search({ ...input, includeTrace: true });\n\t\t},\n\t\tasync status() {\n\t\t\tconst response = await fetchImpl(`${basePath}/status`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGStatusResponse>(response);\n\t\t},\n\t\tasync statusMaintenance() {\n\t\t\tconst response = await fetchImpl(`${basePath}/status/maintenance`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGStatusResponse>(response);\n\t\t},\n\t\tasync retrievalReleaseStatus() {\n\t\t\tconst response = await fetchImpl(`${basePath}/status/release`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\tconst payload =\n\t\t\t\tawait parseJson<RAGRetrievalReleaseStatusResponse>(response);\n\t\t\treturn payload.retrievalComparisons;\n\t\t},\n\t\tasync retrievalReleaseDriftStatus() {\n\t\t\tconst response = await fetchImpl(\n\t\t\t\t`${basePath}/status/release/drift`\n\t\t\t);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalReleaseDriftStatusResponse>(response);\n\t\t},\n\t\tasync retrievalLaneHandoffStatus() {\n\t\t\tconst response = await fetchImpl(`${basePath}/status/handoffs`);\n\n\t\t\tif (!response.ok) {\n\t\t\t\tthrow new Error(await toErrorMessage(response));\n\t\t\t}\n\n\t\t\treturn parseJson<RAGRetrievalLaneHandoffStatusResponse>(response);\n\t\t}\n\t};\n};\n\nexport type RAGClient = ReturnType<typeof createRAGClient>;\n"
10
+ "import type {\n RAGAdminActionPresentation,\n RAGAdminActionRecord,\n RAGAdminJobPresentation,\n RAGAdminJobRecord,\n AIMessage,\n RAGAnswerGroundingCaseSnapshotPresentation,\n RAGAnswerGroundingEvaluationCaseDiff,\n RAGAnswerGroundingEvaluationHistory,\n RAGAnswerGroundingEntityQualitySummary,\n RAGAnswerGroundingEntityQualityView,\n RAGAnswerGroundingEvaluationResponse,\n RAGCorpusHealth,\n RAGCorpusHealthPresentation,\n RAGExtractorReadiness,\n RAGReadinessPresentation,\n RAGGroundingOverviewPresentation,\n RAGGroundingProviderCaseComparisonPresentation,\n RAGGroundingProviderOverviewPresentation,\n RAGGroundingProviderPresentation,\n RAGComparisonOverviewPresentation,\n RAGComparisonPresentation,\n RAGChunkGraph,\n RAGChunkExcerpts,\n RAGExcerptModeCounts,\n RAGExcerptPromotionReason,\n RAGExcerptSelection,\n RAGChunkGraphEdge,\n RAGChunkGraphNavigation,\n RAGChunkGraphNode,\n RAGChunkGraphSectionGroup,\n RAGChunkStructure,\n RAGDocumentChunkPreview,\n RAGLabelValueRow,\n RAGRerankerComparisonEntry,\n RAGRetrievalComparison,\n RAGRetrievalComparisonEntry,\n RAGRetrievalComparisonRun,\n RAGRetrievalReleaseGroupHistoryPresentation,\n RAGRetrievalReleaseHistoryRunPresentation,\n RAGRetrievalReleaseTimelineSummary,\n RAGRetrievalTraceHistoryWindow,\n RAGRetrievalTraceStep,\n RAGRetrievalTrace,\n RAGHybridRetrievalMode,\n RAGSourceBalanceStrategy,\n RAGQualityOverviewPresentation,\n RAGSectionRetrievalDiagnostic,\n RAGEvaluationCaseDiff,\n RAGEvaluationCaseTracePresentation,\n RAGEvaluationEntityQualitySummary,\n RAGEvaluationEntityQualityView,\n RAGEvaluationHistory,\n RAGAnswerGroundingHistoryPresentation,\n RAGEvaluationResponse,\n RAGEvaluationHistoryPresentation,\n RAGEvaluationHistoryStore,\n RAGEvaluationSuiteSnapshotHistory,\n RAGEvaluationSuiteSnapshotHistoryPresentation,\n RAGEvaluationSuiteSnapshotPresentation,\n RAGEntityQualityPresentation,\n RAGEntityQualityViewPresentation,\n RAGRerankerComparison,\n RAGAnswerWorkflowState,\n RAGRetrievalTracePresentation,\n RAGSource,\n RAGSourceLabels,\n RAGSourceGroup,\n RAGSourceSummary,\n RAGStreamStage,\n RAGSyncOverviewPresentation,\n RAGSyncSourcePresentation,\n RAGSyncSourceRecord,\n RAGSyncSourceRunPresentation,\n} from \"@absolutejs/ai\";\nimport {\n buildRAGCitationReferenceMap,\n buildRAGCitations,\n buildRAGGroundedAnswer,\n buildRAGGroundedAnswerSectionSummaries,\n buildRAGGroundingReferences,\n} from \"./grounding\";\nimport {\n buildRAGAnswerGroundingEntityQualityView,\n buildRAGEvaluationEntityQualityView,\n} from \"./quality\";\n\nexport {\n buildRAGCitationReferenceMap,\n buildRAGCitations,\n buildRAGGroundedAnswer,\n buildRAGGroundedAnswerSectionSummaries,\n buildRAGGroundingReferences,\n};\n\nconst buildSourceGroupKey = (source: RAGSource) =>\n source.source ?? source.title ?? source.chunkId;\n\nconst buildSourceLabel = (source: RAGSource) =>\n source.source ?? source.title ?? source.chunkId;\n\nconst getContextNumber = (value: unknown) =>\n typeof value === \"number\" && Number.isFinite(value) ? value : undefined;\n\nconst getContextString = (value: unknown) =>\n typeof value === \"string\" && value.trim().length > 0\n ? value.trim()\n : undefined;\n\nconst isRAGRetrievalTrace = (value: unknown): value is RAGRetrievalTrace => {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n\n const candidate = value as Record<string, unknown>;\n\n return (\n typeof candidate.query === \"string\" &&\n typeof candidate.transformedQuery === \"string\" &&\n Array.isArray(candidate.variantQueries) &&\n Array.isArray(candidate.steps)\n );\n};\n\nconst formatTimestampLabel = (value: unknown) => {\n const timestamp =\n typeof value === \"number\" && Number.isFinite(value)\n ? value\n : typeof value === \"string\"\n ? Date.parse(value)\n : Number.NaN;\n if (!Number.isFinite(timestamp)) {\n return undefined;\n }\n\n return new Date(timestamp).toLocaleString(\"en-US\", {\n dateStyle: \"medium\",\n timeStyle: \"short\",\n });\n};\n\nconst formatRAGTraceValue = (value: unknown): string => {\n if (typeof value === \"string\") return value;\n if (typeof value === \"number\" || typeof value === \"boolean\") {\n return String(value);\n }\n if (Array.isArray(value)) {\n return value.join(\", \");\n }\n if (value && typeof value === \"object\") {\n return JSON.stringify(value);\n }\n return \"n/a\";\n};\n\nconst formatLeadContinuityCue = (value: unknown) => {\n const cue = getContextString(value);\n switch (cue) {\n case \"immediate_follow_up\":\n return \"Immediate follow-up\";\n case \"near_follow_up\":\n return \"Near follow-up\";\n case \"close_follow_up\":\n return \"Close follow-up\";\n case \"delayed_follow_up\":\n return \"Delayed follow-up\";\n case \"immediate_prior\":\n return \"Immediate prior segment\";\n case \"near_prior\":\n return \"Near prior segment\";\n case \"close_prior\":\n return \"Close prior segment\";\n case \"delayed_prior\":\n return \"Delayed prior segment\";\n default:\n return undefined;\n }\n};\n\nconst formatLeadSpeakerAttributionCue = (value: unknown) => {\n const cue = getContextString(value);\n switch (cue) {\n case \"quoted_match\":\n return \"Quoted speaker match\";\n default:\n return undefined;\n }\n};\n\nconst formatLeadChannelAttributionCue = (value: unknown) => {\n const cue = getContextString(value);\n switch (cue) {\n case \"quoted_match\":\n return \"Quoted channel match\";\n default:\n return undefined;\n }\n};\n\nconst formatLeadMediaCueSummary = (input?: {\n leadSpeakerCue?: string;\n leadSpeakerAttributionCue?: string;\n leadChannelCue?: string;\n leadChannelAttributionCue?: string;\n leadContinuityCue?: string;\n}) => {\n const parts = [\n input?.leadSpeakerCue ? `speaker ${input.leadSpeakerCue}` : undefined,\n input?.leadSpeakerAttributionCue === \"quoted_match\"\n ? \"quoted speaker match\"\n : undefined,\n input?.leadChannelCue ? `channel ${input.leadChannelCue}` : undefined,\n input?.leadChannelAttributionCue === \"quoted_match\"\n ? \"quoted channel match\"\n : undefined,\n formatLeadContinuityCue(input?.leadContinuityCue),\n ].filter(\n (value): value is string => typeof value === \"string\" && value.length > 0,\n );\n\n return parts.length > 0 ? parts.join(\" · \") : \"none\";\n};\n\nconst formatRAGTraceMetadataRow = (\n key: string,\n value: unknown,\n): RAGLabelValueRow => ({\n label:\n key === \"sqliteQueryMode\"\n ? \"SQLite query mode\"\n : key === \"postgresQueryMode\"\n ? \"Postgres query mode\"\n : key === \"sqliteQueryPushdownMode\"\n ? \"SQLite pushdown mode\"\n : key === \"postgresQueryPushdownMode\"\n ? \"Postgres pushdown mode\"\n : key === \"sqliteQueryPushdownApplied\"\n ? \"SQLite pushdown applied\"\n : key === \"postgresQueryPushdownApplied\"\n ? \"Postgres pushdown applied\"\n : key === \"sqliteQueryPushdownClauseCount\"\n ? \"SQLite pushdown clauses\"\n : key === \"postgresQueryPushdownClauseCount\"\n ? \"Postgres pushdown clauses\"\n : key === \"sqliteQueryPushdownCoverageRatio\"\n ? \"SQLite pushdown coverage\"\n : key === \"postgresQueryPushdownCoverageRatio\"\n ? \"Postgres pushdown coverage\"\n : key === \"sqliteQueryTotalFilterClauseCount\"\n ? \"SQLite total filter clauses\"\n : key === \"postgresQueryTotalFilterClauseCount\"\n ? \"Postgres total filter clauses\"\n : key === \"sqliteQueryJsRemainderClauseCount\"\n ? \"SQLite JS remainder clauses\"\n : key === \"sqliteQueryMultiplierUsed\"\n ? \"SQLite query multiplier\"\n : key === \"sqliteQueryPlannerProfileUsed\"\n ? \"SQLite query profile\"\n : key === \"sqliteQueryCandidateLimitUsed\"\n ? \"SQLite candidate limit\"\n : key === \"sqliteQueryMaxBackfillsUsed\"\n ? \"SQLite max backfills\"\n : key === \"sqliteQueryMinResultsUsed\"\n ? \"SQLite min results\"\n : key === \"sqliteQueryFillPolicyUsed\"\n ? \"SQLite fill policy\"\n : key ===\n \"postgresQueryJsRemainderClauseCount\"\n ? \"Postgres JS remainder clauses\"\n : key ===\n \"postgresQueryMultiplierUsed\"\n ? \"Postgres query multiplier\"\n : key ===\n \"postgresQueryPlannerProfileUsed\"\n ? \"Postgres query profile\"\n : key ===\n \"postgresQueryCandidateLimitUsed\"\n ? \"Postgres candidate limit\"\n : key ===\n \"postgresQueryMaxBackfillsUsed\"\n ? \"Postgres max backfills\"\n : key ===\n \"postgresQueryMinResultsUsed\"\n ? \"Postgres min results\"\n : key ===\n \"postgresQueryFillPolicyUsed\"\n ? \"Postgres fill policy\"\n : key ===\n \"sqliteQueryJsRemainderRatio\"\n ? \"SQLite JS remainder share\"\n : key ===\n \"postgresQueryJsRemainderRatio\"\n ? \"Postgres JS remainder share\"\n : key ===\n \"sqliteQueryFilteredCandidates\"\n ? \"SQLite filtered candidates\"\n : key ===\n \"postgresQueryFilteredCandidates\"\n ? \"Postgres filtered candidates\"\n : key ===\n \"sqliteQueryInitialSearchK\"\n ? \"SQLite initial searchK\"\n : key ===\n \"postgresQueryInitialSearchK\"\n ? \"Postgres initial searchK\"\n : key ===\n \"sqliteQueryFinalSearchK\"\n ? \"SQLite final searchK\"\n : key ===\n \"postgresQueryFinalSearchK\"\n ? \"Postgres final searchK\"\n : key ===\n \"sqliteQuerySearchExpansionRatio\"\n ? \"SQLite search expansion\"\n : key ===\n \"postgresQuerySearchExpansionRatio\"\n ? \"Postgres search expansion\"\n : key ===\n \"sqliteQueryBackfillCount\"\n ? \"SQLite backfill count\"\n : key ===\n \"sqliteQueryBackfillLimitReached\"\n ? \"SQLite backfill limit reached\"\n : key ===\n \"sqliteQueryMinResultsSatisfied\"\n ? \"SQLite min results satisfied\"\n : key ===\n \"postgresQueryBackfillCount\"\n ? \"Postgres backfill count\"\n : key ===\n \"postgresQueryBackfillLimitReached\"\n ? \"Postgres backfill limit reached\"\n : key ===\n \"postgresQueryMinResultsSatisfied\"\n ? \"Postgres min results satisfied\"\n : key ===\n \"sqliteQueryReturnedCount\"\n ? \"SQLite returned hits\"\n : key ===\n \"postgresQueryReturnedCount\"\n ? \"Postgres returned hits\"\n : key ===\n \"sqliteQueryCandidateYieldRatio\"\n ? \"SQLite candidate yield\"\n : key ===\n \"postgresQueryCandidateYieldRatio\"\n ? \"Postgres candidate yield\"\n : key ===\n \"sqliteQueryTopKFillRatio\"\n ? \"SQLite topK fill rate\"\n : key ===\n \"postgresQueryTopKFillRatio\"\n ? \"Postgres topK fill rate\"\n : key ===\n \"sqliteQueryUnderfilledTopK\"\n ? \"SQLite underfilled topK\"\n : key ===\n \"postgresQueryUnderfilledTopK\"\n ? \"Postgres underfilled topK\"\n : key ===\n \"sqliteQueryCandidateBudgetExhausted\"\n ? \"SQLite candidate budget exhausted\"\n : key ===\n \"postgresQueryCandidateBudgetExhausted\"\n ? \"Postgres candidate budget exhausted\"\n : key ===\n \"sqliteQueryCandidateCoverage\"\n ? \"SQLite candidate coverage\"\n : key ===\n \"postgresQueryCandidateCoverage\"\n ? \"Postgres candidate coverage\"\n : key ===\n \"postgresIndexType\"\n ? \"Postgres index type\"\n : key ===\n \"postgresIndexName\"\n ? \"Postgres index name\"\n : key ===\n \"postgresIndexPresent\"\n ? \"Postgres index present\"\n : key ===\n \"postgresEstimatedRowCount\"\n ? \"Postgres estimated rows\"\n : key ===\n \"postgresTableBytes\"\n ? \"Postgres table bytes\"\n : key ===\n \"postgresIndexBytes\"\n ? \"Postgres index bytes\"\n : key ===\n \"postgresTotalBytes\"\n ? \"Postgres total bytes\"\n : key ===\n \"postgresIndexStorageRatio\"\n ? \"Postgres index storage ratio\"\n : key ===\n \"leadSpeakerCue\"\n ? \"Lead speaker cue\"\n : key ===\n \"leadSpeakerAttributionCue\"\n ? \"Lead speaker attribution\"\n : key ===\n \"leadChannelAttributionCue\"\n ? \"Lead channel attribution\"\n : key ===\n \"leadChannelCue\"\n ? \"Lead channel cue\"\n : key ===\n \"leadContinuityCue\"\n ? \"Lead continuity cue\"\n : key,\n value:\n key === \"sourceAwareChunkReason\"\n ? (formatSourceAwareChunkReason(value) ?? formatRAGTraceValue(value))\n : key === \"leadSpeakerAttributionCue\"\n ? (formatLeadSpeakerAttributionCue(value) ?? formatRAGTraceValue(value))\n : key === \"leadChannelAttributionCue\"\n ? (formatLeadChannelAttributionCue(value) ??\n formatRAGTraceValue(value))\n : key === \"leadContinuityCue\"\n ? (formatLeadContinuityCue(value) ?? formatRAGTraceValue(value))\n : formatRAGTraceValue(value),\n});\n\nexport const buildRAGRetrievalTracePresentation = (\n trace?: RAGRetrievalTrace,\n): RAGRetrievalTracePresentation => {\n if (!trace) {\n return {\n details: [],\n stats: [],\n steps: [],\n };\n }\n\n const stats: RAGLabelValueRow[] = [\n { label: \"Mode\", value: trace.mode },\n { label: \"Final Results\", value: String(trace.resultCounts.final) },\n {\n label: \"Vector Candidates\",\n value: String(trace.resultCounts.vector),\n },\n {\n label: \"Lexical Candidates\",\n value: String(trace.resultCounts.lexical),\n },\n ];\n const details: RAGLabelValueRow[] = [\n { label: \"Transformed query\", value: trace.transformedQuery },\n ...(trace.queryTransformLabel || trace.queryTransformProvider\n ? [\n {\n label: \"Query transform\",\n value:\n trace.queryTransformLabel ??\n trace.queryTransformProvider ??\n \"configured\",\n },\n ...(trace.queryTransformReason\n ? [\n {\n label: \"Query transform reason\",\n value: trace.queryTransformReason,\n },\n ]\n : []),\n ]\n : []),\n {\n label: \"Variant queries\",\n value:\n trace.variantQueries.length > 0\n ? trace.variantQueries.join(\" · \")\n : \"none\",\n },\n ...(trace.requestedMode && trace.requestedMode !== trace.mode\n ? [{ label: \"Requested mode\", value: trace.requestedMode }]\n : []),\n ...(trace.routingLabel || trace.routingProvider\n ? [\n {\n label: \"Routing decision\",\n value: trace.routingLabel ?? trace.routingProvider ?? \"configured\",\n },\n ...(trace.routingReason\n ? [\n {\n label: \"Routing reason\",\n value: trace.routingReason,\n },\n ]\n : []),\n ]\n : []),\n { label: \"Candidate topK\", value: String(trace.candidateTopK) },\n { label: \"Lexical topK\", value: String(trace.lexicalTopK) },\n ];\n const steps = trace.steps.map((step) => {\n const sqlitePlannerCues = formatSQLitePlannerCueSummary(step.metadata);\n const postgresPlannerCues = formatPostgresPlannerCueSummary(step.metadata);\n\n return {\n count: step.count,\n label: step.label,\n rows: [\n { label: \"stage\", value: step.stage },\n ...(typeof step.count === \"number\"\n ? [{ label: \"count\", value: String(step.count) }]\n : []),\n ...(typeof step.durationMs === \"number\"\n ? [{ label: \"durationMs\", value: String(step.durationMs) }]\n : []),\n ...(sqlitePlannerCues !== \"none\"\n ? [\n {\n label: \"SQLite planner cues\",\n value: sqlitePlannerCues,\n },\n ]\n : []),\n ...(postgresPlannerCues !== \"none\"\n ? [\n {\n label: \"Postgres planner cues\",\n value: postgresPlannerCues,\n },\n ]\n : []),\n ...Object.entries(step.metadata ?? {}).map(([key, value]) =>\n formatRAGTraceMetadataRow(key, value),\n ),\n ],\n stage: step.stage,\n };\n });\n\n return {\n details,\n stats,\n steps,\n };\n};\n\nconst formatCompactList = (values?: string[]) =>\n values && values.length > 0 ? values.join(\", \") : \"none\";\n\nconst formatCoverageMap = (entries?: Record<string, number>) => {\n if (!entries) {\n return \"none\";\n }\n\n const values = Object.entries(entries);\n return values.length > 0\n ? values.map(([key, value]) => `${key} ${value}`).join(\" · \")\n : \"none\";\n};\n\nconst formatByteSizeLabel = (value?: number) => {\n if (typeof value !== \"number\" || !Number.isFinite(value) || value < 0) {\n return \"n/a\";\n }\n\n if (value < 1024) {\n return `${Math.round(value)} B`;\n }\n\n if (value < 1024 * 1024) {\n return `${(value / 1024).toFixed(value >= 10 * 1024 ? 0 : 1)} KiB`;\n }\n\n if (value < 1024 * 1024 * 1024) {\n return `${(value / (1024 * 1024)).toFixed(\n value >= 10 * 1024 * 1024 ? 0 : 1,\n )} MiB`;\n }\n\n return `${(value / (1024 * 1024 * 1024)).toFixed(\n value >= 10 * 1024 * 1024 * 1024 ? 0 : 1,\n )} GiB`;\n};\n\nconst formatDurationLabel = (value?: number) => {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n return \"n/a\";\n }\n\n if (value < 1000) {\n return `${value}ms`;\n }\n\n if (value < 60000) {\n return `${(value / 1000).toFixed(value >= 10000 ? 0 : 1)}s`;\n }\n\n if (value < 3600000) {\n return `${(value / 60000).toFixed(value >= 600000 ? 0 : 1)}m`;\n }\n\n return `${(value / 3600000).toFixed(value >= 36000000 ? 0 : 1)}h`;\n};\n\nconst formatDateLabel = (value?: number) =>\n typeof value === \"number\" && Number.isFinite(value)\n ? new Date(value).toLocaleString(\"en-US\")\n : \"n/a\";\n\nconst formatAgeLabel = (value?: number) => {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n return \"n/a\";\n }\n\n if (value < 1000) {\n return `${Math.round(value)}ms`;\n }\n\n if (value < 60000) {\n return `${(value / 1000).toFixed(value >= 10000 ? 0 : 1)}s`;\n }\n\n if (value < 3600000) {\n return `${(value / 60000).toFixed(value >= 600000 ? 0 : 1)}m`;\n }\n\n if (value < 86400000) {\n return `${(value / 3600000).toFixed(value >= 36000000 ? 0 : 1)}h`;\n }\n\n return `${(value / 86400000).toFixed(value >= 864000000 ? 0 : 1)}d`;\n};\n\nconst formatSourceAwareChunkReason = (value: unknown) => {\n const reason = getContextString(value);\n if (reason === \"section_boundary\") {\n return \"Chunk boundary section\";\n }\n if (reason === \"size_limit\") {\n return \"Chunk boundary size limit\";\n }\n if (reason === \"source_native_unit\") {\n return \"Chunk boundary source-native unit\";\n }\n return undefined;\n};\n\nconst buildSourceAwareUnitScopeLabel = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const sectionKind = getContextString(metadata.sectionKind);\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n const pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n const pdfTextKind = getContextString(metadata.pdfTextKind);\n const officeBlockKindValue = getContextString(metadata.officeBlockKind);\n const officeBlockKind =\n officeBlockKindValue === \"table\" ||\n officeBlockKindValue === \"list\" ||\n officeBlockKindValue === \"paragraph\"\n ? officeBlockKindValue\n : undefined;\n const sheetName = getContextString(metadata.sheetName);\n const spreadsheetTableLabel = formatSpreadsheetTableLabel(\n getContextNumber(metadata.spreadsheetTableIndex),\n getContextNumber(metadata.spreadsheetTableCount),\n );\n const slideTitle = getContextString(metadata.slideTitle);\n const slideNumber =\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n\n if (\n sectionPath.length > 0 &&\n (sectionKind === \"markdown_heading\" ||\n sectionKind === \"html_heading\" ||\n sectionKind === \"office_heading\" ||\n sectionKind === undefined)\n ) {\n return `Source-aware section ${sectionPath.join(\" > \")}`;\n }\n\n if (sectionKind === \"pdf_block\") {\n if (pdfSemanticRole === \"figure_caption\" && sectionTitle) {\n return `Source-aware PDF figure caption ${sectionTitle}`;\n }\n if (pdfSemanticRole === \"figure_body\" && sectionTitle) {\n return `Source-aware PDF figure body ${sectionTitle}`;\n }\n if (pdfTextKind === \"table_like\" && sectionTitle) {\n return `Source-aware PDF table block ${sectionTitle}`;\n }\n if (sectionTitle) {\n return `Source-aware PDF block ${sectionTitle}`;\n }\n return \"Source-aware PDF block\";\n }\n\n if (sectionKind === \"office_block\") {\n const officeSectionLabel =\n sectionPath.length > 0 ? sectionPath.join(\" > \") : sectionTitle;\n if (officeBlockKind && officeSectionLabel) {\n return `Source-aware office ${officeBlockKind} block ${officeSectionLabel}`;\n }\n if (officeSectionLabel) {\n return `Source-aware office block ${officeSectionLabel}`;\n }\n return \"Source-aware office block\";\n }\n\n if (\n sectionKind === \"spreadsheet_rows\" ||\n (sectionKind === undefined &&\n (sheetName ||\n spreadsheetTableLabel ||\n getContextNumber(metadata.spreadsheetRowStart) !== undefined ||\n getContextNumber(metadata.spreadsheetRowEnd) !== undefined))\n ) {\n if (sheetName && spreadsheetTableLabel) {\n return `Source-aware spreadsheet ${sheetName} ${spreadsheetTableLabel}`;\n }\n if (sheetName) {\n return `Source-aware spreadsheet ${sheetName}`;\n }\n return \"Source-aware spreadsheet\";\n }\n\n if (sectionKind === \"presentation_slide\") {\n if (slideNumber && slideTitle) {\n return `Source-aware slide ${slideNumber} ${slideTitle}`;\n }\n if (slideTitle) {\n return `Source-aware slide ${slideTitle}`;\n }\n if (slideNumber) {\n return `Source-aware slide ${slideNumber}`;\n }\n return \"Source-aware slide\";\n }\n\n return undefined;\n};\n\nconst buildSyncOverviewLatestRow = (sources: RAGSyncSourceRecord[]) => {\n const latest = [...sources]\n .filter(\n (record) =>\n typeof record.lastSuccessfulSyncAt === \"number\" ||\n typeof record.lastSyncedAt === \"number\",\n )\n .sort(\n (left, right) =>\n (right.lastSuccessfulSyncAt ?? right.lastSyncedAt ?? 0) -\n (left.lastSuccessfulSyncAt ?? left.lastSyncedAt ?? 0),\n )[0];\n\n if (!latest) {\n return {\n label: \"Latest sync\",\n value: \"No completed run yet\",\n };\n }\n\n return {\n label: \"Latest sync\",\n value: [\n latest.label,\n typeof latest.documentCount === \"number\"\n ? `${latest.documentCount} docs`\n : \"\",\n typeof latest.chunkCount === \"number\"\n ? `${latest.chunkCount} chunks`\n : \"\",\n typeof latest.lastSyncDurationMs === \"number\"\n ? formatDurationLabel(latest.lastSyncDurationMs)\n : \"\",\n typeof latest.lastSuccessfulSyncAt === \"number\"\n ? formatDateLabel(latest.lastSuccessfulSyncAt)\n : typeof latest.lastSyncedAt === \"number\"\n ? formatDateLabel(latest.lastSyncedAt)\n : \"\",\n ]\n .filter(Boolean)\n .join(\" · \"),\n };\n};\n\nconst formatAdminActionLabel = (\n value: RAGAdminActionRecord[\"action\"] | RAGAdminJobRecord[\"action\"],\n) => value.replaceAll(\"_\", \" \");\n\nconst buildAdminTimingLabel = (input: {\n elapsedMs?: number;\n startedAt: number;\n}) =>\n typeof input.elapsedMs === \"number\"\n ? formatDurationLabel(input.elapsedMs)\n : formatDateLabel(input.startedAt);\n\nexport const buildRAGAdminJobPresentation = (\n job: RAGAdminJobRecord,\n): RAGAdminJobPresentation => ({\n id: job.id,\n action: job.action,\n status: job.status,\n summary: [\n job.status.toUpperCase(),\n formatAdminActionLabel(job.action),\n job.target,\n buildAdminTimingLabel(job),\n ]\n .filter(Boolean)\n .join(\" · \"),\n rows: [\n { label: \"Action\", value: formatAdminActionLabel(job.action) },\n { label: \"Status\", value: job.status },\n ...(job.target ? [{ label: \"Target\", value: job.target }] : []),\n { label: \"Timing\", value: buildAdminTimingLabel(job) },\n ...(job.error ? [{ label: \"Error\", value: job.error }] : []),\n ],\n});\n\nexport const buildRAGAdminJobPresentations = (\n jobs?: RAGAdminJobRecord[],\n): RAGAdminJobPresentation[] =>\n (jobs ?? []).slice(0, 3).map(buildRAGAdminJobPresentation);\n\nexport const buildRAGAdminActionPresentation = (\n action: RAGAdminActionRecord,\n): RAGAdminActionPresentation => ({\n id: action.id,\n action: action.action,\n status: action.status,\n summary: [\n action.status.toUpperCase(),\n formatAdminActionLabel(action.action),\n action.documentId ?? action.target,\n buildAdminTimingLabel(action),\n ]\n .filter(Boolean)\n .join(\" · \"),\n rows: [\n { label: \"Action\", value: formatAdminActionLabel(action.action) },\n { label: \"Status\", value: action.status },\n ...(action.documentId\n ? [{ label: \"Document\", value: action.documentId }]\n : action.target\n ? [{ label: \"Target\", value: action.target }]\n : []),\n { label: \"Timing\", value: buildAdminTimingLabel(action) },\n ...(action.error ? [{ label: \"Error\", value: action.error }] : []),\n ],\n});\n\nexport const buildRAGAdminActionPresentations = (\n actions?: RAGAdminActionRecord[],\n): RAGAdminActionPresentation[] =>\n (actions ?? []).slice(0, 3).map(buildRAGAdminActionPresentation);\n\nconst buildRAGSyncSourceRunPresentations = (\n source: RAGSyncSourceRecord,\n): RAGSyncSourceRunPresentation[] => {\n if (!Array.isArray(source.metadata?.recentRuns)) {\n return [];\n }\n\n return (source.metadata.recentRuns as Array<Record<string, unknown>>)\n .slice(0, 3)\n .map((entry, index) => {\n const trigger =\n typeof entry.trigger === \"string\" ? entry.trigger : \"sync\";\n const status =\n typeof entry.status === \"string\" ? entry.status : \"unknown\";\n const finishedAt =\n typeof entry.finishedAt === \"number\"\n ? formatDateLabel(entry.finishedAt)\n : \"n/a\";\n const duration =\n typeof entry.durationMs === \"number\"\n ? formatDurationLabel(entry.durationMs)\n : \"n/a\";\n const docs =\n typeof entry.documentCount === \"number\"\n ? `${entry.documentCount} docs`\n : \"n/a\";\n const chunks =\n typeof entry.chunkCount === \"number\"\n ? `${entry.chunkCount} chunks`\n : \"n/a\";\n const error =\n typeof entry.error === \"string\" && entry.error.length > 0\n ? entry.error\n : undefined;\n\n return {\n label: `Run ${index + 1}`,\n status,\n summary: `${trigger} · ${status} · ${docs} · ${chunks} · ${duration} · ${finishedAt}`,\n rows: [\n { label: \"Trigger\", value: trigger },\n { label: \"Status\", value: status },\n { label: \"Output\", value: `${docs} · ${chunks}` },\n { label: \"Duration\", value: duration },\n { label: \"Finished\", value: finishedAt },\n ...(error ? [{ label: \"Error\", value: error }] : []),\n ],\n };\n });\n};\n\nexport const buildRAGSyncSourcePresentation = (\n source: RAGSyncSourceRecord,\n): RAGSyncSourcePresentation => {\n const provider =\n typeof source.metadata?.provider === \"string\"\n ? source.metadata.provider\n : undefined;\n const accountMode =\n typeof source.metadata?.accountMode === \"string\"\n ? source.metadata.accountMode\n : undefined;\n const schedule =\n typeof source.metadata?.schedule === \"string\"\n ? source.metadata.schedule\n : undefined;\n const lastTrigger =\n typeof source.metadata?.lastTrigger === \"string\"\n ? source.metadata.lastTrigger\n : undefined;\n const liveReady =\n typeof source.metadata?.liveReady === \"string\"\n ? source.metadata.liveReady\n : undefined;\n const diagnosticSummary = source.diagnostics?.summary;\n const diagnosticTags =\n source.diagnostics?.entries.map((entry) =>\n entry.code\n .replace(/_/g, \" \")\n .replace(/\\b\\w/g, (letter) => letter.toUpperCase()),\n ) ?? [];\n const retryGuidance = source.diagnostics?.retryGuidance;\n\n return {\n id: source.id,\n label: source.label,\n kind: source.kind,\n status: source.status,\n summary: [\n source.kind,\n source.status,\n typeof source.documentCount === \"number\"\n ? `${source.documentCount} docs`\n : \"\",\n typeof source.chunkCount === \"number\"\n ? `${source.chunkCount} chunks`\n : \"\",\n typeof source.lastSyncDurationMs === \"number\"\n ? formatDurationLabel(source.lastSyncDurationMs)\n : \"\",\n typeof source.lastSuccessfulSyncAt === \"number\"\n ? `last success ${formatDateLabel(source.lastSuccessfulSyncAt)}`\n : typeof source.lastSyncedAt === \"number\"\n ? `last sync ${formatDateLabel(source.lastSyncedAt)}`\n : \"\",\n ]\n .filter(Boolean)\n .join(\" · \"),\n rows: [\n ...(source.target ? [{ label: \"Target\", value: source.target }] : []),\n ...(provider ? [{ label: \"Provider\", value: provider }] : []),\n ...(accountMode ? [{ label: \"Account mode\", value: accountMode }] : []),\n ...(schedule ? [{ label: \"Schedule\", value: schedule }] : []),\n ...(lastTrigger ? [{ label: \"Last trigger\", value: lastTrigger }] : []),\n ...(typeof source.lastSuccessfulSyncAt === \"number\"\n ? [\n {\n label: \"Last success\",\n value: formatDateLabel(source.lastSuccessfulSyncAt),\n },\n ]\n : []),\n ...(typeof source.nextRetryAt === \"number\"\n ? [\n {\n label: \"Next retry\",\n value: formatDateLabel(source.nextRetryAt),\n },\n ]\n : []),\n ...(source.lastError\n ? [{ label: \"Last error\", value: source.lastError }]\n : []),\n ...(diagnosticSummary\n ? [{ label: \"Diagnostics\", value: diagnosticSummary }]\n : []),\n ...(retryGuidance\n ? [{ label: \"Retry guidance\", value: retryGuidance.reason }]\n : []),\n ],\n tags: [\n provider,\n accountMode ? `mode ${accountMode}` : undefined,\n liveReady,\n ...diagnosticTags,\n ].filter((value): value is string => Boolean(value)),\n extendedSummary: diagnosticSummary ?? source.description ?? liveReady,\n runs: buildRAGSyncSourceRunPresentations(source),\n };\n};\n\nexport const buildRAGSyncSourcePresentations = (\n sources?: RAGSyncSourceRecord[],\n): RAGSyncSourcePresentation[] =>\n (sources ?? []).map(buildRAGSyncSourcePresentation);\n\nexport const buildRAGReadinessPresentation = (\n readiness?: RAGExtractorReadiness,\n): RAGReadinessPresentation => {\n if (!readiness) {\n return {\n sections: [\n {\n label: \"Provider\",\n title: \"Unavailable\",\n summary: \"Readiness data is not available yet.\",\n },\n ],\n };\n }\n\n return {\n sections: [\n {\n label: \"Provider\",\n title: readiness.providerConfigured\n ? (readiness.providerName ?? \"Runtime provider routing\")\n : \"Not configured\",\n summary: readiness.providerConfigured\n ? readiness.model\n ? `Requests route through ${readiness.providerName ?? \"the runtime provider registry\"} with default model ${readiness.model}.`\n : `Requests route through ${readiness.providerName ?? \"the runtime provider registry\"}.`\n : \"Provider-backed retrieval is not configured yet.\",\n },\n {\n label: \"Embeddings\",\n title: readiness.embeddingConfigured\n ? readiness.embeddingModel === \"collection-managed embeddings\"\n ? \"Collection-managed\"\n : \"Configured\"\n : \"Missing\",\n summary: readiness.embeddingConfigured\n ? readiness.embeddingModel === \"collection-managed embeddings\"\n ? \"Embeddings come from the collection and vector store layer, so retrieval stays vector-backed without a separate top-level embedding provider.\"\n : (readiness.embeddingModel ?? \"Embedding model configured.\")\n : \"Embeddings are not configured yet.\",\n },\n {\n label: \"Retrieval Stack\",\n title: readiness.rerankerConfigured ? \"Reranker ready\" : \"Vector only\",\n summary: readiness.indexManagerConfigured\n ? \"Index manager configured.\"\n : \"Index manager not configured.\",\n },\n {\n label: \"Extractors\",\n title: readiness.extractorsConfigured\n ? `${readiness.extractorNames.length} configured`\n : \"None configured\",\n summary: readiness.extractorsConfigured\n ? `Configured extractors: ${formatCompactList(readiness.extractorNames)}`\n : \"No extractors configured.\",\n tags:\n readiness.extractorNames.length > 0\n ? readiness.extractorNames\n : [\"No extractors configured\"],\n },\n ],\n };\n};\n\nexport const buildRAGCorpusHealthPresentation = (\n health?: RAGCorpusHealth,\n): RAGCorpusHealthPresentation => {\n if (!health) {\n return {\n sections: [\n {\n label: \"Corpus health\",\n title: \"Unavailable\",\n summary: \"Corpus health is not available yet.\",\n },\n ],\n };\n }\n\n return {\n sections: [\n {\n label: \"Corpus coverage\",\n title: `Formats: ${formatCoverageMap(health.coverageByFormat)}`,\n summary: `Kinds: ${formatCoverageMap(health.coverageByKind)}`,\n rows: [\n {\n label: \"Average chunks per document\",\n value: health.averageChunksPerDocument.toFixed(2),\n },\n ],\n },\n {\n label: \"Chunk quality\",\n title: `${health.averageChunksPerDocument.toFixed(2)} avg chunks/doc`,\n summary: `Empty docs ${health.emptyDocuments} · empty chunks ${health.emptyChunks} · low signal ${health.lowSignalChunks}`,\n rows: [\n {\n label: \"Missing source\",\n value: String(health.documentsMissingSource),\n },\n {\n label: \"Missing title\",\n value: String(health.documentsMissingTitle),\n },\n {\n label: \"Missing metadata\",\n value: String(health.documentsMissingMetadata),\n },\n ],\n },\n {\n label: \"Freshness\",\n title: `${health.staleDocuments.length} stale docs`,\n summary: `Stale threshold ${formatAgeLabel(health.staleAfterMs)}`,\n rows: [\n {\n label: \"Oldest age\",\n value: formatAgeLabel(health.oldestDocumentAgeMs),\n },\n {\n label: \"Newest age\",\n value: formatAgeLabel(health.newestDocumentAgeMs),\n },\n ],\n },\n {\n label: \"Failures\",\n title: `${health.failedIngestJobs} ingest · ${health.failedAdminJobs} admin`,\n summary: `Duplicate sources ${health.duplicateSourceGroups.length} · duplicate ids ${health.duplicateDocumentIdGroups.length}`,\n rows: [\n {\n label: \"Failures by input\",\n value: formatCoverageMap(health.failuresByInputKind),\n },\n {\n label: \"Failures by extractor\",\n value: formatCoverageMap(health.failuresByExtractor),\n },\n {\n label: \"Failures by admin action\",\n value: formatCoverageMap(health.failuresByAdminAction),\n },\n ],\n },\n ],\n };\n};\n\nexport const buildRAGSyncOverviewPresentation = (\n sources?: RAGSyncSourceRecord[],\n): RAGSyncOverviewPresentation => {\n const records = sources ?? [];\n if (records.length === 0) {\n return {\n rows: [\n { label: \"Configured sync sources\", value: \"0\" },\n {\n label: \"Latest sync\",\n value: \"No sync sources configured yet.\",\n },\n ],\n sections: [\n {\n label: \"Sync overview\",\n title: \"No sync sources configured\",\n summary:\n \"Add sync sources to monitor directories, URLs, storage, or mailboxes.\",\n },\n ],\n };\n }\n\n const countByStatus = (status: RAGSyncSourceRecord[\"status\"]) =>\n records.filter((record) => record.status === status).length;\n\n return {\n rows: [\n { label: \"Configured sync sources\", value: String(records.length) },\n { label: \"Completed\", value: String(countByStatus(\"completed\")) },\n { label: \"Running\", value: String(countByStatus(\"running\")) },\n {\n label: \"Failed\",\n value: String(countByStatus(\"failed\")),\n },\n buildSyncOverviewLatestRow(records),\n ],\n sections: [\n {\n label: \"Sync overview\",\n title: `${records.length} configured`,\n summary: `${countByStatus(\"completed\")} completed · ${countByStatus(\"running\")} running · ${countByStatus(\"failed\")} failed`,\n },\n {\n label: \"Latest sync\",\n title: buildSyncOverviewLatestRow(records).value,\n summary: \"Most recent completed or last-known sync activity.\",\n },\n ],\n };\n};\n\nconst formatMediaTimestamp = (value: unknown) => {\n if (typeof value !== \"number\" || !Number.isFinite(value) || value < 0) {\n return undefined;\n }\n\n const totalSeconds = Math.floor(value / 1000);\n const minutes = Math.floor(totalSeconds / 60);\n const seconds = totalSeconds % 60;\n const milliseconds = Math.floor(value % 1000);\n\n return `${String(minutes).padStart(2, \"0\")}:${String(seconds).padStart(\n 2,\n \"0\",\n )}.${String(milliseconds).padStart(3, \"0\")}`;\n};\n\nconst getAttachmentName = (source?: string, title?: string) => {\n const sourceAttachment = source?.split(\"/\").at(-1);\n if (sourceAttachment && sourceAttachment.includes(\".\")) {\n return sourceAttachment;\n }\n\n const titleAttachment = title?.split(\" · \").at(-1);\n if (titleAttachment && titleAttachment.includes(\".\")) {\n return titleAttachment;\n }\n\n return undefined;\n};\n\nconst getSpreadsheetHeaders = (metadata?: Record<string, unknown>) =>\n Array.isArray(metadata?.spreadsheetHeaders)\n ? metadata.spreadsheetHeaders\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n\nconst formatSpreadsheetColumnRange = (\n columnStart?: string,\n columnEnd?: string,\n) => {\n if (typeof columnStart !== \"string\" || columnStart.length === 0) {\n return undefined;\n }\n if (typeof columnEnd !== \"string\" || columnEnd.length === 0) {\n return `Columns ${columnStart}`;\n }\n if (columnStart === columnEnd) {\n return `Columns ${columnStart}`;\n }\n\n return `Columns ${columnStart}-${columnEnd}`;\n};\n\nconst formatSpreadsheetRowRange = (rowStart?: number, rowEnd?: number) => {\n if (typeof rowStart !== \"number\" || !Number.isFinite(rowStart)) {\n return undefined;\n }\n if (\n typeof rowEnd !== \"number\" &&\n typeof rowStart === \"number\" &&\n Number.isFinite(rowStart)\n ) {\n return `Rows ${rowStart}`;\n }\n if (rowStart === rowEnd) {\n return `Rows ${rowStart}`;\n }\n\n return `Rows ${rowStart}-${rowEnd}`;\n};\n\nconst formatSpreadsheetTableLabel = (\n tableIndex?: number,\n tableCount?: number,\n) => {\n if (\n typeof tableIndex !== \"number\" ||\n !Number.isFinite(tableIndex) ||\n tableIndex < 1\n ) {\n return undefined;\n }\n\n if (\n typeof tableCount === \"number\" &&\n Number.isFinite(tableCount) &&\n tableCount >= tableIndex\n ) {\n return `Table ${tableIndex} of ${tableCount}`;\n }\n\n return `Table ${tableIndex}`;\n};\n\nconst formatOfficeListLevelsLabel = (value: unknown) => {\n if (!Array.isArray(value) || value.length === 0) {\n return undefined;\n }\n\n const levels = value\n .map((entry) => getContextNumber(entry))\n .filter((entry): entry is number => typeof entry === \"number\")\n .sort((left, right) => left - right);\n\n if (levels.length === 0) {\n return undefined;\n }\n\n const minLevel = levels[0];\n const maxLevel = levels[levels.length - 1];\n\n return minLevel === maxLevel\n ? `Office list level ${minLevel}`\n : `Office list levels ${minLevel}-${maxLevel}`;\n};\n\nconst formatMediaDurationLabel = (value: unknown) => {\n if (typeof value !== \"number\" || !Number.isFinite(value) || value < 0) {\n return undefined;\n }\n\n return formatMediaTimestamp(value);\n};\n\nconst buildContextLabel = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const pdfTextKind = getContextString(metadata.pdfTextKind);\n const pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n const pdfTableBodyRowStart = getContextNumber(metadata.pdfTableBodyRowStart);\n const pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n const officeBlockKindValue = getContextString(metadata.officeBlockKind);\n const officeBlockKind =\n officeBlockKindValue === \"table\" ||\n officeBlockKindValue === \"list\" ||\n officeBlockKindValue === \"paragraph\"\n ? officeBlockKindValue\n : undefined;\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n if (pdfSemanticRole === \"figure_caption\" && sectionTitle) {\n return `PDF figure caption ${sectionTitle}`;\n }\n if (pdfSemanticRole === \"figure_body\" && sectionTitle) {\n return `PDF figure body ${sectionTitle}`;\n }\n if (pdfTextKind === \"table_like\" && sectionTitle) {\n return `PDF table block ${sectionTitle}`;\n }\n if (pdfTextKind === \"paragraph\" && sectionTitle) {\n return `PDF text block ${sectionTitle}`;\n }\n if (officeBlockKind === \"table\" && sectionTitle) {\n return `Office table block ${sectionPath.join(\" > \") || sectionTitle}`;\n }\n if (officeBlockKind === \"list\" && sectionTitle) {\n return `Office list block ${sectionPath.join(\" > \") || sectionTitle}`;\n }\n if (officeBlockKind === \"paragraph\" && sectionTitle) {\n return `Office paragraph block ${sectionPath.join(\" > \") || sectionTitle}`;\n }\n\n const emailKind = getContextString(metadata.emailKind);\n if (emailKind === \"attachment\") {\n const attachmentName = getContextString(metadata.attachmentName);\n const threadTopic = getContextString(metadata.threadTopic);\n return attachmentName\n ? threadTopic\n ? `Attachment evidence ${attachmentName} in ${threadTopic}`\n : `Attachment evidence ${attachmentName}`\n : \"Attachment evidence\";\n }\n\n if (emailKind === \"message\") {\n const threadTopic = getContextString(metadata.threadTopic);\n const from = getContextString(metadata.from);\n if (threadTopic) {\n return from\n ? `Message in ${threadTopic} from ${from}`\n : `Message in ${threadTopic}`;\n }\n return from ? `Message from ${from}` : \"Message evidence\";\n }\n\n const page =\n getContextNumber(metadata.page) ??\n getContextNumber(metadata.pageNumber) ??\n (typeof metadata.pageIndex === \"number\"\n ? metadata.pageIndex + 1\n : undefined);\n const region =\n getContextNumber(metadata.regionNumber) ??\n (typeof metadata.regionIndex === \"number\"\n ? metadata.regionIndex + 1\n : undefined);\n const hasOCRTrace =\n typeof metadata.ocrRegionConfidence === \"number\" ||\n typeof metadata.ocrConfidence === \"number\" ||\n getContextString(metadata.pdfTextMode) === \"ocr\" ||\n typeof metadata.ocrRegionCount === \"number\";\n const ocrPageStart = getContextNumber(metadata.ocrPageStart);\n const ocrPageEnd = getContextNumber(metadata.ocrPageEnd);\n if (page && region) {\n if (hasOCRTrace) {\n return `OCR page ${page} region ${region}`;\n }\n return `Page ${page} region ${region}`;\n }\n if (page) {\n if (hasOCRTrace) {\n return `OCR page ${page}`;\n }\n return `Page ${page}`;\n }\n if (\n hasOCRTrace &&\n typeof ocrPageStart === \"number\" &&\n typeof ocrPageEnd === \"number\"\n ) {\n return ocrPageStart === ocrPageEnd\n ? `OCR page ${ocrPageStart}`\n : `OCR pages ${ocrPageStart}-${ocrPageEnd}`;\n }\n\n const sheet =\n getContextString(metadata.sheetName) ??\n (Array.isArray(metadata.sheetNames)\n ? getContextString(metadata.sheetNames[0])\n : undefined);\n if (sheet) {\n const tableLabel = formatSpreadsheetTableLabel(\n getContextNumber(metadata.spreadsheetTableIndex),\n getContextNumber(metadata.spreadsheetTableCount),\n );\n const columnRange = formatSpreadsheetColumnRange(\n getContextString(metadata.spreadsheetColumnStart),\n getContextString(metadata.spreadsheetColumnEnd),\n );\n const rowRange = formatSpreadsheetRowRange(\n getContextNumber(metadata.spreadsheetRowStart),\n getContextNumber(metadata.spreadsheetRowEnd),\n );\n const headers = getSpreadsheetHeaders(metadata);\n if (tableLabel && rowRange && columnRange) {\n return `Sheet ${sheet} ${tableLabel} ${rowRange} ${columnRange}`;\n }\n if (tableLabel && rowRange) {\n return `Sheet ${sheet} ${tableLabel} ${rowRange}`;\n }\n if (tableLabel && columnRange) {\n return `Sheet ${sheet} ${tableLabel} ${columnRange}`;\n }\n if (tableLabel) {\n return `Sheet ${sheet} ${tableLabel}`;\n }\n if (rowRange && columnRange) {\n return `Sheet ${sheet} ${rowRange} ${columnRange}`;\n }\n if (rowRange) {\n return `Sheet ${sheet} ${rowRange}`;\n }\n if (columnRange) {\n return `Sheet ${sheet} ${columnRange}`;\n }\n if (headers.length > 0) {\n return `Sheet ${sheet} by ${headers.slice(0, 2).join(\", \")}`;\n }\n return `Sheet ${sheet}`;\n }\n\n const slide =\n getContextNumber(metadata.slide) ??\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n const slideTitle = getContextString(metadata.slideTitle);\n if (slide) {\n if (slideTitle) {\n return `Slide ${slide} ${slideTitle}`;\n }\n return `Slide ${slide}`;\n }\n\n const archiveEntry =\n getContextString(metadata.archiveFullPath) ??\n getContextString(metadata.archivePath) ??\n getContextString(metadata.archiveEntryPath) ??\n getContextString(metadata.entryPath);\n if (archiveEntry) {\n return `Archive entry ${archiveEntry}`;\n }\n\n const threadTopic = getContextString(metadata.threadTopic);\n if (threadTopic) {\n return `Thread ${threadTopic}`;\n }\n\n const speaker = getContextString(metadata.speaker);\n if (speaker) {\n return `Speaker ${speaker}`;\n }\n if (sectionTitle) {\n return `Section ${sectionTitle}`;\n }\n\n return undefined;\n};\n\nconst buildLocatorLabel = (\n metadata?: Record<string, unknown>,\n source?: string,\n title?: string,\n) => {\n if (!metadata) {\n return undefined;\n }\n\n const pdfTextKind = getContextString(metadata.pdfTextKind);\n const pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n const officeBlockKind = getContextString(metadata.officeBlockKind);\n const pdfBlockNumber = getContextNumber(metadata.pdfBlockNumber);\n const pdfTableBodyRowStart = getContextNumber(metadata.pdfTableBodyRowStart);\n const pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n const officeBlockNumber = getContextNumber(metadata.officeBlockNumber);\n const officeTableBodyRowStart = getContextNumber(\n metadata.officeTableBodyRowStart,\n );\n const officeTableBodyRowEnd = getContextNumber(\n metadata.officeTableBodyRowEnd,\n );\n const spreadsheetRowStart = getContextNumber(metadata.spreadsheetRowStart);\n const spreadsheetRowEnd = getContextNumber(metadata.spreadsheetRowEnd);\n const slideTitle = getContextString(metadata.slideTitle);\n\n const page =\n getContextNumber(metadata.page) ??\n getContextNumber(metadata.pageNumber) ??\n (typeof metadata.pageIndex === \"number\"\n ? metadata.pageIndex + 1\n : undefined);\n const region =\n getContextNumber(metadata.regionNumber) ??\n (typeof metadata.regionIndex === \"number\"\n ? metadata.regionIndex + 1\n : undefined);\n const ocrPageStart = getContextNumber(metadata.ocrPageStart);\n const ocrPageEnd = getContextNumber(metadata.ocrPageEnd);\n if (page && region) {\n return `Page ${page} · Region ${region}`;\n }\n if (page && pdfBlockNumber && pdfSemanticRole === \"figure_caption\") {\n return `Page ${page} · Figure Caption ${pdfBlockNumber}`;\n }\n if (page && pdfBlockNumber && pdfSemanticRole === \"figure_body\") {\n return `Page ${page} · Figure Body ${pdfBlockNumber}`;\n }\n if (page && pdfBlockNumber && pdfTextKind === \"table_like\") {\n if (\n typeof pdfTableBodyRowStart === \"number\" &&\n typeof pdfTableBodyRowEnd === \"number\"\n ) {\n return pdfTableBodyRowStart === pdfTableBodyRowEnd\n ? `Page ${page} · Table Block ${pdfBlockNumber} · Row ${pdfTableBodyRowStart}`\n : `Page ${page} · Table Block ${pdfBlockNumber} · Rows ${pdfTableBodyRowStart}-${pdfTableBodyRowEnd}`;\n }\n return `Page ${page} · Table Block ${pdfBlockNumber}`;\n }\n if (page && pdfBlockNumber) {\n return `Page ${page} · Text Block ${pdfBlockNumber}`;\n }\n if (page) {\n return `Page ${page}`;\n }\n if (typeof ocrPageStart === \"number\" && typeof ocrPageEnd === \"number\") {\n return ocrPageStart === ocrPageEnd\n ? `Page ${ocrPageStart}`\n : `Pages ${ocrPageStart}-${ocrPageEnd}`;\n }\n\n const sheet =\n getContextString(metadata.sheetName) ??\n (Array.isArray(metadata.sheetNames)\n ? getContextString(metadata.sheetNames[0])\n : undefined);\n if (sheet) {\n const tableLabel = formatSpreadsheetTableLabel(\n getContextNumber(metadata.spreadsheetTableIndex),\n getContextNumber(metadata.spreadsheetTableCount),\n );\n const columnRange = formatSpreadsheetColumnRange(\n getContextString(metadata.spreadsheetColumnStart),\n getContextString(metadata.spreadsheetColumnEnd),\n );\n const rowRange = formatSpreadsheetRowRange(\n spreadsheetRowStart,\n spreadsheetRowEnd,\n );\n if (tableLabel && rowRange && columnRange) {\n return `Sheet ${sheet} · ${tableLabel} · ${rowRange} · ${columnRange}`;\n }\n if (tableLabel && rowRange) {\n return `Sheet ${sheet} · ${tableLabel} · ${rowRange}`;\n }\n if (tableLabel && columnRange) {\n return `Sheet ${sheet} · ${tableLabel} · ${columnRange}`;\n }\n if (tableLabel) {\n return `Sheet ${sheet} · ${tableLabel}`;\n }\n if (rowRange && columnRange) {\n return `Sheet ${sheet} · ${rowRange} · ${columnRange}`;\n }\n if (rowRange) {\n return `Sheet ${sheet} · ${rowRange}`;\n }\n return columnRange ? `Sheet ${sheet} · ${columnRange}` : `Sheet ${sheet}`;\n }\n\n const slide =\n getContextNumber(metadata.slide) ??\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\"\n ? metadata.slideIndex + 1\n : undefined);\n if (slide) {\n return slideTitle ? `Slide ${slide} · ${slideTitle}` : `Slide ${slide}`;\n }\n\n const archiveEntry =\n getContextString(metadata.archiveFullPath) ??\n getContextString(metadata.archivePath) ??\n getContextString(metadata.archiveEntryPath) ??\n getContextString(metadata.entryPath);\n if (archiveEntry) {\n return `Archive entry ${archiveEntry}`;\n }\n\n const emailKind = getContextString(metadata.emailKind);\n if (emailKind === \"attachment\") {\n const attachmentName =\n getContextString(metadata.attachmentName) ??\n getAttachmentName(source, title);\n const replyDepth = getContextNumber(metadata.replyDepth);\n if (attachmentName && replyDepth && replyDepth > 0) {\n return `Attachment ${attachmentName} · Reply depth ${replyDepth}`;\n }\n return attachmentName ? `Attachment ${attachmentName}` : \"Attachment\";\n }\n\n const mediaStart = formatMediaTimestamp(metadata.startMs);\n const mediaEnd = formatMediaTimestamp(metadata.endMs);\n if (mediaStart && mediaEnd) {\n return `Timestamp ${mediaStart} - ${mediaEnd}`;\n }\n\n if (mediaStart) {\n return `Timestamp ${mediaStart}`;\n }\n\n if (officeBlockNumber && officeBlockKind === \"table\") {\n if (\n typeof officeTableBodyRowStart === \"number\" &&\n typeof officeTableBodyRowEnd === \"number\"\n ) {\n return officeTableBodyRowStart === officeTableBodyRowEnd\n ? `Office table block ${officeBlockNumber} · Row ${officeTableBodyRowStart}`\n : `Office table block ${officeBlockNumber} · Rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`;\n }\n return `Office table block ${officeBlockNumber}`;\n }\n if (officeBlockNumber && officeBlockKind === \"list\") {\n return `Office list block ${officeBlockNumber}`;\n }\n if (officeBlockNumber && officeBlockKind === \"paragraph\") {\n return `Office paragraph block ${officeBlockNumber}`;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n if (sectionPath.length > 0) {\n return `Section ${sectionPath.join(\" > \")}`;\n }\n\n return undefined;\n};\n\nconst buildProvenanceLabel = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const threadTopic = getContextString(metadata.threadTopic);\n const replyDepth = getContextNumber(metadata.replyDepth);\n const threadMessageCount = getContextNumber(metadata.threadMessageCount);\n const threadRootMessageId = getContextString(metadata.threadRootMessageId);\n const from = getContextString(metadata.from);\n const sentAt =\n formatTimestampLabel(metadata.sentAt) ??\n formatTimestampLabel(metadata.receivedAt);\n const speaker = getContextString(metadata.speaker);\n const mediaKind = getContextString(metadata.mediaKind);\n const transcriptSource = getContextString(metadata.transcriptSource);\n const mediaSpeakerCount = getContextNumber(metadata.mediaSpeakerCount);\n const mediaSegmentCount = getContextNumber(metadata.mediaSegmentCount);\n const mediaSegmentGroupSize = getContextNumber(\n metadata.mediaSegmentGroupSize,\n );\n const mediaSegmentGroupIndex = getContextNumber(\n metadata.mediaSegmentGroupIndex,\n );\n const mediaChannel = getContextString(metadata.mediaChannel);\n const mediaDurationLabel = formatMediaDurationLabel(metadata.mediaDurationMs);\n const mediaSegmentWindowDurationLabel = formatMediaDurationLabel(\n metadata.mediaSegmentGroupDurationMs,\n );\n const mediaSegmentGapLabel = formatMediaDurationLabel(\n metadata.mediaSegmentGapFromPreviousMs,\n );\n const spreadsheetHeaders = getSpreadsheetHeaders(metadata);\n const pdfTableHeaders = Array.isArray(metadata.pdfTableHeaders)\n ? metadata.pdfTableHeaders\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const pdfTableColumnCount = getContextNumber(metadata.pdfTableColumnCount);\n const pdfTableBodyRowCount = getContextNumber(metadata.pdfTableBodyRowCount);\n const spreadsheetColumnRange = formatSpreadsheetColumnRange(\n getContextString(metadata.spreadsheetColumnStart),\n getContextString(metadata.spreadsheetColumnEnd),\n );\n const slideNotesText = getContextString(metadata.slideNotesText);\n const pdfTextMode = getContextString(metadata.pdfTextMode);\n const pdfEvidenceMode = getContextString(metadata.pdfEvidenceMode);\n const pdfEvidenceOrigin = getContextString(metadata.pdfEvidenceOrigin);\n const pdfEvidenceSupplement = getContextString(\n metadata.pdfEvidenceSupplement,\n );\n const pdfTextKind = getContextString(metadata.pdfTextKind);\n const pdfSemanticRole = getContextString(metadata.pdfSemanticRole);\n const officeBlockKind = getContextString(metadata.officeBlockKind);\n const officeListContextText = getContextString(\n metadata.officeListContextText,\n );\n const officeListGroupItemCount = getContextNumber(\n metadata.officeListGroupItemCount,\n );\n const officeListLevelsLabel = formatOfficeListLevelsLabel(\n metadata.officeListLevels,\n );\n const officeTableHeaders = Array.isArray(metadata.officeTableHeaders)\n ? metadata.officeTableHeaders\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const officeTableColumnCount = getContextNumber(\n metadata.officeTableColumnCount,\n );\n const officeTableBodyRowCount = getContextNumber(\n metadata.officeTableBodyRowCount,\n );\n const officeTableBodyRowStart = getContextNumber(\n metadata.officeTableBodyRowStart,\n );\n const officeTableBodyRowEnd = getContextNumber(\n metadata.officeTableBodyRowEnd,\n );\n const officeTableContextText = getContextString(\n metadata.officeTableContextText,\n );\n const officeTableFollowUpText = getContextString(\n metadata.officeTableFollowUpText,\n );\n const ocrEngine = getContextString(metadata.ocrEngine);\n const extractorRegistryMatch = getContextString(\n metadata.extractorRegistryMatch,\n );\n const chunkingProfile = getContextString(metadata.chunkingProfile);\n const archiveDepth = getContextNumber(metadata.archiveDepth);\n const archiveNestedDepth = getContextNumber(metadata.archiveNestedDepth);\n const archiveContainerPath = getContextString(metadata.archiveContainerPath);\n const archiveRootName = getContextString(metadata.archiveRootName);\n const sourceAwareChunkReason = formatSourceAwareChunkReason(\n metadata.sourceAwareChunkReason,\n );\n const sourceAwareUnitScope = buildSourceAwareUnitScopeLabel(metadata);\n const spreadsheetTableLabel = formatSpreadsheetTableLabel(\n getContextNumber(metadata.spreadsheetTableIndex),\n getContextNumber(metadata.spreadsheetTableCount),\n );\n const ocrConfidence =\n getContextNumber(metadata.ocrRegionConfidence) ??\n getContextNumber(metadata.ocrConfidence);\n const ocrAverageConfidence =\n getContextNumber(metadata.ocrPageAverageConfidence) ??\n getContextNumber(metadata.ocrAverageConfidence);\n const ocrMinConfidence =\n getContextNumber(metadata.ocrPageMinConfidence) ??\n getContextNumber(metadata.ocrMinConfidence);\n const ocrMaxConfidence =\n getContextNumber(metadata.ocrPageMaxConfidence) ??\n getContextNumber(metadata.ocrMaxConfidence);\n const ocrRegionCount = getContextNumber(metadata.ocrRegionCount);\n const pdfTableBodyRowStart = getContextNumber(metadata.pdfTableBodyRowStart);\n const pdfTableBodyRowEnd = getContextNumber(metadata.pdfTableBodyRowEnd);\n\n const labels = [\n pdfTextMode ? `PDF ${pdfTextMode}` : \"\",\n pdfEvidenceMode ? `PDF evidence ${pdfEvidenceMode}` : \"\",\n pdfEvidenceOrigin ? `PDF origin ${pdfEvidenceOrigin}` : \"\",\n pdfEvidenceSupplement ? `PDF supplement ${pdfEvidenceSupplement}` : \"\",\n pdfSemanticRole === \"figure_caption\" ? \"PDF figure caption\" : \"\",\n pdfSemanticRole === \"figure_body\" ? \"PDF figure body\" : \"\",\n pdfSemanticRole === \"figure_caption\"\n ? \"\"\n : pdfSemanticRole === \"figure_body\"\n ? \"\"\n : pdfTextKind === \"table_like\"\n ? \"PDF table block\"\n : pdfTextKind === \"paragraph\"\n ? \"PDF text block\"\n : \"\",\n officeBlockKind ? `Office ${officeBlockKind}` : \"\",\n typeof officeListGroupItemCount === \"number\"\n ? `Office list ${officeListGroupItemCount} items`\n : \"\",\n officeListLevelsLabel ?? \"\",\n ocrEngine ? `OCR ${ocrEngine}` : \"\",\n extractorRegistryMatch ? `Extractor ${extractorRegistryMatch}` : \"\",\n chunkingProfile ? `Chunking ${chunkingProfile}` : \"\",\n sourceAwareChunkReason ?? \"\",\n sourceAwareUnitScope ?? \"\",\n typeof ocrConfidence === \"number\"\n ? `Confidence ${ocrConfidence.toFixed(2)}`\n : \"\",\n typeof ocrAverageConfidence === \"number\" &&\n ocrAverageConfidence !== ocrConfidence\n ? `Average ${ocrAverageConfidence.toFixed(2)}`\n : \"\",\n typeof ocrMinConfidence === \"number\" &&\n typeof ocrMaxConfidence === \"number\" &&\n ocrMinConfidence !== ocrMaxConfidence\n ? `Range ${ocrMinConfidence.toFixed(2)}-${ocrMaxConfidence.toFixed(2)}`\n : \"\",\n typeof ocrRegionCount === \"number\" ? `${ocrRegionCount} regions` : \"\",\n pdfTableHeaders.length > 0 ? `PDF table ${pdfTableHeaders.join(\", \")}` : \"\",\n typeof pdfTableColumnCount === \"number\"\n ? `PDF table ${pdfTableColumnCount} cols`\n : \"\",\n typeof pdfTableBodyRowCount === \"number\"\n ? `PDF table ${pdfTableBodyRowCount} body rows`\n : \"\",\n typeof pdfTableBodyRowStart === \"number\" &&\n typeof pdfTableBodyRowEnd === \"number\"\n ? pdfTableBodyRowStart === pdfTableBodyRowEnd\n ? `PDF table row ${pdfTableBodyRowStart}`\n : `PDF table rows ${pdfTableBodyRowStart}-${pdfTableBodyRowEnd}`\n : \"\",\n officeListContextText ? `Office list context ${officeListContextText}` : \"\",\n officeTableHeaders.length > 0\n ? `Office table ${officeTableHeaders.join(\", \")}`\n : \"\",\n typeof officeTableColumnCount === \"number\"\n ? `Office table ${officeTableColumnCount} cols`\n : \"\",\n typeof officeTableBodyRowCount === \"number\"\n ? `Office table ${officeTableBodyRowCount} body rows`\n : \"\",\n typeof officeTableBodyRowStart === \"number\" &&\n typeof officeTableBodyRowEnd === \"number\"\n ? officeTableBodyRowStart === officeTableBodyRowEnd\n ? `Office table row ${officeTableBodyRowStart}`\n : `Office table rows ${officeTableBodyRowStart}-${officeTableBodyRowEnd}`\n : \"\",\n officeTableContextText\n ? `Office table context ${officeTableContextText}`\n : \"\",\n officeTableFollowUpText\n ? `Office table follow-up ${officeTableFollowUpText}`\n : \"\",\n spreadsheetHeaders.length > 0\n ? `Spreadsheet ${spreadsheetHeaders.join(\", \")}`\n : \"\",\n spreadsheetColumnRange ? `Spreadsheet ${spreadsheetColumnRange}` : \"\",\n spreadsheetTableLabel ? `Spreadsheet ${spreadsheetTableLabel}` : \"\",\n mediaKind ? `Media ${mediaKind}` : \"\",\n mediaSegmentCount ? `${mediaSegmentCount} segments` : \"\",\n mediaSegmentGroupSize ? `${mediaSegmentGroupSize} grouped segments` : \"\",\n mediaSegmentGroupIndex !== undefined\n ? `Segment group ${mediaSegmentGroupIndex + 1}`\n : \"\",\n mediaChannel ? `Channel ${mediaChannel}` : \"\",\n mediaSpeakerCount ? `${mediaSpeakerCount} speakers` : \"\",\n mediaDurationLabel ? `Duration ${mediaDurationLabel}` : \"\",\n mediaSegmentWindowDurationLabel\n ? `Segment window ${mediaSegmentWindowDurationLabel}`\n : \"\",\n mediaSegmentGapLabel\n ? `Gap ${mediaSegmentGapLabel} from previous window`\n : \"\",\n transcriptSource ? `Transcript ${transcriptSource}` : \"\",\n threadTopic ? `Thread ${threadTopic}` : \"\",\n threadRootMessageId ? `Thread root ${threadRootMessageId}` : \"\",\n threadMessageCount ? `${threadMessageCount} thread messages` : \"\",\n replyDepth ? `Reply depth ${replyDepth}` : \"\",\n slideNotesText ? \"Speaker notes\" : \"\",\n archiveDepth ? `Archive depth ${archiveDepth}` : \"\",\n archiveNestedDepth ? `Archive nested depth ${archiveNestedDepth}` : \"\",\n archiveContainerPath ? `Archive container ${archiveContainerPath}` : \"\",\n archiveRootName ? `Archive root ${archiveRootName}` : \"\",\n speaker ? `Speaker ${speaker}` : \"\",\n from ? `Sender ${from}` : \"\",\n sentAt ? `Sent ${sentAt}` : \"\",\n ].filter((value) => value.length > 0);\n\n return labels.length > 0 ? labels.join(\" · \") : undefined;\n};\n\nexport const buildRAGSourceLabels = ({\n metadata,\n source,\n title,\n}: {\n metadata?: Record<string, unknown>;\n source?: string;\n title?: string;\n}): RAGSourceLabels | undefined => {\n const contextLabel = buildContextLabel(metadata);\n const locatorLabel = buildLocatorLabel(metadata, source, title);\n const provenanceLabel = buildProvenanceLabel(metadata);\n\n if (!contextLabel && !locatorLabel && !provenanceLabel) {\n return undefined;\n }\n\n return {\n contextLabel,\n locatorLabel,\n provenanceLabel,\n };\n};\n\nexport const buildRAGChunkStructure = (\n metadata?: Record<string, unknown>,\n): RAGChunkStructure | undefined => {\n if (!metadata) {\n return undefined;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath.filter(\n (value): value is string =>\n typeof value === \"string\" && value.trim().length > 0,\n )\n : undefined;\n const sectionKind =\n metadata.sectionKind === \"markdown_heading\" ||\n metadata.sectionKind === \"html_heading\" ||\n metadata.sectionKind === \"office_heading\" ||\n metadata.sectionKind === \"office_block\" ||\n metadata.sectionKind === \"pdf_block\" ||\n metadata.sectionKind === \"spreadsheet_rows\" ||\n metadata.sectionKind === \"presentation_slide\"\n ? metadata.sectionKind\n : undefined;\n const section: NonNullable<RAGChunkStructure[\"section\"]> = {\n depth: getContextNumber(metadata.sectionDepth),\n kind: sectionKind,\n path: sectionPath && sectionPath.length > 0 ? sectionPath : undefined,\n title: getContextString(metadata.sectionTitle),\n };\n const sequence: NonNullable<RAGChunkStructure[\"sequence\"]> = {\n nextChunkId: getContextString(metadata.nextChunkId),\n previousChunkId: getContextString(metadata.previousChunkId),\n sectionChunkCount: getContextNumber(metadata.sectionChunkCount),\n sectionChunkId: getContextString(metadata.sectionChunkId),\n sectionChunkIndex: getContextNumber(metadata.sectionChunkIndex),\n };\n\n if (\n !section.title &&\n (!section.path || section.path.length === 0) &&\n typeof section.depth !== \"number\" &&\n !section.kind &&\n !sequence.nextChunkId &&\n !sequence.previousChunkId &&\n typeof sequence.sectionChunkCount !== \"number\" &&\n !sequence.sectionChunkId &&\n typeof sequence.sectionChunkIndex !== \"number\"\n ) {\n return undefined;\n }\n\n return {\n section:\n section.title ||\n (section.path && section.path.length > 0) ||\n typeof section.depth === \"number\" ||\n section.kind\n ? section\n : undefined,\n sequence:\n sequence.nextChunkId ||\n sequence.previousChunkId ||\n typeof sequence.sectionChunkCount === \"number\" ||\n sequence.sectionChunkId ||\n typeof sequence.sectionChunkIndex === \"number\"\n ? sequence\n : undefined,\n };\n};\n\nconst buildExcerpt = (text: string, maxLength = 160) => {\n const normalized = text.replaceAll(/\\s+/g, \" \").trim();\n if (normalized.length <= maxLength) {\n return normalized;\n }\n\n return `${normalized.slice(0, Math.max(0, maxLength - 1)).trimEnd()}…`;\n};\n\ntype ExcerptChunkInput = Pick<\n RAGSource,\n \"chunkId\" | \"metadata\" | \"structure\" | \"text\"\n>;\n\nexport const buildRAGChunkExcerpts = (\n chunks: ExcerptChunkInput[],\n activeChunkId?: string,\n): RAGChunkExcerpts | undefined => {\n if (chunks.length === 0) {\n return undefined;\n }\n\n const graph = buildRAGChunkGraph(\n chunks.map((chunk) => ({\n chunkId: chunk.chunkId,\n metadata: chunk.metadata,\n structure: chunk.structure,\n })),\n );\n const navigation = buildRAGChunkGraphNavigation(graph, activeChunkId);\n const activeChunk =\n chunks.find((chunk) => chunk.chunkId === navigation.activeChunkId) ??\n chunks[0];\n if (!activeChunk) {\n return undefined;\n }\n\n const chunkMap = new Map(chunks.map((chunk) => [chunk.chunkId, chunk]));\n const orderedSectionIds =\n navigation.sectionNodes.length > 0\n ? navigation.sectionNodes.map((node) => node.chunkId)\n : [activeChunk.chunkId];\n const orderedWindowIds =\n navigation.sectionNodes.length > 0\n ? (() => {\n const activeIndex = navigation.sectionNodes.findIndex(\n (node) => node.chunkId === activeChunk.chunkId,\n );\n const startIndex = Math.max(0, activeIndex - 2);\n const endIndex = Math.min(\n navigation.sectionNodes.length,\n activeIndex + 3,\n );\n return navigation.sectionNodes\n .slice(startIndex, endIndex)\n .map((node) => node.chunkId);\n })()\n : [\n navigation.previousNode?.chunkId,\n activeChunk.chunkId,\n navigation.nextNode?.chunkId,\n ].filter(\n (chunkId, index, ids): chunkId is string =>\n Boolean(chunkId) && ids.indexOf(chunkId) === index,\n );\n\n const collectText = (chunkIds: string[]) =>\n chunkIds\n .map((chunkId) => chunkMap.get(chunkId)?.text)\n .filter((text): text is string => typeof text === \"string\")\n .join(\"\\n\\n\");\n\n return {\n chunkExcerpt: buildExcerpt(activeChunk.text, 160),\n sectionExcerpt: buildExcerpt(collectText(orderedSectionIds), 320),\n windowExcerpt: buildExcerpt(collectText(orderedWindowIds), 240),\n };\n};\n\nexport const buildRAGPreferredExcerpt = (\n excerpts?: RAGChunkExcerpts,\n structure?: RAGChunkStructure,\n) => {\n const selection = buildRAGExcerptSelection(excerpts, structure);\n return selection.excerpt;\n};\n\nexport const buildRAGExcerptSelection = (\n excerpts?: RAGChunkExcerpts,\n structure?: RAGChunkStructure,\n): RAGExcerptSelection & { excerpt: string } => {\n if (!excerpts) {\n return {\n excerpt: \"\",\n mode: \"chunk\",\n reason: \"single_chunk\",\n };\n }\n\n const chunkLength = excerpts.chunkExcerpt.trim().length;\n const sectionChunkCount = structure?.sequence?.sectionChunkCount ?? 1;\n if (sectionChunkCount > 1 && chunkLength > 0 && chunkLength < 72) {\n if (sectionChunkCount <= 3 && excerpts.sectionExcerpt.trim().length > 0) {\n return {\n excerpt: excerpts.sectionExcerpt,\n mode: \"section\",\n reason: \"section_small_enough\",\n };\n }\n if (excerpts.windowExcerpt.trim().length > 0) {\n return {\n excerpt: excerpts.windowExcerpt,\n mode: \"window\",\n reason: \"section_too_large_use_window\",\n };\n }\n\n return {\n excerpt: excerpts.chunkExcerpt,\n mode: \"chunk\",\n reason: \"chunk_too_narrow\",\n };\n }\n\n return {\n excerpt: excerpts.chunkExcerpt,\n mode: \"chunk\",\n reason: sectionChunkCount > 1 ? \"chunk_too_narrow\" : \"single_chunk\",\n };\n};\n\nexport const buildRAGExcerptModeCounts = (\n selections: Array<RAGExcerptSelection | undefined>,\n): RAGExcerptModeCounts =>\n selections.reduce<RAGExcerptModeCounts>(\n (counts, selection) => {\n if (selection) {\n counts[selection.mode] += 1;\n }\n return counts;\n },\n { chunk: 0, section: 0, window: 0 },\n );\n\ntype GraphChunkInput = Pick<\n RAGSource,\n \"chunkId\" | \"metadata\" | \"source\" | \"title\" | \"labels\" | \"structure\"\n> &\n Partial<Pick<RAGSource, \"score\">>;\n\nexport const buildRAGChunkGraph = (\n chunks: GraphChunkInput[],\n): RAGChunkGraph => {\n const nodes: RAGChunkGraphNode[] = [];\n const edges: RAGChunkGraphEdge[] = [];\n const edgeKeys = new Set<string>();\n const sections = new Map<string, RAGChunkGraphSectionGroup>();\n\n for (const chunk of chunks) {\n const labels =\n chunk.labels ??\n buildRAGSourceLabels({\n metadata: chunk.metadata,\n source: chunk.source,\n title: chunk.title,\n });\n const structure = chunk.structure ?? buildRAGChunkStructure(chunk.metadata);\n\n nodes.push({\n chunkId: chunk.chunkId,\n contextLabel: labels?.contextLabel,\n label: chunk.source ?? chunk.title ?? chunk.chunkId,\n locatorLabel: labels?.locatorLabel,\n provenanceLabel: labels?.provenanceLabel,\n score: chunk.score,\n source: chunk.source,\n structure,\n title: chunk.title,\n });\n\n const previousChunkId = structure?.sequence?.previousChunkId;\n if (previousChunkId) {\n const key = `previous:${previousChunkId}:${chunk.chunkId}`;\n if (!edgeKeys.has(key)) {\n edgeKeys.add(key);\n edges.push({\n fromChunkId: previousChunkId,\n relation: \"previous\",\n toChunkId: chunk.chunkId,\n });\n }\n }\n\n const nextChunkId = structure?.sequence?.nextChunkId;\n if (nextChunkId) {\n const key = `next:${chunk.chunkId}:${nextChunkId}`;\n if (!edgeKeys.has(key)) {\n edgeKeys.add(key);\n edges.push({\n fromChunkId: chunk.chunkId,\n relation: \"next\",\n toChunkId: nextChunkId,\n });\n }\n }\n\n const sectionId = structure?.sequence?.sectionChunkId;\n if (sectionId) {\n const existing = sections.get(sectionId);\n if (!existing) {\n sections.set(sectionId, {\n childSectionIds: [],\n chunkCount: structure.sequence?.sectionChunkCount ?? 1,\n chunkIds: [chunk.chunkId],\n depth: structure.section?.depth,\n id: sectionId,\n kind: structure.section?.kind,\n leadChunkId: chunk.chunkId,\n path: structure.section?.path,\n title: structure.section?.title,\n });\n continue;\n }\n\n if (!existing.chunkIds.includes(chunk.chunkId)) {\n existing.chunkIds.push(chunk.chunkId);\n }\n existing.chunkCount = Math.max(\n existing.chunkCount,\n structure.sequence?.sectionChunkCount ?? existing.chunkCount,\n );\n }\n }\n\n for (const section of sections.values()) {\n section.chunkIds.sort((left, right) => {\n const leftNode = nodes.find((node) => node.chunkId === left);\n const rightNode = nodes.find((node) => node.chunkId === right);\n const leftIndex =\n leftNode?.structure?.sequence?.sectionChunkIndex ??\n Number.MAX_SAFE_INTEGER;\n const rightIndex =\n rightNode?.structure?.sequence?.sectionChunkIndex ??\n Number.MAX_SAFE_INTEGER;\n if (leftIndex !== rightIndex) {\n return leftIndex - rightIndex;\n }\n\n return left.localeCompare(right);\n });\n section.leadChunkId = section.chunkIds[0];\n }\n\n const sectionPathIndex = new Map<string, RAGChunkGraphSectionGroup>();\n for (const section of sections.values()) {\n const path =\n section.path && section.path.length > 0\n ? section.path\n : section.title\n ? [section.title]\n : undefined;\n if (path && path.length > 0) {\n sectionPathIndex.set(path.join(\"\\u0000\"), section);\n }\n }\n\n for (const section of sections.values()) {\n const path =\n section.path && section.path.length > 0\n ? section.path\n : section.title\n ? [section.title]\n : undefined;\n if (!path || path.length < 2) {\n continue;\n }\n\n const parent = sectionPathIndex.get(path.slice(0, -1).join(\"\\u0000\"));\n if (!parent || parent.id === section.id) {\n continue;\n }\n\n section.parentSectionId = parent.id;\n if (!parent.childSectionIds.includes(section.id)) {\n parent.childSectionIds.push(section.id);\n }\n\n if (parent.leadChunkId && section.leadChunkId) {\n const parentKey = `section_parent:${section.leadChunkId}:${parent.leadChunkId}`;\n if (!edgeKeys.has(parentKey)) {\n edgeKeys.add(parentKey);\n edges.push({\n fromChunkId: section.leadChunkId,\n relation: \"section_parent\",\n toChunkId: parent.leadChunkId,\n });\n }\n\n const childKey = `section_child:${parent.leadChunkId}:${section.leadChunkId}`;\n if (!edgeKeys.has(childKey)) {\n edgeKeys.add(childKey);\n edges.push({\n fromChunkId: parent.leadChunkId,\n relation: \"section_child\",\n toChunkId: section.leadChunkId,\n });\n }\n }\n }\n\n nodes.sort((left, right) => {\n const leftSection =\n left.structure?.sequence?.sectionChunkIndex ?? Number.MAX_SAFE_INTEGER;\n const rightSection =\n right.structure?.sequence?.sectionChunkIndex ?? Number.MAX_SAFE_INTEGER;\n if (leftSection !== rightSection) {\n return leftSection - rightSection;\n }\n\n const leftScore = left.score ?? Number.NEGATIVE_INFINITY;\n const rightScore = right.score ?? Number.NEGATIVE_INFINITY;\n if (leftScore !== rightScore) {\n return rightScore - leftScore;\n }\n\n return left.label.localeCompare(right.label);\n });\n\n return {\n edges,\n nodes,\n sections: [...sections.values()].sort((left, right) =>\n (left.title ?? left.id).localeCompare(right.title ?? right.id),\n ),\n };\n};\n\nexport const buildRAGChunkPreviewGraph = (\n preview: Pick<RAGDocumentChunkPreview, \"chunks\" | \"document\">,\n): RAGChunkGraph =>\n buildRAGChunkGraph(\n preview.chunks.map((chunk) => ({\n chunkId: chunk.chunkId,\n labels: chunk.labels,\n metadata: chunk.metadata,\n source: chunk.source ?? preview.document.source,\n structure: chunk.structure,\n title: chunk.title ?? preview.document.title,\n })),\n );\n\nexport const buildRAGChunkPreviewNavigation = (\n preview: Pick<RAGDocumentChunkPreview, \"chunks\" | \"document\">,\n activeChunkId?: string,\n): RAGChunkGraphNavigation =>\n buildRAGChunkGraphNavigation(\n buildRAGChunkPreviewGraph(preview),\n activeChunkId,\n );\n\nexport const buildRAGChunkGraphNavigation = (\n graph: RAGChunkGraph,\n activeChunkId?: string,\n): RAGChunkGraphNavigation => {\n if (graph.nodes.length === 0) {\n return {\n activeChunkId,\n childSections: [],\n siblingSections: [],\n sectionNodes: [],\n };\n }\n\n const activeNode =\n (activeChunkId\n ? graph.nodes.find((node) => node.chunkId === activeChunkId)\n : undefined) ?? graph.nodes[0];\n const resolvedActiveChunkId = activeNode?.chunkId;\n const previousNode = activeNode?.structure?.sequence?.previousChunkId\n ? graph.nodes.find(\n (node) =>\n node.chunkId === activeNode.structure?.sequence?.previousChunkId,\n )\n : undefined;\n const nextNode = activeNode?.structure?.sequence?.nextChunkId\n ? graph.nodes.find(\n (node) => node.chunkId === activeNode.structure?.sequence?.nextChunkId,\n )\n : undefined;\n const section = activeNode?.structure?.sequence?.sectionChunkId\n ? graph.sections.find(\n (entry) => entry.id === activeNode.structure?.sequence?.sectionChunkId,\n )\n : undefined;\n const parentSection = section?.parentSectionId\n ? graph.sections.find((entry) => entry.id === section.parentSectionId)\n : undefined;\n const childSections = section\n ? section.childSectionIds\n .map((sectionId) =>\n graph.sections.find((entry) => entry.id === sectionId),\n )\n .filter((entry): entry is RAGChunkGraphSectionGroup => Boolean(entry))\n : [];\n const siblingSections = section?.parentSectionId\n ? graph.sections.filter(\n (entry) =>\n entry.parentSectionId === section.parentSectionId &&\n entry.id !== section.id,\n )\n : [];\n const sectionNodes = section\n ? section.chunkIds\n .map((chunkId) => graph.nodes.find((node) => node.chunkId === chunkId))\n .filter((node): node is RAGChunkGraphNode => Boolean(node))\n : activeNode\n ? [activeNode]\n : [];\n\n return {\n activeChunkId: resolvedActiveChunkId,\n activeNode,\n childSections,\n nextNode,\n parentSection,\n previousNode,\n section,\n siblingSections,\n sectionNodes,\n };\n};\nexport const buildRAGRetrievedState = (messages: AIMessage[]) => {\n const message = getLatestRetrievedMessage(messages);\n\n if (!message) {\n return null;\n }\n\n const sources = message.sources ?? [];\n const citations = buildRAGCitations(sources);\n const sectionDiagnostics = buildRAGSectionRetrievalDiagnostics(\n sources,\n isRAGRetrievalTrace(message.retrievalTrace)\n ? message.retrievalTrace\n : undefined,\n );\n const sourceSummaries = buildRAGSourceSummaries(sources);\n const groundedAnswer = buildRAGGroundedAnswer(message.content, sources);\n\n return {\n citationReferenceMap: buildRAGCitationReferenceMap(citations),\n citations,\n conversationId: message.conversationId,\n excerptModeCounts: buildRAGExcerptModeCounts([\n ...citations.map((citation) => citation.excerptSelection),\n ...sourceSummaries.map((summary) => summary.excerptSelection),\n ]),\n groundedAnswer,\n messageId: message.id,\n retrievalDurationMs: message.retrievalDurationMs,\n retrievalStartedAt: message.retrievalStartedAt,\n retrievedAt: message.retrievedAt,\n trace: isRAGRetrievalTrace(message.retrievalTrace)\n ? message.retrievalTrace\n : undefined,\n sectionDiagnostics,\n sourceGroups: buildRAGSourceGroups(sources),\n sourceSummaries,\n sources,\n };\n};\nexport const buildRAGSourceSummaries = (sources: RAGSource[]) => {\n const sourceGroups = buildRAGSourceGroups(sources);\n const citations = buildRAGCitations(sources);\n const citationReferenceMap = buildRAGCitationReferenceMap(citations);\n\n return sourceGroups.map<RAGSourceSummary>((group) => {\n const groupCitations = citations.filter((citation) =>\n group.chunks.some((chunk) => chunk.chunkId === citation.chunkId),\n );\n const leadChunk = getPreferredSourceLeadChunk(group.chunks);\n const excerpts = leadChunk\n ? buildRAGChunkExcerpts(group.chunks, leadChunk.chunkId)\n : undefined;\n const structure =\n leadChunk?.structure ?? buildRAGChunkStructure(leadChunk?.metadata);\n const excerptSelection = buildRAGExcerptSelection(excerpts, structure);\n\n return {\n bestScore: group.bestScore,\n citationNumbers: groupCitations.map(\n (citation) => citationReferenceMap[citation.chunkId] ?? 0,\n ),\n citations: groupCitations,\n chunkIds: group.chunks.map((chunk) => chunk.chunkId),\n contextLabel:\n leadChunk?.labels?.contextLabel ??\n buildContextLabel(leadChunk?.metadata),\n count: group.count,\n excerpt: excerptSelection.excerpt || buildExcerpt(leadChunk?.text ?? \"\"),\n excerpts,\n excerptSelection,\n key: group.key,\n label: group.label,\n locatorLabel:\n leadChunk?.labels?.locatorLabel ??\n buildLocatorLabel(\n leadChunk?.metadata,\n leadChunk?.source,\n leadChunk?.title,\n ),\n provenanceLabel:\n leadChunk?.labels?.provenanceLabel ??\n buildProvenanceLabel(leadChunk?.metadata),\n structure,\n source: group.source,\n title: group.title,\n };\n });\n};\n\nconst getSectionPathFromSource = (source: RAGSource) => {\n const path =\n source.structure?.section?.path ??\n (Array.isArray(source.metadata?.sectionPath)\n ? source.metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : []);\n\n return path.length > 0 ? path : undefined;\n};\n\nconst isBlockAwareContextLabel = (value?: string) =>\n typeof value === \"string\" &&\n (value.startsWith(\"PDF \") ||\n value.startsWith(\"Office \") ||\n value.startsWith(\"Slide \"));\n\nconst getStructuredSectionScoreWeight = (\n metadata?: Record<string, unknown>,\n) => {\n if (!metadata) {\n return 1;\n }\n\n const pdfTextKind = getContextString(metadata.pdfTextKind);\n const officeBlockKind = getContextString(metadata.officeBlockKind);\n const sectionKind = getContextString(metadata.sectionKind);\n const slideTitle = getContextString(metadata.slideTitle);\n const slideNotesText = getContextString(metadata.slideNotesText);\n\n if (pdfTextKind === \"table_like\") {\n return 1.28;\n }\n if (officeBlockKind === \"table\" || officeBlockKind === \"list\") {\n return 1.24;\n }\n if (\n sectionKind === \"pdf_block\" ||\n sectionKind === \"office_block\" ||\n officeBlockKind === \"paragraph\" ||\n pdfTextKind === \"paragraph\"\n ) {\n return 1.12;\n }\n if (sectionKind === \"presentation_slide\" && slideNotesText) {\n return 1.2;\n }\n if (sectionKind === \"presentation_slide\" && slideTitle) {\n return 1.14;\n }\n\n return 1;\n};\n\nconst getStructuredSourceLeadScore = (source: RAGSource) =>\n source.score * getStructuredSectionScoreWeight(source.metadata);\n\nconst getPDFLeadEvidencePreference = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return 0;\n }\n\n const pdfEvidenceMode = getContextString(metadata.pdfEvidenceMode);\n const pdfEvidenceOrigin = getContextString(metadata.pdfEvidenceOrigin);\n const pdfEvidenceSupplement = getContextString(\n metadata.pdfEvidenceSupplement,\n );\n\n if (\n pdfEvidenceMode === \"hybrid\" &&\n pdfEvidenceOrigin === \"native\" &&\n pdfEvidenceSupplement === \"ocr\"\n ) {\n return 3;\n }\n if (pdfEvidenceMode === \"native\" && pdfEvidenceOrigin === \"native\") {\n return 2;\n }\n if (pdfEvidenceMode === \"ocr\" && pdfEvidenceOrigin === \"ocr\") {\n return 1;\n }\n\n return 0;\n};\n\nconst getPDFLeadScope = (metadata?: Record<string, unknown>) => {\n if (!metadata) {\n return undefined;\n }\n\n const pageNumber =\n getContextNumber(metadata.pageNumber) ??\n getContextNumber(metadata.page) ??\n (typeof metadata.pageIndex === \"number\"\n ? metadata.pageIndex + 1\n : undefined);\n const sectionTitle = getContextString(metadata.sectionTitle);\n const sourceNativeKind = getContextString(metadata.sourceNativeKind);\n\n if (typeof pageNumber !== \"number\" && !sectionTitle && !sourceNativeKind) {\n return undefined;\n }\n\n return {\n pageNumber,\n sectionTitle,\n sourceNativeKind,\n };\n};\n\ntype OfficeLeadScope = {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n};\n\ntype GenericStructuredLeadScope = {\n familyPath: string[];\n kind: \"presentation_slide\" | \"spreadsheet_rows\";\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n};\n\nconst getOfficeLeadScope = (\n metadata?: Record<string, unknown>,\n): OfficeLeadScope | undefined => {\n if (!metadata) {\n return undefined;\n }\n\n const officeBlockKindValue = getContextString(metadata.officeBlockKind);\n const officeBlockKind =\n officeBlockKindValue === \"table\" ||\n officeBlockKindValue === \"list\" ||\n officeBlockKindValue === \"paragraph\"\n ? officeBlockKindValue\n : undefined;\n if (\n officeBlockKind !== \"table\" &&\n officeBlockKind !== \"list\" &&\n officeBlockKind !== \"paragraph\"\n ) {\n return undefined;\n }\n\n const sectionPath = Array.isArray(metadata.sectionPath)\n ? metadata.sectionPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const sectionTitle =\n getContextString(metadata.sectionTitle) ?? sectionPath.at(-1);\n const officeContextText =\n officeBlockKind === \"table\"\n ? getContextString(metadata.officeTableContextText)\n : officeBlockKind === \"list\"\n ? getContextString(metadata.officeListContextText)\n : undefined;\n\n if (!sectionTitle) {\n return undefined;\n }\n\n return {\n blockKind: officeBlockKind,\n familyPath: (() => {\n const explicitGenericFamilyPath = Array.isArray(\n metadata.sectionFamilyPath,\n )\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitGenericOrdinalPath = Array.isArray(\n metadata.sectionOrdinalPath,\n )\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n if (\n explicitGenericFamilyPath.length > 0 &&\n explicitGenericFamilyPath.length === explicitGenericOrdinalPath.length\n ) {\n return explicitGenericFamilyPath;\n }\n\n const explicitOfficeFamilyPath = Array.isArray(metadata.officeFamilyPath)\n ? metadata.officeFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n return explicitOfficeFamilyPath.length > 0\n ? explicitOfficeFamilyPath\n : sectionPath.map((value) => value.replace(/\\s+\\((\\d+)\\)$/, \"\").trim());\n })(),\n pathDepth: sectionPath.length,\n ordinalPath: (() => {\n const explicitGenericFamilyPath = Array.isArray(\n metadata.sectionFamilyPath,\n )\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitGenericOrdinalPath = Array.isArray(\n metadata.sectionOrdinalPath,\n )\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n if (\n explicitGenericFamilyPath.length > 0 &&\n explicitGenericFamilyPath.length === explicitGenericOrdinalPath.length\n ) {\n return explicitGenericOrdinalPath;\n }\n\n const explicitOfficeOrdinalPath = Array.isArray(\n metadata.officeOrdinalPath,\n )\n ? metadata.officeOrdinalPath\n .map((value) =>\n typeof value === \"number\" && Number.isFinite(value)\n ? value\n : undefined,\n )\n .filter((value): value is number => typeof value === \"number\")\n : [];\n return explicitOfficeOrdinalPath.length > 0\n ? explicitOfficeOrdinalPath\n : sectionPath.map((value) => {\n const match = value.match(/\\((\\d+)\\)$/);\n return match ? Number.parseInt(match[1] ?? \"1\", 10) : 1;\n });\n })(),\n sectionFamilyKey:\n getContextString(metadata.sectionSiblingFamilyKey) ??\n getContextString(metadata.officeSiblingFamilyKey) ??\n sectionPath\n .at(-1)\n ?.replace(/\\s+\\((\\d+)\\)$/, \"\")\n .trim() ??\n sectionTitle,\n sectionOrdinal:\n getContextNumber(metadata.sectionSiblingOrdinal) ??\n getContextNumber(metadata.officeSiblingOrdinal) ??\n (() => {\n const match = sectionTitle.match(/\\((\\d+)\\)$/);\n return match ? Number.parseInt(match[1] ?? \"1\", 10) : 1;\n })(),\n sectionTitle,\n hasContext: typeof officeContextText === \"string\",\n };\n};\n\nconst areOfficeLeadScopesComparable = (\n left:\n | {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n }\n | undefined,\n right:\n | {\n blockKind: \"list\" | \"paragraph\" | \"table\";\n familyPath: string[];\n hasContext: boolean;\n ordinalPath: number[];\n pathDepth: number;\n sectionFamilyKey: string;\n sectionOrdinal: number;\n sectionTitle: string;\n }\n | undefined,\n) => {\n if (!left || !right) {\n return false;\n }\n if (\n left.blockKind !== right.blockKind ||\n left.sectionFamilyKey !== right.sectionFamilyKey ||\n left.sectionOrdinal !== right.sectionOrdinal\n ) {\n return false;\n }\n const leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n const rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n const leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n const rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n const sharedDepth = Math.min(\n leftAncestorFamilyPath.length,\n rightAncestorFamilyPath.length,\n );\n for (let index = 0; index < sharedDepth; index += 1) {\n if (\n leftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n leftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n ) {\n return false;\n }\n }\n return true;\n};\n\nconst getGenericStructuredLeadScope = (\n metadata?: Record<string, unknown>,\n): GenericStructuredLeadScope | undefined => {\n if (!metadata || metadata.officeBlockKind || metadata.pageNumber) {\n return undefined;\n }\n\n const kind =\n metadata.sectionKind === \"spreadsheet_rows\" ||\n metadata.sectionKind === \"presentation_slide\"\n ? metadata.sectionKind\n : undefined;\n if (!kind) {\n return undefined;\n }\n\n const explicitFamilyPath = Array.isArray(metadata.sectionFamilyPath)\n ? metadata.sectionFamilyPath\n .map((value) => getContextString(value))\n .filter((value): value is string => typeof value === \"string\")\n : [];\n const explicitOrdinalPath = Array.isArray(metadata.sectionOrdinalPath)\n ? metadata.sectionOrdinalPath\n .map((value) => getContextNumber(value))\n .filter((value): value is number => typeof value === \"number\")\n : [];\n let familyPath =\n explicitFamilyPath.length > 0 &&\n explicitFamilyPath.length === explicitOrdinalPath.length\n ? explicitFamilyPath\n : [];\n let ordinalPath =\n explicitFamilyPath.length > 0 &&\n explicitFamilyPath.length === explicitOrdinalPath.length\n ? explicitOrdinalPath\n : [];\n\n if (familyPath.length === 0) {\n if (kind === \"spreadsheet_rows\") {\n const sheetName = getContextString(metadata.sheetName) ?? \"Sheet\";\n const tableIndex = getContextNumber(metadata.spreadsheetTableIndex) ?? 1;\n familyPath = [sheetName, \"Spreadsheet Table\"];\n ordinalPath = [1, tableIndex];\n } else {\n const slideFamily = getContextString(metadata.slideTitle) ?? \"Slide\";\n const slideOrdinal =\n getContextNumber(metadata.slideNumber) ??\n (typeof metadata.slideIndex === \"number\" ? metadata.slideIndex + 1 : 1);\n familyPath = [slideFamily];\n ordinalPath = [slideOrdinal];\n }\n }\n\n const sectionFamilyKey =\n getContextString(metadata.sectionSiblingFamilyKey) ?? familyPath.at(-1);\n const sectionOrdinal =\n getContextNumber(metadata.sectionSiblingOrdinal) ?? ordinalPath.at(-1);\n if (!sectionFamilyKey || typeof sectionOrdinal !== \"number\") {\n return undefined;\n }\n\n return {\n familyPath,\n kind,\n ordinalPath,\n pathDepth: familyPath.length,\n sectionFamilyKey,\n sectionOrdinal,\n };\n};\n\nconst areGenericStructuredLeadScopesComparable = (\n left: GenericStructuredLeadScope | undefined,\n right: GenericStructuredLeadScope | undefined,\n) => {\n if (!left || !right) {\n return false;\n }\n if (\n left.kind !== right.kind ||\n left.sectionFamilyKey !== right.sectionFamilyKey ||\n left.sectionOrdinal !== right.sectionOrdinal\n ) {\n return false;\n }\n const leftAncestorFamilyPath = left.familyPath.slice(0, -1);\n const rightAncestorFamilyPath = right.familyPath.slice(0, -1);\n const leftAncestorOrdinalPath = left.ordinalPath.slice(0, -1);\n const rightAncestorOrdinalPath = right.ordinalPath.slice(0, -1);\n const sharedDepth = Math.min(\n leftAncestorFamilyPath.length,\n rightAncestorFamilyPath.length,\n );\n for (let index = 0; index < sharedDepth; index += 1) {\n if (\n leftAncestorFamilyPath[index] !== rightAncestorFamilyPath[index] ||\n leftAncestorOrdinalPath[index] !== rightAncestorOrdinalPath[index]\n ) {\n return false;\n }\n }\n return true;\n};\n\nconst getOfficeLeadEvidencePreference = (\n metadata?: Record<string, unknown>,\n) => {\n const scope = getOfficeLeadScope(metadata);\n if (!scope) {\n return 0;\n }\n\n return (\n scope.pathDepth * 10 +\n (scope.hasContext ? 1 : 0) +\n (scope.blockKind === \"list\" &&\n typeof metadata?.officeListGroupItemCount === \"number\" &&\n metadata.officeListGroupItemCount > 1\n ? 1\n : 0)\n );\n};\n\nconst getGenericStructuredLeadPreference = (\n metadata?: Record<string, unknown>,\n) => {\n const scope = getGenericStructuredLeadScope(metadata);\n if (!scope) {\n return 0;\n }\n\n return (\n scope.pathDepth * 10 +\n (scope.kind === \"spreadsheet_rows\" &&\n typeof metadata?.spreadsheetTableIndex === \"number\"\n ? 2\n : 0) +\n (Array.isArray(metadata?.spreadsheetHeaders) &&\n metadata.spreadsheetHeaders.length > 0\n ? 1\n : 0) +\n (typeof metadata?.slideNotesText === \"string\" &&\n metadata.slideNotesText.trim().length > 0\n ? 1\n : 0)\n );\n};\n\nconst getPreferredSourceLeadChunk = (chunks: RAGSource[]) =>\n chunks.slice().sort((left, right) => {\n const leftOfficeScope = getOfficeLeadScope(left.metadata);\n const rightOfficeScope = getOfficeLeadScope(right.metadata);\n if (\n left.source === right.source &&\n areOfficeLeadScopesComparable(leftOfficeScope, rightOfficeScope)\n ) {\n const leftOfficePreference = getOfficeLeadEvidencePreference(\n left.metadata,\n );\n const rightOfficePreference = getOfficeLeadEvidencePreference(\n right.metadata,\n );\n if (rightOfficePreference !== leftOfficePreference) {\n return rightOfficePreference - leftOfficePreference;\n }\n }\n const leftGenericScope = getGenericStructuredLeadScope(left.metadata);\n const rightGenericScope = getGenericStructuredLeadScope(right.metadata);\n if (\n left.source === right.source &&\n areGenericStructuredLeadScopesComparable(\n leftGenericScope,\n rightGenericScope,\n )\n ) {\n const leftGenericPreference = getGenericStructuredLeadPreference(\n left.metadata,\n );\n const rightGenericPreference = getGenericStructuredLeadPreference(\n right.metadata,\n );\n if (rightGenericPreference !== leftGenericPreference) {\n return rightGenericPreference - leftGenericPreference;\n }\n }\n const leftWeightedScore = getStructuredSourceLeadScore(left);\n const rightWeightedScore = getStructuredSourceLeadScore(right);\n if (rightWeightedScore !== leftWeightedScore) {\n return rightWeightedScore - leftWeightedScore;\n }\n const leftScope = getPDFLeadScope(left.metadata);\n const rightScope = getPDFLeadScope(right.metadata);\n if (\n left.source === right.source &&\n leftScope &&\n rightScope &&\n ((leftScope.sectionTitle &&\n rightScope.sectionTitle &&\n leftScope.sectionTitle === rightScope.sectionTitle) ||\n (typeof leftScope.pageNumber === \"number\" &&\n typeof rightScope.pageNumber === \"number\" &&\n leftScope.pageNumber === rightScope.pageNumber))\n ) {\n const leftEvidencePreference = getPDFLeadEvidencePreference(\n left.metadata,\n );\n const rightEvidencePreference = getPDFLeadEvidencePreference(\n right.metadata,\n );\n if (rightEvidencePreference !== leftEvidencePreference) {\n return rightEvidencePreference - leftEvidencePreference;\n }\n }\n if (right.score !== left.score) {\n return right.score - left.score;\n }\n\n return left.chunkId.localeCompare(right.chunkId);\n })[0];\n\nexport const buildRAGSectionRetrievalDiagnostics = (\n sources: RAGSource[],\n trace?: RAGRetrievalTrace,\n): RAGSectionRetrievalDiagnostic[] => {\n const totalScore = sources.reduce(\n (sum, source) =>\n sum + source.score * getStructuredSectionScoreWeight(source.metadata),\n 0,\n );\n if (sources.length === 0 || totalScore <= 0) {\n return [];\n }\n\n const sections = new Map<\n string,\n {\n key: string;\n label: string;\n path?: string[];\n parentLabel?: string;\n count: number;\n bestScore: number;\n totalScore: number;\n topChunkId?: string;\n topSource?: string;\n vectorHits: number;\n lexicalHits: number;\n hybridHits: number;\n primaryHits: number;\n transformedHits: number;\n variantHits: number;\n sourceSet: Set<string>;\n }\n >();\n\n for (const source of sources) {\n const structuredScore =\n source.score * getStructuredSectionScoreWeight(source.metadata);\n const path = getSectionPathFromSource(source);\n if (!path) {\n continue;\n }\n\n const key = path.join(\" > \");\n const label = path.at(-1) ?? key;\n const parentLabel =\n path.length > 1 ? path.slice(0, -1).join(\" > \") : undefined;\n const existing = sections.get(key);\n const channels = Array.isArray(source.metadata?.retrievalChannels)\n ? source.metadata.retrievalChannels.filter(\n (value): value is \"vector\" | \"lexical\" =>\n value === \"vector\" || value === \"lexical\",\n )\n : [];\n const isHybrid =\n channels.includes(\"vector\") && channels.includes(\"lexical\");\n const vectorHits = channels.includes(\"vector\") ? 1 : 0;\n const lexicalHits = channels.includes(\"lexical\") ? 1 : 0;\n const hybridHits = isHybrid ? 1 : 0;\n const queryOrigins = Array.isArray(source.metadata?.retrievalQueryOrigins)\n ? source.metadata.retrievalQueryOrigins.filter(\n (value): value is \"primary\" | \"transformed\" | \"variant\" =>\n value === \"primary\" ||\n value === \"transformed\" ||\n value === \"variant\",\n )\n : source.metadata?.retrievalQueryOrigin === \"primary\" ||\n source.metadata?.retrievalQueryOrigin === \"transformed\" ||\n source.metadata?.retrievalQueryOrigin === \"variant\"\n ? [source.metadata.retrievalQueryOrigin]\n : [];\n const primaryHits = queryOrigins.includes(\"primary\") ? 1 : 0;\n const transformedHits = queryOrigins.includes(\"transformed\") ? 1 : 0;\n const variantHits = queryOrigins.includes(\"variant\") ? 1 : 0;\n if (!existing) {\n sections.set(key, {\n bestScore: source.score,\n count: 1,\n hybridHits,\n key,\n label,\n lexicalHits,\n parentLabel,\n path,\n primaryHits,\n sourceSet: new Set(source.source ? [source.source] : []),\n topChunkId: source.chunkId,\n topSource: source.source,\n totalScore: structuredScore,\n transformedHits,\n variantHits,\n vectorHits,\n });\n continue;\n }\n\n existing.count += 1;\n existing.totalScore += structuredScore;\n if (source.source) {\n existing.sourceSet.add(source.source);\n }\n existing.vectorHits += vectorHits;\n existing.lexicalHits += lexicalHits;\n existing.hybridHits += hybridHits;\n existing.primaryHits += primaryHits;\n existing.transformedHits += transformedHits;\n existing.variantHits += variantHits;\n if (source.score > existing.bestScore) {\n existing.bestScore = source.score;\n existing.topChunkId = source.chunkId;\n existing.topSource = source.source;\n }\n }\n\n const diagnostics = [...sections.values()];\n const strongestBestHit = diagnostics.reduce(\n (highest, section) => Math.max(highest, section.bestScore),\n 0,\n );\n const parentLabelByKey = new Map(\n diagnostics.map((section) => [section.key, section.parentLabel] as const),\n );\n const stageSectionCounts = new Map(\n (trace?.steps ?? [])\n .filter(\n (step) =>\n Array.isArray(step.sectionCounts) && step.sectionCounts.length > 0,\n )\n .map((step) => [step.stage, step.sectionCounts ?? []] as const),\n );\n const stageSectionScores = new Map(\n (trace?.steps ?? [])\n .filter(\n (step) =>\n Array.isArray(step.sectionScores) && step.sectionScores.length > 0,\n )\n .map((step) => [step.stage, step.sectionScores ?? []] as const),\n );\n\n return diagnostics\n .map<RAGSectionRetrievalDiagnostic>((section) => {\n const siblingPool = diagnostics.filter(\n (entry) => entry.parentLabel === section.parentLabel,\n );\n const siblings = siblingPool.filter((entry) => entry.key !== section.key);\n const strongestSibling = siblings\n .slice()\n .sort((left, right) => right.totalScore - left.totalScore)[0];\n const parentTotal = siblingPool.reduce(\n (sum, entry) => sum + entry.totalScore,\n 0,\n );\n const scoreShare = section.totalScore / totalScore;\n const parentShare =\n parentTotal > 0 ? section.totalScore / parentTotal : undefined;\n const topChunk = sources.find(\n (source) => source.chunkId === section.topChunkId,\n );\n const topContextLabel =\n topChunk?.labels?.contextLabel ?? buildContextLabel(topChunk?.metadata);\n const topLocatorLabel =\n topChunk?.labels?.locatorLabel ??\n buildLocatorLabel(\n topChunk?.metadata,\n topChunk?.source,\n topChunk?.title,\n );\n const sourceAwareChunkReason = formatSourceAwareChunkReason(\n topChunk?.metadata?.sourceAwareChunkReason,\n );\n const sourceAwareUnitScopeLabel = buildSourceAwareUnitScopeLabel(\n topChunk?.metadata,\n );\n const parentDistribution =\n parentTotal > 0\n ? siblingPool\n .map((entry) => ({\n count: entry.count,\n isActive: entry.key === section.key,\n key: entry.key,\n label: entry.label,\n parentShare: entry.totalScore / parentTotal,\n totalScore: entry.totalScore,\n }))\n .sort((left, right) => right.totalScore - left.totalScore)\n : [];\n const reasons: RAGSectionRetrievalDiagnostic[\"reasons\"] = [];\n const stageCounts =\n trace?.steps\n .map((step) => ({\n count:\n step.sectionCounts?.find((entry) => entry.key === section.key)\n ?.count ?? 0,\n stage: step.stage,\n }))\n .filter((entry) => entry.count > 0) ?? [];\n const stageWeights = stageCounts.map((entry) => {\n const previousStageEntry =\n stageCounts[\n stageCounts.findIndex(\n (candidate) => candidate.stage === entry.stage,\n ) - 1\n ];\n const stageEntries =\n stageSectionCounts\n .get(entry.stage)\n ?.filter((candidate) => candidate.count > 0) ?? [];\n const stageScoreEntries =\n stageSectionScores\n .get(entry.stage)\n ?.filter((candidate) => candidate.totalScore > 0) ?? [];\n const stageTotal = stageEntries.reduce(\n (sum, candidate) => sum + candidate.count,\n 0,\n );\n const stageScoreTotal = stageScoreEntries.reduce(\n (sum, candidate) => sum + candidate.totalScore,\n 0,\n );\n const siblingStageEntries = stageEntries.filter(\n (candidate) =>\n candidate.key !== section.key &&\n parentLabelByKey.get(candidate.key) === section.parentLabel,\n );\n const parentStageEntries = stageEntries.filter(\n (candidate) =>\n parentLabelByKey.get(candidate.key) === section.parentLabel,\n );\n const siblingStageScoreEntries = stageScoreEntries.filter(\n (candidate) =>\n candidate.key !== section.key &&\n parentLabelByKey.get(candidate.key) === section.parentLabel,\n );\n const parentStageScoreEntries = stageScoreEntries.filter(\n (candidate) =>\n parentLabelByKey.get(candidate.key) === section.parentLabel,\n );\n const strongestStageSibling = siblingStageEntries\n .slice()\n .sort((left, right) => right.count - left.count)[0];\n const parentStageTotal = parentStageEntries.reduce(\n (sum, candidate) => sum + candidate.count,\n 0,\n );\n const activeStageScore = stageScoreEntries.find(\n (candidate) => candidate.key === section.key,\n )?.totalScore;\n const strongestStageScoreSibling = siblingStageScoreEntries\n .slice()\n .sort((left, right) => right.totalScore - left.totalScore)[0];\n const parentStageScoreTotal = parentStageScoreEntries.reduce(\n (sum, candidate) => sum + candidate.totalScore,\n 0,\n );\n const stageShare = stageTotal > 0 ? entry.count / stageTotal : 0;\n const retentionRate =\n typeof previousStageEntry?.count === \"number\" &&\n previousStageEntry.count > 0\n ? entry.count / previousStageEntry.count\n : undefined;\n const countDelta =\n typeof previousStageEntry?.count === \"number\"\n ? entry.count - previousStageEntry.count\n : undefined;\n const parentStageShare =\n parentStageTotal > 0 ? entry.count / parentStageTotal : undefined;\n const stageScoreShare =\n typeof activeStageScore === \"number\" && stageScoreTotal > 0\n ? activeStageScore / stageScoreTotal\n : undefined;\n const parentStageScoreShare =\n typeof activeStageScore === \"number\" && parentStageScoreTotal > 0\n ? activeStageScore / parentStageScoreTotal\n : undefined;\n const stageShareGap =\n stageTotal > 0 && strongestStageSibling\n ? entry.count / stageTotal -\n strongestStageSibling.count / stageTotal\n : undefined;\n const parentStageShareGap =\n parentStageTotal > 0 && strongestStageSibling\n ? entry.count / parentStageTotal -\n strongestStageSibling.count / parentStageTotal\n : undefined;\n const stageScoreShareGap =\n typeof activeStageScore === \"number\" &&\n stageScoreTotal > 0 &&\n strongestStageScoreSibling\n ? activeStageScore / stageScoreTotal -\n strongestStageScoreSibling.totalScore / stageScoreTotal\n : undefined;\n const parentStageScoreShareGap =\n typeof activeStageScore === \"number\" &&\n parentStageScoreTotal > 0 &&\n strongestStageScoreSibling\n ? activeStageScore / parentStageScoreTotal -\n strongestStageScoreSibling.totalScore / parentStageScoreTotal\n : undefined;\n const reasons: RAGSectionRetrievalDiagnostic[\"stageWeights\"][number][\"reasons\"] =\n [];\n if (\n entry.stage === \"rerank\" &&\n stageShare > 0.5 &&\n (typeof stageShareGap !== \"number\" || stageShareGap > 0)\n ) {\n reasons.push(\"rerank_preserved_lead\");\n }\n if (entry.stage === \"finalize\" && stageShare >= 0.5) {\n reasons.push(\"final_stage_concentration\");\n }\n if (\n entry.stage === \"finalize\" &&\n typeof parentStageShare === \"number\" &&\n parentStageShare >= 0.6 &&\n (typeof parentStageShareGap !== \"number\" || parentStageShareGap > 0)\n ) {\n reasons.push(\"final_stage_dominant_within_parent\");\n }\n if (\n strongestStageSibling &&\n ((typeof stageShareGap === \"number\" && stageShareGap <= 0.1) ||\n (typeof parentStageShareGap === \"number\" &&\n parentStageShareGap <= 0.1))\n ) {\n reasons.push(\"stage_runner_up_pressure\");\n }\n if (typeof countDelta === \"number\") {\n if (countDelta > 0) {\n reasons.push(\"stage_expanded\");\n } else if (countDelta < 0) {\n reasons.push(\"stage_narrowed\");\n } else {\n reasons.push(\"stage_held\");\n }\n }\n\n return {\n count: entry.count,\n countDelta,\n parentStageScoreShare,\n parentStageShare,\n parentStageShareGap,\n previousCount: previousStageEntry?.count,\n previousStage: previousStageEntry?.stage,\n reasons,\n retentionRate,\n stage: entry.stage,\n stageScoreShare,\n stageScoreShareGap,\n stageShare,\n stageShareGap,\n totalScore: activeStageScore,\n strongestSiblingCount: strongestStageSibling?.count,\n strongestSiblingLabel: strongestStageSibling\n ? (diagnostics.find(\n (candidate) => candidate.key === strongestStageSibling.key,\n )?.label ?? strongestStageSibling.key)\n : undefined,\n };\n });\n const firstSeenStage = stageCounts[0]?.stage;\n const lastSeenStage = stageCounts.at(-1)?.stage;\n const peakStageEntry = stageCounts.reduce<\n (typeof stageCounts)[number] | undefined\n >(\n (highest, entry) =>\n !highest || entry.count > highest.count ? entry : highest,\n undefined,\n );\n const finalStageEntry = stageCounts.at(-1);\n const peakCount = peakStageEntry?.count ?? section.count;\n const finalCount = finalStageEntry?.count;\n const finalRetentionRate =\n typeof finalCount === \"number\" && peakCount > 0\n ? finalCount / peakCount\n : undefined;\n const dropFromPeak =\n typeof finalCount === \"number\" ? peakCount - finalCount : undefined;\n const queryAttributionReasons: RAGSectionRetrievalDiagnostic[\"queryAttribution\"][\"reasons\"] =\n [];\n const queryAttributionMode =\n section.primaryHits > 0 &&\n section.transformedHits === 0 &&\n section.variantHits === 0\n ? \"primary\"\n : section.transformedHits > 0 &&\n section.primaryHits === 0 &&\n section.variantHits === 0\n ? \"transformed\"\n : section.variantHits > 0 &&\n section.primaryHits === 0 &&\n section.transformedHits === 0\n ? \"variant\"\n : \"mixed\";\n if (queryAttributionMode === \"primary\") {\n queryAttributionReasons.push(\"base_query_only\");\n }\n if (queryAttributionMode === \"transformed\") {\n queryAttributionReasons.push(\"transformed_query_only\");\n queryAttributionReasons.push(\"transform_introduced\");\n }\n if (queryAttributionMode === \"variant\") {\n queryAttributionReasons.push(\"variant_only\");\n queryAttributionReasons.push(\"variant_supported\");\n }\n if (queryAttributionMode === \"mixed\") {\n queryAttributionReasons.push(\"mixed_query_sources\");\n if (section.variantHits > 0) {\n queryAttributionReasons.push(\"variant_supported\");\n }\n if (section.transformedHits > 0 && section.primaryHits === 0) {\n queryAttributionReasons.push(\"transform_introduced\");\n }\n }\n\n if (section.bestScore >= strongestBestHit) {\n reasons.push(\"best_hit\");\n }\n if (section.count > 1) {\n reasons.push(\"multi_hit_section\");\n }\n if (siblings.length === 0) {\n reasons.push(\"only_section_in_parent\");\n } else if (\n !strongestSibling ||\n section.totalScore >= strongestSibling.totalScore\n ) {\n reasons.push(\"dominant_within_parent\");\n }\n if (scoreShare >= 0.5 || (parentShare ?? 0) >= 0.6) {\n reasons.push(\"concentrated_evidence\");\n }\n\n const summaryParts = [\n isBlockAwareContextLabel(topContextLabel) ? topContextLabel : \"\",\n `${section.count} hit${section.count === 1 ? \"\" : \"s\"}`,\n `${(scoreShare * 100).toFixed(0)}% score share`,\n `vector ${section.vectorHits} · lexical ${section.lexicalHits} · hybrid ${section.hybridHits}`,\n typeof parentShare === \"number\"\n ? `${(parentShare * 100).toFixed(0)}% of parent section set`\n : \"\",\n sourceAwareChunkReason ? `boundary ${sourceAwareChunkReason}` : \"\",\n sourceAwareUnitScopeLabel ? `scope ${sourceAwareUnitScopeLabel}` : \"\",\n strongestSibling\n ? `ahead of ${strongestSibling.label} by ${(section.totalScore - strongestSibling.totalScore).toFixed(2)}`\n : \"no sibling competition\",\n ].filter(Boolean);\n\n return {\n averageScore: section.totalScore / section.count,\n bestScore: section.bestScore,\n count: section.count,\n key: section.key,\n label: section.label,\n parentLabel: section.parentLabel,\n parentDistribution,\n parentShare,\n parentShareGap:\n typeof parentShare === \"number\" && strongestSibling && parentTotal > 0\n ? parentShare - strongestSibling.totalScore / parentTotal\n : undefined,\n path: section.path,\n firstSeenStage,\n finalCount,\n finalRetentionRate,\n lastSeenStage,\n dropFromPeak,\n peakCount,\n peakStage: peakStageEntry?.stage,\n queryAttribution: {\n mode: queryAttributionMode,\n primaryHits: section.primaryHits,\n reasons: queryAttributionReasons,\n transformedHits: section.transformedHits,\n variantHits: section.variantHits,\n },\n requestedMode: trace?.requestedMode,\n retrievalMode: trace?.mode,\n routingLabel: trace?.routingLabel,\n routingProvider: trace?.routingProvider,\n routingReason: trace?.routingReason,\n queryTransformLabel: trace?.queryTransformLabel,\n queryTransformProvider: trace?.queryTransformProvider,\n queryTransformReason: trace?.queryTransformReason,\n reasons,\n evidenceReconcileApplied: trace?.steps.some(\n (step) => step.stage === \"evidence_reconcile\",\n ),\n rerankApplied: trace?.steps.some(\n (step) => step.stage === \"rerank\" && step.metadata?.applied === true,\n ),\n scoreShare,\n scoreThresholdApplied: trace?.steps.some(\n (step) => step.stage === \"score_filter\",\n ),\n stageCounts,\n stageWeights,\n siblingCount: siblings.length,\n siblingScoreGap: strongestSibling\n ? section.totalScore - strongestSibling.totalScore\n : undefined,\n sourceCount: section.sourceSet.size,\n sourceAwareChunkReasonLabel: sourceAwareChunkReason,\n sourceAwareUnitScopeLabel,\n topContextLabel,\n topLocatorLabel,\n sourceBalanceApplied: trace?.steps.some(\n (step) => step.stage === \"source_balance\",\n ),\n strongestSiblingLabel: strongestSibling?.label,\n strongestSiblingScore: strongestSibling?.totalScore,\n summary: summaryParts.join(\" · \"),\n topChunkId: section.topChunkId,\n topSource: section.topSource,\n totalScore: section.totalScore,\n hybridHits: section.hybridHits,\n lexicalHits: section.lexicalHits,\n vectorHits: section.vectorHits,\n };\n })\n .sort((left, right) => {\n if (right.totalScore !== left.totalScore) {\n return right.totalScore - left.totalScore;\n }\n if (right.bestScore !== left.bestScore) {\n return right.bestScore - left.bestScore;\n }\n return left.label.localeCompare(right.label);\n });\n};\n\nexport type RAGStreamProgress = {\n stage: RAGStreamStage;\n conversationId?: string;\n messageId?: string;\n retrievalStartedAt?: number;\n retrievedAt?: number;\n retrievalDurationMs?: number;\n hasContent: boolean;\n hasRetrieved: boolean;\n hasSources: boolean;\n hasThinking: boolean;\n hasToolCalls: boolean;\n isComplete: boolean;\n isError: boolean;\n isIdle: boolean;\n isRetrieving: boolean;\n isRetrieved: boolean;\n isStreaming: boolean;\n isSubmitting: boolean;\n sourceCount: number;\n latestMessage: AIMessage | undefined;\n};\n\nconst buildStreamProgressState = (messages: AIMessage[]) => {\n const latestMessage = getLatestAssistantMessage(messages);\n const retrieved = latestMessage\n ? buildRAGRetrievedState(messages)\n : undefined;\n\n return {\n conversationId: latestMessage?.conversationId,\n latestMessage,\n messageId: latestMessage?.id,\n retrieved,\n sourceCount:\n retrieved?.sources.length ?? latestMessage?.sources?.length ?? 0,\n };\n};\n\nexport const buildRAGStreamProgress = ({\n error,\n isStreaming,\n messages,\n}: {\n error: string | null;\n isStreaming: boolean;\n messages: AIMessage[];\n}): RAGStreamProgress => {\n const stage = resolveRAGStreamStage({\n error,\n isStreaming,\n messages,\n });\n const state = buildStreamProgressState(messages);\n const hasSources = state.sourceCount > 0;\n const hasRetrieved =\n stage === \"retrieved\" ||\n state.retrieved !== undefined ||\n state.latestMessage?.retrievedAt !== undefined;\n const hasThinking =\n typeof state.latestMessage?.thinking === \"string\" &&\n state.latestMessage.thinking.length > 0;\n const hasToolCalls = (state.latestMessage?.toolCalls?.length ?? 0) > 0;\n\n return {\n conversationId: state.conversationId,\n hasContent:\n typeof state.latestMessage?.content === \"string\" &&\n state.latestMessage.content.length > 0,\n hasRetrieved,\n hasSources,\n hasThinking,\n hasToolCalls,\n isComplete: stage === \"complete\",\n isError: stage === \"error\",\n isIdle: stage === \"idle\",\n isRetrieved: stage === \"retrieved\",\n isRetrieving: stage === \"submitting\" || stage === \"retrieving\",\n isStreaming: stage === \"streaming\",\n isSubmitting: stage === \"submitting\",\n latestMessage: state.latestMessage,\n messageId: state.messageId,\n retrievalDurationMs: state.retrieved?.retrievalDurationMs,\n retrievalStartedAt: state.retrieved?.retrievalStartedAt,\n retrievedAt: state.retrieved?.retrievedAt,\n sourceCount: state.sourceCount,\n stage,\n };\n};\n\nexport type RAGStreamProgressState = ReturnType<typeof buildRAGStreamProgress>;\nexport const buildRAGAnswerWorkflowState = ({\n error,\n isStreaming,\n messages,\n}: {\n error: string | null;\n isStreaming: boolean;\n messages: AIMessage[];\n}): RAGAnswerWorkflowState => {\n const latestAssistantMessage = getLatestAssistantMessage(messages);\n const sources = getLatestRAGSources(messages);\n const sourceGroups = buildRAGSourceGroups(sources);\n const citations = buildRAGCitations(sources);\n const citationReferenceMap = buildRAGCitationReferenceMap(citations);\n const sourceSummaries = buildRAGSourceSummaries(sources);\n const groundingReferences = buildRAGGroundingReferences(sources);\n const groundedAnswer = buildRAGGroundedAnswer(\n latestAssistantMessage?.content ?? \"\",\n sources,\n );\n const retrieval = buildRAGRetrievedState(messages);\n const sectionDiagnostics = buildRAGSectionRetrievalDiagnostics(\n sources,\n retrieval?.trace,\n );\n const progress = buildRAGStreamProgress({\n error,\n isStreaming,\n messages,\n });\n\n return {\n excerptModeCounts: buildRAGExcerptModeCounts([\n ...citations.map((citation) => citation.excerptSelection),\n ...sourceSummaries.map((summary) => summary.excerptSelection),\n ...groundingReferences.map((reference) => reference.excerptSelection),\n ...groundedAnswer.sectionSummaries.map(\n (summary) => summary.excerptSelection,\n ),\n ]),\n citationReferenceMap,\n citations,\n coverage: groundedAnswer.coverage,\n error,\n groundedAnswer,\n groundingReferences,\n hasCitations: groundedAnswer.hasCitations,\n hasGrounding: groundingReferences.length > 0,\n hasRetrieved: progress.hasRetrieved,\n hasSources: sources.length > 0,\n isAnswerStreaming: progress.isStreaming,\n isComplete: progress.isComplete,\n isError: progress.isError,\n isIdle: progress.isIdle,\n isRetrieved: progress.isRetrieved,\n isRetrieving: progress.isRetrieving,\n isRunning:\n progress.isSubmitting || progress.isRetrieving || progress.isStreaming,\n isSubmitting: progress.isSubmitting,\n latestAssistantMessage,\n messages,\n retrieval,\n retrievalDurationMs: retrieval?.retrievalDurationMs,\n retrievalStartedAt: retrieval?.retrievalStartedAt,\n retrievedAt: retrieval?.retrievedAt,\n sectionDiagnostics,\n sourceGroups,\n sourceSummaries,\n sources,\n stage: progress.stage,\n ungroundedReferenceNumbers: groundedAnswer.ungroundedReferenceNumbers,\n };\n};\n\nexport const buildRAGSourceGroups = (sources: RAGSource[]) => {\n const groups = new Map<string, RAGSourceGroup>();\n\n for (const source of sources) {\n updateSourceGroup(groups, source);\n }\n\n return [...groups.values()].sort((left, right) => {\n if (right.bestScore !== left.bestScore) {\n return right.bestScore - left.bestScore;\n }\n\n return left.label.localeCompare(right.label);\n });\n};\n\nconst buildSourceGroup = (source: RAGSource, key: string): RAGSourceGroup => ({\n bestScore: source.score,\n chunks: [source],\n count: 1,\n key,\n label: buildSourceLabel(source),\n labels:\n source.labels ??\n buildRAGSourceLabels({\n metadata: source.metadata,\n source: source.source,\n title: source.title,\n }),\n structure: source.structure ?? buildRAGChunkStructure(source.metadata),\n source: source.source,\n title: source.title,\n});\n\nconst updateSourceGroup = (\n groups: Map<string, RAGSourceGroup>,\n source: RAGSource,\n) => {\n const key = buildSourceGroupKey(source);\n const existing = groups.get(key);\n if (!existing) {\n groups.set(key, buildSourceGroup(source, key));\n\n return;\n }\n\n existing.bestScore = Math.max(existing.bestScore, source.score);\n existing.count += 1;\n existing.chunks.push(source);\n const leadChunk = getPreferredSourceLeadChunk(existing.chunks);\n if (leadChunk) {\n existing.label = buildSourceLabel(leadChunk);\n existing.labels =\n leadChunk.labels ??\n buildRAGSourceLabels({\n metadata: leadChunk.metadata,\n source: leadChunk.source,\n title: leadChunk.title,\n });\n existing.structure =\n leadChunk.structure ?? buildRAGChunkStructure(leadChunk.metadata);\n existing.source = leadChunk.source;\n existing.title = leadChunk.title;\n }\n};\nexport const getLatestAssistantMessage = (messages: AIMessage[]) => {\n for (let index = messages.length - 1; index >= 0; index -= 1) {\n const message = messages[index];\n if (message?.role === \"assistant\") {\n return message;\n }\n }\n\n return undefined;\n};\nexport const getLatestRAGSources = (messages: AIMessage[]) =>\n getLatestAssistantMessage(messages)?.sources ?? [];\nexport const getLatestRetrievedMessage = (messages: AIMessage[]) => {\n for (let index = messages.length - 1; index >= 0; index -= 1) {\n const message = messages[index];\n if (\n message?.role === \"assistant\" &&\n (typeof message.retrievedAt === \"number\" ||\n (message.sources?.length ?? 0) > 0)\n ) {\n return message;\n }\n }\n\n return undefined;\n};\nexport const resolveRAGStreamStage = ({\n error,\n isStreaming,\n messages,\n}: {\n error: string | null;\n isStreaming: boolean;\n messages: AIMessage[];\n}) => {\n if (error) {\n return \"error\";\n }\n\n const assistantMessage = getLatestAssistantMessage(messages);\n if (!assistantMessage) {\n return isStreaming ? \"submitting\" : \"idle\";\n }\n\n const isRetrieving =\n typeof assistantMessage.retrievalStartedAt === \"number\" &&\n typeof assistantMessage.retrievedAt !== \"number\";\n\n if (isRetrieving) {\n return \"retrieving\";\n }\n\n if (!isStreaming) {\n return \"complete\";\n }\n\n const hasRetrieved = typeof assistantMessage.retrievedAt === \"number\";\n const hasContent =\n assistantMessage.content.trim().length > 0 ||\n assistantMessage.thinking?.trim().length ||\n (assistantMessage.toolCalls?.length ?? 0) > 0 ||\n (assistantMessage.images?.length ?? 0) > 0;\n\n if (hasRetrieved && !hasContent) {\n return \"retrieved\";\n }\n\n return \"streaming\";\n};\n\nconst formatSignedDelta = (value: number, decimals = 0, suffix = \"\") =>\n `${value >= 0 ? \"+\" : \"\"}${value.toFixed(decimals)}${suffix}`;\n\nconst formatEvaluationPassingRate = (value: number) => `${value.toFixed(1)}%`;\n\nconst formatEvaluationSummary = (response: RAGEvaluationResponse) =>\n `${response.summary.totalCases} total · f1 ${response.summary.averageF1.toFixed(\n 3,\n )} · latency ${response.summary.averageLatencyMs.toFixed(1)}ms`;\n\nconst formatGroundingHistorySummaryValue = (response: {\n summary: {\n passedCases: number;\n totalCases: number;\n groundedCases: number;\n partialCases: number;\n ungroundedCases: number;\n averageResolvedCitationRate: number;\n averageCitationF1: number;\n };\n}) =>\n `${response.summary.passedCases}/${response.summary.totalCases} pass · grounded ${response.summary.groundedCases} · partial ${response.summary.partialCases} · ungrounded ${response.summary.ungroundedCases} · resolved citations ${(response.summary.averageResolvedCitationRate * 100).toFixed(1)}% · citation f1 ${response.summary.averageCitationF1.toFixed(3)}`;\n\nconst formatHistoryCaseLabels = (cases: RAGEvaluationCaseDiff[]) =>\n cases.length > 0\n ? cases.map((entry) => entry.label ?? entry.caseId).join(\", \")\n : \"none\";\n\nconst buildComparisonCaseLeadLabel = (snapshot?: {\n topLocatorLabel?: string;\n topContextLabel?: string;\n sourceAwareUnitScopeLabel?: string;\n sourceAwareChunkReasonLabel?: string;\n}) =>\n snapshot?.topLocatorLabel ??\n snapshot?.topContextLabel ??\n snapshot?.sourceAwareUnitScopeLabel ??\n snapshot?.sourceAwareChunkReasonLabel;\n\nconst formatComparisonLeadCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const labels = Array.from(\n new Set(\n (entry.caseTraceSnapshots ?? [])\n .map((snapshot) => buildComparisonCaseLeadLabel(snapshot))\n .filter((value): value is string => typeof value === \"string\"),\n ),\n ).slice(0, 3);\n\n return labels.length > 0 ? labels.join(\" · \") : \"none\";\n};\n\nconst formatComparisonLeadMediaCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const labels = Array.from(\n new Set(\n (entry.caseTraceSnapshots ?? [])\n .map((snapshot) =>\n formatLeadMediaCueSummary({\n leadSpeakerCue: snapshot.leadSpeakerCue,\n leadSpeakerAttributionCue: snapshot.leadSpeakerAttributionCue,\n leadChannelCue: snapshot.leadChannelCue,\n leadChannelAttributionCue: snapshot.leadChannelAttributionCue,\n leadContinuityCue: snapshot.leadContinuityCue,\n }),\n )\n .filter(\n (value): value is string =>\n typeof value === \"string\" && value !== \"none\",\n ),\n ),\n ).slice(0, 3);\n\n return labels.length > 0 ? labels.join(\" · \") : \"none\";\n};\n\nconst formatComparisonPresentationCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const labels = Array.from(\n new Set(\n (entry.caseTraceSnapshots ?? [])\n .map((snapshot) => snapshot.leadPresentationCue)\n .filter(\n (value): value is \"body\" | \"notes\" | \"title\" =>\n value === \"body\" || value === \"notes\" || value === \"title\",\n ),\n ),\n ).map((value) =>\n value === \"notes\" ? \"notes\" : value === \"title\" ? \"title\" : \"body\",\n );\n\n return labels.length > 0 ? labels.join(\" / \") : \"none\";\n};\n\nconst formatLeadPresentationCue = (\n cue?: \"body\" | \"notes\" | \"title\",\n): string => {\n if (cue === \"notes\" || cue === \"title\" || cue === \"body\") {\n return cue;\n }\n\n return \"none\";\n};\n\nconst formatSQLitePlannerCueSummary = (input?: {\n sqliteQueryMode?: string;\n sqliteQueryPushdownMode?: string;\n sqliteQueryPushdownApplied?: boolean;\n sqliteQueryPushdownClauseCount?: number;\n sqliteQueryPushdownCoverageRatio?: number;\n sqliteQueryTotalFilterClauseCount?: number;\n sqliteQueryJsRemainderClauseCount?: number;\n sqliteQueryPlannerProfileUsed?: string;\n sqliteQueryMultiplierUsed?: number;\n sqliteQueryCandidateLimitUsed?: number;\n sqliteQueryMaxBackfillsUsed?: number;\n sqliteQueryMinResultsUsed?: number;\n sqliteQueryFillPolicyUsed?: string;\n sqliteQueryJsRemainderRatio?: number;\n sqliteQueryFilteredCandidates?: number;\n sqliteQueryInitialSearchK?: number;\n sqliteQueryFinalSearchK?: number;\n sqliteQuerySearchExpansionRatio?: number;\n sqliteQueryBackfillCount?: number;\n sqliteQueryBackfillLimitReached?: boolean;\n sqliteQueryMinResultsSatisfied?: boolean;\n sqliteQueryReturnedCount?: number;\n sqliteQueryCandidateYieldRatio?: number;\n sqliteQueryTopKFillRatio?: number;\n sqliteQueryUnderfilledTopK?: boolean;\n sqliteQueryCandidateBudgetExhausted?: boolean;\n sqliteQueryCandidateCoverage?: string;\n}) => {\n const plannerJudgment =\n typeof input?.sqliteQuerySearchExpansionRatio === \"number\" &&\n typeof input?.sqliteQueryCandidateYieldRatio === \"number\" &&\n input.sqliteQuerySearchExpansionRatio >= 2 &&\n input.sqliteQueryCandidateYieldRatio < 0.25\n ? \"expensive backfill\"\n : typeof input?.sqliteQueryTopKFillRatio === \"number\" &&\n typeof input?.sqliteQueryCandidateYieldRatio === \"number\" &&\n input.sqliteQueryTopKFillRatio >= 1 &&\n input.sqliteQueryCandidateYieldRatio >= 0.5\n ? \"efficient fill\"\n : input?.sqliteQueryPushdownMode === \"full\" &&\n typeof input?.sqliteQueryPushdownCoverageRatio === \"number\" &&\n input.sqliteQueryPushdownCoverageRatio >= 1\n ? \"full pushdown\"\n : input?.sqliteQueryPushdownMode === \"partial\" &&\n typeof input?.sqliteQueryJsRemainderRatio === \"number\" &&\n input.sqliteQueryJsRemainderRatio >= 0.5\n ? \"heavy js remainder\"\n : undefined;\n\n const parts = [\n input?.sqliteQueryMode ? `mode ${input.sqliteQueryMode}` : undefined,\n input?.sqliteQueryPushdownMode\n ? `pushdown ${input.sqliteQueryPushdownMode}`\n : undefined,\n typeof input?.sqliteQueryPushdownApplied === \"boolean\"\n ? input.sqliteQueryPushdownApplied\n ? \"pushdown applied\"\n : \"pushdown skipped\"\n : undefined,\n typeof input?.sqliteQueryPushdownClauseCount === \"number\"\n ? `clauses ${input.sqliteQueryPushdownClauseCount}`\n : undefined,\n typeof input?.sqliteQueryPushdownCoverageRatio === \"number\"\n ? `pushdown ${(input.sqliteQueryPushdownCoverageRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.sqliteQueryJsRemainderClauseCount === \"number\"\n ? `js remainder ${input.sqliteQueryJsRemainderClauseCount}`\n : undefined,\n input?.sqliteQueryPlannerProfileUsed\n ? `profile ${input.sqliteQueryPlannerProfileUsed}`\n : undefined,\n typeof input?.sqliteQueryMultiplierUsed === \"number\"\n ? `x${input.sqliteQueryMultiplierUsed}`\n : undefined,\n typeof input?.sqliteQueryCandidateLimitUsed === \"number\"\n ? `cap ${input.sqliteQueryCandidateLimitUsed}`\n : undefined,\n typeof input?.sqliteQueryMaxBackfillsUsed === \"number\"\n ? `backfills ${input.sqliteQueryMaxBackfillsUsed}`\n : undefined,\n typeof input?.sqliteQueryMinResultsUsed === \"number\"\n ? `min ${input.sqliteQueryMinResultsUsed}`\n : undefined,\n input?.sqliteQueryFillPolicyUsed\n ? `fill ${input.sqliteQueryFillPolicyUsed}`\n : undefined,\n typeof input?.sqliteQueryJsRemainderRatio === \"number\"\n ? `js ${(input.sqliteQueryJsRemainderRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.sqliteQueryTotalFilterClauseCount === \"number\"\n ? `total clauses ${input.sqliteQueryTotalFilterClauseCount}`\n : undefined,\n typeof input?.sqliteQueryFilteredCandidates === \"number\"\n ? `filtered ${input.sqliteQueryFilteredCandidates}`\n : undefined,\n typeof input?.sqliteQueryInitialSearchK === \"number\" &&\n typeof input?.sqliteQueryFinalSearchK === \"number\"\n ? `searchK ${input.sqliteQueryInitialSearchK}->${input.sqliteQueryFinalSearchK}`\n : typeof input?.sqliteQueryFinalSearchK === \"number\"\n ? `searchK ${input.sqliteQueryFinalSearchK}`\n : undefined,\n typeof input?.sqliteQuerySearchExpansionRatio === \"number\"\n ? `expand ${(input.sqliteQuerySearchExpansionRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.sqliteQueryBackfillCount === \"number\"\n ? `backfill ${input.sqliteQueryBackfillCount}`\n : undefined,\n typeof input?.sqliteQueryBackfillLimitReached === \"boolean\" &&\n input.sqliteQueryBackfillLimitReached\n ? \"backfill limit reached\"\n : undefined,\n typeof input?.sqliteQueryMinResultsSatisfied === \"boolean\" &&\n input.sqliteQueryMinResultsSatisfied\n ? \"min satisfied\"\n : undefined,\n typeof input?.sqliteQueryReturnedCount === \"number\"\n ? `returned ${input.sqliteQueryReturnedCount}`\n : undefined,\n typeof input?.sqliteQueryCandidateYieldRatio === \"number\"\n ? `yield ${(input.sqliteQueryCandidateYieldRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.sqliteQueryTopKFillRatio === \"number\"\n ? `fill ${(input.sqliteQueryTopKFillRatio * 100).toFixed(0)}%`\n : undefined,\n input?.sqliteQueryCandidateCoverage\n ? `coverage ${input.sqliteQueryCandidateCoverage}`\n : undefined,\n typeof input?.sqliteQueryUnderfilledTopK === \"boolean\" &&\n input.sqliteQueryUnderfilledTopK\n ? \"underfilled topK\"\n : undefined,\n typeof input?.sqliteQueryCandidateBudgetExhausted === \"boolean\" &&\n input.sqliteQueryCandidateBudgetExhausted\n ? \"budget exhausted\"\n : undefined,\n plannerJudgment,\n ].filter((value): value is string => typeof value === \"string\");\n\n return parts.length > 0 ? parts.join(\" · \") : \"none\";\n};\n\nconst formatPostgresPlannerCueSummary = (input?: {\n postgresQueryMode?: string;\n postgresQueryPushdownMode?: string;\n postgresQueryPushdownApplied?: boolean;\n postgresQueryPushdownClauseCount?: number;\n postgresQueryPushdownCoverageRatio?: number;\n postgresQueryTotalFilterClauseCount?: number;\n postgresQueryJsRemainderClauseCount?: number;\n postgresQueryPlannerProfileUsed?: string;\n postgresQueryMultiplierUsed?: number;\n postgresQueryCandidateLimitUsed?: number;\n postgresQueryMaxBackfillsUsed?: number;\n postgresQueryMinResultsUsed?: number;\n postgresQueryFillPolicyUsed?: string;\n postgresQueryJsRemainderRatio?: number;\n postgresQueryFilteredCandidates?: number;\n postgresQueryInitialSearchK?: number;\n postgresQueryFinalSearchK?: number;\n postgresQuerySearchExpansionRatio?: number;\n postgresQueryBackfillCount?: number;\n postgresQueryBackfillLimitReached?: boolean;\n postgresQueryMinResultsSatisfied?: boolean;\n postgresQueryReturnedCount?: number;\n postgresQueryCandidateYieldRatio?: number;\n postgresQueryTopKFillRatio?: number;\n postgresQueryUnderfilledTopK?: boolean;\n postgresQueryCandidateBudgetExhausted?: boolean;\n postgresQueryCandidateCoverage?: string;\n postgresIndexType?: string;\n postgresIndexName?: string;\n postgresIndexPresent?: boolean;\n postgresEstimatedRowCount?: number;\n postgresTableBytes?: number;\n postgresIndexBytes?: number;\n postgresTotalBytes?: number;\n postgresIndexStorageRatio?: number;\n}) => {\n const plannerJudgment =\n typeof input?.postgresQuerySearchExpansionRatio === \"number\" &&\n typeof input?.postgresQueryCandidateYieldRatio === \"number\" &&\n input.postgresQuerySearchExpansionRatio >= 2 &&\n input.postgresQueryCandidateYieldRatio < 0.25\n ? \"expensive backfill\"\n : typeof input?.postgresQueryTopKFillRatio === \"number\" &&\n typeof input?.postgresQueryCandidateYieldRatio === \"number\" &&\n input.postgresQueryTopKFillRatio >= 1 &&\n input.postgresQueryCandidateYieldRatio >= 0.5\n ? \"efficient fill\"\n : input?.postgresQueryPushdownMode === \"full\" &&\n typeof input?.postgresQueryPushdownCoverageRatio === \"number\" &&\n input.postgresQueryPushdownCoverageRatio >= 1\n ? \"full pushdown\"\n : input?.postgresQueryPushdownMode === \"partial\" &&\n typeof input?.postgresQueryJsRemainderRatio === \"number\" &&\n input.postgresQueryJsRemainderRatio >= 0.5\n ? \"heavy js remainder\"\n : undefined;\n const healthJudgment =\n input?.postgresIndexPresent === false\n ? \"index missing\"\n : typeof input?.postgresIndexStorageRatio === \"number\" &&\n input.postgresIndexStorageRatio >= 0.7\n ? \"index-heavy storage\"\n : typeof input?.postgresEstimatedRowCount === \"number\" &&\n input.postgresEstimatedRowCount >= 1000 &&\n input.postgresIndexPresent === true\n ? \"indexed larger corpus\"\n : undefined;\n\n const parts = [\n input?.postgresQueryMode ? `mode ${input.postgresQueryMode}` : undefined,\n input?.postgresIndexType ? `index ${input.postgresIndexType}` : undefined,\n typeof input?.postgresIndexPresent === \"boolean\"\n ? input.postgresIndexPresent\n ? \"index present\"\n : \"index missing\"\n : undefined,\n typeof input?.postgresEstimatedRowCount === \"number\"\n ? `rows ${input.postgresEstimatedRowCount}`\n : undefined,\n typeof input?.postgresTableBytes === \"number\"\n ? `table ${formatByteSizeLabel(input.postgresTableBytes)}`\n : undefined,\n typeof input?.postgresIndexBytes === \"number\"\n ? `index ${formatByteSizeLabel(input.postgresIndexBytes)}`\n : undefined,\n typeof input?.postgresIndexStorageRatio === \"number\"\n ? `index share ${(input.postgresIndexStorageRatio * 100).toFixed(0)}%`\n : undefined,\n input?.postgresQueryPushdownMode\n ? `pushdown ${input.postgresQueryPushdownMode}`\n : undefined,\n typeof input?.postgresQueryPushdownApplied === \"boolean\"\n ? input.postgresQueryPushdownApplied\n ? \"pushdown on\"\n : \"pushdown off\"\n : undefined,\n typeof input?.postgresQueryPushdownClauseCount === \"number\"\n ? `clauses ${input.postgresQueryPushdownClauseCount}`\n : undefined,\n typeof input?.postgresQueryPushdownCoverageRatio === \"number\"\n ? `pushdown ${(input.postgresQueryPushdownCoverageRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.postgresQueryJsRemainderClauseCount === \"number\"\n ? `js remainder ${input.postgresQueryJsRemainderClauseCount}`\n : undefined,\n input?.postgresQueryPlannerProfileUsed\n ? `profile ${input.postgresQueryPlannerProfileUsed}`\n : undefined,\n typeof input?.postgresQueryMultiplierUsed === \"number\"\n ? `x${input.postgresQueryMultiplierUsed}`\n : undefined,\n typeof input?.postgresQueryCandidateLimitUsed === \"number\"\n ? `cap ${input.postgresQueryCandidateLimitUsed}`\n : undefined,\n typeof input?.postgresQueryMaxBackfillsUsed === \"number\"\n ? `backfills ${input.postgresQueryMaxBackfillsUsed}`\n : undefined,\n typeof input?.postgresQueryMinResultsUsed === \"number\"\n ? `min ${input.postgresQueryMinResultsUsed}`\n : undefined,\n input?.postgresQueryFillPolicyUsed\n ? `fill ${input.postgresQueryFillPolicyUsed}`\n : undefined,\n typeof input?.postgresQueryJsRemainderRatio === \"number\"\n ? `js ${(input.postgresQueryJsRemainderRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.postgresQueryTotalFilterClauseCount === \"number\"\n ? `total clauses ${input.postgresQueryTotalFilterClauseCount}`\n : undefined,\n typeof input?.postgresQueryFilteredCandidates === \"number\"\n ? `filtered ${input.postgresQueryFilteredCandidates}`\n : undefined,\n typeof input?.postgresQueryInitialSearchK === \"number\" &&\n typeof input?.postgresQueryFinalSearchK === \"number\"\n ? `searchK ${input.postgresQueryInitialSearchK}->${input.postgresQueryFinalSearchK}`\n : typeof input?.postgresQueryFinalSearchK === \"number\"\n ? `searchK ${input.postgresQueryFinalSearchK}`\n : undefined,\n typeof input?.postgresQuerySearchExpansionRatio === \"number\"\n ? `expand ${(input.postgresQuerySearchExpansionRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.postgresQueryBackfillCount === \"number\"\n ? `backfill ${input.postgresQueryBackfillCount}`\n : undefined,\n typeof input?.postgresQueryBackfillLimitReached === \"boolean\" &&\n input.postgresQueryBackfillLimitReached\n ? \"backfill limit reached\"\n : undefined,\n typeof input?.postgresQueryMinResultsSatisfied === \"boolean\" &&\n input.postgresQueryMinResultsSatisfied\n ? \"min satisfied\"\n : undefined,\n typeof input?.postgresQueryReturnedCount === \"number\"\n ? `returned ${input.postgresQueryReturnedCount}`\n : undefined,\n typeof input?.postgresQueryCandidateYieldRatio === \"number\"\n ? `yield ${(input.postgresQueryCandidateYieldRatio * 100).toFixed(0)}%`\n : undefined,\n typeof input?.postgresQueryTopKFillRatio === \"number\"\n ? `fill ${(input.postgresQueryTopKFillRatio * 100).toFixed(0)}%`\n : undefined,\n input?.postgresQueryCandidateCoverage\n ? `coverage ${input.postgresQueryCandidateCoverage}`\n : undefined,\n typeof input?.postgresQueryUnderfilledTopK === \"boolean\" &&\n input.postgresQueryUnderfilledTopK\n ? \"underfilled topK\"\n : undefined,\n typeof input?.postgresQueryCandidateBudgetExhausted === \"boolean\" &&\n input.postgresQueryCandidateBudgetExhausted\n ? \"budget exhausted\"\n : undefined,\n plannerJudgment,\n healthJudgment,\n ].filter((value): value is string => typeof value === \"string\");\n\n return parts.length > 0 ? parts.join(\" · \") : \"none\";\n};\n\nconst formatComparisonSQLitePlannerCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const labels = Array.from(\n new Set(\n (entry.caseTraceSnapshots ?? [])\n .map((snapshot) =>\n formatSQLitePlannerCueSummary({\n sqliteQueryBackfillCount: snapshot.sqliteQueryBackfillCount,\n sqliteQueryCandidateBudgetExhausted:\n snapshot.sqliteQueryCandidateBudgetExhausted,\n sqliteQueryCandidateCoverage: snapshot.sqliteQueryCandidateCoverage,\n sqliteQueryFilteredCandidates:\n snapshot.sqliteQueryFilteredCandidates,\n sqliteQueryFinalSearchK: snapshot.sqliteQueryFinalSearchK,\n sqliteQueryInitialSearchK: snapshot.sqliteQueryInitialSearchK,\n sqliteQuerySearchExpansionRatio:\n snapshot.sqliteQuerySearchExpansionRatio,\n sqliteQueryJsRemainderClauseCount:\n snapshot.sqliteQueryJsRemainderClauseCount,\n sqliteQueryCandidateLimitUsed:\n snapshot.sqliteQueryCandidateLimitUsed,\n sqliteQueryMaxBackfillsUsed: snapshot.sqliteQueryMaxBackfillsUsed,\n sqliteQueryMinResultsUsed: snapshot.sqliteQueryMinResultsUsed,\n sqliteQueryFillPolicyUsed: snapshot.sqliteQueryFillPolicyUsed,\n sqliteQueryMode: snapshot.sqliteQueryMode,\n sqliteQueryPushdownApplied: snapshot.sqliteQueryPushdownApplied,\n sqliteQueryPushdownClauseCount:\n snapshot.sqliteQueryPushdownClauseCount,\n sqliteQueryPushdownCoverageRatio:\n snapshot.sqliteQueryPushdownCoverageRatio,\n sqliteQueryPushdownMode: snapshot.sqliteQueryPushdownMode,\n sqliteQueryTotalFilterClauseCount:\n snapshot.sqliteQueryTotalFilterClauseCount,\n sqliteQueryReturnedCount: snapshot.sqliteQueryReturnedCount,\n sqliteQueryBackfillLimitReached:\n snapshot.sqliteQueryBackfillLimitReached,\n sqliteQueryMinResultsSatisfied:\n snapshot.sqliteQueryMinResultsSatisfied,\n sqliteQueryCandidateYieldRatio:\n snapshot.sqliteQueryCandidateYieldRatio,\n sqliteQueryTopKFillRatio: snapshot.sqliteQueryTopKFillRatio,\n sqliteQueryJsRemainderRatio: snapshot.sqliteQueryJsRemainderRatio,\n sqliteQueryUnderfilledTopK: snapshot.sqliteQueryUnderfilledTopK,\n }),\n )\n .filter(\n (value): value is string =>\n typeof value === \"string\" && value !== \"none\",\n ),\n ),\n ).slice(0, 3);\n\n return labels.length > 0 ? labels.join(\" · \") : \"none\";\n};\n\nconst formatComparisonPostgresPlannerCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const labels = Array.from(\n new Set(\n (entry.caseTraceSnapshots ?? [])\n .map((snapshot) =>\n formatPostgresPlannerCueSummary({\n postgresQueryBackfillCount: snapshot.postgresQueryBackfillCount,\n postgresQueryCandidateBudgetExhausted:\n snapshot.postgresQueryCandidateBudgetExhausted,\n postgresQueryCandidateCoverage:\n snapshot.postgresQueryCandidateCoverage,\n postgresQueryFilteredCandidates:\n snapshot.postgresQueryFilteredCandidates,\n postgresQueryFinalSearchK: snapshot.postgresQueryFinalSearchK,\n postgresQueryInitialSearchK: snapshot.postgresQueryInitialSearchK,\n postgresQuerySearchExpansionRatio:\n snapshot.postgresQuerySearchExpansionRatio,\n postgresQueryJsRemainderClauseCount:\n snapshot.postgresQueryJsRemainderClauseCount,\n postgresQueryCandidateLimitUsed:\n snapshot.postgresQueryCandidateLimitUsed,\n postgresQueryMaxBackfillsUsed:\n snapshot.postgresQueryMaxBackfillsUsed,\n postgresQueryMinResultsUsed: snapshot.postgresQueryMinResultsUsed,\n postgresQueryFillPolicyUsed: snapshot.postgresQueryFillPolicyUsed,\n postgresQueryMultiplierUsed: snapshot.postgresQueryMultiplierUsed,\n postgresQueryMode: snapshot.postgresQueryMode,\n postgresQueryPushdownApplied: snapshot.postgresQueryPushdownApplied,\n postgresQueryPushdownClauseCount:\n snapshot.postgresQueryPushdownClauseCount,\n postgresQueryPushdownCoverageRatio:\n snapshot.postgresQueryPushdownCoverageRatio,\n postgresQueryPushdownMode: snapshot.postgresQueryPushdownMode,\n postgresQueryTotalFilterClauseCount:\n snapshot.postgresQueryTotalFilterClauseCount,\n postgresQueryReturnedCount: snapshot.postgresQueryReturnedCount,\n postgresQueryBackfillLimitReached:\n snapshot.postgresQueryBackfillLimitReached,\n postgresQueryMinResultsSatisfied:\n snapshot.postgresQueryMinResultsSatisfied,\n postgresQueryCandidateYieldRatio:\n snapshot.postgresQueryCandidateYieldRatio,\n postgresQueryTopKFillRatio: snapshot.postgresQueryTopKFillRatio,\n postgresQueryJsRemainderRatio:\n snapshot.postgresQueryJsRemainderRatio,\n postgresEstimatedRowCount: snapshot.postgresEstimatedRowCount,\n postgresIndexBytes: snapshot.postgresIndexBytes,\n postgresIndexName: snapshot.postgresIndexName,\n postgresIndexPresent: snapshot.postgresIndexPresent,\n postgresIndexStorageRatio: snapshot.postgresIndexStorageRatio,\n postgresIndexType: snapshot.postgresIndexType,\n postgresTableBytes: snapshot.postgresTableBytes,\n postgresTotalBytes: snapshot.postgresTotalBytes,\n postgresQueryUnderfilledTopK: snapshot.postgresQueryUnderfilledTopK,\n }),\n )\n .filter(\n (value): value is string =>\n typeof value === \"string\" && value !== \"none\",\n ),\n ),\n ).slice(0, 3);\n\n return labels.length > 0 ? labels.join(\" · \") : \"none\";\n};\n\nconst formatComparisonLeadDrift = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n if (\n !leader?.caseTraceSnapshots?.length ||\n !entry.caseTraceSnapshots?.length\n ) {\n return \"none\";\n }\n\n const leaderCases = new Map(\n leader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot]),\n );\n\n const drift = entry.caseTraceSnapshots\n .map((snapshot) => {\n const leaderSnapshot = leaderCases.get(snapshot.caseId);\n const currentLead = buildComparisonCaseLeadLabel(snapshot);\n const leaderLead = buildComparisonCaseLeadLabel(leaderSnapshot);\n if (!currentLead || !leaderLead || currentLead === leaderLead) {\n return undefined;\n }\n\n return `${snapshot.label ?? snapshot.caseId} ${leaderLead}→${currentLead}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return drift.length > 0 ? drift.join(\" · \") : \"none\";\n};\n\nconst formatComparisonLeadMediaDrift = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n if (\n !leader?.caseTraceSnapshots?.length ||\n !entry.caseTraceSnapshots?.length\n ) {\n return \"none\";\n }\n\n const leaderCases = new Map(\n leader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot]),\n );\n\n const drift = entry.caseTraceSnapshots\n .map((snapshot) => {\n const leaderSnapshot = leaderCases.get(snapshot.caseId);\n const currentMediaCues = formatLeadMediaCueSummary({\n leadSpeakerCue: snapshot.leadSpeakerCue,\n leadSpeakerAttributionCue: snapshot.leadSpeakerAttributionCue,\n leadChannelCue: snapshot.leadChannelCue,\n leadChannelAttributionCue: snapshot.leadChannelAttributionCue,\n leadContinuityCue: snapshot.leadContinuityCue,\n });\n const leaderMediaCues = formatLeadMediaCueSummary({\n leadSpeakerCue: leaderSnapshot?.leadSpeakerCue,\n leadSpeakerAttributionCue: leaderSnapshot?.leadSpeakerAttributionCue,\n leadChannelCue: leaderSnapshot?.leadChannelCue,\n leadChannelAttributionCue: leaderSnapshot?.leadChannelAttributionCue,\n leadContinuityCue: leaderSnapshot?.leadContinuityCue,\n });\n if (\n currentMediaCues === \"none\" ||\n leaderMediaCues === \"none\" ||\n currentMediaCues === leaderMediaCues\n ) {\n return undefined;\n }\n\n return `${snapshot.label ?? snapshot.caseId} ${leaderMediaCues}→${currentMediaCues}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return drift.length > 0 ? drift.join(\" · \") : \"none\";\n};\n\nconst formatComparisonSQLitePlannerDrift = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n if (\n !leader?.caseTraceSnapshots?.length ||\n !entry.caseTraceSnapshots?.length\n ) {\n return \"none\";\n }\n\n const leaderCases = new Map(\n leader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot]),\n );\n\n const drift = entry.caseTraceSnapshots\n .map((snapshot) => {\n const leaderSnapshot = leaderCases.get(snapshot.caseId);\n const currentPlanner = formatSQLitePlannerCueSummary(snapshot);\n const leaderPlanner = formatSQLitePlannerCueSummary(leaderSnapshot);\n if (\n currentPlanner === \"none\" ||\n leaderPlanner === \"none\" ||\n currentPlanner === leaderPlanner\n ) {\n return undefined;\n }\n\n return `${snapshot.label ?? snapshot.caseId} ${leaderPlanner}→${currentPlanner}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return drift.length > 0 ? drift.join(\" · \") : \"none\";\n};\n\nconst formatComparisonPostgresPlannerDrift = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n if (\n !leader?.caseTraceSnapshots?.length ||\n !entry.caseTraceSnapshots?.length\n ) {\n return \"none\";\n }\n\n const leaderCases = new Map(\n leader.caseTraceSnapshots.map((snapshot) => [snapshot.caseId, snapshot]),\n );\n\n const drift = entry.caseTraceSnapshots\n .map((snapshot) => {\n const leaderSnapshot = leaderCases.get(snapshot.caseId);\n const currentPlanner = formatPostgresPlannerCueSummary(snapshot);\n const leaderPlanner = formatPostgresPlannerCueSummary(leaderSnapshot);\n if (\n currentPlanner === \"none\" ||\n leaderPlanner === \"none\" ||\n currentPlanner === leaderPlanner\n ) {\n return undefined;\n }\n\n return `${snapshot.label ?? snapshot.caseId} ${leaderPlanner}→${currentPlanner}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return drift.length > 0 ? drift.join(\" · \") : \"none\";\n};\n\nconst formatComparisonRoutingCueSummary = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const trace = entry.traceSummary;\n if (!trace) {\n return \"none\";\n }\n\n const parts = [\n `modes ${formatTraceModes(trace.modes)}`,\n `balance ${formatSourceBalanceStrategies(trace.sourceBalanceStrategies)}`,\n `rewrites ${formatTraceRatio(trace.transformedCases, trace.totalCases)}`,\n `variants ${formatTraceRatio(trace.variantCases, trace.totalCases)}`,\n ].filter((value) => !value.endsWith(\"n/a\"));\n\n return parts.length > 0 ? parts.join(\" · \") : \"none\";\n};\n\nconst formatComparisonRoutingDrift = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n) => {\n const trace = entry.traceSummary;\n const leaderTrace = leader?.traceSummary;\n if (!trace || !leaderTrace || entry === leader) {\n return \"none\";\n }\n\n const deltas: string[] = [];\n const currentModes = formatTraceModes(trace.modes);\n const previousModes = formatTraceModes(leaderTrace.modes);\n if (currentModes !== previousModes) {\n deltas.push(`modes ${previousModes}→${currentModes}`);\n }\n\n const currentBalance = formatSourceBalanceStrategies(\n trace.sourceBalanceStrategies,\n );\n const previousBalance = formatSourceBalanceStrategies(\n leaderTrace.sourceBalanceStrategies,\n );\n if (currentBalance !== previousBalance) {\n deltas.push(`balance ${previousBalance}→${currentBalance}`);\n }\n\n const transformedDelta =\n trace.transformedCases - leaderTrace.transformedCases;\n if (transformedDelta !== 0) {\n deltas.push(`rewrites ${formatTraceCountDelta(transformedDelta)}`);\n }\n\n const variantDelta = trace.variantCases - leaderTrace.variantCases;\n if (variantDelta !== 0) {\n deltas.push(`variants ${formatTraceCountDelta(variantDelta)}`);\n }\n\n return deltas.length > 0 ? deltas.slice(0, 3).join(\" · \") : \"none\";\n};\n\nconst formatHistoryRoutingShift = (history?: RAGEvaluationHistory) => {\n const delta = history?.diff?.traceSummaryDelta;\n if (!delta) {\n return \"none\";\n }\n\n const shifts: string[] = [];\n if (delta.modesChanged) {\n shifts.push(\"modes changed\");\n }\n if (delta.sourceBalanceStrategiesChanged) {\n shifts.push(\"balance changed\");\n }\n if (delta.transformedCases !== 0) {\n shifts.push(`rewrites ${formatTraceCountDelta(delta.transformedCases)}`);\n }\n if (delta.variantCases !== 0) {\n shifts.push(`variants ${formatTraceCountDelta(delta.variantCases)}`);\n }\n\n return shifts.length > 0 ? shifts.join(\" · \") : \"none\";\n};\n\nconst formatHistorySQLitePlannerShift = (history?: RAGEvaluationHistory) => {\n if (!history?.caseTraceSnapshots.length) {\n return \"none\";\n }\n\n const shifts = history.caseTraceSnapshots\n .map((entry) => {\n const previousPlanner = formatSQLitePlannerCueSummary({\n sqliteQueryBackfillCount: entry.previousSqliteQueryBackfillCount,\n sqliteQueryCandidateBudgetExhausted:\n entry.previousSqliteQueryCandidateBudgetExhausted,\n sqliteQueryCandidateCoverage:\n entry.previousSqliteQueryCandidateCoverage,\n sqliteQueryFilteredCandidates:\n entry.previousSqliteQueryFilteredCandidates,\n sqliteQueryFinalSearchK: entry.previousSqliteQueryFinalSearchK,\n sqliteQueryInitialSearchK: entry.previousSqliteQueryInitialSearchK,\n sqliteQuerySearchExpansionRatio:\n entry.previousSqliteQuerySearchExpansionRatio,\n sqliteQueryJsRemainderClauseCount:\n entry.previousSqliteQueryJsRemainderClauseCount,\n sqliteQueryCandidateLimitUsed:\n entry.previousSqliteQueryCandidateLimitUsed,\n sqliteQueryMaxBackfillsUsed: entry.previousSqliteQueryMaxBackfillsUsed,\n sqliteQueryMinResultsUsed: entry.previousSqliteQueryMinResultsUsed,\n sqliteQueryFillPolicyUsed: entry.previousSqliteQueryFillPolicyUsed,\n sqliteQueryMode: entry.previousSqliteQueryMode,\n sqliteQueryPushdownApplied: entry.previousSqliteQueryPushdownApplied,\n sqliteQueryPushdownClauseCount:\n entry.previousSqliteQueryPushdownClauseCount,\n sqliteQueryPushdownCoverageRatio:\n entry.previousSqliteQueryPushdownCoverageRatio,\n sqliteQueryPushdownMode: entry.previousSqliteQueryPushdownMode,\n sqliteQueryTotalFilterClauseCount:\n entry.previousSqliteQueryTotalFilterClauseCount,\n sqliteQueryJsRemainderRatio: entry.previousSqliteQueryJsRemainderRatio,\n sqliteQueryReturnedCount: entry.previousSqliteQueryReturnedCount,\n sqliteQueryBackfillLimitReached:\n entry.previousSqliteQueryBackfillLimitReached,\n sqliteQueryMinResultsSatisfied:\n entry.previousSqliteQueryMinResultsSatisfied,\n sqliteQueryCandidateYieldRatio:\n entry.previousSqliteQueryCandidateYieldRatio,\n sqliteQueryTopKFillRatio: entry.previousSqliteQueryTopKFillRatio,\n sqliteQueryUnderfilledTopK: entry.previousSqliteQueryUnderfilledTopK,\n });\n const currentPlanner = formatSQLitePlannerCueSummary(entry);\n\n if (\n previousPlanner === \"none\" ||\n currentPlanner === \"none\" ||\n previousPlanner === currentPlanner\n ) {\n return undefined;\n }\n\n return `${entry.label ?? entry.caseId} ${previousPlanner}→${currentPlanner}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return shifts.length > 0 ? shifts.join(\" · \") : \"none\";\n};\n\nconst formatHistoryPostgresPlannerShift = (history?: RAGEvaluationHistory) => {\n if (!history?.caseTraceSnapshots.length) {\n return \"none\";\n }\n\n const shifts = history.caseTraceSnapshots\n .map((entry) => {\n const previousPlanner = formatPostgresPlannerCueSummary({\n postgresQueryBackfillCount: entry.previousPostgresQueryBackfillCount,\n postgresQueryCandidateBudgetExhausted:\n entry.previousPostgresQueryCandidateBudgetExhausted,\n postgresQueryCandidateCoverage:\n entry.previousPostgresQueryCandidateCoverage,\n postgresQueryFilteredCandidates:\n entry.previousPostgresQueryFilteredCandidates,\n postgresQueryFinalSearchK: entry.previousPostgresQueryFinalSearchK,\n postgresQueryInitialSearchK: entry.previousPostgresQueryInitialSearchK,\n postgresQuerySearchExpansionRatio:\n entry.previousPostgresQuerySearchExpansionRatio,\n postgresQueryJsRemainderClauseCount:\n entry.previousPostgresQueryJsRemainderClauseCount,\n postgresQueryCandidateLimitUsed:\n entry.previousPostgresQueryCandidateLimitUsed,\n postgresQueryMaxBackfillsUsed:\n entry.previousPostgresQueryMaxBackfillsUsed,\n postgresQueryMinResultsUsed: entry.previousPostgresQueryMinResultsUsed,\n postgresQueryFillPolicyUsed: entry.previousPostgresQueryFillPolicyUsed,\n postgresQueryMultiplierUsed: entry.previousPostgresQueryMultiplierUsed,\n postgresQueryMode: entry.previousPostgresQueryMode,\n postgresQueryPushdownApplied:\n entry.previousPostgresQueryPushdownApplied,\n postgresQueryPushdownClauseCount:\n entry.previousPostgresQueryPushdownClauseCount,\n postgresQueryPushdownCoverageRatio:\n entry.previousPostgresQueryPushdownCoverageRatio,\n postgresQueryPushdownMode: entry.previousPostgresQueryPushdownMode,\n postgresQueryTotalFilterClauseCount:\n entry.previousPostgresQueryTotalFilterClauseCount,\n postgresQueryJsRemainderRatio:\n entry.previousPostgresQueryJsRemainderRatio,\n postgresQueryReturnedCount: entry.previousPostgresQueryReturnedCount,\n postgresQueryBackfillLimitReached:\n entry.previousPostgresQueryBackfillLimitReached,\n postgresQueryMinResultsSatisfied:\n entry.previousPostgresQueryMinResultsSatisfied,\n postgresQueryCandidateYieldRatio:\n entry.previousPostgresQueryCandidateYieldRatio,\n postgresQueryTopKFillRatio: entry.previousPostgresQueryTopKFillRatio,\n postgresQueryUnderfilledTopK:\n entry.previousPostgresQueryUnderfilledTopK,\n });\n const currentPlanner = formatPostgresPlannerCueSummary(entry);\n if (\n previousPlanner === \"none\" ||\n currentPlanner === \"none\" ||\n previousPlanner === currentPlanner\n ) {\n return undefined;\n }\n\n return `${entry.label ?? entry.caseId} ${previousPlanner}→${currentPlanner}`;\n })\n .filter((value): value is string => typeof value === \"string\")\n .slice(0, 3);\n\n return shifts.length > 0 ? shifts.join(\" · \") : \"none\";\n};\n\nconst formatTraceLeadChanges = (\n changes?: Array<{\n caseId: string;\n label?: string;\n previousLead?: string;\n currentLead: string;\n }>,\n) =>\n changes && changes.length > 0\n ? changes\n .slice(0, 3)\n .map((entry) => {\n const label = entry.label ?? entry.caseId;\n const previousLead = entry.previousLead ?? \"n/a\";\n return `${label} ${previousLead}→${entry.currentLead}`;\n })\n .join(\" · \")\n : \"none\";\n\nconst formatGroundingHistoryCaseLabels = (\n cases: RAGAnswerGroundingEvaluationCaseDiff[],\n) =>\n cases.length > 0\n ? cases.map((entry) => entry.label ?? entry.caseId).join(\", \")\n : \"none\";\n\nconst formatRerankerComparisonHeadline = (entry: RAGRerankerComparisonEntry) =>\n [\n entry.label,\n `passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n `f1 ${entry.response.summary.averageF1.toFixed(3)}`,\n `latency ${entry.response.summary.averageLatencyMs.toFixed(1)}ms`,\n ].join(\" · \");\n\nconst formatRetrievalComparisonHeadline = (\n entry: RAGRetrievalComparisonEntry,\n) =>\n [\n entry.label,\n `mode ${entry.retrievalMode}`,\n `passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n `f1 ${entry.response.summary.averageF1.toFixed(3)}`,\n `latency ${entry.response.summary.averageLatencyMs.toFixed(1)}ms`,\n ].join(\" · \");\n\nconst formatTraceModes = (modes: RAGHybridRetrievalMode[]) =>\n modes.length > 0 ? modes.join(\" / \") : \"n/a\";\n\nconst formatSourceBalanceStrategies = (\n strategies: RAGSourceBalanceStrategy[],\n) => (strategies.length > 0 ? strategies.join(\" / \") : \"n/a\");\n\nconst formatTraceStageSummary = (\n stageCounts: Partial<\n Record<RAGRetrievalTrace[\"steps\"][number][\"stage\"], number>\n >,\n) => {\n const topStages = Object.entries(stageCounts)\n .sort((left, right) => right[1] - left[1])\n .slice(0, 3);\n\n return topStages.length > 0\n ? topStages.map(([stage, count]) => `${stage} ${count}`).join(\" · \")\n : \"n/a\";\n};\n\nconst formatTraceRatio = (count: number, total: number) => `${count}/${total}`;\n\nconst formatTraceCountDelta = (value: number) =>\n `${value >= 0 ? \"+\" : \"\"}${value}`;\n\nconst buildComparisonOverviewPresentation = <\n TEntry extends {\n label: string;\n response: {\n passingRate: number;\n summary: {\n averageF1: number;\n averageLatencyMs: number;\n };\n };\n },\n>(input: {\n entries: TEntry[];\n summary: {\n bestByPassingRate?: string;\n bestByAverageF1?: string;\n fastest?: string;\n bestByPresentationTitleCueCases?: string;\n bestByPresentationBodyCueCases?: string;\n bestByPresentationNotesCueCases?: string;\n bestBySpreadsheetSheetCueCases?: string;\n bestBySpreadsheetTableCueCases?: string;\n bestBySpreadsheetColumnCueCases?: string;\n bestByMultivectorCollapsedCases?: string;\n bestByMultivectorLexicalHitCases?: string;\n bestByMultivectorVectorHitCases?: string;\n bestByEvidenceReconcileCases?: string;\n bestByOfficeEvidenceReconcileCases?: string;\n bestByOfficeParagraphEvidenceReconcileCases?: string;\n bestByOfficeListEvidenceReconcileCases?: string;\n bestByOfficeTableEvidenceReconcileCases?: string;\n bestByPDFEvidenceReconcileCases?: string;\n bestByLowestRuntimeCandidateBudgetExhaustedCases?: string;\n bestByLowestRuntimeUnderfilledTopKCases?: string;\n };\n resolveLabel: (id?: string) => string;\n resolveEntry: (id?: string) => TEntry | undefined;\n}): RAGComparisonOverviewPresentation => {\n const winnerLabel = input.resolveLabel(input.summary.bestByPassingRate);\n const winnerEntry = input.resolveEntry(input.summary.bestByPassingRate);\n const rows: RAGLabelValueRow[] = [\n {\n label: \"Best passing rate\",\n value: input.resolveLabel(input.summary.bestByPassingRate),\n },\n {\n label: \"Best average F1\",\n value: input.resolveLabel(input.summary.bestByAverageF1),\n },\n {\n label: \"Fastest\",\n value: input.resolveLabel(input.summary.fastest),\n },\n ];\n\n if (input.summary.bestByMultivectorCollapsedCases) {\n rows.push({\n label: \"Best multivector collapse\",\n value: input.resolveLabel(input.summary.bestByMultivectorCollapsedCases),\n });\n }\n if (input.summary.bestByMultivectorLexicalHitCases) {\n rows.push({\n label: \"Best multivector lexical hits\",\n value: input.resolveLabel(input.summary.bestByMultivectorLexicalHitCases),\n });\n }\n if (input.summary.bestByMultivectorVectorHitCases) {\n rows.push({\n label: \"Best multivector vector hits\",\n value: input.resolveLabel(input.summary.bestByMultivectorVectorHitCases),\n });\n }\n if (input.summary.bestByEvidenceReconcileCases) {\n rows.push({\n label: \"Best evidence reconcile\",\n value: input.resolveLabel(input.summary.bestByEvidenceReconcileCases),\n });\n }\n if (input.summary.bestByPresentationTitleCueCases) {\n rows.push({\n label: \"Best presentation title cue\",\n value: input.resolveLabel(input.summary.bestByPresentationTitleCueCases),\n });\n }\n if (input.summary.bestByPresentationBodyCueCases) {\n rows.push({\n label: \"Best presentation body cue\",\n value: input.resolveLabel(input.summary.bestByPresentationBodyCueCases),\n });\n }\n if (input.summary.bestByPresentationNotesCueCases) {\n rows.push({\n label: \"Best presentation notes cue\",\n value: input.resolveLabel(input.summary.bestByPresentationNotesCueCases),\n });\n }\n if (input.summary.bestBySpreadsheetSheetCueCases) {\n rows.push({\n label: \"Best spreadsheet sheet cue\",\n value: input.resolveLabel(input.summary.bestBySpreadsheetSheetCueCases),\n });\n }\n if (input.summary.bestBySpreadsheetTableCueCases) {\n rows.push({\n label: \"Best spreadsheet table cue\",\n value: input.resolveLabel(input.summary.bestBySpreadsheetTableCueCases),\n });\n }\n if (input.summary.bestBySpreadsheetColumnCueCases) {\n rows.push({\n label: \"Best spreadsheet column cue\",\n value: input.resolveLabel(input.summary.bestBySpreadsheetColumnCueCases),\n });\n }\n if (input.summary.bestByOfficeEvidenceReconcileCases) {\n rows.push({\n label: \"Best office structure reconcile (docx/xlsx/pptx)\",\n value: input.resolveLabel(\n input.summary.bestByOfficeEvidenceReconcileCases,\n ),\n });\n }\n if (input.summary.bestByOfficeParagraphEvidenceReconcileCases) {\n rows.push({\n label: \"Best office narrative reconcile\",\n value: input.resolveLabel(\n input.summary.bestByOfficeParagraphEvidenceReconcileCases,\n ),\n });\n }\n if (input.summary.bestByOfficeListEvidenceReconcileCases) {\n rows.push({\n label: \"Best office checklist reconcile\",\n value: input.resolveLabel(\n input.summary.bestByOfficeListEvidenceReconcileCases,\n ),\n });\n }\n if (input.summary.bestByOfficeTableEvidenceReconcileCases) {\n rows.push({\n label: \"Best office table reconcile\",\n value: input.resolveLabel(\n input.summary.bestByOfficeTableEvidenceReconcileCases,\n ),\n });\n }\n if (input.summary.bestByPDFEvidenceReconcileCases) {\n rows.push({\n label: \"Best PDF native evidence\",\n value: input.resolveLabel(input.summary.bestByPDFEvidenceReconcileCases),\n });\n }\n if (input.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases) {\n rows.push({\n label: \"Lowest runtime budget exhaustion\",\n value: input.resolveLabel(\n input.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases,\n ),\n });\n }\n if (input.summary.bestByLowestRuntimeUnderfilledTopKCases) {\n rows.push({\n label: \"Lowest runtime underfilled TopK\",\n value: input.resolveLabel(\n input.summary.bestByLowestRuntimeUnderfilledTopKCases,\n ),\n });\n }\n\n return {\n rows,\n winnerLabel,\n summary: winnerEntry\n ? `passing ${formatEvaluationPassingRate(winnerEntry.response.passingRate)} · f1 ${winnerEntry.response.summary.averageF1.toFixed(3)} · latency ${winnerEntry.response.summary.averageLatencyMs.toFixed(1)}ms`\n : \"Stored benchmark comparison\",\n };\n};\n\nexport const buildRAGComparisonTraceSummaryRows = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n): RAGLabelValueRow[] => {\n const trace = entry.traceSummary;\n const rows: RAGLabelValueRow[] = [\n {\n label: \"Lead cues\",\n value: formatComparisonLeadCueSummary(entry),\n },\n {\n label: \"Lead media cues\",\n value: formatComparisonLeadMediaCueSummary(entry),\n },\n {\n label: \"Presentation cues\",\n value: formatComparisonPresentationCueSummary(entry),\n },\n {\n label: \"SQLite planner cues\",\n value: formatComparisonSQLitePlannerCueSummary(entry),\n },\n {\n label: \"Postgres planner cues\",\n value: formatComparisonPostgresPlannerCueSummary(entry),\n },\n {\n label: \"Routing cues\",\n value: formatComparisonRoutingCueSummary(entry),\n },\n ];\n\n if (!trace) {\n rows.unshift({ label: \"Trace\", value: \"Unavailable\" });\n return rows;\n }\n\n rows.push(\n { label: \"Modes\", value: formatTraceModes(trace.modes) },\n {\n label: \"Balance\",\n value: formatSourceBalanceStrategies(trace.sourceBalanceStrategies),\n },\n { label: \"Avg final\", value: trace.averageFinalCount.toFixed(1) },\n { label: \"Avg vector\", value: trace.averageVectorCount.toFixed(1) },\n { label: \"Avg lexical\", value: trace.averageLexicalCount.toFixed(1) },\n {\n label: \"Balanced\",\n value: formatTraceRatio(trace.balancedCases, trace.totalCases),\n },\n {\n label: \"Round robin\",\n value: formatTraceRatio(trace.roundRobinCases, trace.totalCases),\n },\n {\n label: \"Transforms\",\n value: formatTraceRatio(trace.transformedCases, trace.totalCases),\n },\n {\n label: \"Variants\",\n value: formatTraceRatio(trace.variantCases, trace.totalCases),\n },\n {\n label: \"Multivector\",\n value: `${formatTraceRatio(\n trace.multiVectorCases,\n trace.totalCases,\n )} · collapse ${formatTraceRatio(\n trace.multiVectorCollapsedCases,\n trace.totalCases,\n )} · lexical ${formatTraceRatio(\n trace.multiVectorLexicalHitCases,\n trace.totalCases,\n )} · vector ${formatTraceRatio(\n trace.multiVectorVectorHitCases,\n trace.totalCases,\n )}`,\n },\n {\n label: \"Runtime\",\n value: `budget ${formatTraceRatio(\n trace.runtimeCandidateBudgetExhaustedCases,\n trace.totalCases,\n )} · underfilled ${formatTraceRatio(\n trace.runtimeUnderfilledTopKCases,\n trace.totalCases,\n )}`,\n },\n {\n label: \"Evidence reconcile (office/pdf)\",\n value: `all ${formatTraceRatio(\n trace.stageCounts.evidence_reconcile ?? 0,\n trace.totalCases,\n )} · office structure ${formatTraceRatio(\n trace.officeEvidenceReconcileCases,\n trace.totalCases,\n )} · narrative ${formatTraceRatio(\n trace.officeParagraphEvidenceReconcileCases ?? 0,\n trace.totalCases,\n )} · checklist ${formatTraceRatio(\n trace.officeListEvidenceReconcileCases ?? 0,\n trace.totalCases,\n )} · table ${formatTraceRatio(\n trace.officeTableEvidenceReconcileCases ?? 0,\n trace.totalCases,\n )} · pdf native ${formatTraceRatio(\n trace.pdfEvidenceReconcileCases,\n trace.totalCases,\n )}`,\n },\n {\n label: \"TopK\",\n value: `${trace.averageCandidateTopK.toFixed(\n 1,\n )} / ${trace.averageLexicalTopK.toFixed(1)}`,\n },\n {\n label: \"Stages\",\n value: formatTraceStageSummary(trace.stageCounts),\n },\n );\n\n return rows;\n};\n\nexport const buildRAGComparisonTraceDiffRows = (\n entry: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n leader?: RAGRerankerComparisonEntry | RAGRetrievalComparisonEntry,\n): RAGLabelValueRow[] => {\n const trace = entry.traceSummary;\n const leadDriftRow = {\n label: \"Lead drift vs leader\",\n value: formatComparisonLeadDrift(entry, leader),\n } satisfies RAGLabelValueRow;\n const leadMediaDriftRow = {\n label: \"Lead media shift vs leader\",\n value: formatComparisonLeadMediaDrift(entry, leader),\n } satisfies RAGLabelValueRow;\n const sqlitePlannerDriftRow = {\n label: \"SQLite planner shift vs leader\",\n value: formatComparisonSQLitePlannerDrift(entry, leader),\n } satisfies RAGLabelValueRow;\n const postgresPlannerDriftRow = {\n label: \"Postgres planner shift vs leader\",\n value: formatComparisonPostgresPlannerDrift(entry, leader),\n } satisfies RAGLabelValueRow;\n const routingDriftRow = {\n label: \"Routing shift vs leader\",\n value: formatComparisonRoutingDrift(entry, leader),\n } satisfies RAGLabelValueRow;\n\n if (!trace) {\n return [\n { label: \"Trace\", value: \"Unavailable for comparison\" },\n leadDriftRow,\n leadMediaDriftRow,\n sqlitePlannerDriftRow,\n postgresPlannerDriftRow,\n routingDriftRow,\n ];\n }\n\n const leaderTrace = leader?.traceSummary;\n if (!leaderTrace) {\n return [\n { label: \"Baseline\", value: \"Leader trace unavailable\" },\n leadDriftRow,\n leadMediaDriftRow,\n sqlitePlannerDriftRow,\n postgresPlannerDriftRow,\n routingDriftRow,\n ];\n }\n\n if (entry === leader) {\n return [\n { label: \"Baseline\", value: \"Leader strategy\" },\n leadDriftRow,\n leadMediaDriftRow,\n sqlitePlannerDriftRow,\n postgresPlannerDriftRow,\n routingDriftRow,\n ];\n }\n\n const stageDelta = Object.keys({\n ...leaderTrace.stageCounts,\n ...trace.stageCounts,\n })\n .map((stage) => {\n const typedStage = stage as RAGRetrievalTraceStep[\"stage\"];\n const delta =\n (trace.stageCounts[typedStage] ?? 0) -\n (leaderTrace.stageCounts[typedStage] ?? 0);\n return delta === 0\n ? null\n : `${typedStage} ${formatTraceCountDelta(delta)}`;\n })\n .filter((value): value is string => Boolean(value))\n .slice(0, 3)\n .join(\" · \");\n\n const rows: RAGLabelValueRow[] = [{ label: \"Baseline\", value: leader.label }];\n\n if (formatTraceModes(trace.modes) !== formatTraceModes(leaderTrace.modes)) {\n rows.push({\n label: \"Modes vs leader\",\n value: `${formatTraceModes(trace.modes)} vs ${formatTraceModes(\n leaderTrace.modes,\n )}`,\n });\n }\n\n if (\n formatSourceBalanceStrategies(trace.sourceBalanceStrategies) !==\n formatSourceBalanceStrategies(leaderTrace.sourceBalanceStrategies)\n ) {\n rows.push({\n label: \"Balance vs leader\",\n value: `${formatSourceBalanceStrategies(\n trace.sourceBalanceStrategies,\n )} vs ${formatSourceBalanceStrategies(\n leaderTrace.sourceBalanceStrategies,\n )}`,\n });\n }\n\n rows.push(\n leadDriftRow,\n leadMediaDriftRow,\n sqlitePlannerDriftRow,\n postgresPlannerDriftRow,\n routingDriftRow,\n );\n\n rows.push(\n {\n label: \"Final delta\",\n value: formatSignedDelta(\n trace.averageFinalCount - leaderTrace.averageFinalCount,\n 1,\n ),\n },\n {\n label: \"Vector delta\",\n value: formatSignedDelta(\n trace.averageVectorCount - leaderTrace.averageVectorCount,\n 1,\n ),\n },\n {\n label: \"Lexical delta\",\n value: formatSignedDelta(\n trace.averageLexicalCount - leaderTrace.averageLexicalCount,\n 1,\n ),\n },\n {\n label: \"Transform delta\",\n value: formatTraceCountDelta(\n trace.transformedCases - leaderTrace.transformedCases,\n ),\n },\n {\n label: \"Balanced delta\",\n value: formatTraceCountDelta(\n trace.balancedCases - leaderTrace.balancedCases,\n ),\n },\n {\n label: \"Round robin delta\",\n value: formatTraceCountDelta(\n trace.roundRobinCases - leaderTrace.roundRobinCases,\n ),\n },\n {\n label: \"Runtime budget delta\",\n value: formatTraceCountDelta(\n trace.runtimeCandidateBudgetExhaustedCases -\n leaderTrace.runtimeCandidateBudgetExhaustedCases,\n ),\n },\n {\n label: \"Runtime underfilled delta\",\n value: formatTraceCountDelta(\n trace.runtimeUnderfilledTopKCases -\n leaderTrace.runtimeUnderfilledTopKCases,\n ),\n },\n );\n\n if (stageDelta) {\n rows.push({ label: \"Stage delta\", value: stageDelta });\n }\n\n return rows;\n};\n\nexport const buildRAGRetrievalComparisonPresentations = (\n comparison: RAGRetrievalComparison,\n): RAGComparisonPresentation[] => {\n const leader = comparison.entries[0];\n return comparison.entries.map((entry) => ({\n diffLabel: leader?.label ?? \"Leader\",\n diffRows: buildRAGComparisonTraceDiffRows(entry, leader),\n summary: formatRetrievalComparisonHeadline(entry),\n id: entry.retrievalId,\n label: entry.label,\n traceSummaryRows: buildRAGComparisonTraceSummaryRows(entry),\n }));\n};\n\nexport const buildRAGRetrievalComparisonOverviewPresentation = (\n comparison: RAGRetrievalComparison,\n): RAGComparisonOverviewPresentation =>\n buildComparisonOverviewPresentation({\n entries: comparison.entries,\n resolveEntry: (id?: string) =>\n comparison.entries.find((entry) => entry.retrievalId === id),\n resolveLabel: (id?: string) =>\n comparison.entries.find((entry) => entry.retrievalId === id)?.label ??\n id ??\n \"n/a\",\n summary: comparison.summary,\n });\n\nexport const buildRAGRerankerComparisonPresentations = (\n comparison: RAGRerankerComparison,\n): RAGComparisonPresentation[] => {\n const leader = comparison.entries[0];\n return comparison.entries.map((entry) => ({\n diffLabel: leader?.label ?? \"Leader\",\n diffRows: buildRAGComparisonTraceDiffRows(entry, leader),\n summary: formatRerankerComparisonHeadline(entry),\n id: entry.rerankerId,\n label: entry.label,\n traceSummaryRows: buildRAGComparisonTraceSummaryRows(entry),\n }));\n};\n\nexport const buildRAGRerankerComparisonOverviewPresentation = (\n comparison: RAGRerankerComparison,\n): RAGComparisonOverviewPresentation =>\n buildComparisonOverviewPresentation({\n entries: comparison.entries,\n resolveEntry: (id?: string) =>\n comparison.entries.find((entry) => entry.rerankerId === id),\n resolveLabel: (id?: string) =>\n comparison.entries.find((entry) => entry.rerankerId === id)?.label ??\n id ??\n \"n/a\",\n summary: comparison.summary,\n });\n\nexport const buildRAGGroundingProviderPresentations = (\n entries: Array<{\n providerKey: string;\n label: string;\n elapsedMs: number;\n response: RAGAnswerGroundingEvaluationResponse;\n }>,\n): RAGGroundingProviderPresentation[] =>\n entries.map((entry) => ({\n summary: [\n entry.label,\n `passing ${formatEvaluationPassingRate(entry.response.passingRate)}`,\n `citation f1 ${entry.response.summary.averageCitationF1.toFixed(3)}`,\n `resolved ${formatEvaluationPassingRate(\n entry.response.summary.averageResolvedCitationRate,\n )}`,\n `latency ${entry.elapsedMs.toFixed(1)}ms`,\n ].join(\" · \"),\n id: entry.providerKey,\n label: entry.label,\n }));\n\nexport const buildRAGGroundingProviderOverviewPresentation = (input: {\n entries: Array<{\n providerKey: string;\n label: string;\n elapsedMs: number;\n response: RAGAnswerGroundingEvaluationResponse;\n }>;\n summary: {\n bestByPassingRate?: string;\n bestByAverageCitationF1?: string;\n bestByResolvedCitationRate?: string;\n fastest?: string;\n };\n}): RAGGroundingProviderOverviewPresentation => {\n const resolveLabel = (key?: string) =>\n input.entries.find((entry) => entry.providerKey === key)?.label ??\n key ??\n \"n/a\";\n const winnerLabel = resolveLabel(input.summary.bestByPassingRate);\n const winnerEntry = input.entries.find(\n (entry) => entry.providerKey === input.summary.bestByPassingRate,\n );\n\n return {\n rows: [\n {\n label: \"Best passing rate\",\n value: resolveLabel(input.summary.bestByPassingRate),\n },\n {\n label: \"Best citation F1\",\n value: resolveLabel(input.summary.bestByAverageCitationF1),\n },\n {\n label: \"Best resolved citations\",\n value: resolveLabel(input.summary.bestByResolvedCitationRate),\n },\n {\n label: \"Fastest\",\n value: resolveLabel(input.summary.fastest),\n },\n ],\n winnerLabel,\n summary: winnerEntry\n ? `passing ${formatEvaluationPassingRate(winnerEntry.response.passingRate)} · citation f1 ${winnerEntry.response.summary.averageCitationF1.toFixed(3)} · resolved ${formatEvaluationPassingRate(winnerEntry.response.summary.averageResolvedCitationRate)}`\n : \"Stored workflow evaluation\",\n };\n};\n\nexport const buildRAGRetrievalOverviewPresentation = (\n comparison: RAGRetrievalComparison,\n): RAGQualityOverviewPresentation => ({\n rows: buildRAGRetrievalComparisonOverviewPresentation(comparison).rows,\n});\n\nexport const buildRAGRerankerOverviewPresentation = (\n comparison: RAGRerankerComparison,\n): RAGQualityOverviewPresentation => ({\n rows: buildRAGRerankerComparisonOverviewPresentation(comparison).rows,\n});\n\nexport const buildRAGGroundingOverviewPresentation = (input: {\n groundingEvaluation: RAGAnswerGroundingEvaluationResponse;\n groundingProviderOverview?: RAGGroundingProviderOverviewPresentation | null;\n}): RAGGroundingOverviewPresentation => ({\n rows: [\n {\n label: \"Grounding\",\n value: formatGroundingHistorySummaryValue(input.groundingEvaluation),\n },\n ...(input.groundingProviderOverview?.rows ?? [\n {\n label: \"Grounding providers\",\n value: \"Configure an AI provider to compare grounded answers.\",\n },\n ]),\n ],\n});\n\nexport const buildRAGQualityOverviewPresentation = (input: {\n retrievalComparison: RAGRetrievalComparison;\n rerankerComparison: RAGRerankerComparison;\n groundingEvaluation: RAGAnswerGroundingEvaluationResponse;\n groundingProviderOverview?: RAGGroundingProviderOverviewPresentation | null;\n}): RAGQualityOverviewPresentation => ({\n rows: [\n ...buildRAGRetrievalOverviewPresentation(input.retrievalComparison).rows,\n ...buildRAGRerankerOverviewPresentation(input.rerankerComparison).rows,\n ...buildRAGGroundingOverviewPresentation({\n groundingEvaluation: input.groundingEvaluation,\n groundingProviderOverview: input.groundingProviderOverview,\n }).rows,\n ],\n});\n\nexport const buildRAGGroundingProviderCaseComparisonPresentations = (\n comparisons: Array<{\n caseId: string;\n label: string;\n entries: Array<{\n providerKey: string;\n label: string;\n status: string;\n coverage: string;\n citationF1: number;\n resolvedCitationRate: number;\n matchedIds: string[];\n missingIds: string[];\n extraIds: string[];\n answerExcerpt: string;\n }>;\n summary: {\n bestByStatus?: string;\n bestByCitationF1?: string;\n bestByResolvedCitationRate?: string;\n };\n }>,\n): RAGGroundingProviderCaseComparisonPresentation[] =>\n comparisons.map((comparison) => {\n const resolveLabel = (key?: string) =>\n comparison.entries.find((entry) => entry.providerKey === key)?.label ??\n key ??\n \"n/a\";\n\n return {\n caseId: comparison.caseId,\n label: comparison.label,\n rows: [\n {\n label: \"Best grounded\",\n value: resolveLabel(comparison.summary.bestByStatus),\n },\n {\n label: \"Best citation F1\",\n value: resolveLabel(comparison.summary.bestByCitationF1),\n },\n {\n label: \"Best resolved citations\",\n value: resolveLabel(comparison.summary.bestByResolvedCitationRate),\n },\n ...comparison.entries.map((entry) => ({\n label: entry.label,\n value: [\n entry.status.toUpperCase(),\n `coverage ${entry.coverage}`,\n `f1 ${entry.citationF1.toFixed(3)}`,\n `resolved ${formatEvaluationPassingRate(\n entry.resolvedCitationRate,\n )}`,\n `matched ${entry.matchedIds.join(\", \") || \"none\"}`,\n `missing ${entry.missingIds.join(\", \") || \"none\"}`,\n `extra ${entry.extraIds.join(\", \") || \"none\"}`,\n `answer ${entry.answerExcerpt || \"n/a\"}`,\n ].join(\" · \"),\n })),\n ],\n summary: [\n `Best grounded: ${resolveLabel(comparison.summary.bestByStatus)}`,\n `Best citation F1: ${resolveLabel(\n comparison.summary.bestByCitationF1,\n )}`,\n `Best resolved citations: ${resolveLabel(\n comparison.summary.bestByResolvedCitationRate,\n )}`,\n ].join(\" · \"),\n };\n });\n\nexport const buildRAGEvaluationHistoryRows = (\n history?: RAGEvaluationHistory,\n): RAGLabelValueRow[] => {\n if (!history?.latestRun) {\n return [{ label: \"History\", value: \"No persisted benchmark runs yet.\" }];\n }\n\n const rows: RAGLabelValueRow[] = [\n { label: \"Runs recorded\", value: String(history.runs.length) },\n {\n label: \"Latest\",\n value: `${history.latestRun.label} · ${formatEvaluationSummary(\n history.latestRun.response,\n )}`,\n },\n ];\n\n if (history.latestRun.traceSummary) {\n rows.push({\n label: \"Latest trace\",\n value: `${formatTraceModes(\n history.latestRun.traceSummary.modes,\n )} · balance ${formatSourceBalanceStrategies(\n history.latestRun.traceSummary.sourceBalanceStrategies,\n )} · final ${history.latestRun.traceSummary.averageFinalCount.toFixed(\n 1,\n )} · vector ${history.latestRun.traceSummary.averageVectorCount.toFixed(\n 1,\n )} · lexical ${history.latestRun.traceSummary.averageLexicalCount.toFixed(\n 1,\n )}`,\n });\n }\n\n if (history.previousRun) {\n rows.push({\n label: \"Previous\",\n value: `${history.previousRun.label} · ${formatEvaluationSummary(\n history.previousRun.response,\n )}`,\n });\n }\n\n if (!history.diff) {\n rows.push({\n label: \"History diff\",\n value: \"Run the benchmark again to diff regressions over time.\",\n });\n return rows;\n }\n\n rows.push(\n {\n label: \"Passing delta\",\n value: formatSignedDelta(history.diff.summaryDelta.passingRate, 1, \"%\"),\n },\n {\n label: \"Average F1 delta\",\n value: formatSignedDelta(history.diff.summaryDelta.averageF1, 3),\n },\n {\n label: \"Latency delta\",\n value: formatSignedDelta(\n history.diff.summaryDelta.averageLatencyMs,\n 1,\n \"ms\",\n ),\n },\n {\n label: \"Improved\",\n value: formatHistoryCaseLabels(history.diff.improvedCases),\n },\n {\n label: \"Regressed\",\n value: formatHistoryCaseLabels(history.diff.regressedCases),\n },\n {\n label: \"Lead drift\",\n value: formatTraceLeadChanges(history.diff.traceLeadChanges),\n },\n {\n label: \"SQLite planner shift\",\n value: formatHistorySQLitePlannerShift(history),\n },\n {\n label: \"Postgres planner shift\",\n value: formatHistoryPostgresPlannerShift(history),\n },\n {\n label: \"Trace routing shift\",\n value: formatHistoryRoutingShift(history),\n },\n );\n\n if (history.previousRun) {\n const currentEntityView = buildRAGEvaluationEntityQualityView(\n history.latestRun.response,\n );\n const previousEntityView = buildRAGEvaluationEntityQualityView(\n history.previousRun.response,\n );\n rows.push(\n {\n label: \"Source regression hotspots\",\n value: formatEntityRegressionHotspots(\n currentEntityView.bySource,\n previousEntityView.bySource,\n (entry) => entry.averageF1,\n \"f1\",\n ),\n },\n {\n label: \"Document regression hotspots\",\n value: formatEntityRegressionHotspots(\n currentEntityView.byDocument,\n previousEntityView.byDocument,\n (entry) => entry.averageF1,\n \"f1\",\n ),\n },\n );\n }\n\n if (history.diff.traceSummaryDelta) {\n rows.push(\n {\n label: \"Trace mode shift\",\n value: history.diff.traceSummaryDelta.modesChanged\n ? \"changed\"\n : \"stable\",\n },\n {\n label: \"Trace balance shift\",\n value: history.diff.traceSummaryDelta.sourceBalanceStrategiesChanged\n ? \"changed\"\n : \"stable\",\n },\n {\n label: \"Trace final delta\",\n value: formatSignedDelta(\n history.diff.traceSummaryDelta.averageFinalCount,\n 1,\n ),\n },\n {\n label: \"Trace vector delta\",\n value: formatSignedDelta(\n history.diff.traceSummaryDelta.averageVectorCount,\n 1,\n ),\n },\n {\n label: \"Trace lexical delta\",\n value: formatSignedDelta(\n history.diff.traceSummaryDelta.averageLexicalCount,\n 1,\n ),\n },\n {\n label: \"Trace balanced delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.balancedCases,\n ),\n },\n {\n label: \"Trace round robin delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.roundRobinCases,\n ),\n },\n {\n label: \"Trace transform delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.transformedCases,\n ),\n },\n {\n label: \"Trace variant delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.variantCases,\n ),\n },\n );\n\n const evidenceReconcileDelta =\n history.diff.traceSummaryDelta.stageCounts?.evidence_reconcile;\n if (typeof evidenceReconcileDelta === \"number\") {\n rows.push({\n label: \"Trace evidence reconcile delta (all)\",\n value: formatTraceCountDelta(evidenceReconcileDelta),\n });\n }\n if (\n typeof history.diff.traceSummaryDelta\n .officeEvidenceReconcileCasesDelta === \"number\"\n ) {\n rows.push({\n label: \"Trace office structure evidence reconcile delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.officeEvidenceReconcileCasesDelta,\n ),\n });\n }\n if (\n typeof history.diff.traceSummaryDelta\n .officeParagraphEvidenceReconcileCasesDelta === \"number\"\n ) {\n rows.push({\n label: \"Trace office narrative evidence reconcile delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta\n .officeParagraphEvidenceReconcileCasesDelta,\n ),\n });\n }\n if (\n typeof history.diff.traceSummaryDelta\n .officeListEvidenceReconcileCasesDelta === \"number\"\n ) {\n rows.push({\n label: \"Trace office checklist evidence reconcile delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.officeListEvidenceReconcileCasesDelta,\n ),\n });\n }\n if (\n typeof history.diff.traceSummaryDelta\n .officeTableEvidenceReconcileCasesDelta === \"number\"\n ) {\n rows.push({\n label: \"Trace office table evidence reconcile delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.officeTableEvidenceReconcileCasesDelta,\n ),\n });\n }\n const officeReconcileDeltas = [\n typeof history.diff.traceSummaryDelta\n .officeParagraphEvidenceReconcileCasesDelta === \"number\"\n ? `narrative=${formatTraceCountDelta(\n history.diff.traceSummaryDelta\n .officeParagraphEvidenceReconcileCasesDelta,\n )}`\n : null,\n typeof history.diff.traceSummaryDelta\n .officeListEvidenceReconcileCasesDelta === \"number\"\n ? `checklist=${formatTraceCountDelta(\n history.diff.traceSummaryDelta\n .officeListEvidenceReconcileCasesDelta,\n )}`\n : null,\n typeof history.diff.traceSummaryDelta\n .officeTableEvidenceReconcileCasesDelta === \"number\"\n ? `table=${formatTraceCountDelta(\n history.diff.traceSummaryDelta\n .officeTableEvidenceReconcileCasesDelta,\n )}`\n : null,\n ].filter((value): value is string => Boolean(value));\n if (officeReconcileDeltas.length > 0) {\n rows.push({\n label: \"Trace office reconcile deltas\",\n value: officeReconcileDeltas.join(\", \"),\n });\n }\n if (\n typeof history.diff.traceSummaryDelta.pdfEvidenceReconcileCasesDelta ===\n \"number\"\n ) {\n rows.push({\n label: \"Trace PDF native evidence reconcile delta\",\n value: formatTraceCountDelta(\n history.diff.traceSummaryDelta.pdfEvidenceReconcileCasesDelta,\n ),\n });\n }\n\n const stageDelta = Object.entries(\n history.diff.traceSummaryDelta.stageCounts ?? {},\n )\n .map(([stage, count]) => `${stage} ${formatTraceCountDelta(count)}`)\n .join(\", \");\n\n if (stageDelta) {\n rows.push({ label: \"Trace stage delta\", value: stageDelta });\n }\n }\n\n if (history.caseTraceSnapshots.length > 0) {\n const changedCases = history.caseTraceSnapshots.filter(\n (entry) => entry.traceChange === \"changed\",\n );\n rows.push({\n label: \"Trace drift cases\",\n value:\n changedCases.length > 0\n ? changedCases\n .map((entry) => entry.label ?? entry.caseId)\n .slice(0, 4)\n .join(\", \")\n : \"none\",\n });\n rows.push({\n label: \"Lead media cues\",\n value:\n Array.from(\n new Set(\n history.caseTraceSnapshots\n .map((entry) =>\n formatLeadMediaCueSummary({\n leadChannelAttributionCue: entry.leadChannelAttributionCue,\n leadChannelCue: entry.leadChannelCue,\n leadContinuityCue: entry.leadContinuityCue,\n leadSpeakerAttributionCue: entry.leadSpeakerAttributionCue,\n leadSpeakerCue: entry.leadSpeakerCue,\n }),\n )\n .filter((value) => value !== \"none\"),\n ),\n )\n .slice(0, 3)\n .join(\" · \") || \"none\",\n });\n rows.push({\n label: \"Presentation cues\",\n value:\n Array.from(\n new Set(\n history.caseTraceSnapshots\n .map((entry) =>\n formatLeadPresentationCue(entry.leadPresentationCue),\n )\n .filter((value) => value !== \"none\"),\n ),\n )\n .slice(0, 3)\n .join(\" / \") || \"none\",\n });\n }\n\n return rows;\n};\n\nexport const buildRAGEvaluationCaseTracePresentations = (\n history?: RAGEvaluationHistory,\n): RAGEvaluationCaseTracePresentation[] => {\n if (!history?.caseTraceSnapshots.length) {\n return [];\n }\n\n return history.caseTraceSnapshots.map((entry) => {\n const label = entry.label ?? entry.caseId;\n const currentMode = entry.traceMode ?? \"no-trace\";\n const previousMode = entry.previousTraceMode ?? \"n/a\";\n const currentBalance = entry.sourceBalanceStrategy ?? \"cap\";\n const previousBalance = entry.previousSourceBalanceStrategy ?? \"n/a\";\n const currentVariants =\n entry.variantQueries.length > 0\n ? entry.variantQueries.join(\", \")\n : \"none\";\n const previousVariants =\n entry.previousVariantQueries.length > 0\n ? entry.previousVariantQueries.join(\", \")\n : \"none\";\n const currentStages =\n Object.keys(entry.stageCounts).length > 0\n ? Object.entries(entry.stageCounts)\n .map(([stage, count]) => `${stage} ${count}`)\n .join(\", \")\n : \"none\";\n const previousStages =\n Object.keys(entry.previousStageCounts).length > 0\n ? Object.entries(entry.previousStageCounts)\n .map(([stage, count]) => `${stage} ${count}`)\n .join(\", \")\n : \"none\";\n const currentLeadContext = entry.topContextLabel ?? \"n/a\";\n const previousLeadContext = entry.previousTopContextLabel ?? \"n/a\";\n const currentLeadLocation = entry.topLocatorLabel ?? \"n/a\";\n const previousLeadLocation = entry.previousTopLocatorLabel ?? \"n/a\";\n const currentBoundary = entry.sourceAwareChunkReasonLabel ?? \"n/a\";\n const previousBoundary = entry.previousSourceAwareChunkReasonLabel ?? \"n/a\";\n const currentScope = entry.sourceAwareUnitScopeLabel ?? \"n/a\";\n const previousScope = entry.previousSourceAwareUnitScopeLabel ?? \"n/a\";\n const currentMediaCues = formatLeadMediaCueSummary({\n leadChannelAttributionCue: entry.leadChannelAttributionCue,\n leadChannelCue: entry.leadChannelCue,\n leadContinuityCue: entry.leadContinuityCue,\n leadSpeakerAttributionCue: entry.leadSpeakerAttributionCue,\n leadSpeakerCue: entry.leadSpeakerCue,\n });\n const previousMediaCues = formatLeadMediaCueSummary({\n leadChannelAttributionCue: entry.previousLeadChannelAttributionCue,\n leadChannelCue: entry.previousLeadChannelCue,\n leadContinuityCue: entry.previousLeadContinuityCue,\n leadSpeakerAttributionCue: entry.previousLeadSpeakerAttributionCue,\n leadSpeakerCue: entry.previousLeadSpeakerCue,\n });\n const currentPresentationCue = formatLeadPresentationCue(\n entry.leadPresentationCue,\n );\n const previousPresentationCue = formatLeadPresentationCue(\n entry.previousLeadPresentationCue,\n );\n const leadSummary =\n entry.topLocatorLabel ??\n entry.topContextLabel ??\n entry.sourceAwareUnitScopeLabel ??\n \"n/a\";\n const previousLeadSummary =\n entry.previousTopLocatorLabel ??\n entry.previousTopContextLabel ??\n entry.previousSourceAwareUnitScopeLabel ??\n \"n/a\";\n\n return {\n caseId: entry.caseId,\n label,\n summary: `${entry.traceChange} · ${previousMode}→${currentMode} · ${previousBalance}→${currentBalance} · lead ${previousLeadSummary}→${leadSummary} · final ${\n entry.previousFinalCount ?? 0\n }→${entry.finalCount}`,\n traceChange: entry.traceChange,\n rows: [\n { label: \"Query\", value: entry.query },\n { label: \"Trace change\", value: entry.traceChange },\n { label: \"Mode\", value: `${previousMode}→${currentMode}` },\n {\n label: \"Balance\",\n value: `${previousBalance}→${currentBalance}`,\n },\n {\n label: \"Transformed query\",\n value: `${\n entry.previousTransformedQuery?.trim() || \"n/a\"\n }→${entry.transformedQuery?.trim() || \"n/a\"}`,\n },\n {\n label: \"Final\",\n value: `${entry.previousFinalCount ?? 0}→${entry.finalCount}`,\n },\n {\n label: \"Vector\",\n value: `${entry.previousVectorCount ?? 0}→${entry.vectorCount}`,\n },\n {\n label: \"Lexical\",\n value: `${entry.previousLexicalCount ?? 0}→${entry.lexicalCount}`,\n },\n {\n label: \"Candidate topK\",\n value: `${entry.previousCandidateTopK ?? 0}→${entry.candidateTopK}`,\n },\n {\n label: \"Lexical topK\",\n value: `${entry.previousLexicalTopK ?? 0}→${entry.lexicalTopK}`,\n },\n {\n label: \"Variants\",\n value: `${previousVariants}→${currentVariants}`,\n },\n {\n label: \"Lead context\",\n value: `${previousLeadContext}→${currentLeadContext}`,\n },\n {\n label: \"Lead location\",\n value: `${previousLeadLocation}→${currentLeadLocation}`,\n },\n {\n label: \"Chunk boundary\",\n value: `${previousBoundary}→${currentBoundary}`,\n },\n {\n label: \"Source-aware scope\",\n value: `${previousScope}→${currentScope}`,\n },\n {\n label: \"Lead media cues\",\n value: `${previousMediaCues}→${currentMediaCues}`,\n },\n {\n label: \"Lead presentation cues\",\n value: `${previousPresentationCue}→${currentPresentationCue}`,\n },\n {\n label: \"Stages\",\n value: `${previousStages}→${currentStages}`,\n },\n { label: \"Status\", value: entry.status },\n ],\n };\n });\n};\n\nexport const buildRAGEvaluationHistoryPresentation = (\n history?: RAGEvaluationHistory,\n): RAGEvaluationHistoryPresentation => ({\n caseTraces: buildRAGEvaluationCaseTracePresentations(history),\n rows: buildRAGEvaluationHistoryRows(history),\n summary: history?.latestRun\n ? history.latestRun.label\n : \"No persisted benchmark runs yet.\",\n});\n\nexport const buildRAGEvaluationSuiteSnapshotRows = (\n history?: RAGEvaluationSuiteSnapshotHistory,\n): RAGLabelValueRow[] => {\n if (!history?.latestSnapshot) {\n return [\n { label: \"Suite snapshots\", value: \"No saved suite snapshots yet.\" },\n ];\n }\n\n const rows: RAGLabelValueRow[] = [\n {\n label: \"Snapshots recorded\",\n value: String(history.snapshots.length),\n },\n {\n label: \"Latest snapshot\",\n value: `v${history.latestSnapshot.version} · ${history.latestSnapshot.caseCount} cases`,\n },\n ];\n\n if (history.previousSnapshot) {\n rows.push({\n label: \"Previous snapshot\",\n value: `v${history.previousSnapshot.version} · ${history.previousSnapshot.caseCount} cases`,\n });\n }\n\n if (!history.diff) {\n rows.push({\n label: \"Snapshot diff\",\n value: \"Save another suite snapshot to compare dataset changes.\",\n });\n return rows;\n }\n\n rows.push(\n {\n label: \"Case count change\",\n value: formatSignedDelta(history.diff.caseCountDelta),\n },\n {\n label: \"Added cases\",\n value:\n history.diff.addedCaseIds.length > 0\n ? history.diff.addedCaseIds.join(\", \")\n : \"none\",\n },\n {\n label: \"Removed cases\",\n value:\n history.diff.removedCaseIds.length > 0\n ? history.diff.removedCaseIds.join(\", \")\n : \"none\",\n },\n {\n label: \"Changed cases\",\n value:\n history.diff.changedCaseIds.length > 0\n ? history.diff.changedCaseIds.join(\", \")\n : \"none\",\n },\n {\n label: \"Order changed\",\n value: history.diff.orderChanged ? \"changed\" : \"stable\",\n },\n );\n\n return rows;\n};\n\nexport const buildRAGEvaluationSuiteSnapshotPresentations = (\n history?: RAGEvaluationSuiteSnapshotHistory,\n): RAGEvaluationSuiteSnapshotPresentation[] =>\n (history?.snapshots ?? []).map((snapshot) => ({\n id: snapshot.id,\n label: snapshot.label ?? snapshot.suiteId,\n rows: [\n { label: \"Version\", value: `v${snapshot.version}` },\n { label: \"Created\", value: formatDateLabel(snapshot.createdAt) },\n { label: \"Cases\", value: String(snapshot.caseCount) },\n {\n label: \"Case ids\",\n value:\n snapshot.suite.input.cases.map((entry) => entry.id).join(\", \") ||\n \"none\",\n },\n ],\n summary: `v${snapshot.version} · ${snapshot.caseCount} cases`,\n version: snapshot.version,\n }));\n\nexport const buildRAGEvaluationSuiteSnapshotHistoryPresentation = (\n history?: RAGEvaluationSuiteSnapshotHistory,\n): RAGEvaluationSuiteSnapshotHistoryPresentation => ({\n rows: buildRAGEvaluationSuiteSnapshotRows(history),\n snapshots: buildRAGEvaluationSuiteSnapshotPresentations(history),\n summary: history?.latestSnapshot\n ? `v${history.latestSnapshot.version}`\n : \"No saved suite snapshots yet.\",\n});\n\nconst isRuntimeGateReason = (reason: string) =>\n /runtime|candidate-budget|underfilled/i.test(reason);\n\nconst getFixtureVariantsFromRunTags = (tags?: string[]): string[] =>\n (tags ?? [])\n .filter((tag) => tag.startsWith(\"fixture:\"))\n .map((tag) => tag.slice(\"fixture:\".length))\n .filter((tag, index, all) => tag.length > 0 && all.indexOf(tag) === index);\n\nconst buildRAGRetrievalReleaseHistoryRunPresentation = (\n run: RAGRetrievalComparisonRun,\n): RAGRetrievalReleaseHistoryRunPresentation => {\n const runtimeGateReasons = (\n run.decisionSummary?.gate?.reasons ??\n run.releaseVerdict?.gate?.reasons ??\n []\n ).filter(isRuntimeGateReason);\n const rows: RAGLabelValueRow[] = [\n { label: \"Finished\", value: formatDateLabel(run.finishedAt) },\n {\n label: \"Passing-rate winner\",\n value: run.comparison.summary.bestByPassingRate ?? \"n/a\",\n },\n {\n label: \"Average F1 winner\",\n value: run.comparison.summary.bestByAverageF1 ?? \"n/a\",\n },\n ];\n const fixtureVariants = getFixtureVariantsFromRunTags(run.tags);\n\n if (fixtureVariants.length > 0) {\n rows.push({\n label: \"Fixture variant\",\n value: fixtureVariants.join(\", \"),\n });\n }\n const officeWinnerSummaries = [\n run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases\n ? `narrative=${run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases}`\n : null,\n run.comparison.summary.bestByOfficeListEvidenceReconcileCases\n ? `checklist=${run.comparison.summary.bestByOfficeListEvidenceReconcileCases}`\n : null,\n run.comparison.summary.bestByOfficeTableEvidenceReconcileCases\n ? `table=${run.comparison.summary.bestByOfficeTableEvidenceReconcileCases}`\n : null,\n ].filter((value): value is string => Boolean(value));\n if (officeWinnerSummaries.length > 0) {\n rows.push({\n label: \"Office reconcile winners (docx/xlsx/pptx)\",\n value: officeWinnerSummaries.join(\", \"),\n });\n }\n const presentationCueWinners = [\n run.comparison.summary.bestByPresentationTitleCueCases\n ? `title=${run.comparison.summary.bestByPresentationTitleCueCases}`\n : null,\n run.comparison.summary.bestByPresentationBodyCueCases\n ? `body=${run.comparison.summary.bestByPresentationBodyCueCases}`\n : null,\n run.comparison.summary.bestByPresentationNotesCueCases\n ? `notes=${run.comparison.summary.bestByPresentationNotesCueCases}`\n : null,\n ].filter((value): value is string => Boolean(value));\n if (presentationCueWinners.length > 0) {\n rows.push({\n label: \"Presentation cue winners\",\n value: presentationCueWinners.join(\", \"),\n });\n }\n const spreadsheetCueWinners = [\n run.comparison.summary.bestBySpreadsheetSheetCueCases\n ? `sheet=${run.comparison.summary.bestBySpreadsheetSheetCueCases}`\n : null,\n run.comparison.summary.bestBySpreadsheetTableCueCases\n ? `table=${run.comparison.summary.bestBySpreadsheetTableCueCases}`\n : null,\n run.comparison.summary.bestBySpreadsheetColumnCueCases\n ? `column=${run.comparison.summary.bestBySpreadsheetColumnCueCases}`\n : null,\n ].filter((value): value is string => Boolean(value));\n if (spreadsheetCueWinners.length > 0) {\n rows.push({\n label: \"Spreadsheet cue winners\",\n value: spreadsheetCueWinners.join(\", \"),\n });\n }\n if (run.comparison.summary.bestByPresentationTitleCueCases) {\n rows.push({\n label: \"Best presentation title cue\",\n value: run.comparison.summary.bestByPresentationTitleCueCases,\n });\n }\n if (run.comparison.summary.bestByPresentationBodyCueCases) {\n rows.push({\n label: \"Best presentation body cue\",\n value: run.comparison.summary.bestByPresentationBodyCueCases,\n });\n }\n if (run.comparison.summary.bestByPresentationNotesCueCases) {\n rows.push({\n label: \"Best presentation notes cue\",\n value: run.comparison.summary.bestByPresentationNotesCueCases,\n });\n }\n if (run.comparison.summary.bestBySpreadsheetSheetCueCases) {\n rows.push({\n label: \"Best spreadsheet sheet cue\",\n value: run.comparison.summary.bestBySpreadsheetSheetCueCases,\n });\n }\n if (run.comparison.summary.bestBySpreadsheetTableCueCases) {\n rows.push({\n label: \"Best spreadsheet table cue\",\n value: run.comparison.summary.bestBySpreadsheetTableCueCases,\n });\n }\n if (run.comparison.summary.bestBySpreadsheetColumnCueCases) {\n rows.push({\n label: \"Best spreadsheet column cue\",\n value: run.comparison.summary.bestBySpreadsheetColumnCueCases,\n });\n }\n if (run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases) {\n rows.push({\n label: \"Best office narrative reconcile\",\n value: run.comparison.summary.bestByOfficeParagraphEvidenceReconcileCases,\n });\n }\n if (run.comparison.summary.bestByOfficeListEvidenceReconcileCases) {\n rows.push({\n label: \"Best office checklist reconcile\",\n value: run.comparison.summary.bestByOfficeListEvidenceReconcileCases,\n });\n }\n if (run.comparison.summary.bestByOfficeTableEvidenceReconcileCases) {\n rows.push({\n label: \"Best office table reconcile\",\n value: run.comparison.summary.bestByOfficeTableEvidenceReconcileCases,\n });\n }\n\n if (run.comparison.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases) {\n rows.push({\n label: \"Lowest runtime budget exhaustion\",\n value:\n run.comparison.summary.bestByLowestRuntimeCandidateBudgetExhaustedCases,\n });\n }\n\n if (run.comparison.summary.bestByLowestRuntimeUnderfilledTopKCases) {\n rows.push({\n label: \"Lowest runtime underfilled TopK\",\n value: run.comparison.summary.bestByLowestRuntimeUnderfilledTopKCases,\n });\n }\n\n rows.push(\n {\n label: \"Gate status\",\n value:\n run.decisionSummary?.gate?.status ??\n run.releaseVerdict?.gate?.status ??\n \"n/a\",\n },\n {\n label: \"Runtime gate failures\",\n value:\n runtimeGateReasons.length > 0 ? runtimeGateReasons.join(\"; \") : \"none\",\n },\n );\n\n return {\n label: run.label,\n rows,\n runId: run.id,\n summary:\n runtimeGateReasons.length > 0\n ? `${run.label} · runtime gate blocked`\n : `${run.label} · ${run.comparison.summary.bestByPassingRate ?? \"n/a\"} leads passing rate`,\n };\n};\n\nexport const buildRAGRetrievalReleaseGroupHistoryPresentation = (input: {\n timeline?: RAGRetrievalReleaseTimelineSummary;\n runs?: RAGRetrievalComparisonRun[];\n}): RAGRetrievalReleaseGroupHistoryPresentation => {\n const recentRuns = (input.runs ?? []).map(\n buildRAGRetrievalReleaseHistoryRunPresentation,\n );\n const fixtureVariants = (input.runs ?? [])\n .flatMap((run) => getFixtureVariantsFromRunTags(run.tags))\n .filter((tag, index, all) => all.indexOf(tag) === index);\n const runtimeBlockedRuns = recentRuns.filter((entry) =>\n entry.rows.some(\n (row) => row.label === \"Runtime gate failures\" && row.value !== \"none\",\n ),\n ).length;\n const rows: RAGLabelValueRow[] = [\n {\n label: \"Latest decision\",\n value: input.timeline?.latestDecisionKind ?? \"none\",\n },\n {\n label: \"Latest decision at\",\n value: formatDateLabel(input.timeline?.latestDecisionAt),\n },\n {\n label: \"Last promoted\",\n value: formatDateLabel(input.timeline?.lastPromotedAt),\n },\n {\n label: \"Last reverted\",\n value: formatDateLabel(input.timeline?.lastRevertedAt),\n },\n {\n label: \"Recent runtime-blocked runs\",\n value: String(runtimeBlockedRuns),\n },\n ];\n\n if (fixtureVariants.length > 0) {\n rows.push({\n label: \"Fixture variants\",\n value: fixtureVariants.join(\", \"),\n });\n }\n\n return {\n recentRuns,\n rows,\n summary: input.timeline?.latestDecisionKind\n ? `${input.timeline.latestDecisionKind} · ${recentRuns.length} recent runs`\n : recentRuns.length > 0\n ? `${recentRuns.length} recent runs`\n : \"No release history yet.\",\n };\n};\n\nexport const buildRAGAnswerGroundingCaseSnapshotPresentations = (\n history?: RAGAnswerGroundingEvaluationHistory,\n): RAGAnswerGroundingCaseSnapshotPresentation[] => {\n if (!history?.caseSnapshots.length) {\n return [];\n }\n\n return history.caseSnapshots.map((entry) => {\n const label = entry.label ?? entry.caseId;\n return {\n answerChange: entry.answerChange,\n caseId: entry.caseId,\n label,\n rows: [\n {\n label: \"Query\",\n value: entry.query?.trim().length ? entry.query : \"n/a\",\n },\n { label: \"Answer change\", value: entry.answerChange },\n { label: \"Coverage\", value: entry.coverage },\n {\n label: \"Resolved citations\",\n value: `${entry.resolvedCitationCount}/${entry.citationCount}`,\n },\n {\n label: \"Resolved citation rate\",\n value: entry.resolvedCitationRate.toFixed(3),\n },\n { label: \"Citation F1\", value: entry.citationF1.toFixed(3) },\n {\n label: \"Reference count\",\n value: String(entry.referenceCount),\n },\n {\n label: \"Cited IDs\",\n value: entry.citedIds.length > 0 ? entry.citedIds.join(\", \") : \"none\",\n },\n {\n label: \"Matched IDs\",\n value:\n entry.matchedIds.length > 0 ? entry.matchedIds.join(\", \") : \"none\",\n },\n {\n label: \"Missing IDs\",\n value:\n entry.missingIds.length > 0 ? entry.missingIds.join(\", \") : \"none\",\n },\n {\n label: \"Extra IDs\",\n value: entry.extraIds.length > 0 ? entry.extraIds.join(\", \") : \"none\",\n },\n {\n label: \"Unresolved refs\",\n value:\n entry.ungroundedReferenceNumbers.length > 0\n ? entry.ungroundedReferenceNumbers.join(\", \")\n : \"none\",\n },\n {\n label: \"Answer\",\n value: entry.answer.trim().length > 0 ? entry.answer : \"n/a\",\n },\n {\n label: \"Previous answer\",\n value:\n entry.previousAnswer && entry.previousAnswer.trim().length > 0\n ? entry.previousAnswer\n : \"n/a\",\n },\n ],\n summary: `${entry.answerChange} · ${entry.coverage} · resolved ${entry.resolvedCitationCount}/${entry.citationCount} · refs ${entry.referenceCount}`,\n };\n });\n};\n\nexport const buildRAGAnswerGroundingHistoryRows = (\n history?: RAGAnswerGroundingEvaluationHistory,\n): RAGLabelValueRow[] => {\n if (!history?.latestRun) {\n return [{ label: \"History\", value: \"No persisted provider runs yet.\" }];\n }\n\n const rows: RAGLabelValueRow[] = [\n { label: \"Runs recorded\", value: String(history.runs.length) },\n {\n label: \"Latest\",\n value: `${history.latestRun.label} · ${formatGroundingHistorySummaryValue(\n history.latestRun.response,\n )}`,\n },\n ];\n\n if (history.previousRun) {\n rows.push({\n label: \"Previous\",\n value: `${history.previousRun.label} · ${formatGroundingHistorySummaryValue(\n history.previousRun.response,\n )}`,\n });\n }\n\n if (history.leaderboard[0]) {\n rows.push({\n label: \"Best recorded\",\n value: `#${history.leaderboard[0].rank} · ${history.leaderboard[0].label} · passing ${formatEvaluationPassingRate(\n history.leaderboard[0].passingRate,\n )} · citation f1 ${history.leaderboard[0].averageCitationF1.toFixed(\n 3,\n )} · resolved ${formatEvaluationPassingRate(\n history.leaderboard[0].averageResolvedCitationRate,\n )}`,\n });\n }\n\n if (history.caseSnapshots.length > 0) {\n const changedAnswers = history.caseSnapshots.filter(\n (entry) => entry.answerChange === \"changed\",\n ).length;\n rows.push({\n label: \"Answer drift\",\n value: `${changedAnswers}/${history.caseSnapshots.length} changed`,\n });\n }\n\n if (!history.diff) {\n rows.push({\n label: \"History diff\",\n value:\n \"Run the provider comparison again to diff grounding regressions over time.\",\n });\n return rows;\n }\n\n rows.push(\n {\n label: \"Passing delta\",\n value: formatSignedDelta(history.diff.summaryDelta.passingRate, 1, \"%\"),\n },\n {\n label: \"Citation F1 delta\",\n value: formatSignedDelta(history.diff.summaryDelta.averageCitationF1, 3),\n },\n {\n label: \"Resolved citation delta\",\n value: formatSignedDelta(\n history.diff.summaryDelta.averageResolvedCitationRate * 100,\n 1,\n \"%\",\n ),\n },\n {\n label: \"Improved\",\n value: formatGroundingHistoryCaseLabels(history.diff.improvedCases),\n },\n {\n label: \"Regressed\",\n value: formatGroundingHistoryCaseLabels(history.diff.regressedCases),\n },\n );\n\n if (history.previousRun) {\n const currentEntityView = buildRAGAnswerGroundingEntityQualityView(\n history.latestRun.response,\n );\n const previousEntityView = buildRAGAnswerGroundingEntityQualityView(\n history.previousRun.response,\n );\n rows.push(\n {\n label: \"Source regression hotspots\",\n value: formatEntityRegressionHotspots(\n currentEntityView.bySource,\n previousEntityView.bySource,\n (entry) => entry.averageCitationF1,\n \"citation f1\",\n ),\n },\n {\n label: \"Document regression hotspots\",\n value: formatEntityRegressionHotspots(\n currentEntityView.byDocument,\n previousEntityView.byDocument,\n (entry) => entry.averageCitationF1,\n \"citation f1\",\n ),\n },\n );\n }\n\n return rows;\n};\n\nexport const buildRAGAnswerGroundingHistoryPresentation = (\n history?: RAGAnswerGroundingEvaluationHistory,\n): RAGAnswerGroundingHistoryPresentation => ({\n caseSnapshots: buildRAGAnswerGroundingCaseSnapshotPresentations(history),\n rows: buildRAGAnswerGroundingHistoryRows(history),\n summary: history?.latestRun\n ? history.latestRun.label\n : \"No persisted provider runs yet.\",\n});\n\nconst formatFailureCounts = (failureCounts: Record<string, number>) => {\n const entries = Object.entries(failureCounts).sort((left, right) => {\n if (right[1] !== left[1]) {\n return right[1] - left[1];\n }\n\n return left[0].localeCompare(right[0]);\n });\n\n return entries.length > 0\n ? entries.map(([key, count]) => `${key} ${count}`).join(\" · \")\n : \"none\";\n};\n\nconst formatFailureCountDelta = (\n current: Record<string, number>,\n previous: Record<string, number>,\n) => {\n const deltas = Object.keys({ ...current, ...previous })\n .map((key) => ({\n delta: (current[key] ?? 0) - (previous[key] ?? 0),\n key,\n }))\n .filter((entry) => entry.delta > 0)\n .sort((left, right) => {\n if (right.delta !== left.delta) {\n return right.delta - left.delta;\n }\n\n return left.key.localeCompare(right.key);\n });\n\n return deltas.length > 0\n ? deltas\n .slice(0, 3)\n .map((entry) => `${entry.key} +${entry.delta}`)\n .join(\" · \")\n : \"stable\";\n};\n\nconst formatEntityRegressionHotspots = <\n T extends {\n key: string;\n label: string;\n passingRate: number;\n failureCounts: Record<string, number>;\n },\n>(\n currentEntries: T[],\n previousEntries: T[],\n metricSelector: (entry: T) => number,\n metricLabel: string,\n) => {\n const previousMap = new Map(\n previousEntries.map((entry) => [entry.key, entry]),\n );\n const regressions = currentEntries\n .map((entry) => {\n const previous = previousMap.get(entry.key);\n const passDelta = entry.passingRate - (previous?.passingRate ?? 0);\n const metricDelta =\n metricSelector(entry) - (previous ? metricSelector(previous) : 0);\n const failureDelta = formatFailureCountDelta(\n entry.failureCounts,\n previous?.failureCounts ?? {},\n );\n\n return {\n entry,\n failureDelta,\n metricDelta,\n passDelta,\n };\n })\n .filter(\n (entry) =>\n entry.passDelta < 0 ||\n entry.metricDelta < 0 ||\n entry.failureDelta !== \"stable\",\n )\n .sort((left, right) => {\n if (left.passDelta !== right.passDelta) {\n return left.passDelta - right.passDelta;\n }\n if (left.metricDelta !== right.metricDelta) {\n return left.metricDelta - right.metricDelta;\n }\n\n return left.entry.label.localeCompare(right.entry.label);\n });\n\n return regressions.length > 0\n ? regressions\n .slice(0, 3)\n .map(\n ({ entry, failureDelta, metricDelta, passDelta }) =>\n `${entry.label} pass ${formatSignedDelta(\n passDelta,\n 1,\n \"%\",\n )} · ${metricLabel} ${formatSignedDelta(\n metricDelta,\n 3,\n )} · ${failureDelta}`,\n )\n .join(\" | \")\n : \"none\";\n};\n\nconst buildEvaluationEntityPresentation = (\n entry: RAGEvaluationEntityQualitySummary,\n): RAGEntityQualityPresentation => ({\n key: entry.key,\n label: entry.label,\n rows: [\n { label: \"Entity type\", value: entry.entityType },\n { label: \"Cases\", value: String(entry.totalCases) },\n {\n label: \"Status mix\",\n value: `${entry.passedCases} pass · ${entry.partialCases} partial · ${entry.failedCases} fail`,\n },\n {\n label: \"Passing rate\",\n value: formatEvaluationPassingRate(entry.passingRate),\n },\n { label: \"Average F1\", value: entry.averageF1.toFixed(3) },\n {\n label: \"Failure classes\",\n value: formatFailureCounts(entry.failureCounts),\n },\n {\n label: \"Cases\",\n value: entry.caseIds.length > 0 ? entry.caseIds.join(\", \") : \"none\",\n },\n ],\n summary: `${entry.entityType} · passing ${formatEvaluationPassingRate(\n entry.passingRate,\n )} · f1 ${entry.averageF1.toFixed(3)} · failures ${formatFailureCounts(\n entry.failureCounts,\n )}`,\n});\n\nconst buildGroundingEntityPresentation = (\n entry: RAGAnswerGroundingEntityQualitySummary,\n): RAGEntityQualityPresentation => ({\n key: entry.key,\n label: entry.label,\n rows: [\n { label: \"Entity type\", value: entry.entityType },\n { label: \"Cases\", value: String(entry.totalCases) },\n {\n label: \"Status mix\",\n value: `${entry.passedCases} pass · ${entry.partialCases} partial · ${entry.failedCases} fail`,\n },\n {\n label: \"Passing rate\",\n value: formatEvaluationPassingRate(entry.passingRate),\n },\n {\n label: \"Average citation F1\",\n value: entry.averageCitationF1.toFixed(3),\n },\n {\n label: \"Average resolved citation rate\",\n value: formatEvaluationPassingRate(\n entry.averageResolvedCitationRate * 100,\n ),\n },\n {\n label: \"Failure classes\",\n value: formatFailureCounts(entry.failureCounts),\n },\n {\n label: \"Cases\",\n value: entry.caseIds.length > 0 ? entry.caseIds.join(\", \") : \"none\",\n },\n ],\n summary: `${entry.entityType} · passing ${formatEvaluationPassingRate(\n entry.passingRate,\n )} · citation f1 ${entry.averageCitationF1.toFixed(\n 3,\n )} · failures ${formatFailureCounts(entry.failureCounts)}`,\n});\n\nexport const buildRAGEvaluationEntityQualityPresentation = (\n view: RAGEvaluationEntityQualityView,\n entityType: \"source\" | \"document\",\n): RAGEntityQualityViewPresentation => {\n const entities =\n entityType === \"source\"\n ? view.bySource.map(buildEvaluationEntityPresentation)\n : view.byDocument.map(buildEvaluationEntityPresentation);\n\n return {\n entities,\n rows: [\n { label: \"Entity type\", value: entityType },\n { label: \"Entities tracked\", value: String(entities.length) },\n {\n label: \"Best coverage\",\n value: entities[0]?.summary ?? \"No entity quality data yet.\",\n },\n ],\n summary:\n entities[0]?.label ??\n `No ${entityType === \"source\" ? \"source\" : \"document\"} quality data yet.`,\n };\n};\n\nexport const buildRAGAnswerGroundingEntityQualityPresentation = (\n view: RAGAnswerGroundingEntityQualityView,\n entityType: \"source\" | \"document\",\n): RAGEntityQualityViewPresentation => {\n const entities =\n entityType === \"source\"\n ? view.bySource.map(buildGroundingEntityPresentation)\n : view.byDocument.map(buildGroundingEntityPresentation);\n\n return {\n entities,\n rows: [\n { label: \"Entity type\", value: entityType },\n { label: \"Entities tracked\", value: String(entities.length) },\n {\n label: \"Best coverage\",\n value: entities[0]?.summary ?? \"No entity quality data yet.\",\n },\n ],\n summary:\n entities[0]?.label ??\n `No ${entityType === \"source\" ? \"source\" : \"document\"} quality data yet.`,\n };\n};\n",
11
+ "import { Injectable } from \"@angular/core\";\nimport type {\n RAGEvaluationInput,\n RAGRetrievalBaselineResponse,\n RAGRetrievalLaneHandoffDecisionRequest,\n RAGRetrievalBaselinePromotionFromRunRequest,\n RAGRetrievalBaselinePromotionRequest,\n RAGRetrievalBaselineRevertRequest,\n RAGRetrievalReleaseDecisionActionRequest,\n RAGRetrievalComparisonRequest,\n RAGDocumentChunk,\n RAGDocumentIngestInput,\n RAGDocumentUploadIngestInput,\n RAGDocumentUrlIngestInput,\n RAGRetrievalIncidentRemediationDecisionRequest,\n RAGRetrievalIncidentRemediationBulkExecutionRequest,\n RAGRetrievalIncidentRemediationExecutionRequest,\n RAGSearchRequest,\n RAGSyncRunOptions,\n} from \"@absolutejs/ai\";\nimport { createRAGClient } from \"../../ai/client/ragClient\";\n\n@Injectable({ providedIn: \"root\" })\nexport class RAGClientService {\n private clients = new Map<string, ReturnType<typeof createRAGClient>>();\n\n private client(path: string) {\n const existing = this.clients.get(path);\n if (existing) {\n return existing;\n }\n\n const created = createRAGClient({ path });\n this.clients.set(path, created);\n\n return created;\n }\n\n ingest(path: string, chunks: RAGDocumentChunk[]) {\n return this.client(path).ingest(chunks);\n }\n\n ingestDocuments(path: string, input: RAGDocumentIngestInput) {\n return this.client(path).ingestDocuments(input);\n }\n\n ingestUrls(path: string, input: RAGDocumentUrlIngestInput) {\n return this.client(path).ingestUrls(input);\n }\n\n ingestUploads(path: string, input: RAGDocumentUploadIngestInput) {\n return this.client(path).ingestUploads(input);\n }\n\n search(path: string, input: RAGSearchRequest) {\n return this.client(path).search(input);\n }\n\n searchWithTrace(path: string, input: RAGSearchRequest) {\n return this.client(path).searchWithTrace(input);\n }\n\n evaluate(path: string, input: RAGEvaluationInput) {\n return this.client(path).evaluate(input);\n }\n\n compareRetrievals(path: string, input: RAGRetrievalComparisonRequest) {\n return this.client(path).compareRetrievals(input);\n }\n\n retrievalComparisonHistory(\n path: string,\n input?: {\n limit?: number;\n suiteId?: string;\n label?: string;\n winnerId?: string;\n groupKey?: string;\n tag?: string;\n },\n ) {\n return this.client(path).retrievalComparisonHistory(input);\n }\n\n retrievalBaselines(\n path: string,\n input?: {\n groupKey?: string;\n tag?: string;\n limit?: number;\n status?: \"active\" | \"superseded\";\n },\n ) {\n return this.client(path).retrievalBaselines(input);\n }\n\n promoteRetrievalBaseline(\n path: string,\n input: RAGRetrievalBaselinePromotionRequest,\n ) {\n return this.client(path).promoteRetrievalBaseline(input);\n }\n\n promoteRetrievalBaselineDetailed(\n path: string,\n input: RAGRetrievalBaselinePromotionRequest,\n ): Promise<RAGRetrievalBaselineResponse> {\n return this.client(path).promoteRetrievalBaselineDetailed(input);\n }\n\n promoteRetrievalBaselineToLane(\n path: string,\n input: RAGRetrievalBaselinePromotionRequest & {\n rolloutLabel: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).promoteRetrievalBaselineToLane(input);\n }\n\n promoteRetrievalBaselineToLaneDetailed(\n path: string,\n input: RAGRetrievalBaselinePromotionRequest & {\n rolloutLabel: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ): Promise<RAGRetrievalBaselineResponse> {\n return this.client(path).promoteRetrievalBaselineToLaneDetailed(input);\n }\n\n promoteRetrievalBaselineFromRun(\n path: string,\n input: RAGRetrievalBaselinePromotionFromRunRequest,\n ) {\n return this.client(path).promoteRetrievalBaselineFromRun(input);\n }\n\n promoteRetrievalBaselineFromRunDetailed(\n path: string,\n input: RAGRetrievalBaselinePromotionFromRunRequest,\n ): Promise<RAGRetrievalBaselineResponse> {\n return this.client(path).promoteRetrievalBaselineFromRunDetailed(input);\n }\n\n revertRetrievalBaseline(\n path: string,\n input: RAGRetrievalBaselineRevertRequest,\n ) {\n return this.client(path).revertRetrievalBaseline(input);\n }\n\n retrievalBaselineDecisions(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n kind?: \"approve\" | \"promote\" | \"reject\" | \"revert\";\n freshnessStatus?: \"fresh\" | \"expired\" | \"not_applicable\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalBaselineDecisions(input);\n }\n\n retrievalReleaseGroupHistory(\n path: string,\n input: {\n groupKey: string;\n decisionLimit?: number;\n baselineLimit?: number;\n runLimit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalReleaseGroupHistory(input);\n }\n\n retrievalLaneHandoffs(\n path: string,\n input?: {\n groupKey?: string;\n sourceRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n limit?: number;\n },\n ) {\n return this.client(path).retrievalLaneHandoffs(input);\n }\n\n retrievalLaneHandoffDecisions(\n path: string,\n input?: {\n groupKey?: string;\n sourceRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n kind?: \"approve\" | \"reject\" | \"complete\";\n limit?: number;\n },\n ) {\n return this.client(path).retrievalLaneHandoffDecisions(input);\n }\n\n retrievalLaneHandoffIncidents(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n status?: \"open\" | \"resolved\";\n severity?: \"warning\" | \"critical\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalLaneHandoffIncidents(input);\n }\n\n retrievalLaneHandoffIncidentHistory(\n path: string,\n input?: {\n action?: \"opened\" | \"acknowledged\" | \"unacknowledged\" | \"resolved\";\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalLaneHandoffIncidentHistory(input);\n }\n\n retrievalLaneHandoffAutoCompletePolicyHistory(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalLaneHandoffAutoCompletePolicyHistory(\n input,\n );\n }\n\n retrievalReleaseLanePolicyHistory(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n rolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n scope?: \"rollout_label\" | \"group_rollout_label\";\n },\n ) {\n return this.client(path).retrievalReleaseLanePolicyHistory(input);\n }\n\n retrievalBaselineGatePolicyHistory(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n rolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n scope?: \"rollout_label\" | \"group_rollout_label\";\n },\n ) {\n return this.client(path).retrievalBaselineGatePolicyHistory(input);\n }\n\n retrievalReleaseLaneEscalationPolicyHistory(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalReleaseLaneEscalationPolicyHistory(input);\n }\n\n retrievalReleaseIncidentPolicyHistory(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalReleaseIncidentPolicyHistory(input);\n }\n\n decideRetrievalLaneHandoff(\n path: string,\n input: RAGRetrievalLaneHandoffDecisionRequest,\n ) {\n return this.client(path).decideRetrievalLaneHandoff(input);\n }\n\n decideRetrievalLaneHandoffDetailed(\n path: string,\n input: RAGRetrievalLaneHandoffDecisionRequest,\n ) {\n return this.client(path).decideRetrievalLaneHandoffDetailed(input);\n }\n\n retrievalReleaseIncidents(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n status?: \"open\" | \"resolved\";\n severity?: \"warning\" | \"critical\";\n kind?:\n | \"approval_expired\"\n | \"baseline_regression\"\n | \"gate_failure\"\n | \"handoff_stale\";\n acknowledged?: boolean;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalReleaseIncidents(input);\n }\n\n retrievalIncidentRemediationDecisions(\n path: string,\n input?: {\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n remediationKind?:\n | \"renew_approval\"\n | \"record_approval\"\n | \"inspect_gate\"\n | \"rerun_comparison\"\n | \"restore_source_lane\"\n | \"review_readiness\"\n | \"monitor_lane\";\n status?: \"planned\" | \"applied\" | \"dismissed\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalIncidentRemediationDecisions(input);\n }\n\n retrievalIncidentRemediationExecutions(\n path: string,\n input?: {\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n actionKind?: RAGRetrievalIncidentRemediationExecutionRequest[\"action\"][\"kind\"];\n code?:\n | \"approval_recorded\"\n | \"incident_acknowledged\"\n | \"incident_resolved\"\n | \"release_status_loaded\"\n | \"release_drift_loaded\"\n | \"handoff_status_loaded\"\n | \"guardrail_blocked\"\n | \"idempotent_replay\";\n blockedByGuardrail?: boolean;\n idempotentReplay?: boolean;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n return this.client(path).retrievalIncidentRemediationExecutions(input);\n }\n\n recordRetrievalIncidentRemediationDecision(\n path: string,\n input: RAGRetrievalIncidentRemediationDecisionRequest,\n ) {\n return this.client(path).recordRetrievalIncidentRemediationDecision(input);\n }\n\n executeRetrievalIncidentRemediation(\n path: string,\n input: RAGRetrievalIncidentRemediationExecutionRequest,\n ) {\n return this.client(path).executeRetrievalIncidentRemediation(input);\n }\n\n bulkExecuteRetrievalIncidentRemediations(\n path: string,\n input: RAGRetrievalIncidentRemediationBulkExecutionRequest,\n ) {\n return this.client(path).bulkExecuteRetrievalIncidentRemediations(input);\n }\n\n retrievalReleaseStatus(path: string) {\n return this.client(path).retrievalReleaseStatus();\n }\n\n retrievalReleaseIncidentStatus(path: string) {\n return this.client(path).retrievalReleaseIncidentStatus();\n }\n\n retrievalIncidentRemediationStatus(path: string) {\n return this.client(path).retrievalIncidentRemediationStatus();\n }\n\n retrievalReleaseDriftStatus(path: string) {\n return this.client(path).retrievalReleaseDriftStatus();\n }\n\n retrievalLaneHandoffStatus(path: string) {\n return this.client(path).retrievalLaneHandoffStatus();\n }\n\n retrievalLaneHandoffIncidentStatus(path: string) {\n return this.client(path).retrievalLaneHandoffIncidentStatus();\n }\n\n acknowledgeRetrievalLaneHandoffIncident(\n path: string,\n input: {\n incidentId: string;\n acknowledgedAt?: number;\n acknowledgedBy?: string;\n acknowledgementNotes?: string;\n },\n ) {\n return this.client(path).acknowledgeRetrievalLaneHandoffIncident(input);\n }\n\n unacknowledgeRetrievalLaneHandoffIncident(\n path: string,\n input: {\n incidentId: string;\n },\n ) {\n return this.client(path).unacknowledgeRetrievalLaneHandoffIncident(input);\n }\n\n resolveRetrievalLaneHandoffIncident(\n path: string,\n input: {\n incidentId: string;\n resolvedAt?: number;\n resolvedBy?: string;\n resolutionNotes?: string;\n },\n ) {\n return this.client(path).resolveRetrievalLaneHandoffIncident(input);\n }\n\n acknowledgeRetrievalReleaseIncident(\n path: string,\n input: {\n incidentId: string;\n acknowledgedAt?: number;\n acknowledgedBy?: string;\n acknowledgementNotes?: string;\n },\n ) {\n return this.client(path).acknowledgeRetrievalReleaseIncident(input);\n }\n\n unacknowledgeRetrievalReleaseIncident(\n path: string,\n input: {\n incidentId: string;\n },\n ) {\n return this.client(path).unacknowledgeRetrievalReleaseIncident(input);\n }\n\n resolveRetrievalReleaseIncident(\n path: string,\n input: {\n incidentId: string;\n resolvedAt?: number;\n resolvedBy?: string;\n resolutionNotes?: string;\n },\n ) {\n return this.client(path).resolveRetrievalReleaseIncident(input);\n }\n\n retrievalPromotionCandidates(\n path: string,\n input?: {\n groupKey?: string;\n limit?: number;\n tag?: string;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n approved?: boolean;\n ready?: boolean;\n blocked?: boolean;\n reviewStatus?: \"approved\" | \"blocked\" | \"needs_review\" | \"ready\";\n freshnessStatus?: \"fresh\" | \"expired\" | \"not_applicable\";\n sortBy?: \"approvalFreshness\" | \"finishedAt\" | \"gateSeverity\" | \"priority\";\n sortDirection?: \"asc\" | \"desc\";\n },\n ) {\n return this.client(path).retrievalPromotionCandidates(input);\n }\n\n approveRetrievalCandidate(\n path: string,\n input: RAGRetrievalReleaseDecisionActionRequest,\n ) {\n return this.client(path).approveRetrievalCandidate(input);\n }\n\n rejectRetrievalCandidate(\n path: string,\n input: RAGRetrievalReleaseDecisionActionRequest,\n ) {\n return this.client(path).rejectRetrievalCandidate(input);\n }\n\n status(path: string) {\n return this.client(path).status();\n }\n\n ops(path: string) {\n return this.client(path).ops();\n }\n\n searchTraceHistory(\n path: string,\n input?: {\n query?: string;\n groupKey?: string;\n tag?: string;\n limit?: number;\n },\n ) {\n return this.client(path).searchTraceHistory(input);\n }\n\n searchTraceGroups(\n path: string,\n input?: {\n tag?: string;\n limit?: number;\n },\n ) {\n return this.client(path).searchTraceGroups(input);\n }\n\n searchTraceStats(path: string, input?: { tag?: string }) {\n return this.client(path).searchTraceStats(input);\n }\n\n previewSearchTracePrune(\n path: string,\n input?: {\n maxAgeMs?: number;\n maxRecordsPerQuery?: number;\n maxRecordsPerGroup?: number;\n now?: number;\n tag?: string;\n },\n ) {\n return this.client(path).previewSearchTracePrune(input);\n }\n\n pruneSearchTraces(\n path: string,\n input?: {\n maxAgeMs?: number;\n maxRecordsPerQuery?: number;\n maxRecordsPerGroup?: number;\n now?: number;\n tag?: string;\n },\n ) {\n return this.client(path).pruneSearchTraces(input);\n }\n\n searchTracePruneHistory(\n path: string,\n input?: {\n limit?: number;\n trigger?: \"manual\" | \"write\" | \"schedule\";\n },\n ) {\n return this.client(path).searchTracePruneHistory(input);\n }\n\n syncSources(path: string) {\n return this.client(path).syncSources();\n }\n\n syncAllSources(path: string, options?: RAGSyncRunOptions) {\n return this.client(path).syncAllSources(options);\n }\n\n syncSource(path: string, id: string, options?: RAGSyncRunOptions) {\n return this.client(path).syncSource(id, options);\n }\n\n documents(path: string, kind?: string) {\n return this.client(path).documents(kind);\n }\n\n documentChunks(path: string, id: string) {\n return this.client(path).documentChunks(id);\n }\n\n createDocument(\n path: string,\n input: RAGDocumentIngestInput[\"documents\"][number],\n ) {\n return this.client(path).createDocument(input);\n }\n\n deleteDocument(path: string, id: string) {\n return this.client(path).deleteDocument(id);\n }\n\n reseed(path: string) {\n return this.client(path).reseed();\n }\n\n reset(path: string) {\n return this.client(path).reset();\n }\n\n reindexDocument(path: string, id: string) {\n return this.client(path).reindexDocument(id);\n }\n\n reindexSource(path: string, source: string) {\n return this.client(path).reindexSource(source);\n }\n\n backends(path: string) {\n return this.client(path).backends();\n }\n\n clearIndex(path: string) {\n return this.client(path).clearIndex();\n }\n}\n",
12
+ "import type {\n RAGAdminCapabilities,\n RAGBackendsResponse,\n RAGBackendMaintenanceRecommendation,\n RAGBackendMaintenanceSummary,\n RAGDocumentChunksResponse,\n RAGEvaluationInput,\n RAGEvaluationResponse,\n RAGRetrievalBaselineListResponse,\n RAGRetrievalBaselinePromotionFromRunRequest,\n RAGRetrievalBaselinePromotionRequest,\n RAGRetrievalBaselineRevertRequest,\n RAGRetrievalReleaseIncidentAcknowledgeRequest,\n RAGRetrievalReleaseDecisionActionRequest,\n RAGRetrievalBaselineResponse,\n RAGRetrievalPromotionCandidateListResponse,\n RAGRetrievalReleaseDecisionListResponse,\n RAGRetrievalLaneHandoffDecisionListResponse,\n RAGRetrievalLaneHandoffDecisionRequest,\n RAGRetrievalLaneHandoffDecisionResponse,\n RAGRetrievalLaneHandoffAutoCompletePolicyHistoryResponse,\n RAGRetrievalReleaseLanePolicyHistoryResponse,\n RAGRetrievalBaselineGatePolicyHistoryResponse,\n RAGRetrievalReleaseLaneEscalationPolicyHistoryResponse,\n RAGRetrievalLaneHandoffIncidentHistoryResponse,\n RAGRetrievalLaneHandoffIncidentListResponse,\n RAGRetrievalLaneHandoffIncidentStatusResponse,\n RAGRetrievalLaneHandoffListResponse,\n RAGRetrievalLaneHandoffStatusResponse,\n RAGRetrievalIncidentRemediationDecisionListResponse,\n RAGRetrievalIncidentRemediationDecisionRequest,\n RAGRetrievalIncidentRemediationExecutionHistoryResponse,\n RAGRetrievalIncidentRemediationBulkExecutionRequest,\n RAGRetrievalIncidentRemediationBulkExecutionResponse,\n RAGRetrievalIncidentRemediationExecutionRequest,\n RAGRetrievalIncidentRemediationExecutionResponse,\n RAGRetrievalIncidentRemediationStatusResponse,\n RAGRetrievalReleaseGroupHistoryResponse,\n RAGRetrievalReleaseIncidentListResponse,\n RAGRetrievalReleaseIncidentStatusResponse,\n RAGRetrievalReleaseDriftStatusResponse,\n RAGRetrievalReleaseStatusResponse,\n RAGRetrievalComparisonHistoryResponse,\n RAGRetrievalComparisonRequest,\n RAGRetrievalComparisonResponse,\n RAGAdaptiveNativePlannerBenchmarkResponse,\n RAGAdaptiveNativePlannerBenchmarkSnapshotResponse,\n RAGNativeBackendComparisonBenchmarkResponse,\n RAGNativeBackendComparisonBenchmarkSnapshotResponse,\n RAGDocumentIngestInput,\n RAGDocumentChunk,\n RAGDocumentsResponse,\n RAGDocumentUrlIngestInput,\n RAGDocumentUploadIngestInput,\n RAGIngestResponse,\n RAGMutationResponse,\n RAGOperationsResponse,\n RAGSearchRequest,\n RAGSearchResponse,\n RAGSearchTracePrunePreviewResponse,\n RAGSearchTracePruneHistoryResponse,\n RAGSearchTracePruneResponse,\n RAGSearchTraceGroupHistoryResponse,\n RAGSearchTraceHistoryResponse,\n RAGSearchTraceStatsResponse,\n RAGSource,\n RAGStatusResponse,\n RAGSyncRunOptions,\n RAGSyncResponse,\n} from \"@absolutejs/ai\";\nconst UNFOUND_INDEX = -1;\n\ntype FetchLike = typeof fetch;\n\nexport type RAGClientOptions = {\n path: string;\n fetch?: FetchLike;\n};\n\nexport type RAGDetailedSearchResponse = {\n results: RAGSource[];\n trace?: RAGSearchResponse[\"trace\"];\n};\n\nexport type RAGMaintenancePayload =\n | Pick<RAGMutationResponse, \"maintenance\" | \"admin\" | \"workflowStatus\">\n | Pick<RAGOperationsResponse, \"maintenance\" | \"admin\" | \"status\">\n | Pick<RAGStatusResponse, \"maintenance\" | \"admin\" | \"status\">\n | null\n | undefined;\n\nexport type RAGMaintenanceActionDescriptor = {\n kind: \"analyze_backend\" | \"rebuild_native_index\";\n label: string;\n available: boolean;\n recommended: boolean;\n reason?: string;\n};\n\nexport type RAGMaintenanceOverview = {\n activeJobCount: number;\n actions: RAGMaintenanceActionDescriptor[];\n availableActions: RAGMaintenanceActionDescriptor[];\n backend?: RAGBackendMaintenanceSummary[\"backend\"];\n blockingRecommendations: RAGBackendMaintenanceRecommendation[];\n criticalCount: number;\n hasBlockingIssue: boolean;\n infoCount: number;\n primaryRecommendation?: RAGBackendMaintenanceRecommendation;\n recentlyCompletedActions: NonNullable<RAGBackendMaintenanceSummary>[\"recentActions\"];\n recommendationCount: number;\n recommendations: RAGBackendMaintenanceRecommendation[];\n recommendedNow: RAGBackendMaintenanceRecommendation[];\n warningCount: number;\n};\n\nconst jsonHeaders: { \"Content-Type\": string } = {\n \"Content-Type\": \"application/json\",\n};\n\nconst normalizeBasePath = (path: string) =>\n path.endsWith(\"/\") ? path.slice(0, UNFOUND_INDEX) : path;\n\nconst parseJson = async <T>(response: Response) => {\n const payload: T = JSON.parse(await response.text());\n\n return payload;\n};\n\nconst isErrorPayload = (value: unknown): value is { error?: string } => {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n\n return !(\"error\" in value) || typeof value.error === \"string\";\n};\n\nconst toErrorMessage = async (response: Response) => {\n try {\n const payload = JSON.parse(await response.text());\n if (\n isErrorPayload(payload) &&\n typeof payload.error === \"string\" &&\n payload.error\n ) {\n return payload.error;\n }\n } catch {\n // fall through\n }\n\n return `Request failed with status ${response.status}`;\n};\n\nconst getMaintenanceSummary = (\n payload: RAGMaintenancePayload,\n): RAGBackendMaintenanceSummary | undefined => payload?.maintenance;\n\nconst getMaintenanceAdmin = (\n payload: RAGMaintenancePayload,\n): RAGAdminCapabilities | undefined => payload?.admin;\n\nexport const buildRAGMaintenanceOverview = (\n payload: RAGMaintenancePayload,\n): RAGMaintenanceOverview => {\n const summary = getMaintenanceSummary(payload);\n const admin = getMaintenanceAdmin(payload);\n const recommendations = summary?.recommendations ?? [];\n const blockingRecommendations = recommendations.filter(\n (entry) => entry.severity === \"error\",\n );\n const recommendedNow = recommendations.filter(\n (entry) => entry.severity !== \"info\",\n );\n const recommendedActions = new Set(\n recommendations.flatMap((entry) => (entry.action ? [entry.action] : [])),\n );\n const actionReason = (kind: \"analyze_backend\" | \"rebuild_native_index\") =>\n recommendations.find((entry) => entry.action === kind)?.message;\n\n const actions: RAGMaintenanceActionDescriptor[] = [\n {\n available: admin?.canAnalyzeBackend ?? false,\n kind: \"analyze_backend\",\n label: \"Analyze backend\",\n reason: actionReason(\"analyze_backend\"),\n recommended: recommendedActions.has(\"analyze_backend\"),\n },\n {\n available: admin?.canRebuildNativeIndex ?? false,\n kind: \"rebuild_native_index\",\n label: \"Rebuild native index\",\n reason: actionReason(\"rebuild_native_index\"),\n recommended: recommendedActions.has(\"rebuild_native_index\"),\n },\n ];\n\n return {\n activeJobCount: summary?.activeJobs.length ?? 0,\n actions,\n availableActions: actions.filter((action) => action.available),\n backend: summary?.backend,\n blockingRecommendations,\n criticalCount: blockingRecommendations.length,\n hasBlockingIssue: blockingRecommendations.length > 0,\n infoCount: recommendations.filter((entry) => entry.severity === \"info\")\n .length,\n primaryRecommendation: [...recommendations].sort((left, right) => {\n const severityRank = { error: 0, warning: 1, info: 2 } as const;\n return severityRank[left.severity] - severityRank[right.severity];\n })[0],\n recentlyCompletedActions: (summary?.recentActions ?? []).filter(\n (action) => action.status === \"completed\",\n ),\n recommendationCount: recommendations.length,\n recommendations,\n recommendedNow,\n warningCount: recommendations.filter(\n (entry) => entry.severity === \"warning\",\n ).length,\n };\n};\n\nexport const createRAGClient = (options: RAGClientOptions) => {\n const basePath = normalizeBasePath(options.path);\n const fetchImpl = options.fetch ?? fetch;\n\n const search = async <IncludeTrace extends boolean | undefined = undefined>(\n input: RAGSearchRequest & { includeTrace?: IncludeTrace },\n ): Promise<\n IncludeTrace extends true ? RAGDetailedSearchResponse : RAGSource[]\n > => {\n const response = await fetchImpl(`${basePath}/search`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGSearchResponse>(response);\n\n if (!payload.ok) {\n throw new Error(payload.error ?? \"RAG search failed\");\n }\n\n if (input.includeTrace === true) {\n return {\n results: payload.results ?? [],\n trace: payload.trace,\n } as IncludeTrace extends true ? RAGDetailedSearchResponse : RAGSource[];\n }\n\n return (payload.results ?? []) as IncludeTrace extends true\n ? RAGDetailedSearchResponse\n : RAGSource[];\n };\n\n return {\n async backends() {\n const response = await fetchImpl(`${basePath}/backends`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGBackendsResponse>(response);\n },\n async clearIndex() {\n const response = await fetchImpl(`${basePath}/index`, {\n method: \"DELETE\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<{ ok: boolean }>(response);\n },\n async createDocument(input: RAGDocumentIngestInput[\"documents\"][number]) {\n const response = await fetchImpl(`${basePath}/documents`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async deleteDocument(id: string) {\n const response = await fetchImpl(\n `${basePath}/documents/${encodeURIComponent(id)}`,\n {\n method: \"DELETE\",\n },\n );\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async documentChunks(id: string) {\n const response = await fetchImpl(\n `${basePath}/documents/${encodeURIComponent(id)}/chunks`,\n );\n\n if (!response.ok) {\n const error = await toErrorMessage(response);\n\n const errorResponse: RAGDocumentChunksResponse = {\n error,\n ok: false,\n };\n\n return errorResponse;\n }\n\n return parseJson<RAGDocumentChunksResponse>(response);\n },\n async documents(kind?: string) {\n const query = kind ? `?kind=${encodeURIComponent(kind)}` : \"\";\n const response = await fetchImpl(`${basePath}/documents${query}`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGDocumentsResponse>(response);\n },\n async evaluate(input: RAGEvaluationInput) {\n const response = await fetchImpl(`${basePath}/evaluate`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGEvaluationResponse>(response);\n },\n async compareRetrievals(input: RAGRetrievalComparisonRequest) {\n const response = await fetchImpl(`${basePath}/compare/retrieval`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGRetrievalComparisonResponse>(response);\n if (!payload.ok || !payload.comparison) {\n throw new Error(payload.error ?? \"RAG retrieval comparison failed\");\n }\n\n return payload.comparison;\n },\n async retrievalComparisonHistory(input?: {\n limit?: number;\n suiteId?: string;\n label?: string;\n winnerId?: string;\n groupKey?: string;\n tag?: string;\n }) {\n const searchParams = new URLSearchParams();\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.suiteId) {\n searchParams.set(\"suiteId\", input.suiteId);\n }\n if (input?.label) {\n searchParams.set(\"label\", input.label);\n }\n if (input?.winnerId) {\n searchParams.set(\"winnerId\", input.winnerId);\n }\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalComparisonHistoryResponse>(response);\n if (!payload.ok || !payload.runs) {\n throw new Error(\n payload.error ?? \"RAG retrieval comparison history failed\",\n );\n }\n\n return payload.runs;\n },\n async retrievalBaselines(input?: {\n groupKey?: string;\n tag?: string;\n limit?: number;\n status?: \"active\" | \"superseded\";\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.status) {\n searchParams.set(\"status\", input.status);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalBaselineListResponse>(response);\n if (!payload.ok || !payload.baselines) {\n throw new Error(payload.error ?? \"RAG retrieval baseline list failed\");\n }\n\n return payload.baselines;\n },\n async promoteRetrievalBaseline(\n input: RAGRetrievalBaselinePromotionRequest,\n ) {\n const payload = await this.promoteRetrievalBaselineDetailed(input);\n return payload.baseline!;\n },\n async promoteRetrievalBaselineDetailed(\n input: RAGRetrievalBaselinePromotionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/promote`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGRetrievalBaselineResponse>(response);\n if (!payload.ok || !payload.baseline) {\n throw new Error(\n payload.error ?? \"RAG retrieval baseline promotion failed\",\n );\n }\n\n return payload;\n },\n async promoteRetrievalBaselineToLane(\n input: RAGRetrievalBaselinePromotionRequest & {\n rolloutLabel: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n const payload = await this.promoteRetrievalBaselineToLaneDetailed(input);\n return payload.baseline!;\n },\n async promoteRetrievalBaselineToLaneDetailed(\n input: RAGRetrievalBaselinePromotionRequest & {\n rolloutLabel: \"canary\" | \"stable\" | \"rollback_target\";\n },\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/promote-lane`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGRetrievalBaselineResponse>(response);\n if (!payload.ok || !payload.baseline) {\n throw new Error(\n payload.error ?? \"RAG retrieval rollout-lane promotion failed\",\n );\n }\n\n return payload;\n },\n async promoteRetrievalBaselineFromRun(\n input: RAGRetrievalBaselinePromotionFromRunRequest,\n ) {\n const payload = await this.promoteRetrievalBaselineFromRunDetailed(input);\n return payload.baseline!;\n },\n async promoteRetrievalBaselineFromRunDetailed(\n input: RAGRetrievalBaselinePromotionFromRunRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/promote-run`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGRetrievalBaselineResponse>(response);\n if (!payload.ok || !payload.baseline) {\n throw new Error(\n payload.error ?? \"RAG retrieval baseline promotion from run failed\",\n );\n }\n\n return payload;\n },\n async revertRetrievalBaseline(input: RAGRetrievalBaselineRevertRequest) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/revert`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGRetrievalBaselineResponse>(response);\n if (!payload.ok || !payload.baseline) {\n throw new Error(\n payload.error ?? \"RAG retrieval baseline revert failed\",\n );\n }\n\n return payload.baseline;\n },\n async retrievalBaselineDecisions(input?: {\n groupKey?: string;\n limit?: number;\n kind?: \"approve\" | \"promote\" | \"reject\" | \"revert\";\n freshnessStatus?: \"fresh\" | \"expired\" | \"not_applicable\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.kind) {\n searchParams.set(\"kind\", input.kind);\n }\n if (input?.freshnessStatus) {\n searchParams.set(\"freshnessStatus\", input.freshnessStatus);\n }\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/decisions${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseDecisionListResponse>(response);\n if (!payload.ok || !payload.decisions) {\n throw new Error(\n payload.error ?? \"RAG retrieval release decision list failed\",\n );\n }\n\n return payload.decisions;\n },\n async retrievalReleaseGroupHistory(input: {\n groupKey: string;\n decisionLimit?: number;\n baselineLimit?: number;\n benchmarkLimit?: number;\n runLimit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const searchParams = new URLSearchParams();\n searchParams.set(\"groupKey\", input.groupKey);\n if (typeof input.decisionLimit === \"number\") {\n searchParams.set(\"decisionLimit\", String(input.decisionLimit));\n }\n if (typeof input.baselineLimit === \"number\") {\n searchParams.set(\"baselineLimit\", String(input.baselineLimit));\n }\n if (typeof input.runLimit === \"number\") {\n searchParams.set(\"runLimit\", String(input.runLimit));\n }\n if (typeof input.benchmarkLimit === \"number\") {\n searchParams.set(\"benchmarkLimit\", String(input.benchmarkLimit));\n }\n if (input.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/release-history?${searchParams}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseGroupHistoryResponse>(response);\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"RAG retrieval release group history failed\",\n );\n }\n\n return payload;\n },\n async adaptiveNativePlannerBenchmark(input?: {\n limit?: number;\n runLimit?: number;\n label?: string;\n description?: string;\n groupKey?: string;\n corpusGroupKey?: string;\n }) {\n const searchParams = new URLSearchParams();\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (typeof input?.runLimit === \"number\") {\n searchParams.set(\"runLimit\", String(input.runLimit));\n }\n if (input?.label) {\n searchParams.set(\"label\", input.label);\n }\n if (input?.description) {\n searchParams.set(\"description\", input.description);\n }\n if (input?.groupKey) {\n searchParams.set(\"benchmarkGroupKey\", input.groupKey);\n }\n if (input?.corpusGroupKey) {\n searchParams.set(\"benchmarkCorpusGroupKey\", input.corpusGroupKey);\n }\n const suffix = searchParams.size ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/adaptive-native-planner${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGAdaptiveNativePlannerBenchmarkResponse>(response);\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"Adaptive native planner benchmark history failed\",\n );\n }\n\n return payload;\n },\n async runAdaptiveNativePlannerBenchmark(input?: {\n limit?: number;\n runLimit?: number;\n topK?: number;\n label?: string;\n description?: string;\n groupKey?: string;\n corpusGroupKey?: string;\n persistRun?: boolean;\n baselineRetrievalId?: string;\n candidateRetrievalId?: string;\n retrievals?: Array<{\n id: string;\n label?: string;\n retrieval?: Record<string, unknown> | string;\n }>;\n tags?: string[];\n metadata?: Record<string, unknown>;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/adaptive-native-planner/run`,\n {\n body: JSON.stringify({\n baselineRetrievalId: input?.baselineRetrievalId,\n candidateRetrievalId: input?.candidateRetrievalId,\n corpusGroupKey: input?.corpusGroupKey,\n description: input?.description,\n groupKey: input?.groupKey,\n label: input?.label,\n limit: input?.limit,\n metadata: input?.metadata,\n persistRun: input?.persistRun,\n retrievals: input?.retrievals,\n runLimit: input?.runLimit,\n tags: input?.tags,\n topK: input?.topK,\n }),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGAdaptiveNativePlannerBenchmarkResponse>(response);\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"Adaptive native planner benchmark run failed\",\n );\n }\n\n return payload;\n },\n async saveAdaptiveNativePlannerBenchmarkSnapshot(input?: {\n limit?: number;\n label?: string;\n description?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n snapshotMetadata?: Record<string, unknown>;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/adaptive-native-planner/snapshots`,\n {\n body: JSON.stringify({\n createdAt: input?.createdAt,\n description: input?.description,\n label: input?.label,\n limit: input?.limit,\n metadata: input?.metadata,\n snapshotMetadata: input?.snapshotMetadata,\n version: input?.version,\n }),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGAdaptiveNativePlannerBenchmarkSnapshotResponse>(\n response,\n );\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"Adaptive native planner benchmark snapshot failed\",\n );\n }\n\n return payload;\n },\n async nativeBackendComparisonBenchmark(input?: {\n limit?: number;\n runLimit?: number;\n label?: string;\n description?: string;\n groupKey?: string;\n corpusGroupKey?: string;\n }) {\n const searchParams = new URLSearchParams();\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (typeof input?.runLimit === \"number\") {\n searchParams.set(\"runLimit\", String(input.runLimit));\n }\n if (input?.label) {\n searchParams.set(\"label\", input.label);\n }\n if (input?.description) {\n searchParams.set(\"description\", input.description);\n }\n if (input?.groupKey) {\n searchParams.set(\"benchmarkGroupKey\", input.groupKey);\n }\n if (input?.corpusGroupKey) {\n searchParams.set(\"benchmarkCorpusGroupKey\", input.corpusGroupKey);\n }\n const suffix = searchParams.size ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/native-backend-comparison${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGNativeBackendComparisonBenchmarkResponse>(response);\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"Native backend comparison benchmark history failed\",\n );\n }\n\n return payload;\n },\n async runNativeBackendComparisonBenchmark(input?: {\n limit?: number;\n runLimit?: number;\n topK?: number;\n label?: string;\n description?: string;\n groupKey?: string;\n corpusGroupKey?: string;\n persistRun?: boolean;\n baselineRetrievalId?: string;\n candidateRetrievalId?: string;\n retrievals?: Array<{\n id: string;\n label?: string;\n retrieval?: Record<string, unknown> | string;\n }>;\n tags?: string[];\n metadata?: Record<string, unknown>;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/native-backend-comparison/run`,\n {\n body: JSON.stringify({\n baselineRetrievalId: input?.baselineRetrievalId,\n candidateRetrievalId: input?.candidateRetrievalId,\n corpusGroupKey: input?.corpusGroupKey,\n description: input?.description,\n groupKey: input?.groupKey,\n label: input?.label,\n limit: input?.limit,\n metadata: input?.metadata,\n persistRun: input?.persistRun,\n retrievals: input?.retrievals,\n runLimit: input?.runLimit,\n tags: input?.tags,\n topK: input?.topK,\n }),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGNativeBackendComparisonBenchmarkResponse>(response);\n if (!payload.ok) {\n throw new Error(\n payload.error ?? \"Native backend comparison benchmark run failed\",\n );\n }\n\n return payload;\n },\n async saveNativeBackendComparisonBenchmarkSnapshot(input?: {\n limit?: number;\n label?: string;\n description?: string;\n version?: number;\n createdAt?: number;\n metadata?: Record<string, unknown>;\n snapshotMetadata?: Record<string, unknown>;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/benchmarks/native-backend-comparison/snapshots`,\n {\n body: JSON.stringify({\n createdAt: input?.createdAt,\n description: input?.description,\n label: input?.label,\n limit: input?.limit,\n metadata: input?.metadata,\n snapshotMetadata: input?.snapshotMetadata,\n version: input?.version,\n }),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGNativeBackendComparisonBenchmarkSnapshotResponse>(\n response,\n );\n if (!payload.ok) {\n throw new Error(\n payload.error ??\n \"Native backend comparison benchmark snapshot failed\",\n );\n }\n\n return payload;\n },\n async retrievalLaneHandoffs(input?: {\n groupKey?: string;\n sourceRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n limit?: number;\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (input?.sourceRolloutLabel) {\n searchParams.set(\"sourceRolloutLabel\", input.sourceRolloutLabel);\n }\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffListResponse>(response);\n if (!payload.ok || !payload.handoffs) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff list failed\",\n );\n }\n\n return payload.handoffs;\n },\n async retrievalLaneHandoffDecisions(input?: {\n groupKey?: string;\n sourceRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n kind?: \"approve\" | \"reject\" | \"complete\";\n limit?: number;\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (input?.sourceRolloutLabel) {\n searchParams.set(\"sourceRolloutLabel\", input.sourceRolloutLabel);\n }\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n if (input?.kind) {\n searchParams.set(\"kind\", input.kind);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/decisions${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffDecisionListResponse>(response);\n if (!payload.ok || !payload.decisions) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff decision list failed\",\n );\n }\n\n return payload.decisions;\n },\n async retrievalLaneHandoffIncidents(input?: {\n groupKey?: string;\n limit?: number;\n status?: \"open\" | \"resolved\";\n severity?: \"warning\" | \"critical\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) searchParams.set(\"groupKey\", input.groupKey);\n if (typeof input?.limit === \"number\")\n searchParams.set(\"limit\", String(input.limit));\n if (input?.status) searchParams.set(\"status\", input.status);\n if (input?.severity) searchParams.set(\"severity\", input.severity);\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/incidents${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff incident list failed\",\n );\n }\n\n return payload.incidents;\n },\n async retrievalLaneHandoffIncidentHistory(input?: {\n action?: \"opened\" | \"acknowledged\" | \"unacknowledged\" | \"resolved\";\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/incidents/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffIncidentHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff incident history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalLaneHandoffAutoCompletePolicyHistory(input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/policies/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffAutoCompletePolicyHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval lane handoff auto-complete policy history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalReleaseLanePolicyHistory(input?: {\n groupKey?: string;\n limit?: number;\n rolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n scope?: \"rollout_label\" | \"group_rollout_label\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/release-policies/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseLanePolicyHistoryResponse>(response);\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ?? \"RAG retrieval release lane policy history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalBaselineGatePolicyHistory(input?: {\n groupKey?: string;\n limit?: number;\n rolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n scope?: \"rollout_label\" | \"group_rollout_label\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/gate-policies/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalBaselineGatePolicyHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ?? \"RAG retrieval baseline gate policy history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalReleaseLaneEscalationPolicyHistory(input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/escalation-policies/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseLaneEscalationPolicyHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval release lane escalation policy history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalReleaseIncidentPolicyHistory(input?: {\n groupKey?: string;\n limit?: number;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incident-policies/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseLaneEscalationPolicyHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval release incident policy history failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalReleaseIncidentStatus() {\n const response = await fetchImpl(`${basePath}/status/release/incidents`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalReleaseIncidentStatusResponse>(response);\n },\n async retrievalIncidentRemediationStatus() {\n const response = await fetchImpl(\n `${basePath}/status/release/remediations`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalIncidentRemediationStatusResponse>(response);\n },\n async retrievalLaneHandoffIncidentStatus() {\n const response = await fetchImpl(`${basePath}/status/handoffs/incidents`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalLaneHandoffIncidentStatusResponse>(response);\n },\n async acknowledgeRetrievalLaneHandoffIncident(\n input: RAGRetrievalReleaseIncidentAcknowledgeRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/incidents/acknowledge`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ??\n \"RAG retrieval lane handoff incident acknowledgement failed\",\n );\n }\n\n return payload.incidents;\n },\n async unacknowledgeRetrievalLaneHandoffIncident(input: {\n incidentId: string;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/incidents/unacknowledge`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ??\n \"RAG retrieval lane handoff incident unacknowledge failed\",\n );\n }\n\n return payload.incidents;\n },\n async resolveRetrievalLaneHandoffIncident(input: {\n incidentId: string;\n resolvedAt?: number;\n resolvedBy?: string;\n resolutionNotes?: string;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/incidents/resolve`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalLaneHandoffIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff incident resolve failed\",\n );\n }\n\n return payload.incidents;\n },\n async decideRetrievalLaneHandoff(\n input: RAGRetrievalLaneHandoffDecisionRequest,\n ) {\n const payload = await this.decideRetrievalLaneHandoffDetailed(input);\n if (!payload.decision) {\n throw new Error(\n payload.error ?? \"RAG retrieval lane handoff decision failed\",\n );\n }\n return payload.decision;\n },\n async decideRetrievalLaneHandoffDetailed(\n input: RAGRetrievalLaneHandoffDecisionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/handoffs/decide`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalLaneHandoffDecisionResponse>(response);\n },\n async retrievalReleaseIncidents(input?: {\n groupKey?: string;\n limit?: number;\n status?: \"open\" | \"resolved\";\n severity?: \"warning\" | \"critical\";\n kind?:\n | \"approval_expired\"\n | \"baseline_regression\"\n | \"gate_failure\"\n | \"handoff_stale\";\n acknowledged?: boolean;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.status) {\n searchParams.set(\"status\", input.status);\n }\n if (input?.severity) {\n searchParams.set(\"severity\", input.severity);\n }\n if (input?.kind) {\n searchParams.set(\"kind\", input.kind);\n }\n if (typeof input?.acknowledged === \"boolean\") {\n searchParams.set(\"acknowledged\", String(input.acknowledged));\n }\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ?? \"RAG retrieval release incident list failed\",\n );\n }\n\n return payload.incidents;\n },\n async retrievalIncidentRemediationDecisions(input?: {\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n remediationKind?: RAGRetrievalIncidentRemediationDecisionRequest[\"remediationKind\"];\n status?: \"planned\" | \"applied\" | \"dismissed\";\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/remediations${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalIncidentRemediationDecisionListResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval incident remediation decision list failed\",\n );\n }\n\n return payload.records;\n },\n async retrievalIncidentRemediationExecutions(input?: {\n groupKey?: string;\n incidentId?: string;\n limit?: number;\n actionKind?: RAGRetrievalIncidentRemediationExecutionRequest[\"action\"][\"kind\"];\n code?: NonNullable<\n RAGRetrievalIncidentRemediationExecutionResponse[\"execution\"]\n >[\"code\"];\n blockedByGuardrail?: boolean;\n idempotentReplay?: boolean;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n }) {\n const suffix = input\n ? `?${new URLSearchParams(\n Object.entries(input)\n .filter(([, value]) => value !== undefined)\n .map(([key, value]) => [key, String(value)]),\n ).toString()}`\n : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/remediations/executions${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalIncidentRemediationExecutionHistoryResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval incident remediation execution history failed\",\n );\n }\n\n return payload.records;\n },\n async recordRetrievalIncidentRemediationDecision(\n input: RAGRetrievalIncidentRemediationDecisionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/remediations`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalIncidentRemediationDecisionListResponse>(\n response,\n );\n if (!payload.ok || !payload.records) {\n throw new Error(\n payload.error ??\n \"RAG retrieval incident remediation decision record failed\",\n );\n }\n\n return payload.records;\n },\n async executeRetrievalIncidentRemediation(\n input: RAGRetrievalIncidentRemediationExecutionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/remediations/execute`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalIncidentRemediationExecutionResponse>(\n response,\n );\n if (!payload.ok || !payload.execution) {\n throw new Error(\n payload.error ??\n \"RAG retrieval incident remediation execution failed\",\n );\n }\n\n return payload;\n },\n async bulkExecuteRetrievalIncidentRemediations(\n input: RAGRetrievalIncidentRemediationBulkExecutionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/remediations/execute/bulk`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalIncidentRemediationBulkExecutionResponse>(\n response,\n );\n if (!payload.ok || !payload.results) {\n throw new Error(\n payload.error ??\n \"Bulk RAG retrieval incident remediation execution failed\",\n );\n }\n\n return payload.results;\n },\n async acknowledgeRetrievalReleaseIncident(\n input: RAGRetrievalReleaseIncidentAcknowledgeRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/acknowledge`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ??\n \"RAG retrieval release incident acknowledgement failed\",\n );\n }\n\n return payload.incidents;\n },\n async unacknowledgeRetrievalReleaseIncident(input: { incidentId: string }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/unacknowledge`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ??\n \"RAG retrieval release incident unacknowledge failed\",\n );\n }\n\n return payload.incidents;\n },\n async resolveRetrievalReleaseIncident(input: {\n incidentId: string;\n resolvedAt?: number;\n resolvedBy?: string;\n resolutionNotes?: string;\n }) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/incidents/resolve`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseIncidentListResponse>(response);\n if (!payload.ok || !payload.incidents) {\n throw new Error(\n payload.error ?? \"RAG retrieval release incident resolve failed\",\n );\n }\n\n return payload.incidents;\n },\n async retrievalPromotionCandidates(input?: {\n groupKey?: string;\n limit?: number;\n tag?: string;\n targetRolloutLabel?: \"canary\" | \"stable\" | \"rollback_target\";\n approved?: boolean;\n ready?: boolean;\n blocked?: boolean;\n reviewStatus?: \"approved\" | \"blocked\" | \"needs_review\" | \"ready\";\n freshnessStatus?: \"fresh\" | \"expired\" | \"not_applicable\";\n sortBy?: \"approvalFreshness\" | \"finishedAt\" | \"gateSeverity\" | \"priority\";\n sortDirection?: \"asc\" | \"desc\";\n }) {\n const searchParams = new URLSearchParams();\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n if (input?.targetRolloutLabel) {\n searchParams.set(\"targetRolloutLabel\", input.targetRolloutLabel);\n }\n if (typeof input?.approved === \"boolean\") {\n searchParams.set(\"approved\", String(input.approved));\n }\n if (typeof input?.ready === \"boolean\") {\n searchParams.set(\"ready\", String(input.ready));\n }\n if (typeof input?.blocked === \"boolean\") {\n searchParams.set(\"blocked\", String(input.blocked));\n }\n if (input?.reviewStatus) {\n searchParams.set(\"reviewStatus\", input.reviewStatus);\n }\n if (input?.freshnessStatus) {\n searchParams.set(\"freshnessStatus\", input.freshnessStatus);\n }\n if (input?.sortBy) {\n searchParams.set(\"sortBy\", input.sortBy);\n }\n if (input?.sortDirection) {\n searchParams.set(\"sortDirection\", input.sortDirection);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/candidates${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalPromotionCandidateListResponse>(response);\n if (!payload.ok || !payload.candidates) {\n throw new Error(\n payload.error ?? \"RAG retrieval promotion candidate list failed\",\n );\n }\n\n return payload.candidates;\n },\n async approveRetrievalCandidate(\n input: RAGRetrievalReleaseDecisionActionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/approve`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseDecisionListResponse>(response);\n if (!payload.ok || !payload.decisions) {\n throw new Error(payload.error ?? \"RAG retrieval approval failed\");\n }\n\n return payload.decisions;\n },\n async rejectRetrievalCandidate(\n input: RAGRetrievalReleaseDecisionActionRequest,\n ) {\n const response = await fetchImpl(\n `${basePath}/compare/retrieval/baselines/reject`,\n {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseDecisionListResponse>(response);\n if (!payload.ok || !payload.decisions) {\n throw new Error(payload.error ?? \"RAG retrieval rejection failed\");\n }\n\n return payload.decisions;\n },\n async ingest(chunks: RAGDocumentChunk[]) {\n const response = await fetchImpl(`${basePath}/ingest`, {\n body: JSON.stringify({ chunks }),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGIngestResponse>(response);\n },\n async ingestDocuments(input: RAGDocumentIngestInput) {\n const response = await fetchImpl(`${basePath}/ingest`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGIngestResponse>(response);\n },\n async ingestUploads(input: RAGDocumentUploadIngestInput) {\n const response = await fetchImpl(`${basePath}/ingest`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGIngestResponse>(response);\n },\n async ingestUrls(input: RAGDocumentUrlIngestInput) {\n const response = await fetchImpl(`${basePath}/ingest`, {\n body: JSON.stringify(input),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGIngestResponse>(response);\n },\n async analyzeBackend() {\n const response = await fetchImpl(`${basePath}/backend/analyze`, {\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async ops() {\n const response = await fetchImpl(`${basePath}/ops`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGOperationsResponse>(response);\n },\n async searchTraceHistory(input?: {\n query?: string;\n groupKey?: string;\n tag?: string;\n limit?: number;\n }) {\n const searchParams = new URLSearchParams();\n if (input?.query) {\n searchParams.set(\"query\", input.query);\n }\n if (input?.groupKey) {\n searchParams.set(\"groupKey\", input.groupKey);\n }\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(`${basePath}/traces${suffix}`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGSearchTraceHistoryResponse>(response);\n if (!payload.ok || !payload.history) {\n throw new Error(payload.error ?? \"RAG search trace history failed\");\n }\n\n return payload.history;\n },\n async searchTraceGroups(input?: { tag?: string; limit?: number }) {\n const searchParams = new URLSearchParams();\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(`${basePath}/traces/groups${suffix}`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGSearchTraceGroupHistoryResponse>(response);\n if (!payload.ok || !payload.history) {\n throw new Error(\n payload.error ?? \"RAG search trace group history failed\",\n );\n }\n\n return payload.history;\n },\n async searchTraceStats(input?: { tag?: string }) {\n const searchParams = new URLSearchParams();\n if (input?.tag) {\n searchParams.set(\"tag\", input.tag);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(`${basePath}/traces/stats${suffix}`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGSearchTraceStatsResponse>(response);\n if (!payload.ok || !payload.stats) {\n throw new Error(payload.error ?? \"RAG search trace stats failed\");\n }\n\n return payload.stats;\n },\n async previewSearchTracePrune(input?: {\n maxAgeMs?: number;\n maxRecordsPerQuery?: number;\n maxRecordsPerGroup?: number;\n now?: number;\n tag?: string;\n }) {\n const response = await fetchImpl(`${basePath}/traces/prune/preview`, {\n body: JSON.stringify(input ?? {}),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGSearchTracePrunePreviewResponse>(response);\n if (!payload.ok || !payload.preview) {\n throw new Error(\n payload.error ?? \"RAG search trace prune preview failed\",\n );\n }\n\n return payload.preview;\n },\n async pruneSearchTraces(input?: {\n maxAgeMs?: number;\n maxRecordsPerQuery?: number;\n maxRecordsPerGroup?: number;\n now?: number;\n tag?: string;\n }) {\n const response = await fetchImpl(`${basePath}/traces/prune`, {\n body: JSON.stringify(input ?? {}),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload = await parseJson<RAGSearchTracePruneResponse>(response);\n if (!payload.ok || !payload.result) {\n throw new Error(payload.error ?? \"RAG search trace prune failed\");\n }\n\n return payload;\n },\n async searchTracePruneHistory(input?: {\n limit?: number;\n trigger?: \"manual\" | \"write\" | \"schedule\";\n }) {\n const searchParams = new URLSearchParams();\n if (typeof input?.limit === \"number\") {\n searchParams.set(\"limit\", String(input.limit));\n }\n if (input?.trigger) {\n searchParams.set(\"trigger\", input.trigger);\n }\n const suffix = searchParams.size > 0 ? `?${searchParams}` : \"\";\n const response = await fetchImpl(\n `${basePath}/traces/prune/history${suffix}`,\n );\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGSearchTracePruneHistoryResponse>(response);\n if (!payload.ok || !payload.runs) {\n throw new Error(\n payload.error ?? \"RAG search trace prune history failed\",\n );\n }\n\n return payload.runs;\n },\n async syncSources() {\n const response = await fetchImpl(`${basePath}/sync`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGSyncResponse>(response);\n },\n async syncAllSources(options?: RAGSyncRunOptions) {\n const response = await fetchImpl(`${basePath}/sync`, {\n body:\n options?.background === true\n ? JSON.stringify({ background: true })\n : undefined,\n headers: options?.background === true ? jsonHeaders : undefined,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n } satisfies RAGSyncResponse;\n }\n\n return parseJson<RAGSyncResponse>(response);\n },\n async syncSource(id: string, options?: RAGSyncRunOptions) {\n const response = await fetchImpl(\n `${basePath}/sync/${encodeURIComponent(id)}`,\n {\n body:\n options?.background === true\n ? JSON.stringify({ background: true })\n : undefined,\n headers: options?.background === true ? jsonHeaders : undefined,\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n } satisfies RAGSyncResponse;\n }\n\n return parseJson<RAGSyncResponse>(response);\n },\n async reindexDocument(id: string) {\n const response = await fetchImpl(\n `${basePath}/reindex/documents/${encodeURIComponent(id)}`,\n {\n method: \"POST\",\n },\n );\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async reindexSource(source: string) {\n const response = await fetchImpl(`${basePath}/reindex/source`, {\n body: JSON.stringify({ source }),\n headers: jsonHeaders,\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async reseed() {\n const response = await fetchImpl(`${basePath}/reseed`, {\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async reset() {\n const response = await fetchImpl(`${basePath}/reset`, {\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n async rebuildNativeIndex() {\n const response = await fetchImpl(`${basePath}/backend/reindex-native`, {\n method: \"POST\",\n });\n\n if (!response.ok) {\n return {\n error: await toErrorMessage(response),\n ok: false,\n };\n }\n\n return parseJson<RAGMutationResponse>(response);\n },\n search,\n async searchWithTrace(input: RAGSearchRequest) {\n return search({ ...input, includeTrace: true });\n },\n /**\n * @deprecated Use `searchWithTrace` for trace-aware search responses.\n */\n async searchDetailed(input: RAGSearchRequest) {\n return search({ ...input, includeTrace: true });\n },\n async status() {\n const response = await fetchImpl(`${basePath}/status`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGStatusResponse>(response);\n },\n async statusMaintenance() {\n const response = await fetchImpl(`${basePath}/status/maintenance`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGStatusResponse>(response);\n },\n async retrievalReleaseStatus() {\n const response = await fetchImpl(`${basePath}/status/release`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n const payload =\n await parseJson<RAGRetrievalReleaseStatusResponse>(response);\n return payload.retrievalComparisons;\n },\n async retrievalReleaseDriftStatus() {\n const response = await fetchImpl(`${basePath}/status/release/drift`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalReleaseDriftStatusResponse>(response);\n },\n async retrievalLaneHandoffStatus() {\n const response = await fetchImpl(`${basePath}/status/handoffs`);\n\n if (!response.ok) {\n throw new Error(await toErrorMessage(response));\n }\n\n return parseJson<RAGRetrievalLaneHandoffStatusResponse>(response);\n },\n };\n};\n\nexport type RAGClient = ReturnType<typeof createRAGClient>;\n"
13
13
  ],
14
- "mappings": "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",
14
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qBAAS,yBAAU;;;ACAnB;;;ACWA,IAAM,mBAAmB,CAAC,UACxB,OAAO,UAAU,YAAY,MAAM,KAAK,EAAE,SAAS,IAC/C,MAAM,KAAK,IACX;AAEN,IAAM,mBAAmB,CAAC,UACxB,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAAI,QAAQ;AAEhE,IAAM,oBAAoB,CAAC,QAAiB,UAAmB;AAAA,EAC7D,MAAM,mBAAmB,QAAQ,MAAM,GAAG,EAAE,GAAG,EAAE;AAAA,EACjD,IAAI,oBAAoB,iBAAiB,SAAS,GAAG,GAAG;AAAA,IACtD,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,kBAAkB,OAAO,MAAM,KAAI,EAAE,GAAG,EAAE;AAAA,EAChD,IAAI,mBAAmB,gBAAgB,SAAS,GAAG,GAAG;AAAA,IACpD,OAAO;AAAA,EACT;AAAA,EAEA;AAAA;AAGF,IAAM,oBAAoB,CAAC,aAAuC;AAAA,EAChE,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,YAAY,iBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,uBAAuB,iBAAiB,SAAS,eAAe;AAAA,EACtE,MAAM,kBACJ,yBAAyB,WACzB,yBAAyB,UACzB,yBAAyB,cACrB,uBACA;AAAA,EACN,IAAI,cAAc,cAAc;AAAA,IAC9B,OAAO;AAAA,EACT;AAAA,EAEA,IAAI,cAAc,WAAW;AAAA,IAC3B,MAAM,OAAO,iBAAiB,SAAS,IAAI;AAAA,IAC3C,OAAO,OAAO,gBAAgB,SAAS;AAAA,EACzC;AAAA,EAEA,MAAM,OACJ,iBAAiB,SAAS,IAAI,KAC9B,iBAAiB,SAAS,UAAU,MACnC,OAAO,SAAS,cAAc,WAC3B,SAAS,YAAY,IACrB;AAAA,EACN,MAAM,SACJ,iBAAiB,SAAS,YAAY,MACrC,OAAO,SAAS,gBAAgB,WAC7B,SAAS,cAAc,IACvB;AAAA,EACN,IAAI,QAAQ,QAAQ;AAAA,IAClB,OAAO,QAAQ,eAAe;AAAA,EAChC;AAAA,EACA,IAAI,MAAM;AAAA,IACR,OAAO,QAAQ;AAAA,EACjB;AAAA,EAEA,MAAM,QACJ,iBAAiB,SAAS,SAAS,MAClC,MAAM,QAAQ,SAAS,UAAU,IAC9B,iBAAiB,SAAS,WAAW,EAAE,IACvC;AAAA,EACN,IAAI,OAAO;AAAA,IACT,OAAO,SAAS;AAAA,EAClB;AAAA,EAEA,MAAM,QACJ,iBAAiB,SAAS,KAAK,KAC/B,iBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAC5B,SAAS,aAAa,IACtB;AAAA,EACN,MAAM,aAAa,iBAAiB,SAAS,UAAU;AAAA,EACvD,IAAI,OAAO;AAAA,IACT,OAAO,aAAa,SAAS,WAAU,eAAe,SAAS;AAAA,EACjE;AAAA,EAEA,MAAM,eACJ,iBAAiB,SAAS,gBAAgB,KAC1C,iBAAiB,SAAS,SAAS;AAAA,EACrC,IAAI,cAAc;AAAA,IAChB,OAAO,iBAAiB;AAAA,EAC1B;AAAA,EAEA,MAAM,cAAc,iBAAiB,SAAS,WAAW;AAAA,EACzD,IAAI,aAAa;AAAA,IACf,OAAO,UAAU;AAAA,EACnB;AAAA,EAEA,MAAM,UAAU,iBAAiB,SAAS,OAAO;AAAA,EACjD,IAAI,SAAS;AAAA,IACX,OAAO,WAAW;AAAA,EACpB;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,eACJ,iBAAiB,SAAS,YAAY,KAAK,YAAY,GAAG,EAAE;AAAA,EAC9D,MAAM,qBACJ,YAAY,SAAS,IAAI,YAAY,KAAK,KAAK,IAAI;AAAA,EACrD,IAAI,oBAAoB,WAAW,oBAAoB;AAAA,IACrD,OAAO,sBAAsB;AAAA,EAC/B;AAAA,EACA,IAAI,oBAAoB,UAAU,oBAAoB;AAAA,IACpD,OAAO,qBAAqB;AAAA,EAC9B;AAAA,EACA,IAAI,oBAAoB,eAAe,oBAAoB;AAAA,IACzD,OAAO,0BAA0B;AAAA,EACnC;AAAA,EACA,IAAI,cAAc;AAAA,IAChB,OAAO,WAAW;AAAA,EACpB;AAAA,EAEA;AAAA;AAGF,IAAM,uBAAuB,CAAC,UAAmB;AAAA,EAC/C,IAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GAAG;AAAA,IACrE;AAAA,EACF;AAAA,EAEA,MAAM,eAAe,KAAK,MAAM,QAAQ,IAAI;AAAA,EAC5C,MAAM,UAAU,KAAK,MAAM,eAAe,EAAE;AAAA,EAC5C,MAAM,UAAU,eAAe;AAAA,EAC/B,MAAM,eAAe,KAAK,MAAM,QAAQ,IAAI;AAAA,EAE5C,OAAO,GAAG,OAAO,OAAO,EAAE,SAAS,GAAG,GAAG,KAAK,OAAO,OAAO,EAAE,SAC5D,GACA,GACF,KAAK,OAAO,YAAY,EAAE,SAAS,GAAG,GAAG;AAAA;AAG3C,IAAM,2BAA2B,CAAC,UAAmB;AAAA,EACnD,IAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GAAG;AAAA,IACrE;AAAA,EACF;AAAA,EAEA,OAAO,qBAAqB,KAAK;AAAA;AAGnC,IAAM,8BAA8B,CAAC,UAAmB;AAAA,EACtD,IAAI,CAAC,MAAM,QAAQ,KAAK,KAAK,MAAM,WAAW,GAAG;AAAA,IAC/C;AAAA,EACF;AAAA,EAEA,MAAM,SAAS,MACZ,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,EAC5D,KAAK,CAAC,MAAM,UAAU,OAAO,KAAK;AAAA,EAErC,IAAI,OAAO,WAAW,GAAG;AAAA,IACvB;AAAA,EACF;AAAA,EAEA,MAAM,WAAW,OAAO;AAAA,EACxB,MAAM,WAAW,OAAO,OAAO,SAAS;AAAA,EAExC,OAAO,aAAa,WAChB,qBAAqB,aACrB,sBAAsB,YAAY;AAAA;AAuBxC,IAAM,8BAA8B,CAClC,aACoC;AAAA,EACpC,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,uBAAuB,iBAAiB,SAAS,eAAe;AAAA,EACtE,MAAM,kBACJ,yBAAyB,WACzB,yBAAyB,UACzB,yBAAyB,cACrB,uBACA;AAAA,EACN,IACE,oBAAoB,WACpB,oBAAoB,UACpB,oBAAoB,aACpB;AAAA,IACA;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,eACJ,iBAAiB,SAAS,YAAY,KAAK,YAAY,GAAG,EAAE;AAAA,EAC9D,MAAM,oBACJ,oBAAoB,UAChB,iBAAiB,SAAS,sBAAsB,IAChD,oBAAoB,SAClB,iBAAiB,SAAS,qBAAqB,IAC/C;AAAA,EAER,IAAI,CAAC,cAAc;AAAA,IACjB;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL,WAAW;AAAA,IACX,aAAa,MAAM;AAAA,MACjB,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,MAAM,6BAA6B,MAAM,QACvC,SAAS,kBACX,IACI,SAAS,mBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,IACE,0BAA0B,SAAS,KACnC,0BAA0B,WAAW,2BAA2B,QAChE;AAAA,QACA,OAAO;AAAA,MACT;AAAA,MAEA,MAAM,2BAA2B,MAAM,QAAQ,SAAS,gBAAgB,IACpE,SAAS,iBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,OAAO,yBAAyB,SAAS,IACrC,2BACA,YAAY,IAAI,CAAC,UAAU,MAAM,QAAQ,iBAAiB,EAAE,EAAE,KAAK,CAAC;AAAA,OACvE;AAAA,IACH,WAAW,YAAY;AAAA,IACvB,cAAc,MAAM;AAAA,MAClB,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,MAAM,6BAA6B,MAAM,QACvC,SAAS,kBACX,IACI,SAAS,mBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,IACE,0BAA0B,SAAS,KACnC,0BAA0B,WAAW,2BAA2B,QAChE;AAAA,QACA,OAAO;AAAA,MACT;AAAA,MAEA,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UACJ,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAC9C,QACA,SACN,EACC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,OAAO,0BAA0B,SAAS,IACtC,4BACA,YAAY,IAAI,CAAC,UAAU;AAAA,QACzB,MAAM,QAAQ,MAAM,MAAM,YAAY;AAAA,QACtC,OAAO,QAAQ,OAAO,SAAS,MAAM,MAAM,KAAK,EAAE,IAAI;AAAA,OACvD;AAAA,OACJ;AAAA,IACH,kBACE,iBAAiB,SAAS,uBAAuB,KACjD,iBAAiB,SAAS,sBAAsB,KAChD,YACG,GAAG,EAAE,GACJ,QAAQ,iBAAiB,EAAE,EAC5B,KAAK,KACR;AAAA,IACF,gBACE,iBAAiB,SAAS,qBAAqB,KAC/C,iBAAiB,SAAS,oBAAoB,MAC7C,MAAM;AAAA,MACL,MAAM,QAAQ,aAAa,MAAM,YAAY;AAAA,MAC7C,OAAO,QAAQ,OAAO,SAAS,MAAM,MAAM,KAAK,EAAE,IAAI;AAAA,OACrD;AAAA,IACL;AAAA,IACA,YAAY,OAAO,sBAAsB;AAAA,EAC3C;AAAA;AAGF,IAAM,oCAAoC,CACxC,MAYA,UAYG;AAAA,EACH,IAAI,CAAC,QAAQ,CAAC,OAAO;AAAA,IACnB,OAAO;AAAA,EACT;AAAA,EACA,IACE,KAAK,cAAc,MAAM,aACzB,KAAK,qBAAqB,MAAM,oBAChC,KAAK,mBAAmB,MAAM,gBAC9B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,MAAM,yBAAyB,KAAK,WAAW,MAAM,GAAG,EAAE;AAAA,EAC1D,MAAM,0BAA0B,MAAM,WAAW,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,0BAA0B,KAAK,YAAY,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,2BAA2B,MAAM,YAAY,MAAM,GAAG,EAAE;AAAA,EAC9D,MAAM,cAAc,KAAK,IACvB,uBAAuB,QACvB,wBAAwB,MAC1B;AAAA,EACA,SAAS,QAAQ,EAAG,QAAQ,aAAa,SAAS,GAAG;AAAA,IACnD,IACE,uBAAuB,WAAW,wBAAwB,UAC1D,wBAAwB,WAAW,yBAAyB,QAC5D;AAAA,MACA,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EACA,OAAO;AAAA;AAGT,IAAM,oCAAoC,CACxC,aAC+C;AAAA,EAC/C,IAAI,CAAC,YAAY,SAAS,mBAAmB,SAAS,YAAY;AAAA,IAChE;AAAA,EACF;AAAA,EAEA,MAAM,OACJ,SAAS,gBAAgB,sBACzB,SAAS,gBAAgB,uBACrB,SAAS,cACT;AAAA,EACN,IAAI,CAAC,MAAM;AAAA,IACT;AAAA,EACF;AAAA,EAEA,MAAM,qBAAqB,MAAM,QAAQ,SAAS,iBAAiB,IAC/D,SAAS,kBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,sBAAsB,MAAM,QAAQ,SAAS,kBAAkB,IACjE,SAAS,mBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,IAAI,aACF,mBAAmB,SAAS,KAC5B,mBAAmB,WAAW,oBAAoB,SAC9C,qBACA,CAAC;AAAA,EACP,IAAI,cACF,mBAAmB,SAAS,KAC5B,mBAAmB,WAAW,oBAAoB,SAC9C,sBACA,CAAC;AAAA,EAEP,IAAI,WAAW,WAAW,GAAG;AAAA,IAC3B,IAAI,SAAS,oBAAoB;AAAA,MAC/B,MAAM,YAAY,iBAAiB,SAAS,SAAS,KAAK;AAAA,MAC1D,MAAM,aAAa,iBAAiB,SAAS,qBAAqB,KAAK;AAAA,MACvE,aAAa,CAAC,WAAW,mBAAmB;AAAA,MAC5C,cAAc,CAAC,GAAG,UAAU;AAAA,IAC9B,EAAO;AAAA,MACL,MAAM,cAAc,iBAAiB,SAAS,UAAU,KAAK;AAAA,MAC7D,MAAM,eACJ,iBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAAW,SAAS,aAAa,IAAI;AAAA,MACvE,aAAa,CAAC,WAAW;AAAA,MACzB,cAAc,CAAC,YAAY;AAAA;AAAA,EAE/B;AAAA,EAEA,MAAM,mBACJ,iBAAiB,SAAS,uBAAuB,KAAK,WAAW,GAAG,EAAE;AAAA,EACxE,MAAM,iBACJ,iBAAiB,SAAS,qBAAqB,KAAK,YAAY,GAAG,EAAE;AAAA,EACvE,IAAI,CAAC,oBAAoB,OAAO,mBAAmB,UAAU;AAAA,IAC3D;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW,WAAW;AAAA,IACtB;AAAA,IACA;AAAA,EACF;AAAA;AAGF,IAAM,+CAA+C,CACnD,MACA,UACG;AAAA,EACH,IAAI,CAAC,QAAQ,CAAC,OAAO;AAAA,IACnB,OAAO;AAAA,EACT;AAAA,EACA,IACE,KAAK,SAAS,MAAM,QACpB,KAAK,qBAAqB,MAAM,oBAChC,KAAK,mBAAmB,MAAM,gBAC9B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,MAAM,yBAAyB,KAAK,WAAW,MAAM,GAAG,EAAE;AAAA,EAC1D,MAAM,0BAA0B,MAAM,WAAW,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,0BAA0B,KAAK,YAAY,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,2BAA2B,MAAM,YAAY,MAAM,GAAG,EAAE;AAAA,EAC9D,MAAM,cAAc,KAAK,IACvB,uBAAuB,QACvB,wBAAwB,MAC1B;AAAA,EACA,SAAS,QAAQ,EAAG,QAAQ,aAAa,SAAS,GAAG;AAAA,IACnD,IACE,uBAAuB,WAAW,wBAAwB,UAC1D,wBAAwB,WAAW,yBAAyB,QAC5D;AAAA,MACA,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EACA,OAAO;AAAA;AAGT,IAAM,mCAAmC,CACvC,aACG;AAAA,EACH,MAAM,QAAQ,4BAA4B,QAAQ;AAAA,EAClD,IAAI,CAAC,OAAO;AAAA,IACV,OAAO;AAAA,EACT;AAAA,EAEA,OACE,MAAM,YAAY,MACjB,MAAM,aAAa,IAAI,MACvB,MAAM,cAAc,UACrB,OAAO,UAAU,6BAA6B,YAC9C,SAAS,2BAA2B,IAChC,IACA;AAAA;AAIR,IAAM,yCAAyC,CAC7C,aACG;AAAA,EACH,MAAM,QAAQ,kCAAkC,QAAQ;AAAA,EACxD,IAAI,CAAC,OAAO;AAAA,IACV,OAAO;AAAA,EACT;AAAA,EAEA,OACE,MAAM,YAAY,MACjB,MAAM,SAAS,sBAChB,OAAO,UAAU,0BAA0B,WACvC,IACA,MACH,MAAM,QAAQ,UAAU,kBAAkB,KAC3C,SAAS,mBAAmB,SAAS,IACjC,IACA,MACH,OAAO,UAAU,mBAAmB,YACrC,SAAS,eAAe,KAAK,EAAE,SAAS,IACpC,IACA;AAAA;AAIR,IAAM,oBAAoB,CACxB,UACA,QACA,UACG;AAAA,EACH,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,OACJ,iBAAiB,SAAS,IAAI,KAC9B,iBAAiB,SAAS,UAAU,MACnC,OAAO,SAAS,cAAc,WAC3B,SAAS,YAAY,IACrB;AAAA,EACN,MAAM,SACJ,iBAAiB,SAAS,YAAY,MACrC,OAAO,SAAS,gBAAgB,WAC7B,SAAS,cAAc,IACvB;AAAA,EACN,IAAI,QAAQ,QAAQ;AAAA,IAClB,OAAO,QAAQ,iBAAgB;AAAA,EACjC;AAAA,EACA,IAAI,MAAM;AAAA,IACR,OAAO,QAAQ;AAAA,EACjB;AAAA,EAEA,MAAM,QACJ,iBAAiB,SAAS,SAAS,MAClC,MAAM,QAAQ,SAAS,UAAU,IAC9B,iBAAiB,SAAS,WAAW,EAAE,IACvC;AAAA,EACN,IAAI,OAAO;AAAA,IACT,OAAO,SAAS;AAAA,EAClB;AAAA,EAEA,MAAM,QACJ,iBAAiB,SAAS,KAAK,KAC/B,iBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAC5B,SAAS,aAAa,IACtB;AAAA,EACN,MAAM,aAAa,iBAAiB,SAAS,UAAU;AAAA,EACvD,IAAI,OAAO;AAAA,IACT,OAAO,aAAa,SAAS,WAAU,eAAe,SAAS;AAAA,EACjE;AAAA,EAEA,MAAM,eACJ,iBAAiB,SAAS,gBAAgB,KAC1C,iBAAiB,SAAS,SAAS;AAAA,EACrC,IAAI,cAAc;AAAA,IAChB,OAAO,iBAAiB;AAAA,EAC1B;AAAA,EAEA,MAAM,YAAY,iBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,kBAAkB,iBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,oBAAoB,iBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,0BAA0B,iBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,wBAAwB,iBAC5B,SAAS,qBACX;AAAA,EACA,IAAI,cAAc,cAAc;AAAA,IAC9B,MAAM,iBACJ,iBAAiB,SAAS,cAAc,KACxC,kBAAkB,QAAQ,KAAK;AAAA,IACjC,OAAO,iBAAiB,cAAc,mBAAmB;AAAA,EAC3D;AAAA,EAEA,MAAM,aAAa,qBAAqB,SAAS,OAAO;AAAA,EACxD,MAAM,WAAW,qBAAqB,SAAS,KAAK;AAAA,EACpD,IAAI,cAAc,UAAU;AAAA,IAC1B,OAAO,aAAa,gBAAgB;AAAA,EACtC;AAAA,EAEA,IAAI,YAAY;AAAA,IACd,OAAO,aAAa;AAAA,EACtB;AAAA,EAEA,IAAI,qBAAqB,oBAAoB,SAAS;AAAA,IACpD,IACE,OAAO,4BAA4B,YACnC,OAAO,0BAA0B,UACjC;AAAA,MACA,OAAO,4BAA4B,wBAC/B,sBAAsB,2BAA0B,4BAChD,sBAAsB,4BAA2B,2BAA2B;AAAA,IAClF;AAAA,IACA,OAAO,sBAAsB;AAAA,EAC/B;AAAA,EACA,IAAI,qBAAqB,oBAAoB,QAAQ;AAAA,IACnD,OAAO,qBAAqB;AAAA,EAC9B;AAAA,EACA,IAAI,qBAAqB,oBAAoB,aAAa;AAAA,IACxD,OAAO,0BAA0B;AAAA,EACnC;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,IAAI,YAAY,SAAS,GAAG;AAAA,IAC1B,OAAO,WAAW,YAAY,KAAK,KAAK;AAAA,EAC1C;AAAA,EAEA;AAAA;AAGF,IAAM,uBAAuB,CAAC,UAAmB;AAAA,EAC/C,MAAM,YACJ,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAC9C,QACA,OAAO,UAAU,WACf,KAAK,MAAM,KAAK,IAChB,OAAO;AAAA,EACf,IAAI,CAAC,OAAO,SAAS,SAAS,GAAG;AAAA,IAC/B;AAAA,EACF;AAAA,EAEA,OAAO,IAAI,KAAK,SAAS,EAAE,eAAe,SAAS;AAAA,IACjD,WAAW;AAAA,IACX,WAAW;AAAA,EACb,CAAC;AAAA;AAGH,IAAM,uBAAuB,CAAC,aAAuC;AAAA,EACnE,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,iBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,OAAO,iBAAiB,SAAS,IAAI;AAAA,EAC3C,MAAM,SACJ,qBAAqB,SAAS,MAAM,KACpC,qBAAqB,SAAS,UAAU;AAAA,EAC1C,MAAM,UAAU,iBAAiB,SAAS,OAAO;AAAA,EACjD,MAAM,YAAY,iBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,oBAAoB,iBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,wBAAwB,iBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,yBAAyB,iBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,eAAe,iBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,oBAAoB,iBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,qBAAqB,yBAAyB,SAAS,eAAe;AAAA,EAC5E,MAAM,mBAAmB,iBAAiB,SAAS,gBAAgB;AAAA,EACnE,MAAM,cAAc,iBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,iBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,wBAAwB,iBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,2BAA2B,iBAC/B,SAAS,wBACX;AAAA,EACA,MAAM,wBAAwB,4BAC5B,SAAS,gBACX;AAAA,EACA,MAAM,qBAAqB,MAAM,QAAQ,SAAS,kBAAkB,IAChE,SAAS,mBACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,yBAAyB,iBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,0BAA0B,iBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,0BAA0B,iBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,wBAAwB,iBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,yBAAyB,iBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,0BAA0B,iBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,iBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,YAAY,iBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,gBACJ,iBAAiB,SAAS,mBAAmB,KAC7C,iBAAiB,SAAS,aAAa;AAAA,EAEzC,MAAM,SAAS;AAAA,IACb,cAAc,OAAO,gBAAgB;AAAA,IACrC,kBAAkB,UAAU,oBAAoB;AAAA,IAChD,OAAO,6BAA6B,WAChC,eAAe,mCACf;AAAA,IACJ,yBAAyB;AAAA,IACzB,YAAY,SAAS,KAAK,kBACtB,uBAAuB,yBAAyB,YAAY,KAAK,KAAK,MACtE;AAAA,IACJ,wBAAwB,uBAAuB,0BAA0B;AAAA,IACzE,mBAAmB,SAAS,IACxB,gBAAgB,mBAAmB,KAAK,IAAI,MAC5C;AAAA,IACJ,OAAO,2BAA2B,WAC9B,gBAAgB,gCAChB;AAAA,IACJ,OAAO,4BAA4B,WAC/B,gBAAgB,sCAChB;AAAA,IACJ,OAAO,4BAA4B,YACnC,OAAO,0BAA0B,WAC7B,4BAA4B,wBAC1B,oBAAoB,4BACpB,qBAAqB,2BAA2B,0BAClD;AAAA,IACJ,yBACI,wBAAwB,2BACxB;AAAA,IACJ,0BACI,0BAA0B,4BAC1B;AAAA,IACJ,YAAY,OAAO,cAAc;AAAA,IACjC,OAAO,kBAAkB,WACrB,cAAc,cAAc,QAAQ,CAAC,MACrC;AAAA,IACJ,YAAY,SAAS,cAAc;AAAA,IACnC,oBAAoB,GAAG,+BAA+B;AAAA,IACtD,wBAAwB,GAAG,2CAA2C;AAAA,IACtE,2BAA2B,YACvB,iBAAiB,yBAAyB,MAC1C;AAAA,IACJ,eAAe,WAAW,iBAAiB;AAAA,IAC3C,oBAAoB,GAAG,+BAA+B;AAAA,IACtD,qBAAqB,YAAY,uBAAuB;AAAA,IACxD,mBAAmB,cAAc,qBAAqB;AAAA,IACtD,cAAc,UAAU,gBAAgB;AAAA,IACxC,UAAU,WAAW,YAAY;AAAA,IACjC,OAAO,UAAU,SAAS;AAAA,IAC1B,SAAS,QAAQ,WAAW;AAAA,EAC9B,EAAE,OAAO,CAAC,UAAU,MAAM,SAAS,CAAC;AAAA,EAEpC,OAAO,OAAO,SAAS,IAAI,OAAO,KAAK,KAAI,IAAI;AAAA;AAGjD,IAAM,mBAAmB,CAAC,WACxB,OAAO,UAAU,OAAO,SAAS,OAAO;AAE1C,IAAM,eAAe,CAAC,MAAc,YAAY,QAAQ;AAAA,EACtD,MAAM,aAAa,KAAK,WAAW,QAAQ,GAAG,EAAE,KAAK;AAAA,EACrD,IAAI,WAAW,UAAU,WAAW;AAAA,IAClC,OAAO;AAAA,EACT;AAAA,EAEA,OAAO,GAAG,WAAW,MAAM,GAAG,KAAK,IAAI,GAAG,YAAY,CAAC,CAAC,EAAE,QAAQ;AAAA;AAGpE,IAAM,yBAAyB,CAC7B,UAKA,sBACG;AAAA,EACH,IAAI,CAAC,UAAU;AAAA,IACb,OAAO;AAAA,MACL,SAAS;AAAA,MACT,MAAM;AAAA,MACN,QAAQ;AAAA,IACV;AAAA,EACF;AAAA,EAEA,MAAM,eAAe,SAAS,cAAc,KAAK,KAAK;AAAA,EACtD,MAAM,gBAAgB,SAAS,eAAe,KAAK,KAAK;AAAA,EACxD,MAAM,iBAAiB,SAAS,gBAAgB,KAAK,KAAK;AAAA,EAC1D,IACE,qBACA,oBAAoB,KACpB,aAAa,SAAS,KACtB,aAAa,SAAS,IACtB;AAAA,IACA,IAAI,qBAAqB,KAAK,gBAAgB;AAAA,MAC5C,OAAO;AAAA,QACL,SAAS;AAAA,QACT,MAAM;AAAA,QACN,QAAQ;AAAA,MACV;AAAA,IACF;AAAA,IACA,IAAI,eAAe;AAAA,MACjB,OAAO;AAAA,QACL,SAAS;AAAA,QACT,MAAM;AAAA,QACN,QAAQ;AAAA,MACV;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,MACL,SAAS;AAAA,MACT,MAAM;AAAA,MACN,QAAQ;AAAA,IACV;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL,SAAS,gBAAgB,iBAAiB;AAAA,IAC1C,MAAM;AAAA,IACN,SACG,qBAAqB,KAAK,IACtB,qBACA;AAAA,EACT;AAAA;AAGF,IAAM,yBAAyB,CAC7B,eAIA,WAAW,OACT,CAAC,QAAQ,cAAc;AAAA,EACrB,IAAI,WAAW,kBAAkB;AAAA,IAC/B,OAAO,UAAU,iBAAiB,SAAS;AAAA,EAC7C;AAAA,EACA,OAAO;AAAA,GAET,EAAE,OAAO,GAAG,SAAS,GAAG,QAAQ,EAAE,CACpC;AAEF,IAAM,8BAA8B,CAClC,SACA,kBACG;AAAA,EACH,IAAI,QAAQ,WAAW,GAAG;AAAA,IACxB;AAAA,EACF;AAAA,EAEA,MAAM,gBACH,gBACG,QAAQ,KAAK,CAAC,WAAW,OAAO,YAAY,aAAa,IACzD,cAAc,QAAQ;AAAA,EAC5B,IAAI,CAAC,cAAc;AAAA,IACjB;AAAA,EACF;AAAA,EAEA,MAAM,WAAW,IAAI,IAAI,QAAQ,IAAI,CAAC,WAAW,CAAC,OAAO,SAAS,MAAM,CAAC,CAAC;AAAA,EAC1E,MAAM,iBAAiB,aAAa,YAAY,CAAC;AAAA,EACjD,MAAM,kBAAkB,iBAAiB,eAAe,eAAe;AAAA,EACvE,MAAM,cAAc,iBAAiB,eAAe,WAAW;AAAA,EAC/D,MAAM,iBAAiB,iBAAiB,eAAe,cAAc;AAAA,EACrE,MAAM,iBAAiB,iBACnB,QACG,OACC,CAAC,WACC,iBAAiB,OAAO,UAAU,cAAc,MAChD,cACJ,EACC,KAAK,CAAC,MAAM,UAAU;AAAA,IACrB,MAAM,YACJ,iBAAiB,KAAK,UAAU,iBAAiB,KACjD,OAAO;AAAA,IACT,MAAM,aACJ,iBAAiB,MAAM,UAAU,iBAAiB,KAClD,OAAO;AAAA,IACT,IAAI,cAAc,YAAY;AAAA,MAC5B,OAAO,YAAY;AAAA,IACrB;AAAA,IACA,OAAO,KAAK,QAAQ,cAAc,MAAM,OAAO;AAAA,GAChD,IACH,CAAC,YAAY;AAAA,EACjB,MAAM,cAAc,CAAC,aACnB,SACG,IAAI,CAAC,YAAY,SAAS,IAAI,OAAO,GAAG,IAAI,EAC5C,OAAO,CAAC,SAAyB,OAAO,SAAS,QAAQ,EACzD,KAAK;AAAA;AAAA,CAAM;AAAA,EAChB,MAAM,mBAAmB;AAAA,IACvB;AAAA,IACA,aAAa;AAAA,IACb;AAAA,EACF,EAAE,OACA,CAAC,SAAS,OAAO,WACf,QAAQ,OAAO,KAAK,OAAO,QAAQ,OAAO,MAAM,KACpD;AAAA,EAEA,OAAO;AAAA,IACL,cAAc,aAAa,aAAa,MAAM,GAAG;AAAA,IACjD,gBAAgB,aACd,eAAe,IAAI,CAAC,WAAW,OAAO,IAAI,EAAE,KAAK;AAAA;AAAA,CAAM,GACvD,GACF;AAAA,IACA,eAAe,aAAa,YAAY,gBAAgB,GAAG,GAAG;AAAA,EAChE;AAAA;AAGF,IAAM,uCAAuC,CAC3C,cAEA,CAAC,UAAU,OAAO,UAAU,cAAc,UAAU,YAAY,EAC7D,OAAO,CAAC,UAA2B,QAAQ,SAAS,MAAM,SAAS,CAAC,CAAC,EACrE,OACC,CAAC,OAAO,OAAO,WACb,OAAO,UAAU,CAAC,UAAU,UAAU,KAAK,MAAM,KACrD,EACC,KAAK,KAAI;AAEd,IAAM,yCAAyC,CAC7C,cAEA;AAAA,EACE,UAAU,UAAU,UAAU,SAAS,UAAU;AAAA,EACjD,UAAU;AAAA,EACV,UAAU;AAAA,EACV,UAAU;AACZ,EACG,OAAO,CAAC,UAA2B,QAAQ,SAAS,MAAM,SAAS,CAAC,CAAC,EACrE,OACC,CAAC,OAAO,OAAO,WACb,OAAO,UAAU,CAAC,UAAU,UAAU,KAAK,MAAM,KACrD,EACC,KAAK,KAAI;AAEd,IAAM,2BAA2B,CAAC,cAChC,UAAU,gBACV,UAAU,gBACV,UAAU,SACV,UAAU,UACV,UAAU;AAEZ,IAAM,mCAAmC,CAAC,cACxC;AAAA,EACE,UAAU,UAAU,UAAU,SAAS,UAAU;AAAA,EACjD,UAAU;AAAA,EACV,UAAU;AAAA,EACV,UAAU;AACZ,EACG,OAAO,CAAC,UAA2B,QAAQ,SAAS,MAAM,SAAS,CAAC,CAAC,EACrE,OACC,CAAC,OAAO,OAAO,WACb,OAAO,UAAU,CAAC,UAAU,UAAU,KAAK,MAAM,KACrD,EACC,KAAK,KAAI;AAEd,IAAM,oCAAoC,CACxC,eACqC;AAAA,EACrC,cAAc,UAAU;AAAA,EACxB,eAAe,qCAAqC,SAAS;AAAA,EAC7D,iBAAiB,uCAAuC,SAAS;AAAA,EACjE,SACE,uBACE,UAAU,UACV,iBAAiB,UAAU,UAAU,iBAAiB,CACxD,EAAE,WAAW,UAAU;AAAA,EACzB,UAAU,UAAU;AAAA,EACpB,kBAAkB,UAAU;AAAA,EAC5B,OAAO,UAAU;AAAA,EACjB,cAAc,UAAU;AAAA,EACxB,QAAQ,UAAU;AAAA,EAClB,iBAAiB,UAAU;AAAA,EAC3B,QAAQ,UAAU;AAAA,EAClB,OAAO,UAAU;AACnB;AAEO,IAAM,+BAA+B,CAC1C,cAEA,OAAO,YACL,UAAU,IAAI,CAAC,UAAU,UAAU,CAAC,SAAS,SAAS,QAAQ,CAAC,CAAC,CAClE;AAEK,IAAM,oBAAoB,CAAC,YAAyB;AAAA,EACzD,MAAM,SAAS,IAAI;AAAA,EAEnB,WAAW,UAAU,SAAS;AAAA,IAC5B,MAAM,MAAM,OAAO;AAAA,IACnB,MAAM,WAAW,OAAO,IAAI,GAAG;AAAA,IAC/B,MAAM,oBACJ,aAAa,aAAa,SAAS,SAAS,OAAO;AAAA,IACrD,IAAI;AAAA,MAAmB;AAAA,IACvB,MAAM,WAAW,4BAA4B,SAAS,OAAO,OAAO;AAAA,IACpE,MAAM,mBAAmB,uBACvB,UACA,iBAAiB,OAAO,UAAU,iBAAiB,CACrD;AAAA,IAEA,OAAO,IAAI,KAAK;AAAA,MACd,SAAS,OAAO;AAAA,MAChB,cACE,OAAO,QAAQ,gBAAgB,kBAAkB,OAAO,QAAQ;AAAA,MAClE,SAAS,iBAAiB,WAAW,aAAa,OAAO,IAAI;AAAA,MAC7D;AAAA,MACA;AAAA,MACA;AAAA,MACA,OAAO,iBAAiB,MAAM;AAAA,MAC9B,cACE,OAAO,QAAQ,gBACf,kBAAkB,OAAO,UAAU,OAAO,QAAQ,OAAO,KAAK;AAAA,MAChE,UAAU,OAAO;AAAA,MACjB,iBACE,OAAO,QAAQ,mBAAmB,qBAAqB,OAAO,QAAQ;AAAA,MACxE,OAAO,OAAO;AAAA,MACd,QAAQ,OAAO;AAAA,MACf,MAAM,OAAO;AAAA,MACb,OAAO,OAAO;AAAA,IAChB,CAAC;AAAA,EACH;AAAA,EAEA,OAAO,CAAC,GAAG,OAAO,OAAO,CAAC,EAAE,KAAK,CAAC,MAAM,UAAU;AAAA,IAChD,MAAM,kBAAkB,4BAA4B,KAAK,QAAQ;AAAA,IACjE,MAAM,mBAAmB,4BAA4B,MAAM,QAAQ;AAAA,IACnE,IACE,KAAK,WAAW,MAAM,UACtB,kCAAkC,iBAAiB,gBAAgB,GACnE;AAAA,MACA,MAAM,uBAAuB,iCAC3B,KAAK,QACP;AAAA,MACA,MAAM,wBAAwB,iCAC5B,MAAM,QACR;AAAA,MACA,IAAI,0BAA0B,sBAAsB;AAAA,QAClD,OAAO,wBAAwB;AAAA,MACjC;AAAA,IACF;AAAA,IACA,MAAM,mBAAmB,kCAAkC,KAAK,QAAQ;AAAA,IACxE,MAAM,oBAAoB,kCAAkC,MAAM,QAAQ;AAAA,IAC1E,IACE,KAAK,WAAW,MAAM,UACtB,6CACE,kBACA,iBACF,GACA;AAAA,MACA,MAAM,wBAAwB,uCAC5B,KAAK,QACP;AAAA,MACA,MAAM,yBAAyB,uCAC7B,MAAM,QACR;AAAA,MACA,IAAI,2BAA2B,uBAAuB;AAAA,QACpD,OAAO,yBAAyB;AAAA,MAClC;AAAA,IACF;AAAA,IACA,IAAI,MAAM,UAAU,KAAK,OAAO;AAAA,MAC9B,OAAO,MAAM,QAAQ,KAAK;AAAA,IAC5B;AAAA,IAEA,OAAO,KAAK,MAAM,cAAc,MAAM,KAAK;AAAA,GAC5C;AAAA;AAGI,IAAM,yBAAyB,CACpC,SACA,YACsB;AAAA,EACtB,MAAM,aAAa,4BAA4B,OAAO;AAAA,EACtD,MAAM,mBAAmB,uCAAuC,UAAU;AAAA,EAC1E,MAAM,eAAe,IAAI,IACvB,WAAW,IAAI,CAAC,cAAc,CAAC,UAAU,QAAQ,SAAS,CAAC,CAC7D;AAAA,EACA,MAAM,QAAoC,CAAC;AAAA,EAC3C,MAAM,6BAA6B,IAAI;AAAA,EACvC,MAAM,kBAAkB;AAAA,EACxB,IAAI,SAAS;AAAA,EAEb,WAAW,SAAS,QAAQ,SAAS,eAAe,GAAG;AAAA,IACrD,MAAM,MAAM,MAAM;AAAA,IAClB,MAAM,WAAW,MAAM,MAAM,IAC1B,MAAM,GAAG,EACT,IAAI,CAAC,UAAU,OAAO,SAAS,MAAM,KAAK,GAAG,EAAE,CAAC,EAChD,OAAO,CAAC,UAAU,OAAO,UAAU,KAAK,KAAK,QAAQ,CAAC;AAAA,IACzD,MAAM,QAAQ,MAAM,SAAS;AAAA,IAC7B,IAAI,QAAQ,QAAQ;AAAA,MAClB,MAAM,KAAK;AAAA,QACT,MAAM,QAAQ,MAAM,QAAQ,KAAK;AAAA,QACjC,MAAM;AAAA,MACR,CAAC;AAAA,IACH;AAAA,IAEA,MAAM,qBAAqB,QACxB,IAAI,CAAC,WAAW,aAAa,IAAI,MAAM,CAAC,EACxC,OAAO,CAAC,cACP,QAAQ,SAAS,CACnB;AAAA,IACF,WAAW,UAAU,SAAS;AAAA,MAC5B,IAAI,CAAC,aAAa,IAAI,MAAM,GAAG;AAAA,QAC7B,2BAA2B,IAAI,MAAM;AAAA,MACvC;AAAA,IACF;AAAA,IACA,MAAM,oBAAoB,QAAQ,OAChC,CAAC,WAAW,CAAC,aAAa,IAAI,MAAM,CACtC;AAAA,IAEA,MAAM,KAAK;AAAA,MACT,kBAAkB;AAAA,MAClB,kBAAkB,mBAAmB,IACnC,iCACF;AAAA,MACA,YAAY;AAAA,MACZ,MAAM;AAAA,MACN,MAAM;AAAA,MACN,4BAA4B;AAAA,IAC9B,CAAC;AAAA,IACD,SAAS,QAAQ,IAAI;AAAA,EACvB;AAAA,EAEA,IAAI,SAAS,QAAQ,UAAU,MAAM,WAAW,GAAG;AAAA,IACjD,MAAM,KAAK;AAAA,MACT,MAAM,QAAQ,MAAM,MAAM;AAAA,MAC1B,MAAM;AAAA,IACR,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,eAAe,MAAM,KAAK,CAAC,SAAS,KAAK,SAAS,UAAU;AAAA,EAClE,MAAM,WAA0C,CAAC,eAC7C,eACA,2BAA2B,SAAS,IAClC,aACA,WAAW,SAAS,IAClB,YACA;AAAA,EAER,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,mBAAmB,uBAAuB;AAAA,MACxC,GAAG;AAAA,MACH,GAAG;AAAA,IACL,CAAC;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,4BAA4B,CAAC,GAAG,0BAA0B,EAAE,KAC1D,CAAC,MAAM,UAAU,OAAO,KAC1B;AAAA,EACF;AAAA;AAGK,IAAM,yCAAyC,CACpD,eACsC;AAAA,EACtC,MAAM,SAAS,IAAI;AAAA,EAEnB,WAAW,aAAa,YAAY;AAAA,IAClC,MAAM,MAAM,yBAAyB,SAAS;AAAA,IAC9C,MAAM,WAAW,OAAO,IAAI,GAAG;AAAA,IAC/B,IAAI,CAAC,UAAU;AAAA,MACb,MAAM,WAAW,UAAU,WACvB;AAAA,QACE,cAAc,UAAU,SAAS;AAAA,QACjC,gBAAgB,UAAU,SAAS;AAAA,QACnC,eAAe,UAAU,SAAS;AAAA,MACpC,IACA;AAAA,MACJ,OAAO,IAAI,KAAK;AAAA,QACd,UAAU,CAAC,UAAU,OAAO;AAAA,QAC5B,cAAc,UAAU;AAAA,QACxB,OAAO;AAAA,QACP,SACE,uBACE,UACA,iBAAiB,UAAU,UAAU,iBAAiB,CACxD,EAAE,WACF,UAAU,kBACV,UAAU;AAAA,QACZ;AAAA,QACA,kBAAkB,UAAU;AAAA,QAC5B;AAAA,QACA,OAAO;AAAA,QACP,cAAc,UAAU;AAAA,QACxB,iBAAiB,UAAU;AAAA,QAC3B,kBAAkB,CAAC,UAAU,MAAM;AAAA,QACnC,YAAY,CAAC,SAAS;AAAA,QACtB,SACE,iCAAiC,SAAS,KAC1C,UAAU,SACV,UAAU;AAAA,MACd,CAAC;AAAA,MACD;AAAA,IACF;AAAA,IAEA,SAAS,SAAS;AAAA,IAClB,IAAI,CAAC,SAAS,SAAS,SAAS,UAAU,OAAO,GAAG;AAAA,MAClD,SAAS,SAAS,KAAK,UAAU,OAAO;AAAA,IAC1C;AAAA,IACA,IAAI,CAAC,SAAS,iBAAiB,SAAS,UAAU,MAAM,GAAG;AAAA,MACzD,SAAS,iBAAiB,KAAK,UAAU,MAAM;AAAA,IACjD;AAAA,IACA,SAAS,WAAW,KAAK,SAAS;AAAA,IAClC,IAAI,CAAC,SAAS,gBAAgB,UAAU,cAAc;AAAA,MACpD,SAAS,eAAe,UAAU;AAAA,IACpC;AAAA,IACA,IAAI,CAAC,SAAS,gBAAgB,UAAU,cAAc;AAAA,MACpD,SAAS,eAAe,UAAU;AAAA,IACpC;AAAA,IACA,IAAI,CAAC,SAAS,mBAAmB,UAAU,iBAAiB;AAAA,MAC1D,SAAS,kBAAkB,UAAU;AAAA,IACvC;AAAA,IACA,IAAI,CAAC,SAAS,YAAY,UAAU,UAAU;AAAA,MAC5C,SAAS,WAAW;AAAA,QAClB,cAAc,UAAU,SAAS;AAAA,QACjC,gBAAgB,UAAU,SAAS;AAAA,QACnC,eAAe,UAAU,SAAS;AAAA,MACpC;AAAA,MACA,SAAS,UAAU,UAAU,SAAS;AAAA,IACxC;AAAA,IACA,IAAI,CAAC,SAAS,oBAAoB,UAAU,kBAAkB;AAAA,MAC5D,SAAS,mBAAmB,UAAU;AAAA,IACxC;AAAA,EACF;AAAA,EAEA,OAAO,CAAC,GAAG,OAAO,OAAO,CAAC,EACvB,IAAI,CAAC,WAAW;AAAA,OACZ;AAAA,IACH,kBAAkB,CAAC,GAAG,MAAM,gBAAgB,EAAE,KAC5C,CAAC,MAAM,UAAU,OAAO,KAC1B;AAAA,IACA,YAAY,MAAM,WACf,MAAM,EACN,KAAK,CAAC,MAAM,UAAU,KAAK,SAAS,MAAM,MAAM;AAAA,EACrD,EAAE,EACD,KAAK,CAAC,MAAM,UAAU;AAAA,IACrB,MAAM,YAAY,KAAK,iBAAiB,MAAM,OAAO;AAAA,IACrD,MAAM,aAAa,MAAM,iBAAiB,MAAM,OAAO;AAAA,IACvD,IAAI,cAAc,YAAY;AAAA,MAC5B,OAAO,YAAY;AAAA,IACrB;AAAA,IACA,OAAO,KAAK,MAAM,cAAc,MAAM,KAAK;AAAA,GAC5C;AAAA;AAGE,IAAM,8BAA8B,CAAC,YAAyB;AAAA,EACnE,MAAM,YAAY,kBAAkB,OAAO;AAAA,EAC3C,MAAM,uBAAuB,6BAA6B,SAAS;AAAA,EAEnE,OAAO,UAAU,IAA2B,CAAC,aAAa;AAAA,IACxD,MAAM,WAAW,4BAA4B,SAAS,SAAS,OAAO;AAAA,IACtE,MAAM,mBAAmB,uBACvB,UACA,iBAAiB,SAAS,UAAU,iBAAiB,CACvD;AAAA,IACA,OAAO;AAAA,MACL,SAAS,SAAS;AAAA,MAClB,cACE,SAAS,gBAAgB,kBAAkB,SAAS,QAAQ;AAAA,MAC9D,SACE,iBAAiB,WACjB,UAAU,gBACV,aAAa,SAAS,IAAI;AAAA,MAC5B;AAAA,MACA;AAAA,MACA,OAAO,SAAS;AAAA,MAChB,cACE,SAAS,gBACT,kBAAkB,SAAS,UAAU,SAAS,QAAQ,SAAS,KAAK;AAAA,MACtE,UAAU,SAAS;AAAA,MACnB,QAAQ,qBAAqB,SAAS,YAAY;AAAA,MAClD,iBACE,SAAS,mBAAmB,qBAAqB,SAAS,QAAQ;AAAA,MACpE,OAAO,SAAS;AAAA,MAChB,QAAQ,SAAS;AAAA,MACjB,MAAM,SAAS;AAAA,MACf,OAAO,SAAS;AAAA,IAClB;AAAA,GACD;AAAA;;;AC3xCH;;;ACAA,SAAS,UAAU,CAAC,MAAK;AAAA,EAAC,IAAG,OAAO,SAAO;AAAA,IAAS,MAAM,UAAU,qCAAmC,KAAK,UAAU,IAAI,CAAC;AAAA;AAAE,SAAS,oBAAoB,CAAC,MAAK,gBAAe;AAAA,EAAC,IAAI,MAAI,IAAG,oBAAkB,GAAE,YAAU,IAAG,OAAK,GAAE;AAAA,EAAK,SAAQ,IAAE,EAAE,KAAG,KAAK,QAAO,EAAE,GAAE;AAAA,IAAC,IAAG,IAAE,KAAK;AAAA,MAAO,OAAK,KAAK,WAAW,CAAC;AAAA,IAAO,SAAG,SAAO;AAAA,MAAG;AAAA,IAAW;AAAA,aAAK;AAAA,IAAG,IAAG,SAAO,IAAG;AAAA,MAAC,IAAG,cAAY,IAAE,KAAG,SAAO;AAAA;AAAA,MAAQ,SAAG,cAAY,IAAE,KAAG,SAAO,GAAE;AAAA,QAAC,IAAG,IAAI,SAAO,KAAG,sBAAoB,KAAG,IAAI,WAAW,IAAI,SAAO,CAAC,MAAI,MAAI,IAAI,WAAW,IAAI,SAAO,CAAC,MAAI,IAAG;AAAA,UAAC,IAAG,IAAI,SAAO,GAAE;AAAA,YAAC,IAAI,iBAAe,IAAI,YAAY,GAAG;AAAA,YAAE,IAAG,mBAAiB,IAAI,SAAO,GAAE;AAAA,cAAC,IAAG,mBAAiB;AAAA,gBAAG,MAAI,IAAG,oBAAkB;AAAA,cAAO;AAAA,sBAAI,IAAI,MAAM,GAAE,cAAc,GAAE,oBAAkB,IAAI,SAAO,IAAE,IAAI,YAAY,GAAG;AAAA,cAAE,YAAU,GAAE,OAAK;AAAA,cAAE;AAAA,YAAQ;AAAA,UAAC,EAAM,SAAG,IAAI,WAAS,KAAG,IAAI,WAAS,GAAE;AAAA,YAAC,MAAI,IAAG,oBAAkB,GAAE,YAAU,GAAE,OAAK;AAAA,YAAE;AAAA,UAAQ;AAAA,QAAC;AAAA,QAAC,IAAG,gBAAe;AAAA,UAAC,IAAG,IAAI,SAAO;AAAA,YAAE,OAAK;AAAA,UAAW;AAAA,kBAAI;AAAA,UAAK,oBAAkB;AAAA,QAAC;AAAA,MAAC,EAAK;AAAA,QAAC,IAAG,IAAI,SAAO;AAAA,UAAE,OAAK,MAAI,KAAK,MAAM,YAAU,GAAE,CAAC;AAAA,QAAO;AAAA,gBAAI,KAAK,MAAM,YAAU,GAAE,CAAC;AAAA,QAAE,oBAAkB,IAAE,YAAU;AAAA;AAAA,MAAE,YAAU,GAAE,OAAK;AAAA,IAAC,EAAM,SAAG,SAAO,MAAI,SAAO;AAAA,MAAG,EAAE;AAAA,IAAU;AAAA,aAAK;AAAA,EAAE;AAAA,EAAC,OAAO;AAAA;AAAI,SAAS,OAAO,CAAC,KAAI,YAAW;AAAA,EAAC,IAAI,MAAI,WAAW,OAAK,WAAW,MAAK,OAAK,WAAW,SAAO,WAAW,QAAM,OAAK,WAAW,OAAK;AAAA,EAAI,IAAG,CAAC;AAAA,IAAI,OAAO;AAAA,EAAK,IAAG,QAAM,WAAW;AAAA,IAAK,OAAO,MAAI;AAAA,EAAK,OAAO,MAAI,MAAI;AAAA;AAAK,SAAS,OAAO,GAAE;AAAA,EAAC,IAAI,eAAa,IAAG,mBAAiB,OAAG;AAAA,EAAI,SAAQ,IAAE,UAAU,SAAO,EAAE,KAAG,MAAI,CAAC,kBAAiB,KAAI;AAAA,IAAC,IAAI;AAAA,IAAK,IAAG,KAAG;AAAA,MAAE,OAAK,UAAU;AAAA,IAAO;AAAA,MAAC,IAAG,QAAW;AAAA,QAAE,MAAI,QAAQ,IAAI;AAAA,MAAE,OAAK;AAAA;AAAA,IAAI,IAAG,WAAW,IAAI,GAAE,KAAK,WAAS;AAAA,MAAE;AAAA,IAAS,eAAa,OAAK,MAAI,cAAa,mBAAiB,KAAK,WAAW,CAAC,MAAI;AAAA,EAAE;AAAA,EAAC,IAAG,eAAa,qBAAqB,cAAa,CAAC,gBAAgB,GAAE;AAAA,IAAiB,IAAG,aAAa,SAAO;AAAA,MAAE,OAAM,MAAI;AAAA,IAAkB;AAAA,aAAM;AAAA,EAAS,SAAG,aAAa,SAAO;AAAA,IAAE,OAAO;AAAA,EAAkB;AAAA,WAAM;AAAA;AAAI,SAAS,SAAS,CAAC,MAAK;AAAA,EAAC,IAAG,WAAW,IAAI,GAAE,KAAK,WAAS;AAAA,IAAE,OAAM;AAAA,EAAI,IAAI,aAAW,KAAK,WAAW,CAAC,MAAI,IAAG,oBAAkB,KAAK,WAAW,KAAK,SAAO,CAAC,MAAI;AAAA,EAAG,IAAG,OAAK,qBAAqB,MAAK,CAAC,UAAU,GAAE,KAAK,WAAS,KAAG,CAAC;AAAA,IAAW,OAAK;AAAA,EAAI,IAAG,KAAK,SAAO,KAAG;AAAA,IAAkB,QAAM;AAAA,EAAI,IAAG;AAAA,IAAW,OAAM,MAAI;AAAA,EAAK,OAAO;AAAA;AAAK,SAAS,UAAU,CAAC,MAAK;AAAA,EAAC,OAAO,WAAW,IAAI,GAAE,KAAK,SAAO,KAAG,KAAK,WAAW,CAAC,MAAI;AAAA;AAAG,SAAS,IAAI,GAAE;AAAA,EAAC,IAAG,UAAU,WAAS;AAAA,IAAE,OAAM;AAAA,EAAI,IAAI;AAAA,EAAO,SAAQ,IAAE,EAAE,IAAE,UAAU,QAAO,EAAE,GAAE;AAAA,IAAC,IAAI,MAAI,UAAU;AAAA,IAAG,IAAG,WAAW,GAAG,GAAE,IAAI,SAAO;AAAA,MAAE,IAAG,WAAc;AAAA,QAAE,SAAO;AAAA,MAAS;AAAA,kBAAQ,MAAI;AAAA,EAAG;AAAA,EAAC,IAAG,WAAc;AAAA,IAAE,OAAM;AAAA,EAAI,OAAO,UAAU,MAAM;AAAA;AAAE,SAAS,QAAQ,CAAC,MAAK,IAAG;AAAA,EAAC,IAAG,WAAW,IAAI,GAAE,WAAW,EAAE,GAAE,SAAO;AAAA,IAAG,OAAM;AAAA,EAAG,IAAG,OAAK,QAAQ,IAAI,GAAE,KAAG,QAAQ,EAAE,GAAE,SAAO;AAAA,IAAG,OAAM;AAAA,EAAG,IAAI,YAAU;AAAA,EAAE,MAAK,YAAU,KAAK,QAAO,EAAE;AAAA,IAAU,IAAG,KAAK,WAAW,SAAS,MAAI;AAAA,MAAG;AAAA,EAAM,IAAI,UAAQ,KAAK,QAAO,UAAQ,UAAQ,WAAU,UAAQ;AAAA,EAAE,MAAK,UAAQ,GAAG,QAAO,EAAE;AAAA,IAAQ,IAAG,GAAG,WAAW,OAAO,MAAI;AAAA,MAAG;AAAA,EAAM,IAAI,QAAM,GAAG,QAAO,QAAM,QAAM,SAAQ,SAAO,UAAQ,QAAM,UAAQ,OAAM,gBAAc,IAAG,IAAE;AAAA,EAAE,MAAK,KAAG,QAAO,EAAE,GAAE;AAAA,IAAC,IAAG,MAAI,QAAO;AAAA,MAAC,IAAG,QAAM,QAAO;AAAA,QAAC,IAAG,GAAG,WAAW,UAAQ,CAAC,MAAI;AAAA,UAAG,OAAO,GAAG,MAAM,UAAQ,IAAE,CAAC;AAAA,QAAO,SAAG,MAAI;AAAA,UAAE,OAAO,GAAG,MAAM,UAAQ,CAAC;AAAA,MAAC,EAAM,SAAG,UAAQ,QAAO;AAAA,QAAC,IAAG,KAAK,WAAW,YAAU,CAAC,MAAI;AAAA,UAAG,gBAAc;AAAA,QAAO,SAAG,MAAI;AAAA,UAAE,gBAAc;AAAA,MAAC;AAAA,MAAC;AAAA,IAAK;AAAA,IAAC,IAAI,WAAS,KAAK,WAAW,YAAU,CAAC,GAAE,SAAO,GAAG,WAAW,UAAQ,CAAC;AAAA,IAAE,IAAG,aAAW;AAAA,MAAO;AAAA,IAAW,SAAG,aAAW;AAAA,MAAG,gBAAc;AAAA,EAAC;AAAA,EAAC,IAAI,MAAI;AAAA,EAAG,KAAI,IAAE,YAAU,gBAAc,EAAE,KAAG,SAAQ,EAAE;AAAA,IAAE,IAAG,MAAI,WAAS,KAAK,WAAW,CAAC,MAAI;AAAA,MAAG,IAAG,IAAI,WAAS;AAAA,QAAE,OAAK;AAAA,MAAU;AAAA,eAAK;AAAA,EAAM,IAAG,IAAI,SAAO;AAAA,IAAE,OAAO,MAAI,GAAG,MAAM,UAAQ,aAAa;AAAA,EAAM;AAAA,IAAC,IAAG,WAAS,eAAc,GAAG,WAAW,OAAO,MAAI;AAAA,MAAG,EAAE;AAAA,IAAQ,OAAO,GAAG,MAAM,OAAO;AAAA;AAAA;AAAG,SAAS,SAAS,CAAC,MAAK;AAAA,EAAC,OAAO;AAAA;AAAK,SAAS,OAAO,CAAC,MAAK;AAAA,EAAC,IAAG,WAAW,IAAI,GAAE,KAAK,WAAS;AAAA,IAAE,OAAM;AAAA,EAAI,IAAI,OAAK,KAAK,WAAW,CAAC,GAAE,UAAQ,SAAO,IAAG,MAAI,IAAG,eAAa;AAAA,EAAG,SAAQ,IAAE,KAAK,SAAO,EAAE,KAAG,GAAE,EAAE;AAAA,IAAE,IAAG,OAAK,KAAK,WAAW,CAAC,GAAE,SAAO,IAAG;AAAA,MAAC,IAAG,CAAC,cAAa;AAAA,QAAC,MAAI;AAAA,QAAE;AAAA,MAAK;AAAA,IAAC,EAAM;AAAA,qBAAa;AAAA,EAAG,IAAG,QAAM;AAAA,IAAG,OAAO,UAAQ,MAAI;AAAA,EAAI,IAAG,WAAS,QAAM;AAAA,IAAE,OAAM;AAAA,EAAK,OAAO,KAAK,MAAM,GAAE,GAAG;AAAA;AAAE,SAAS,QAAQ,CAAC,MAAK,KAAI;AAAA,EAAC,IAAG,QAAW,aAAG,OAAO,QAAM;AAAA,IAAS,MAAM,UAAU,iCAAiC;AAAA,EAAE,WAAW,IAAI;AAAA,EAAE,IAAI,QAAM,GAAE,MAAI,IAAG,eAAa,MAAG;AAAA,EAAE,IAAG,QAAW,aAAG,IAAI,SAAO,KAAG,IAAI,UAAQ,KAAK,QAAO;AAAA,IAAC,IAAG,IAAI,WAAS,KAAK,UAAQ,QAAM;AAAA,MAAK,OAAM;AAAA,IAAG,IAAI,SAAO,IAAI,SAAO,GAAE,mBAAiB;AAAA,IAAG,KAAI,IAAE,KAAK,SAAO,EAAE,KAAG,GAAE,EAAE,GAAE;AAAA,MAAC,IAAI,OAAK,KAAK,WAAW,CAAC;AAAA,MAAE,IAAG,SAAO,IAAG;AAAA,QAAC,IAAG,CAAC,cAAa;AAAA,UAAC,QAAM,IAAE;AAAA,UAAE;AAAA,QAAK;AAAA,MAAC,EAAK;AAAA,QAAC,IAAG,qBAAmB;AAAA,UAAG,eAAa,OAAG,mBAAiB,IAAE;AAAA,QAAE,IAAG,UAAQ;AAAA,UAAE,IAAG,SAAO,IAAI,WAAW,MAAM,GAAE;AAAA,YAAC,IAAG,EAAE,WAAS;AAAA,cAAG,MAAI;AAAA,UAAC,EAAM;AAAA,qBAAO,IAAG,MAAI;AAAA;AAAA,IAAiB;AAAA,IAAC,IAAG,UAAQ;AAAA,MAAI,MAAI;AAAA,IAAsB,SAAG,QAAM;AAAA,MAAG,MAAI,KAAK;AAAA,IAAO,OAAO,KAAK,MAAM,OAAM,GAAG;AAAA,EAAC,EAAK;AAAA,IAAC,KAAI,IAAE,KAAK,SAAO,EAAE,KAAG,GAAE,EAAE;AAAA,MAAE,IAAG,KAAK,WAAW,CAAC,MAAI,IAAG;AAAA,QAAC,IAAG,CAAC,cAAa;AAAA,UAAC,QAAM,IAAE;AAAA,UAAE;AAAA,QAAK;AAAA,MAAC,EAAM,SAAG,QAAM;AAAA,QAAG,eAAa,OAAG,MAAI,IAAE;AAAA,IAAE,IAAG,QAAM;AAAA,MAAG,OAAM;AAAA,IAAG,OAAO,KAAK,MAAM,OAAM,GAAG;AAAA;AAAA;AAAG,SAAS,OAAO,CAAC,MAAK;AAAA,EAAC,WAAW,IAAI;AAAA,EAAE,IAAI,WAAS,IAAG,YAAU,GAAE,MAAI,IAAG,eAAa,MAAG,cAAY;AAAA,EAAE,SAAQ,IAAE,KAAK,SAAO,EAAE,KAAG,GAAE,EAAE,GAAE;AAAA,IAAC,IAAI,OAAK,KAAK,WAAW,CAAC;AAAA,IAAE,IAAG,SAAO,IAAG;AAAA,MAAC,IAAG,CAAC,cAAa;AAAA,QAAC,YAAU,IAAE;AAAA,QAAE;AAAA,MAAK;AAAA,MAAC;AAAA,IAAQ;AAAA,IAAC,IAAG,QAAM;AAAA,MAAG,eAAa,OAAG,MAAI,IAAE;AAAA,IAAE,IAAG,SAAO,IAAG;AAAA,MAAC,IAAG,aAAW;AAAA,QAAG,WAAS;AAAA,MAAO,SAAG,gBAAc;AAAA,QAAE,cAAY;AAAA,IAAC,EAAM,SAAG,aAAW;AAAA,MAAG,cAAY;AAAA,EAAE;AAAA,EAAC,IAAG,aAAW,MAAI,QAAM,MAAI,gBAAc,KAAG,gBAAc,KAAG,aAAW,MAAI,KAAG,aAAW,YAAU;AAAA,IAAE,OAAM;AAAA,EAAG,OAAO,KAAK,MAAM,UAAS,GAAG;AAAA;AAAE,SAAS,MAAM,CAAC,YAAW;AAAA,EAAC,IAAG,eAAa,QAAM,OAAO,eAAa;AAAA,IAAS,MAAM,UAAU,qEAAmE,OAAO,UAAU;AAAA,EAAE,OAAO,QAAQ,KAAI,UAAU;AAAA;AAAE,SAAS,KAAK,CAAC,MAAK;AAAA,EAAC,WAAW,IAAI;AAAA,EAAE,IAAI,MAAI,EAAC,MAAK,IAAG,KAAI,IAAG,MAAK,IAAG,KAAI,IAAG,MAAK,GAAE;AAAA,EAAE,IAAG,KAAK,WAAS;AAAA,IAAE,OAAO;AAAA,EAAI,IAAI,OAAK,KAAK,WAAW,CAAC,GAAE,cAAY,SAAO,IAAG;AAAA,EAAM,IAAG;AAAA,IAAY,IAAI,OAAK,KAAI,QAAM;AAAA,EAAO;AAAA,YAAM;AAAA,EAAE,IAAI,WAAS,IAAG,YAAU,GAAE,MAAI,IAAG,eAAa,MAAG,IAAE,KAAK,SAAO,GAAE,cAAY;AAAA,EAAE,MAAK,KAAG,OAAM,EAAE,GAAE;AAAA,IAAC,IAAG,OAAK,KAAK,WAAW,CAAC,GAAE,SAAO,IAAG;AAAA,MAAC,IAAG,CAAC,cAAa;AAAA,QAAC,YAAU,IAAE;AAAA,QAAE;AAAA,MAAK;AAAA,MAAC;AAAA,IAAQ;AAAA,IAAC,IAAG,QAAM;AAAA,MAAG,eAAa,OAAG,MAAI,IAAE;AAAA,IAAE,IAAG,SAAO,IAAG;AAAA,MAAC,IAAG,aAAW;AAAA,QAAG,WAAS;AAAA,MAAO,SAAG,gBAAc;AAAA,QAAE,cAAY;AAAA,IAAC,EAAM,SAAG,aAAW;AAAA,MAAG,cAAY;AAAA,EAAE;AAAA,EAAC,IAAG,aAAW,MAAI,QAAM,MAAI,gBAAc,KAAG,gBAAc,KAAG,aAAW,MAAI,KAAG,aAAW,YAAU,GAAE;AAAA,IAAC,IAAG,QAAM;AAAA,MAAG,IAAG,cAAY,KAAG;AAAA,QAAY,IAAI,OAAK,IAAI,OAAK,KAAK,MAAM,GAAE,GAAG;AAAA,MAAO;AAAA,YAAI,OAAK,IAAI,OAAK,KAAK,MAAM,WAAU,GAAG;AAAA,EAAC,EAAK;AAAA,IAAC,IAAG,cAAY,KAAG;AAAA,MAAY,IAAI,OAAK,KAAK,MAAM,GAAE,QAAQ,GAAE,IAAI,OAAK,KAAK,MAAM,GAAE,GAAG;AAAA,IAAO;AAAA,UAAI,OAAK,KAAK,MAAM,WAAU,QAAQ,GAAE,IAAI,OAAK,KAAK,MAAM,WAAU,GAAG;AAAA,IAAE,IAAI,MAAI,KAAK,MAAM,UAAS,GAAG;AAAA;AAAA,EAAE,IAAG,YAAU;AAAA,IAAE,IAAI,MAAI,KAAK,MAAM,GAAE,YAAU,CAAC;AAAA,EAAO,SAAG;AAAA,IAAY,IAAI,MAAI;AAAA,EAAI,OAAO;AAAA;AAAI,IAAI,MAAI;AAAR,IAAY,YAAU;AAAtB,IAA0B,SAAO,CAAC,OAAK,EAAE,QAAM,GAAE,IAAI,EAAC,SAAQ,WAAU,YAAW,MAAK,UAAS,WAAU,SAAQ,UAAS,SAAQ,QAAO,OAAM,KAAI,WAAU,OAAM,MAAK,OAAM,KAAI,CAAC;;;ADoI/4N;AAizCO,IAAM,gCAAgC,CAC3C,SACG;AAAA,EACH,MAAM,SAAS,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,MAAM,UAAU;AAAA,IAC7C,IAAI,MAAM,SAAS,gBAAgB,KAAK,SAAS,aAAa;AAAA,MAC5D,OAAO,MAAM,SAAS,cAAc,KAAK,SAAS;AAAA,IACpD;AAAA,IACA,IAAI,MAAM,SAAS,QAAQ,cAAc,KAAK,SAAS,QAAQ,WAAW;AAAA,MACxE,OAAO,MAAM,SAAS,QAAQ,YAAY,KAAK,SAAS,QAAQ;AAAA,IAClE;AAAA,IAEA,OACE,KAAK,SAAS,QAAQ,mBACtB,MAAM,SAAS,QAAQ;AAAA,GAE1B;AAAA,EAED,OAAO,OAAO,IAAmC,CAAC,KAAK,WAAW;AAAA,IAChE,WAAW,IAAI,SAAS,QAAQ;AAAA,IAChC,kBAAkB,IAAI,SAAS,QAAQ;AAAA,IACvC,OAAO,IAAI;AAAA,IACX,aAAa,IAAI,SAAS;AAAA,IAC1B,MAAM,QAAQ;AAAA,IACd,OAAO,IAAI;AAAA,IACX,SAAS,IAAI;AAAA,IACb,YAAY,IAAI,SAAS;AAAA,EAC3B,EAAE;AAAA;AAwnTG,IAAM,wBAAwB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MASI;AAAA,EACJ,MAAM,YAAY,KAAK,IAAI;AAAA,EAC3B,MAAM,WAAW,MAAM,SAAS;AAAA,OAC3B,MAAM;AAAA,OACN;AAAA,IACH,OAAO,WAAW,SAAS,MAAM,MAAM;AAAA,EACzC,CAAC;AAAA,EACD,MAAM,aAAa,KAAK,IAAI;AAAA,EAE5B,OAAO;AAAA,IACL,oBAAoB,WAAW;AAAA,IAC/B,WAAW,aAAa;AAAA,IACxB;AAAA,IACA,IAAI,WAAW;AAAA,IACf,OAAO,MAAM,SAAS,MAAM;AAAA,IAC5B,UAAU,MAAM;AAAA,IAChB;AAAA,IACA;AAAA,IACA,SAAS,MAAM;AAAA,IACf,cAAc,WAAW;AAAA,EAC3B;AAAA;;;AEzgWF,IAAM,sBAAsB,CAAC,WAC3B,OAAO,UAAU,OAAO,SAAS,OAAO;AAE1C,IAAM,oBAAmB,CAAC,WACxB,OAAO,UAAU,OAAO,SAAS,OAAO;AAE1C,IAAM,oBAAmB,CAAC,UACxB,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAAI,QAAQ;AAEhE,IAAM,oBAAmB,CAAC,UACxB,OAAO,UAAU,YAAY,MAAM,KAAK,EAAE,SAAS,IAC/C,MAAM,KAAK,IACX;AAEN,IAAM,sBAAsB,CAAC,UAA+C;AAAA,EAC1E,IAAI,CAAC,SAAS,OAAO,UAAU,UAAU;AAAA,IACvC,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,YAAY;AAAA,EAElB,OACE,OAAO,UAAU,UAAU,YAC3B,OAAO,UAAU,qBAAqB,YACtC,MAAM,QAAQ,UAAU,cAAc,KACtC,MAAM,QAAQ,UAAU,KAAK;AAAA;AAIjC,IAAM,wBAAuB,CAAC,UAAmB;AAAA,EAC/C,MAAM,YACJ,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAC9C,QACA,OAAO,UAAU,WACf,KAAK,MAAM,KAAK,IAChB,OAAO;AAAA,EACf,IAAI,CAAC,OAAO,SAAS,SAAS,GAAG;AAAA,IAC/B;AAAA,EACF;AAAA,EAEA,OAAO,IAAI,KAAK,SAAS,EAAE,eAAe,SAAS;AAAA,IACjD,WAAW;AAAA,IACX,WAAW;AAAA,EACb,CAAC;AAAA;AA4eH,IAAM,+BAA+B,CAAC,UAAmB;AAAA,EACvD,MAAM,SAAS,kBAAiB,KAAK;AAAA,EACrC,IAAI,WAAW,oBAAoB;AAAA,IACjC,OAAO;AAAA,EACT;AAAA,EACA,IAAI,WAAW,cAAc;AAAA,IAC3B,OAAO;AAAA,EACT;AAAA,EACA,IAAI,WAAW,sBAAsB;AAAA,IACnC,OAAO;AAAA,EACT;AAAA,EACA;AAAA;AAGF,IAAM,iCAAiC,CAAC,aAAuC;AAAA,EAC7E,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,eACJ,kBAAiB,SAAS,YAAY,KAAK,YAAY,GAAG,EAAE;AAAA,EAC9D,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,uBAAuB,kBAAiB,SAAS,eAAe;AAAA,EACtE,MAAM,kBACJ,yBAAyB,WACzB,yBAAyB,UACzB,yBAAyB,cACrB,uBACA;AAAA,EACN,MAAM,YAAY,kBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,wBAAwB,4BAC5B,kBAAiB,SAAS,qBAAqB,GAC/C,kBAAiB,SAAS,qBAAqB,CACjD;AAAA,EACA,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,MAAM,cACJ,kBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAC5B,SAAS,aAAa,IACtB;AAAA,EAEN,IACE,YAAY,SAAS,MACpB,gBAAgB,sBACf,gBAAgB,kBAChB,gBAAgB,oBAChB,gBAAgB,YAClB;AAAA,IACA,OAAO,wBAAwB,YAAY,KAAK,KAAK;AAAA,EACvD;AAAA,EAEA,IAAI,gBAAgB,aAAa;AAAA,IAC/B,IAAI,oBAAoB,oBAAoB,cAAc;AAAA,MACxD,OAAO,mCAAmC;AAAA,IAC5C;AAAA,IACA,IAAI,oBAAoB,iBAAiB,cAAc;AAAA,MACrD,OAAO,gCAAgC;AAAA,IACzC;AAAA,IACA,IAAI,gBAAgB,gBAAgB,cAAc;AAAA,MAChD,OAAO,gCAAgC;AAAA,IACzC;AAAA,IACA,IAAI,cAAc;AAAA,MAChB,OAAO,0BAA0B;AAAA,IACnC;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EAEA,IAAI,gBAAgB,gBAAgB;AAAA,IAClC,MAAM,qBACJ,YAAY,SAAS,IAAI,YAAY,KAAK,KAAK,IAAI;AAAA,IACrD,IAAI,mBAAmB,oBAAoB;AAAA,MACzC,OAAO,uBAAuB,yBAAyB;AAAA,IACzD;AAAA,IACA,IAAI,oBAAoB;AAAA,MACtB,OAAO,6BAA6B;AAAA,IACtC;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EAEA,IACE,gBAAgB,sBACf,gBAAgB,cACd,aACC,yBACA,kBAAiB,SAAS,mBAAmB,MAAM,aACnD,kBAAiB,SAAS,iBAAiB,MAAM,YACrD;AAAA,IACA,IAAI,aAAa,uBAAuB;AAAA,MACtC,OAAO,4BAA4B,aAAa;AAAA,IAClD;AAAA,IACA,IAAI,WAAW;AAAA,MACb,OAAO,4BAA4B;AAAA,IACrC;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EAEA,IAAI,gBAAgB,sBAAsB;AAAA,IACxC,IAAI,eAAe,YAAY;AAAA,MAC7B,OAAO,sBAAsB,eAAe;AAAA,IAC9C;AAAA,IACA,IAAI,YAAY;AAAA,MACd,OAAO,sBAAsB;AAAA,IAC/B;AAAA,IACA,IAAI,aAAa;AAAA,MACf,OAAO,sBAAsB;AAAA,IAC/B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EAEA;AAAA;AA8dF,IAAM,wBAAuB,CAAC,UAAmB;AAAA,EAC/C,IAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GAAG;AAAA,IACrE;AAAA,EACF;AAAA,EAEA,MAAM,eAAe,KAAK,MAAM,QAAQ,IAAI;AAAA,EAC5C,MAAM,UAAU,KAAK,MAAM,eAAe,EAAE;AAAA,EAC5C,MAAM,UAAU,eAAe;AAAA,EAC/B,MAAM,eAAe,KAAK,MAAM,QAAQ,IAAI;AAAA,EAE5C,OAAO,GAAG,OAAO,OAAO,EAAE,SAAS,GAAG,GAAG,KAAK,OAAO,OAAO,EAAE,SAC5D,GACA,GACF,KAAK,OAAO,YAAY,EAAE,SAAS,GAAG,GAAG;AAAA;AAG3C,IAAM,qBAAoB,CAAC,QAAiB,UAAmB;AAAA,EAC7D,MAAM,mBAAmB,QAAQ,MAAM,GAAG,EAAE,GAAG,EAAE;AAAA,EACjD,IAAI,oBAAoB,iBAAiB,SAAS,GAAG,GAAG;AAAA,IACtD,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,kBAAkB,OAAO,MAAM,KAAI,EAAE,GAAG,EAAE;AAAA,EAChD,IAAI,mBAAmB,gBAAgB,SAAS,GAAG,GAAG;AAAA,IACpD,OAAO;AAAA,EACT;AAAA,EAEA;AAAA;AAGF,IAAM,wBAAwB,CAAC,aAC7B,MAAM,QAAQ,UAAU,kBAAkB,IACtC,SAAS,mBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAEP,IAAM,+BAA+B,CACnC,aACA,cACG;AAAA,EACH,IAAI,OAAO,gBAAgB,YAAY,YAAY,WAAW,GAAG;AAAA,IAC/D;AAAA,EACF;AAAA,EACA,IAAI,OAAO,cAAc,YAAY,UAAU,WAAW,GAAG;AAAA,IAC3D,OAAO,WAAW;AAAA,EACpB;AAAA,EACA,IAAI,gBAAgB,WAAW;AAAA,IAC7B,OAAO,WAAW;AAAA,EACpB;AAAA,EAEA,OAAO,WAAW,eAAe;AAAA;AAGnC,IAAM,4BAA4B,CAAC,UAAmB,WAAoB;AAAA,EACxE,IAAI,OAAO,aAAa,YAAY,CAAC,OAAO,SAAS,QAAQ,GAAG;AAAA,IAC9D;AAAA,EACF;AAAA,EACA,IACE,OAAO,WAAW,YAClB,OAAO,aAAa,YACpB,OAAO,SAAS,QAAQ,GACxB;AAAA,IACA,OAAO,QAAQ;AAAA,EACjB;AAAA,EACA,IAAI,aAAa,QAAQ;AAAA,IACvB,OAAO,QAAQ;AAAA,EACjB;AAAA,EAEA,OAAO,QAAQ,YAAY;AAAA;AAG7B,IAAM,8BAA8B,CAClC,YACA,eACG;AAAA,EACH,IACE,OAAO,eAAe,YACtB,CAAC,OAAO,SAAS,UAAU,KAC3B,aAAa,GACb;AAAA,IACA;AAAA,EACF;AAAA,EAEA,IACE,OAAO,eAAe,YACtB,OAAO,SAAS,UAAU,KAC1B,cAAc,YACd;AAAA,IACA,OAAO,SAAS,iBAAiB;AAAA,EACnC;AAAA,EAEA,OAAO,SAAS;AAAA;AAGlB,IAAM,+BAA8B,CAAC,UAAmB;AAAA,EACtD,IAAI,CAAC,MAAM,QAAQ,KAAK,KAAK,MAAM,WAAW,GAAG;AAAA,IAC/C;AAAA,EACF;AAAA,EAEA,MAAM,SAAS,MACZ,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,EAC5D,KAAK,CAAC,MAAM,UAAU,OAAO,KAAK;AAAA,EAErC,IAAI,OAAO,WAAW,GAAG;AAAA,IACvB;AAAA,EACF;AAAA,EAEA,MAAM,WAAW,OAAO;AAAA,EACxB,MAAM,WAAW,OAAO,OAAO,SAAS;AAAA,EAExC,OAAO,aAAa,WAChB,qBAAqB,aACrB,sBAAsB,YAAY;AAAA;AAGxC,IAAM,4BAA2B,CAAC,UAAmB;AAAA,EACnD,IAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GAAG;AAAA,IACrE;AAAA,EACF;AAAA,EAEA,OAAO,sBAAqB,KAAK;AAAA;AAGnC,IAAM,qBAAoB,CAAC,aAAuC;AAAA,EAChE,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,uBAAuB,kBAAiB,SAAS,oBAAoB;AAAA,EAC3E,MAAM,qBAAqB,kBAAiB,SAAS,kBAAkB;AAAA,EACvE,MAAM,uBAAuB,kBAAiB,SAAS,eAAe;AAAA,EACtE,MAAM,kBACJ,yBAAyB,WACzB,yBAAyB,UACzB,yBAAyB,cACrB,uBACA;AAAA,EACN,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,eACJ,kBAAiB,SAAS,YAAY,KAAK,YAAY,GAAG,EAAE;AAAA,EAC9D,IAAI,oBAAoB,oBAAoB,cAAc;AAAA,IACxD,OAAO,sBAAsB;AAAA,EAC/B;AAAA,EACA,IAAI,oBAAoB,iBAAiB,cAAc;AAAA,IACrD,OAAO,mBAAmB;AAAA,EAC5B;AAAA,EACA,IAAI,gBAAgB,gBAAgB,cAAc;AAAA,IAChD,OAAO,mBAAmB;AAAA,EAC5B;AAAA,EACA,IAAI,gBAAgB,eAAe,cAAc;AAAA,IAC/C,OAAO,kBAAkB;AAAA,EAC3B;AAAA,EACA,IAAI,oBAAoB,WAAW,cAAc;AAAA,IAC/C,OAAO,sBAAsB,YAAY,KAAK,KAAK,KAAK;AAAA,EAC1D;AAAA,EACA,IAAI,oBAAoB,UAAU,cAAc;AAAA,IAC9C,OAAO,qBAAqB,YAAY,KAAK,KAAK,KAAK;AAAA,EACzD;AAAA,EACA,IAAI,oBAAoB,eAAe,cAAc;AAAA,IACnD,OAAO,0BAA0B,YAAY,KAAK,KAAK,KAAK;AAAA,EAC9D;AAAA,EAEA,MAAM,YAAY,kBAAiB,SAAS,SAAS;AAAA,EACrD,IAAI,cAAc,cAAc;AAAA,IAC9B,MAAM,iBAAiB,kBAAiB,SAAS,cAAc;AAAA,IAC/D,MAAM,eAAc,kBAAiB,SAAS,WAAW;AAAA,IACzD,OAAO,iBACH,eACE,uBAAuB,qBAAqB,iBAC5C,uBAAuB,mBACzB;AAAA,EACN;AAAA,EAEA,IAAI,cAAc,WAAW;AAAA,IAC3B,MAAM,eAAc,kBAAiB,SAAS,WAAW;AAAA,IACzD,MAAM,OAAO,kBAAiB,SAAS,IAAI;AAAA,IAC3C,IAAI,cAAa;AAAA,MACf,OAAO,OACH,cAAc,qBAAoB,SAClC,cAAc;AAAA,IACpB;AAAA,IACA,OAAO,OAAO,gBAAgB,SAAS;AAAA,EACzC;AAAA,EAEA,MAAM,OACJ,kBAAiB,SAAS,IAAI,KAC9B,kBAAiB,SAAS,UAAU,MACnC,OAAO,SAAS,cAAc,WAC3B,SAAS,YAAY,IACrB;AAAA,EACN,MAAM,SACJ,kBAAiB,SAAS,YAAY,MACrC,OAAO,SAAS,gBAAgB,WAC7B,SAAS,cAAc,IACvB;AAAA,EACN,MAAM,cACJ,OAAO,SAAS,wBAAwB,YACxC,OAAO,SAAS,kBAAkB,YAClC,kBAAiB,SAAS,WAAW,MAAM,SAC3C,OAAO,SAAS,mBAAmB;AAAA,EACrC,MAAM,eAAe,kBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,IAAI,QAAQ,QAAQ;AAAA,IAClB,IAAI,aAAa;AAAA,MACf,OAAO,YAAY,eAAe;AAAA,IACpC;AAAA,IACA,OAAO,QAAQ,eAAe;AAAA,EAChC;AAAA,EACA,IAAI,MAAM;AAAA,IACR,IAAI,aAAa;AAAA,MACf,OAAO,YAAY;AAAA,IACrB;AAAA,IACA,OAAO,QAAQ;AAAA,EACjB;AAAA,EACA,IACE,eACA,OAAO,iBAAiB,YACxB,OAAO,eAAe,UACtB;AAAA,IACA,OAAO,iBAAiB,aACpB,YAAY,iBACZ,aAAa,gBAAgB;AAAA,EACnC;AAAA,EAEA,MAAM,QACJ,kBAAiB,SAAS,SAAS,MAClC,MAAM,QAAQ,SAAS,UAAU,IAC9B,kBAAiB,SAAS,WAAW,EAAE,IACvC;AAAA,EACN,IAAI,OAAO;AAAA,IACT,MAAM,aAAa,4BACjB,kBAAiB,SAAS,qBAAqB,GAC/C,kBAAiB,SAAS,qBAAqB,CACjD;AAAA,IACA,MAAM,cAAc,6BAClB,kBAAiB,SAAS,sBAAsB,GAChD,kBAAiB,SAAS,oBAAoB,CAChD;AAAA,IACA,MAAM,WAAW,0BACf,kBAAiB,SAAS,mBAAmB,GAC7C,kBAAiB,SAAS,iBAAiB,CAC7C;AAAA,IACA,MAAM,UAAU,sBAAsB,QAAQ;AAAA,IAC9C,IAAI,cAAc,YAAY,aAAa;AAAA,MACzC,OAAO,SAAS,SAAS,cAAc,YAAY;AAAA,IACrD;AAAA,IACA,IAAI,cAAc,UAAU;AAAA,MAC1B,OAAO,SAAS,SAAS,cAAc;AAAA,IACzC;AAAA,IACA,IAAI,cAAc,aAAa;AAAA,MAC7B,OAAO,SAAS,SAAS,cAAc;AAAA,IACzC;AAAA,IACA,IAAI,YAAY;AAAA,MACd,OAAO,SAAS,SAAS;AAAA,IAC3B;AAAA,IACA,IAAI,YAAY,aAAa;AAAA,MAC3B,OAAO,SAAS,SAAS,YAAY;AAAA,IACvC;AAAA,IACA,IAAI,UAAU;AAAA,MACZ,OAAO,SAAS,SAAS;AAAA,IAC3B;AAAA,IACA,IAAI,aAAa;AAAA,MACf,OAAO,SAAS,SAAS;AAAA,IAC3B;AAAA,IACA,IAAI,QAAQ,SAAS,GAAG;AAAA,MACtB,OAAO,SAAS,YAAY,QAAQ,MAAM,GAAG,CAAC,EAAE,KAAK,IAAI;AAAA,IAC3D;AAAA,IACA,OAAO,SAAS;AAAA,EAClB;AAAA,EAEA,MAAM,QACJ,kBAAiB,SAAS,KAAK,KAC/B,kBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAC5B,SAAS,aAAa,IACtB;AAAA,EACN,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,IAAI,OAAO;AAAA,IACT,IAAI,YAAY;AAAA,MACd,OAAO,SAAS,SAAS;AAAA,IAC3B;AAAA,IACA,OAAO,SAAS;AAAA,EAClB;AAAA,EAEA,MAAM,eACJ,kBAAiB,SAAS,eAAe,KACzC,kBAAiB,SAAS,WAAW,KACrC,kBAAiB,SAAS,gBAAgB,KAC1C,kBAAiB,SAAS,SAAS;AAAA,EACrC,IAAI,cAAc;AAAA,IAChB,OAAO,iBAAiB;AAAA,EAC1B;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,IAAI,aAAa;AAAA,IACf,OAAO,UAAU;AAAA,EACnB;AAAA,EAEA,MAAM,UAAU,kBAAiB,SAAS,OAAO;AAAA,EACjD,IAAI,SAAS;AAAA,IACX,OAAO,WAAW;AAAA,EACpB;AAAA,EACA,IAAI,cAAc;AAAA,IAChB,OAAO,WAAW;AAAA,EACpB;AAAA,EAEA;AAAA;AAGF,IAAM,qBAAoB,CACxB,UACA,QACA,UACG;AAAA,EACH,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,iBAAiB,kBAAiB,SAAS,cAAc;AAAA,EAC/D,MAAM,uBAAuB,kBAAiB,SAAS,oBAAoB;AAAA,EAC3E,MAAM,qBAAqB,kBAAiB,SAAS,kBAAkB;AAAA,EACvE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,0BAA0B,kBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,sBAAsB,kBAAiB,SAAS,mBAAmB;AAAA,EACzE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EAEvD,MAAM,OACJ,kBAAiB,SAAS,IAAI,KAC9B,kBAAiB,SAAS,UAAU,MACnC,OAAO,SAAS,cAAc,WAC3B,SAAS,YAAY,IACrB;AAAA,EACN,MAAM,SACJ,kBAAiB,SAAS,YAAY,MACrC,OAAO,SAAS,gBAAgB,WAC7B,SAAS,cAAc,IACvB;AAAA,EACN,MAAM,eAAe,kBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,IAAI,QAAQ,QAAQ;AAAA,IAClB,OAAO,QAAQ,iBAAgB;AAAA,EACjC;AAAA,EACA,IAAI,QAAQ,kBAAkB,oBAAoB,kBAAkB;AAAA,IAClE,OAAO,QAAQ,yBAAwB;AAAA,EACzC;AAAA,EACA,IAAI,QAAQ,kBAAkB,oBAAoB,eAAe;AAAA,IAC/D,OAAO,QAAQ,sBAAqB;AAAA,EACtC;AAAA,EACA,IAAI,QAAQ,kBAAkB,gBAAgB,cAAc;AAAA,IAC1D,IACE,OAAO,yBAAyB,YAChC,OAAO,uBAAuB,UAC9B;AAAA,MACA,OAAO,yBAAyB,qBAC5B,QAAQ,sBAAqB,wBAAwB,yBACrD,QAAQ,sBAAqB,yBAAyB,wBAAwB;AAAA,IACpF;AAAA,IACA,OAAO,QAAQ,sBAAqB;AAAA,EACtC;AAAA,EACA,IAAI,QAAQ,gBAAgB;AAAA,IAC1B,OAAO,QAAQ,qBAAoB;AAAA,EACrC;AAAA,EACA,IAAI,MAAM;AAAA,IACR,OAAO,QAAQ;AAAA,EACjB;AAAA,EACA,IAAI,OAAO,iBAAiB,YAAY,OAAO,eAAe,UAAU;AAAA,IACtE,OAAO,iBAAiB,aACpB,QAAQ,iBACR,SAAS,gBAAgB;AAAA,EAC/B;AAAA,EAEA,MAAM,QACJ,kBAAiB,SAAS,SAAS,MAClC,MAAM,QAAQ,SAAS,UAAU,IAC9B,kBAAiB,SAAS,WAAW,EAAE,IACvC;AAAA,EACN,IAAI,OAAO;AAAA,IACT,MAAM,aAAa,4BACjB,kBAAiB,SAAS,qBAAqB,GAC/C,kBAAiB,SAAS,qBAAqB,CACjD;AAAA,IACA,MAAM,cAAc,6BAClB,kBAAiB,SAAS,sBAAsB,GAChD,kBAAiB,SAAS,oBAAoB,CAChD;AAAA,IACA,MAAM,WAAW,0BACf,qBACA,iBACF;AAAA,IACA,IAAI,cAAc,YAAY,aAAa;AAAA,MACzC,OAAO,SAAS,WAAU,gBAAgB,cAAc;AAAA,IAC1D;AAAA,IACA,IAAI,cAAc,UAAU;AAAA,MAC1B,OAAO,SAAS,WAAU,gBAAgB;AAAA,IAC5C;AAAA,IACA,IAAI,cAAc,aAAa;AAAA,MAC7B,OAAO,SAAS,WAAU,gBAAgB;AAAA,IAC5C;AAAA,IACA,IAAI,YAAY;AAAA,MACd,OAAO,SAAS,WAAU;AAAA,IAC5B;AAAA,IACA,IAAI,YAAY,aAAa;AAAA,MAC3B,OAAO,SAAS,WAAU,cAAc;AAAA,IAC1C;AAAA,IACA,IAAI,UAAU;AAAA,MACZ,OAAO,SAAS,WAAU;AAAA,IAC5B;AAAA,IACA,OAAO,cAAc,SAAS,WAAU,gBAAgB,SAAS;AAAA,EACnE;AAAA,EAEA,MAAM,QACJ,kBAAiB,SAAS,KAAK,KAC/B,kBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAC5B,SAAS,aAAa,IACtB;AAAA,EACN,IAAI,OAAO;AAAA,IACT,OAAO,aAAa,SAAS,WAAU,eAAe,SAAS;AAAA,EACjE;AAAA,EAEA,MAAM,eACJ,kBAAiB,SAAS,eAAe,KACzC,kBAAiB,SAAS,WAAW,KACrC,kBAAiB,SAAS,gBAAgB,KAC1C,kBAAiB,SAAS,SAAS;AAAA,EACrC,IAAI,cAAc;AAAA,IAChB,OAAO,iBAAiB;AAAA,EAC1B;AAAA,EAEA,MAAM,YAAY,kBAAiB,SAAS,SAAS;AAAA,EACrD,IAAI,cAAc,cAAc;AAAA,IAC9B,MAAM,iBACJ,kBAAiB,SAAS,cAAc,KACxC,mBAAkB,QAAQ,KAAK;AAAA,IACjC,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,IACvD,IAAI,kBAAkB,cAAc,aAAa,GAAG;AAAA,MAClD,OAAO,cAAc,gCAA+B;AAAA,IACtD;AAAA,IACA,OAAO,iBAAiB,cAAc,mBAAmB;AAAA,EAC3D;AAAA,EAEA,MAAM,aAAa,sBAAqB,SAAS,OAAO;AAAA,EACxD,MAAM,WAAW,sBAAqB,SAAS,KAAK;AAAA,EACpD,IAAI,cAAc,UAAU;AAAA,IAC1B,OAAO,aAAa,gBAAgB;AAAA,EACtC;AAAA,EAEA,IAAI,YAAY;AAAA,IACd,OAAO,aAAa;AAAA,EACtB;AAAA,EAEA,IAAI,qBAAqB,oBAAoB,SAAS;AAAA,IACpD,IACE,OAAO,4BAA4B,YACnC,OAAO,0BAA0B,UACjC;AAAA,MACA,OAAO,4BAA4B,wBAC/B,sBAAsB,2BAA0B,4BAChD,sBAAsB,4BAA2B,2BAA2B;AAAA,IAClF;AAAA,IACA,OAAO,sBAAsB;AAAA,EAC/B;AAAA,EACA,IAAI,qBAAqB,oBAAoB,QAAQ;AAAA,IACnD,OAAO,qBAAqB;AAAA,EAC9B;AAAA,EACA,IAAI,qBAAqB,oBAAoB,aAAa;AAAA,IACxD,OAAO,0BAA0B;AAAA,EACnC;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,IAAI,YAAY,SAAS,GAAG;AAAA,IAC1B,OAAO,WAAW,YAAY,KAAK,KAAK;AAAA,EAC1C;AAAA,EAEA;AAAA;AAGF,IAAM,wBAAuB,CAAC,aAAuC;AAAA,EACnE,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,MAAM,qBAAqB,kBAAiB,SAAS,kBAAkB;AAAA,EACvE,MAAM,sBAAsB,kBAAiB,SAAS,mBAAmB;AAAA,EACzE,MAAM,OAAO,kBAAiB,SAAS,IAAI;AAAA,EAC3C,MAAM,SACJ,sBAAqB,SAAS,MAAM,KACpC,sBAAqB,SAAS,UAAU;AAAA,EAC1C,MAAM,UAAU,kBAAiB,SAAS,OAAO;AAAA,EACjD,MAAM,YAAY,kBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,mBAAmB,kBAAiB,SAAS,gBAAgB;AAAA,EACnE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,yBAAyB,kBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,eAAe,kBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,qBAAqB,0BAAyB,SAAS,eAAe;AAAA,EAC5E,MAAM,kCAAkC,0BACtC,SAAS,2BACX;AAAA,EACA,MAAM,uBAAuB,0BAC3B,SAAS,6BACX;AAAA,EACA,MAAM,qBAAqB,sBAAsB,QAAQ;AAAA,EACzD,MAAM,kBAAkB,MAAM,QAAQ,SAAS,eAAe,IAC1D,SAAS,gBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,sBAAsB,kBAAiB,SAAS,mBAAmB;AAAA,EACzE,MAAM,uBAAuB,kBAAiB,SAAS,oBAAoB;AAAA,EAC3E,MAAM,yBAAyB,6BAC7B,kBAAiB,SAAS,sBAAsB,GAChD,kBAAiB,SAAS,oBAAoB,CAChD;AAAA,EACA,MAAM,iBAAiB,kBAAiB,SAAS,cAAc;AAAA,EAC/D,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,2BAA2B,kBAC/B,SAAS,wBACX;AAAA,EACA,MAAM,wBAAwB,6BAC5B,SAAS,gBACX;AAAA,EACA,MAAM,qBAAqB,MAAM,QAAQ,SAAS,kBAAkB,IAChE,SAAS,mBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,yBAAyB,kBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,0BAA0B,kBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,0BAA0B,kBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EACA,MAAM,yBAAyB,kBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,0BAA0B,kBAC9B,SAAS,uBACX;AAAA,EACA,MAAM,YAAY,kBAAiB,SAAS,SAAS;AAAA,EACrD,MAAM,yBAAyB,kBAC7B,SAAS,sBACX;AAAA,EACA,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,eAAe,kBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,qBAAqB,kBAAiB,SAAS,kBAAkB;AAAA,EACvE,MAAM,uBAAuB,kBAAiB,SAAS,oBAAoB;AAAA,EAC3E,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,yBAAyB,6BAC7B,SAAS,sBACX;AAAA,EACA,MAAM,uBAAuB,+BAA+B,QAAQ;AAAA,EACpE,MAAM,wBAAwB,4BAC5B,kBAAiB,SAAS,qBAAqB,GAC/C,kBAAiB,SAAS,qBAAqB,CACjD;AAAA,EACA,MAAM,gBACJ,kBAAiB,SAAS,mBAAmB,KAC7C,kBAAiB,SAAS,aAAa;AAAA,EACzC,MAAM,uBACJ,kBAAiB,SAAS,wBAAwB,KAClD,kBAAiB,SAAS,oBAAoB;AAAA,EAChD,MAAM,mBACJ,kBAAiB,SAAS,oBAAoB,KAC9C,kBAAiB,SAAS,gBAAgB;AAAA,EAC5C,MAAM,mBACJ,kBAAiB,SAAS,oBAAoB,KAC9C,kBAAiB,SAAS,gBAAgB;AAAA,EAC5C,MAAM,iBAAiB,kBAAiB,SAAS,cAAc;AAAA,EAC/D,MAAM,uBAAuB,kBAAiB,SAAS,oBAAoB;AAAA,EAC3E,MAAM,qBAAqB,kBAAiB,SAAS,kBAAkB;AAAA,EAEvE,MAAM,SAAS;AAAA,IACb,cAAc,OAAO,gBAAgB;AAAA,IACrC,kBAAkB,gBAAgB,oBAAoB;AAAA,IACtD,oBAAoB,cAAc,sBAAsB;AAAA,IACxD,wBAAwB,kBAAkB,0BAA0B;AAAA,IACpE,oBAAoB,mBAAmB,uBAAuB;AAAA,IAC9D,oBAAoB,gBAAgB,oBAAoB;AAAA,IACxD,oBAAoB,mBAChB,KACA,oBAAoB,gBAClB,KACA,gBAAgB,eACd,oBACA,gBAAgB,cACd,mBACA;AAAA,IACV,kBAAkB,UAAU,oBAAoB;AAAA,IAChD,OAAO,6BAA6B,WAChC,eAAe,mCACf;AAAA,IACJ,yBAAyB;AAAA,IACzB,YAAY,OAAO,cAAc;AAAA,IACjC,yBAAyB,aAAa,2BAA2B;AAAA,IACjE,kBAAkB,YAAY,oBAAoB;AAAA,IAClD,0BAA0B;AAAA,IAC1B,wBAAwB;AAAA,IACxB,OAAO,kBAAkB,WACrB,cAAc,cAAc,QAAQ,CAAC,MACrC;AAAA,IACJ,OAAO,yBAAyB,YAChC,yBAAyB,gBACrB,WAAW,qBAAqB,QAAQ,CAAC,MACzC;AAAA,IACJ,OAAO,qBAAqB,YAC5B,OAAO,qBAAqB,YAC5B,qBAAqB,mBACjB,SAAS,iBAAiB,QAAQ,CAAC,KAAK,iBAAiB,QAAQ,CAAC,MAClE;AAAA,IACJ,OAAO,mBAAmB,WAAW,GAAG,2BAA2B;AAAA,IACnE,gBAAgB,SAAS,IAAI,aAAa,gBAAgB,KAAK,IAAI,MAAM;AAAA,IACzE,OAAO,wBAAwB,WAC3B,aAAa,6BACb;AAAA,IACJ,OAAO,yBAAyB,WAC5B,aAAa,mCACb;AAAA,IACJ,OAAO,yBAAyB,YAChC,OAAO,uBAAuB,WAC1B,yBAAyB,qBACvB,iBAAiB,yBACjB,kBAAkB,wBAAwB,uBAC5C;AAAA,IACJ,wBAAwB,uBAAuB,0BAA0B;AAAA,IACzE,mBAAmB,SAAS,IACxB,gBAAgB,mBAAmB,KAAK,IAAI,MAC5C;AAAA,IACJ,OAAO,2BAA2B,WAC9B,gBAAgB,gCAChB;AAAA,IACJ,OAAO,4BAA4B,WAC/B,gBAAgB,sCAChB;AAAA,IACJ,OAAO,4BAA4B,YACnC,OAAO,0BAA0B,WAC7B,4BAA4B,wBAC1B,oBAAoB,4BACpB,qBAAqB,2BAA2B,0BAClD;AAAA,IACJ,yBACI,wBAAwB,2BACxB;AAAA,IACJ,0BACI,0BAA0B,4BAC1B;AAAA,IACJ,mBAAmB,SAAS,IACxB,eAAe,mBAAmB,KAAK,IAAI,MAC3C;AAAA,IACJ,yBAAyB,eAAe,2BAA2B;AAAA,IACnE,wBAAwB,eAAe,0BAA0B;AAAA,IACjE,YAAY,SAAS,cAAc;AAAA,IACnC,oBAAoB,GAAG,+BAA+B;AAAA,IACtD,wBAAwB,GAAG,2CAA2C;AAAA,IACtE,2BAA2B,YACvB,iBAAiB,yBAAyB,MAC1C;AAAA,IACJ,eAAe,WAAW,iBAAiB;AAAA,IAC3C,oBAAoB,GAAG,+BAA+B;AAAA,IACtD,qBAAqB,YAAY,uBAAuB;AAAA,IACxD,kCACI,kBAAkB,oCAClB;AAAA,IACJ,uBACI,OAAO,8CACP;AAAA,IACJ,mBAAmB,cAAc,qBAAqB;AAAA,IACtD,cAAc,UAAU,gBAAgB;AAAA,IACxC,sBAAsB,eAAe,wBAAwB;AAAA,IAC7D,qBAAqB,GAAG,uCAAuC;AAAA,IAC/D,aAAa,eAAe,eAAe;AAAA,IAC3C,iBAAiB,kBAAkB;AAAA,IACnC,eAAe,iBAAiB,iBAAiB;AAAA,IACjD,qBAAqB,wBAAwB,uBAAuB;AAAA,IACpE,uBAAuB,qBAAqB,yBAAyB;AAAA,IACrE,kBAAkB,gBAAgB,oBAAoB;AAAA,IACtD,UAAU,WAAW,YAAY;AAAA,IACjC,OAAO,UAAU,SAAS;AAAA,IAC1B,SAAS,QAAQ,WAAW;AAAA,EAC9B,EAAE,OAAO,CAAC,UAAU,MAAM,SAAS,CAAC;AAAA,EAEpC,OAAO,OAAO,SAAS,IAAI,OAAO,KAAK,KAAI,IAAI;AAAA;AAG1C,IAAM,uBAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,MAKiC;AAAA,EACjC,MAAM,eAAe,mBAAkB,QAAQ;AAAA,EAC/C,MAAM,eAAe,mBAAkB,UAAU,QAAQ,KAAK;AAAA,EAC9D,MAAM,kBAAkB,sBAAqB,QAAQ;AAAA,EAErD,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,iBAAiB;AAAA,IACtD;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA;AAGK,IAAM,yBAAyB,CACpC,aACkC;AAAA,EAClC,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YAAY,OACnB,CAAC,UACC,OAAO,UAAU,YAAY,MAAM,KAAK,EAAE,SAAS,CACvD,IACA;AAAA,EACJ,MAAM,cACJ,SAAS,gBAAgB,sBACzB,SAAS,gBAAgB,kBACzB,SAAS,gBAAgB,oBACzB,SAAS,gBAAgB,kBACzB,SAAS,gBAAgB,eACzB,SAAS,gBAAgB,sBACzB,SAAS,gBAAgB,uBACrB,SAAS,cACT;AAAA,EACN,MAAM,UAAqD;AAAA,IACzD,OAAO,kBAAiB,SAAS,YAAY;AAAA,IAC7C,MAAM;AAAA,IACN,MAAM,eAAe,YAAY,SAAS,IAAI,cAAc;AAAA,IAC5D,OAAO,kBAAiB,SAAS,YAAY;AAAA,EAC/C;AAAA,EACA,MAAM,WAAuD;AAAA,IAC3D,aAAa,kBAAiB,SAAS,WAAW;AAAA,IAClD,iBAAiB,kBAAiB,SAAS,eAAe;AAAA,IAC1D,mBAAmB,kBAAiB,SAAS,iBAAiB;AAAA,IAC9D,gBAAgB,kBAAiB,SAAS,cAAc;AAAA,IACxD,mBAAmB,kBAAiB,SAAS,iBAAiB;AAAA,EAChE;AAAA,EAEA,IACE,CAAC,QAAQ,UACR,CAAC,QAAQ,QAAQ,QAAQ,KAAK,WAAW,MAC1C,OAAO,QAAQ,UAAU,YACzB,CAAC,QAAQ,QACT,CAAC,SAAS,eACV,CAAC,SAAS,mBACV,OAAO,SAAS,sBAAsB,YACtC,CAAC,SAAS,kBACV,OAAO,SAAS,sBAAsB,UACtC;AAAA,IACA;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL,SACE,QAAQ,SACP,QAAQ,QAAQ,QAAQ,KAAK,SAAS,KACvC,OAAO,QAAQ,UAAU,YACzB,QAAQ,OACJ,UACA;AAAA,IACN,UACE,SAAS,eACT,SAAS,mBACT,OAAO,SAAS,sBAAsB,YACtC,SAAS,kBACT,OAAO,SAAS,sBAAsB,WAClC,WACA;AAAA,EACR;AAAA;AAGF,IAAM,gBAAe,CAAC,MAAc,YAAY,QAAQ;AAAA,EACtD,MAAM,aAAa,KAAK,WAAW,QAAQ,GAAG,EAAE,KAAK;AAAA,EACrD,IAAI,WAAW,UAAU,WAAW;AAAA,IAClC,OAAO;AAAA,EACT;AAAA,EAEA,OAAO,GAAG,WAAW,MAAM,GAAG,KAAK,IAAI,GAAG,YAAY,CAAC,CAAC,EAAE,QAAQ;AAAA;AAQ7D,IAAM,wBAAwB,CACnC,QACA,kBACiC;AAAA,EACjC,IAAI,OAAO,WAAW,GAAG;AAAA,IACvB;AAAA,EACF;AAAA,EAEA,MAAM,QAAQ,mBACZ,OAAO,IAAI,CAAC,WAAW;AAAA,IACrB,SAAS,MAAM;AAAA,IACf,UAAU,MAAM;AAAA,IAChB,WAAW,MAAM;AAAA,EACnB,EAAE,CACJ;AAAA,EACA,MAAM,aAAa,6BAA6B,OAAO,aAAa;AAAA,EACpE,MAAM,cACJ,OAAO,KAAK,CAAC,UAAU,MAAM,YAAY,WAAW,aAAa,KACjE,OAAO;AAAA,EACT,IAAI,CAAC,aAAa;AAAA,IAChB;AAAA,EACF;AAAA,EAEA,MAAM,WAAW,IAAI,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,SAAS,KAAK,CAAC,CAAC;AAAA,EACtE,MAAM,oBACJ,WAAW,aAAa,SAAS,IAC7B,WAAW,aAAa,IAAI,CAAC,SAAS,KAAK,OAAO,IAClD,CAAC,YAAY,OAAO;AAAA,EAC1B,MAAM,mBACJ,WAAW,aAAa,SAAS,KAC5B,MAAM;AAAA,IACL,MAAM,cAAc,WAAW,aAAa,UAC1C,CAAC,SAAS,KAAK,YAAY,YAAY,OACzC;AAAA,IACA,MAAM,aAAa,KAAK,IAAI,GAAG,cAAc,CAAC;AAAA,IAC9C,MAAM,WAAW,KAAK,IACpB,WAAW,aAAa,QACxB,cAAc,CAChB;AAAA,IACA,OAAO,WAAW,aACf,MAAM,YAAY,QAAQ,EAC1B,IAAI,CAAC,SAAS,KAAK,OAAO;AAAA,KAC5B,IACH;AAAA,IACE,WAAW,cAAc;AAAA,IACzB,YAAY;AAAA,IACZ,WAAW,UAAU;AAAA,EACvB,EAAE,OACA,CAAC,SAAS,OAAO,QACf,QAAQ,OAAO,KAAK,IAAI,QAAQ,OAAO,MAAM,KACjD;AAAA,EAEN,MAAM,cAAc,CAAC,aACnB,SACG,IAAI,CAAC,YAAY,SAAS,IAAI,OAAO,GAAG,IAAI,EAC5C,OAAO,CAAC,SAAyB,OAAO,SAAS,QAAQ,EACzD,KAAK;AAAA;AAAA,CAAM;AAAA,EAEhB,OAAO;AAAA,IACL,cAAc,cAAa,YAAY,MAAM,GAAG;AAAA,IAChD,gBAAgB,cAAa,YAAY,iBAAiB,GAAG,GAAG;AAAA,IAChE,eAAe,cAAa,YAAY,gBAAgB,GAAG,GAAG;AAAA,EAChE;AAAA;AAWK,IAAM,2BAA2B,CACtC,UACA,cAC8C;AAAA,EAC9C,IAAI,CAAC,UAAU;AAAA,IACb,OAAO;AAAA,MACL,SAAS;AAAA,MACT,MAAM;AAAA,MACN,QAAQ;AAAA,IACV;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,SAAS,aAAa,KAAK,EAAE;AAAA,EACjD,MAAM,oBAAoB,WAAW,UAAU,qBAAqB;AAAA,EACpE,IAAI,oBAAoB,KAAK,cAAc,KAAK,cAAc,IAAI;AAAA,IAChE,IAAI,qBAAqB,KAAK,SAAS,eAAe,KAAK,EAAE,SAAS,GAAG;AAAA,MACvE,OAAO;AAAA,QACL,SAAS,SAAS;AAAA,QAClB,MAAM;AAAA,QACN,QAAQ;AAAA,MACV;AAAA,IACF;AAAA,IACA,IAAI,SAAS,cAAc,KAAK,EAAE,SAAS,GAAG;AAAA,MAC5C,OAAO;AAAA,QACL,SAAS,SAAS;AAAA,QAClB,MAAM;AAAA,QACN,QAAQ;AAAA,MACV;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,MACL,SAAS,SAAS;AAAA,MAClB,MAAM;AAAA,MACN,QAAQ;AAAA,IACV;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,MAAM;AAAA,IACN,QAAQ,oBAAoB,IAAI,qBAAqB;AAAA,EACvD;AAAA;AAGK,IAAM,4BAA4B,CACvC,eAEA,WAAW,OACT,CAAC,QAAQ,cAAc;AAAA,EACrB,IAAI,WAAW;AAAA,IACb,OAAO,UAAU,SAAS;AAAA,EAC5B;AAAA,EACA,OAAO;AAAA,GAET,EAAE,OAAO,GAAG,SAAS,GAAG,QAAQ,EAAE,CACpC;AAQK,IAAM,qBAAqB,CAChC,WACkB;AAAA,EAClB,MAAM,QAA6B,CAAC;AAAA,EACpC,MAAM,QAA6B,CAAC;AAAA,EACpC,MAAM,WAAW,IAAI;AAAA,EACrB,MAAM,WAAW,IAAI;AAAA,EAErB,WAAW,SAAS,QAAQ;AAAA,IAC1B,MAAM,SACJ,MAAM,UACN,qBAAqB;AAAA,MACnB,UAAU,MAAM;AAAA,MAChB,QAAQ,MAAM;AAAA,MACd,OAAO,MAAM;AAAA,IACf,CAAC;AAAA,IACH,MAAM,YAAY,MAAM,aAAa,uBAAuB,MAAM,QAAQ;AAAA,IAE1E,MAAM,KAAK;AAAA,MACT,SAAS,MAAM;AAAA,MACf,cAAc,QAAQ;AAAA,MACtB,OAAO,MAAM,UAAU,MAAM,SAAS,MAAM;AAAA,MAC5C,cAAc,QAAQ;AAAA,MACtB,iBAAiB,QAAQ;AAAA,MACzB,OAAO,MAAM;AAAA,MACb,QAAQ,MAAM;AAAA,MACd;AAAA,MACA,OAAO,MAAM;AAAA,IACf,CAAC;AAAA,IAED,MAAM,kBAAkB,WAAW,UAAU;AAAA,IAC7C,IAAI,iBAAiB;AAAA,MACnB,MAAM,MAAM,YAAY,mBAAmB,MAAM;AAAA,MACjD,IAAI,CAAC,SAAS,IAAI,GAAG,GAAG;AAAA,QACtB,SAAS,IAAI,GAAG;AAAA,QAChB,MAAM,KAAK;AAAA,UACT,aAAa;AAAA,UACb,UAAU;AAAA,UACV,WAAW,MAAM;AAAA,QACnB,CAAC;AAAA,MACH;AAAA,IACF;AAAA,IAEA,MAAM,cAAc,WAAW,UAAU;AAAA,IACzC,IAAI,aAAa;AAAA,MACf,MAAM,MAAM,QAAQ,MAAM,WAAW;AAAA,MACrC,IAAI,CAAC,SAAS,IAAI,GAAG,GAAG;AAAA,QACtB,SAAS,IAAI,GAAG;AAAA,QAChB,MAAM,KAAK;AAAA,UACT,aAAa,MAAM;AAAA,UACnB,UAAU;AAAA,UACV,WAAW;AAAA,QACb,CAAC;AAAA,MACH;AAAA,IACF;AAAA,IAEA,MAAM,YAAY,WAAW,UAAU;AAAA,IACvC,IAAI,WAAW;AAAA,MACb,MAAM,WAAW,SAAS,IAAI,SAAS;AAAA,MACvC,IAAI,CAAC,UAAU;AAAA,QACb,SAAS,IAAI,WAAW;AAAA,UACtB,iBAAiB,CAAC;AAAA,UAClB,YAAY,UAAU,UAAU,qBAAqB;AAAA,UACrD,UAAU,CAAC,MAAM,OAAO;AAAA,UACxB,OAAO,UAAU,SAAS;AAAA,UAC1B,IAAI;AAAA,UACJ,MAAM,UAAU,SAAS;AAAA,UACzB,aAAa,MAAM;AAAA,UACnB,MAAM,UAAU,SAAS;AAAA,UACzB,OAAO,UAAU,SAAS;AAAA,QAC5B,CAAC;AAAA,QACD;AAAA,MACF;AAAA,MAEA,IAAI,CAAC,SAAS,SAAS,SAAS,MAAM,OAAO,GAAG;AAAA,QAC9C,SAAS,SAAS,KAAK,MAAM,OAAO;AAAA,MACtC;AAAA,MACA,SAAS,aAAa,KAAK,IACzB,SAAS,YACT,UAAU,UAAU,qBAAqB,SAAS,UACpD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,WAAW,WAAW,SAAS,OAAO,GAAG;AAAA,IACvC,QAAQ,SAAS,KAAK,CAAC,MAAM,UAAU;AAAA,MACrC,MAAM,WAAW,MAAM,KAAK,CAAC,SAAS,KAAK,YAAY,IAAI;AAAA,MAC3D,MAAM,YAAY,MAAM,KAAK,CAAC,SAAS,KAAK,YAAY,KAAK;AAAA,MAC7D,MAAM,YACJ,UAAU,WAAW,UAAU,qBAC/B,OAAO;AAAA,MACT,MAAM,aACJ,WAAW,WAAW,UAAU,qBAChC,OAAO;AAAA,MACT,IAAI,cAAc,YAAY;AAAA,QAC5B,OAAO,YAAY;AAAA,MACrB;AAAA,MAEA,OAAO,KAAK,cAAc,KAAK;AAAA,KAChC;AAAA,IACD,QAAQ,cAAc,QAAQ,SAAS;AAAA,EACzC;AAAA,EAEA,MAAM,mBAAmB,IAAI;AAAA,EAC7B,WAAW,WAAW,SAAS,OAAO,GAAG;AAAA,IACvC,MAAM,OACJ,QAAQ,QAAQ,QAAQ,KAAK,SAAS,IAClC,QAAQ,OACR,QAAQ,QACN,CAAC,QAAQ,KAAK,IACd;AAAA,IACR,IAAI,QAAQ,KAAK,SAAS,GAAG;AAAA,MAC3B,iBAAiB,IAAI,KAAK,KAAK,MAAQ,GAAG,OAAO;AAAA,IACnD;AAAA,EACF;AAAA,EAEA,WAAW,WAAW,SAAS,OAAO,GAAG;AAAA,IACvC,MAAM,OACJ,QAAQ,QAAQ,QAAQ,KAAK,SAAS,IAClC,QAAQ,OACR,QAAQ,QACN,CAAC,QAAQ,KAAK,IACd;AAAA,IACR,IAAI,CAAC,QAAQ,KAAK,SAAS,GAAG;AAAA,MAC5B;AAAA,IACF;AAAA,IAEA,MAAM,SAAS,iBAAiB,IAAI,KAAK,MAAM,GAAG,EAAE,EAAE,KAAK,MAAQ,CAAC;AAAA,IACpE,IAAI,CAAC,UAAU,OAAO,OAAO,QAAQ,IAAI;AAAA,MACvC;AAAA,IACF;AAAA,IAEA,QAAQ,kBAAkB,OAAO;AAAA,IACjC,IAAI,CAAC,OAAO,gBAAgB,SAAS,QAAQ,EAAE,GAAG;AAAA,MAChD,OAAO,gBAAgB,KAAK,QAAQ,EAAE;AAAA,IACxC;AAAA,IAEA,IAAI,OAAO,eAAe,QAAQ,aAAa;AAAA,MAC7C,MAAM,YAAY,kBAAkB,QAAQ,eAAe,OAAO;AAAA,MAClE,IAAI,CAAC,SAAS,IAAI,SAAS,GAAG;AAAA,QAC5B,SAAS,IAAI,SAAS;AAAA,QACtB,MAAM,KAAK;AAAA,UACT,aAAa,QAAQ;AAAA,UACrB,UAAU;AAAA,UACV,WAAW,OAAO;AAAA,QACpB,CAAC;AAAA,MACH;AAAA,MAEA,MAAM,WAAW,iBAAiB,OAAO,eAAe,QAAQ;AAAA,MAChE,IAAI,CAAC,SAAS,IAAI,QAAQ,GAAG;AAAA,QAC3B,SAAS,IAAI,QAAQ;AAAA,QACrB,MAAM,KAAK;AAAA,UACT,aAAa,OAAO;AAAA,UACpB,UAAU;AAAA,UACV,WAAW,QAAQ;AAAA,QACrB,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,KAAK,CAAC,MAAM,UAAU;AAAA,IAC1B,MAAM,cACJ,KAAK,WAAW,UAAU,qBAAqB,OAAO;AAAA,IACxD,MAAM,eACJ,MAAM,WAAW,UAAU,qBAAqB,OAAO;AAAA,IACzD,IAAI,gBAAgB,cAAc;AAAA,MAChC,OAAO,cAAc;AAAA,IACvB;AAAA,IAEA,MAAM,YAAY,KAAK,SAAS,OAAO;AAAA,IACvC,MAAM,aAAa,MAAM,SAAS,OAAO;AAAA,IACzC,IAAI,cAAc,YAAY;AAAA,MAC5B,OAAO,aAAa;AAAA,IACtB;AAAA,IAEA,OAAO,KAAK,MAAM,cAAc,MAAM,KAAK;AAAA,GAC5C;AAAA,EAED,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,UAAU,CAAC,GAAG,SAAS,OAAO,CAAC,EAAE,KAAK,CAAC,MAAM,WAC1C,KAAK,SAAS,KAAK,IAAI,cAAc,MAAM,SAAS,MAAM,EAAE,CAC/D;AAAA,EACF;AAAA;AAGK,IAAM,4BAA4B,CACvC,YAEA,mBACE,QAAQ,OAAO,IAAI,CAAC,WAAW;AAAA,EAC7B,SAAS,MAAM;AAAA,EACf,QAAQ,MAAM;AAAA,EACd,UAAU,MAAM;AAAA,EAChB,QAAQ,MAAM,UAAU,QAAQ,SAAS;AAAA,EACzC,WAAW,MAAM;AAAA,EACjB,OAAO,MAAM,SAAS,QAAQ,SAAS;AACzC,EAAE,CACJ;AAEK,IAAM,iCAAiC,CAC5C,SACA,kBAEA,6BACE,0BAA0B,OAAO,GACjC,aACF;AAEK,IAAM,+BAA+B,CAC1C,OACA,kBAC4B;AAAA,EAC5B,IAAI,MAAM,MAAM,WAAW,GAAG;AAAA,IAC5B,OAAO;AAAA,MACL;AAAA,MACA,eAAe,CAAC;AAAA,MAChB,iBAAiB,CAAC;AAAA,MAClB,cAAc,CAAC;AAAA,IACjB;AAAA,EACF;AAAA,EAEA,MAAM,cACH,gBACG,MAAM,MAAM,KAAK,CAAC,SAAS,KAAK,YAAY,aAAa,IACzD,cAAc,MAAM,MAAM;AAAA,EAChC,MAAM,wBAAwB,YAAY;AAAA,EAC1C,MAAM,eAAe,YAAY,WAAW,UAAU,kBAClD,MAAM,MAAM,KACV,CAAC,SACC,KAAK,YAAY,WAAW,WAAW,UAAU,eACrD,IACA;AAAA,EACJ,MAAM,WAAW,YAAY,WAAW,UAAU,cAC9C,MAAM,MAAM,KACV,CAAC,SAAS,KAAK,YAAY,WAAW,WAAW,UAAU,WAC7D,IACA;AAAA,EACJ,MAAM,UAAU,YAAY,WAAW,UAAU,iBAC7C,MAAM,SAAS,KACb,CAAC,UAAU,MAAM,OAAO,WAAW,WAAW,UAAU,cAC1D,IACA;AAAA,EACJ,MAAM,gBAAgB,SAAS,kBAC3B,MAAM,SAAS,KAAK,CAAC,UAAU,MAAM,OAAO,QAAQ,eAAe,IACnE;AAAA,EACJ,MAAM,gBAAgB,UAClB,QAAQ,gBACL,IAAI,CAAC,cACJ,MAAM,SAAS,KAAK,CAAC,UAAU,MAAM,OAAO,SAAS,CACvD,EACC,OAAO,CAAC,UAA8C,QAAQ,KAAK,CAAC,IACvE,CAAC;AAAA,EACL,MAAM,kBAAkB,SAAS,kBAC7B,MAAM,SAAS,OACb,CAAC,UACC,MAAM,oBAAoB,QAAQ,mBAClC,MAAM,OAAO,QAAQ,EACzB,IACA,CAAC;AAAA,EACL,MAAM,eAAe,UACjB,QAAQ,SACL,IAAI,CAAC,YAAY,MAAM,MAAM,KAAK,CAAC,SAAS,KAAK,YAAY,OAAO,CAAC,EACrE,OAAO,CAAC,SAAoC,QAAQ,IAAI,CAAC,IAC5D,aACE,CAAC,UAAU,IACX,CAAC;AAAA,EAEP,OAAO;AAAA,IACL,eAAe;AAAA,IACf;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA;AAEK,IAAM,yBAAyB,CAAC,aAA0B;AAAA,EAC/D,MAAM,UAAU,0BAA0B,QAAQ;AAAA,EAElD,IAAI,CAAC,SAAS;AAAA,IACZ,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,UAAU,QAAQ,WAAW,CAAC;AAAA,EACpC,MAAM,YAAY,kBAAkB,OAAO;AAAA,EAC3C,MAAM,qBAAqB,oCACzB,SACA,oBAAoB,QAAQ,cAAc,IACtC,QAAQ,iBACR,SACN;AAAA,EACA,MAAM,kBAAkB,wBAAwB,OAAO;AAAA,EACvD,MAAM,iBAAiB,uBAAuB,QAAQ,SAAS,OAAO;AAAA,EAEtE,OAAO;AAAA,IACL,sBAAsB,6BAA6B,SAAS;AAAA,IAC5D;AAAA,IACA,gBAAgB,QAAQ;AAAA,IACxB,mBAAmB,0BAA0B;AAAA,MAC3C,GAAG,UAAU,IAAI,CAAC,aAAa,SAAS,gBAAgB;AAAA,MACxD,GAAG,gBAAgB,IAAI,CAAC,YAAY,QAAQ,gBAAgB;AAAA,IAC9D,CAAC;AAAA,IACD;AAAA,IACA,WAAW,QAAQ;AAAA,IACnB,qBAAqB,QAAQ;AAAA,IAC7B,oBAAoB,QAAQ;AAAA,IAC5B,aAAa,QAAQ;AAAA,IACrB,OAAO,oBAAoB,QAAQ,cAAc,IAC7C,QAAQ,iBACR;AAAA,IACJ;AAAA,IACA,cAAc,qBAAqB,OAAO;AAAA,IAC1C;AAAA,IACA;AAAA,EACF;AAAA;AAEK,IAAM,0BAA0B,CAAC,YAAyB;AAAA,EAC/D,MAAM,eAAe,qBAAqB,OAAO;AAAA,EACjD,MAAM,YAAY,kBAAkB,OAAO;AAAA,EAC3C,MAAM,uBAAuB,6BAA6B,SAAS;AAAA,EAEnE,OAAO,aAAa,IAAsB,CAAC,UAAU;AAAA,IACnD,MAAM,iBAAiB,UAAU,OAAO,CAAC,aACvC,MAAM,OAAO,KAAK,CAAC,UAAU,MAAM,YAAY,SAAS,OAAO,CACjE;AAAA,IACA,MAAM,YAAY,4BAA4B,MAAM,MAAM;AAAA,IAC1D,MAAM,WAAW,YACb,sBAAsB,MAAM,QAAQ,UAAU,OAAO,IACrD;AAAA,IACJ,MAAM,YACJ,WAAW,aAAa,uBAAuB,WAAW,QAAQ;AAAA,IACpE,MAAM,mBAAmB,yBAAyB,UAAU,SAAS;AAAA,IAErE,OAAO;AAAA,MACL,WAAW,MAAM;AAAA,MACjB,iBAAiB,eAAe,IAC9B,CAAC,aAAa,qBAAqB,SAAS,YAAY,CAC1D;AAAA,MACA,WAAW;AAAA,MACX,UAAU,MAAM,OAAO,IAAI,CAAC,UAAU,MAAM,OAAO;AAAA,MACnD,cACE,WAAW,QAAQ,gBACnB,mBAAkB,WAAW,QAAQ;AAAA,MACvC,OAAO,MAAM;AAAA,MACb,SAAS,iBAAiB,WAAW,cAAa,WAAW,QAAQ,EAAE;AAAA,MACvE;AAAA,MACA;AAAA,MACA,KAAK,MAAM;AAAA,MACX,OAAO,MAAM;AAAA,MACb,cACE,WAAW,QAAQ,gBACnB,mBACE,WAAW,UACX,WAAW,QACX,WAAW,KACb;AAAA,MACF,iBACE,WAAW,QAAQ,mBACnB,sBAAqB,WAAW,QAAQ;AAAA,MAC1C;AAAA,MACA,QAAQ,MAAM;AAAA,MACd,OAAO,MAAM;AAAA,IACf;AAAA,GACD;AAAA;AAGH,IAAM,2BAA2B,CAAC,WAAsB;AAAA,EACtD,MAAM,OACJ,OAAO,WAAW,SAAS,SAC1B,MAAM,QAAQ,OAAO,UAAU,WAAW,IACvC,OAAO,SAAS,YACb,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EAEP,OAAO,KAAK,SAAS,IAAI,OAAO;AAAA;AAGlC,IAAM,2BAA2B,CAAC,UAChC,OAAO,UAAU,aAChB,MAAM,WAAW,MAAM,KACtB,MAAM,WAAW,SAAS,KAC1B,MAAM,WAAW,QAAQ;AAE7B,IAAM,kCAAkC,CACtC,aACG;AAAA,EACH,IAAI,CAAC,UAAU;AAAA,IACb,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,cAAc,kBAAiB,SAAS,WAAW;AAAA,EACzD,MAAM,aAAa,kBAAiB,SAAS,UAAU;AAAA,EACvD,MAAM,iBAAiB,kBAAiB,SAAS,cAAc;AAAA,EAE/D,IAAI,gBAAgB,cAAc;AAAA,IAChC,OAAO;AAAA,EACT;AAAA,EACA,IAAI,oBAAoB,WAAW,oBAAoB,QAAQ;AAAA,IAC7D,OAAO;AAAA,EACT;AAAA,EACA,IACE,gBAAgB,eAChB,gBAAgB,kBAChB,oBAAoB,eACpB,gBAAgB,aAChB;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,IAAI,gBAAgB,wBAAwB,gBAAgB;AAAA,IAC1D,OAAO;AAAA,EACT;AAAA,EACA,IAAI,gBAAgB,wBAAwB,YAAY;AAAA,IACtD,OAAO;AAAA,EACT;AAAA,EAEA,OAAO;AAAA;AAGT,IAAM,+BAA+B,CAAC,WACpC,OAAO,QAAQ,gCAAgC,OAAO,QAAQ;AAEhE,IAAM,+BAA+B,CAAC,aAAuC;AAAA,EAC3E,IAAI,CAAC,UAAU;AAAA,IACb,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,kBAAkB,kBAAiB,SAAS,eAAe;AAAA,EACjE,MAAM,oBAAoB,kBAAiB,SAAS,iBAAiB;AAAA,EACrE,MAAM,wBAAwB,kBAC5B,SAAS,qBACX;AAAA,EAEA,IACE,oBAAoB,YACpB,sBAAsB,YACtB,0BAA0B,OAC1B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,IAAI,oBAAoB,YAAY,sBAAsB,UAAU;AAAA,IAClE,OAAO;AAAA,EACT;AAAA,EACA,IAAI,oBAAoB,SAAS,sBAAsB,OAAO;AAAA,IAC5D,OAAO;AAAA,EACT;AAAA,EAEA,OAAO;AAAA;AAGT,IAAM,kBAAkB,CAAC,aAAuC;AAAA,EAC9D,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,aACJ,kBAAiB,SAAS,UAAU,KACpC,kBAAiB,SAAS,IAAI,MAC7B,OAAO,SAAS,cAAc,WAC3B,SAAS,YAAY,IACrB;AAAA,EACN,MAAM,eAAe,kBAAiB,SAAS,YAAY;AAAA,EAC3D,MAAM,mBAAmB,kBAAiB,SAAS,gBAAgB;AAAA,EAEnE,IAAI,OAAO,eAAe,YAAY,CAAC,gBAAgB,CAAC,kBAAkB;AAAA,IACxE;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA;AAuBF,IAAM,qBAAqB,CACzB,aACgC;AAAA,EAChC,IAAI,CAAC,UAAU;AAAA,IACb;AAAA,EACF;AAAA,EAEA,MAAM,uBAAuB,kBAAiB,SAAS,eAAe;AAAA,EACtE,MAAM,kBACJ,yBAAyB,WACzB,yBAAyB,UACzB,yBAAyB,cACrB,uBACA;AAAA,EACN,IACE,oBAAoB,WACpB,oBAAoB,UACpB,oBAAoB,aACpB;AAAA,IACA;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,MAAM,QAAQ,SAAS,WAAW,IAClD,SAAS,YACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,eACJ,kBAAiB,SAAS,YAAY,KAAK,YAAY,GAAG,EAAE;AAAA,EAC9D,MAAM,oBACJ,oBAAoB,UAChB,kBAAiB,SAAS,sBAAsB,IAChD,oBAAoB,SAClB,kBAAiB,SAAS,qBAAqB,IAC/C;AAAA,EAER,IAAI,CAAC,cAAc;AAAA,IACjB;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL,WAAW;AAAA,IACX,aAAa,MAAM;AAAA,MACjB,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,MAAM,6BAA6B,MAAM,QACvC,SAAS,kBACX,IACI,SAAS,mBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,IACE,0BAA0B,SAAS,KACnC,0BAA0B,WAAW,2BAA2B,QAChE;AAAA,QACA,OAAO;AAAA,MACT;AAAA,MAEA,MAAM,2BAA2B,MAAM,QAAQ,SAAS,gBAAgB,IACpE,SAAS,iBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,OAAO,yBAAyB,SAAS,IACrC,2BACA,YAAY,IAAI,CAAC,UAAU,MAAM,QAAQ,iBAAiB,EAAE,EAAE,KAAK,CAAC;AAAA,OACvE;AAAA,IACH,WAAW,YAAY;AAAA,IACvB,cAAc,MAAM;AAAA,MAClB,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,MAAM,6BAA6B,MAAM,QACvC,SAAS,kBACX,IACI,SAAS,mBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,IACE,0BAA0B,SAAS,KACnC,0BAA0B,WAAW,2BAA2B,QAChE;AAAA,QACA,OAAO;AAAA,MACT;AAAA,MAEA,MAAM,4BAA4B,MAAM,QACtC,SAAS,iBACX,IACI,SAAS,kBACN,IAAI,CAAC,UACJ,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,IAC9C,QACA,SACN,EACC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,MACL,OAAO,0BAA0B,SAAS,IACtC,4BACA,YAAY,IAAI,CAAC,UAAU;AAAA,QACzB,MAAM,QAAQ,MAAM,MAAM,YAAY;AAAA,QACtC,OAAO,QAAQ,OAAO,SAAS,MAAM,MAAM,KAAK,EAAE,IAAI;AAAA,OACvD;AAAA,OACJ;AAAA,IACH,kBACE,kBAAiB,SAAS,uBAAuB,KACjD,kBAAiB,SAAS,sBAAsB,KAChD,YACG,GAAG,EAAE,GACJ,QAAQ,iBAAiB,EAAE,EAC5B,KAAK,KACR;AAAA,IACF,gBACE,kBAAiB,SAAS,qBAAqB,KAC/C,kBAAiB,SAAS,oBAAoB,MAC7C,MAAM;AAAA,MACL,MAAM,QAAQ,aAAa,MAAM,YAAY;AAAA,MAC7C,OAAO,QAAQ,OAAO,SAAS,MAAM,MAAM,KAAK,EAAE,IAAI;AAAA,OACrD;AAAA,IACL;AAAA,IACA,YAAY,OAAO,sBAAsB;AAAA,EAC3C;AAAA;AAGF,IAAM,gCAAgC,CACpC,MAYA,UAYG;AAAA,EACH,IAAI,CAAC,QAAQ,CAAC,OAAO;AAAA,IACnB,OAAO;AAAA,EACT;AAAA,EACA,IACE,KAAK,cAAc,MAAM,aACzB,KAAK,qBAAqB,MAAM,oBAChC,KAAK,mBAAmB,MAAM,gBAC9B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,MAAM,yBAAyB,KAAK,WAAW,MAAM,GAAG,EAAE;AAAA,EAC1D,MAAM,0BAA0B,MAAM,WAAW,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,0BAA0B,KAAK,YAAY,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,2BAA2B,MAAM,YAAY,MAAM,GAAG,EAAE;AAAA,EAC9D,MAAM,cAAc,KAAK,IACvB,uBAAuB,QACvB,wBAAwB,MAC1B;AAAA,EACA,SAAS,QAAQ,EAAG,QAAQ,aAAa,SAAS,GAAG;AAAA,IACnD,IACE,uBAAuB,WAAW,wBAAwB,UAC1D,wBAAwB,WAAW,yBAAyB,QAC5D;AAAA,MACA,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EACA,OAAO;AAAA;AAGT,IAAM,gCAAgC,CACpC,aAC2C;AAAA,EAC3C,IAAI,CAAC,YAAY,SAAS,mBAAmB,SAAS,YAAY;AAAA,IAChE;AAAA,EACF;AAAA,EAEA,MAAM,OACJ,SAAS,gBAAgB,sBACzB,SAAS,gBAAgB,uBACrB,SAAS,cACT;AAAA,EACN,IAAI,CAAC,MAAM;AAAA,IACT;AAAA,EACF;AAAA,EAEA,MAAM,qBAAqB,MAAM,QAAQ,SAAS,iBAAiB,IAC/D,SAAS,kBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,MAAM,sBAAsB,MAAM,QAAQ,SAAS,kBAAkB,IACjE,SAAS,mBACN,IAAI,CAAC,UAAU,kBAAiB,KAAK,CAAC,EACtC,OAAO,CAAC,UAA2B,OAAO,UAAU,QAAQ,IAC/D,CAAC;AAAA,EACL,IAAI,aACF,mBAAmB,SAAS,KAC5B,mBAAmB,WAAW,oBAAoB,SAC9C,qBACA,CAAC;AAAA,EACP,IAAI,cACF,mBAAmB,SAAS,KAC5B,mBAAmB,WAAW,oBAAoB,SAC9C,sBACA,CAAC;AAAA,EAEP,IAAI,WAAW,WAAW,GAAG;AAAA,IAC3B,IAAI,SAAS,oBAAoB;AAAA,MAC/B,MAAM,YAAY,kBAAiB,SAAS,SAAS,KAAK;AAAA,MAC1D,MAAM,aAAa,kBAAiB,SAAS,qBAAqB,KAAK;AAAA,MACvE,aAAa,CAAC,WAAW,mBAAmB;AAAA,MAC5C,cAAc,CAAC,GAAG,UAAU;AAAA,IAC9B,EAAO;AAAA,MACL,MAAM,cAAc,kBAAiB,SAAS,UAAU,KAAK;AAAA,MAC7D,MAAM,eACJ,kBAAiB,SAAS,WAAW,MACpC,OAAO,SAAS,eAAe,WAAW,SAAS,aAAa,IAAI;AAAA,MACvE,aAAa,CAAC,WAAW;AAAA,MACzB,cAAc,CAAC,YAAY;AAAA;AAAA,EAE/B;AAAA,EAEA,MAAM,mBACJ,kBAAiB,SAAS,uBAAuB,KAAK,WAAW,GAAG,EAAE;AAAA,EACxE,MAAM,iBACJ,kBAAiB,SAAS,qBAAqB,KAAK,YAAY,GAAG,EAAE;AAAA,EACvE,IAAI,CAAC,oBAAoB,OAAO,mBAAmB,UAAU;AAAA,IAC3D;AAAA,EACF;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW,WAAW;AAAA,IACtB;AAAA,IACA;AAAA,EACF;AAAA;AAGF,IAAM,2CAA2C,CAC/C,MACA,UACG;AAAA,EACH,IAAI,CAAC,QAAQ,CAAC,OAAO;AAAA,IACnB,OAAO;AAAA,EACT;AAAA,EACA,IACE,KAAK,SAAS,MAAM,QACpB,KAAK,qBAAqB,MAAM,oBAChC,KAAK,mBAAmB,MAAM,gBAC9B;AAAA,IACA,OAAO;AAAA,EACT;AAAA,EACA,MAAM,yBAAyB,KAAK,WAAW,MAAM,GAAG,EAAE;AAAA,EAC1D,MAAM,0BAA0B,MAAM,WAAW,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,0BAA0B,KAAK,YAAY,MAAM,GAAG,EAAE;AAAA,EAC5D,MAAM,2BAA2B,MAAM,YAAY,MAAM,GAAG,EAAE;AAAA,EAC9D,MAAM,cAAc,KAAK,IACvB,uBAAuB,QACvB,wBAAwB,MAC1B;AAAA,EACA,SAAS,QAAQ,EAAG,QAAQ,aAAa,SAAS,GAAG;AAAA,IACnD,IACE,uBAAuB,WAAW,wBAAwB,UAC1D,wBAAwB,WAAW,yBAAyB,QAC5D;AAAA,MACA,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EACA,OAAO;AAAA;AAGT,IAAM,kCAAkC,CACtC,aACG;AAAA,EACH,MAAM,QAAQ,mBAAmB,QAAQ;AAAA,EACzC,IAAI,CAAC,OAAO;AAAA,IACV,OAAO;AAAA,EACT;AAAA,EAEA,OACE,MAAM,YAAY,MACjB,MAAM,aAAa,IAAI,MACvB,MAAM,cAAc,UACrB,OAAO,UAAU,6BAA6B,YAC9C,SAAS,2BAA2B,IAChC,IACA;AAAA;AAIR,IAAM,qCAAqC,CACzC,aACG;AAAA,EACH,MAAM,QAAQ,8BAA8B,QAAQ;AAAA,EACpD,IAAI,CAAC,OAAO;AAAA,IACV,OAAO;AAAA,EACT;AAAA,EAEA,OACE,MAAM,YAAY,MACjB,MAAM,SAAS,sBAChB,OAAO,UAAU,0BAA0B,WACvC,IACA,MACH,MAAM,QAAQ,UAAU,kBAAkB,KAC3C,SAAS,mBAAmB,SAAS,IACjC,IACA,MACH,OAAO,UAAU,mBAAmB,YACrC,SAAS,eAAe,KAAK,EAAE,SAAS,IACpC,IACA;AAAA;AAIR,IAAM,8BAA8B,CAAC,WACnC,OAAO,MAAM,EAAE,KAAK,CAAC,MAAM,UAAU;AAAA,EACnC,MAAM,kBAAkB,mBAAmB,KAAK,QAAQ;AAAA,EACxD,MAAM,mBAAmB,mBAAmB,MAAM,QAAQ;AAAA,EAC1D,IACE,KAAK,WAAW,MAAM,UACtB,8BAA8B,iBAAiB,gBAAgB,GAC/D;AAAA,IACA,MAAM,uBAAuB,gCAC3B,KAAK,QACP;AAAA,IACA,MAAM,wBAAwB,gCAC5B,MAAM,QACR;AAAA,IACA,IAAI,0BAA0B,sBAAsB;AAAA,MAClD,OAAO,wBAAwB;AAAA,IACjC;AAAA,EACF;AAAA,EACA,MAAM,mBAAmB,8BAA8B,KAAK,QAAQ;AAAA,EACpE,MAAM,oBAAoB,8BAA8B,MAAM,QAAQ;AAAA,EACtE,IACE,KAAK,WAAW,MAAM,UACtB,yCACE,kBACA,iBACF,GACA;AAAA,IACA,MAAM,wBAAwB,mCAC5B,KAAK,QACP;AAAA,IACA,MAAM,yBAAyB,mCAC7B,MAAM,QACR;AAAA,IACA,IAAI,2BAA2B,uBAAuB;AAAA,MACpD,OAAO,yBAAyB;AAAA,IAClC;AAAA,EACF;AAAA,EACA,MAAM,oBAAoB,6BAA6B,IAAI;AAAA,EAC3D,MAAM,qBAAqB,6BAA6B,KAAK;AAAA,EAC7D,IAAI,uBAAuB,mBAAmB;AAAA,IAC5C,OAAO,qBAAqB;AAAA,EAC9B;AAAA,EACA,MAAM,YAAY,gBAAgB,KAAK,QAAQ;AAAA,EAC/C,MAAM,aAAa,gBAAgB,MAAM,QAAQ;AAAA,EACjD,IACE,KAAK,WAAW,MAAM,UACtB,aACA,eACE,UAAU,gBACV,WAAW,gBACX,UAAU,iBAAiB,WAAW,gBACrC,OAAO,UAAU,eAAe,YAC/B,OAAO,WAAW,eAAe,YACjC,UAAU,eAAe,WAAW,aACxC;AAAA,IACA,MAAM,yBAAyB,6BAC7B,KAAK,QACP;AAAA,IACA,MAAM,0BAA0B,6BAC9B,MAAM,QACR;AAAA,IACA,IAAI,4BAA4B,wBAAwB;AAAA,MACtD,OAAO,0BAA0B;AAAA,IACnC;AAAA,EACF;AAAA,EACA,IAAI,MAAM,UAAU,KAAK,OAAO;AAAA,IAC9B,OAAO,MAAM,QAAQ,KAAK;AAAA,EAC5B;AAAA,EAEA,OAAO,KAAK,QAAQ,cAAc,MAAM,OAAO;AAAA,CAChD,EAAE;AAEE,IAAM,sCAAsC,CACjD,SACA,UACoC;AAAA,EACpC,MAAM,aAAa,QAAQ,OACzB,CAAC,KAAK,WACJ,MAAM,OAAO,QAAQ,gCAAgC,OAAO,QAAQ,GACtE,CACF;AAAA,EACA,IAAI,QAAQ,WAAW,KAAK,cAAc,GAAG;AAAA,IAC3C,OAAO,CAAC;AAAA,EACV;AAAA,EAEA,MAAM,WAAW,IAAI;AAAA,EAsBrB,WAAW,UAAU,SAAS;AAAA,IAC5B,MAAM,kBACJ,OAAO,QAAQ,gCAAgC,OAAO,QAAQ;AAAA,IAChE,MAAM,OAAO,yBAAyB,MAAM;AAAA,IAC5C,IAAI,CAAC,MAAM;AAAA,MACT;AAAA,IACF;AAAA,IAEA,MAAM,MAAM,KAAK,KAAK,KAAK;AAAA,IAC3B,MAAM,QAAQ,KAAK,GAAG,EAAE,KAAK;AAAA,IAC7B,MAAM,cACJ,KAAK,SAAS,IAAI,KAAK,MAAM,GAAG,EAAE,EAAE,KAAK,KAAK,IAAI;AAAA,IACpD,MAAM,WAAW,SAAS,IAAI,GAAG;AAAA,IACjC,MAAM,WAAW,MAAM,QAAQ,OAAO,UAAU,iBAAiB,IAC7D,OAAO,SAAS,kBAAkB,OAChC,CAAC,UACC,UAAU,YAAY,UAAU,SACpC,IACA,CAAC;AAAA,IACL,MAAM,WACJ,SAAS,SAAS,QAAQ,KAAK,SAAS,SAAS,SAAS;AAAA,IAC5D,MAAM,aAAa,SAAS,SAAS,QAAQ,IAAI,IAAI;AAAA,IACrD,MAAM,cAAc,SAAS,SAAS,SAAS,IAAI,IAAI;AAAA,IACvD,MAAM,aAAa,WAAW,IAAI;AAAA,IAClC,MAAM,eAAe,MAAM,QAAQ,OAAO,UAAU,qBAAqB,IACrE,OAAO,SAAS,sBAAsB,OACpC,CAAC,UACC,UAAU,aACV,UAAU,iBACV,UAAU,SACd,IACA,OAAO,UAAU,yBAAyB,aACxC,OAAO,UAAU,yBAAyB,iBAC1C,OAAO,UAAU,yBAAyB,YAC1C,CAAC,OAAO,SAAS,oBAAoB,IACrC,CAAC;AAAA,IACP,MAAM,cAAc,aAAa,SAAS,SAAS,IAAI,IAAI;AAAA,IAC3D,MAAM,kBAAkB,aAAa,SAAS,aAAa,IAAI,IAAI;AAAA,IACnE,MAAM,cAAc,aAAa,SAAS,SAAS,IAAI,IAAI;AAAA,IAC3D,IAAI,CAAC,UAAU;AAAA,MACb,SAAS,IAAI,KAAK;AAAA,QAChB,WAAW,OAAO;AAAA,QAClB,OAAO;AAAA,QACP;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,WAAW,IAAI,IAAI,OAAO,SAAS,CAAC,OAAO,MAAM,IAAI,CAAC,CAAC;AAAA,QACvD,YAAY,OAAO;AAAA,QACnB,WAAW,OAAO;AAAA,QAClB,YAAY;AAAA,QACZ;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAAA,MACD;AAAA,IACF;AAAA,IAEA,SAAS,SAAS;AAAA,IAClB,SAAS,cAAc;AAAA,IACvB,IAAI,OAAO,QAAQ;AAAA,MACjB,SAAS,UAAU,IAAI,OAAO,MAAM;AAAA,IACtC;AAAA,IACA,SAAS,cAAc;AAAA,IACvB,SAAS,eAAe;AAAA,IACxB,SAAS,cAAc;AAAA,IACvB,SAAS,eAAe;AAAA,IACxB,SAAS,mBAAmB;AAAA,IAC5B,SAAS,eAAe;AAAA,IACxB,IAAI,OAAO,QAAQ,SAAS,WAAW;AAAA,MACrC,SAAS,YAAY,OAAO;AAAA,MAC5B,SAAS,aAAa,OAAO;AAAA,MAC7B,SAAS,YAAY,OAAO;AAAA,IAC9B;AAAA,EACF;AAAA,EAEA,MAAM,cAAc,CAAC,GAAG,SAAS,OAAO,CAAC;AAAA,EACzC,MAAM,mBAAmB,YAAY,OACnC,CAAC,SAAS,YAAY,KAAK,IAAI,SAAS,QAAQ,SAAS,GACzD,CACF;AAAA,EACA,MAAM,mBAAmB,IAAI,IAC3B,YAAY,IAAI,CAAC,YAAY,CAAC,QAAQ,KAAK,QAAQ,WAAW,CAAU,CAC1E;AAAA,EACA,MAAM,qBAAqB,IAAI,KAC5B,OAAO,SAAS,CAAC,GACf,OACC,CAAC,SACC,MAAM,QAAQ,KAAK,aAAa,KAAK,KAAK,cAAc,SAAS,CACrE,EACC,IAAI,CAAC,SAAS,CAAC,KAAK,OAAO,KAAK,iBAAiB,CAAC,CAAC,CAAU,CAClE;AAAA,EACA,MAAM,qBAAqB,IAAI,KAC5B,OAAO,SAAS,CAAC,GACf,OACC,CAAC,SACC,MAAM,QAAQ,KAAK,aAAa,KAAK,KAAK,cAAc,SAAS,CACrE,EACC,IAAI,CAAC,SAAS,CAAC,KAAK,OAAO,KAAK,iBAAiB,CAAC,CAAC,CAAU,CAClE;AAAA,EAEA,OAAO,YACJ,IAAmC,CAAC,YAAY;AAAA,IAC/C,MAAM,cAAc,YAAY,OAC9B,CAAC,UAAU,MAAM,gBAAgB,QAAQ,WAC3C;AAAA,IACA,MAAM,WAAW,YAAY,OAAO,CAAC,UAAU,MAAM,QAAQ,QAAQ,GAAG;AAAA,IACxE,MAAM,mBAAmB,SACtB,MAAM,EACN,KAAK,CAAC,MAAM,UAAU,MAAM,aAAa,KAAK,UAAU,EAAE;AAAA,IAC7D,MAAM,cAAc,YAAY,OAC9B,CAAC,KAAK,UAAU,MAAM,MAAM,YAC5B,CACF;AAAA,IACA,MAAM,aAAa,QAAQ,aAAa;AAAA,IACxC,MAAM,cACJ,cAAc,IAAI,QAAQ,aAAa,cAAc;AAAA,IACvD,MAAM,WAAW,QAAQ,KACvB,CAAC,WAAW,OAAO,YAAY,QAAQ,UACzC;AAAA,IACA,MAAM,kBACJ,UAAU,QAAQ,gBAAgB,mBAAkB,UAAU,QAAQ;AAAA,IACxE,MAAM,kBACJ,UAAU,QAAQ,gBAClB,mBACE,UAAU,UACV,UAAU,QACV,UAAU,KACZ;AAAA,IACF,MAAM,yBAAyB,6BAC7B,UAAU,UAAU,sBACtB;AAAA,IACA,MAAM,4BAA4B,+BAChC,UAAU,QACZ;AAAA,IACA,MAAM,qBACJ,cAAc,IACV,YACG,IAAI,CAAC,WAAW;AAAA,MACf,OAAO,MAAM;AAAA,MACb,UAAU,MAAM,QAAQ,QAAQ;AAAA,MAChC,KAAK,MAAM;AAAA,MACX,OAAO,MAAM;AAAA,MACb,aAAa,MAAM,aAAa;AAAA,MAChC,YAAY,MAAM;AAAA,IACpB,EAAE,EACD,KAAK,CAAC,MAAM,UAAU,MAAM,aAAa,KAAK,UAAU,IAC3D,CAAC;AAAA,IACP,MAAM,UAAoD,CAAC;AAAA,IAC3D,MAAM,cACJ,OAAO,MACJ,IAAI,CAAC,UAAU;AAAA,MACd,OACE,KAAK,eAAe,KAAK,CAAC,UAAU,MAAM,QAAQ,QAAQ,GAAG,GACzD,SAAS;AAAA,MACf,OAAO,KAAK;AAAA,IACd,EAAE,EACD,OAAO,CAAC,UAAU,MAAM,QAAQ,CAAC,KAAK,CAAC;AAAA,IAC5C,MAAM,eAAe,YAAY,IAAI,CAAC,UAAU;AAAA,MAC9C,MAAM,qBACJ,YACE,YAAY,UACV,CAAC,cAAc,UAAU,UAAU,MAAM,KAC3C,IAAI;AAAA,MAER,MAAM,eACJ,mBACG,IAAI,MAAM,KAAK,GACd,OAAO,CAAC,cAAc,UAAU,QAAQ,CAAC,KAAK,CAAC;AAAA,MACrD,MAAM,oBACJ,mBACG,IAAI,MAAM,KAAK,GACd,OAAO,CAAC,cAAc,UAAU,aAAa,CAAC,KAAK,CAAC;AAAA,MAC1D,MAAM,aAAa,aAAa,OAC9B,CAAC,KAAK,cAAc,MAAM,UAAU,OACpC,CACF;AAAA,MACA,MAAM,kBAAkB,kBAAkB,OACxC,CAAC,KAAK,cAAc,MAAM,UAAU,YACpC,CACF;AAAA,MACA,MAAM,sBAAsB,aAAa,OACvC,CAAC,cACC,UAAU,QAAQ,QAAQ,OAC1B,iBAAiB,IAAI,UAAU,GAAG,MAAM,QAAQ,WACpD;AAAA,MACA,MAAM,qBAAqB,aAAa,OACtC,CAAC,cACC,iBAAiB,IAAI,UAAU,GAAG,MAAM,QAAQ,WACpD;AAAA,MACA,MAAM,2BAA2B,kBAAkB,OACjD,CAAC,cACC,UAAU,QAAQ,QAAQ,OAC1B,iBAAiB,IAAI,UAAU,GAAG,MAAM,QAAQ,WACpD;AAAA,MACA,MAAM,0BAA0B,kBAAkB,OAChD,CAAC,cACC,iBAAiB,IAAI,UAAU,GAAG,MAAM,QAAQ,WACpD;AAAA,MACA,MAAM,wBAAwB,oBAC3B,MAAM,EACN,KAAK,CAAC,MAAM,UAAU,MAAM,QAAQ,KAAK,KAAK,EAAE;AAAA,MACnD,MAAM,mBAAmB,mBAAmB,OAC1C,CAAC,KAAK,cAAc,MAAM,UAAU,OACpC,CACF;AAAA,MACA,MAAM,mBAAmB,kBAAkB,KACzC,CAAC,cAAc,UAAU,QAAQ,QAAQ,GAC3C,GAAG;AAAA,MACH,MAAM,6BAA6B,yBAChC,MAAM,EACN,KAAK,CAAC,MAAM,UAAU,MAAM,aAAa,KAAK,UAAU,EAAE;AAAA,MAC7D,MAAM,wBAAwB,wBAAwB,OACpD,CAAC,KAAK,cAAc,MAAM,UAAU,YACpC,CACF;AAAA,MACA,MAAM,aAAa,aAAa,IAAI,MAAM,QAAQ,aAAa;AAAA,MAC/D,MAAM,gBACJ,OAAO,oBAAoB,UAAU,YACrC,mBAAmB,QAAQ,IACvB,MAAM,QAAQ,mBAAmB,QACjC;AAAA,MACN,MAAM,aACJ,OAAO,oBAAoB,UAAU,WACjC,MAAM,QAAQ,mBAAmB,QACjC;AAAA,MACN,MAAM,mBACJ,mBAAmB,IAAI,MAAM,QAAQ,mBAAmB;AAAA,MAC1D,MAAM,kBACJ,OAAO,qBAAqB,YAAY,kBAAkB,IACtD,mBAAmB,kBACnB;AAAA,MACN,MAAM,wBACJ,OAAO,qBAAqB,YAAY,wBAAwB,IAC5D,mBAAmB,wBACnB;AAAA,MACN,MAAM,gBACJ,aAAa,KAAK,wBACd,MAAM,QAAQ,aACd,sBAAsB,QAAQ,aAC9B;AAAA,MACN,MAAM,sBACJ,mBAAmB,KAAK,wBACpB,MAAM,QAAQ,mBACd,sBAAsB,QAAQ,mBAC9B;AAAA,MACN,MAAM,qBACJ,OAAO,qBAAqB,YAC5B,kBAAkB,KAClB,6BACI,mBAAmB,kBACnB,2BAA2B,aAAa,kBACxC;AAAA,MACN,MAAM,2BACJ,OAAO,qBAAqB,YAC5B,wBAAwB,KACxB,6BACI,mBAAmB,wBACnB,2BAA2B,aAAa,wBACxC;AAAA,MACN,MAAM,WACJ,CAAC;AAAA,MACH,IACE,MAAM,UAAU,YAChB,aAAa,QACZ,OAAO,kBAAkB,YAAY,gBAAgB,IACtD;AAAA,QACA,SAAQ,KAAK,uBAAuB;AAAA,MACtC;AAAA,MACA,IAAI,MAAM,UAAU,cAAc,cAAc,KAAK;AAAA,QACnD,SAAQ,KAAK,2BAA2B;AAAA,MAC1C;AAAA,MACA,IACE,MAAM,UAAU,cAChB,OAAO,qBAAqB,YAC5B,oBAAoB,QACnB,OAAO,wBAAwB,YAAY,sBAAsB,IAClE;AAAA,QACA,SAAQ,KAAK,oCAAoC;AAAA,MACnD;AAAA,MACA,IACE,0BACE,OAAO,kBAAkB,YAAY,iBAAiB,OACrD,OAAO,wBAAwB,YAC9B,uBAAuB,MAC3B;AAAA,QACA,SAAQ,KAAK,0BAA0B;AAAA,MACzC;AAAA,MACA,IAAI,OAAO,eAAe,UAAU;AAAA,QAClC,IAAI,aAAa,GAAG;AAAA,UAClB,SAAQ,KAAK,gBAAgB;AAAA,QAC/B,EAAO,SAAI,aAAa,GAAG;AAAA,UACzB,SAAQ,KAAK,gBAAgB;AAAA,QAC/B,EAAO;AAAA,UACL,SAAQ,KAAK,YAAY;AAAA;AAAA,MAE7B;AAAA,MAEA,OAAO;AAAA,QACL,OAAO,MAAM;AAAA,QACb;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,eAAe,oBAAoB;AAAA,QACnC,eAAe,oBAAoB;AAAA,QACnC;AAAA,QACA;AAAA,QACA,OAAO,MAAM;AAAA,QACb;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,YAAY;AAAA,QACZ,uBAAuB,uBAAuB;AAAA,QAC9C,uBAAuB,wBAClB,YAAY,KACX,CAAC,cAAc,UAAU,QAAQ,sBAAsB,GACzD,GAAG,SAAS,sBAAsB,MAClC;AAAA,MACN;AAAA,KACD;AAAA,IACD,MAAM,iBAAiB,YAAY,IAAI;AAAA,IACvC,MAAM,gBAAgB,YAAY,GAAG,EAAE,GAAG;AAAA,IAC1C,MAAM,iBAAiB,YAAY,OAGjC,CAAC,SAAS,UACR,CAAC,WAAW,MAAM,QAAQ,QAAQ,QAAQ,QAAQ,SACpD,SACF;AAAA,IACA,MAAM,kBAAkB,YAAY,GAAG,EAAE;AAAA,IACzC,MAAM,YAAY,gBAAgB,SAAS,QAAQ;AAAA,IACnD,MAAM,aAAa,iBAAiB;AAAA,IACpC,MAAM,qBACJ,OAAO,eAAe,YAAY,YAAY,IAC1C,aAAa,YACb;AAAA,IACN,MAAM,eACJ,OAAO,eAAe,WAAW,YAAY,aAAa;AAAA,IAC5D,MAAM,0BACJ,CAAC;AAAA,IACH,MAAM,uBACJ,QAAQ,cAAc,KACtB,QAAQ,oBAAoB,KAC5B,QAAQ,gBAAgB,IACpB,YACA,QAAQ,kBAAkB,KACxB,QAAQ,gBAAgB,KACxB,QAAQ,gBAAgB,IACxB,gBACA,QAAQ,cAAc,KACpB,QAAQ,gBAAgB,KACxB,QAAQ,oBAAoB,IAC5B,YACA;AAAA,IACV,IAAI,yBAAyB,WAAW;AAAA,MACtC,wBAAwB,KAAK,iBAAiB;AAAA,IAChD;AAAA,IACA,IAAI,yBAAyB,eAAe;AAAA,MAC1C,wBAAwB,KAAK,wBAAwB;AAAA,MACrD,wBAAwB,KAAK,sBAAsB;AAAA,IACrD;AAAA,IACA,IAAI,yBAAyB,WAAW;AAAA,MACtC,wBAAwB,KAAK,cAAc;AAAA,MAC3C,wBAAwB,KAAK,mBAAmB;AAAA,IAClD;AAAA,IACA,IAAI,yBAAyB,SAAS;AAAA,MACpC,wBAAwB,KAAK,qBAAqB;AAAA,MAClD,IAAI,QAAQ,cAAc,GAAG;AAAA,QAC3B,wBAAwB,KAAK,mBAAmB;AAAA,MAClD;AAAA,MACA,IAAI,QAAQ,kBAAkB,KAAK,QAAQ,gBAAgB,GAAG;AAAA,QAC5D,wBAAwB,KAAK,sBAAsB;AAAA,MACrD;AAAA,IACF;AAAA,IAEA,IAAI,QAAQ,aAAa,kBAAkB;AAAA,MACzC,QAAQ,KAAK,UAAU;AAAA,IACzB;AAAA,IACA,IAAI,QAAQ,QAAQ,GAAG;AAAA,MACrB,QAAQ,KAAK,mBAAmB;AAAA,IAClC;AAAA,IACA,IAAI,SAAS,WAAW,GAAG;AAAA,MACzB,QAAQ,KAAK,wBAAwB;AAAA,IACvC,EAAO,SACL,CAAC,oBACD,QAAQ,cAAc,iBAAiB,YACvC;AAAA,MACA,QAAQ,KAAK,wBAAwB;AAAA,IACvC;AAAA,IACA,IAAI,cAAc,QAAQ,eAAe,MAAM,KAAK;AAAA,MAClD,QAAQ,KAAK,uBAAuB;AAAA,IACtC;AAAA,IAEA,MAAM,eAAe;AAAA,MACnB,yBAAyB,eAAe,IAAI,kBAAkB;AAAA,MAC9D,GAAG,QAAQ,YAAY,QAAQ,UAAU,IAAI,KAAK;AAAA,MAClD,IAAI,aAAa,KAAK,QAAQ,CAAC;AAAA,MAC/B,UAAU,QAAQ,wBAAuB,QAAQ,wBAAwB,QAAQ;AAAA,MACjF,OAAO,gBAAgB,WACnB,IAAI,cAAc,KAAK,QAAQ,CAAC,6BAChC;AAAA,MACJ,yBAAyB,YAAY,2BAA2B;AAAA,MAChE,4BAA4B,SAAS,8BAA8B;AAAA,MACnE,mBACI,YAAY,iBAAiB,aAAa,QAAQ,aAAa,iBAAiB,YAAY,QAAQ,CAAC,MACrG;AAAA,IACN,EAAE,OAAO,OAAO;AAAA,IAEhB,OAAO;AAAA,MACL,cAAc,QAAQ,aAAa,QAAQ;AAAA,MAC3C,WAAW,QAAQ;AAAA,MACnB,OAAO,QAAQ;AAAA,MACf,KAAK,QAAQ;AAAA,MACb,OAAO,QAAQ;AAAA,MACf,aAAa,QAAQ;AAAA,MACrB;AAAA,MACA;AAAA,MACA,gBACE,OAAO,gBAAgB,YAAY,oBAAoB,cAAc,IACjE,cAAc,iBAAiB,aAAa,cAC5C;AAAA,MACN,MAAM,QAAQ;AAAA,MACd;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW,gBAAgB;AAAA,MAC3B,kBAAkB;AAAA,QAChB,MAAM;AAAA,QACN,aAAa,QAAQ;AAAA,QACrB,SAAS;AAAA,QACT,iBAAiB,QAAQ;AAAA,QACzB,aAAa,QAAQ;AAAA,MACvB;AAAA,MACA,eAAe,OAAO;AAAA,MACtB,eAAe,OAAO;AAAA,MACtB,cAAc,OAAO;AAAA,MACrB,iBAAiB,OAAO;AAAA,MACxB,eAAe,OAAO;AAAA,MACtB,qBAAqB,OAAO;AAAA,MAC5B,wBAAwB,OAAO;AAAA,MAC/B,sBAAsB,OAAO;AAAA,MAC7B;AAAA,MACA,0BAA0B,OAAO,MAAM,KACrC,CAAC,SAAS,KAAK,UAAU,oBAC3B;AAAA,MACA,eAAe,OAAO,MAAM,KAC1B,CAAC,SAAS,KAAK,UAAU,YAAY,KAAK,UAAU,YAAY,IAClE;AAAA,MACA;AAAA,MACA,uBAAuB,OAAO,MAAM,KAClC,CAAC,SAAS,KAAK,UAAU,cAC3B;AAAA,MACA;AAAA,MACA;AAAA,MACA,cAAc,SAAS;AAAA,MACvB,iBAAiB,mBACb,QAAQ,aAAa,iBAAiB,aACtC;AAAA,MACJ,aAAa,QAAQ,UAAU;AAAA,MAC/B,6BAA6B;AAAA,MAC7B;AAAA,MACA;AAAA,MACA;AAAA,MACA,sBAAsB,OAAO,MAAM,KACjC,CAAC,SAAS,KAAK,UAAU,gBAC3B;AAAA,MACA,uBAAuB,kBAAkB;AAAA,MACzC,uBAAuB,kBAAkB;AAAA,MACzC,SAAS,aAAa,KAAK,KAAI;AAAA,MAC/B,YAAY,QAAQ;AAAA,MACpB,WAAW,QAAQ;AAAA,MACnB,YAAY,QAAQ;AAAA,MACpB,YAAY,QAAQ;AAAA,MACpB,aAAa,QAAQ;AAAA,MACrB,YAAY,QAAQ;AAAA,IACtB;AAAA,GACD,EACA,KAAK,CAAC,MAAM,UAAU;AAAA,IACrB,IAAI,MAAM,eAAe,KAAK,YAAY;AAAA,MACxC,OAAO,MAAM,aAAa,KAAK;AAAA,IACjC;AAAA,IACA,IAAI,MAAM,cAAc,KAAK,WAAW;AAAA,MACtC,OAAO,MAAM,YAAY,KAAK;AAAA,IAChC;AAAA,IACA,OAAO,KAAK,MAAM,cAAc,MAAM,KAAK;AAAA,GAC5C;AAAA;AA0BL,IAAM,2BAA2B,CAAC,aAA0B;AAAA,EAC1D,MAAM,gBAAgB,0BAA0B,QAAQ;AAAA,EACxD,MAAM,YAAY,gBACd,uBAAuB,QAAQ,IAC/B;AAAA,EAEJ,OAAO;AAAA,IACL,gBAAgB,eAAe;AAAA,IAC/B;AAAA,IACA,WAAW,eAAe;AAAA,IAC1B;AAAA,IACA,aACE,WAAW,QAAQ,UAAU,eAAe,SAAS,UAAU;AAAA,EACnE;AAAA;AAGK,IAAM,yBAAyB;AAAA,EACpC;AAAA,EACA;AAAA,EACA;AAAA,MAKuB;AAAA,EACvB,MAAM,QAAQ,sBAAsB;AAAA,IAClC;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAAA,EACD,MAAM,QAAQ,yBAAyB,QAAQ;AAAA,EAC/C,MAAM,aAAa,MAAM,cAAc;AAAA,EACvC,MAAM,eACJ,UAAU,eACV,MAAM,cAAc,aACpB,MAAM,eAAe,gBAAgB;AAAA,EACvC,MAAM,cACJ,OAAO,MAAM,eAAe,aAAa,YACzC,MAAM,cAAc,SAAS,SAAS;AAAA,EACxC,MAAM,gBAAgB,MAAM,eAAe,WAAW,UAAU,KAAK;AAAA,EAErE,OAAO;AAAA,IACL,gBAAgB,MAAM;AAAA,IACtB,YACE,OAAO,MAAM,eAAe,YAAY,YACxC,MAAM,cAAc,QAAQ,SAAS;AAAA,IACvC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,YAAY,UAAU;AAAA,IACtB,SAAS,UAAU;AAAA,IACnB,QAAQ,UAAU;AAAA,IAClB,aAAa,UAAU;AAAA,IACvB,cAAc,UAAU,gBAAgB,UAAU;AAAA,IAClD,aAAa,UAAU;AAAA,IACvB,cAAc,UAAU;AAAA,IACxB,eAAe,MAAM;AAAA,IACrB,WAAW,MAAM;AAAA,IACjB,qBAAqB,MAAM,WAAW;AAAA,IACtC,oBAAoB,MAAM,WAAW;AAAA,IACrC,aAAa,MAAM,WAAW;AAAA,IAC9B,aAAa,MAAM;AAAA,IACnB;AAAA,EACF;AAAA;AAIK,IAAM,8BAA8B;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AAAA,MAK4B;AAAA,EAC5B,MAAM,yBAAyB,0BAA0B,QAAQ;AAAA,EACjE,MAAM,UAAU,oBAAoB,QAAQ;AAAA,EAC5C,MAAM,eAAe,qBAAqB,OAAO;AAAA,EACjD,MAAM,YAAY,kBAAkB,OAAO;AAAA,EAC3C,MAAM,uBAAuB,6BAA6B,SAAS;AAAA,EACnE,MAAM,kBAAkB,wBAAwB,OAAO;AAAA,EACvD,MAAM,sBAAsB,4BAA4B,OAAO;AAAA,EAC/D,MAAM,iBAAiB,uBACrB,wBAAwB,WAAW,IACnC,OACF;AAAA,EACA,MAAM,YAAY,uBAAuB,QAAQ;AAAA,EACjD,MAAM,qBAAqB,oCACzB,SACA,WAAW,KACb;AAAA,EACA,MAAM,WAAW,uBAAuB;AAAA,IACtC;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAAA,EAED,OAAO;AAAA,IACL,mBAAmB,0BAA0B;AAAA,MAC3C,GAAG,UAAU,IAAI,CAAC,aAAa,SAAS,gBAAgB;AAAA,MACxD,GAAG,gBAAgB,IAAI,CAAC,YAAY,QAAQ,gBAAgB;AAAA,MAC5D,GAAG,oBAAoB,IAAI,CAAC,cAAc,UAAU,gBAAgB;AAAA,MACpE,GAAG,eAAe,iBAAiB,IACjC,CAAC,YAAY,QAAQ,gBACvB;AAAA,IACF,CAAC;AAAA,IACD;AAAA,IACA;AAAA,IACA,UAAU,eAAe;AAAA,IACzB;AAAA,IACA;AAAA,IACA;AAAA,IACA,cAAc,eAAe;AAAA,IAC7B,cAAc,oBAAoB,SAAS;AAAA,IAC3C,cAAc,SAAS;AAAA,IACvB,YAAY,QAAQ,SAAS;AAAA,IAC7B,mBAAmB,SAAS;AAAA,IAC5B,YAAY,SAAS;AAAA,IACrB,SAAS,SAAS;AAAA,IAClB,QAAQ,SAAS;AAAA,IACjB,aAAa,SAAS;AAAA,IACtB,cAAc,SAAS;AAAA,IACvB,WACE,SAAS,gBAAgB,SAAS,gBAAgB,SAAS;AAAA,IAC7D,cAAc,SAAS;AAAA,IACvB;AAAA,IACA;AAAA,IACA;AAAA,IACA,qBAAqB,WAAW;AAAA,IAChC,oBAAoB,WAAW;AAAA,IAC/B,aAAa,WAAW;AAAA,IACxB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO,SAAS;AAAA,IAChB,4BAA4B,eAAe;AAAA,EAC7C;AAAA;AAGK,IAAM,uBAAuB,CAAC,YAAyB;AAAA,EAC5D,MAAM,SAAS,IAAI;AAAA,EAEnB,WAAW,UAAU,SAAS;AAAA,IAC5B,kBAAkB,QAAQ,MAAM;AAAA,EAClC;AAAA,EAEA,OAAO,CAAC,GAAG,OAAO,OAAO,CAAC,EAAE,KAAK,CAAC,MAAM,UAAU;AAAA,IAChD,IAAI,MAAM,cAAc,KAAK,WAAW;AAAA,MACtC,OAAO,MAAM,YAAY,KAAK;AAAA,IAChC;AAAA,IAEA,OAAO,KAAK,MAAM,cAAc,MAAM,KAAK;AAAA,GAC5C;AAAA;AAGH,IAAM,mBAAmB,CAAC,QAAmB,SAAiC;AAAA,EAC5E,WAAW,OAAO;AAAA,EAClB,QAAQ,CAAC,MAAM;AAAA,EACf,OAAO;AAAA,EACP;AAAA,EACA,OAAO,kBAAiB,MAAM;AAAA,EAC9B,QACE,OAAO,UACP,qBAAqB;AAAA,IACnB,UAAU,OAAO;AAAA,IACjB,QAAQ,OAAO;AAAA,IACf,OAAO,OAAO;AAAA,EAChB,CAAC;AAAA,EACH,WAAW,OAAO,aAAa,uBAAuB,OAAO,QAAQ;AAAA,EACrE,QAAQ,OAAO;AAAA,EACf,OAAO,OAAO;AAChB;AAEA,IAAM,oBAAoB,CACxB,QACA,WACG;AAAA,EACH,MAAM,MAAM,oBAAoB,MAAM;AAAA,EACtC,MAAM,WAAW,OAAO,IAAI,GAAG;AAAA,EAC/B,IAAI,CAAC,UAAU;AAAA,IACb,OAAO,IAAI,KAAK,iBAAiB,QAAQ,GAAG,CAAC;AAAA,IAE7C;AAAA,EACF;AAAA,EAEA,SAAS,YAAY,KAAK,IAAI,SAAS,WAAW,OAAO,KAAK;AAAA,EAC9D,SAAS,SAAS;AAAA,EAClB,SAAS,OAAO,KAAK,MAAM;AAAA,EAC3B,MAAM,YAAY,4BAA4B,SAAS,MAAM;AAAA,EAC7D,IAAI,WAAW;AAAA,IACb,SAAS,QAAQ,kBAAiB,SAAS;AAAA,IAC3C,SAAS,SACP,UAAU,UACV,qBAAqB;AAAA,MACnB,UAAU,UAAU;AAAA,MACpB,QAAQ,UAAU;AAAA,MAClB,OAAO,UAAU;AAAA,IACnB,CAAC;AAAA,IACH,SAAS,YACP,UAAU,aAAa,uBAAuB,UAAU,QAAQ;AAAA,IAClE,SAAS,SAAS,UAAU;AAAA,IAC5B,SAAS,QAAQ,UAAU;AAAA,EAC7B;AAAA;AAEK,IAAM,4BAA4B,CAAC,aAA0B;AAAA,EAClE,SAAS,QAAQ,SAAS,SAAS,EAAG,SAAS,GAAG,SAAS,GAAG;AAAA,IAC5D,MAAM,UAAU,SAAS;AAAA,IACzB,IAAI,SAAS,SAAS,aAAa;AAAA,MACjC,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEA;AAAA;AAEK,IAAM,sBAAsB,CAAC,aAClC,0BAA0B,QAAQ,GAAG,WAAW,CAAC;AAC5C,IAAM,4BAA4B,CAAC,aAA0B;AAAA,EAClE,SAAS,QAAQ,SAAS,SAAS,EAAG,SAAS,GAAG,SAAS,GAAG;AAAA,IAC5D,MAAM,UAAU,SAAS;AAAA,IACzB,IACE,SAAS,SAAS,gBACjB,OAAO,QAAQ,gBAAgB,aAC7B,QAAQ,SAAS,UAAU,KAAK,IACnC;AAAA,MACA,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEA;AAAA;AAEK,IAAM,wBAAwB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,MAKI;AAAA,EACJ,IAAI,OAAO;AAAA,IACT,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,mBAAmB,0BAA0B,QAAQ;AAAA,EAC3D,IAAI,CAAC,kBAAkB;AAAA,IACrB,OAAO,cAAc,eAAe;AAAA,EACtC;AAAA,EAEA,MAAM,eACJ,OAAO,iBAAiB,uBAAuB,YAC/C,OAAO,iBAAiB,gBAAgB;AAAA,EAE1C,IAAI,cAAc;AAAA,IAChB,OAAO;AAAA,EACT;AAAA,EAEA,IAAI,CAAC,aAAa;AAAA,IAChB,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,eAAe,OAAO,iBAAiB,gBAAgB;AAAA,EAC7D,MAAM,aACJ,iBAAiB,QAAQ,KAAK,EAAE,SAAS,KACzC,iBAAiB,UAAU,KAAK,EAAE,WACjC,iBAAiB,WAAW,UAAU,KAAK,MAC3C,iBAAiB,QAAQ,UAAU,KAAK;AAAA,EAE3C,IAAI,gBAAgB,CAAC,YAAY;AAAA,IAC/B,OAAO;AAAA,EACT;AAAA,EAEA,OAAO;AAAA;;AJ31HT;AAGO;AAAA,EADN,WAAW,EAAE,YAAY,OAAO,CAAC;AAAA;AAC3B,YAA+B;AAA/B;AAAA;AAAA,MAAM,yBAAN,MAA+C;AAAA,EACpD,OAAO,CAAC,MAAc,gBAAyB;AAAA,IAC7C,MAAM,SAAS,MAAM,QAAQ,MAAM,cAAc;AAAA,IAEjD,MAAM,WAAW,SAAS,MACxB,4BAA4B;AAAA,MAC1B,OAAO,OAAO,MAAM;AAAA,MACpB,aAAa,OAAO,YAAY;AAAA,MAChC,UAAU,OAAO,SAAS;AAAA,IAC5B,CAAC,CACH;AAAA,IACA,MAAM,WAAW,SAAS,MACxB,uBAAuB;AAAA,MACrB,OAAO,OAAO,MAAM;AAAA,MACpB,aAAa,OAAO,YAAY;AAAA,MAChC,UAAU,OAAO,SAAS;AAAA,IAC5B,CAAC,CACH;AAAA,IACA,MAAM,yBAAyB,SAC7B,MAAM,SAAS,EAAE,sBACnB;AAAA,IACA,MAAM,UAAU,SAAS,MAAM,SAAS,EAAE,OAAO;AAAA,IACjD,MAAM,eAAe,SAAS,MAAM,SAAS,EAAE,YAAY;AAAA,IAC3D,MAAM,YAAY,SAAS,MAAM,SAAS,EAAE,SAAS;AAAA,IACrD,MAAM,kBAAkB,SAAS,MAAM,SAAS,EAAE,eAAe;AAAA,IACjE,MAAM,uBAAuB,SAC3B,MAAM,SAAS,EAAE,oBACnB;AAAA,IACA,MAAM,YAAY,SAAS,MAAM,SAAS,EAAE,SAAS;AAAA,IACrD,MAAM,iBAAiB,SAAS,MAAM,SAAS,EAAE,cAAc;AAAA,IAC/D,MAAM,sBAAsB,SAAS,MAAM,SAAS,EAAE,mBAAmB;AAAA,IACzE,MAAM,eAAe,SAAS,MAAM,SAAS,EAAE,YAAY;AAAA,IAC3D,MAAM,aAAa,SAAS,MAAM,SAAS,EAAE,UAAU;AAAA,IACvD,MAAM,eAAe,SAAS,MAAM,SAAS,EAAE,YAAY;AAAA,IAC3D,MAAM,cAAc,SAAS,MAAM,SAAS,EAAE,WAAW;AAAA,IACzD,MAAM,oBAAoB,SAAS,MAAM,SAAS,EAAE,iBAAiB;AAAA,IACrE,MAAM,aAAa,SAAS,MAAM,SAAS,EAAE,UAAU;AAAA,IACvD,MAAM,UAAU,SAAS,MAAM,SAAS,EAAE,OAAO;AAAA,IACjD,MAAM,YAAY,SAAS,MAAM,SAAS,EAAE,SAAS;AAAA,IACrD,MAAM,QAAQ,SAAS,MAAM,SAAS,EAAE,KAAK;AAAA,IAE7C,OAAO;AAAA,SACF;AAAA,MACH;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,OAAO,OAAO;AAAA,MACd;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA;AAEJ;AAlEa,mBAAN,sDAAM;AAAN,4BAAM;AAAN,2BAAM;AAAN,wBAAM;;;ADJN;AAAA,EADN,YAAW,EAAE,YAAY,OAAO,CAAC;AAAA;AAC3B,YAAiC;AAAjC;AAAA;AAAA,MAAM,2BAAN,MAAkD;AAAA,EACvD,OAAO,CAAC,MAAc,gBAAyB;AAAA,IAC7C,MAAM,SAAS,MAAM,QAAQ,MAAM,cAAc;AAAA,IAEjD,OAAO;AAAA,SACF;AAAA,MACH,OAAO,UAAS,MAAM,OAAO,SAAS,CAAC;AAAA,IACzC;AAAA;AAEJ;AATa,qBAAN,wDAAM;AAAN,4BAAM;AAAN,2BAAM;AAAN,0BAAM;;AMJb,uBAAS;;;ACsET,IAAM,gBAAgB;AA8CtB,IAAM,cAA0C;AAAA,EAC9C,gBAAgB;AAClB;AAEA,IAAM,oBAAoB,CAAC,SACzB,KAAK,SAAS,GAAG,IAAI,KAAK,MAAM,GAAG,aAAa,IAAI;AAEtD,IAAM,YAAY,OAAU,aAAuB;AAAA,EACjD,MAAM,UAAa,KAAK,MAAM,MAAM,SAAS,KAAK,CAAC;AAAA,EAEnD,OAAO;AAAA;AAGT,IAAM,iBAAiB,CAAC,UAAgD;AAAA,EACtE,IAAI,CAAC,SAAS,OAAO,UAAU,UAAU;AAAA,IACvC,OAAO;AAAA,EACT;AAAA,EAEA,OAAO,EAAE,WAAW,UAAU,OAAO,MAAM,UAAU;AAAA;AAGvD,IAAM,iBAAiB,OAAO,aAAuB;AAAA,EACnD,IAAI;AAAA,IACF,MAAM,UAAU,KAAK,MAAM,MAAM,SAAS,KAAK,CAAC;AAAA,IAChD,IACE,eAAe,OAAO,KACtB,OAAO,QAAQ,UAAU,YACzB,QAAQ,OACR;AAAA,MACA,OAAO,QAAQ;AAAA,IACjB;AAAA,IACA,MAAM;AAAA,EAIR,OAAO,8BAA8B,SAAS;AAAA;AAwEzC,IAAM,kBAAkB,CAAC,YAA8B;AAAA,EAC5D,MAAM,WAAW,kBAAkB,QAAQ,IAAI;AAAA,EAC/C,MAAM,YAAY,QAAQ,SAAS;AAAA,EAEnC,MAAM,SAAS,OACb,UAGG;AAAA,IACH,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,MACrD,MAAM,KAAK,UAAU,KAAK;AAAA,MAC1B,SAAS;AAAA,MACT,QAAQ;AAAA,IACV,CAAC;AAAA,IAED,IAAI,CAAC,SAAS,IAAI;AAAA,MAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,IAChD;AAAA,IAEA,MAAM,UAAU,MAAM,UAA6B,QAAQ;AAAA,IAE3D,IAAI,CAAC,QAAQ,IAAI;AAAA,MACf,MAAM,IAAI,MAAM,QAAQ,SAAS,mBAAmB;AAAA,IACtD;AAAA,IAEA,IAAI,MAAM,iBAAiB,MAAM;AAAA,MAC/B,OAAO;AAAA,QACL,SAAS,QAAQ,WAAW,CAAC;AAAA,QAC7B,OAAO,QAAQ;AAAA,MACjB;AAAA,IACF;AAAA,IAEA,OAAQ,QAAQ,WAAW,CAAC;AAAA;AAAA,EAK9B,OAAO;AAAA,SACC,SAAQ,GAAG;AAAA,MACf,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,MAEvD,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,WAAU,GAAG;AAAA,MACjB,MAAM,WAAW,MAAM,UAAU,GAAG,kBAAkB;AAAA,QACpD,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAA2B,QAAQ;AAAA;AAAA,SAEtC,eAAc,CAAC,OAAoD;AAAA,MACvE,MAAM,WAAW,MAAM,UAAU,GAAG,sBAAsB;AAAA,QACxD,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,eAAc,CAAC,IAAY;AAAA,MAC/B,MAAM,WAAW,MAAM,UACrB,GAAG,sBAAsB,mBAAmB,EAAE,KAC9C;AAAA,QACE,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,eAAc,CAAC,IAAY;AAAA,MAC/B,MAAM,WAAW,MAAM,UACrB,GAAG,sBAAsB,mBAAmB,EAAE,UAChD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,QAAQ,MAAM,eAAe,QAAQ;AAAA,QAE3C,MAAM,gBAA2C;AAAA,UAC/C;AAAA,UACA,IAAI;AAAA,QACN;AAAA,QAEA,OAAO;AAAA,MACT;AAAA,MAEA,OAAO,UAAqC,QAAQ;AAAA;AAAA,SAEhD,UAAS,CAAC,MAAe;AAAA,MAC7B,MAAM,QAAQ,OAAO,SAAS,mBAAmB,IAAI,MAAM;AAAA,MAC3D,MAAM,WAAW,MAAM,UAAU,GAAG,qBAAqB,OAAO;AAAA,MAEhE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAgC,QAAQ;AAAA;AAAA,SAE3C,SAAQ,CAAC,OAA2B;AAAA,MACxC,MAAM,WAAW,MAAM,UAAU,GAAG,qBAAqB;AAAA,QACvD,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAiC,QAAQ;AAAA;AAAA,SAE5C,kBAAiB,CAAC,OAAsC;AAAA,MAC5D,MAAM,WAAW,MAAM,UAAU,GAAG,8BAA8B;AAAA,QAChE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAA0C,QAAQ;AAAA,MACxE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,YAAY;AAAA,QACtC,MAAM,IAAI,MAAM,QAAQ,SAAS,iCAAiC;AAAA,MACpE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,2BAA0B,CAAC,OAO9B;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,SAAS;AAAA,QAClB,aAAa,IAAI,WAAW,MAAM,OAAO;AAAA,MAC3C;AAAA,MACA,IAAI,OAAO,OAAO;AAAA,QAChB,aAAa,IAAI,SAAS,MAAM,KAAK;AAAA,MACvC;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,qCAAqC,QAC1C;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAiD,QAAQ;AAAA,MACjE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,MAAM;AAAA,QAChC,MAAM,IAAI,MACR,QAAQ,SAAS,yCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,mBAAkB,CAAC,OAKtB;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,QAAQ;AAAA,QACjB,aAAa,IAAI,UAAU,MAAM,MAAM;AAAA,MACzC;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,uCAAuC,QAC5C;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA4C,QAAQ;AAAA,MAC5D,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MAAM,QAAQ,SAAS,oCAAoC;AAAA,MACvE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,yBAAwB,CAC5B,OACA;AAAA,MACA,MAAM,UAAU,MAAM,KAAK,iCAAiC,KAAK;AAAA,MACjE,OAAO,QAAQ;AAAA;AAAA,SAEX,iCAAgC,CACpC,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,gDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAwC,QAAQ;AAAA,MACtE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,UAAU;AAAA,QACpC,MAAM,IAAI,MACR,QAAQ,SAAS,yCACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,+BAA8B,CAClC,OAGA;AAAA,MACA,MAAM,UAAU,MAAM,KAAK,uCAAuC,KAAK;AAAA,MACvE,OAAO,QAAQ;AAAA;AAAA,SAEX,uCAAsC,CAC1C,OAGA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,qDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAwC,QAAQ;AAAA,MACtE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,UAAU;AAAA,QACpC,MAAM,IAAI,MACR,QAAQ,SAAS,6CACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,gCAA+B,CACnC,OACA;AAAA,MACA,MAAM,UAAU,MAAM,KAAK,wCAAwC,KAAK;AAAA,MACxE,OAAO,QAAQ;AAAA;AAAA,SAEX,wCAAuC,CAC3C,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,oDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAwC,QAAQ;AAAA,MACtE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,UAAU;AAAA,QACpC,MAAM,IAAI,MACR,QAAQ,SAAS,kDACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,wBAAuB,CAAC,OAA0C;AAAA,MACtE,MAAM,WAAW,MAAM,UACrB,GAAG,+CACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAwC,QAAQ;AAAA,MACtE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,UAAU;AAAA,QACpC,MAAM,IAAI,MACR,QAAQ,SAAS,sCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,2BAA0B,CAAC,OAM9B;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,MAAM;AAAA,QACf,aAAa,IAAI,QAAQ,MAAM,IAAI;AAAA,MACrC;AAAA,MACA,IAAI,OAAO,iBAAiB;AAAA,QAC1B,aAAa,IAAI,mBAAmB,MAAM,eAAe;AAAA,MAC3D;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,iDAAiD,QACtD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,4CACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,6BAA4B,CAAC,OAOhC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC3C,IAAI,OAAO,MAAM,kBAAkB,UAAU;AAAA,QAC3C,aAAa,IAAI,iBAAiB,OAAO,MAAM,aAAa,CAAC;AAAA,MAC/D;AAAA,MACA,IAAI,OAAO,MAAM,kBAAkB,UAAU;AAAA,QAC3C,aAAa,IAAI,iBAAiB,OAAO,MAAM,aAAa,CAAC;AAAA,MAC/D;AAAA,MACA,IAAI,OAAO,MAAM,aAAa,UAAU;AAAA,QACtC,aAAa,IAAI,YAAY,OAAO,MAAM,QAAQ,CAAC;AAAA,MACrD;AAAA,MACA,IAAI,OAAO,MAAM,mBAAmB,UAAU;AAAA,QAC5C,aAAa,IAAI,kBAAkB,OAAO,MAAM,cAAc,CAAC;AAAA,MACjE;AAAA,MACA,IAAI,MAAM,oBAAoB;AAAA,QAC5B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,8CAA8C,cACnD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,4CACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,+BAA8B,CAAC,OAOlC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,OAAO,aAAa,UAAU;AAAA,QACvC,aAAa,IAAI,YAAY,OAAO,MAAM,QAAQ,CAAC;AAAA,MACrD;AAAA,MACA,IAAI,OAAO,OAAO;AAAA,QAChB,aAAa,IAAI,SAAS,MAAM,KAAK;AAAA,MACvC;AAAA,MACA,IAAI,OAAO,aAAa;AAAA,QACtB,aAAa,IAAI,eAAe,MAAM,WAAW;AAAA,MACnD;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,qBAAqB,MAAM,QAAQ;AAAA,MACtD;AAAA,MACA,IAAI,OAAO,gBAAgB;AAAA,QACzB,aAAa,IAAI,2BAA2B,MAAM,cAAc;AAAA,MAClE;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,iBAAiB;AAAA,MACxD,MAAM,WAAW,MAAM,UACrB,GAAG,gEAAgE,QACrE;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAqD,QAAQ;AAAA,MACrE,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,kDACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,kCAAiC,CAAC,OAkBrC;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,qEACH;AAAA,QACE,MAAM,KAAK,UAAU;AAAA,UACnB,qBAAqB,OAAO;AAAA,UAC5B,sBAAsB,OAAO;AAAA,UAC7B,gBAAgB,OAAO;AAAA,UACvB,aAAa,OAAO;AAAA,UACpB,UAAU,OAAO;AAAA,UACjB,OAAO,OAAO;AAAA,UACd,OAAO,OAAO;AAAA,UACd,UAAU,OAAO;AAAA,UACjB,YAAY,OAAO;AAAA,UACnB,YAAY,OAAO;AAAA,UACnB,UAAU,OAAO;AAAA,UACjB,MAAM,OAAO;AAAA,UACb,MAAM,OAAO;AAAA,QACf,CAAC;AAAA,QACD,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAqD,QAAQ;AAAA,MACrE,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,8CACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,2CAA0C,CAAC,OAQ9C;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,2EACH;AAAA,QACE,MAAM,KAAK,UAAU;AAAA,UACnB,WAAW,OAAO;AAAA,UAClB,aAAa,OAAO;AAAA,UACpB,OAAO,OAAO;AAAA,UACd,OAAO,OAAO;AAAA,UACd,UAAU,OAAO;AAAA,UACjB,kBAAkB,OAAO;AAAA,UACzB,SAAS,OAAO;AAAA,QAClB,CAAC;AAAA,QACD,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,mDACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,iCAAgC,CAAC,OAOpC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,OAAO,aAAa,UAAU;AAAA,QACvC,aAAa,IAAI,YAAY,OAAO,MAAM,QAAQ,CAAC;AAAA,MACrD;AAAA,MACA,IAAI,OAAO,OAAO;AAAA,QAChB,aAAa,IAAI,SAAS,MAAM,KAAK;AAAA,MACvC;AAAA,MACA,IAAI,OAAO,aAAa;AAAA,QACtB,aAAa,IAAI,eAAe,MAAM,WAAW;AAAA,MACnD;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,qBAAqB,MAAM,QAAQ;AAAA,MACtD;AAAA,MACA,IAAI,OAAO,gBAAgB;AAAA,QACzB,aAAa,IAAI,2BAA2B,MAAM,cAAc;AAAA,MAClE;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,iBAAiB;AAAA,MACxD,MAAM,WAAW,MAAM,UACrB,GAAG,kEAAkE,QACvE;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,oDACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,oCAAmC,CAAC,OAkBvC;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,uEACH;AAAA,QACE,MAAM,KAAK,UAAU;AAAA,UACnB,qBAAqB,OAAO;AAAA,UAC5B,sBAAsB,OAAO;AAAA,UAC7B,gBAAgB,OAAO;AAAA,UACvB,aAAa,OAAO;AAAA,UACpB,UAAU,OAAO;AAAA,UACjB,OAAO,OAAO;AAAA,UACd,OAAO,OAAO;AAAA,UACd,UAAU,OAAO;AAAA,UACjB,YAAY,OAAO;AAAA,UACnB,YAAY,OAAO;AAAA,UACnB,UAAU,OAAO;AAAA,UACjB,MAAM,OAAO;AAAA,UACb,MAAM,OAAO;AAAA,QACf,CAAC;AAAA,QACD,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SAAS,gDACnB;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,6CAA4C,CAAC,OAQhD;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,6EACH;AAAA,QACE,MAAM,KAAK,UAAU;AAAA,UACnB,WAAW,OAAO;AAAA,UAClB,aAAa,OAAO;AAAA,UACpB,OAAO,OAAO;AAAA,UACd,OAAO,OAAO;AAAA,UACd,UAAU,OAAO;AAAA,UACjB,kBAAkB,OAAO;AAAA,UACzB,SAAS,OAAO;AAAA,QAClB,CAAC;AAAA,QACD,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,IAAI;AAAA,QACf,MAAM,IAAI,MACR,QAAQ,SACN,qDACJ;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,sBAAqB,CAAC,OAKzB;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,sCAAsC,QAC3C;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA+C,QAAQ;AAAA,MAC/D,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,UAAU;AAAA,QACpC,MAAM,IAAI,MACR,QAAQ,SAAS,wCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,8BAA6B,CAAC,OAMjC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,IAAI,OAAO,MAAM;AAAA,QACf,aAAa,IAAI,QAAQ,MAAM,IAAI;AAAA,MACrC;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,gDAAgD,QACrD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,iDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,8BAA6B,CAAC,OAMjC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO;AAAA,QAAU,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAChE,IAAI,OAAO,OAAO,UAAU;AAAA,QAC1B,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C,IAAI,OAAO;AAAA,QAAQ,aAAa,IAAI,UAAU,MAAM,MAAM;AAAA,MAC1D,IAAI,OAAO;AAAA,QAAU,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAChE,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,gDAAgD,QACrD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,iDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,oCAAmC,CAAC,OAMvC;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,wDAAwD,QAC7D;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SAAS,oDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,8CAA6C,CAAC,OAIjD;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,uDAAuD,QAC5D;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,gEACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,kCAAiC,CAAC,OAKrC;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,sDAAsD,QAC3D;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAwD,QAAQ;AAAA,MACxE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SAAS,kDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,mCAAkC,CAAC,OAKtC;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,mDAAmD,QACxD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SAAS,mDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,4CAA2C,CAAC,OAI/C;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,yDAAyD,QAC9D;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,6DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,sCAAqC,CAAC,OAIzC;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,uDAAuD,QAC5D;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,sDACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,+BAA8B,GAAG;AAAA,MACrC,MAAM,WAAW,MAAM,UAAU,GAAG,mCAAmC;AAAA,MAEvE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAqD,QAAQ;AAAA;AAAA,SAEhE,mCAAkC,GAAG;AAAA,MACzC,MAAM,WAAW,MAAM,UACrB,GAAG,sCACL;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAyD,QAAQ;AAAA;AAAA,SAEpE,mCAAkC,GAAG;AAAA,MACzC,MAAM,WAAW,MAAM,UAAU,GAAG,oCAAoC;AAAA,MAExE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAyD,QAAQ;AAAA;AAAA,SAEpE,wCAAuC,CAC3C,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,6DACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SACN,4DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,0CAAyC,CAAC,OAE7C;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,+DACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SACN,0DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,oCAAmC,CAAC,OAKvC;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,yDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAuD,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,oDACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,2BAA0B,CAC9B,OACA;AAAA,MACA,MAAM,UAAU,MAAM,KAAK,mCAAmC,KAAK;AAAA,MACnE,IAAI,CAAC,QAAQ,UAAU;AAAA,QACrB,MAAM,IAAI,MACR,QAAQ,SAAS,4CACnB;AAAA,MACF;AAAA,MACA,OAAO,QAAQ;AAAA;AAAA,SAEX,mCAAkC,CACtC,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,8CACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAmD,QAAQ;AAAA;AAAA,SAE9D,0BAAyB,CAAC,OAY7B;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,QAAQ;AAAA,QACjB,aAAa,IAAI,UAAU,MAAM,MAAM;AAAA,MACzC;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,MAAM;AAAA,QACf,aAAa,IAAI,QAAQ,MAAM,IAAI;AAAA,MACrC;AAAA,MACA,IAAI,OAAO,OAAO,iBAAiB,WAAW;AAAA,QAC5C,aAAa,IAAI,gBAAgB,OAAO,MAAM,YAAY,CAAC;AAAA,MAC7D;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,uCAAuC,QAC5C;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,4CACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,sCAAqC,CAAC,OAOzC;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,oDAAoD,QACzD;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,yDACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,uCAAsC,CAAC,OAW1C;AAAA,MACD,MAAM,SAAS,QACX,IAAI,IAAI,gBACN,OAAO,QAAQ,KAAK,EACjB,OAAO,IAAI,WAAW,UAAU,SAAS,EACzC,IAAI,EAAE,KAAK,WAAW,CAAC,KAAK,OAAO,KAAK,CAAC,CAAC,CAC/C,EAAE,SAAS,MACX;AAAA,MACJ,MAAM,WAAW,MAAM,UACrB,GAAG,+DAA+D,QACpE;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,6DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,2CAA0C,CAC9C,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,qDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,2DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,oCAAmC,CACvC,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,6DACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SACN,qDACJ;AAAA,MACF;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,yCAAwC,CAC5C,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,kEACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UACJ,QACF;AAAA,MACF,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SACN,0DACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,oCAAmC,CACvC,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,oDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SACN,uDACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,sCAAqC,CAAC,OAA+B;AAAA,MACzE,MAAM,WAAW,MAAM,UACrB,GAAG,sDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SACN,qDACJ;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,gCAA+B,CAAC,OAKnC;AAAA,MACD,MAAM,WAAW,MAAM,UACrB,GAAG,gDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MACR,QAAQ,SAAS,+CACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,6BAA4B,CAAC,OAYhC;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,IAAI,OAAO,oBAAoB;AAAA,QAC7B,aAAa,IAAI,sBAAsB,MAAM,kBAAkB;AAAA,MACjE;AAAA,MACA,IAAI,OAAO,OAAO,aAAa,WAAW;AAAA,QACxC,aAAa,IAAI,YAAY,OAAO,MAAM,QAAQ,CAAC;AAAA,MACrD;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,WAAW;AAAA,QACrC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,OAAO,YAAY,WAAW;AAAA,QACvC,aAAa,IAAI,WAAW,OAAO,MAAM,OAAO,CAAC;AAAA,MACnD;AAAA,MACA,IAAI,OAAO,cAAc;AAAA,QACvB,aAAa,IAAI,gBAAgB,MAAM,YAAY;AAAA,MACrD;AAAA,MACA,IAAI,OAAO,iBAAiB;AAAA,QAC1B,aAAa,IAAI,mBAAmB,MAAM,eAAe;AAAA,MAC3D;AAAA,MACA,IAAI,OAAO,QAAQ;AAAA,QACjB,aAAa,IAAI,UAAU,MAAM,MAAM;AAAA,MACzC;AAAA,MACA,IAAI,OAAO,eAAe;AAAA,QACxB,aAAa,IAAI,iBAAiB,MAAM,aAAa;AAAA,MACvD;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,wCAAwC,QAC7C;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAsD,QAAQ;AAAA,MACtE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,YAAY;AAAA,QACtC,MAAM,IAAI,MACR,QAAQ,SAAS,+CACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,0BAAyB,CAC7B,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,gDACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MAAM,QAAQ,SAAS,+BAA+B;AAAA,MAClE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,yBAAwB,CAC5B,OACA;AAAA,MACA,MAAM,WAAW,MAAM,UACrB,GAAG,+CACH;AAAA,QACE,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAAmD,QAAQ;AAAA,MACnE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,WAAW;AAAA,QACrC,MAAM,IAAI,MAAM,QAAQ,SAAS,gCAAgC;AAAA,MACnE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,OAAM,CAAC,QAA4B;AAAA,MACvC,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,QACrD,MAAM,KAAK,UAAU,EAAE,OAAO,CAAC;AAAA,QAC/B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,gBAAe,CAAC,OAA+B;AAAA,MACnD,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,QACrD,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,cAAa,CAAC,OAAqC;AAAA,MACvD,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,QACrD,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,WAAU,CAAC,OAAkC;AAAA,MACjD,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,QACrD,MAAM,KAAK,UAAU,KAAK;AAAA,QAC1B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,eAAc,GAAG;AAAA,MACrB,MAAM,WAAW,MAAM,UAAU,GAAG,4BAA4B;AAAA,QAC9D,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,IAAG,GAAG;AAAA,MACV,MAAM,WAAW,MAAM,UAAU,GAAG,cAAc;AAAA,MAElD,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAiC,QAAQ;AAAA;AAAA,SAE5C,mBAAkB,CAAC,OAKtB;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,OAAO;AAAA,QAChB,aAAa,IAAI,SAAS,MAAM,KAAK;AAAA,MACvC;AAAA,MACA,IAAI,OAAO,UAAU;AAAA,QACnB,aAAa,IAAI,YAAY,MAAM,QAAQ;AAAA,MAC7C;AAAA,MACA,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UAAU,GAAG,kBAAkB,QAAQ;AAAA,MAE9D,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAyC,QAAQ;AAAA,MACvE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MAAM,QAAQ,SAAS,iCAAiC;AAAA,MACpE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,kBAAiB,CAAC,OAA0C;AAAA,MAChE,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UAAU,GAAG,yBAAyB,QAAQ;AAAA,MAErE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA8C,QAAQ;AAAA,MAC9D,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SAAS,uCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,iBAAgB,CAAC,OAA0B;AAAA,MAC/C,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,KAAK;AAAA,QACd,aAAa,IAAI,OAAO,MAAM,GAAG;AAAA,MACnC;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UAAU,GAAG,wBAAwB,QAAQ;AAAA,MAEpE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAuC,QAAQ;AAAA,MACrE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,OAAO;AAAA,QACjC,MAAM,IAAI,MAAM,QAAQ,SAAS,+BAA+B;AAAA,MAClE;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,wBAAuB,CAAC,OAM3B;AAAA,MACD,MAAM,WAAW,MAAM,UAAU,GAAG,iCAAiC;AAAA,QACnE,MAAM,KAAK,UAAU,SAAS,CAAC,CAAC;AAAA,QAChC,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA8C,QAAQ;AAAA,MAC9D,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,SAAS;AAAA,QACnC,MAAM,IAAI,MACR,QAAQ,SAAS,uCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,kBAAiB,CAAC,OAMrB;AAAA,MACD,MAAM,WAAW,MAAM,UAAU,GAAG,yBAAyB;AAAA,QAC3D,MAAM,KAAK,UAAU,SAAS,CAAC,CAAC;AAAA,QAChC,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UAAU,MAAM,UAAuC,QAAQ;AAAA,MACrE,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,QAAQ;AAAA,QAClC,MAAM,IAAI,MAAM,QAAQ,SAAS,+BAA+B;AAAA,MAClE;AAAA,MAEA,OAAO;AAAA;AAAA,SAEH,wBAAuB,CAAC,OAG3B;AAAA,MACD,MAAM,eAAe,IAAI;AAAA,MACzB,IAAI,OAAO,OAAO,UAAU,UAAU;AAAA,QACpC,aAAa,IAAI,SAAS,OAAO,MAAM,KAAK,CAAC;AAAA,MAC/C;AAAA,MACA,IAAI,OAAO,SAAS;AAAA,QAClB,aAAa,IAAI,WAAW,MAAM,OAAO;AAAA,MAC3C;AAAA,MACA,MAAM,SAAS,aAAa,OAAO,IAAI,IAAI,iBAAiB;AAAA,MAC5D,MAAM,WAAW,MAAM,UACrB,GAAG,gCAAgC,QACrC;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA8C,QAAQ;AAAA,MAC9D,IAAI,CAAC,QAAQ,MAAM,CAAC,QAAQ,MAAM;AAAA,QAChC,MAAM,IAAI,MACR,QAAQ,SAAS,uCACnB;AAAA,MACF;AAAA,MAEA,OAAO,QAAQ;AAAA;AAAA,SAEX,YAAW,GAAG;AAAA,MAClB,MAAM,WAAW,MAAM,UAAU,GAAG,eAAe;AAAA,MAEnD,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAA2B,QAAQ;AAAA;AAAA,SAEtC,eAAc,CAAC,UAA6B;AAAA,MAChD,MAAM,WAAW,MAAM,UAAU,GAAG,iBAAiB;AAAA,QACnD,MACE,UAAS,eAAe,OACpB,KAAK,UAAU,EAAE,YAAY,KAAK,CAAC,IACnC;AAAA,QACN,SAAS,UAAS,eAAe,OAAO,cAAc;AAAA,QACtD,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA2B,QAAQ;AAAA;AAAA,SAEtC,WAAU,CAAC,IAAY,UAA6B;AAAA,MACxD,MAAM,WAAW,MAAM,UACrB,GAAG,iBAAiB,mBAAmB,EAAE,KACzC;AAAA,QACE,MACE,UAAS,eAAe,OACpB,KAAK,UAAU,EAAE,YAAY,KAAK,CAAC,IACnC;AAAA,QACN,SAAS,UAAS,eAAe,OAAO,cAAc;AAAA,QACtD,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA2B,QAAQ;AAAA;AAAA,SAEtC,gBAAe,CAAC,IAAY;AAAA,MAChC,MAAM,WAAW,MAAM,UACrB,GAAG,8BAA8B,mBAAmB,EAAE,KACtD;AAAA,QACE,QAAQ;AAAA,MACV,CACF;AAAA,MAEA,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,cAAa,CAAC,QAAgB;AAAA,MAClC,MAAM,WAAW,MAAM,UAAU,GAAG,2BAA2B;AAAA,QAC7D,MAAM,KAAK,UAAU,EAAE,OAAO,CAAC;AAAA,QAC/B,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,OAAM,GAAG;AAAA,MACb,MAAM,WAAW,MAAM,UAAU,GAAG,mBAAmB;AAAA,QACrD,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,MAAK,GAAG;AAAA,MACZ,MAAM,WAAW,MAAM,UAAU,GAAG,kBAAkB;AAAA,QACpD,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,SAE1C,mBAAkB,GAAG;AAAA,MACzB,MAAM,WAAW,MAAM,UAAU,GAAG,mCAAmC;AAAA,QACrE,QAAQ;AAAA,MACV,CAAC;AAAA,MAED,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,OAAO;AAAA,UACL,OAAO,MAAM,eAAe,QAAQ;AAAA,UACpC,IAAI;AAAA,QACN;AAAA,MACF;AAAA,MAEA,OAAO,UAA+B,QAAQ;AAAA;AAAA,IAEhD;AAAA,SACM,gBAAe,CAAC,OAAyB;AAAA,MAC7C,OAAO,OAAO,KAAK,OAAO,cAAc,KAAK,CAAC;AAAA;AAAA,SAK1C,eAAc,CAAC,OAAyB;AAAA,MAC5C,OAAO,OAAO,KAAK,OAAO,cAAc,KAAK,CAAC;AAAA;AAAA,SAE1C,OAAM,GAAG;AAAA,MACb,MAAM,WAAW,MAAM,UAAU,GAAG,iBAAiB;AAAA,MAErD,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,kBAAiB,GAAG;AAAA,MACxB,MAAM,WAAW,MAAM,UAAU,GAAG,6BAA6B;AAAA,MAEjE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAA6B,QAAQ;AAAA;AAAA,SAExC,uBAAsB,GAAG;AAAA,MAC7B,MAAM,WAAW,MAAM,UAAU,GAAG,yBAAyB;AAAA,MAE7D,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,MAAM,UACJ,MAAM,UAA6C,QAAQ;AAAA,MAC7D,OAAO,QAAQ;AAAA;AAAA,SAEX,4BAA2B,GAAG;AAAA,MAClC,MAAM,WAAW,MAAM,UAAU,GAAG,+BAA+B;AAAA,MAEnE,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAkD,QAAQ;AAAA;AAAA,SAE7D,2BAA0B,GAAG;AAAA,MACjC,MAAM,WAAW,MAAM,UAAU,GAAG,0BAA0B;AAAA,MAE9D,IAAI,CAAC,SAAS,IAAI;AAAA,QAChB,MAAM,IAAI,MAAM,MAAM,eAAe,QAAQ,CAAC;AAAA,MAChD;AAAA,MAEA,OAAO,UAAiD,QAAQ;AAAA;AAAA,EAEpE;AAAA;;;AD1qEK;AAAA,EADN,YAAW,EAAE,YAAY,OAAO,CAAC;AAAA;AAC3B;AAAA;AAAA,MAAM,iBAAiB;AAAA,EACpB,UAAU,IAAI;AAAA,EAEd,MAAM,CAAC,MAAc;AAAA,IAC3B,MAAM,WAAW,KAAK,QAAQ,IAAI,IAAI;AAAA,IACtC,IAAI,UAAU;AAAA,MACZ,OAAO;AAAA,IACT;AAAA,IAEA,MAAM,UAAU,gBAAgB,EAAE,KAAK,CAAC;AAAA,IACxC,KAAK,QAAQ,IAAI,MAAM,OAAO;AAAA,IAE9B,OAAO;AAAA;AAAA,EAGT,MAAM,CAAC,MAAc,QAA4B;AAAA,IAC/C,OAAO,KAAK,OAAO,IAAI,EAAE,OAAO,MAAM;AAAA;AAAA,EAGxC,eAAe,CAAC,MAAc,OAA+B;AAAA,IAC3D,OAAO,KAAK,OAAO,IAAI,EAAE,gBAAgB,KAAK;AAAA;AAAA,EAGhD,UAAU,CAAC,MAAc,OAAkC;AAAA,IACzD,OAAO,KAAK,OAAO,IAAI,EAAE,WAAW,KAAK;AAAA;AAAA,EAG3C,aAAa,CAAC,MAAc,OAAqC;AAAA,IAC/D,OAAO,KAAK,OAAO,IAAI,EAAE,cAAc,KAAK;AAAA;AAAA,EAG9C,MAAM,CAAC,MAAc,OAAyB;AAAA,IAC5C,OAAO,KAAK,OAAO,IAAI,EAAE,OAAO,KAAK;AAAA;AAAA,EAGvC,eAAe,CAAC,MAAc,OAAyB;AAAA,IACrD,OAAO,KAAK,OAAO,IAAI,EAAE,gBAAgB,KAAK;AAAA;AAAA,EAGhD,QAAQ,CAAC,MAAc,OAA2B;AAAA,IAChD,OAAO,KAAK,OAAO,IAAI,EAAE,SAAS,KAAK;AAAA;AAAA,EAGzC,iBAAiB,CAAC,MAAc,OAAsC;AAAA,IACpE,OAAO,KAAK,OAAO,IAAI,EAAE,kBAAkB,KAAK;AAAA;AAAA,EAGlD,0BAA0B,CACxB,MACA,OAQA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,2BAA2B,KAAK;AAAA;AAAA,EAG3D,kBAAkB,CAChB,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,mBAAmB,KAAK;AAAA;AAAA,EAGnD,wBAAwB,CACtB,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,yBAAyB,KAAK;AAAA;AAAA,EAGzD,gCAAgC,CAC9B,MACA,OACuC;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,iCAAiC,KAAK;AAAA;AAAA,EAGjE,8BAA8B,CAC5B,MACA,OAGA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,+BAA+B,KAAK;AAAA;AAAA,EAG/D,sCAAsC,CACpC,MACA,OAGuC;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,uCAAuC,KAAK;AAAA;AAAA,EAGvE,+BAA+B,CAC7B,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,gCAAgC,KAAK;AAAA;AAAA,EAGhE,uCAAuC,CACrC,MACA,OACuC;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,wCAAwC,KAAK;AAAA;AAAA,EAGxE,uBAAuB,CACrB,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,wBAAwB,KAAK;AAAA;AAAA,EAGxD,0BAA0B,CACxB,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,2BAA2B,KAAK;AAAA;AAAA,EAG3D,4BAA4B,CAC1B,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,6BAA6B,KAAK;AAAA;AAAA,EAG7D,qBAAqB,CACnB,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,sBAAsB,KAAK;AAAA;AAAA,EAGtD,6BAA6B,CAC3B,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,8BAA8B,KAAK;AAAA;AAAA,EAG9D,6BAA6B,CAC3B,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,8BAA8B,KAAK;AAAA;AAAA,EAG9D,mCAAmC,CACjC,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,oCAAoC,KAAK;AAAA;AAAA,EAGpE,6CAA6C,CAC3C,MACA,OAKA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,8CACvB,KACF;AAAA;AAAA,EAGF,iCAAiC,CAC/B,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,kCAAkC,KAAK;AAAA;AAAA,EAGlE,kCAAkC,CAChC,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,mCAAmC,KAAK;AAAA;AAAA,EAGnE,2CAA2C,CACzC,MACA,OAKA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,4CAA4C,KAAK;AAAA;AAAA,EAG5E,qCAAqC,CACnC,MACA,OAKA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,sCAAsC,KAAK;AAAA;AAAA,EAGtE,0BAA0B,CACxB,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,2BAA2B,KAAK;AAAA;AAAA,EAG3D,kCAAkC,CAChC,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,mCAAmC,KAAK;AAAA;AAAA,EAGnE,yBAAyB,CACvB,MACA,OAaA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,0BAA0B,KAAK;AAAA;AAAA,EAG1D,qCAAqC,CACnC,MACA,OAeA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,sCAAsC,KAAK;AAAA;AAAA,EAGtE,sCAAsC,CACpC,MACA,OAkBA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,uCAAuC,KAAK;AAAA;AAAA,EAGvE,0CAA0C,CACxC,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,2CAA2C,KAAK;AAAA;AAAA,EAG3E,mCAAmC,CACjC,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,oCAAoC,KAAK;AAAA;AAAA,EAGpE,wCAAwC,CACtC,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,yCAAyC,KAAK;AAAA;AAAA,EAGzE,sBAAsB,CAAC,MAAc;AAAA,IACnC,OAAO,KAAK,OAAO,IAAI,EAAE,uBAAuB;AAAA;AAAA,EAGlD,8BAA8B,CAAC,MAAc;AAAA,IAC3C,OAAO,KAAK,OAAO,IAAI,EAAE,+BAA+B;AAAA;AAAA,EAG1D,kCAAkC,CAAC,MAAc;AAAA,IAC/C,OAAO,KAAK,OAAO,IAAI,EAAE,mCAAmC;AAAA;AAAA,EAG9D,2BAA2B,CAAC,MAAc;AAAA,IACxC,OAAO,KAAK,OAAO,IAAI,EAAE,4BAA4B;AAAA;AAAA,EAGvD,0BAA0B,CAAC,MAAc;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,2BAA2B;AAAA;AAAA,EAGtD,kCAAkC,CAAC,MAAc;AAAA,IAC/C,OAAO,KAAK,OAAO,IAAI,EAAE,mCAAmC;AAAA;AAAA,EAG9D,uCAAuC,CACrC,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,wCAAwC,KAAK;AAAA;AAAA,EAGxE,yCAAyC,CACvC,MACA,OAGA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,0CAA0C,KAAK;AAAA;AAAA,EAG1E,mCAAmC,CACjC,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,oCAAoC,KAAK;AAAA;AAAA,EAGpE,mCAAmC,CACjC,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,oCAAoC,KAAK;AAAA;AAAA,EAGpE,qCAAqC,CACnC,MACA,OAGA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,sCAAsC,KAAK;AAAA;AAAA,EAGtE,+BAA+B,CAC7B,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,gCAAgC,KAAK;AAAA;AAAA,EAGhE,4BAA4B,CAC1B,MACA,OAaA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,6BAA6B,KAAK;AAAA;AAAA,EAG7D,yBAAyB,CACvB,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,0BAA0B,KAAK;AAAA;AAAA,EAG1D,wBAAwB,CACtB,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,yBAAyB,KAAK;AAAA;AAAA,EAGzD,MAAM,CAAC,MAAc;AAAA,IACnB,OAAO,KAAK,OAAO,IAAI,EAAE,OAAO;AAAA;AAAA,EAGlC,GAAG,CAAC,MAAc;AAAA,IAChB,OAAO,KAAK,OAAO,IAAI,EAAE,IAAI;AAAA;AAAA,EAG/B,kBAAkB,CAChB,MACA,OAMA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,mBAAmB,KAAK;AAAA;AAAA,EAGnD,iBAAiB,CACf,MACA,OAIA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,kBAAkB,KAAK;AAAA;AAAA,EAGlD,gBAAgB,CAAC,MAAc,OAA0B;AAAA,IACvD,OAAO,KAAK,OAAO,IAAI,EAAE,iBAAiB,KAAK;AAAA;AAAA,EAGjD,uBAAuB,CACrB,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,wBAAwB,KAAK;AAAA;AAAA,EAGxD,iBAAiB,CACf,MACA,OAOA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,kBAAkB,KAAK;AAAA;AAAA,EAGlD,uBAAuB,CACrB,MACA,OAIA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,wBAAwB,KAAK;AAAA;AAAA,EAGxD,WAAW,CAAC,MAAc;AAAA,IACxB,OAAO,KAAK,OAAO,IAAI,EAAE,YAAY;AAAA;AAAA,EAGvC,cAAc,CAAC,MAAc,SAA6B;AAAA,IACxD,OAAO,KAAK,OAAO,IAAI,EAAE,eAAe,OAAO;AAAA;AAAA,EAGjD,UAAU,CAAC,MAAc,IAAY,SAA6B;AAAA,IAChE,OAAO,KAAK,OAAO,IAAI,EAAE,WAAW,IAAI,OAAO;AAAA;AAAA,EAGjD,SAAS,CAAC,MAAc,MAAe;AAAA,IACrC,OAAO,KAAK,OAAO,IAAI,EAAE,UAAU,IAAI;AAAA;AAAA,EAGzC,cAAc,CAAC,MAAc,IAAY;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,eAAe,EAAE;AAAA;AAAA,EAG5C,cAAc,CACZ,MACA,OACA;AAAA,IACA,OAAO,KAAK,OAAO,IAAI,EAAE,eAAe,KAAK;AAAA;AAAA,EAG/C,cAAc,CAAC,MAAc,IAAY;AAAA,IACvC,OAAO,KAAK,OAAO,IAAI,EAAE,eAAe,EAAE;AAAA;AAAA,EAG5C,MAAM,CAAC,MAAc;AAAA,IACnB,OAAO,KAAK,OAAO,IAAI,EAAE,OAAO;AAAA;AAAA,EAGlC,KAAK,CAAC,MAAc;AAAA,IAClB,OAAO,KAAK,OAAO,IAAI,EAAE,MAAM;AAAA;AAAA,EAGjC,eAAe,CAAC,MAAc,IAAY;AAAA,IACxC,OAAO,KAAK,OAAO,IAAI,EAAE,gBAAgB,EAAE;AAAA;AAAA,EAG7C,aAAa,CAAC,MAAc,QAAgB;AAAA,IAC1C,OAAO,KAAK,OAAO,IAAI,EAAE,cAAc,MAAM;AAAA;AAAA,EAG/C,QAAQ,CAAC,MAAc;AAAA,IACrB,OAAO,KAAK,OAAO,IAAI,EAAE,SAAS;AAAA;AAAA,EAGpC,UAAU,CAAC,MAAc;AAAA,IACvB,OAAO,KAAK,OAAO,IAAI,EAAE,WAAW;AAAA;AAExC;AAhmBa,mBAAN,sDAAM;AAAN,4BAAM;AAAN,2BAAM;AAAN,wBAAM;",
15
15
  "debugId": "2089A913B3BF077264756E2164756E21",
16
16
  "names": []
17
17
  }