stringtranslate.com

Código polar (teoría de la codificación)

En teoría de la información , los códigos polares son códigos de corrección de errores de bloques lineales . La construcción del código se basa en una concatenación recursiva múltiple de un código de núcleo corto que transforma el canal físico en canales externos virtuales. Cuando el número de recursiones se vuelve grande, los canales virtuales tienden a tener alta o baja confiabilidad (en otras palabras, se polarizan o se vuelven dispersos), y los bits de datos se asignan a los canales más confiables. Es el primer código con una construcción explícita que logra de manera demostrable la capacidad de canal para canales discretos, sin memoria y con entrada binaria simétrica (B-DMC) con dependencia polinómica de la brecha de capacidad. [1] Los códigos polares fueron desarrollados por Erdal Arikan , profesor de ingeniería eléctrica en la Universidad de Bilkent .

Cabe destacar que los códigos polares tienen una complejidad de codificación y decodificación modesta O ( n log n ) , lo que los hace atractivos para muchas aplicaciones. Además, la complejidad energética de codificación y decodificación de los códigos polares generalizados puede alcanzar los límites inferiores fundamentales para el consumo de energía de circuitos bidimensionales dentro de un factor O ( n ε polylog n ) para cualquier ε > 0 . [2]

Aplicaciones industriales

Los códigos polares tienen algunas limitaciones cuando se utilizan en aplicaciones industriales. Principalmente, el diseño original de los códigos polares logra capacidad cuando los tamaños de bloque son asintóticamente grandes con un decodificador de cancelación sucesiva. Sin embargo, con los tamaños de bloque utilizados en la industria, el rendimiento de la cancelación sucesiva es deficiente en comparación con esquemas de codificación bien definidos e implementados, como el código de verificación de paridad de baja densidad (LDPC) y el código turbo . El rendimiento polar se puede mejorar con la decodificación de listas de cancelación sucesiva, pero su usabilidad en aplicaciones reales aún es cuestionable debido a las eficiencias de implementación muy deficientes causadas por el enfoque iterativo. [3]

En octubre de 2016, Huawei anunció que había alcanzado los 27 Gbit/s en pruebas de campo de 5G utilizando códigos polares para la codificación de canales. Las mejoras se han introducido de modo que el rendimiento del canal ahora casi ha cerrado la brecha con el límite de Shannon , que establece el estándar para la velocidad máxima para un ancho de banda determinado y un nivel de ruido determinado. [4]

En noviembre de 2016, el 3GPP acordó adoptar códigos polares para los canales de control eMBB (banda ancha móvil mejorada) para la interfaz 5G NR (nueva radio). En la misma reunión, el 3GPP acordó utilizar LDPC para el canal de datos correspondiente. [5] [6]

Códigos PAC

En 2019, Arıkan sugirió emplear una pretransformación convolucional antes de la codificación polar. Estas variantes pretransformadas de códigos polares se denominaron códigos convolucionales ajustados por polarización (PAC). [7] Se demostró que la pretransformación puede mejorar eficazmente las propiedades de distancia de los códigos polares al reducir la cantidad de palabras de código de peso mínimo y, en general, de peso pequeño, [8] lo que da como resultado la mejora de las tasas de error de bloque bajo un algoritmo de decodificación de máxima verosimilitud (ML) cercano, como la decodificación Fano y la decodificación de lista. [9] La decodificación Fano es un algoritmo de búsqueda de árbol que determina la palabra de código transmitida utilizando una función métrica óptima para guiar de manera eficiente el proceso de búsqueda. [10] Los códigos PAC también son equivalentes a los códigos polares postransformados con ciertos códigos cíclicos. [11] En longitudes de bloque cortas, dichos códigos superan tanto a los códigos convolucionales como a la decodificación de lista asistida por CRC de códigos polares convencionales. [12] [13]

Decodificadores polares neuronales

Los decodificadores polares neuronales (NPD) [14] son ​​un avance en la codificación de canales que combina redes neuronales (NN) con códigos polares, lo que proporciona una decodificación unificada para canales con o sin memoria, sin requerir un modelo de canal explícito. Utilizan cuatro redes neuronales para aproximar las funciones de la decodificación polar: la NN de incrustación (E), la NN de nodo de verificación (F), la NN de nodo de bit (G) y la NN de incrustación a LLR (H). Los pesos de estas NN se determinan estimando la información mutua de los canales sintéticos. Al final del entrenamiento, los pesos de los NPD son fijos y luego se pueden usar para la decodificación.

La complejidad computacional de los NPD está determinada por la parametrización de las redes neuronales, a diferencia de los decodificadores de enrejado de cancelación sucesiva (SC), [15] cuya complejidad está determinada por el modelo de canal y se utilizan típicamente para canales de estados finitos (FSC). La complejidad computacional de los NPD es , donde es el número de unidades ocultas en las redes neuronales, es la dimensión de la incrustación y es la longitud del bloque. Por el contrario, la complejidad computacional de los decodificadores de enrejado SC es , donde es el espacio de estados del modelo de canal.

