Procesador de señales digitales

Procesador de señal digital ( ing.  procesador de señal digital , DSP , procesador de señal digital (DSP) - un microprocesador especializado diseñado para procesar señales digitalizadas (generalmente en tiempo real ) [1] .

Características arquitectónicas

La arquitectura de los procesadores de señales, en comparación con los microprocesadores de propósito general, tiene algunas características asociadas con el deseo de acelerar al máximo la ejecución de las tareas típicas del procesamiento de señales digitales, como el filtrado digital , la transformada de Fourier , la búsqueda de señales , etc. Matemáticamente, estas tareas se reducen a elementos de multiplicación por elementos de vectores multicomponente de números reales, seguidos de la suma de los productos (por ejemplo, en el filtrado digital, la señal de salida de un filtro con una respuesta de impulso finita es igual a la suma de los productos de los coeficientes de filtro por el vector de muestras de señal, se realizan cálculos similares cuando se buscan los máximos de las funciones de correlación y autocorrelación de muestras de señal). Por lo tanto, los procesadores de señales están optimizados para la velocidad para realizar tales operaciones. Y los DSP están orientados, en primer lugar, a la ejecución repetida de multiplicaciones con el cálculo "sobre la marcha" de las direcciones de los elementos del array a multiplicar:

Los recursos de hardware limitados de los primeros DSP dejaron una huella significativa en su arquitectura:

En la microelectrónica moderna, los procesadores de propósito general a menudo contienen soporte de hardware para las operaciones típicas de DSP. Las tareas de DSP que consumen mucho tiempo se resuelven sobre la base de lógica programable , donde es posible lograr la máxima optimización de la ejecución de una operación particular. Los procesadores DSP especializados se están haciendo cada vez más vectoriales . Al mismo tiempo, los DSP clásicos brindan conjuntos de instrucciones avanzadas para procesadores de uso general y suavizan las características del modelo de software, posicionándolos como productos de uso general con funciones DSP aceleradas. Todas estas tendencias conducen a la difuminación del concepto clásico de DSP.

Aplicaciones

Historia

Desarrollos anteriores

Antes de 1980, varias empresas produjeron dispositivos que pueden considerarse los precursores de los DSP. Entonces, en 1978, Intel lanzó el "procesador de señal analógica" 2120. Incluía un ADC , un DAC y un procesador de datos digital, pero no había una función de multiplicación de hardware. En 1979 , AMI lanza el S2811, un dispositivo periférico controlado por el procesador principal de la computadora. Ambos productos no tuvieron éxito en el mercado.

Primera generación (principios de los 80)

La historia principal de los DSP generalmente se cuenta entre 1979 y 1980, cuando Bell Labs presentó el primer DSP de un solo chip Mac 4, y también se mostraron el µMPD7720 de NEC y el DSP1 de AT&T en la Conferencia Internacional de Circuitos de Estado Sólido IEEE '80 , que, sin embargo, no recibió una amplia difusión. El estándar de facto fue el cristal Texas Instruments TMS32010 lanzado un poco más tarde , que supera los productos de la competencia en muchos parámetros y soluciones técnicas exitosas. Estas son algunas de sus características:

Segunda generación (mediados de los 80)

Debido a los avances en la tecnología de semiconductores durante este período, se lanzaron productos que tenían características mejoradas en comparación con la primera generación. Las diferencias características incluyen:

Mucho más tarde, también se lanzaron dispositivos pertenecientes formalmente a la segunda generación, pero con las siguientes mejoras:

Tercera generación (finales de la década de 1980)

La tercera generación de DSP generalmente se asocia con el inicio de la producción de productos que implementan aritmética de punto flotante. Rasgos característicos de las primeras muestras lanzadas:

Cuarta generación

La cuarta generación de DSP se caracteriza por una importante expansión de los conjuntos de instrucciones, la creación de VLIW y procesadores superescalares . Las frecuencias de reloj han aumentado notablemente. Así, por ejemplo, el tiempo de ejecución de la instrucción MAC ( Y := X + A × B ) se redujo a 3 ns.

DSP modernos

Los mejores DSP modernos se pueden caracterizar por los siguientes parámetros:

Parámetros DSP básicos

Las características integrales del DSP también se utilizan a menudo, por ejemplo, el indicador de "potencia / corriente / velocidad", por ejemplo, ma / MIPS (miliamperios por 1 millón de instrucciones por segundo), que permite estimar el consumo de energía real dependiendo de la complejidad de la tarea que está resolviendo el procesador en un momento específico.

La elección de DSP está completamente determinada por el propósito del sistema que se está desarrollando. Por ejemplo, los procesadores baratos y el bajo consumo de energía son importantes para los dispositivos móviles masivos, mientras que el costo de desarrollar un sistema se desvanece en un segundo plano. Por otro lado, para los equipos de medición, son importantes los sistemas de procesamiento de información de audio y video, la eficiencia del procesador, la disponibilidad de herramientas avanzadas, el multiprocesamiento , etc.

Evaluación y comparación de desempeño

Como se señaló anteriormente, las características individuales como la frecuencia de reloj, MIPS, MOPS, MFLOPS permiten evaluar el rendimiento de un DSP de manera bastante ambigua. Por lo tanto, para resolver el problema de medir y comparar las características de diferentes DSP, se utilizan conjuntos especiales de pruebas que imitan algunas tareas comunes de procesamiento de señales digitales. Cada prueba consta de varios programas pequeños que están escritos en ensamblador y optimizados para una arquitectura determinada. Estas pruebas pueden incluir la implementación de:

El paquete de prueba más autorizado en la actualidad es la prueba BTDImark2000 ( Resultados certificados de BDTI DSP Kernel Benchmarks™ (BDTImark2000™) ), que, además de estos algoritmos, también incluye una evaluación de la memoria utilizada por el algoritmo, el tiempo de desarrollo del sistema y otros parámetros

Dispositivo

Arquitectura de Harvard

Los procesadores de señales digitales se construyen sobre la base de los llamados. "Arquitectura de Harvard", cuya característica distintiva es que los programas y los datos se almacenan en diferentes dispositivos de memoria: memoria de programa y memoria de datos. A diferencia de la arquitectura von Neumann , donde el procesador necesita al menos tres ciclos de bus para obtener una instrucción y dos operandos, un DSP puede realizar accesos simultáneos tanto a la memoria de instrucciones como a la memoria de datos, y la instrucción anterior se puede recibir en dos ciclos de bus. En realidad, gracias a la consideración del sistema de comando y otras medidas, este tiempo se puede reducir a un ciclo. En dispositivos reales, la memoria de instrucciones puede almacenar no solo programas, sino también datos. En este caso, se dice que el DSP está construido de acuerdo con una arquitectura Harvard modificada.

La memoria de instrucciones y la memoria de datos generalmente se encuentran en el chip DSP. Debido al hecho de que esta memoria tiene un volumen relativamente pequeño, se hace necesario utilizar dispositivos de almacenamiento externos (en relación con el chip del procesador). Para tales dispositivos, no se utilizan buses de datos y comandos separados, ya que esto requeriría un aumento significativo en el número de pines de cristal externos, lo cual es costoso y poco práctico. Por lo tanto, la interacción del DSP con los dispositivos de almacenamiento externo ocurre en un conjunto de buses sin separación en comandos y datos. También se debe tener en cuenta que acceder a la memoria externa siempre toma mucho más tiempo que a la memoria interna, por lo que en aplicaciones que son críticas para el tiempo de ejecución, dichos accesos deben minimizarse.

Diagrama estructural

Pipeline ejecución de comandos

La tubería es un subproceso computacional que realiza una determinada microoperación en cada etapa , por lo que hay varios comandos en diferentes etapas de ejecución en la tubería en un momento dado. Esto mejora el rendimiento.

La presencia de varias tuberías implementa una arquitectura superescalar.

Con el procesamiento paralelo de comandos en diferentes canalizaciones, se logra el máximo efecto en el mismo tipo de comandos que no dependen unos de otros. Si el programa contiene comandos de diferentes tipos, se introducen ciclos de espera en la canalización.

Para optimizar la carga de los transportadores, se requiere lo siguiente:

Como resultado, los comandos no se ejecutan en el orden en que los escribió el programador.

Implementación de hardware de las funciones principales

Multiplicadores

Se utiliza un multiplicador de hardware para reducir el tiempo de ejecución de una de las principales operaciones DSP: la operación de multiplicación. En los procesadores de propósito general, esta operación se implementa en varios ciclos de cambio y adición y toma mucho tiempo, y en DSP, gracias a un multiplicador especializado, en un ciclo de instrucción.

Funcionalmente, los multiplicadores se dividen en dos tipos:

  • multiplicador sencillo. Realiza una operación de multiplicación de toda la palabra. El resultado tiene un ancho de palabra doble y se almacena en un registro de ancho doble o en dos registros regulares (o dos ubicaciones de memoria).
  • Multiplicador-sumador (MAC - Multiplicador / Acumulador). Realiza una operación de acumulación múltiple que se usa ampliamente en muchos algoritmos de procesamiento de señales digitales. Para obtener detalles sobre cómo usar este comando, consulte #Clasificación de los DSP por arquitectura .
Cambiadores

Un shifter es tanto un dispositivo que realiza una operación de cambio de datos como un registro que almacena el resultado del cambio [2] .

En cuanto a sus funciones, los cambiadores se dividen en:

  • Preshifters que realizan un turno antes del inicio de la operación o durante su ejecución;
  • Post- shifters que realizan un turno después de que se ha ejecutado la operación.

En ambos casos, la estructura del registro que almacena el resultado del desplazamiento es la misma que la estructura del acumulador .

Funciones de precambio
  • escalado preliminar. Se utiliza en comandos aritméticos complejos, por ejemplo, así como comandos de carga con un cambio de la forma ;
  • Shift antes de realizar operaciones lógicas complejas, por ejemplo, ;
  • Desplazamientos aritméticos, lógicos y cíclicos durante la ejecución de los comandos correspondientes.
Funciones de poscambio
  • Resultados de escala al guardar en la memoria. Al mismo tiempo, el contenido del acumulador (el resultado de la operación principal) permanece sin cambios;
  • Eliminación de bits de extensión de señal;
  • Normalización;
  • Selección del mismo pedido.
Dispositivos de generación de direcciones Hardware organización de ciclos

ALU

ALU es una unidad procesadora que, bajo el control de un decodificador de instrucciones, realiza transformaciones aritméticas y lógicas sobre los datos, que en este caso se denominan operandos. El ancho de bits de los operandos generalmente se denomina tamaño de la palabra de la máquina.

Registros

Batería

Un acumulador es un registro diseñado para almacenar los resultados de las operaciones. La arquitectura de muchos DSP tiene dos acumuladores, lo que permite acelerar la ejecución de operaciones que requieren almacenar resultados intermedios. Técnicamente, un acumulador puede constar de varios registros [2] :

  • EXT - registro de extensión;
  • MSP - registro alto de palabras;
  • LSP - registro bajo de palabras.

La presencia del registro EXT le permite aumentar la precisión del cálculo de los resultados intermedios, así como aumentar el rango de almacenamiento de valores que no conducen al desbordamiento. Cuando un valor acumulador se almacena en una celda de memoria o en un registro regular, su valor se redondea al ancho estándar de esa celda o registro. Por otro lado, si es necesario, el contenido del registro EXT se puede almacenar por separado.

Métodos de direccionamiento

El procesador admite el direccionamiento directo, el direccionamiento indirecto previo y posterior al incremento y los modos de direccionamiento de inversión de bit de dirección y direccionamiento cíclico específicos de DSP.

Clasificación de DSPs por arquitectura

Cabe señalar que la clasificación dada a continuación [2] es bastante condicional, ya que la variedad de soluciones técnicas a menudo no permite atribuir sin ambigüedad cada dispositivo específico a uno de los tipos especificados. Por lo tanto, lo siguiente debería usarse más como material para comprender las características de la arquitectura DSP que para una clasificación real de cualquier producto.

Es conveniente considerar las características de la arquitectura DSP en el ejemplo de un algoritmo específico de procesamiento de datos digitales, por ejemplo, un filtro FIR , cuya señal de salida se puede escribir como:

, dónde

  •  — lecturas de la señal de entrada;
  •  son los coeficientes del filtro.

Como puede ver fácilmente, calcular el resultado es un ejemplo clásico del uso de la operación de multiplicación-acumulación - MAC (Y := X + A × B) .

DSP estándar

La figura muestra dos opciones para ejecutar una instrucción MAC en un DSP estándar. En la primera variante, ambos operandos se almacenan en la memoria de datos, por lo que se necesitan dos ciclos para recuperarlos, es decir, el tiempo de ejecución de n sumas es 2n . En el segundo caso, uno de los operandos se almacena en la memoria del programa, por lo que la instrucción se ejecuta en un ciclo, y el tiempo total de ejecución del ciclo será igual a n ciclos (cabe aclarar que en realidad, para la ejecución en un ciclo, el MAC debe ejecutarse dentro de una instrucción de bucle especial para evitar recuperar el código de instrucción en sí, lo que requiere un ciclo de reloj adicional). Se puede ver aquí que la implementación eficiente del algoritmo requiere el uso de memoria de programa para almacenar datos.

Una de las opciones que le permite abandonar el uso de la memoria del programa para el almacenamiento de datos es el uso de los llamados. "memoria de doble puerto", es decir, memoria que tiene dos conjuntos de buses de entrada: dos buses de dirección y de datos. Esta arquitectura permite el acceso simultáneo a dos direcciones (sin embargo, deben estar en diferentes bloques direccionables). Esta solución se utiliza en DSP de Motorola (DSP56000) y Lucent (DSP1600).

Con esta arquitectura, la única forma de mejorar el rendimiento es aumentar la frecuencia del reloj.

DSP estándar mejorados

Los "DSP estándar mejorados" utilizan las siguientes técnicas de mejora del paralelismo para mejorar el rendimiento del sistema en comparación con los DSP estándar:

  • Aumentar el número de dispositivos operativos y de cómputo;
  • Introducción de coprocesadores especializados;
  • Expansión de bus para aumentar la cantidad de datos transferidos;
  • Uso de memoria con acceso múltiple (varios accesos por ciclo);
  • Complicación del sistema de mando;

Muchos de estos métodos han existido desde los primeros procesadores, por lo que a menudo es imposible clasificarlos inequívocamente como "estándar" o "mejorado".

La figura muestra un ejemplo de la implementación del cálculo de dos comandos MAC paralelos. Para ello, el DSP contiene dos módulos MAC y dos baterías. Los bloques MAC reciben datos en tres buses al mismo tiempo, y uno de los valores es común para ellos. Por lo tanto, dos comandos se ejecutan simultáneamente:

  • AK1 := AK1 + D1 × D2
  • AK2 := AK2 + D1 × D3

La peculiaridad de la solución mostrada es que muchos algoritmos DSP pueden reducirse a la ejecución de dos comandos paralelos con un factor común, por ejemplo:

  • Filtro FIR con coeficientes simétricos. Los coeficientes de filtro se utilizan como factores idénticos, y dos conjuntos diferentes de muestras de señal se alimentan a buses separados, es decir, dos mitades del filtro se calculan en paralelo, que luego se suman.
  • Procesamiento de doble canal. Las muestras de señal se alimentan al bus común y los conjuntos de coeficientes se alimentan a buses separados.

Algunos procesadores (Lucent DSP16xxx, ADI ADSP-2116x) utilizan dos núcleos idénticos, cada uno con su propia memoria, es decir, una instrucción se ejecuta simultáneamente en dos núcleos con datos diferentes. Esto elude la restricción sobre el uso de datos completamente independientes.

Una desventaja característica de tales procesadores puede considerarse la necesidad de un desarrollador altamente calificado, ya que el uso efectivo de estas características requiere programación en lenguaje ensamblador, un buen conocimiento de la arquitectura y el sistema de comando, es decir, estos dispositivos se consideran "antipáticos". a lenguajes de alto nivel.

DSP con arquitectura VLIW

La principal diferencia entre los procesadores VLIW es que los códigos de instrucción se ensamblan en grandes "superinstrucciones" en la etapa de compilación y se ejecutan en paralelo. Por lo general, estos procesadores utilizan una arquitectura RISC con una longitud de instrucción fija, donde cada uno de ellos se ejecuta en una unidad operativa separada. Los rasgos característicos de tales procesadores incluyen:

  • Un gran conjunto de módulos operativos que funcionan independientemente unos de otros. Estos módulos pueden incluir:
    • Aritmética:
      • módulos de operaciones aritméticas y operaciones de comparación;
      • módulos de operaciones lógicas;
      • módulos para multiplicar números con coma flotante y fija;
      • módulos de generación constante.
    • Módulos de generación de direcciones, incluidos los de búfer lineales y cíclicos;
  • La necesidad de optimizar el compilador para cada modelo de procesador, ya que la composición y funciones de las unidades de cómputo pueden cambiar entre modelos, lo que implica un cambio en la lista de comandos que se pueden ejecutar simultáneamente;
  • La necesidad de buses de datos ultra anchos (alrededor de 128 bits) para que el código de operación, que consta de comandos individuales (hasta 8), se pueda obtener de la memoria en una sola llamada.
  • Altos requisitos para la cantidad de memoria del programa, que también se asocia con una gran duración de la operación.

Por lo general, si el procesador tiene varios módulos idénticos, al crear un programa en ensamblador, es posible especificar solo el tipo del módulo operativo requerido, y el compilador asignará el dispositivo específico. Por un lado, esto simplifica la programación de dichos dispositivos y, por otro lado, permite utilizar sus recursos de manera bastante eficiente.

DSP superescalares

Los procesadores superescalares también se caracterizan por un gran conjunto de unidades operativas paralelas y la capacidad de ejecutar múltiples instrucciones simultáneamente. Sin embargo, en comparación con VLIW, tienen dos características destacadas:

  • Las instrucciones del procesador no se agrupan en bloques, cada una de ellas ingresa al procesador de forma independiente;
  • Las instrucciones para la ejecución en paralelo se agrupan dentro del procesador según la composición y la carga de trabajo actual de los bloques operativos, así como la relación entre los datos.

Usando el enfoque descrito, puede sortear las siguientes desventajas de VLIW:

  • Uso de memoria ineficiente debido a la gran duración de la operación del grupo;
  • La dependencia del código compilado de la composición de los módulos operativos de un procesador en particular.

El precio de resolver estos problemas es una complicación significativa del circuito del procesador, en el que aparece un módulo para programar la ejecución de instrucciones.

Los procesadores superescalares planifican la ejecución de instrucciones no solo en función de la información sobre la carga de trabajo de los bloques operativos, sino también en función del análisis de dependencias entre datos. Por ejemplo, una instrucción para guardar el resultado de una operación aritmética no se puede ejecutar antes de la operación de cálculo en sí, incluso si el módulo de acceso a la memoria está actualmente libre. Esta característica conduce, entre otras cosas, al hecho de que el mismo conjunto de instrucciones se puede ejecutar de manera diferente en diferentes lugares del programa, lo que hace que sea imposible evaluar con precisión el rendimiento. Esto es especialmente importante para los sistemas que se ejecutan en tiempo real, ya que la peor calificación de resultados conducirá al hecho de que los recursos del procesador no se utilizarán por completo. Por lo tanto, en estos sistemas, el problema de estimar con precisión el rendimiento de los DSP superescalares permanece abierto.

DSP híbridos

Los DSP híbridos generalmente se entienden como dispositivos especializados que combinan las funciones de un microcontrolador y un procesador de señal digital. Por lo general, estos productos están diseñados para realizar una función, por ejemplo, el control de motores eléctricos u otros objetos en tiempo real. Otra amplia área de su aplicación se ha convertido recientemente en telefonía móvil, donde anteriormente se usaban dos procesadores: uno convencional para controlar las funciones del dispositivo (pantalla, teclado) y el otro para procesar señales de voz (codificación, etc.).

Clasificación de DSP por propósito

En general, de acuerdo con el propósito del DSP se puede dividir en dos grupos:

  • DSP de propósito general;
  • DSP orientados a problemas.

La "orientación de problemas" generalmente no se refiere a comandos adicionales, sino a un conjunto de periféricos especializados incorporados. Por ejemplo, los DSP diseñados para controlar motores eléctricos pueden contener generadores de señales PWM en el chip , controladores LAN industriales, etc. Los procesadores utilizados para procesar señales de voz a menudo contienen unidades de manipulación de bits (BMU) y coprocesadores de corrección de errores. Las cámaras de fotos y vídeo digitales utilizan DSP con módulos de codificación/descodificación MPEG1, MPEG4, JPG, MP3, AAC, etc.

Programación DSP

Para la programación de DSP , generalmente se usa uno de dos lenguajes: ensamblador y C. Las características principales de los ensambladores DSP son las mismas que las de los lenguajes de microprocesadores convencionales y, en general, pueden describirse como:

  • El lenguaje ensamblador está orientado a máquina, es decir, cada familia de procesadores tiene un lenguaje que es diferente al lenguaje de otras familias;
  • Una instrucción en lenguaje ensamblador suele ser equivalente a una instrucción en lenguaje máquina;
  • Al programar en ensamblador, el programador tiene acceso a todos los recursos del procesador y del sistema, lo que permite utilizarlos de la manera más eficiente posible;
  • Se requiere que el programador tenga un buen conocimiento de la arquitectura de cada procesador específico con el que trabaja, es decir, la calificación requerida del personal debe ser suficientemente alta;
  • Crear y depurar programas en ensamblador es un proceso largo y laborioso, que también requiere una alta cualificación.

Por otro lado, al usar lenguajes de nivel medio y alto, en particular C, es posible simplificar y acelerar significativamente la creación de programas, pero los recursos del sistema se utilizarán de manera menos eficiente en comparación con un programa escrito completamente en ensamblador.

En realidad, se suele utilizar un enfoque que combina las ventajas tanto de los lenguajes de alto nivel como de la eficiencia de los programas ensambladores. Esto se expresa en el hecho de que las bibliotecas estándar generalmente se crean en ensamblador, así como las partes críticas del código en términos de tiempo de ejecución y tamaño de la memoria. Al mismo tiempo, se pueden crear módulos auxiliares en un lenguaje de alto nivel, acelerando y simplificando el desarrollo de un sistema de software en su conjunto.

Características de los ensambladores DSP

Las características interesantes de los ensambladores DSP incluyen las siguientes:

  • La presencia de dos formas de escribir muchos comandos - mnemónico y algebraico . La forma mnemotécnica es similar a escribir comandos para microprocesadores convencionales, por ejemplo, ADD dst, src . Otro, algebraico, se usa con menos frecuencia en ensambladores de microprocesadores estándar, mientras que en el lenguaje DSP el comando mencionado se puede escribir como dst = dst + src . Por lo general, los ensambladores de DSP entienden ambas formas de notación, pero, por ejemplo, los ensambladores de Analog Devices y Lucent Technologies usan solo notación algebraica.
  • Medios para organizar estructuras estándar, por ejemplo, instrucciones de hardware especiales para repetir una instrucción o bloque de código. Al mismo tiempo, a diferencia de los comandos de repetición de los procesadores convencionales, el DSP puede omitir el ciclo de obtención del código de la instrucción repetida, lo que reduce el tiempo de ejecución de cada repetición en al menos 1 ciclo de bus, que, con un ciclo de dos ciclos. instrucción, da una doble ganancia en el tiempo.

Compatibilidad dentro de las familias DSP

Por lo general, los DSP se producen en familias, y los productos dentro de las familias tienen lenguajes ensambladores similares o incluso compatibilidad a nivel de código de máquina. Además, dentro de una familia, se suelen utilizar los mismos conjuntos de bibliotecas de subrutinas. Al igual que con los microprocesadores convencionales, los modelos más antiguos de DSP a menudo pueden ejecutar el código de máquina de los modelos inferiores, o su ensamblador incluye todas las instrucciones de los modelos inferiores como un subconjunto de su propio conjunto de instrucciones.

Depuración de programas

Por lo general, la depuración de programas escritos para el DSP se realiza mediante herramientas especiales, incluidos simuladores y emuladores de software . También suelen incluir herramientas de creación de perfiles (que miden la velocidad de ejecución de bloques de código).

Notas

  1. Procesadores de señales digitales: un manual. Por debajo. edición A. G. Ostapenko, M., Radio y comunicación, 1994.
  2. 1 2 3 Solonina A. I., Ulakhovich D. A., Yakovlev L. A. Algoritmos y procesadores de procesamiento de señales digitales. - San Petersburgo. : BHV-Petersburg, 2001. - 464 p. — ISBN 5-94157-065-1 .

Literatura

  • Solonina AI, Ulakhovich DA, Yakovlev LA Algoritmos y procesadores de procesamiento de señales digitales. - San Petersburgo. : BHV-Petersburg, 2001. - 464 p. — ISBN 5-94157-065-1 .
  • Aplicación del procesamiento digital de señales \ Ed. E. Openheim - MUNDO, 1980.
  • Procesadores de señales digitales. Mundo PC, 5'93
  • Procesadores de señal digital Zilog y sus aplicaciones. CHIPNEWS, No. 2 (11) 1997
  • Markov. C. Procesadores de señales digitales. Libro 1. M.: Microarte, 1996