-
Notifications
You must be signed in to change notification settings - Fork 590
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix Looker Classifications handing (#5322)
* fix looker classifications * cleanup * update tsconfig * enhance filterView * add viewsAreEqual tests * use sample overlays * empty state overlay array buffer tests * temporal detections
- Loading branch information
1 parent
3fbee6c
commit 199872a
Showing
6 changed files
with
131 additions
and
47 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,57 @@ | ||
import type { Buffers } from "../state"; | ||
import type { LabelMask, Overlay } from "../overlays/base"; | ||
import DetectionOverlay from "../overlays/detection"; | ||
import HeatmapOverlay from "../overlays/heatmap"; | ||
import SegmentationOverlay from "../overlays/segmentation"; | ||
import type { BaseState, Buffers } from "../state"; | ||
|
||
export const hasFrame = (buffers: Buffers, frameNumber: number) => { | ||
return buffers.some( | ||
([start, end]) => start <= frameNumber && frameNumber <= end | ||
); | ||
}; | ||
|
||
export const retrieveArrayBuffers = <State extends BaseState>( | ||
overlays?: Overlay<State>[] | ||
) => { | ||
// collect any mask targets array buffer that overlays might have | ||
// we'll transfer that to the worker instead of copying it | ||
const arrayBuffers: ArrayBuffer[] = []; | ||
|
||
for (const overlay of overlays ?? []) { | ||
let overlayData: LabelMask = null; | ||
|
||
if ( | ||
overlay instanceof DetectionOverlay || | ||
overlay instanceof SegmentationOverlay | ||
) { | ||
overlayData = overlay.label.mask; | ||
} else if (overlay instanceof HeatmapOverlay) { | ||
overlayData = overlay.label.map; | ||
} | ||
|
||
const buffer = overlayData?.data?.buffer; | ||
|
||
if (!buffer) { | ||
continue; | ||
} | ||
|
||
// check for detached buffer (happens if user is switching colors too fast) | ||
// note: ArrayBuffer.prototype.detached is a new browser API | ||
if (typeof buffer.detached !== "undefined") { | ||
if (buffer.detached) { | ||
// most likely sample is already being processed, skip update | ||
return []; | ||
} | ||
|
||
arrayBuffers.push(buffer); | ||
} else if (buffer.byteLength) { | ||
// hope we don't run into this edge case (old browser) | ||
// sometimes detached buffers have bytelength > 0 | ||
// if we run into this case, we'll just attempt to transfer the buffer | ||
// might get a DataCloneError if user is switching colors too fast | ||
arrayBuffers.push(buffer); | ||
} | ||
} | ||
|
||
return arrayBuffers; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters