@loaders.gl/pcd
Version:
Framework-independent loader for the PCD format
8 lines (7 loc) • 26.5 kB
Source Map (JSON)
{
"version": 3,
"sources": ["index.js", "lib/parse-pcd.js", "lib/decompress-lzf.js", "lib/get-pcd-schema.js", "pcd-loader.js"],
"sourcesContent": ["// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright vis.gl contributors\nimport parsePCDSync from \"./lib/parse-pcd.js\";\nimport { PCDLoader as PCDWorkerLoader } from \"./pcd-loader.js\";\nexport { PCDWorkerLoader };\n/**\n * Loader for PCD - Point Cloud Data\n */\nexport const PCDLoader = {\n ...PCDWorkerLoader,\n parse: async (arrayBuffer) => parsePCDSync(arrayBuffer),\n parseSync: parsePCDSync\n};\n", "// PCD Loader, adapted from THREE.js (MIT license)\n// Description: A loader for PCD ascii and binary files.\n// Limitations: Compressed binary files are not supported.\n//\n// Attributions per original THREE.js source file:\n// @author Filipe Caixeta / http://filipecaixeta.com.br\n// @author Mugen87 / https://github.com/Mugen87\nimport { getMeshBoundingBox } from '@loaders.gl/schema';\nimport { decompressLZF } from \"./decompress-lzf.js\";\nimport { getPCDSchema } from \"./get-pcd-schema.js\";\nconst LITTLE_ENDIAN = true;\n/**\n *\n * @param data\n * @returns\n */\nexport default function parsePCD(data) {\n // parse header (always ascii format)\n const textData = new TextDecoder().decode(data);\n const pcdHeader = parsePCDHeader(textData);\n let attributes = {};\n // parse data\n switch (pcdHeader.data) {\n case 'ascii':\n attributes = parsePCDASCII(pcdHeader, textData);\n break;\n case 'binary':\n attributes = parsePCDBinary(pcdHeader, data);\n break;\n case 'binary_compressed':\n attributes = parsePCDBinaryCompressed(pcdHeader, data);\n break;\n default:\n throw new Error(`PCD: ${pcdHeader.data} files are not supported`);\n }\n attributes = getMeshAttributes(attributes);\n const header = getMeshHeader(pcdHeader, attributes);\n const metadata = Object.fromEntries([\n ['mode', '0'],\n ['boundingBox', JSON.stringify(header.boundingBox)]\n ]);\n const schema = getPCDSchema(pcdHeader, metadata);\n return {\n loader: 'pcd',\n loaderData: pcdHeader,\n header,\n schema,\n mode: 0, // POINTS\n topology: 'point-list',\n attributes\n };\n}\n// Create a header that contains common data for PointCloud category loaders\nfunction getMeshHeader(pcdHeader, attributes) {\n if (typeof pcdHeader.width === 'number' && typeof pcdHeader.height === 'number') {\n const pointCount = pcdHeader.width * pcdHeader.height; // Supports \"organized\" point sets\n return {\n vertexCount: pointCount,\n boundingBox: getMeshBoundingBox(attributes)\n };\n }\n return {\n vertexCount: pcdHeader.vertexCount,\n boundingBox: pcdHeader.boundingBox\n };\n}\n/**\n * @param attributes\n * @returns Normalized attributes\n */\nfunction getMeshAttributes(attributes) {\n const normalizedAttributes = {\n POSITION: {\n // Binary PCD is only 32 bit\n value: new Float32Array(attributes.position),\n size: 3\n }\n };\n if (attributes.normal && attributes.normal.length > 0) {\n normalizedAttributes.NORMAL = {\n value: new Float32Array(attributes.normal),\n size: 3\n };\n }\n if (attributes.color && attributes.color.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.color),\n size: 3\n };\n }\n if (attributes.intensity && attributes.intensity.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.color),\n size: 3\n };\n }\n if (attributes.label && attributes.label.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.label),\n size: 3\n };\n }\n return normalizedAttributes;\n}\n/**\n * Incoming data parsing\n * @param data\n * @returns Header\n */\n/* eslint-disable complexity, max-statements */\nfunction parsePCDHeader(data) {\n const result1 = data.search(/[\\r\\n]DATA\\s(\\S*)\\s/i);\n const result2 = /[\\r\\n]DATA\\s(\\S*)\\s/i.exec(data.substr(result1 - 1));\n const pcdHeader = {};\n pcdHeader.data = result2 && result2[1];\n if (result2 !== null) {\n pcdHeader.headerLen = (result2 && result2[0].length) + result1;\n }\n pcdHeader.str = data.substr(0, pcdHeader.headerLen);\n // remove comments\n pcdHeader.str = pcdHeader.str.replace(/\\#.*/gi, '');\n // parse\n pcdHeader.version = /VERSION (.*)/i.exec(pcdHeader.str);\n pcdHeader.fields = /FIELDS (.*)/i.exec(pcdHeader.str);\n pcdHeader.size = /SIZE (.*)/i.exec(pcdHeader.str);\n pcdHeader.type = /TYPE (.*)/i.exec(pcdHeader.str);\n pcdHeader.count = /COUNT (.*)/i.exec(pcdHeader.str);\n pcdHeader.width = /WIDTH (.*)/i.exec(pcdHeader.str);\n pcdHeader.height = /HEIGHT (.*)/i.exec(pcdHeader.str);\n pcdHeader.viewpoint = /VIEWPOINT (.*)/i.exec(pcdHeader.str);\n pcdHeader.points = /POINTS (.*)/i.exec(pcdHeader.str);\n // evaluate\n if (pcdHeader.version !== null) {\n pcdHeader.version = parseFloat(pcdHeader.version[1]);\n }\n if (pcdHeader.fields !== null) {\n pcdHeader.fields = pcdHeader.fields[1].split(' ');\n }\n if (pcdHeader.type !== null) {\n pcdHeader.type = pcdHeader.type[1].split(' ');\n }\n if (pcdHeader.width !== null) {\n pcdHeader.width = parseInt(pcdHeader.width[1], 10);\n }\n if (pcdHeader.height !== null) {\n pcdHeader.height = parseInt(pcdHeader.height[1], 10);\n }\n if (pcdHeader.viewpoint !== null) {\n pcdHeader.viewpoint = pcdHeader.viewpoint[1];\n }\n if (pcdHeader.points !== null) {\n pcdHeader.points = parseInt(pcdHeader.points[1], 10);\n }\n if (pcdHeader.points === null &&\n typeof pcdHeader.width === 'number' &&\n typeof pcdHeader.height === 'number') {\n pcdHeader.points = pcdHeader.width * pcdHeader.height;\n }\n if (pcdHeader.size !== null) {\n pcdHeader.size = pcdHeader.size[1].split(' ').map((x) => parseInt(x, 10));\n }\n if (pcdHeader.count !== null) {\n pcdHeader.count = pcdHeader.count[1].split(' ').map((x) => parseInt(x, 10));\n }\n else {\n pcdHeader.count = [];\n if (pcdHeader.fields !== null) {\n for (let i = 0; i < pcdHeader.fields.length; i++) {\n pcdHeader.count.push(1);\n }\n }\n }\n pcdHeader.offset = {};\n let sizeSum = 0;\n if (pcdHeader.fields !== null && pcdHeader.size !== null) {\n for (let i = 0; i < pcdHeader.fields.length; i++) {\n if (pcdHeader.data === 'ascii') {\n pcdHeader.offset[pcdHeader.fields[i]] = i;\n }\n else {\n pcdHeader.offset[pcdHeader.fields[i]] = sizeSum;\n sizeSum += pcdHeader.size[i];\n }\n }\n }\n // for binary only\n pcdHeader.rowSize = sizeSum;\n return pcdHeader;\n}\n/**\n * @param pcdHeader\n * @param textData\n * @returns [attributes]\n */\n// eslint-enable-next-line complexity, max-statements\nfunction parsePCDASCII(pcdHeader, textData) {\n const position = [];\n const normal = [];\n const color = [];\n const intensity = [];\n const label = [];\n const offset = pcdHeader.offset;\n const pcdData = textData.substr(pcdHeader.headerLen);\n const lines = pcdData.split('\\n');\n for (let i = 0; i < lines.length; i++) {\n if (lines[i] !== '') {\n const line = lines[i].split(' ');\n if (offset.x !== undefined) {\n position.push(parseFloat(line[offset.x]));\n position.push(parseFloat(line[offset.y]));\n position.push(parseFloat(line[offset.z]));\n }\n if (offset.rgb !== undefined) {\n const floatValue = parseFloat(line[offset.rgb]);\n const binaryColor = new Float32Array([floatValue]);\n const dataview = new DataView(binaryColor.buffer, 0);\n color.push(dataview.getUint8(0));\n color.push(dataview.getUint8(1));\n color.push(dataview.getUint8(2));\n // TODO - handle alpha channel / RGBA?\n }\n if (offset.normal_x !== undefined) {\n normal.push(parseFloat(line[offset.normal_x]));\n normal.push(parseFloat(line[offset.normal_y]));\n normal.push(parseFloat(line[offset.normal_z]));\n }\n if (offset.intensity !== undefined) {\n intensity.push(parseFloat(line[offset.intensity]));\n }\n if (offset.label !== undefined) {\n label.push(parseInt(line[offset.label]));\n }\n }\n }\n return { position, normal, color };\n}\n/**\n * @param pcdHeader\n * @param data\n * @returns [attributes]\n */\nfunction parsePCDBinary(pcdHeader, data) {\n const position = [];\n const normal = [];\n const color = [];\n const intensity = [];\n const label = [];\n const dataview = new DataView(data, pcdHeader.headerLen);\n const offset = pcdHeader.offset;\n for (let i = 0, row = 0; i < pcdHeader.points; i++, row += pcdHeader.rowSize) {\n if (offset.x !== undefined) {\n position.push(dataview.getFloat32(row + offset.x, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(row + offset.y, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(row + offset.z, LITTLE_ENDIAN));\n }\n if (offset.rgb !== undefined) {\n color.push(dataview.getUint8(row + offset.rgb + 0));\n color.push(dataview.getUint8(row + offset.rgb + 1));\n color.push(dataview.getUint8(row + offset.rgb + 2));\n }\n if (offset.normal_x !== undefined) {\n normal.push(dataview.getFloat32(row + offset.normal_x, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(row + offset.normal_y, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(row + offset.normal_z, LITTLE_ENDIAN));\n }\n if (offset.intensity !== undefined) {\n intensity.push(dataview.getFloat32(row + offset.intensity, LITTLE_ENDIAN));\n }\n if (offset.label !== undefined) {\n label.push(dataview.getInt32(row + offset.label, LITTLE_ENDIAN));\n }\n }\n return { position, normal, color, intensity, label };\n}\n/** Parse compressed PCD data in in binary_compressed form ( https://pointclouds.org/documentation/tutorials/pcd_file_format.html)\n * from https://github.com/mrdoob/three.js/blob/master/examples/jsm/loaders/PCDLoader.js\n * @license MIT (http://opensource.org/licenses/MIT)\n * @param pcdHeader\n * @param data\n * @returns [attributes]\n */\n// eslint-enable-next-line complexity, max-statements\nfunction parsePCDBinaryCompressed(pcdHeader, data) {\n const position = [];\n const normal = [];\n const color = [];\n const intensity = [];\n const label = [];\n const sizes = new Uint32Array(data.slice(pcdHeader.headerLen, pcdHeader.headerLen + 8));\n const compressedSize = sizes[0];\n const decompressedSize = sizes[1];\n const decompressed = decompressLZF(new Uint8Array(data, pcdHeader.headerLen + 8, compressedSize), decompressedSize);\n const dataview = new DataView(decompressed.buffer);\n const offset = pcdHeader.offset;\n for (let i = 0; i < pcdHeader.points; i++) {\n if (offset.x !== undefined) {\n position.push(dataview.getFloat32(pcdHeader.points * offset.x + pcdHeader.size[0] * i, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(pcdHeader.points * offset.y + pcdHeader.size[1] * i, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(pcdHeader.points * offset.z + pcdHeader.size[2] * i, LITTLE_ENDIAN));\n }\n if (offset.rgb !== undefined) {\n color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 0) / 255.0);\n color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 1) / 255.0);\n color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 2) / 255.0);\n }\n if (offset.normal_x !== undefined) {\n normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_x + pcdHeader.size[4] * i, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_y + pcdHeader.size[5] * i, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_z + pcdHeader.size[6] * i, LITTLE_ENDIAN));\n }\n if (offset.intensity !== undefined) {\n const intensityIndex = pcdHeader.fields.indexOf('intensity');\n intensity.push(dataview.getFloat32(pcdHeader.points * offset.intensity + pcdHeader.size[intensityIndex] * i, LITTLE_ENDIAN));\n }\n if (offset.label !== undefined) {\n const labelIndex = pcdHeader.fields.indexOf('label');\n label.push(dataview.getInt32(pcdHeader.points * offset.label + pcdHeader.size[labelIndex] * i, LITTLE_ENDIAN));\n }\n }\n return {\n position,\n normal,\n color,\n intensity,\n label\n };\n}\n", "/* eslint-disable */\n/**\n * from https://gitlab.com/taketwo/three-pcd-loader/blob/master/decompress-lzf.js\n * @param inData\n * @param outLength\n * @returns\n */\nexport function decompressLZF(inData, outLength) {\n const inLength = inData.length;\n const outData = new Uint8Array(outLength);\n let inPtr = 0;\n let outPtr = 0;\n let ctrl;\n let len;\n let ref;\n do {\n ctrl = inData[inPtr++];\n if (ctrl < 1 << 5) {\n ctrl++;\n if (outPtr + ctrl > outLength) {\n throw new Error('Output buffer is not large enough');\n }\n if (inPtr + ctrl > inLength) {\n throw new Error('Invalid compressed data');\n }\n do {\n outData[outPtr++] = inData[inPtr++];\n } while (--ctrl);\n }\n else {\n len = ctrl >> 5;\n ref = outPtr - ((ctrl & 0x1f) << 8) - 1;\n if (inPtr >= inLength) {\n throw new Error('Invalid compressed data');\n }\n if (len === 7) {\n len += inData[inPtr++];\n if (inPtr >= inLength) {\n throw new Error('Invalid compressed data');\n }\n }\n ref -= inData[inPtr++];\n if (outPtr + len + 2 > outLength) {\n throw new Error('Output buffer is not large enough');\n }\n if (ref < 0) {\n throw new Error('Invalid compressed data');\n }\n if (ref >= outPtr) {\n throw new Error('Invalid compressed data');\n }\n do {\n outData[outPtr++] = outData[ref++];\n } while (--len + 2);\n }\n } while (inPtr < inLength);\n return outData;\n}\n", "/**\n * Gets schema from PCD header\n * @param PCDheader\n * @param metadata\n * @returns Schema\n */\nexport function getPCDSchema(PCDheader, metadata) {\n const offset = PCDheader.offset;\n const fields = [];\n if (offset.x !== undefined) {\n fields.push({\n name: 'POSITION',\n type: { type: 'fixed-size-list', listSize: 3, children: [{ name: 'xyz', type: 'float32' }] }\n });\n }\n if (offset.normal_x !== undefined) {\n fields.push({\n name: 'NORMAL',\n type: { type: 'fixed-size-list', listSize: 3, children: [{ name: 'xyz', type: 'float32' }] }\n });\n }\n if (offset.rgb !== undefined) {\n fields.push({\n name: 'COLOR_0',\n type: { type: 'fixed-size-list', listSize: 3, children: [{ name: 'rgb', type: 'uint8' }] }\n });\n }\n return { fields, metadata };\n}\n", "// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof \"4.3.3\" !== 'undefined' ? \"4.3.3\" : 'latest';\n/**\n * Worker loader for PCD - Point Cloud Data\n */\nexport const PCDLoader = {\n dataType: null,\n batchType: null,\n name: 'PCD (Point Cloud Data)',\n id: 'pcd',\n module: 'pcd',\n version: VERSION,\n worker: true,\n extensions: ['pcd'],\n mimeTypes: ['text/plain'],\n options: {\n pcd: {}\n }\n};\n"],
"mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA,mBAAAA;AAAA,EAAA;AAAA;AAAA;;;ACOA,oBAAmC;;;ACA5B,SAAS,cAAc,QAAQ,WAAW;AAC7C,QAAM,WAAW,OAAO;AACxB,QAAM,UAAU,IAAI,WAAW,SAAS;AACxC,MAAI,QAAQ;AACZ,MAAI,SAAS;AACb,MAAI;AACJ,MAAI;AACJ,MAAI;AACJ,KAAG;AACC,WAAO,OAAO,OAAO;AACrB,QAAI,OAAO,KAAK,GAAG;AACf;AACA,UAAI,SAAS,OAAO,WAAW;AAC3B,cAAM,IAAI,MAAM,mCAAmC;AAAA,MACvD;AACA,UAAI,QAAQ,OAAO,UAAU;AACzB,cAAM,IAAI,MAAM,yBAAyB;AAAA,MAC7C;AACA,SAAG;AACC,gBAAQ,QAAQ,IAAI,OAAO,OAAO;AAAA,MACtC,SAAS,EAAE;AAAA,IACf,OACK;AACD,YAAM,QAAQ;AACd,YAAM,WAAW,OAAO,OAAS,KAAK;AACtC,UAAI,SAAS,UAAU;AACnB,cAAM,IAAI,MAAM,yBAAyB;AAAA,MAC7C;AACA,UAAI,QAAQ,GAAG;AACX,eAAO,OAAO,OAAO;AACrB,YAAI,SAAS,UAAU;AACnB,gBAAM,IAAI,MAAM,yBAAyB;AAAA,QAC7C;AAAA,MACJ;AACA,aAAO,OAAO,OAAO;AACrB,UAAI,SAAS,MAAM,IAAI,WAAW;AAC9B,cAAM,IAAI,MAAM,mCAAmC;AAAA,MACvD;AACA,UAAI,MAAM,GAAG;AACT,cAAM,IAAI,MAAM,yBAAyB;AAAA,MAC7C;AACA,UAAI,OAAO,QAAQ;AACf,cAAM,IAAI,MAAM,yBAAyB;AAAA,MAC7C;AACA,SAAG;AACC,gBAAQ,QAAQ,IAAI,QAAQ,KAAK;AAAA,MACrC,SAAS,EAAE,MAAM;AAAA,IACrB;AAAA,EACJ,SAAS,QAAQ;AACjB,SAAO;AACX;;;ACnDO,SAAS,aAAa,WAAW,UAAU;AAC9C,QAAM,SAAS,UAAU;AACzB,QAAM,SAAS,CAAC;AAChB,MAAI,OAAO,MAAM,QAAW;AACxB,WAAO,KAAK;AAAA,MACR,MAAM;AAAA,MACN,MAAM,EAAE,MAAM,mBAAmB,UAAU,GAAG,UAAU,CAAC,EAAE,MAAM,OAAO,MAAM,UAAU,CAAC,EAAE;AAAA,IAC/F,CAAC;AAAA,EACL;AACA,MAAI,OAAO,aAAa,QAAW;AAC/B,WAAO,KAAK;AAAA,MACR,MAAM;AAAA,MACN,MAAM,EAAE,MAAM,mBAAmB,UAAU,GAAG,UAAU,CAAC,EAAE,MAAM,OAAO,MAAM,UAAU,CAAC,EAAE;AAAA,IAC/F,CAAC;AAAA,EACL;AACA,MAAI,OAAO,QAAQ,QAAW;AAC1B,WAAO,KAAK;AAAA,MACR,MAAM;AAAA,MACN,MAAM,EAAE,MAAM,mBAAmB,UAAU,GAAG,UAAU,CAAC,EAAE,MAAM,OAAO,MAAM,QAAQ,CAAC,EAAE;AAAA,IAC7F,CAAC;AAAA,EACL;AACA,SAAO,EAAE,QAAQ,SAAS;AAC9B;;;AFlBA,IAAM,gBAAgB;AAMP,SAAR,SAA0B,MAAM;AAEnC,QAAM,WAAW,IAAI,YAAY,EAAE,OAAO,IAAI;AAC9C,QAAM,YAAY,eAAe,QAAQ;AACzC,MAAI,aAAa,CAAC;AAElB,UAAQ,UAAU,MAAM;AAAA,IACpB,KAAK;AACD,mBAAa,cAAc,WAAW,QAAQ;AAC9C;AAAA,IACJ,KAAK;AACD,mBAAa,eAAe,WAAW,IAAI;AAC3C;AAAA,IACJ,KAAK;AACD,mBAAa,yBAAyB,WAAW,IAAI;AACrD;AAAA,IACJ;AACI,YAAM,IAAI,MAAM,QAAQ,UAAU,8BAA8B;AAAA,EACxE;AACA,eAAa,kBAAkB,UAAU;AACzC,QAAM,SAAS,cAAc,WAAW,UAAU;AAClD,QAAM,WAAW,OAAO,YAAY;AAAA,IAChC,CAAC,QAAQ,GAAG;AAAA,IACZ,CAAC,eAAe,KAAK,UAAU,OAAO,WAAW,CAAC;AAAA,EACtD,CAAC;AACD,QAAM,SAAS,aAAa,WAAW,QAAQ;AAC/C,SAAO;AAAA,IACH,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA,MAAM;AAAA;AAAA,IACN,UAAU;AAAA,IACV;AAAA,EACJ;AACJ;AAEA,SAAS,cAAc,WAAW,YAAY;AAC1C,MAAI,OAAO,UAAU,UAAU,YAAY,OAAO,UAAU,WAAW,UAAU;AAC7E,UAAM,aAAa,UAAU,QAAQ,UAAU;AAC/C,WAAO;AAAA,MACH,aAAa;AAAA,MACb,iBAAa,kCAAmB,UAAU;AAAA,IAC9C;AAAA,EACJ;AACA,SAAO;AAAA,IACH,aAAa,UAAU;AAAA,IACvB,aAAa,UAAU;AAAA,EAC3B;AACJ;AAKA,SAAS,kBAAkB,YAAY;AACnC,QAAM,uBAAuB;AAAA,IACzB,UAAU;AAAA;AAAA,MAEN,OAAO,IAAI,aAAa,WAAW,QAAQ;AAAA,MAC3C,MAAM;AAAA,IACV;AAAA,EACJ;AACA,MAAI,WAAW,UAAU,WAAW,OAAO,SAAS,GAAG;AACnD,yBAAqB,SAAS;AAAA,MAC1B,OAAO,IAAI,aAAa,WAAW,MAAM;AAAA,MACzC,MAAM;AAAA,IACV;AAAA,EACJ;AACA,MAAI,WAAW,SAAS,WAAW,MAAM,SAAS,GAAG;AAEjD,yBAAqB,UAAU;AAAA,MAC3B,OAAO,IAAI,WAAW,WAAW,KAAK;AAAA,MACtC,MAAM;AAAA,IACV;AAAA,EACJ;AACA,MAAI,WAAW,aAAa,WAAW,UAAU,SAAS,GAAG;AAEzD,yBAAqB,UAAU;AAAA,MAC3B,OAAO,IAAI,WAAW,WAAW,KAAK;AAAA,MACtC,MAAM;AAAA,IACV;AAAA,EACJ;AACA,MAAI,WAAW,SAAS,WAAW,MAAM,SAAS,GAAG;AAEjD,yBAAqB,UAAU;AAAA,MAC3B,OAAO,IAAI,WAAW,WAAW,KAAK;AAAA,MACtC,MAAM;AAAA,IACV;AAAA,EACJ;AACA,SAAO;AACX;AAOA,SAAS,eAAe,MAAM;AAC1B,QAAM,UAAU,KAAK,OAAO,sBAAsB;AAClD,QAAM,UAAU,uBAAuB,KAAK,KAAK,OAAO,UAAU,CAAC,CAAC;AACpE,QAAM,YAAY,CAAC;AACnB,YAAU,OAAO,WAAW,QAAQ,CAAC;AACrC,MAAI,YAAY,MAAM;AAClB,cAAU,aAAa,WAAW,QAAQ,CAAC,EAAE,UAAU;AAAA,EAC3D;AACA,YAAU,MAAM,KAAK,OAAO,GAAG,UAAU,SAAS;AAElD,YAAU,MAAM,UAAU,IAAI,QAAQ,UAAU,EAAE;AAElD,YAAU,UAAU,gBAAgB,KAAK,UAAU,GAAG;AACtD,YAAU,SAAS,eAAe,KAAK,UAAU,GAAG;AACpD,YAAU,OAAO,aAAa,KAAK,UAAU,GAAG;AAChD,YAAU,OAAO,aAAa,KAAK,UAAU,GAAG;AAChD,YAAU,QAAQ,cAAc,KAAK,UAAU,GAAG;AAClD,YAAU,QAAQ,cAAc,KAAK,UAAU,GAAG;AAClD,YAAU,SAAS,eAAe,KAAK,UAAU,GAAG;AACpD,YAAU,YAAY,kBAAkB,KAAK,UAAU,GAAG;AAC1D,YAAU,SAAS,eAAe,KAAK,UAAU,GAAG;AAEpD,MAAI,UAAU,YAAY,MAAM;AAC5B,cAAU,UAAU,WAAW,UAAU,QAAQ,CAAC,CAAC;AAAA,EACvD;AACA,MAAI,UAAU,WAAW,MAAM;AAC3B,cAAU,SAAS,UAAU,OAAO,CAAC,EAAE,MAAM,GAAG;AAAA,EACpD;AACA,MAAI,UAAU,SAAS,MAAM;AACzB,cAAU,OAAO,UAAU,KAAK,CAAC,EAAE,MAAM,GAAG;AAAA,EAChD;AACA,MAAI,UAAU,UAAU,MAAM;AAC1B,cAAU,QAAQ,SAAS,UAAU,MAAM,CAAC,GAAG,EAAE;AAAA,EACrD;AACA,MAAI,UAAU,WAAW,MAAM;AAC3B,cAAU,SAAS,SAAS,UAAU,OAAO,CAAC,GAAG,EAAE;AAAA,EACvD;AACA,MAAI,UAAU,cAAc,MAAM;AAC9B,cAAU,YAAY,UAAU,UAAU,CAAC;AAAA,EAC/C;AACA,MAAI,UAAU,WAAW,MAAM;AAC3B,cAAU,SAAS,SAAS,UAAU,OAAO,CAAC,GAAG,EAAE;AAAA,EACvD;AACA,MAAI,UAAU,WAAW,QACrB,OAAO,UAAU,UAAU,YAC3B,OAAO,UAAU,WAAW,UAAU;AACtC,cAAU,SAAS,UAAU,QAAQ,UAAU;AAAA,EACnD;AACA,MAAI,UAAU,SAAS,MAAM;AACzB,cAAU,OAAO,UAAU,KAAK,CAAC,EAAE,MAAM,GAAG,EAAE,IAAI,CAAC,MAAM,SAAS,GAAG,EAAE,CAAC;AAAA,EAC5E;AACA,MAAI,UAAU,UAAU,MAAM;AAC1B,cAAU,QAAQ,UAAU,MAAM,CAAC,EAAE,MAAM,GAAG,EAAE,IAAI,CAAC,MAAM,SAAS,GAAG,EAAE,CAAC;AAAA,EAC9E,OACK;AACD,cAAU,QAAQ,CAAC;AACnB,QAAI,UAAU,WAAW,MAAM;AAC3B,eAAS,IAAI,GAAG,IAAI,UAAU,OAAO,QAAQ,KAAK;AAC9C,kBAAU,MAAM,KAAK,CAAC;AAAA,MAC1B;AAAA,IACJ;AAAA,EACJ;AACA,YAAU,SAAS,CAAC;AACpB,MAAI,UAAU;AACd,MAAI,UAAU,WAAW,QAAQ,UAAU,SAAS,MAAM;AACtD,aAAS,IAAI,GAAG,IAAI,UAAU,OAAO,QAAQ,KAAK;AAC9C,UAAI,UAAU,SAAS,SAAS;AAC5B,kBAAU,OAAO,UAAU,OAAO,CAAC,CAAC,IAAI;AAAA,MAC5C,OACK;AACD,kBAAU,OAAO,UAAU,OAAO,CAAC,CAAC,IAAI;AACxC,mBAAW,UAAU,KAAK,CAAC;AAAA,MAC/B;AAAA,IACJ;AAAA,EACJ;AAEA,YAAU,UAAU;AACpB,SAAO;AACX;AAOA,SAAS,cAAc,WAAW,UAAU;AACxC,QAAM,WAAW,CAAC;AAClB,QAAM,SAAS,CAAC;AAChB,QAAM,QAAQ,CAAC;AACf,QAAM,YAAY,CAAC;AACnB,QAAM,QAAQ,CAAC;AACf,QAAM,SAAS,UAAU;AACzB,QAAM,UAAU,SAAS,OAAO,UAAU,SAAS;AACnD,QAAM,QAAQ,QAAQ,MAAM,IAAI;AAChC,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACnC,QAAI,MAAM,CAAC,MAAM,IAAI;AACjB,YAAM,OAAO,MAAM,CAAC,EAAE,MAAM,GAAG;AAC/B,UAAI,OAAO,MAAM,QAAW;AACxB,iBAAS,KAAK,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC;AACxC,iBAAS,KAAK,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC;AACxC,iBAAS,KAAK,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC;AAAA,MAC5C;AACA,UAAI,OAAO,QAAQ,QAAW;AAC1B,cAAM,aAAa,WAAW,KAAK,OAAO,GAAG,CAAC;AAC9C,cAAM,cAAc,IAAI,aAAa,CAAC,UAAU,CAAC;AACjD,cAAM,WAAW,IAAI,SAAS,YAAY,QAAQ,CAAC;AACnD,cAAM,KAAK,SAAS,SAAS,CAAC,CAAC;AAC/B,cAAM,KAAK,SAAS,SAAS,CAAC,CAAC;AAC/B,cAAM,KAAK,SAAS,SAAS,CAAC,CAAC;AAAA,MAEnC;AACA,UAAI,OAAO,aAAa,QAAW;AAC/B,eAAO,KAAK,WAAW,KAAK,OAAO,QAAQ,CAAC,CAAC;AAC7C,eAAO,KAAK,WAAW,KAAK,OAAO,QAAQ,CAAC,CAAC;AAC7C,eAAO,KAAK,WAAW,KAAK,OAAO,QAAQ,CAAC,CAAC;AAAA,MACjD;AACA,UAAI,OAAO,cAAc,QAAW;AAChC,kBAAU,KAAK,WAAW,KAAK,OAAO,SAAS,CAAC,CAAC;AAAA,MACrD;AACA,UAAI,OAAO,UAAU,QAAW;AAC5B,cAAM,KAAK,SAAS,KAAK,OAAO,KAAK,CAAC,CAAC;AAAA,MAC3C;AAAA,IACJ;AAAA,EACJ;AACA,SAAO,EAAE,UAAU,QAAQ,MAAM;AACrC;AAMA,SAAS,eAAe,WAAW,MAAM;AACrC,QAAM,WAAW,CAAC;AAClB,QAAM,SAAS,CAAC;AAChB,QAAM,QAAQ,CAAC;AACf,QAAM,YAAY,CAAC;AACnB,QAAM,QAAQ,CAAC;AACf,QAAM,WAAW,IAAI,SAAS,MAAM,UAAU,SAAS;AACvD,QAAM,SAAS,UAAU;AACzB,WAAS,IAAI,GAAG,MAAM,GAAG,IAAI,UAAU,QAAQ,KAAK,OAAO,UAAU,SAAS;AAC1E,QAAI,OAAO,MAAM,QAAW;AACxB,eAAS,KAAK,SAAS,WAAW,MAAM,OAAO,GAAG,aAAa,CAAC;AAChE,eAAS,KAAK,SAAS,WAAW,MAAM,OAAO,GAAG,aAAa,CAAC;AAChE,eAAS,KAAK,SAAS,WAAW,MAAM,OAAO,GAAG,aAAa,CAAC;AAAA,IACpE;AACA,QAAI,OAAO,QAAQ,QAAW;AAC1B,YAAM,KAAK,SAAS,SAAS,MAAM,OAAO,MAAM,CAAC,CAAC;AAClD,YAAM,KAAK,SAAS,SAAS,MAAM,OAAO,MAAM,CAAC,CAAC;AAClD,YAAM,KAAK,SAAS,SAAS,MAAM,OAAO,MAAM,CAAC,CAAC;AAAA,IACtD;AACA,QAAI,OAAO,aAAa,QAAW;AAC/B,aAAO,KAAK,SAAS,WAAW,MAAM,OAAO,UAAU,aAAa,CAAC;AACrE,aAAO,KAAK,SAAS,WAAW,MAAM,OAAO,UAAU,aAAa,CAAC;AACrE,aAAO,KAAK,SAAS,WAAW,MAAM,OAAO,UAAU,aAAa,CAAC;AAAA,IACzE;AACA,QAAI,OAAO,cAAc,QAAW;AAChC,gBAAU,KAAK,SAAS,WAAW,MAAM,OAAO,WAAW,aAAa,CAAC;AAAA,IAC7E;AACA,QAAI,OAAO,UAAU,QAAW;AAC5B,YAAM,KAAK,SAAS,SAAS,MAAM,OAAO,OAAO,aAAa,CAAC;AAAA,IACnE;AAAA,EACJ;AACA,SAAO,EAAE,UAAU,QAAQ,OAAO,WAAW,MAAM;AACvD;AASA,SAAS,yBAAyB,WAAW,MAAM;AAC/C,QAAM,WAAW,CAAC;AAClB,QAAM,SAAS,CAAC;AAChB,QAAM,QAAQ,CAAC;AACf,QAAM,YAAY,CAAC;AACnB,QAAM,QAAQ,CAAC;AACf,QAAM,QAAQ,IAAI,YAAY,KAAK,MAAM,UAAU,WAAW,UAAU,YAAY,CAAC,CAAC;AACtF,QAAM,iBAAiB,MAAM,CAAC;AAC9B,QAAM,mBAAmB,MAAM,CAAC;AAChC,QAAM,eAAe,cAAc,IAAI,WAAW,MAAM,UAAU,YAAY,GAAG,cAAc,GAAG,gBAAgB;AAClH,QAAM,WAAW,IAAI,SAAS,aAAa,MAAM;AACjD,QAAM,SAAS,UAAU;AACzB,WAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AACvC,QAAI,OAAO,MAAM,QAAW;AACxB,eAAS,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,IAAI,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AACrG,eAAS,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,IAAI,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AACrG,eAAS,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,IAAI,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AAAA,IACzG;AACA,QAAI,OAAO,QAAQ,QAAW;AAC1B,YAAM,KAAK,SAAS,SAAS,UAAU,SAAS,OAAO,MAAM,UAAU,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,GAAK;AAC/F,YAAM,KAAK,SAAS,SAAS,UAAU,SAAS,OAAO,MAAM,UAAU,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,GAAK;AAC/F,YAAM,KAAK,SAAS,SAAS,UAAU,SAAS,OAAO,MAAM,UAAU,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,GAAK;AAAA,IACnG;AACA,QAAI,OAAO,aAAa,QAAW;AAC/B,aAAO,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,WAAW,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AAC1G,aAAO,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,WAAW,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AAC1G,aAAO,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,WAAW,UAAU,KAAK,CAAC,IAAI,GAAG,aAAa,CAAC;AAAA,IAC9G;AACA,QAAI,OAAO,cAAc,QAAW;AAChC,YAAM,iBAAiB,UAAU,OAAO,QAAQ,WAAW;AAC3D,gBAAU,KAAK,SAAS,WAAW,UAAU,SAAS,OAAO,YAAY,UAAU,KAAK,cAAc,IAAI,GAAG,aAAa,CAAC;AAAA,IAC/H;AACA,QAAI,OAAO,UAAU,QAAW;AAC5B,YAAM,aAAa,UAAU,OAAO,QAAQ,OAAO;AACnD,YAAM,KAAK,SAAS,SAAS,UAAU,SAAS,OAAO,QAAQ,UAAU,KAAK,UAAU,IAAI,GAAG,aAAa,CAAC;AAAA,IACjH;AAAA,EACJ;AACA,SAAO;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACJ;AACJ;;;AGpUA,IAAM,UAAU,OAAiC,UAAU;AAIpD,IAAM,YAAY;AAAA,EACrB,UAAU;AAAA,EACV,WAAW;AAAA,EACX,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,YAAY,CAAC,KAAK;AAAA,EAClB,WAAW,CAAC,YAAY;AAAA,EACxB,SAAS;AAAA,IACL,KAAK,CAAC;AAAA,EACV;AACJ;;;AJbO,IAAMC,aAAY;AAAA,EACrB,GAAG;AAAA,EACH,OAAO,OAAO,gBAAgB,SAAa,WAAW;AAAA,EACtD,WAAW;AACf;",
"names": ["PCDLoader", "PCDLoader"]
}