⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tablecarmap.h

📁 Dream.exe soft source (Visual C++)
💻 H
字号:
/******************************************************************************\
 * Technische Universitaet Darmstadt, Institut fuer Nachrichtentechnik
 * Copyright (c) 2001
 *
 * Author(s):
 *	Volker Fischer
 *
 * Description:
 *	Tables for carrier mapping
 *
 ******************************************************************************
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation; either version 2 of the License, or (at your option) any later 
 * version.
 *
 * This program 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 General Public License for more 
 * details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc., 
 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 *
\******************************************************************************/

#if !defined(TABLE_CAR_MAP_H__3B0_CA63_4344_BB2B_23E7912__INCLUDED_)
#define TABLE_CAR_MAP_H__3B0_CA63_4344_BB2B_23E7912__INCLUDED_

#include "../GlobalDefinitions.h"


/* Definitions ****************************************************************/
/* FAC ************************************************************************/
#define NUM_FAC_CELLS			65

/* FAC positions. The two numbers are {symbol no, carrier no} */
const int iTableFACRobModA[NUM_FAC_CELLS][2] = {
	{2, 26}, {2, 46}, {2, 66}, {2, 86},
	{3, 10}, {3, 30}, {3, 50}, {3, 70}, {3, 90},
	{4, 14}, {4, 22}, {4, 34}, {4, 62}, {4, 74}, {4, 94},
	{5, 26}, {5, 38}, {5, 58}, {5, 66}, {5, 78},
	{6, 22}, {6, 30}, {6, 42}, {6, 62}, {6, 70}, {6, 82},
	{7, 26}, {7, 34}, {7, 46}, {7, 66}, {7, 74}, {7, 86},
	{8, 10}, {8, 30}, {8, 38}, {8, 50}, {8, 58}, {8, 70}, {8, 78}, {8, 90},
	{9, 14}, {9, 22}, {9, 34}, {9, 42}, {9, 62}, {9, 74}, {9, 82}, {9, 94},
	{10, 26}, {10, 38}, {10, 46}, {10, 66}, {10, 86},
	{11, 10}, {11, 30}, {11, 50}, {11, 70}, {11, 90},
	{12, 14}, {12, 34}, {12, 74}, {12, 94},
	{13, 38}, {13, 58}, {13, 78}
};

const int iTableFACRobModB[NUM_FAC_CELLS][2] = {
	{2, 13}, {2, 25}, {2, 43}, {2, 55}, {2, 67},
	{3, 15}, {3, 27}, {3, 45}, {3, 57}, {3, 69},
	{4, 17}, {4, 29}, {4, 47}, {4, 59}, {4, 71},
	{5, 19}, {5, 31}, {5, 49}, {5, 61}, {5, 73},
	{6, 9}, {6, 21}, {6, 33}, {6, 51}, {6, 63}, {6, 75},
	{7, 11}, {7, 23}, {7, 35}, {7, 53}, {7, 65}, {7, 77},
	{8, 13}, {8, 25}, {8, 37}, {8, 55}, {8, 67}, {8, 79},
	{9, 15}, {9, 27}, {9, 39}, {9, 57}, {9, 69}, {9, 81},
	{10, 17}, {10, 29}, {10, 41}, {10, 59}, {10, 71}, {10, 83},
	{11, 19}, {11, 31}, {11, 43}, {11, 61}, {11, 73},
	{12, 21}, {12, 33}, {12, 45}, {12, 63}, {12, 75},
	{13, 23}, {13, 35}, {13, 47}, {13, 65}, {13, 77},
};

const int iTableFACRobModC[NUM_FAC_CELLS][2] = {
	{3, 9}, {3, 21}, {3, 45}, {3, 57},
	{4, 23}, {4, 35}, {4, 47},
	{5, 13}, {5, 25}, {5, 37}, {5, 49},
	{6, 15}, {6, 27}, {6, 39}, {6, 51},
	{7, 5}, {7, 17}, {7, 29}, {7, 41}, {7, 53},
	{8, 7}, {8, 19}, {8, 31}, {8, 43}, {8, 55},
	{9, 9}, {9, 21}, {9, 45}, {9, 57},
	{10, 23}, {10, 35}, {10, 47},
	{11, 13}, {11, 25}, {11, 37}, {11, 49},
	{12, 15}, {12, 27}, {12, 39}, {12, 51},
	{13, 5}, {13, 17}, {13, 29}, {13, 41}, {13, 53},
	{14, 7}, {14, 19}, {14, 31}, {14, 43}, {14, 55},
	{15, 9}, {15, 21}, {15, 45}, {15, 57},
	{16, 23}, {16, 35}, {16, 47},
	{17, 13}, {17, 25}, {17, 37}, {17, 49},
	{18, 15}, {18, 27}, {18, 39}, {18, 51}
};

const int iTableFACRobModD[NUM_FAC_CELLS][2] = {
	{3, 9}, {3, 18}, {3, 27},
	{4, 10}, {4, 19},
	{5, 11}, {5, 20}, {5, 29},
	{6, 12}, {6, 30},
	{7, 13}, {7, 22}, {7, 31},
	{8, 5}, {8, 14}, {8, 23}, {8, 32},
	{9, 6}, {9, 15}, {9, 24}, {9, 33},
	{10, 16}, {10, 25}, {10, 34},
	{11, 8}, {11, 17}, {11, 26}, {11, 35},
	{12, 9}, {12, 18}, {12, 27}, {12, 36},
	{13, 10}, {13, 19}, {13, 37},
	{14, 11}, {14, 20}, {14, 29},
	{15, 12}, {15, 30},
	{16, 13}, {16, 22}, {16, 31},
	{17, 5}, {17, 14}, {17, 23}, {17, 32},
	{18, 6}, {18, 15}, {18, 24}, {18, 33},
	{19, 16}, {19, 25}, {19, 34},
	{20, 8}, {20, 17}, {20, 26}, {20, 35},
	{21, 9}, {21, 18}, {21, 27}, {21, 36},
	{22, 10}, {22, 19}, {22, 37}
};


/* Frequency pilots ***********************************************************/
#define NUM_FREQ_PILOTS			3
const int iTableFreqPilRobModA[NUM_FREQ_PILOTS][2] = {
	{18, 205},
	{54, 836},
	{72, 215}
};

const int iTableFreqPilRobModB[NUM_FREQ_PILOTS][2] = {
	{16, 331},
	{48, 651},
	{64, 555}
};

const int iTableFreqPilRobModC[NUM_FREQ_PILOTS][2] = {
	{11, 214},
	{33, 392},
	{44, 242}
};

const int iTableFreqPilRobModD[NUM_FREQ_PILOTS][2] = {
	{7,	788},
	{21, 1014},
	{28, 332}
};


/* Time pilots ****************************************************************/
/* The two numbers are: {carrier no, phase} (Phases are normalized to 1024) */
#define RMA_NUM_TIME_PIL	21
const int iTableTimePilRobModA[RMA_NUM_TIME_PIL][2] = {
	{17, 973},
	{18, 205},
	{19, 717},
	{21, 264},
	{28, 357},
	{29, 357},
	{32, 952},
	{33, 440},
	{39, 856},
	{40, 88},
	{41, 88},
	{53, 68},
	{54, 836},
	{55, 836},
	{56, 836},
	{60, 1008},
	{61, 1008},
	{63, 752},
	{71, 215},
	{72, 215},
	{73, 727}
};

#define RMB_NUM_TIME_PIL	19
const int iTableTimePilRobModB[RMB_NUM_TIME_PIL][2] = {
	{14, 304},
	{16, 331},
	{18, 108},
	{20, 620},
	{24, 192},
	{26, 704},
	{32, 44},
	{36, 432},
	{42, 588},
	{44, 844},
	{48, 651},
	{49, 651},
	{50, 651},
	{54, 460},
	{56, 460},
	{62, 944},
	{64, 555},
	{66, 940},
	{68, 428}
};

