Skip to content

Instantly share code, notes, and snippets.

View yongjun21's full-sized avatar

Yong Jun yongjun21

  • Singapore
  • 11:05 (UTC +08:00)
View GitHub Profile
@yongjun21
yongjun21 / bitmaskHelpers3d.ts
Created March 10, 2025 05:41
A set of helper functions for manipulating 3D bitmask in sparse (run-based) format
import SparseBitmask from "./SparseBitmask";
import { bitmaskFromWeightedRuns } from "./bitmaskHelpers";
import { OrderedMap } from "./OrderedCollections";
import { range } from "./base";
export function cutAndPasteBitmask3d(
from: SparseBitmask,
fromWidth: number,
fromHeight: number,
fromDepth: number,
@yongjun21
yongjun21 / perfectFit.ts
Created March 10, 2025 05:38
Calculates an ideal viewBox that centers on a target object
/**
* Calculates an ideal viewBox that centers on a target object
* @param objectBBox - Bounding box of the target object
* @param assetWidth - Width of the asset
* @param assetHeight - Height of the asset
* @param targetCoverage - target percentage of the viewport width or height the object should take up
* @param viewportAspectRatio - Aspect ratio of the viewport
* @param minFit - Minimum width and height of the viewport
* @returns - [offsetX, offsetY, viewportWidth, viewportHeight]
*/
@yongjun21
yongjun21 / MultiClassBitmask.ts
Last active March 10, 2025 05:52
Data structure for handling multiple bitmasks within one stack
import _noop from "lodash/noop";
import SparseBitmask from "../../utils/SparseBitmask";
import { OrderedSet, OrderedMap } from "../../utils/OrderedCollections";
import { range } from "../../utils/base";
interface RunNode<T> {
currState: OrderedSet<number>;
diff: Set<number>;
pending: Set<number>;
@yongjun21
yongjun21 / bitmaskHelpers.ts
Last active March 10, 2025 05:43
Some helpers functions for manipulating bitmask in sparse (run-based) format
import SparseBitmask, {
unionRunEnds,
intersectionRunEnds,
subtractionRunEnds,
} from "./SparseBitmask";
import {
cutAndPasteBitmask3d,
getBoundingBox3d,
getCentroid3d,
getWindowedRunLengths3d,
@yongjun21
yongjun21 / SparseBitmask.ts
Last active March 10, 2025 05:45
Custom data structure for efficient manipulation of sparse bitmask
import {
iterFilter,
iterFilterIndex,
range,
ArrayConstructor,
ArrayLike,
} from "./base";
import { OrderedSet } from "./OrderedCollections";
@yongjun21
yongjun21 / OrderedCollections.ts
Last active March 10, 2025 05:43
Combining heap with hash table to get a data structure that supports fast iteration even with frequent insert and delete
export class OrderedSet<T> {
private heap: T[] = [];
private sorted: T[] = [];
private heapIndex = new Map<T, number>();
private comparator: (item: T) => any;
constructor(comparator: (item: T) => any = item => item) {
this.comparator = comparator;
}
@yongjun21
yongjun21 / bitmask.ts
Last active February 6, 2024 02:49
Memory efficient implementation of bitmask
import { Stack } from './common.js';
export function decodeBitmask(
encoded: Uint8Array,
maxIndex: number
): Iterable<number> {
return {
*[Symbol.iterator]() {
const n = maxIndex + 1;
const depth = Math.ceil(Math.log2(n));
@yongjun21
yongjun21 / decodeOctree.ts
Last active July 25, 2022 16:53
Fast Octree decoder in JS
const MAX_LEVEL = 30;
const STACK = new Float32Array((7 * MAX_LEVEL + 1) * 4);
interface OctreeHeader {
version: number;
precision: number;
maxLevel: number;
nodeCounts: number[];
leafCount: number;
dataStartOffset: number;
@yongjun21
yongjun21 / encode_octree.ipynb
Last active July 25, 2022 15:23
Fast (vectorized) implementation of Octree encoding
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
@yongjun21
yongjun21 / minheap.js
Last active December 18, 2021 08:27
MinHeap in JS
class MinHeap {
constructor (comparator = (a, b) => a - b) {
this._data = []
this._comparator = comparator
}
push (...values) {
for (const v of values) {
let cIndex = this._data.push(v) - 1
while (cIndex > 0) {