summaryrefslogtreecommitdiff
path: root/gr-digital/python/digital/utils/lfsr.py
blob: 44f62f0c7a92b95d9da4eac18808cb214919b1dd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#!/usr/bin/env python
#
# Copyright 2020 Free Software Foundation, Inc.
#
# This file is part of GNU Radio
#
# SPDX-License-Identifier: GPL-3.0-or-later
#
#

def lfsr_args(seed, *exp):
    """
    Produce arguments to create scrambler objects from exponent polynomial expressions.
     seed: start-value of register
    *exp: exponents of desired polynomial.
     Example:
    >>> l = digital.lfsr(*lfrs_args(0b11001,7,1,0))
    Creates an lfsr object with seed 0b11001, mask 0b1000011, K=6
    """
    from functools import reduce
    return reduce(int.__xor__, map(lambda x: 2**x, exp)), seed, max(exp) - 1