File: intdec.sci

package info (click to toggle)
scilab 2.4-1
  • links: PTS
  • area: non-free
  • in suites: potato, slink
  • size: 55,196 kB
  • ctags: 38,019
  • sloc: ansic: 231,970; fortran: 148,976; tcl: 7,099; makefile: 4,585; sh: 2,978; csh: 154; cpp: 101; asm: 39; sed: 5
file content (105 lines) | stat: -rw-r--r-- 3,470 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
function [y]=intdec(x,lom)
//y=intdec(x,lom)
//Changes the sampling rate of a 1D or 2D signal by the rates in lom
//  x      :Input sampled signal
//  lom    :For a 1D signal this is a scalar which gives the rate change
//         :For a 2D signal this is a 2-Vector of sampling rate
//         :changes lom=(col rate change,row rate change)
//  y      :Output sampled signal
//!
// author: C. Bunks  date: 8 August 1990
// Copyright INRIA

//Get dimensions of vectors
 
   xsize=size(x);
   xmin=mini(x);xmax=maxi(x);
   if xsize(1)==1 then, lom=[1 lom]; end,
   if xsize(2)==1 then, lom=[lom 1]; end,
 
//compute sampling rate change as ratio of two integers
 
   [l,m]=rat(lom);
 
//Assuming that the signal length is N (=xsize)
//the interpolated signal is N*l and the decimated
//signal is N*l/m.  The resulting output will have
//length int(N*l/m).
 
   xlsize=xsize.*l;
   xmsize=int(xlsize./m);
 
//Since the location of %pi in the frequency domain
//falls on a sample point for N even and between two
//sample points for N odd care must be taken to differentiate
//between the two cases in the following manipulations.
 
   leven=2*(int(xsize/2)-xsize/2)+ones(xsize);
   meven=2*(int(xmsize/2)-xmsize/2)+ones(xmsize);
 
//The position of %pi for the Fourier transform of the
//original signal is different for odd and even length signals.
//For an even length signal %pi is at the (N/2)+1 sample and
//for an odd length signal %pi is between the (N+1)/2 and the
//(N+1)/2 + 1 samples.
 
   fp=int(xsize/2)+ones(xsize);
   fpc=xsize-fp+leven;
 
   fm=int(xmsize/2)+ones(xmsize);
   fmc=fm-ones(fm)-meven;
 
//If the input is a constant then don't do the work
 
   if xmax==xmin then,
      y=xmax*ones(xmsize(1),xmsize(2));
   else,
 
//For interpolation we, theoretically, would upsample x by putting l-1
//zeroes between each sample and then low pass filter at w=%pi.
//However, this corresponds to cutting the Fourier transform of the
//original signal into two parts at w=%pi and inserting l times the
//length of the signal in zeroes.
//
//For decimation we, theoretically, would low pass filter at the
//Nyquist frequency and then remove m-1 samples out of m of the
//time domain signal.  However, this corresponds to saving the
//N/m points of the signal at the two ends of the Fourier transform
//and then inverse transforming.
 
//Fourier transform the signal
 
      xf=fft(x,-1);
 
//Re-assemble the correct portions of the frequency domain signal
 
      if fm(1)<fp(1) then,//reduce row length (decimation)
         xlf=[xf(1:fm(1),:);xf(xsize(1)-fmc(1)+1:xsize(1),:)];
      else,
         if xmsize(1)==xsize(1) then,//no changes in row length
            xlf=xf;
         else,//increase row length (interpolation)
            xlf=[xf(1:fp(1),:);...
                 0*ones(xmsize(1)-fpc(1)-fp(1),xsize(2));...
                 xf(xsize(1)-fpc(1)+1:xsize(1),:)];
         end,
      end,
      if fm(2)<fp(2) then,//decrease column length (decimation)
         xlf=[xlf(:,1:fm(2)),xlf(:,xsize(2)-fmc(2)+1:xsize(2))];
      else,
         if xmsize(2)==xsize(2) then,//no changes in column length
            xlf=xlf;
         else,//increase column length (interpolation)
            xlf=[xlf(:,1:fp(2)),...
                 0*ones(xmsize(1),xmsize(2)-fpc(2)-fp(2)),...
                 xlf(:,xsize(2)-fpc(2)+1:xsize(2))];
         end,
      end,
 
//recuperate new signal and rescale
 
      y=real(fft(xlf,1));
      y=prod(lom)*y;
 
    end