@jbrowse/plugin-alignments 1.6.9 → 1.7.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 (131) hide show
  1. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.d.ts +6 -6
  2. package/dist/AlignmentsFeatureDetail/AlignmentsFeatureDetail.js +216 -0
  3. package/dist/AlignmentsFeatureDetail/index.d.ts +13 -13
  4. package/dist/AlignmentsFeatureDetail/index.js +63 -0
  5. package/dist/AlignmentsFeatureDetail/index.test.js +60 -0
  6. package/dist/AlignmentsTrack/index.d.ts +2 -2
  7. package/dist/AlignmentsTrack/index.js +37 -0
  8. package/dist/BamAdapter/BamAdapter.d.ts +40 -30
  9. package/dist/BamAdapter/BamAdapter.js +598 -0
  10. package/dist/BamAdapter/BamAdapter.test.js +177 -0
  11. package/dist/BamAdapter/BamSlightlyLazyFeature.d.ts +33 -33
  12. package/dist/BamAdapter/BamSlightlyLazyFeature.js +176 -0
  13. package/dist/BamAdapter/MismatchParser.d.ts +28 -28
  14. package/dist/BamAdapter/MismatchParser.js +384 -0
  15. package/dist/BamAdapter/MismatchParser.test.js +259 -0
  16. package/dist/BamAdapter/configSchema.d.ts +2 -2
  17. package/dist/BamAdapter/configSchema.js +48 -0
  18. package/dist/BamAdapter/index.d.ts +3 -3
  19. package/dist/BamAdapter/index.js +36 -0
  20. package/dist/CramAdapter/CramAdapter.d.ts +52 -43
  21. package/dist/CramAdapter/CramAdapter.js +660 -0
  22. package/dist/CramAdapter/CramAdapter.test.js +138 -0
  23. package/dist/CramAdapter/CramSlightlyLazyFeature.d.ts +49 -49
  24. package/dist/CramAdapter/CramSlightlyLazyFeature.js +447 -0
  25. package/dist/CramAdapter/CramTestAdapters.d.ts +29 -29
  26. package/dist/CramAdapter/CramTestAdapters.js +234 -0
  27. package/dist/CramAdapter/configSchema.d.ts +3 -3
  28. package/dist/CramAdapter/configSchema.js +40 -0
  29. package/dist/CramAdapter/index.d.ts +3 -3
  30. package/dist/CramAdapter/index.js +36 -0
  31. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.d.ts +9 -9
  32. package/dist/HtsgetBamAdapter/HtsgetBamAdapter.js +97 -0
  33. package/dist/HtsgetBamAdapter/configSchema.d.ts +2 -2
  34. package/dist/HtsgetBamAdapter/configSchema.js +31 -0
  35. package/dist/HtsgetBamAdapter/index.d.ts +3 -3
  36. package/dist/HtsgetBamAdapter/index.js +42 -0
  37. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.d.ts +7 -7
  38. package/dist/LinearAlignmentsDisplay/components/AlignmentsDisplay.js +69 -0
  39. package/dist/LinearAlignmentsDisplay/index.d.ts +2 -2
  40. package/dist/LinearAlignmentsDisplay/index.js +31 -0
  41. package/dist/LinearAlignmentsDisplay/models/configSchema.d.ts +4 -4
  42. package/dist/LinearAlignmentsDisplay/models/configSchema.js +25 -0
  43. package/dist/LinearAlignmentsDisplay/models/configSchema.test.js +83 -0
  44. package/dist/LinearAlignmentsDisplay/models/model.d.ts +105 -105
  45. package/dist/LinearAlignmentsDisplay/models/model.js +250 -0
  46. package/dist/LinearPileupDisplay/components/ColorByModifications.d.ts +14 -14
  47. package/dist/LinearPileupDisplay/components/ColorByModifications.js +123 -0
  48. package/dist/LinearPileupDisplay/components/ColorByTag.d.ts +9 -9
  49. package/dist/LinearPileupDisplay/components/ColorByTag.js +98 -0
  50. package/dist/LinearPileupDisplay/components/FilterByTag.d.ts +18 -18
  51. package/dist/LinearPileupDisplay/components/FilterByTag.js +203 -0
  52. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.d.ts +13 -13
  53. package/dist/LinearPileupDisplay/components/LinearPileupDisplayBlurb.js +32 -0
  54. package/dist/LinearPileupDisplay/components/SetFeatureHeight.d.ts +16 -16
  55. package/dist/LinearPileupDisplay/components/SetFeatureHeight.js +99 -0
  56. package/dist/LinearPileupDisplay/components/SetMaxHeight.d.ts +10 -10
  57. package/dist/LinearPileupDisplay/components/SetMaxHeight.js +90 -0
  58. package/dist/LinearPileupDisplay/components/SortByTag.d.ts +9 -9
  59. package/dist/LinearPileupDisplay/components/SortByTag.js +95 -0
  60. package/dist/LinearPileupDisplay/configSchema.d.ts +6 -6
  61. package/dist/LinearPileupDisplay/configSchema.js +47 -0
  62. package/dist/LinearPileupDisplay/configSchema.test.js +92 -0
  63. package/dist/LinearPileupDisplay/index.d.ts +2 -2
  64. package/dist/LinearPileupDisplay/index.js +30 -0
  65. package/dist/LinearPileupDisplay/model.d.ts +319 -321
  66. package/dist/LinearPileupDisplay/model.js +602 -0
  67. package/dist/LinearSNPCoverageDisplay/components/Tooltip.d.ts +10 -10
  68. package/dist/LinearSNPCoverageDisplay/components/Tooltip.js +63 -0
  69. package/dist/LinearSNPCoverageDisplay/index.d.ts +2 -2
  70. package/dist/LinearSNPCoverageDisplay/index.js +30 -0
  71. package/dist/LinearSNPCoverageDisplay/models/configSchema.d.ts +2 -2
  72. package/dist/LinearSNPCoverageDisplay/models/configSchema.js +57 -0
  73. package/dist/LinearSNPCoverageDisplay/models/configSchema.test.js +62 -0
  74. package/dist/LinearSNPCoverageDisplay/models/model.d.ts +346 -96
  75. package/dist/LinearSNPCoverageDisplay/models/model.js +237 -0
  76. package/dist/NestedFrequencyTable.d.ts +14 -14
  77. package/dist/NestedFrequencyTable.js +152 -0
  78. package/dist/PileupRPC/rpcMethods.d.ts +34 -34
  79. package/dist/PileupRPC/rpcMethods.js +285 -0
  80. package/dist/PileupRenderer/PileupLayoutSession.d.ts +29 -29
  81. package/dist/PileupRenderer/PileupLayoutSession.js +79 -0
  82. package/dist/PileupRenderer/PileupRenderer.d.ts +125 -125
  83. package/dist/PileupRenderer/PileupRenderer.js +1220 -0
  84. package/dist/PileupRenderer/components/PileupRendering.d.ts +23 -23
  85. package/dist/PileupRenderer/components/PileupRendering.js +270 -0
  86. package/dist/PileupRenderer/components/PileupRendering.test.js +36 -0
  87. package/dist/PileupRenderer/configSchema.d.ts +2 -2
  88. package/dist/PileupRenderer/configSchema.js +72 -0
  89. package/dist/PileupRenderer/index.d.ts +2 -2
  90. package/dist/PileupRenderer/index.js +25 -0
  91. package/dist/PileupRenderer/sortUtil.d.ts +8 -8
  92. package/dist/PileupRenderer/sortUtil.js +112 -0
  93. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.d.ts +67 -71
  94. package/dist/SNPCoverageAdapter/SNPCoverageAdapter.js +606 -0
  95. package/dist/SNPCoverageAdapter/configSchema.d.ts +3 -3
  96. package/dist/SNPCoverageAdapter/configSchema.js +22 -0
  97. package/dist/SNPCoverageAdapter/index.d.ts +3 -3
  98. package/dist/SNPCoverageAdapter/index.js +45 -0
  99. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.d.ts +20 -20
  100. package/dist/SNPCoverageRenderer/SNPCoverageRenderer.js +296 -0
  101. package/dist/SNPCoverageRenderer/configSchema.d.ts +2 -2
  102. package/dist/SNPCoverageRenderer/configSchema.js +40 -0
  103. package/dist/SNPCoverageRenderer/index.d.ts +3 -3
  104. package/dist/SNPCoverageRenderer/index.js +34 -0
  105. package/dist/declare.d.js +1 -0
  106. package/dist/index.d.ts +10 -10
  107. package/dist/index.js +154 -6
  108. package/dist/index.test.js +26 -0
  109. package/dist/shared.d.ts +25 -25
  110. package/dist/shared.js +96 -0
  111. package/dist/util.d.ts +19 -19
  112. package/dist/util.js +135 -0
  113. package/package.json +5 -8
  114. package/src/BamAdapter/BamAdapter.ts +35 -8
  115. package/src/CramAdapter/CramAdapter.ts +42 -15
  116. package/src/LinearPileupDisplay/components/SetMaxHeight.tsx +1 -1
  117. package/src/LinearPileupDisplay/model.ts +2 -22
  118. package/src/LinearSNPCoverageDisplay/models/model.ts +6 -36
  119. package/src/PileupRenderer/PileupRenderer.tsx +3 -6
  120. package/src/SNPCoverageAdapter/SNPCoverageAdapter.ts +11 -17
  121. package/dist/AlignmentsFeatureDetail/index.test.d.ts +0 -1
  122. package/dist/LinearAlignmentsDisplay/models/configSchema.test.d.ts +0 -1
  123. package/dist/LinearPileupDisplay/configSchema.test.d.ts +0 -1
  124. package/dist/LinearSNPCoverageDisplay/models/configSchema.test.d.ts +0 -1
  125. package/dist/PileupRenderer/components/PileupRendering.test.d.ts +0 -1
  126. package/dist/plugin-alignments.cjs.development.js +0 -8438
  127. package/dist/plugin-alignments.cjs.development.js.map +0 -1
  128. package/dist/plugin-alignments.cjs.production.min.js +0 -2
  129. package/dist/plugin-alignments.cjs.production.min.js.map +0 -1
  130. package/dist/plugin-alignments.esm.js +0 -8430
  131. package/dist/plugin-alignments.esm.js.map +0 -1
