@cornerstonejs/tools 1.81.3 → 1.81.5

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.
@@ -146,45 +146,12 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
146
146
  }
147
147
  const { imageData, metadata } = image;
148
148
  const canvasCoordinates = points.map((p) => viewport.worldToCanvas(p));
149
- const canvasPoint = canvasCoordinates[0];
150
- const originalWorldPoint = viewport.canvasToWorld(canvasPoint);
151
- const deltaXPoint = viewport.canvasToWorld([
152
- canvasPoint[0] + 1,
153
- canvasPoint[1],
154
- ]);
155
- const deltaYPoint = viewport.canvasToWorld([
156
- canvasPoint[0],
157
- canvasPoint[1] + 1,
158
- ]);
159
- const deltaInX = vec3.distance(originalWorldPoint, deltaXPoint);
160
- const deltaInY = vec3.distance(originalWorldPoint, deltaYPoint);
161
- const worldPosIndex = csUtils.transformWorldToIndex(imageData, points[0]);
162
- worldPosIndex[0] = Math.floor(worldPosIndex[0]);
163
- worldPosIndex[1] = Math.floor(worldPosIndex[1]);
164
- worldPosIndex[2] = Math.floor(worldPosIndex[2]);
165
- let iMin = worldPosIndex[0];
166
- let iMax = worldPosIndex[0];
167
- let jMin = worldPosIndex[1];
168
- let jMax = worldPosIndex[1];
169
- let kMin = worldPosIndex[2];
170
- let kMax = worldPosIndex[2];
171
- for (let j = 1; j < points.length; j++) {
172
- const worldPosIndex = csUtils.transformWorldToIndex(imageData, points[j]);
173
- worldPosIndex[0] = Math.floor(worldPosIndex[0]);
174
- worldPosIndex[1] = Math.floor(worldPosIndex[1]);
175
- worldPosIndex[2] = Math.floor(worldPosIndex[2]);
176
- iMin = Math.min(iMin, worldPosIndex[0]);
177
- iMax = Math.max(iMax, worldPosIndex[0]);
178
- jMin = Math.min(jMin, worldPosIndex[1]);
179
- jMax = Math.max(jMax, worldPosIndex[1]);
180
- kMin = Math.min(kMin, worldPosIndex[2]);
181
- kMax = Math.max(kMax, worldPosIndex[2]);
182
- }
183
- const worldPosIndex2 = csUtils.transformWorldToIndex(imageData, points[1]);
184
- worldPosIndex2[0] = Math.floor(worldPosIndex2[0]);
185
- worldPosIndex2[1] = Math.floor(worldPosIndex2[1]);
186
- worldPosIndex2[2] = Math.floor(worldPosIndex2[2]);
187
- const { scale, areaUnits } = getCalibratedLengthUnitsAndScale(image, () => {
149
+ const modalityUnitOptions = {
150
+ isPreScaled: isViewportPreScaled(viewport, targetId),
151
+ isSuvScaled: this.isSuvScaled(viewport, targetId, annotation.metadata.referencedImageId),
152
+ };
153
+ const modalityUnit = getModalityUnit(metadata.Modality, annotation.metadata.referencedImageId, modalityUnitOptions);
154
+ const calibratedScale = getCalibratedLengthUnitsAndScale(image, () => {
188
155
  const polyline = data.contour.polyline;
189
156
  const numPoints = polyline.length;
190
157
  const projectedPolyline = new Array(numPoints);
@@ -192,10 +159,7 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
192
159
  projectedPolyline[i] = viewport.worldToCanvas(polyline[i]);
193
160
  }
194
161
  const { maxX: canvasMaxX, maxY: canvasMaxY, minX: canvasMinX, minY: canvasMinY, } = math.polyline.getAABB(projectedPolyline);
195
- const topLeftBBWorld = viewport.canvasToWorld([
196
- canvasMinX,
197
- canvasMinY,
198
- ]);
162
+ const topLeftBBWorld = viewport.canvasToWorld([canvasMinX, canvasMinY]);
199
163
  const topLeftBBIndex = csUtils.transformWorldToIndex(imageData, topLeftBBWorld);
200
164
  const bottomRightBBWorld = viewport.canvasToWorld([
201
165
  canvasMaxX,
@@ -204,71 +168,29 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
204
168
  const bottomRightBBIndex = csUtils.transformWorldToIndex(imageData, bottomRightBBWorld);
205
169
  return [topLeftBBIndex, bottomRightBBIndex];
206
170
  });
207
- let area = polyline.getArea(canvasCoordinates) / scale / scale;
208
- area *= deltaInX * deltaInY;
209
- const iDelta = 0.01 * (iMax - iMin);
210
- const jDelta = 0.01 * (jMax - jMin);
211
- const kDelta = 0.01 * (kMax - kMin);
212
- iMin = Math.floor(iMin - iDelta);
213
- iMax = Math.ceil(iMax + iDelta);
214
- jMin = Math.floor(jMin - jDelta);
215
- jMax = Math.ceil(jMax + jDelta);
216
- kMin = Math.floor(kMin - kDelta);
217
- kMax = Math.ceil(kMax + kDelta);
218
- const boundsIJK = [
219
- [iMin, iMax],
220
- [jMin, jMax],
221
- [kMin, kMax],
222
- ];
223
- const worldPosEnd = imageData.indexToWorld([iMax, jMax, kMax]);
224
- const canvasPosEnd = viewport.worldToCanvas(worldPosEnd);
225
- let curRow = 0;
226
- let intersections = [];
227
- let intersectionCounter = 0;
228
- const pointsInShape = pointInShapeCallback(imageData, (pointLPS, pointIJK) => {
229
- let result = true;
230
- const point = viewport.worldToCanvas(pointLPS);
231
- if (point[1] != curRow) {
232
- intersectionCounter = 0;
233
- curRow = point[1];
234
- intersections = getLineSegmentIntersectionsCoordinates(canvasCoordinates, point, [canvasPosEnd[0], point[1]]);
235
- intersections.sort((function (index) {
236
- return function (a, b) {
237
- return a[index] === b[index]
238
- ? 0
239
- : a[index] < b[index]
240
- ? -1
241
- : 1;
242
- };
243
- })(0));
244
- }
245
- if (intersections.length && point[0] > intersections[0][0]) {
246
- intersections.shift();
247
- intersectionCounter++;
248
- }
249
- if (intersectionCounter % 2 === 0) {
250
- result = false;
251
- }
252
- return result;
253
- }, this.configuration.statsCalculator.statsCallback, boundsIJK);
254
- const modalityUnitOptions = {
255
- isPreScaled: isViewportPreScaled(viewport, targetId),
256
- isSuvScaled: this.isSuvScaled(viewport, targetId, annotation.metadata.referencedImageId),
257
- };
258
- const modalityUnit = getModalityUnit(metadata.Modality, annotation.metadata.referencedImageId, modalityUnitOptions);
259
- const stats = this.configuration.statsCalculator.getStatistics();
260
- cachedStats[targetId] = {
261
- Modality: metadata.Modality,
262
- area,
263
- perimeter: calculatePerimeter(canvasCoordinates, closed),
264
- mean: stats.mean?.value,
265
- max: stats.max?.value,
266
- stdDev: stats.stdDev?.value,
267
- statsArray: stats.array,
268
- pointsInShape: pointsInShape,
269
- areaUnit: areaUnits,
270
- modalityUnit,
271
- };
171
+ if (closed) {
172
+ this.updateClosedCachedStats({
173
+ targetId,
174
+ viewport,
175
+ canvasCoordinates,
176
+ points,
177
+ imageData,
178
+ metadata,
179
+ cachedStats,
180
+ modalityUnit,
181
+ calibratedScale,
182
+ });
183
+ }
184
+ else {
185
+ this.updateOpenCachedStats({
186
+ metadata,
187
+ canvasCoordinates,
188
+ targetId,
189
+ cachedStats,
190
+ modalityUnit,
191
+ calibratedScale,
192
+ });
193
+ }
272
194
  }
273
195
  triggerAnnotationModified(annotation, enabledElement.viewport.element, ChangeTypes.StatsUpdated);
274
196
  annotation.invalidated = false;
@@ -461,10 +383,117 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
461
383
  }
462
384
  }
