nr_estimation.h 4.95 KB
Newer Older
Hongzhi Wang's avatar
Hongzhi Wang committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The OpenAirInterface Software Alliance licenses this file to You under
 * the OAI Public License, Version 1.1  (the "License"); you may not use this file
 * except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.openairinterface.org/?page_id=698
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *-------------------------------------------------------------------------------
 * For more information about the OpenAirInterface (OAI) Software Alliance:
 *      contact@openairinterface.org
 */

22 23
#ifndef __NR_ESTIMATION_DEFS__H__
#define __NR_ESTIMATION_DEFS__H__
Hongzhi Wang's avatar
Hongzhi Wang committed
24 25 26


#include "PHY/defs_nr_UE.h"
27
//#include "PHY/defs_gNB.h"
Hongzhi Wang's avatar
Hongzhi Wang committed
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
/** @addtogroup _PHY_PARAMETER_ESTIMATION_BLOCKS_
 * @{
 */

/*!\brief Timing drift hysterisis in samples*/
#define SYNCH_HYST 2

/*!
\brief This function performs channel estimation including frequency and temporal interpolation
\param phy_vars_ue Pointer to UE PHY variables
\param eNB_id Index of target eNB
\param eNB_offset Offset for interfering eNB (in terms cell ID mod 3)
\param Ns slot number (0..19)
\param p antenna port
\param l symbol within slot
\param symbol symbol within frame
*/
45
int nr_pdcch_channel_estimation(PHY_VARS_NR_UE *ue,
46
                                UE_nr_rxtx_proc_t *proc,
47 48 49 50 51
                                uint8_t eNB_offset,
                                unsigned char Ns,
                                unsigned char symbol,
                                unsigned short coreset_start_subcarrier,
                                unsigned short nb_rb_coreset);
Hongzhi Wang's avatar
Hongzhi Wang committed
52

53
int nr_pbch_dmrs_correlation(PHY_VARS_NR_UE *ue,
54
                             UE_nr_rxtx_proc_t *proc,
55 56 57
                             uint8_t eNB_offset,
                             unsigned char Ns,
                             unsigned char symbol,
58 59
                             int dmrss,
                             NR_UE_SSB *current_ssb);
60

Hongzhi Wang's avatar
Hongzhi Wang committed
61
int nr_pbch_channel_estimation(PHY_VARS_NR_UE *ue,
62
                               UE_nr_rxtx_proc_t *proc,
Francesco Mani's avatar
Francesco Mani committed
63 64
                               uint8_t eNB_offset,
                               unsigned char Ns,
65
                               unsigned char symbol,
66 67 68
                               int dmrss,
                               uint8_t ssb_index,
                               uint8_t n_hf);
69 70

int nr_pdsch_channel_estimation(PHY_VARS_NR_UE *ue,
71
                                UE_nr_rxtx_proc_t *proc,
72 73 74 75 76 77
                                uint8_t eNB_offset,
                                unsigned char Ns,
                                unsigned short p,
                                unsigned char symbol,
                                unsigned short bwp_start_subcarrier,
                                unsigned short nb_rb_pdsch);
Francesco Mani's avatar
Francesco Mani committed
78

hongzhi wang's avatar
hongzhi wang committed
79
void nr_adjust_synch_ue(NR_DL_FRAME_PARMS *frame_parms,
80 81
                        PHY_VARS_NR_UE *ue,
                        module_id_t eNB_id,
82
                        uint8_t frame,
83 84 85
                        uint8_t subframe,
                        unsigned char clear,
                        short coef);
Hongzhi Wang's avatar
Hongzhi Wang committed
86 87
                      
void nr_ue_measurements(PHY_VARS_NR_UE *ue,
88
                        UE_nr_rxtx_proc_t *proc,
89 90 91 92 93 94
                        unsigned int subframe_offset,
                        unsigned char N0_symbol,
                        unsigned char abstraction_flag,
                        unsigned char rank_adaptation,
                        uint8_t subframe);

95
void nr_ue_rsrp_measurements(PHY_VARS_NR_UE *ue,
96 97 98
                             UE_nr_rxtx_proc_t *proc,
                             uint8_t slot,
                             uint8_t abstraction_flag);
99

100 101 102
void phy_adjust_gain_nr(PHY_VARS_NR_UE *ue,
                        uint32_t rx_power_fil_dB,
                        uint8_t eNB_id);
hongzhi wang's avatar
hongzhi wang committed
103

104
int16_t get_nr_PL(uint8_t Mod_id, uint8_t CC_id, uint8_t gNB_index);
105

106 107 108 109 110 111
void nr_pdsch_ptrs_processing(PHY_VARS_NR_UE *ue,
                              NR_UE_PDSCH **pdsch_vars,
                              NR_DL_FRAME_PARMS *frame_parms,
                              NR_DL_UE_HARQ_t *dlsch0_harq,
                              NR_DL_UE_HARQ_t *dlsch1_harq,
                              uint8_t eNB_id,
112
                              uint8_t nr_slot_rx,
113 114 115 116 117
                              unsigned char symbol,
                              uint32_t nb_re_pdsch,
                              unsigned char harq_pid,
                              uint16_t rnti,
                              RX_type_t rx_type);
118

119 120
float_t get_nr_RSRP(module_id_t Mod_id,uint8_t CC_id,uint8_t gNB_index);

Hongzhi Wang's avatar
Hongzhi Wang committed
121
#endif