mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-11-03 13:11:20 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			74 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// Copyright 2020 Mobilinkd LLC.
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include "Util.h"
 | 
						|
 | 
						|
#include <algorithm>
 | 
						|
#include <array>
 | 
						|
 | 
						|
namespace modemm17
 | 
						|
{
 | 
						|
 | 
						|
template <size_t F1= 45, size_t F2 = 92, size_t K = 368>
 | 
						|
struct PolynomialInterleaver
 | 
						|
{
 | 
						|
    using buffer_t = std::array<int8_t, K>;
 | 
						|
    using bytes_t = std::array<uint8_t, K / 8>;
 | 
						|
 | 
						|
    alignas(16) buffer_t buffer_;
 | 
						|
 | 
						|
    size_t index(size_t i)
 | 
						|
    {
 | 
						|
        return ((F1 * i) + (F2 * i * i)) % K;
 | 
						|
    }
 | 
						|
 | 
						|
    void interleave(buffer_t& data)
 | 
						|
    {
 | 
						|
        buffer_.fill(0);
 | 
						|
 | 
						|
        for (size_t i = 0; i != K; ++i)
 | 
						|
            buffer_[index(i)] = data[i];
 | 
						|
 | 
						|
        std::copy(std::begin(buffer_), std::end(buffer_), std::begin(data));
 | 
						|
    }
 | 
						|
 | 
						|
    void interleave(bytes_t& data)
 | 
						|
    {
 | 
						|
        bytes_t buffer;
 | 
						|
        buffer.fill(0);
 | 
						|
        for (size_t i = 0; i != K; ++i)
 | 
						|
        {
 | 
						|
            assign_bit_index(buffer, index(i), get_bit_index(data, i));
 | 
						|
        }
 | 
						|
        std::copy(buffer.begin(), buffer.end(), data.begin());
 | 
						|
    }
 | 
						|
 | 
						|
    void deinterleave(buffer_t& frame)
 | 
						|
    {
 | 
						|
        buffer_.fill(0);
 | 
						|
 | 
						|
        for (size_t i = 0; i != K; ++i)
 | 
						|
        {
 | 
						|
            auto idx = index(i);
 | 
						|
            buffer_[i] = frame[idx];
 | 
						|
        }
 | 
						|
 | 
						|
        std::copy(buffer_.begin(), buffer_.end(), frame.begin());
 | 
						|
    }
 | 
						|
 | 
						|
    void deinterleave(bytes_t& data)
 | 
						|
    {
 | 
						|
        bytes_t buffer;
 | 
						|
        buffer.fill(0);
 | 
						|
        for (size_t i = 0; i != K; ++i)
 | 
						|
        {
 | 
						|
            assign_bit_index(buffer, i, get_bit_index(data, index(i)));
 | 
						|
        }
 | 
						|
        std::copy(buffer.begin(), buffer.end(), data.begin());
 | 
						|
    }
 | 
						|
 | 
						|
};
 | 
						|
 | 
						|
} // modemm17
 |