diff options
author | jcorgan | 2006-08-03 04:51:51 +0000 |
---|---|---|
committer | jcorgan | 2006-08-03 04:51:51 +0000 |
commit | 5d69a524f81f234b3fbc41d49ba18d6f6886baba (patch) | |
tree | b71312bf7f1e8d10fef0f3ac6f28784065e73e72 /gr-atsc/src/lib/gen_encoder.py | |
download | gnuradio-5d69a524f81f234b3fbc41d49ba18d6f6886baba.tar.gz gnuradio-5d69a524f81f234b3fbc41d49ba18d6f6886baba.tar.bz2 gnuradio-5d69a524f81f234b3fbc41d49ba18d6f6886baba.zip |
Houston, we have a trunk.
git-svn-id: http://gnuradio.org/svn/gnuradio/trunk@3122 221aa14e-8319-0410-a670-987f0aec2ac5
Diffstat (limited to 'gr-atsc/src/lib/gen_encoder.py')
-rwxr-xr-x | gr-atsc/src/lib/gen_encoder.py | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/gr-atsc/src/lib/gen_encoder.py b/gr-atsc/src/lib/gen_encoder.py new file mode 100755 index 000000000..0a2a50801 --- /dev/null +++ b/gr-atsc/src/lib/gen_encoder.py @@ -0,0 +1,63 @@ +#!/usr/bin/python +# +# Copyright 2002 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING. If not, write to +# the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +# Boston, MA 02111-1307, USA. +# + +def output(input, state): + x2 = (input >> 1) & 0x1 + x1 = (input >> 0) & 0x1 + s = (state >> 2) & 0x1 + t = (state >> 1) & 0x1 + u = (state >> 0) & 0x1 + + z0 = u + z1 = x1 + z2 = x2 ^ s + return (z2 << 2) | (z1 << 1) | z0 + + +def next_state(input, state): + x2 = (input >> 1) & 0x1 + x1 = (input >> 0) & 0x1 + s0 = (state >> 2) & 0x1 + t0 = (state >> 1) & 0x1 + u0 = (state >> 0) & 0x1 + + s1 = x2 ^ s0 + t1 = u0 + u1 = t0 ^ x1 + + return (s1 << 2) | (t1 << 1) | u1 + +print "@@@ NEXT @@@" + +for i in range (32): + state = (i >> 2) & 0x7 + input = i & 0x3 + print next_state (input, state) + + +print "@@@ OUTPUT @@@" + +for i in range (32): + state = (i >> 2) & 0x7 + input = i & 0x3 + print output (input, state) + |