#define RMC_NUM_TIME_PIL	19
const int iTableTimePilRobModC[RMC_NUM_TIME_PIL][2] = {
	{8, 722},
	{10, 466},
	{11, 214},
	{12, 214},
	{14, 479},
	{16, 516},
	{18, 260},
	{22, 577},
	{24, 662},
	{28, 3},
	{30, 771},
	{32, 392},
	{33, 392},
	{36, 37},
	{38, 37},
	{42, 474},
	{44, 242},
	{45, 242},
	{46, 754}
};

#define RMD_NUM_TIME_PIL	21
const int iTableTimePilRobModD[RMD_NUM_TIME_PIL][2] = {
	{5, 636},
	{6, 124},
	{7, 788},
	{8, 788},
	{9, 200},
	{11, 688},
	{12, 152},
	{14, 920},
	{15, 920},
	{17, 644},
	{18, 388},
	{20, 652},
	{21, 1014},
	{23, 176},
	{24, 176},
	{26, 752},
	{27, 496},
	{28, 332},
	{29, 432},
	{30, 964},
	{32, 452}
};


/* Scattered pilots ***********************************************************/
/* Definitions for the positions of scattered pilots */
#define RMA_SCAT_PIL_FREQ_INT	4
#define RMA_SCAT_PIL_TIME_INT	5

#define RMB_SCAT_PIL_FREQ_INT	2
#define RMB_SCAT_PIL_TIME_INT	3

#define RMC_SCAT_PIL_FREQ_INT	2
#define RMC_SCAT_PIL_TIME_INT	2

#define RMD_SCAT_PIL_FREQ_INT	1
#define RMD_SCAT_PIL_TIME_INT	3

/* Phase definitions of scattered pilots ------------------------------------ */
const int iTableScatPilConstRobModA[3] = {4, 5, 2};

const int iTableScatPilConstRobModB[3] = {2, 3, 1};

const int iTableScatPilConstRobModC[3] = {2, 2, 1};

const int iTableScatPilConstRobModD[3] = {1, 3, 1};

#define SIZE_ROW_WZ_ROB_MOD_A	5
#define SIZE_COL_WZ_ROB_MOD_A	3
const int iScatPilWRobModA[SIZE_ROW_WZ_ROB_MOD_A][SIZE_COL_WZ_ROB_MOD_A] = {
	{228, 341, 455},
	{455, 569, 683},
	{683, 796, 910},
	{910,   0, 114},
	{114, 228, 341}
};
const int iScatPilZRobModA[SIZE_ROW_WZ_ROB_MOD_A][SIZE_COL_WZ_ROB_MOD_A] = {
	{0,    81, 248},
	{18,  106, 106},
	{122, 116,  31},
	{129, 129,  39},
	{33,   32, 111}
};
const int iScatPilQRobModA = 36;

#define SIZE_ROW_WZ_ROB_MOD_B	3
#define SIZE_COL_WZ_ROB_MOD_B	5
const int iScatPilWRobModB[SIZE_ROW_WZ_ROB_MOD_B][SIZE_COL_WZ_ROB_MOD_B] = {
	{512,   0, 512,   0, 512},
	{0,   512,   0, 512,   0},
	{512,   0, 512,   0, 512}
};
const int iScatPilZRobModB[SIZE_ROW_WZ_ROB_MOD_B][SIZE_COL_WZ_ROB_MOD_B] = {
	{0,    57, 164,  64,  12},
	{168, 255, 161, 106, 118},
	{25,  232, 132, 233,  38}
};
const int iScatPilQRobModB = 12;

