⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gridsamp.m

📁 Kriging插值工具箱
💻 M
字号:
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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -