Public
Edited
Jan 11
Fork of 3D RBFs
1 star
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
data = {
randomize;
const points = [],
values = [];
const rand = (min, max) => Math.random() * (max - min) + min;
const n = npoints;
for (let i = 0; i < n; i++) {
points.push([rand(-1, 1), rand(-1, 1), rand(-1, 1)]);
values.push([0]);
}
const anchorPoints = [
[-1, -1, -1],
[-1, -1, 1],
[-1, 1, -1],
[-1, 1, 1],
[1, 1, -1],
[1, 1, 1],
[1, -1, -1],
[1, -1, 1]
].map(([x, y, z]) => [2 * x, 2 * y, 2 * z]);
const dist = [];
for (let p of anchorPoints) {
let minDist = Number.MAX_VALUE;
for (let i = 0; i < n; i++) {
const q = points[i];
const d = Math.sqrt(
(p[0] - q[0]) ** 2 + (p[1] - q[1]) ** 2 + (p[2] - q[2]) ** 2
);
minDist = Math.min(d, minDist);
}
dist.push([minDist]);
}
return { points: anchorPoints.concat(points), values: dist.concat(values) };
}
Insert cell
rbf = RBF(data.points, data.values, kernel)
Insert cell
interpolant = rbf.interpolant
Insert cell
Insert cell
cubeSamples = 8
Insert cell
function sampleCube(n = cubeSamples) {
const delta = 2 / n;
let samples = [];
for (let i = 0; i <= n; i++) {
samples.push([]);
let x = -1 + i * delta;
for (let j = 0; j <= n; j++) {
samples[i].push([]);
let y = -1 + j * delta;
for (let k = 0; k <= n; k++) {
let z = -1 + k * delta;
samples[i][j][k] = interpolant([x, y, z])[0];
}
}
}
return samples;
}
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
rayMarchingApp = {
const { width: w, height: h } = rayMarchingCanvas;
const bigTriangle = new Float32Array([-5, -5, 5, -5, 0, 5]);
const app = picogl
.createApp(rayMarchingCanvas, {
premultipliedAlpha: false,
preserveDrawingBuffer: true
})
.clearColor(0.5, 0.5, 0.5, 1);
const positions = app.createVertexBuffer(picogl.FLOAT, 2, bigTriangle);
const triangleArray = app
.createVertexArray()
.vertexAttributeBuffer(0, positions);
const program = app.createProgram(vertShader, fragShader);
const drawCall = app.createDrawCall(program, triangleArray);
return { app, drawCall };
}
Insert cell
renderRayMarching = {
const canvas = rayMarchingCanvas;
const { app, drawCall } = rayMarchingApp;
const arcball = new Arcball(canvas);

const refresh = () => {
app.clear();
drawCall
//.uniform("u_n", data.points.length)
.uniform("u_resolution", [canvas.width, canvas.height])
.uniform("u_points[0]", data.points.flat())
.uniform("transform", arcball.transform)
.uniform("correctionPower", correctionPower)
.uniform("correctionLinear", correctionLinear)
.uniform("u_weights[0]", rbf.w[0])
.draw();
};
canvas.onmousedown = (e) =>
arcball.mousedown(e.offsetX, canvas.height - e.offsetY);
canvas.onmousemove = (e) => {
if (e.buttons) {
arcball.mousemove(e.offsetX, canvas.height - e.offsetY);
refresh();
}
};
canvas.onmouseup = (e) => arcball.mouseup();
refresh();
}
Insert cell
Insert cell
Insert cell
glslKernels = ({
linear: `r`,
cubic: `pow(r,3.)`,
quintic: `pow(r,5.)`,
"thin-plate": `r==0.0 ? 0.0 : r*r*log(r)`
})
Insert cell
Insert cell
Insert cell
Insert cell
picogl = require("picogl@0.17.8/build/picogl.min.js")
Insert cell
glmatrix = require("https://bundle.run/gl-matrix@3.3.0")
Insert cell
mat4 = glmatrix.mat4
Insert cell
vec3 = glmatrix.vec3
Insert cell
vec2 = glmatrix.vec2
Insert cell
Insert cell

One platform to build and deploy the best data apps

Experiment and prototype by building visualizations in live JavaScript notebooks. Collaborate with your team and decide which concepts to build out.
Use Observable Framework to build data apps locally. Use data loaders to build in any language or library, including Python, SQL, and R.
Seamlessly deploy to Observable. Test before you ship, use automatic deploy-on-commit, and ensure your projects are always up-to-date.
Learn more