#define SIZE_ROW_WZ_ROB_MOD_C	2
#define SIZE_COL_WZ_ROB_MOD_C	10
const int iScatPilWRobModC[SIZE_ROW_WZ_ROB_MOD_C][SIZE_COL_WZ_ROB_MOD_C] = {
	{465, 372, 279, 186,  93,   0, 931, 838, 745, 652},
	{931, 838, 745, 652, 559, 465, 372, 279, 186,  93}
};
const int iScatPilZRobModC[SIZE_ROW_WZ_ROB_MOD_C][SIZE_COL_WZ_ROB_MOD_C] = {
	{0,    76, 29,  76,   9, 190, 161, 248,  33, 108},
	{179, 178, 83, 253, 127, 105, 101, 198, 250, 145}
};
const int iScatPilQRobModC = 12;

#define SIZE_ROW_WZ_ROB_MOD_D	3
#define SIZE_COL_WZ_ROB_MOD_D	8
const int iScatPilWRobModD[SIZE_ROW_WZ_ROB_MOD_D][SIZE_COL_WZ_ROB_MOD_D] = {
	{366, 439, 512, 585, 658, 731, 805, 878},
	{731, 805, 878, 951,   0,  73, 146, 219},
	{73,  146, 219, 293, 366, 439, 512, 585}
};
const int iScatPilZRobModD[SIZE_ROW_WZ_ROB_MOD_D][SIZE_COL_WZ_ROB_MOD_D] = {
	{0,   240,  17,  60, 220,  38, 151, 101},
	{110,   7,  78,  82, 175, 150, 106,  25},
	{165,   7, 252, 124, 253, 177, 197, 142}
};
const int iScatPilQRobModD = 14;

/* Gain definitions of scattered pilots ------------------------------------- */
#define NUM_BOOSTED_SCAT_PILOTS		4
const int iScatPilGainRobModA[6][NUM_BOOSTED_SCAT_PILOTS] = {
	{2, 6, 98, 102},
	{2, 6, 110, 114},
	{-102, -98, 98, 102},
	{-114, -110, 110, 114},
	{-98, -94, 310, 314},
	{-110, -106, 346, 350}
};

const int iScatPilGainRobModB[6][NUM_BOOSTED_SCAT_PILOTS] = {
	{1, 3, 89, 91},
	{1, 3, 101, 103},
	{-91, -89, 89, 91},
	{-103, -101, 101, 103},
	{-87, -85, 277, 279},
	{-99, -97, 309, 311}
};

const int iScatPilGainRobModC[6][NUM_BOOSTED_SCAT_PILOTS] = {
	{0, 0, 0, 0},
	{0, 0, 0, 0},
	{0, 0, 0, 0},
	{-69, -67, 67, 69},
	{0, 0, 0, 0},
	{-67, -65, 211, 213}
};

const int iScatPilGainRobModD[6][NUM_BOOSTED_SCAT_PILOTS] = {
	{0, 0, 0, 0},
	{0, 0, 0, 0},
	{0, 0, 0, 0},
	{-44, -43, 43, 44},
	{0, 0, 0, 0},
	{-43, -42, 134, 135}
};


/* Dummy cells for the MSC ****************************************************/
/* Already normalized */
const _COMPLEX cDummyCells64QAM[2] = {
	_COMPLEX(0.1543033499f,  0.1543033499f),
	_COMPLEX(0.1543033499f, -0.1543033499f)
};

const _COMPLEX cDummyCells16QAM[2] = {
	_COMPLEX(0.3162277660f,  0.3162277660f),
	_COMPLEX(0.3162277660f, -0.3162277660f)
};


/* Spectrum occupancy, carrier numbers for each mode **************************/
const int iTableCarrierKmin[6][4] = {
	{2, 1, 0, 0},
	{2, 1, 0, 0},
	{-102, -91, 0, 0},
	{-114, -103, -69, -44},
	{-98, -87, 0, 0},
	{-110, -99, -67, -43}
};

const int iTableCarrierKmax[6][4] = {
	{102, 91, 0, 0},
	{114, 103, 0, 0},
	{102, 91, 0, 0},
	{114, 103, 69, 44},
	{314, 279, 0, 0},
	{350, 311, 213, 135}
};


#endif // !defined(TABLE_CAR_MAP_H__3B0_CA63_4344_BB2B_23E7912__INCLUDED_)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -