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 + -
显示快捷键?