Los NPD se pueden integrar en esquemas de decodificación SC [1] como la decodificación de lista SC y la decodificación SC asistida por CRC. [16] También son compatibles con distribuciones de entrada no uniformes e iid al integrarlas en el esquema Honda-Yamamoto. [17] Esta flexibilidad permite que los NPD se utilicen en varios escenarios de decodificación, mejorando el rendimiento de corrección de errores y manteniendo una complejidad computacional manejable.

Referencias

  1. ^ ab Arikan, Erdal (2009). "Polarización de canal: un método para construir códigos que logren capacidad para canales sin memoria de entrada binaria simétricos". IEEE Transactions on Information Theory . 55 (7): 3051–3073. arXiv : 0807.3917 . doi :10.1109/TIT.2009.2021379. ISSN  0018-9448.
  2. ^ Blake, Christopher G. (2017). "Consumo de energía de circuitos de codificación de control de errores" (PDF) . Universidad de Toronto . Consultado el 18 de octubre de 2019 .
  3. ^ Arikan, Erdal; Najeeb ul Hassan; Lentmaier, Michael; Montorsi, Guido; Sayir, Jossy (2015). "Desafíos y algunas direcciones nuevas en la codificación de canales". arXiv : 1504.03916 [cs.IT].
  4. ^ "Huawei alcanza velocidades 5G de 27 Gbps con Polar Code" . Consultado el 10 de octubre de 2016 .
  5. ^ "Informe final de la reunión 3GPP RAN1 nº 87". 3GPP . Consultado el 31 de agosto de 2017 .[ enlace muerto ]
  6. ^ M. Rowshan, M. Qiu, Y. Xie, X. Gu y J. Yuan, "Codificación de canales hacia 6G: descripción técnica general y perspectivas", en IEEE Open Journal of the Communications Society , vol. 5, págs. 2585-2685, 2024, doi: 10.1109/OJCOMS.2024.3390000.
  7. ^ E. Arıkan, "De la decodificación secuencial a la polarización de canales y viceversa", 2019, arXiv:1908.09594
  8. ^ M. Rowshan y J. Yuan, "Sobre las palabras clave de peso mínimo de los códigos PAC: el impacto de la pretransformación", en IEEE Journal on Selected Areas in Information Theory , vol. 4, págs. 487-498, 2023, doi: 10.1109/JSAIT.2023.3312678.
  9. ^ M. Rowshan, A. Burg y E. Viterbo, "Códigos convolucionales ajustados por polarización (PAC): decodificación secuencial frente a decodificación de listas", en IEEE Transactions on Vehicular Technology , vol. 70, n.º 2, págs. 1434-1447, febrero de 2021, doi: 10.1109/TVT.2021.3052550.
  10. ^ M. Moradi, "Sobre la función métrica de decodificación secuencial de códigos convolucionales ajustados por polarización (PAC)", IEEE Transactions on Communications, vol. 69, n.º 12, págs. 7913-7922, 2021, doi: 10.1109/TCOMM.2021.3111018.
  11. ^ M. Moradi, "Códigos convolucionales ajustados a la polarización (PAC) como una concatenación de códigos cíclicos internos y códigos externos polares y similares a Reed-Muller", Finite Fields and Their Applications, vol. 93, pág. 102321, 2024, doi: https://doi.org/10.1016/j.ffa.2023.102321.
  12. ^ Moradi, Mohsen; Mozammel, Amir; Qin, Kangjian; Arikan, Erdal (2020). "Rendimiento y complejidad de la decodificación secuencial de códigos PAC". arXiv : 2012.04990 [cs.IT].
  13. ^ Yao, Hanwen; Fazeli, Arman; Vardy, Alexander (2021). "Descodificación de listas de los códigos PAC de Arıkan". Entropía . 23 (7): 841. arXiv : 2005.13711 . Bibcode :2021Entrp..23..841Y. doi : 10.3390/e23070841 . PMC 8303677 . PMID  34209050. 
  14. ^ Aharoni, Ziv; Huleihel, Bashar; Pfister, Henry D.; Permuter, Haim H. (6 de septiembre de 2023). "Códigos polares neuronales basados ​​en datos para canales desconocidos con y sin memoria". arXiv : 2309.03148 [cs.IT].
  15. ^ Wang, Runxin; Honda, Junya; Yamamoto, Hirosuke; Liu, Rongke; Hou, Yi (2015). "Construcción de códigos polares para canales con memoria". Taller de teoría de la información del IEEE de 2015 - Otoño (ITW) . IEEE. págs. 187–191. doi :10.1109/ITWF.2015.7360760. ISBN . 978-1-4673-7852-9.
  16. ^ Tal, Ido; Vardy, Alexander (2015). "Descodificación de listas de códigos polares". IEEE Transactions on Information Theory . 61 (5): 2213–2226. arXiv : 1206.0050 . doi :10.1109/TIT.2015.2410251. ISSN  0018-9448.
  17. ^ Honda, Junya; Yamamoto, Hirosuke (2013). "Codificación polar sin extensión del alfabeto para modelos asimétricos". IEEE Transactions on Information Theory . 59 (12): 7829–7838. doi :10.1109/TIT.2013.2282305. ISSN  0018-9448.

Enlaces externos