463
385
  }
386
+ updateClosedCachedStats({ viewport, points, imageData, metadata, cachedStats, targetId, modalityUnit, canvasCoordinates, calibratedScale, }) {
387
+ const { scale, areaUnits, units } = calibratedScale;
388
+ const canvasPoint = canvasCoordinates[0];
389
+ const originalWorldPoint = viewport.canvasToWorld(canvasPoint);
390
+ const deltaXPoint = viewport.canvasToWorld([
391
+ canvasPoint[0] + 1,
392
+ canvasPoint[1],
393
+ ]);
394
+ const deltaYPoint = viewport.canvasToWorld([
395
+ canvasPoint[0],
396
+ canvasPoint[1] + 1,
397
+ ]);
398
+ const deltaInX = vec3.distance(originalWorldPoint, deltaXPoint);
399
+ const deltaInY = vec3.distance(originalWorldPoint, deltaYPoint);
400
+ const worldPosIndex = csUtils.transformWorldToIndex(imageData, points[0]);
401
+ worldPosIndex[0] = Math.floor(worldPosIndex[0]);
402
+ worldPosIndex[1] = Math.floor(worldPosIndex[1]);
403
+ worldPosIndex[2] = Math.floor(worldPosIndex[2]);
404
+ let iMin = worldPosIndex[0];
405
+ let iMax = worldPosIndex[0];
406
+ let jMin = worldPosIndex[1];
407
+ let jMax = worldPosIndex[1];
408
+ let kMin = worldPosIndex[2];
409
+ let kMax = worldPosIndex[2];
410
+ for (let j = 1; j < points.length; j++) {
411
+ const worldPosIndex = csUtils.transformWorldToIndex(imageData, points[j]);
412
+ worldPosIndex[0] = Math.floor(worldPosIndex[0]);
413
+ worldPosIndex[1] = Math.floor(worldPosIndex[1]);
414
+ worldPosIndex[2] = Math.floor(worldPosIndex[2]);
415
+ iMin = Math.min(iMin, worldPosIndex[0]);
416
+ iMax = Math.max(iMax, worldPosIndex[0]);
417
+ jMin = Math.min(jMin, worldPosIndex[1]);
418
+ jMax = Math.max(jMax, worldPosIndex[1]);
419
+ kMin = Math.min(kMin, worldPosIndex[2]);
420
+ kMax = Math.max(kMax, worldPosIndex[2]);
421
+ }
422
+ const worldPosIndex2 = csUtils.transformWorldToIndex(imageData, points[1]);
423
+ worldPosIndex2[0] = Math.floor(worldPosIndex2[0]);
424
+ worldPosIndex2[1] = Math.floor(worldPosIndex2[1]);
425
+ worldPosIndex2[2] = Math.floor(worldPosIndex2[2]);
426
+ let area = polyline.getArea(canvasCoordinates) / scale / scale;
427
+ area *= deltaInX * deltaInY;
428
+ const iDelta = 0.01 * (iMax - iMin);
429
+ const jDelta = 0.01 * (jMax - jMin);
430
+ const kDelta = 0.01 * (kMax - kMin);
431
+ iMin = Math.floor(iMin - iDelta);
432
+ iMax = Math.ceil(iMax + iDelta);
433
+ jMin = Math.floor(jMin - jDelta);
434
+ jMax = Math.ceil(jMax + jDelta);
435
+ kMin = Math.floor(kMin - kDelta);
436
+ kMax = Math.ceil(kMax + kDelta);
437
+ const boundsIJK = [
438
+ [iMin, iMax],
439
+ [jMin, jMax],
440
+ [kMin, kMax],
441
+ ];
442
+ const worldPosEnd = imageData.indexToWorld([iMax, jMax, kMax]);
443
+ const canvasPosEnd = viewport.worldToCanvas(worldPosEnd);
444
+ let curRow = 0;
445
+ let intersections = [];
446
+ let intersectionCounter = 0;
447
+ const pointsInShape = pointInShapeCallback(imageData, (pointLPS, _pointIJK) => {
448
+ let result = true;
449
+ const point = viewport.worldToCanvas(pointLPS);
450
+ if (point[1] != curRow) {
451
+ intersectionCounter = 0;
452
+ curRow = point[1];
453
+ intersections = getLineSegmentIntersectionsCoordinates(canvasCoordinates, point, [canvasPosEnd[0], point[1]]);
454
+ intersections.sort((function (index) {
455
+ return function (a, b) {
456
+ return a[index] === b[index] ? 0 : a[index] < b[index] ? -1 : 1;
457
+ };
458
+ })(0));
459
+ }
460
+ if (intersections.length && point[0] > intersections[0][0]) {
461
+ intersections.shift();
462
+ intersectionCounter++;
463
+ }
464
+ if (intersectionCounter % 2 === 0) {
465
+ result = false;
466
+ }
467
+ return result;
468
+ }, this.configuration.statsCalculator.statsCallback, boundsIJK);
469
+ const stats = this.configuration.statsCalculator.getStatistics();
470
+ cachedStats[targetId] = {
471
+ Modality: metadata.Modality,
472
+ area,
473
+ perimeter: calculatePerimeter(canvasCoordinates, closed) / scale,
474
+ mean: stats.mean?.value,
475
+ max: stats.max?.value,
476
+ stdDev: stats.stdDev?.value,
477
+ statsArray: stats.array,
478
+ pointsInShape: pointsInShape,
479
+ areaUnit: areaUnits,
480
+ modalityUnit,
481
+ unit: units,
482
+ };
483
+ }
484
+ updateOpenCachedStats({ targetId, metadata, canvasCoordinates, cachedStats, modalityUnit, calibratedScale, }) {
485
+ const { scale, units } = calibratedScale;
486
+ cachedStats[targetId] = {
487
+ Modality: metadata.Modality,
488
+ length: calculatePerimeter(canvasCoordinates, false) / scale,
489
+ modalityUnit,
490
+ unit: units,
491
+ };
492
+ }
464
493
  }
