@luxonis/visualizer-protobuf 2.22.0 → 2.23.0
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.
- package/dist/{WorkerImageDecoder.worker-tkX9-IYo.js → WorkerImageDecoder.worker-C3ZBQ2Wk.js} +1 -1
- package/dist/{decodeImage-C8kB6T3V.js → decodeImage-CxUhz2gE.js} +14278 -2893
- package/dist/{index-P-f_cKZS.js → index-B9Zf3rrb.js} +2 -2
- package/dist/{index-BQ24Upp_.js → index-BJOK4X3d.js} +2 -2
- package/dist/{index-DMvr0-pP.js → index-BTO4og7t.js} +2 -2
- package/dist/{index-DTCT-lVn.js → index-BqTw2FSJ.js} +4 -4
- package/dist/{index-CH1TUS48.js → index-Bw0fCcF0.js} +2 -2
- package/dist/{index-DDVf76z9.js → index-CCWfhL1j.js} +2 -2
- package/dist/{index-BHXfMPMv.js → index-CFz07x1R.js} +2 -2
- package/dist/{index-Bvet1xE9.js → index-CM0J0Tip.js} +2 -2
- package/dist/{index-DtzTeqB7.js → index-D3by772J.js} +2 -2
- package/dist/{index-DzyYicoH.js → index-DMmaMUCD.js} +2813 -1608
- package/dist/{index-C-cGIa0r.js → index-DQ_hdLpb.js} +2 -2
- package/dist/{index-yfiGMPtK.js → index-DRmoIUFd.js} +2 -2
- package/dist/{index-Dcus_L6F.js → index-DWgnF3_o.js} +156 -57
- package/dist/{index-DYpNYj7G.js → index-Db42Qzy_.js} +2 -2
- package/dist/{index-C_ioBAtk.js → index-DgisSKDf.js} +2 -2
- package/dist/{index-CV57d9Tz.js → index-DjOkSXUO.js} +2 -2
- package/dist/{index-D5F-PpU5.js → index-DqqFhpKC.js} +2 -2
- package/dist/{index-RKZ-F77P.js → index-Wr3SUBO9.js} +2 -2
- package/dist/{index-DHgo3Ne_.js → index-oTzD1_p-.js} +2 -2
- package/dist/index.js +2 -2
- package/dist/lib/src/connection/foxglove-connection.d.ts +3 -1
- package/dist/lib/src/connection/foxglove-connection.d.ts.map +1 -1
- package/dist/lib/src/connection/foxglove-connection.js +16 -32
- package/dist/lib/src/connection/foxglove-connection.js.map +1 -1
- package/dist/lib/src/messaging/deserialization/pointcloud/pointcloudFromDepth.worker.js +373 -247
- package/dist/lib/src/messaging/deserialization/pointcloud/pointcloudFromDepth.worker.js.map +1 -1
- package/dist/lib/src/messaging/deserialization/pointcloud/poitcloudPoolManager.d.ts +30 -0
- package/dist/lib/src/messaging/deserialization/pointcloud/poitcloudPoolManager.d.ts.map +1 -0
- package/dist/lib/src/messaging/deserialization/pointcloud/poitcloudPoolManager.js +106 -0
- package/dist/lib/src/messaging/deserialization/pointcloud/poitcloudPoolManager.js.map +1 -0
- package/dist/lib/src/messaging/deserialization/pointcloud/utils.d.ts +0 -9
- package/dist/lib/src/messaging/deserialization/pointcloud/utils.d.ts.map +1 -1
- package/dist/lib/src/messaging/deserialization/pointcloud/utils.js +0 -16
- package/dist/lib/src/messaging/deserialization/pointcloud/utils.js.map +1 -1
- package/dist/lib/src/panels/PointCloudPanel.js +3 -3
- package/dist/lib/src/panels/PointCloudPanel.js.map +1 -1
- package/dist/lib/src/utils/poitcloud-sync.js +1 -1
- package/dist/lib/src/utils/poitcloud-sync.js.map +1 -1
- package/dist/packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.d.ts +1 -0
- package/dist/packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.d.ts.map +1 -1
- package/dist/packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.js +243 -154
- package/dist/packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.js.map +1 -1
- package/dist/pointcloudFromDepth.worker-qotYPy_e.js +450 -0
- package/dist/{utils-Cmsz3FxA.js → utils-Hzt3wxhG.js} +2 -20
- package/package.json +2 -1
- package/dist/pointcloudFromDepth.worker-CNKyMUU-.js +0 -326
package/dist/packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CameraStateSettings.js","sourceRoot":"","sources":["../../../../../../../../packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"CameraStateSettings.js","sourceRoot":"","sources":["../../../../../../../../packages/studio-base/src/panels/ThreeDeeRender/renderables/CameraStateSettings.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,450 @@
|
|
|
1
|
+
import { e as expose } from './comlink-DHMAu6X7.js';
|
|
2
|
+
import { i as i420ToRgbaToPointcloud } from './utils-Hzt3wxhG.js';
|
|
3
|
+
|
|
4
|
+
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
5
|
+
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
6
|
+
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
7
|
+
/// <reference types="@webgpu/types" />
|
|
8
|
+
function depthToPointCloudBuffer(uint16Array, width, height, fx, fy, cx, cy) {
|
|
9
|
+
const numPixels = width * height;
|
|
10
|
+
const points = new Float32Array(numPixels * 3);
|
|
11
|
+
for (let v = 0; v < height; v++) {
|
|
12
|
+
for (let u = 0; u < width; u++) {
|
|
13
|
+
const pixelIndex = v * width + u;
|
|
14
|
+
const depthValue = uint16Array[pixelIndex] ?? 0;
|
|
15
|
+
let x = 0.0;
|
|
16
|
+
let y = 0.0;
|
|
17
|
+
let z = 0.0;
|
|
18
|
+
const depthScale = 1.0;
|
|
19
|
+
const scaledDepth = depthValue * depthScale;
|
|
20
|
+
if (scaledDepth > 0 && fx !== 0 && fy !== 0) {
|
|
21
|
+
x = (cx - u) * scaledDepth / fx;
|
|
22
|
+
y = (cy - v) * scaledDepth / fy;
|
|
23
|
+
z = scaledDepth;
|
|
24
|
+
}
|
|
25
|
+
const pointOffset = pixelIndex * 3;
|
|
26
|
+
points[pointOffset] = x;
|
|
27
|
+
points[pointOffset + 1] = y;
|
|
28
|
+
points[pointOffset + 2] = z;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
const buffer = new ArrayBuffer(numPixels * 16);
|
|
32
|
+
const view = new DataView(buffer);
|
|
33
|
+
const pointsU8 = new Uint8Array(points.buffer);
|
|
34
|
+
for (let i = 0; i < numPixels; i++) {
|
|
35
|
+
const xyzOffsetBytes = i * 12;
|
|
36
|
+
const outputOffsetBytes = i * 16;
|
|
37
|
+
for (let b = 0; b < 12; ++b) {
|
|
38
|
+
// biome-ignore lint/style/noNonNullAssertion: <explanation>
|
|
39
|
+
view.setUint8(outputOffsetBytes + b, pointsU8[xyzOffsetBytes + b]);
|
|
40
|
+
}
|
|
41
|
+
view.setUint8(outputOffsetBytes + 12, 0); // R
|
|
42
|
+
view.setUint8(outputOffsetBytes + 13, 0); // G
|
|
43
|
+
view.setUint8(outputOffsetBytes + 14, 0); // B
|
|
44
|
+
view.setUint8(outputOffsetBytes + 15, 255); // A (Opaque)
|
|
45
|
+
}
|
|
46
|
+
return new Uint8Array(buffer);
|
|
47
|
+
}
|
|
48
|
+
const WORKGROUP_SIZE_X = 128;
|
|
49
|
+
const POINT_STRIDE_BYTES = 16;
|
|
50
|
+
const shader = `
|
|
51
|
+
struct Intrinsics {
|
|
52
|
+
fx: f32,
|
|
53
|
+
fy: f32,
|
|
54
|
+
cx: f32,
|
|
55
|
+
cy: f32,
|
|
56
|
+
depthScale: f32,
|
|
57
|
+
depthWidth: f32,
|
|
58
|
+
depthHeight: f32,
|
|
59
|
+
i420Width: f32,
|
|
60
|
+
i420Height: f32,
|
|
61
|
+
numFrames_f: f32,
|
|
62
|
+
bytesPerI420Frame_f: f32,
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
struct OutputPointData {
|
|
66
|
+
x: f32,
|
|
67
|
+
y: f32,
|
|
68
|
+
z: f32,
|
|
69
|
+
color: u32,
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
@group(0) @binding(0) var<storage, read> depthBuffer: array<u32>;
|
|
73
|
+
@group(0) @binding(1) var<storage, read> intrinsics: Intrinsics;
|
|
74
|
+
@group(0) @binding(2) var<storage, read_write> xyzColorBuffer: array<OutputPointData>;
|
|
75
|
+
@group(0) @binding(3) var<storage, read> i420Buffer: array<u32>;
|
|
76
|
+
|
|
77
|
+
fn getI420Byte(byteIndexWithinFrame: u32, frameOffsetElements: u32, bufferLengthElements: u32) -> u32 {
|
|
78
|
+
let globalByteIndex = (frameOffsetElements * 4u) + byteIndexWithinFrame;
|
|
79
|
+
let elementIndex = globalByteIndex / 4u;
|
|
80
|
+
let offsetInElement = globalByteIndex % 4u;
|
|
81
|
+
if (elementIndex >= bufferLengthElements) {
|
|
82
|
+
return 0u;
|
|
83
|
+
}
|
|
84
|
+
let packedValue = i420Buffer[elementIndex];
|
|
85
|
+
return (packedValue >> (offsetInElement * 8u)) & 0xFFu;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@compute @workgroup_size(${WORKGROUP_SIZE_X}, 1, 1)
|
|
89
|
+
fn main(@builtin(global_invocation_id) global_id: vec3<u32>) {
|
|
90
|
+
let pixel_idx_in_frame = global_id.x;
|
|
91
|
+
let frame_idx = global_id.y;
|
|
92
|
+
let depthWidth = u32(intrinsics.depthWidth);
|
|
93
|
+
let depthHeight = u32(intrinsics.depthHeight);
|
|
94
|
+
let i420WidthU = u32(intrinsics.i420Width);
|
|
95
|
+
let i420HeightU = u32(intrinsics.i420Height);
|
|
96
|
+
let numFrames = u32(intrinsics.numFrames_f);
|
|
97
|
+
let bytesPerI420Frame = u32(intrinsics.bytesPerI420Frame_f);
|
|
98
|
+
let numPixelsPerFrame = depthWidth * depthHeight;
|
|
99
|
+
if (pixel_idx_in_frame >= numPixelsPerFrame || frame_idx >= numFrames || depthWidth == 0u || depthHeight == 0u) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
let global_output_idx = (frame_idx * numPixelsPerFrame) + pixel_idx_in_frame;
|
|
103
|
+
let depth_elements_per_frame = (numPixelsPerFrame + 1u) / 2u;
|
|
104
|
+
let depth_frame_offset = frame_idx * depth_elements_per_frame;
|
|
105
|
+
let i420AlignedStrideBytes = (bytesPerI420Frame + 3u) / 4u * 4u;
|
|
106
|
+
let i420_elements_per_frame_aligned = i420AlignedStrideBytes / 4u;
|
|
107
|
+
let i420_frame_offset = frame_idx * i420_elements_per_frame_aligned;
|
|
108
|
+
let depthIndex32_within_frame = pixel_idx_in_frame / 2u;
|
|
109
|
+
let packedDepthU32_idx = depth_frame_offset + depthIndex32_within_frame;
|
|
110
|
+
if (packedDepthU32_idx >= arrayLength(&depthBuffer)) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
let packedDepthU32 = depthBuffer[packedDepthU32_idx];
|
|
114
|
+
var rawDepthU16: u32;
|
|
115
|
+
if (pixel_idx_in_frame % 2u == 0u) {
|
|
116
|
+
rawDepthU16 = packedDepthU32 & 0xFFFFu;
|
|
117
|
+
} else {
|
|
118
|
+
rawDepthU16 = (packedDepthU32 >> 16u) & 0xFFFFu;
|
|
119
|
+
}
|
|
120
|
+
let u = f32(pixel_idx_in_frame % depthWidth);
|
|
121
|
+
let v = f32(pixel_idx_in_frame / depthWidth);
|
|
122
|
+
var outputPoint: OutputPointData;
|
|
123
|
+
outputPoint.x = 0.0;
|
|
124
|
+
outputPoint.y = 0.0;
|
|
125
|
+
outputPoint.z = 0.0;
|
|
126
|
+
outputPoint.color = 0xFF000000u;
|
|
127
|
+
let fx = intrinsics.fx;
|
|
128
|
+
let fy = intrinsics.fy;
|
|
129
|
+
let cx = intrinsics.cx;
|
|
130
|
+
let cy = intrinsics.cy;
|
|
131
|
+
let depthScale = intrinsics.depthScale;
|
|
132
|
+
if (rawDepthU16 > 0u && fx != 0.0 && fy != 0.0 && depthScale > 0.0) {
|
|
133
|
+
let z = f32(rawDepthU16) * depthScale;
|
|
134
|
+
outputPoint.x = (cx - u) * z / fx;
|
|
135
|
+
outputPoint.y = (cy - v) * z / fy;
|
|
136
|
+
outputPoint.z = z;
|
|
137
|
+
if (i420WidthU > 0u && i420HeightU > 0u && bytesPerI420Frame > 0u) {
|
|
138
|
+
let i420X = min(i420WidthU - 1u, u32(floor(u * (intrinsics.i420Width / intrinsics.depthWidth))));
|
|
139
|
+
let i420Y = min(i420HeightU - 1u, u32(floor(v * (intrinsics.i420Height / intrinsics.depthHeight))));
|
|
140
|
+
let frameSizeY = i420WidthU * i420HeightU;
|
|
141
|
+
let uvWidth = (i420WidthU + 1u) / 2u;
|
|
142
|
+
let uvHeight = (i420HeightU + 1u) / 2u;
|
|
143
|
+
let frameSizeUV = uvWidth * uvHeight;
|
|
144
|
+
let uOffsetBytes = frameSizeY;
|
|
145
|
+
let vOffsetBytes = frameSizeY + frameSizeUV;
|
|
146
|
+
let yIndexBytes = i420Y * i420WidthU + i420X;
|
|
147
|
+
let uvX = i420X / 2u;
|
|
148
|
+
let uvY = i420Y / 2u;
|
|
149
|
+
let uvIndexBytes = uvY * uvWidth + uvX;
|
|
150
|
+
let uIndexBytes = uOffsetBytes + uvIndexBytes;
|
|
151
|
+
let vIndexBytes = vOffsetBytes + uvIndexBytes;
|
|
152
|
+
let i420BufferTotalElements = arrayLength(&i420Buffer);
|
|
153
|
+
if (yIndexBytes < bytesPerI420Frame && uIndexBytes < bytesPerI420Frame && vIndexBytes < bytesPerI420Frame && (i420_frame_offset + (vIndexBytes / 4u)) < i420BufferTotalElements) {
|
|
154
|
+
let y_byte = getI420Byte(yIndexBytes, i420_frame_offset, i420BufferTotalElements);
|
|
155
|
+
let u_byte = getI420Byte(uIndexBytes, i420_frame_offset, i420BufferTotalElements);
|
|
156
|
+
let v_byte = getI420Byte(vIndexBytes, i420_frame_offset, i420BufferTotalElements);
|
|
157
|
+
let y_f = f32(y_byte);
|
|
158
|
+
let u_f = f32(u_byte) - 128.0;
|
|
159
|
+
let v_f = f32(v_byte) - 128.0;
|
|
160
|
+
var r_f = y_f + 1.402 * v_f;
|
|
161
|
+
var g_f = y_f - 0.344136 * u_f - 0.714136 * v_f;
|
|
162
|
+
var b_f = y_f + 1.772 * u_f;
|
|
163
|
+
let r = u32(clamp(r_f, 0.0, 255.0)) & 0xFFu;
|
|
164
|
+
let g = u32(clamp(g_f, 0.0, 255.0)) & 0xFFu;
|
|
165
|
+
let b = u32(clamp(b_f, 0.0, 255.0)) & 0xFFu;
|
|
166
|
+
let a = 255u;
|
|
167
|
+
outputPoint.color = (r) | (g << 8u) | (b << 16u) | (a << 24u);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
if (global_output_idx < arrayLength(&xyzColorBuffer)) {
|
|
172
|
+
xyzColorBuffer[global_output_idx] = outputPoint;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
`;
|
|
177
|
+
async function depthToPointcloudGPU(depthFrames, depthWidth, depthHeight, fx, fy, cx, cy, i420Frames, i420Width, i420Height, {
|
|
178
|
+
hasGPU
|
|
179
|
+
}) {
|
|
180
|
+
const numFrames = depthFrames.length;
|
|
181
|
+
if (numFrames === 0 || numFrames !== i420Frames.length) {
|
|
182
|
+
console.warn("GPU: Input frame arrays are empty or mismatched.");
|
|
183
|
+
return [];
|
|
184
|
+
}
|
|
185
|
+
if (depthWidth <= 0 || depthHeight <= 0) {
|
|
186
|
+
throw new Error("GPU: Invalid depth dimensions!");
|
|
187
|
+
}
|
|
188
|
+
if (depthFrames[0] && !(depthFrames[0] instanceof Uint16Array)) {
|
|
189
|
+
throw new Error("GPU: depthFrames[0].data is NOT a Uint16Array!");
|
|
190
|
+
}
|
|
191
|
+
if (i420Frames[0] && !(i420Frames[0] instanceof Uint8Array)) {
|
|
192
|
+
throw new Error("GPU: i420Frames[0].data is NOT a Uint8Array!");
|
|
193
|
+
}
|
|
194
|
+
const depthScale = 1.0;
|
|
195
|
+
|
|
196
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
197
|
+
if (!hasGPU) {
|
|
198
|
+
const results = [];
|
|
199
|
+
for (let i = 0; i < numFrames; i++) {
|
|
200
|
+
const depthFrame = depthFrames[i];
|
|
201
|
+
const colorFrame = i420Frames[i];
|
|
202
|
+
if (!depthFrame || !colorFrame) {
|
|
203
|
+
console.warn(`CPU Fallback: Skipping frame ${i} due to missing data.`);
|
|
204
|
+
results.push(new Uint8Array(0));
|
|
205
|
+
continue;
|
|
206
|
+
}
|
|
207
|
+
try {
|
|
208
|
+
const xyzData = depthToPointCloudBuffer(depthFrame, depthWidth, depthHeight, fx, fy, cx, cy);
|
|
209
|
+
results.push(i420ToRgbaToPointcloud(colorFrame, i420Width, i420Height, depthWidth, depthHeight, xyzData));
|
|
210
|
+
} catch (cpuError) {
|
|
211
|
+
console.error(`CPU Fallback: Error processing frame ${i}:`, cpuError);
|
|
212
|
+
results.push(new Uint8Array(0));
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return results;
|
|
216
|
+
}
|
|
217
|
+
let device = null;
|
|
218
|
+
let depthGpuBuffer = null;
|
|
219
|
+
let intrinsicsBuffer = null;
|
|
220
|
+
let i420GpuBuffer = null;
|
|
221
|
+
let xyzColorBuffer = null;
|
|
222
|
+
let readbackBuffer = null;
|
|
223
|
+
try {
|
|
224
|
+
const adapter = await navigator.gpu.requestAdapter();
|
|
225
|
+
if (!adapter) {
|
|
226
|
+
throw new Error("Failed to get GPU adapter.");
|
|
227
|
+
}
|
|
228
|
+
device = await adapter.requestDevice();
|
|
229
|
+
const queue = device.queue;
|
|
230
|
+
const numPixelsPerFrame = depthWidth * depthHeight;
|
|
231
|
+
const outputFrameSize = numPixelsPerFrame * POINT_STRIDE_BYTES;
|
|
232
|
+
const totalOutputBufferSize = outputFrameSize * numFrames;
|
|
233
|
+
const depthBytesPerFrame = numPixelsPerFrame * 2;
|
|
234
|
+
const depthElementsPerFrame = Math.ceil(depthBytesPerFrame / 4);
|
|
235
|
+
const totalDepthBufferSize = depthElementsPerFrame * numFrames * 4;
|
|
236
|
+
const i420BytesPerFrame = i420Frames[0]?.byteLength ?? 0;
|
|
237
|
+
if (i420BytesPerFrame === 0 && numFrames > 0) {
|
|
238
|
+
throw new Error("GPU: I420 frame data is empty or invalid for size calculation.");
|
|
239
|
+
}
|
|
240
|
+
const i420AlignedStrideBytes = Math.ceil(i420BytesPerFrame / 4) * 4;
|
|
241
|
+
const totalI420BufferSize = i420AlignedStrideBytes * numFrames;
|
|
242
|
+
const intrinsicsData = new Float32Array([fx, fy, cx, cy, depthScale, depthWidth, depthHeight, i420Width, i420Height, numFrames, i420BytesPerFrame]);
|
|
243
|
+
const intrinsicsBufferSize = Math.max(intrinsicsData.byteLength, 64);
|
|
244
|
+
intrinsicsBuffer = device.createBuffer({
|
|
245
|
+
label: "Intrinsics Buffer",
|
|
246
|
+
size: intrinsicsBufferSize,
|
|
247
|
+
usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_DST
|
|
248
|
+
});
|
|
249
|
+
queue.writeBuffer(intrinsicsBuffer, 0, intrinsicsData.buffer, intrinsicsData.byteOffset, intrinsicsData.byteLength);
|
|
250
|
+
depthGpuBuffer = device.createBuffer({
|
|
251
|
+
label: "Depth Buffer (Combined)",
|
|
252
|
+
size: totalDepthBufferSize,
|
|
253
|
+
usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_DST,
|
|
254
|
+
mappedAtCreation: true
|
|
255
|
+
});
|
|
256
|
+
const mappedDepthRange = depthGpuBuffer.getMappedRange();
|
|
257
|
+
const fullDepthArrayViewU32 = new Uint32Array(mappedDepthRange);
|
|
258
|
+
for (let i = 0; i < numFrames; ++i) {
|
|
259
|
+
const frameDataU16 = depthFrames[i];
|
|
260
|
+
if (!frameDataU16 || !(frameDataU16 instanceof Uint16Array)) {
|
|
261
|
+
console.warn(`GPU: Skipping depth frame ${i} due to missing/invalid data.`);
|
|
262
|
+
const frameOffsetElements = i * depthElementsPerFrame;
|
|
263
|
+
const elementsToWrite = depthElementsPerFrame;
|
|
264
|
+
fullDepthArrayViewU32.fill(0, frameOffsetElements, frameOffsetElements + elementsToWrite);
|
|
265
|
+
continue;
|
|
266
|
+
}
|
|
267
|
+
const frameOffsetElements = i * depthElementsPerFrame;
|
|
268
|
+
for (let p = 0; p < numPixelsPerFrame; p++) {
|
|
269
|
+
const u16_val = frameDataU16[p] ?? 0;
|
|
270
|
+
const elementIdx = frameOffsetElements + Math.floor(p / 2);
|
|
271
|
+
if (elementIdx >= fullDepthArrayViewU32.length) {
|
|
272
|
+
continue;
|
|
273
|
+
}
|
|
274
|
+
const isLowerHalf = p % 2 === 0;
|
|
275
|
+
if (isLowerHalf) {
|
|
276
|
+
// biome-ignore lint/style/noNonNullAssertion: <explanation>
|
|
277
|
+
fullDepthArrayViewU32[elementIdx] = fullDepthArrayViewU32[elementIdx] & 0xFFFF0000 | u16_val;
|
|
278
|
+
} else {
|
|
279
|
+
// biome-ignore lint/style/noNonNullAssertion: <explanation>
|
|
280
|
+
fullDepthArrayViewU32[elementIdx] = fullDepthArrayViewU32[elementIdx] & 0x0000FFFF | u16_val << 16;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
depthGpuBuffer.unmap();
|
|
285
|
+
i420GpuBuffer = device.createBuffer({
|
|
286
|
+
label: "I420 Buffer (Combined, Aligned)",
|
|
287
|
+
size: totalI420BufferSize,
|
|
288
|
+
usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_DST,
|
|
289
|
+
mappedAtCreation: true
|
|
290
|
+
});
|
|
291
|
+
const mappedI420Range = i420GpuBuffer.getMappedRange();
|
|
292
|
+
const fullI420ArrayViewU8 = new Uint8Array(mappedI420Range);
|
|
293
|
+
for (let i = 0; i < numFrames; ++i) {
|
|
294
|
+
const frameData = i420Frames[i];
|
|
295
|
+
const byteOffset = i * i420AlignedStrideBytes;
|
|
296
|
+
if (!frameData || !(frameData instanceof Uint8Array) || frameData.byteLength !== i420BytesPerFrame) {
|
|
297
|
+
console.warn(`GPU: Skipping I420 frame ${i} due to missing/invalid data or size mismatch.`);
|
|
298
|
+
fullI420ArrayViewU8.fill(0, byteOffset, byteOffset + i420AlignedStrideBytes);
|
|
299
|
+
continue;
|
|
300
|
+
}
|
|
301
|
+
const frameTargetView = new Uint8Array(mappedI420Range, byteOffset, frameData.byteLength);
|
|
302
|
+
frameTargetView.set(frameData);
|
|
303
|
+
if (i420AlignedStrideBytes > frameData.byteLength) {
|
|
304
|
+
const paddingStart = byteOffset + frameData.byteLength;
|
|
305
|
+
const paddingLength = i420AlignedStrideBytes - frameData.byteLength;
|
|
306
|
+
fullI420ArrayViewU8.fill(0, paddingStart, paddingStart + paddingLength);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
i420GpuBuffer.unmap();
|
|
310
|
+
xyzColorBuffer = device.createBuffer({
|
|
311
|
+
label: "Output XYZColor Buffer (Combined)",
|
|
312
|
+
size: totalOutputBufferSize,
|
|
313
|
+
usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_SRC
|
|
314
|
+
});
|
|
315
|
+
readbackBuffer = device.createBuffer({
|
|
316
|
+
label: "Readback Buffer",
|
|
317
|
+
size: totalOutputBufferSize,
|
|
318
|
+
usage: GPUBufferUsage.COPY_DST | GPUBufferUsage.MAP_READ
|
|
319
|
+
});
|
|
320
|
+
const bindGroupLayout = device.createBindGroupLayout({
|
|
321
|
+
label: "Compute Bind Group Layout",
|
|
322
|
+
entries: [{
|
|
323
|
+
binding: 0,
|
|
324
|
+
visibility: GPUShaderStage.COMPUTE,
|
|
325
|
+
buffer: {
|
|
326
|
+
type: "read-only-storage"
|
|
327
|
+
}
|
|
328
|
+
}, {
|
|
329
|
+
binding: 1,
|
|
330
|
+
visibility: GPUShaderStage.COMPUTE,
|
|
331
|
+
buffer: {
|
|
332
|
+
type: "read-only-storage"
|
|
333
|
+
}
|
|
334
|
+
}, {
|
|
335
|
+
binding: 2,
|
|
336
|
+
visibility: GPUShaderStage.COMPUTE,
|
|
337
|
+
buffer: {
|
|
338
|
+
type: "storage"
|
|
339
|
+
}
|
|
340
|
+
}, {
|
|
341
|
+
binding: 3,
|
|
342
|
+
visibility: GPUShaderStage.COMPUTE,
|
|
343
|
+
buffer: {
|
|
344
|
+
type: "read-only-storage"
|
|
345
|
+
}
|
|
346
|
+
}]
|
|
347
|
+
});
|
|
348
|
+
const bindGroup = device.createBindGroup({
|
|
349
|
+
label: "Compute Bind Group",
|
|
350
|
+
layout: bindGroupLayout,
|
|
351
|
+
entries: [{
|
|
352
|
+
binding: 0,
|
|
353
|
+
resource: {
|
|
354
|
+
buffer: depthGpuBuffer
|
|
355
|
+
}
|
|
356
|
+
}, {
|
|
357
|
+
binding: 1,
|
|
358
|
+
resource: {
|
|
359
|
+
buffer: intrinsicsBuffer
|
|
360
|
+
}
|
|
361
|
+
}, {
|
|
362
|
+
binding: 2,
|
|
363
|
+
resource: {
|
|
364
|
+
buffer: xyzColorBuffer
|
|
365
|
+
}
|
|
366
|
+
}, {
|
|
367
|
+
binding: 3,
|
|
368
|
+
resource: {
|
|
369
|
+
buffer: i420GpuBuffer
|
|
370
|
+
}
|
|
371
|
+
}]
|
|
372
|
+
});
|
|
373
|
+
const shaderModule = device.createShaderModule({
|
|
374
|
+
label: "Compute Shader Module",
|
|
375
|
+
code: shader
|
|
376
|
+
});
|
|
377
|
+
const pipeline = device.createComputePipeline({
|
|
378
|
+
label: "Compute Pipeline",
|
|
379
|
+
layout: device.createPipelineLayout({
|
|
380
|
+
bindGroupLayouts: [bindGroupLayout]
|
|
381
|
+
}),
|
|
382
|
+
compute: {
|
|
383
|
+
module: shaderModule,
|
|
384
|
+
entryPoint: "main"
|
|
385
|
+
}
|
|
386
|
+
});
|
|
387
|
+
const commandEncoder = device.createCommandEncoder({
|
|
388
|
+
label: "Compute Command Encoder"
|
|
389
|
+
});
|
|
390
|
+
const passEncoder = commandEncoder.beginComputePass({
|
|
391
|
+
label: "Compute Pass"
|
|
392
|
+
});
|
|
393
|
+
passEncoder.setPipeline(pipeline);
|
|
394
|
+
passEncoder.setBindGroup(0, bindGroup);
|
|
395
|
+
const numWorkgroupsX = Math.ceil(numPixelsPerFrame / WORKGROUP_SIZE_X);
|
|
396
|
+
const numWorkgroupsY = numFrames;
|
|
397
|
+
passEncoder.dispatchWorkgroups(numWorkgroupsX, numWorkgroupsY, 1);
|
|
398
|
+
passEncoder.end();
|
|
399
|
+
commandEncoder.copyBufferToBuffer(xyzColorBuffer, 0, readbackBuffer, 0, totalOutputBufferSize);
|
|
400
|
+
queue.submit([commandEncoder.finish()]);
|
|
401
|
+
await readbackBuffer.mapAsync(GPUMapMode.READ);
|
|
402
|
+
const mappedRange = readbackBuffer.getMappedRange();
|
|
403
|
+
const fullResultData = new Uint8Array(mappedRange.slice(0));
|
|
404
|
+
readbackBuffer.unmap();
|
|
405
|
+
readbackBuffer = null;
|
|
406
|
+
const results = [];
|
|
407
|
+
for (let i = 0; i < numFrames; i++) {
|
|
408
|
+
const frameOffset = i * outputFrameSize;
|
|
409
|
+
const frameEnd = Math.min(frameOffset + outputFrameSize, fullResultData.byteLength);
|
|
410
|
+
const frameData = fullResultData.slice(frameOffset, frameEnd);
|
|
411
|
+
if (frameData.byteLength !== outputFrameSize) {
|
|
412
|
+
console.warn(`GPU: Result frame ${i} has incorrect size (${frameData.byteLength} vs ${outputFrameSize}). Padding or error occurred.`);
|
|
413
|
+
results.push(new Uint8Array(outputFrameSize));
|
|
414
|
+
} else {
|
|
415
|
+
results.push(frameData);
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
return results;
|
|
419
|
+
} catch (error) {
|
|
420
|
+
console.error("GPU: Error during WebGPU processing:", error);
|
|
421
|
+
console.warn("GPU: Falling back to CPU due to error.");
|
|
422
|
+
const results = [];
|
|
423
|
+
for (let i = 0; i < numFrames; i++) {
|
|
424
|
+
const depthFrame = depthFrames[i];
|
|
425
|
+
const colorFrame = i420Frames[i];
|
|
426
|
+
if (!depthFrame || !colorFrame) {
|
|
427
|
+
console.warn(`CPU Fallback (error path): Skipping frame ${i} due to missing data.`);
|
|
428
|
+
results.push(new Uint8Array(0));
|
|
429
|
+
continue;
|
|
430
|
+
}
|
|
431
|
+
try {
|
|
432
|
+
const xyzData = depthToPointCloudBuffer(depthFrame, depthWidth, depthHeight, fx, fy, cx, cy);
|
|
433
|
+
results.push(i420ToRgbaToPointcloud(colorFrame, i420Width, i420Height, depthWidth, depthHeight, xyzData));
|
|
434
|
+
} catch (cpuError) {
|
|
435
|
+
console.error(`CPU Fallback (error path): Error processing frame ${i}:`, cpuError);
|
|
436
|
+
results.push(new Uint8Array(0));
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
return results;
|
|
440
|
+
} finally {
|
|
441
|
+
depthGpuBuffer?.destroy();
|
|
442
|
+
intrinsicsBuffer?.destroy();
|
|
443
|
+
i420GpuBuffer?.destroy();
|
|
444
|
+
xyzColorBuffer?.destroy();
|
|
445
|
+
readbackBuffer?.destroy();
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
expose({
|
|
449
|
+
depthToPointcloudGPU
|
|
450
|
+
});
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import { w as wrap } from './comlink-DHMAu6X7.js';
|
|
2
|
-
|
|
3
1
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
4
2
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
5
3
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/
|
|
6
|
-
|
|
4
|
+
|
|
7
5
|
function uint8ArrayToUint16Array(uint8Array) {
|
|
8
6
|
if (uint8Array.length % 2 !== 0) {
|
|
9
7
|
throw new Error("Uint8Array length must be a multiple of 2 for conversion to Uint16Array");
|
|
@@ -12,7 +10,6 @@ function uint8ArrayToUint16Array(uint8Array) {
|
|
|
12
10
|
for (let i = 0; i < uint16Array.length; i++) {
|
|
13
11
|
const lowByte = uint8Array[i * 2];
|
|
14
12
|
const highByte = uint8Array[i * 2 + 1];
|
|
15
|
-
|
|
16
13
|
// eslint-disable-next-line @foxglove/strict-equality
|
|
17
14
|
if (highByte === undefined || lowByte === undefined) {
|
|
18
15
|
throw new Error("Invalid data in uint8Array");
|
|
@@ -21,21 +18,6 @@ function uint8ArrayToUint16Array(uint8Array) {
|
|
|
21
18
|
}
|
|
22
19
|
return uint16Array;
|
|
23
20
|
}
|
|
24
|
-
const WORKER_COUNT = 4;
|
|
25
|
-
class depthToPointcloudWorkerPool {
|
|
26
|
-
lastUsedWorkerIndex = 0;
|
|
27
|
-
constructor() {
|
|
28
|
-
this.workerApis = new Array(WORKER_COUNT).fill(undefined).map(() => wrap(new Worker(new URL("pointcloudFromDepth.worker-CNKyMUU-.js", import.meta.url), {
|
|
29
|
-
type: "module"
|
|
30
|
-
})));
|
|
31
|
-
}
|
|
32
|
-
async depthToPointcloudGPU(depthArray, width, height, fx, fy, cx, cy, i420Data, i420Width, i420Height) {
|
|
33
|
-
// biome-ignore lint/style/noNonNullAssertion: This should work
|
|
34
|
-
const workerApi = this.workerApis[this.lastUsedWorkerIndex];
|
|
35
|
-
this.lastUsedWorkerIndex = (this.lastUsedWorkerIndex + 1) % WORKER_COUNT;
|
|
36
|
-
return await workerApi.depthToPointcloudGPU(depthArray, width, height, fx, fy, cx, cy, i420Data, i420Width, i420Height);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
21
|
|
|
40
22
|
/* H264 (i420) to RGBA */
|
|
41
23
|
function i420ToRgbaToPointcloud(i420Data, i420Width, i420Height, depthWidth, depthHeight, data) {
|
|
@@ -77,4 +59,4 @@ function i420ToRgbaToPointcloud(i420Data, i420Width, i420Height, depthWidth, dep
|
|
|
77
59
|
return new Uint8Array(buffer);
|
|
78
60
|
}
|
|
79
61
|
|
|
80
|
-
export {
|
|
62
|
+
export { i420ToRgbaToPointcloud as i, uint8ArrayToUint16Array as u };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@luxonis/visualizer-protobuf",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.23.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "RobotHub Visualizer Library",
|
|
6
6
|
"author": "Luxonis Corp",
|
|
@@ -22,6 +22,7 @@
|
|
|
22
22
|
"@mui/icons-material": "5.15.5",
|
|
23
23
|
"@mui/material": "5.15.6",
|
|
24
24
|
"@tailwindcss/cli": "4.0.17",
|
|
25
|
+
"camera-controls": "2.10.0",
|
|
25
26
|
"color": "^4.2.3",
|
|
26
27
|
"lodash.curry": "^4.1.1",
|
|
27
28
|
"nearley": "2.20.1",
|