You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

133 lines
5.3 KiB
C

/**
* Copyright 2013-2023 Software Radio Systems Limited
*
* This file is part of srsRAN.
*
* srsRAN is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
*
* srsRAN 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 Affero General Public License for more details.
*
* A copy of the GNU Affero General Public License can be found in
* the LICENSE file in the top-level directory of this distribution
* and at http://www.gnu.org/licenses/.
*
*/
#ifndef SRSRAN_RE_PATTERN_H
#define SRSRAN_RE_PATTERN_H
#include "../common/phy_common_nr.h"
/**
* @brief Maximum number of elements in a pattern list
*/
#define SRSRAN_RE_PATTERN_LIST_SIZE 4
/**
* @brief Characterizes a pattern in frequency-time domain in an NR slot resource grid
*/
typedef struct SRSRAN_API {
uint32_t rb_begin; ///< RB where the pattern begins in frequency domain
uint32_t rb_end; ///< RB where the pattern ends in frequency domain (excluded)
uint32_t rb_stride; ///< RB index jump
bool sc[SRSRAN_NRE]; ///< Frequency-domain pattern
bool symbol[SRSRAN_NSYMB_PER_SLOT_NR]; ///< Indicates OFDM symbols where the pattern is present
} srsran_re_pattern_t;
/**
* @brief List of RE patterns
*/
typedef struct SRSRAN_API {
srsran_re_pattern_t data[SRSRAN_RE_PATTERN_LIST_SIZE]; ///< Actual patterns
uint32_t count; ///< Number of RE patterns
} srsran_re_pattern_list_t;
/**
* @brief Calculates if a pattern matches a RE given a symbol l and a subcarrier k
* @param list Provides a list of patterns
* @param l OFDM symbol index
* @param k Subcarrier index
* @return True if pattern is valid and there is a match, false otherwise
*/
SRSRAN_API bool srsran_re_pattern_to_mask(const srsran_re_pattern_list_t* list, uint32_t l, uint32_t k);
/**
* @brief Calculates the pattern mask for an entire symbol from a RE pattern list
* @param list Provides a list of patterns
* @param l OFDM symbol index
* @param[out] mask Mask vector
* @return SRSRAN_SUCCESS if the mask is computed successfully, SRSRAN_ERROR code otherwise
*/
SRSRAN_API int srsran_re_pattern_to_symbol_mask(const srsran_re_pattern_t* pattern, uint32_t l, bool* mask);
/**
* @brief Calculates the pattern mask for an entire symbol from a RE pattern
* @param list Provides a list of patterns
* @param l OFDM symbol index
* @param[out] mask Mask vector
* @return SRSRAN_SUCCESS if the mask is computed successfully, SRSRAN_ERROR code otherwise
*/
SRSRAN_API int srsran_re_pattern_list_to_symbol_mask(const srsran_re_pattern_list_t* list, uint32_t l, bool* mask);
/**
* @brief Merges a pattern into the pattern list, it either merges subcarrier or symbol mask or simply appends a new
* pattern
* @param patterns Provides a list of patterns
* @param p Provides pattern to merge
* @return SRSRAN_SUCCESS if merging is successful, SRSRAN_ERROR code otherwise
*/
SRSRAN_API int srsran_re_pattern_merge(srsran_re_pattern_list_t* list, const srsran_re_pattern_t* p);
/**
* @brief Checks collision between a RE pattern list and a RE pattern
* @param list Provides pattern list
* @param p Provides a pattern
* @return SRSRAN_SUCCESS if no collision is detected, SRSRAN_ERROR code otherwise
*/
SRSRAN_API int srsran_re_pattern_check_collision(const srsran_re_pattern_list_t* list, const srsran_re_pattern_t* p);
/**
* @brief Initialises a given pattern list
* @param patterns Provides a list of patterns
*/
SRSRAN_API void srsran_re_pattern_reset(srsran_re_pattern_list_t* list);
/**
* @brief Writes a RE pattern information into a string
* @param pattern Provides the pattern
* @param str Provides string pointer
* @param str_len Maximum string length
* @return The number of characters writen into the string
*/
SRSRAN_API uint32_t srsran_re_pattern_info(const srsran_re_pattern_t* pattern, char* str, uint32_t str_len);
/**
* @brief Writes a RE pattern list information into a string
* @param pattern Provides the pattern list
* @param str Provides string pointer
* @param str_len Maximum string length
* @return The number of characters writen into the string
*/
SRSRAN_API uint32_t srsran_re_pattern_list_info(const srsran_re_pattern_list_t* pattern, char* str, uint32_t str_len);
/**
* @brief Counts the number of RE in a transmission characterised by initial and final symbol indexes and a PRB mask.
* @param list RE pattern list
* @param symbol_begin First transmission symbol
* @param symbol_end Last (excluded) transmission symbol
* @param prb_mask Frequency domain resource block mask
* @return The number of RE occupied by the pattern list in the transmission
*/
SRSRAN_API uint32_t srsran_re_pattern_list_count(const srsran_re_pattern_list_t* list,
uint32_t symbol_begin,
uint32_t symbol_end,
const bool prb_mask[SRSRAN_MAX_PRB_NR]);
#endif // SRSRAN_RE_PATTERN_H