]> Creatis software - CreaPhase.git/blob - octave_packages/communications-1.1.1/rledeco.m
Add a useful package (from Source forge) for octave
[CreaPhase.git] / octave_packages / communications-1.1.1 / rledeco.m
1 ## Copyright (C) 2006 Muthiah Annamalai <muthiah.annamalai@uta.edu>
2 ##
3 ## This program is free software; you can redistribute it and/or modify it under
4 ## the terms of the GNU General Public License as published by the Free Software
5 ## Foundation; either version 3 of the License, or (at your option) any later
6 ## version.
7 ##
8 ## This program is distributed in the hope that it will be useful, but WITHOUT
9 ## ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10 ## FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
11 ## details.
12 ##
13 ## You should have received a copy of the GNU General Public License along with
14 ## this program; if not, see <http://www.gnu.org/licenses/>.
15
16 ## -*- texinfo -*-
17 ## @deftypefn {Function File} {} rledeco (@var{message})
18 ##
19 ## Returns decoded run-length @var{message}. 
20 ## The RLE encoded @var{message} has to be in the form of a 
21 ## row-vector. The message format (encoded RLE) is like  repetition 
22 ## [factor, value]+.
23 ##
24 ## An example use of @code{rledeco} is
25 ## @example
26 ## @group
27 ##          message=[1 5 2 4 3 1];
28 ##          rledeco(message) #gives
29 ##          ans = [    5   4   4   1   1   1]
30 ## @end group
31 ## @end example
32 ## @end deftypefn
33 ## @seealso{rledeco}
34
35 function rmsg=rledeco(message)
36      if nargin < 1
37        error('Usage: rledeco(message)')
38      end
39      rmsg=[];
40      L=length(message);
41      itr=1;
42      while itr < L
43        times=message(itr);
44        val=message(itr+1);
45        rmsg=[rmsg val*(ones(1,times))];
46        itr=itr+2;
47      end
48      return
49 end
50 %!
51 %!assert( rledeco([1 5 2 4 3 1]),[5 4 4 1 1 1])
52 %!