Skip to content

Commit

Permalink
Implement IDW interpolation (#32)
Browse files Browse the repository at this point in the history
* Implement Inverse Kinematics
* Add MathNet.Numerics dll
* Implement 3D thin-plate splines
* Add inverse weighted distance
  • Loading branch information
bjrtx authored Feb 14, 2024
1 parent ea02092 commit 455ea9c
Show file tree
Hide file tree
Showing 5 changed files with 84 additions and 0 deletions.
Binary file added Visuo-haptic Toolkit/Assets/MathNet.Numerics.dll
Binary file not shown.
33 changes: 33 additions & 0 deletions Visuo-haptic Toolkit/Assets/MathNet.Numerics.dll.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
using System.Linq;
using UnityEngine;
using VHToolkit;

namespace VHToolkit
{
public static class InverseWeightedDistance
{
public static Vector3 Interpolate(Vector3[] x, Vector3[] target, float p, Vector3 position) {
var weights = new float[x.Length];
int idx = 0;
foreach (var (origin, targ) in x.Zip(target)) {
var d = Vector3.Distance(origin, position);
if (Mathf.Approximately(d, 0)) {
return targ;
}
else {
weights[idx++] = Mathf.Pow(d, -p);
}
}
return target.Zip(weights, (t, w) => w * t).Aggregate(Vector3.zero, (a, b) => a + b) / weights.Sum();
}
}
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -103,5 +103,21 @@ public static Func<Vector3, Vector3> SabooSmoothedDisplacementField(Vector3[] x,

return point => new(components[0](point), components[1](point), components[2](point));
}

public static Func<Vector3, float> Solve(Vector3[] x, float[] y) => SolveSmoothed(x, y, 0f);

public static Func<Vector3, float> SolveSmoothed(Vector3[] x, float[] y, float lambda)
{
static float GreenFunction3D(Vector3 a, Vector3 b) => Vector3.Distance(a, b);
var Mat = Matrix<float>.Build;

var yVec = Vector<float>.Build.DenseOfArray(y);
var N = Mat.DenseOfRowArrays(x.Select(xx => new[] { 1, xx.x, xx.y, xx.z }));
var Minv = (Mat.Dense(x.Length, x.Length, (i, j) => GreenFunction3D(x[i], x[j])) + lambda * Mat.DenseIdentity(x.Length)).Inverse();
var b = (N.Transpose() * Minv * N).Inverse() * N.Transpose() * Minv * yVec;
var w = Minv * (yVec - N * b);

return (point) => x.Select(xx => GreenFunction3D(xx, point)).Zip(w, (ww, g) => ww * g).Sum() + b[0] + b[1] * point.x + b[2] * point.y + b[3] * point.z;
}
}
}

0 comments on commit 455ea9c

Please sign in to comment.