/* * 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 */ /*!\file ldpc_encode_parity_check.c * \brief Parity check function used by ldpc encoders * \author Florian Kaltenberger, Raymond Knopp, Kien le Trung (Eurecom) * \email openair_tech@eurecom.fr * \date 27-03-2018 * \version 1.0 * \note * \warning */ #include <stdlib.h> #include <math.h> #include <stdio.h> #include <string.h> #include <types.h> #include "assertions.h" #include "common/utils/LOG/log.h" //#define DEBUG_LDPC #include "ldpc384_byte.c" #include "ldpc352_byte.c" #include "ldpc320_byte.c" #include "ldpc288_byte.c" #include "ldpc256_byte.c" #include "ldpc240_byte.c" #include "ldpc224_byte.c" #include "ldpc208_byte.c" #include "ldpc192_byte.c" #include "ldpc176_byte.c" #include "ldpc_BG2_Zc384_byte.c" #include "ldpc_BG2_Zc352_byte.c" #include "ldpc_BG2_Zc320_byte.c" #include "ldpc_BG2_Zc288_byte.c" #include "ldpc_BG2_Zc256_byte.c" #include "ldpc_BG2_Zc240_byte.c" #include "ldpc_BG2_Zc224_byte.c" #include "ldpc_BG2_Zc208_byte.c" #include "ldpc_BG2_Zc192_byte.c" #include "ldpc_BG2_Zc176_byte.c" #include "ldpc_BG2_Zc160_byte.c" #include "ldpc_BG2_Zc144_byte.c" #include "ldpc_BG2_Zc128_byte.c" #include "ldpc_BG2_Zc120_byte.c" #include "ldpc_BG2_Zc112_byte.c" #include "ldpc_BG2_Zc104_byte.c" #include "ldpc_BG2_Zc96_byte.c" #include "ldpc_BG2_Zc88_byte.c" #include "ldpc_BG2_Zc80_byte.c" #include "ldpc_BG2_Zc72_byte.c" static inline void encode_parity_check_part_optim(uint8_t *c,uint8_t *d, short BG,short Zc,short Kb) { if (BG==1) { switch (Zc) { case 2: break; case 3: break; case 4: break; case 5: break; case 6: break; case 7: break; case 8: break; case 9: break; case 10: break; case 11: break; case 12: break; case 13: break; case 14: break; case 15: break; case 16: break; case 18: break; case 20: break; case 22: break; case 24: break; case 26: break; case 28: break; case 30: break; case 32: break; case 36: break; case 40: break; case 44: break; case 48: break; case 52: break; case 56: break; case 60: break; case 64: break; case 72: break; case 80: break; case 88: break; case 96: break; case 104: break; case 112: break; case 120: break; case 128: break; case 144: break; case 160: break; case 176: ldpc176_byte(c,d); break; case 192: ldpc192_byte(c,d); break; case 208: ldpc208_byte(c,d); break; case 224: ldpc224_byte(c,d); break; case 240: ldpc240_byte(c,d); break; case 256: ldpc256_byte(c,d); break; case 288: ldpc288_byte(c,d); break; case 320: ldpc320_byte(c,d); break; case 352: ldpc352_byte(c,d); break; case 384: ldpc384_byte(c,d); break; default: AssertFatal(0,"BG %d Zc %d is not supported yet\n",BG,Zc); break; } } else if (BG==2) { switch (Zc) { case 2: break; case 3: break; case 4: break; case 5: break; case 6: break; case 7: break; case 8: break; case 9: break; case 10: break; case 11: break; case 12: break; case 13: break; case 14: break; case 15: break; case 16: break; case 18: break; case 20: break; case 22: break; case 24: break; case 26: break; case 28: break; case 30: break; case 32: break; case 36: break; case 40: break; case 44: break; case 48: break; case 52: break; case 56: break; case 60: break; case 64: break; case 72: ldpc_BG2_Zc72_byte(c,d); break; case 80: ldpc_BG2_Zc80_byte(c,d); break; case 88: ldpc_BG2_Zc88_byte(c,d); break; case 96: ldpc_BG2_Zc96_byte(c,d); break; case 104: ldpc_BG2_Zc104_byte(c,d); break; case 112: ldpc_BG2_Zc112_byte(c,d); break; case 120: ldpc_BG2_Zc120_byte(c,d); break; case 128: ldpc_BG2_Zc128_byte(c,d); break; case 144: ldpc_BG2_Zc144_byte(c,d); break; case 160: ldpc_BG2_Zc160_byte(c,d); break; case 176: ldpc_BG2_Zc176_byte(c,d); break; case 192: ldpc_BG2_Zc192_byte(c,d); break; case 208: ldpc_BG2_Zc208_byte(c,d); break; case 224: ldpc_BG2_Zc224_byte(c,d); break; case 240: ldpc_BG2_Zc240_byte(c,d); break; case 256: ldpc_BG2_Zc256_byte(c,d); break; case 288: ldpc_BG2_Zc288_byte(c,d); break; case 320: ldpc_BG2_Zc320_byte(c,d); break; case 352: ldpc_BG2_Zc352_byte(c,d); break; case 384: ldpc_BG2_Zc384_byte(c,d); break; default: AssertFatal(0,"BG %d Zc %d is not supported yet\n",BG,Zc); break; } } else { AssertFatal(0,"BG %d is not supported yet\n",BG); } }