RunMat
GitHub

interp2 — Interpolate values on two-dimensional grids in MATLAB and RunMat.

interp2(X, Y, Z, Xq, Yq) estimates surface values at query points from gridded data. Meshgrid-style coordinates and implicit-axis forms are supported, consistent with MATLAB semantics.

Syntax

Vq = interp2(Z, Xq, Yq)
Vq = interp2(X, Y, Z, Xq, Yq)
Vq = interp2(Z, Xq, Yq, method)
Vq = interp2(X, Y, Z, Xq, Yq, method)
Vq = interp2(Z, Xq, Yq, extrap)
Vq = interp2(X, Y, Z, Xq, Yq, extrap)
Vq = interp2(Z, Xq, Yq, method, extrap)
Vq = interp2(X, Y, Z, Xq, Yq, method, extrap)

Inputs

NameTypeRequiredDefaultDescription
ZAnyYesGrid sample matrix.
XqAnyYesQuery X coordinates.
YqAnyYesQuery Y coordinates.
XAnyYesGrid X axis vector or mesh.
YAnyYesGrid Y axis vector or mesh.
methodStringScalarNo"linear"Interpolation method: "linear" or "nearest".
extrapAnyNoNaNExtrapolation mode: "extrap" or scalar fill value.

Returns

NameTypeDescription
VqNumericArrayInterpolated values over a 2-D grid.

Errors

IdentifierWhenMessage
RunMat:interp2:InvalidArgumentArgument count, method/extrapolation options, or axis/query compatibility is invalid.interp2: invalid argument
RunMat:interp2:InvalidInputGrid or query values cannot be converted to numeric interpolation domains.interp2: invalid input
RunMat:interp2:InternalInterpolation output construction fails due to internal tensor assembly paths.interp2: internal interpolation failure

How interp2 works

  • Supports linear and nearest methods in the initial implementation.
  • Out-of-range query points return NaN unless an extrapolation value or 'extrap' is supplied.
  • Dense real numeric inputs are supported. GPU inputs gather to the host reference path.

Examples

Bilinear interpolation with implicit axes

Z = [1 2; 3 4];
zq = interp2(Z, 1.5, 1.5)

Expected output:

zq = 2.5

Interpolation with meshgrid axes

[X, Y] = meshgrid([10 20], [100 200]);
Z = [1 2; 3 4];
zq = interp2(X, Y, Z, 15, 150)

Expected output:

zq = 2.5

Using interp2 with coding agents

Open a RunMat example with live inputs, then ask the agent to explain how interp2 changes the result.

Run a small interp2 example, explain the result, then change one input and compare the output.

Interpolation

interp1 · pchip · ppval · spline

Elementwise

abs · angle · complex · conj · double · exp · expm1 · factorial · gamma · hypot · imag · ldivide · log · log10 · log1p · log2 · minus · nextpow2 · plus · pow2 · power · rdivide · real · sign · single · sqrt · times

Trigonometry

acos · acosh · asin · asinh · atan · atan2 · atanh · cos · cosd · cosh · deg2rad · rad2deg · sin · sind · sinh · tan · tand · tanh

Reduction

all · any · cummax · cummin · cumprod · cumsum · cumtrapz · diff · gradient · max · mean · median · min · nnz · prod · std · sum · trapz · var

Signal

blackman · butter · conv · conv2 · deconv · filter · hamming · hann · sawtooth · sinc · square

Rounding

ceil · fix · floor · mod · rem · round

Factor

chol · eig · lu · qr · svd

Solve

cond · det · inv · linsolve · norm · pinv · rank · rcond · rref

Fft

fft · fft2 · fftshift · ifft · ifft2 · ifftshift

Ode

ode15s · ode23 · ode45

Open-source implementation

Unlike proprietary runtimes, every RunMat function is open-source. Read exactly how interp2 is executed, line by line, in Rust.

About RunMat

RunMat is an open-source runtime that executes MATLAB-syntax code blazing on any GPU. It is licensed under the Apache 2.0 license.

  • RunMat automatically optimizes your math for GPU execution on Apple, Nvidia, and AMD hardware. No code changes needed. Simulations that took hours now take minutes.
  • Start running code in seconds. RunMat runs in the browser, on the desktop, or from the CLI. No license server, no IT ticket.

Getting started · Benchmarks · Pricing

Download RunMat

Download RunMat for full performance, or use RunMat in your browser for zero setup.