465
494
  function defaultGetTextLines(data, targetId) {
466
495
  const cachedVolumeStats = data.cachedStats[targetId];
467
- const { area, mean, stdDev, perimeter, max, isEmptyArea, areaUnit, modalityUnit, } = cachedVolumeStats || {};
496
+ const { area, mean, stdDev, length, perimeter, max, isEmptyArea, areaUnit, modalityUnit, unit, } = cachedVolumeStats || {};
468
497
  const textLines = [];
469
498
  if (area) {
470
499
  const areaLine = isEmptyArea
@@ -482,7 +511,10 @@ function defaultGetTextLines(data, targetId) {
482
511
  textLines.push(`Std Dev: ${roundNumber(stdDev)} ${modalityUnit}`);
483
512
  }
484
513
  if (perimeter) {
485
- textLines.push(`Perimeter: ${roundNumber(perimeter)} ${modalityUnit}`);
514
+ textLines.push(`Perimeter: ${roundNumber(perimeter)} ${unit}`);
515
+ }
516
+ if (length) {
517
+ textLines.push(`${roundNumber(length)} ${unit}`);
486
518
  }
487
519
  return textLines;
488
520
  }
@@ -1 +1 @@
1
- {"version":3,"file":"PlanarFreehandROITool.js","sourceRoot":"","sources":["../../../../src/tools/annotation/PlanarFreehandROITool.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"PlanarFreehandROITool.js","sourceRoot":"","sources":["../../../../src/tools/annotation/PlanarFreehandROITool.ts"],"names":[],"mappings":"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"}
@@ -11,8 +11,17 @@ const SUPPORTED_PROBE_VARIANT = [
11
11
  '4,3',
12
12
  ];
13
13
  const UNIT_MAPPING = {
14
+ 0: 'px',
15
+ 1: 'percent',
16
+ 2: 'dB',
14
17
  3: 'cm',
15
18
  4: 'seconds',
19
+ 5: 'hertz',
20
+ 6: 'dB/seconds',
21
+ 7: 'cm/sec',
22
+ 8: 'cm\xb2',
23
+ 9: 'cm\xb2/s',
24
+ 0xc: 'degrees',
16
25
  };
17
26
  const EPS = 1e-3;
18
27
  const SQUARE = '\xb2';
@@ -60,10 +69,10 @@ const getCalibratedLengthUnitsAndScale = (image, handles) => {
60
69
  const physicalDeltaY = Math.abs(region.physicalDeltaY);
61
70
  const isSamePhysicalDelta = utilities.isEqual(physicalDeltaX, physicalDeltaY, EPS);
62
71
  if (isSamePhysicalDelta) {
63
- scale = 1 / (physicalDeltaX * 10);
72
+ scale = 1 / physicalDeltaX;
64
73
  calibrationType = 'US Region';
65
- units = 'mm';
66
- areaUnits = 'mm' + SQUARE;
74
+ units = UNIT_MAPPING[region.physicalUnitsXDirection] || 'unknown';
75
+ areaUnits = units + SQUARE;
67
76
  }
68
77
  else {
69
78
  return { units: PIXEL_UNITS, areaUnits: PIXEL_UNITS + SQUARE, scale };
@@ -1 +1 @@
1
- {"version":3,"file":"getCalibratedUnits.js","sourceRoot":"","sources":["../../../src/utilities/getCalibratedUnits.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"getCalibratedUnits.js","sourceRoot":"","sources":["../../../src/utilities/getCalibratedUnits.ts"],"names":[],"mappings":"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"}
@@ -37,6 +37,25 @@ declare class PlanarFreehandROITool extends ContourSegmentationBaseTool {
37
37
  protected renderAnnotationInstance(renderContext: AnnotationRenderContext): boolean;
38
38
  _calculateStatsIfActive(annotation: PlanarFreehandROIAnnotation, targetId: string, viewport: any, renderingEngine: any, enabledElement: any): void;
39
39
  private _calculateCachedStats;
40
+ protected updateClosedCachedStats({ viewport, points, imageData, metadata, cachedStats, targetId, modalityUnit, canvasCoordinates, calibratedScale, }: {
41
+ viewport: any;
42
+ points: any;
43
+ imageData: any;
44
+ metadata: any;
45
+ cachedStats: any;
46
+ targetId: any;
47
+ modalityUnit: any;
48
+ canvasCoordinates: any;
49
+ calibratedScale: any;
50
+ }): void;
51
+ protected updateOpenCachedStats({ targetId, metadata, canvasCoordinates, cachedStats, modalityUnit, calibratedScale, }: {
52
+ targetId: any;
53
+ metadata: any;
54
+ canvasCoordinates: any;
55
+ cachedStats: any;
56
+ modalityUnit: any;
57
+ calibratedScale: any;
58
+ }): void;
40
59
  private _renderStats;
41
60
  }
42
61
  export default PlanarFreehandROITool;
@@ -1 +1 @@
1
- {"version":3,"file":"PlanarFreehandROITool.d.ts","sourceRoot":"","sources":["../../../../src/tools/annotation/PlanarFreehandROITool.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAgBjD,OAAO,KAAK,EACV,UAAU,EACV,UAAU,EACV,UAAU,EACV,WAAW,EAEX,eAAe,EACf,SAAS,EAET,uBAAuB,EACxB,MAAM,aAAa,CAAC;AAGrB,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAUtF,OAAO,2BAA2B,MAAM,qCAAqC,CAAC;AAsE9E,cAAM,qBAAsB,SAAQ,2BAA2B;IAC7D,MAAM,CAAC,QAAQ,MAAC;IAET,iBAAiB,EAAE,GAAG,CAAC;IACvB,iBAAiB,EAAE,GAAG,CAAC;IAC9B,8BAA8B,EAAE,GAAG,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,CAA8B;IACjD,SAAS,UAAS;IAClB,eAAe,UAAS;IACxB,aAAa,UAAS;IAEtB,SAAS,CAAC,YAAY,EAAE,CACtB,GAAG,EAAE,UAAU,CAAC,oBAAoB,EACpC,UAAU,EAAE,2BAA2B,EACvC,mBAAmB,EAAE,MAAM,EAAE,KAC1B,IAAI,CAAC;IACV,OAAO,CAAC,yBAAyB,CAIvB;IACV,OAAO,CAAC,uBAAuB,CAIrB;IACV,OAAO,CAAC,0BAA0B,CAKxB;IACV,OAAO,CAAC,aAAa,CAAoC;IACzD,OAAO,CAAC,uBAAuB,CAAoC;IACnE,OAAO,CAAC,qBAAqB,CAAoC;IAEjE,OAAO,CAAC,aAAa,CAIX;IACV,OAAO,CAAC,uBAAuB,CAIrB;IACV,OAAO,CAAC,8BAA8B,CAI5B;IACV,OAAO,CAAC,4BAA4B,CAI1B;IAEV,OAAO,CAAC,4BAA4B,CAI1B;gBAGR,SAAS,GAAE,eAAoB,EAC/B,gBAAgB,GAAE,SA2EjB;IA2BH,gBAAgB,QACT,WAAW,oBAAoB,KACnC,2BAA2B,CAwB5B;IAWF,sBAAsB,QACf,WAAW,oBAAoB,cACxB,2BAA2B,UAC/B,UAAU,KACjB,IAAI,CAeL;IAKF,oBAAoB,QACb,WAAW,oBAAoB,cACxB,2BAA2B,KACtC,IAAI,CAgBL;IAaF,eAAe,YACJ,cAAc,cACX,2BAA2B,yCAE5B,MAAM,KAChB,OAAO,CAgCR;IAEK,MAAM,YAAa,cAAc,KAAG,IAAI,CAY7C;IAOK,uCAAuC,CAC5C,OAAO,EAAE,cAAc,EACvB,WAAW,EAAE,WAAW,GACvB,WAAW,GAAG,SAAS;IAoC1B,OAAO,CAAC,4BAA4B;IA6DpC,SAAS,CAAC,yBAAyB,IAAI,OAAO;IAM9C,SAAS,CAAC,gBAAgB,CAAC,GAAG,EAAE,UAAU,CAAC,oBAAoB,GAAG,UAAU;IA0B5E,SAAS,CAAC,kBAAkB,CAAC,OAAO,KAAA;IAMpC,SAAS,CAAC,wBAAwB,CAChC,aAAa,EAAE,uBAAuB,GACrC,OAAO;IA4FV,uBAAuB,CACrB,UAAU,EAAE,2BAA2B,EACvC,QAAQ,EAAE,MAAM,EAChB,QAAQ,KAAA,EACR,eAAe,KAAA,EACf,cAAc,KAAA;IA2ChB,OAAO,CAAC,qBAAqB,CAqO3B;IAEF,OAAO,CAAC,YAAY,CA2DlB;CACH;AA4CD,eAAe,qBAAqB,CAAC"}
1
+ {"version":3,"file":"PlanarFreehandROITool.d.ts","sourceRoot":"","sources":["../../../../src/tools/annotation/PlanarFreehandROITool.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAgBjD,OAAO,KAAK,EACV,UAAU,EACV,UAAU,EACV,UAAU,EACV,WAAW,EAEX,eAAe,EACf,SAAS,EAET,uBAAuB,EACxB,MAAM,aAAa,CAAC;AAGrB,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAUtF,OAAO,2BAA2B,MAAM,qCAAqC,CAAC;AAsE9E,cAAM,qBAAsB,SAAQ,2BAA2B;IAC7D,MAAM,CAAC,QAAQ,MAAC;IAET,iBAAiB,EAAE,GAAG,CAAC;IACvB,iBAAiB,EAAE,GAAG,CAAC;IAC9B,8BAA8B,EAAE,GAAG,CAAC;IACpC,OAAO,CAAC,UAAU,CAAC,CAA8B;IACjD,SAAS,UAAS;IAClB,eAAe,UAAS;IACxB,aAAa,UAAS;IAEtB,SAAS,CAAC,YAAY,EAAE,CACtB,GAAG,EAAE,UAAU,CAAC,oBAAoB,EACpC,UAAU,EAAE,2BAA2B,EACvC,mBAAmB,EAAE,MAAM,EAAE,KAC1B,IAAI,CAAC;IACV,OAAO,CAAC,yBAAyB,CAIvB;IACV,OAAO,CAAC,uBAAuB,CAIrB;IACV,OAAO,CAAC,0BAA0B,CAKxB;IACV,OAAO,CAAC,aAAa,CAAoC;IACzD,OAAO,CAAC,uBAAuB,CAAoC;IACnE,OAAO,CAAC,qBAAqB,CAAoC;IAEjE,OAAO,CAAC,aAAa,CAIX;IACV,OAAO,CAAC,uBAAuB,CAIrB;IACV,OAAO,CAAC,8BAA8B,CAI5B;IACV,OAAO,CAAC,4BAA4B,CAI1B;IAEV,OAAO,CAAC,4BAA4B,CAI1B;gBAGR,SAAS,GAAE,eAAoB,EAC/B,gBAAgB,GAAE,SA2EjB;IA2BH,gBAAgB,QACT,WAAW,oBAAoB,KACnC,2BAA2B,CAwB5B;IAWF,sBAAsB,QACf,WAAW,oBAAoB,cACxB,2BAA2B,UAC/B,UAAU,KACjB,IAAI,CAeL;IAKF,oBAAoB,QACb,WAAW,oBAAoB,cACxB,2BAA2B,KACtC,IAAI,CAgBL;IAaF,eAAe,YACJ,cAAc,cACX,2BAA2B,yCAE5B,MAAM,KAChB,OAAO,CAgCR;IAEK,MAAM,YAAa,cAAc,KAAG,IAAI,CAY7C;IAOK,uCAAuC,CAC5C,OAAO,EAAE,cAAc,EACvB,WAAW,EAAE,WAAW,GACvB,WAAW,GAAG,SAAS;IAoC1B,OAAO,CAAC,4BAA4B;IA6DpC,SAAS,CAAC,yBAAyB,IAAI,OAAO;IAM9C,SAAS,CAAC,gBAAgB,CAAC,GAAG,EAAE,UAAU,CAAC,oBAAoB,GAAG,UAAU;IA0B5E,SAAS,CAAC,kBAAkB,CAAC,OAAO,KAAA;IAMpC,SAAS,CAAC,wBAAwB,CAChC,aAAa,EAAE,uBAAuB,GACrC,OAAO;IA4FV,uBAAuB,CACrB,UAAU,EAAE,2BAA2B,EACvC,QAAQ,EAAE,MAAM,EAChB,QAAQ,KAAA,EACR,eAAe,KAAA,EACf,cAAc,KAAA;IA2ChB,OAAO,CAAC,qBAAqB,CA6G3B;IAEF,SAAS,CAAC,uBAAuB,CAAC,EAChC,QAAQ,EACR,MAAM,EACN,SAAS,EACT,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,iBAAiB,EACjB,eAAe,GAChB;;;;;;;;;;KAAA;IAwID,SAAS,CAAC,qBAAqB,CAAC,EAC9B,QAAQ,EACR,QAAQ,EACR,iBAAiB,EACjB,WAAW,EACX,YAAY,EACZ,eAAe,GAChB;;;;;;;KAAA;IAWD,OAAO,CAAC,YAAY,CA2DlB;CACH;AAmDD,eAAe,qBAAqB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"getCalibratedUnits.d.ts","sourceRoot":"","sources":["../../../src/utilities/getCalibratedUnits.ts"],"names":[],"mappings":"AAgCA,QAAA,MAAM,gCAAgC;;;;CA+GrC,CAAC;AAEF,QAAA,MAAM,+BAA+B;;;;;;;;CAoEpC,CAAC;AAQF,QAAA,MAAM,mBAAmB,qBAA4C,CAAC;AAEtE,OAAO,EACL,gCAAgC,EAChC,mBAAmB,EACnB,+BAA+B,GAChC,CAAC"}
1
+ {"version":3,"file":"getCalibratedUnits.d.ts","sourceRoot":"","sources":["../../../src/utilities/getCalibratedUnits.ts"],"names":[],"mappings":"AAyCA,QAAA,MAAM,gCAAgC;;;;CA+GrC,CAAC;AAEF,QAAA,MAAM,+BAA+B;;;;;;;;CAoEpC,CAAC;AAQF,QAAA,MAAM,mBAAmB,qBAA4C,CAAC;AAEtE,OAAO,EACL,gCAAgC,EAChC,mBAAmB,EACnB,+BAA+B,GAChC,CAAC"}