@@ -1,125 +1,125 @@
1
- /// <reference types="react" />
2
- import BoxRendererType, { RenderArgs, RenderArgsSerialized, RenderArgsDeserialized as BoxRenderArgsDeserialized, RenderResults, ResultsSerialized, ResultsDeserialized } from '@jbrowse/core/pluggableElementTypes/renderers/BoxRendererType';
3
- import { Theme } from '@material-ui/core';
4
- import { Region, Feature } from '@jbrowse/core/util';
5
- import { BaseLayout } from '@jbrowse/core/util/layouts/BaseLayout';
6
- import { AnyConfigurationModel } from '@jbrowse/core/configuration';
7
- import { PileupLayoutSession, PileupLayoutSessionProps } from './PileupLayoutSession';
8
- export interface RenderArgsDeserialized extends BoxRenderArgsDeserialized {
9
- colorBy?: {
10
- type: string;
11
- tag?: string;
12
- };
13
- colorTagMap?: Record<string, string>;
14
- modificationTagMap?: Record<string, string>;
15
- sortedBy?: {
16
- type: string;
17
- pos: number;
18
- refName: string;
19
- assemblyName: string;
20
- tag?: string;
21
- };
22
- showSoftClip: boolean;
23
- highResolutionScaling: number;
24
- }
25
- export interface RenderArgsDeserializedWithFeaturesAndLayout extends RenderArgsDeserialized {
26
- features: Map<string, Feature>;
27
- layout: BaseLayout<Feature>;
28
- regionSequence?: string;
29
- }
30
- interface LayoutRecord {
31
- feature: Feature;
32
- leftPx: number;
33
- rightPx: number;
34
- topPx: number;
35
- heightPx: number;
36
- }
37
- interface LayoutFeature {
38
- heightPx: number;
39
- topPx: number;
40
- feature: Feature;
41
- }
42
- export default class PileupRenderer extends BoxRendererType {
43
- supportsSVG: boolean;
44
- getCharWidthHeight(ctx: CanvasRenderingContext2D): {
45
- charWidth: number;
46
- charHeight: number;
47
- };
48
- layoutFeature({ feature, layout, bpPerPx, region, showSoftClip, heightPx, displayMode, }: {
49
- feature: Feature;
50
- layout: BaseLayout<Feature>;
51
- bpPerPx: number;
52
- region: Region;
53
- showSoftClip?: boolean;
54
- heightPx: number;
55
- displayMode: string;
56
- }): LayoutRecord | null;
57
- getExpandedRegion(region: Region, renderArgs: RenderArgsDeserialized): {
58
- start: number;
59
- end: number;
60
- refName: string;
61
- assemblyName: string;
62
- reversed?: boolean | undefined;
63
- };
64
- colorByOrientation(feature: Feature, config: AnyConfigurationModel): string;
65
- getOrientation(feature: Feature, config: AnyConfigurationModel): string;
66
- colorByInsertSize(feature: Feature, _config: AnyConfigurationModel): string;
67
- colorByStranded(feature: Feature, _config: AnyConfigurationModel): "color_rev_strand" | "color_fwd_strand" | "color_rev_missing_mate" | "color_fwd_missing_mate" | "color_rev_strand_not_proper" | "color_fwd_strand_not_proper" | "color_fwd_diff_chr" | "color_rev_diff_chr";
68
- colorByPerBaseLettering(ctx: CanvasRenderingContext2D, feat: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: {
69
- colorForBase: Record<string, string>;
70
- contrastForBase: Record<string, string>;
71
- charWidth: number;
72
- charHeight: number;
73
- }): void;
74
- colorByPerBaseQuality(ctx: CanvasRenderingContext2D, feat: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number): void;
75
- colorByModifications(ctx: CanvasRenderingContext2D, layoutFeature: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: RenderArgsDeserializedWithFeaturesAndLayout): void;
76
- colorByMethylation(ctx: CanvasRenderingContext2D, layoutFeature: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: RenderArgsDeserializedWithFeaturesAndLayout): void;
77
- drawRect(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserialized): void;
78
- drawAlignmentRect(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout & {
79
- colorForBase: Record<string, string>;
80
- contrastForBase: Record<string, string>;
81
- charWidth: number;
82
- charHeight: number;
83
- defaultColor: boolean;
84
- }): void;
85
- drawMismatches(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout, opts: {
86
- colorForBase: {
87
- [key: string]: string;
88
- };
89
- contrastForBase: {
90
- [key: string]: string;
91
- };
92
- mismatchAlpha?: boolean;
93
- drawSNPs?: boolean;
94
- drawIndels?: boolean;
95
- minSubfeatureWidth: number;
96
- largeInsertionIndicatorScale: number;
97
- charWidth: number;
98
- charHeight: number;
99
- }): void;
100
- drawSoftClipping(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout, config: AnyConfigurationModel, theme: Theme): void;
101
- makeImageData(ctx: CanvasRenderingContext2D, layoutRecords: (LayoutFeature | null)[], props: RenderArgsDeserializedWithFeaturesAndLayout): Promise<void>;
102
- layoutFeats(props: RenderArgsDeserializedWithFeaturesAndLayout): (LayoutRecord | null)[];
103
- fetchSequence(renderProps: RenderArgsDeserialized): Promise<any>;
104
- render(renderProps: RenderArgsDeserialized): Promise<{
105
- features: Map<string, Feature>;
106
- layout: import("@jbrowse/core/util/layouts").GranularRectLayout<unknown>;
107
- height: number;
108
- width: number;
109
- maxHeightReached: boolean;
110
- reactElement: any;
111
- imageData?: undefined;
112
- html?: string | undefined;
113
- } | {
114
- features: Map<string, Feature>;
115
- layout: import("@jbrowse/core/util/layouts").GranularRectLayout<unknown>;
116
- height: number;
117
- width: number;
118
- maxHeightReached: boolean;
119
- imageData: any;
120
- reactElement?: import("react").ReactElement<any, string | ((props: any) => import("react").ReactElement<any, any> | null) | (new (props: any) => import("react").Component<any, any, any>)> | undefined;
121
- html?: string | undefined;
122
- }>;
123
- createSession(args: PileupLayoutSessionProps): PileupLayoutSession;
124
- }
125
- export type { RenderArgs, RenderArgsSerialized, RenderResults, ResultsSerialized, ResultsDeserialized, };
1
+ /// <reference types="react" />
2
+ import BoxRendererType, { RenderArgs, RenderArgsSerialized, RenderArgsDeserialized as BoxRenderArgsDeserialized, RenderResults, ResultsSerialized, ResultsDeserialized } from '@jbrowse/core/pluggableElementTypes/renderers/BoxRendererType';
3
+ import { Theme } from '@material-ui/core';
4
+ import { Region, Feature } from '@jbrowse/core/util';
5
+ import { BaseLayout } from '@jbrowse/core/util/layouts/BaseLayout';
6
+ import { AnyConfigurationModel } from '@jbrowse/core/configuration';
7
+ import { PileupLayoutSession, PileupLayoutSessionProps } from './PileupLayoutSession';
8
+ export interface RenderArgsDeserialized extends BoxRenderArgsDeserialized {
9
+ colorBy?: {
10
+ type: string;
11
+ tag?: string;
12
+ };
13
+ colorTagMap?: Record<string, string>;
14
+ modificationTagMap?: Record<string, string>;
15
+ sortedBy?: {
16
+ type: string;
17
+ pos: number;
18
+ refName: string;
19
+ assemblyName: string;
20
+ tag?: string;
21
+ };
22
+ showSoftClip: boolean;
23
+ highResolutionScaling: number;
24
+ }
25
+ export interface RenderArgsDeserializedWithFeaturesAndLayout extends RenderArgsDeserialized {
26
+ features: Map<string, Feature>;
27
+ layout: BaseLayout<Feature>;
28
+ regionSequence?: string;
29
+ }
30
+ interface LayoutRecord {
31
+ feature: Feature;
32
+ leftPx: number;
33
+ rightPx: number;
34
+ topPx: number;
35
+ heightPx: number;
36
+ }
37
+ interface LayoutFeature {
38
+ heightPx: number;
39
+ topPx: number;
40
+ feature: Feature;
41
+ }
42
+ export default class PileupRenderer extends BoxRendererType {
43
+ supportsSVG: boolean;
44
+ getCharWidthHeight(ctx: CanvasRenderingContext2D): {
45
+ charWidth: number;
46
+ charHeight: number;
47
+ };
48
+ layoutFeature({ feature, layout, bpPerPx, region, showSoftClip, heightPx, displayMode, }: {
49
+ feature: Feature;
50
+ layout: BaseLayout<Feature>;
51
+ bpPerPx: number;
52
+ region: Region;
53
+ showSoftClip?: boolean;
54
+ heightPx: number;
55
+ displayMode: string;
56
+ }): LayoutRecord | null;
57
+ getExpandedRegion(region: Region, renderArgs: RenderArgsDeserialized): {
58
+ start: number;
59
+ end: number;
60
+ refName: string;
61
+ assemblyName: string;
62
+ reversed?: boolean | undefined;
63
+ };
64
+ colorByOrientation(feature: Feature, config: AnyConfigurationModel): string;
65
+ getOrientation(feature: Feature, config: AnyConfigurationModel): string;
66
+ colorByInsertSize(feature: Feature, _config: AnyConfigurationModel): string;
67
+ colorByStranded(feature: Feature, _config: AnyConfigurationModel): "color_rev_strand" | "color_fwd_strand" | "color_rev_missing_mate" | "color_fwd_missing_mate" | "color_rev_strand_not_proper" | "color_fwd_strand_not_proper" | "color_fwd_diff_chr" | "color_rev_diff_chr";
68
+ colorByPerBaseLettering(ctx: CanvasRenderingContext2D, feat: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: {
69
+ colorForBase: Record<string, string>;
70
+ contrastForBase: Record<string, string>;
71
+ charWidth: number;
72
+ charHeight: number;
73
+ }): void;
74
+ colorByPerBaseQuality(ctx: CanvasRenderingContext2D, feat: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number): void;
75
+ colorByModifications(ctx: CanvasRenderingContext2D, layoutFeature: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: RenderArgsDeserializedWithFeaturesAndLayout): void;
76
+ colorByMethylation(ctx: CanvasRenderingContext2D, layoutFeature: LayoutFeature, _config: AnyConfigurationModel, region: Region, bpPerPx: number, props: RenderArgsDeserializedWithFeaturesAndLayout): void;
77
+ drawRect(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserialized): void;
78
+ drawAlignmentRect(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout & {
79
+ colorForBase: Record<string, string>;
80
+ contrastForBase: Record<string, string>;
81
+ charWidth: number;
82
+ charHeight: number;
83
+ defaultColor: boolean;
84
+ }): void;
85
+ drawMismatches(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout, opts: {
86
+ colorForBase: {
87
+ [key: string]: string;
88
+ };
89
+ contrastForBase: {
90
+ [key: string]: string;
91
+ };
92
+ mismatchAlpha?: boolean;
93
+ drawSNPs?: boolean;
94
+ drawIndels?: boolean;
95
+ minSubfeatureWidth: number;
96
+ largeInsertionIndicatorScale: number;
97
+ charWidth: number;
98
+ charHeight: number;
99
+ }): void;
100
+ drawSoftClipping(ctx: CanvasRenderingContext2D, feat: LayoutFeature, props: RenderArgsDeserializedWithFeaturesAndLayout, config: AnyConfigurationModel, theme: Theme): void;
101
+ makeImageData(ctx: CanvasRenderingContext2D, layoutRecords: (LayoutFeature | null)[], props: RenderArgsDeserializedWithFeaturesAndLayout): Promise<void>;
102
+ layoutFeats(props: RenderArgsDeserializedWithFeaturesAndLayout): (LayoutRecord | null)[];
103
+ fetchSequence(renderProps: RenderArgsDeserialized): Promise<any>;
104
+ render(renderProps: RenderArgsDeserialized): Promise<{
105
+ features: Map<string, Feature>;
106
+ layout: import("@jbrowse/core/util/layouts").GranularRectLayout<unknown>;
107
+ height: number;
108
+ width: number;
109
+ maxHeightReached: boolean;
110
+ reactElement: JSX.Element;
111
+ imageData?: undefined;
112
+ html?: string | undefined;
113
+ } | {
114
+ features: Map<string, Feature>;
115
+ layout: import("@jbrowse/core/util/layouts").GranularRectLayout<unknown>;
116
+ height: number;
117
+ width: number;
118
+ maxHeightReached: boolean;
119
+ imageData: import("@jbrowse/core/util/offscreenCanvas/types").AbstractImageBitmap;
120
+ reactElement?: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>> | undefined;
121
+ html?: string | undefined;
122
+ }>;
123
+ createSession(args: PileupLayoutSessionProps): PileupLayoutSession;
124
+ }
125
+ export type { RenderArgs, RenderArgsSerialized, RenderResults, ResultsSerialized, ResultsDeserialized, };