summaryrefslogtreecommitdiff
path: root/gr-digital/python/digital/utils/lfsr.py
blob: 2b8a47cb76414759f903584bb2b6a002c6053caa (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