| 1 | 
% EXTRACT - Extract a section from an input vector which contains an  | 
| 2 | 
%           n-dimensional array in a linear series. | 
| 3 | 
%           Usage: out = Extract( InputVector, section ) | 
| 4 | 
%           InputVector is of form | 
| 5 | 
%           [ NumberDimensions Dim1 Dim2 ... DimN data ] | 
| 6 | 
%           section is of form | 
| 7 | 
%           [ Dim1Min Dim1Max Dim2Min Dim2Max ... DimNMin DimNMax ] | 
| 8 | 
% | 
| 9 | 
function outArr = Extract( inArr, subSection ) | 
| 10 | 
if nargin ~= 2  | 
| 11 | 
  fprintf(2,'**ERROR** wrong number of arguments.\n') | 
| 12 | 
  fprintf(2,'Usage: a = Slice ( b, [ xmin xmax ymin ymax ... ]\n') | 
| 13 | 
  return | 
| 14 | 
end | 
| 15 | 
if size(subSection,1) ~= 1 | 
| 16 | 
  fprintf(2,'**ERROR** sub-section incorrectly specified.\n') | 
| 17 | 
  fprintf(2,'Usage: a = Slice ( b, [ xmin xmax ymin ymax ... ]\n') | 
| 18 | 
  return | 
| 19 | 
end | 
| 20 | 
if inArr(1)*2 ~= size(subSection,2) | 
| 21 | 
  fprintf(2,'**ERROR** sub-section has wrong number of elments.\n') | 
| 22 | 
  fprintf(2,'Usage: a = Slice ( b, [ xmin xmax ymin ymax ... ]\n') | 
| 23 | 
  return | 
| 24 | 
end | 
| 25 | 
% | 
| 26 | 
% Get dimensions of data array help in input vector. | 
| 27 | 
nD=inArr(1);                                 | 
| 28 | 
Ds=inArr(2:nD+1); | 
| 29 | 
for i=1:nD | 
| 30 | 
 s1(i)=subSection((i-1)*2+1); s2(i)=subSection((i-1)*2+2); | 
| 31 | 
end | 
| 32 | 
inStep(1)=1; | 
| 33 | 
for i=2:nD | 
| 34 | 
  inStep(i)=inStep(i-1)*Ds(i-1); | 
| 35 | 
end | 
| 36 | 
nC=1; | 
| 37 | 
for i =1:nD | 
| 38 | 
  nC=nC*(subSection((i-1)*2+2)-subSection((i-1)*2+1)+1); | 
| 39 | 
end | 
| 40 | 
wk=zeros(nC,nD); | 
| 41 | 
% | 
| 42 | 
%  Build list of coordinates to extract. | 
| 43 | 
for i=1:nD                    | 
| 44 | 
 ss=subSection((i-1)*2+1); se=subSection((i-1)*2+2); | 
| 45 | 
 if i == 1 lCycle = 1; | 
| 46 | 
 else      lCycle = prod((s2(1:i-1)-s1(1:i-1)+1)); | 
| 47 | 
 end | 
| 48 | 
 if i < nD nRep = prod((s2(i+1:nD)-s1(i+1:nD)+1)); | 
| 49 | 
 else      nRep = 1; | 
| 50 | 
 end | 
| 51 | 
 blk=reshape(([ss:se]'*(zeros(1,lCycle)+1))',lCycle*(se-ss+1),1); | 
| 52 | 
 wk(:,i)=reshape(blk*(zeros(1,nRep)+1),nRep*lCycle*(se-ss+1),1); | 
| 53 | 
end | 
| 54 | 
% | 
| 55 | 
% Translate coordinate list into offsets along vector. | 
| 56 | 
iS=[0,inStep(2:nD)];                           | 
| 57 | 
wk(:,1)=1+nD+wk(:,1)+(wk-1)*iS'; | 
| 58 | 
% | 
| 59 | 
% Extract selected locations. | 
| 60 | 
outArr=inArr(wk(:,1)');                         | 
| 61 | 
return |