gridsamp.m
来自「Kriging插值工具箱」· M 代码 · 共 45 行
M
45 行
function S = gridsamp(range, q)%GRIDSAMP n-dimensional grid over given range%% Call: S = gridsamp(range, q)%% range : 2*n matrix with lower and upper limits% q : n-vector, q(j) is the number of points% in the j'th direction.% If q is a scalar, then all q(j) = q% S : m*n array with points, m = prod(q)% hbn@imm.dtu.dk % Last update June 25, 2002[mr n] = size(range); dr = diff(range);if mr ~= 2 | any(dr < 0) error('range must be an array with two rows and range(1,:) <= range(2,:)')end sq = size(q);if min(sq) > 1 | any(q <= 0) error('q must be a vector with non-negative elements')endp = length(q); if p == 1, q = repmat(q,1,n); elseif p ~= n error(sprintf('length of q must be either 1 or %d',n))end % Check for degenerate intervalsi = find(dr == 0);if ~isempty(i), q(i) = 0*q(i); end% Recursive computationif n > 1 A = gridsamp(range(:,2:end), q(2:end)); % Recursive call [m p] = size(A); q = q(1); S = [zeros(m*q,1) repmat(A,q,1)]; y = linspace(range(1,1),range(2,1), q); k = 1:m; for i = 1 : q S(k,1) = repmat(y(i),m,1); k = k + m; endelse S = linspace(range(1,1),range(2,1), q).';end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?