tensor product spline evaluation

조회 수: 5 (최근 30일)
Jack
Jack 2014년 10월 30일
답변: Aditya 2025년 7월 22일
Hello everyone:
Background is that I have a set of 3D points (x,y,z) and would like to know if y are under a B-spline . My idea is to substitute x and y into spline equations and use point-membership classification.
example I am using is from spline toolbox.
% create data
x = sort([(0:10)/10,.03 .07, .93 .97]);
y = sort([(0:6)/6,.03 .07, .93 .97]);
[xx,yy] = ndgrid(x,y); z = franke(xx,yy);
% fitting y
ky = 3; knotsy = augknt([0,.25,.5,.75,1],ky);
sp = spap2(knotsy,ky,y,z);
% fitting x
coefsy = fnbrk(sp,'coefs');
kx = 4; knotsx = augknt([0:.2:1],kx);
sp2 = spap2(knotsx,kx,x,coefsy.');
coefs = fnbrk(sp2,'coefs').';
% plot results
xv = 0:.025:1; yv = 0:.025:1;
values = spcol(knotsx,kx,xv)*coefs*spcol(knotsy,ky,yv).';
mesh(xv,yv,values.'), view(150,50);
% random points in 3D
pts=rand(100,3);
% evulation
for j=1:size(pts,1)
zEst(j,:) = fnval(spmak({knotsx,knotsy},coefs),{pts(j,1),pts(j,2)});
end
[IX,~]=find(pts(:,3)-zEst<0);
My question is: is it possible to use one function that is able to substitute all x and y values rar than put m into a for loop
I have try spcol but not working as point sequence TAU should be nondecreasing.
spcol(knotsx,kx,pts(j,1))*coefs*spcol(knotsy,ky,pts(j,2)).';
Thank You

답변 (1개)

Aditya
Aditya 2025년 7월 22일
Hi jack,
You can efficiently evaluate a bivariate B-spline surface at many arbitrary (x, y) points without a for-loop by using MATLAB's fnval function in a vectorized manner. The key is to pass your x and y coordinates as row vectors inside a cell array to fnval, which will then return the estimated z-values for all points at once. This is much faster and cleaner than looping through each point. For example, if your random 3D points are stored in pts, you can compute all estimated surface z-values like this:
zEst = fnval(spmak({knotsx, knotsy}, coefs), {pts(:,1).', pts(:,2).'});
zEst = zEst(:); % Ensure it's a column vector
This approach avoids the need for a for-loop entirely and leverages MATLAB's optimized spline evaluation routines. There's no need to use spcol directly for this task, as fnval handles the details internally and works correctly for scattered input points.

카테고리

Help CenterFile Exchange에서 Spline Postprocessing에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by