#### Tecnológico de Costa Rica

#### Escuela de Ingeniería Electrónica

Programa de Licenciatura en Ingeniería Electrónica



Desarrollo de un conjunto de flujos de trabajo para la implementación de software a bordo de computadoras de guía, navegación y control espacial

Informe de Trabajo Final de Graduación para optar por el título de Ingeniero en Electrónica con el grado académico de Licenciatura

David Duarte Sánchez

El documento Requisitos para la entrega de Trabajos Finales de Graduación a las bibliotecas del TEC indica que usted debe incluir la licencia de Creative Commons en la página siguiente de la portada.

Asegúrse entonces de elegir la licencia correcta, y ajustar el texto abajo a su selección.

Es necesario que descargue el ícono correcto en formato vectorial, y lo coloque en el directorio fig/.



Este trabajo titulado Desarrollo de un conjunto de flujos de trabajo para la implementación de software a bordo de computadoras de guía, navegación y control espacial por David Duarte Sánchez, se encuentra bajo la Licencia Creative Commons Atribución-ShareAlike 4.0 International.

Para ver una copia de esta Licencia, visite http://creativecommons.org/licenses/by-sa/4.0/.

 $\bigcirc$  2024

David Duarte Sánchez

Instituto Tecnológico de Costa Rica

Declaro que el presente documento de tesis ha sido realizado enteramente por mi persona, utilizando y aplicando literatura referente al tema e introduciendo conocimientos y resultados experimentales propios.

En los casos en que he utilizado bibliografía he procedido a indicar las fuentes mediante las respectivas citas bibliográficas. En consecuencia, asumo la responsabilidad total por el trabajo de tesis realizado y por el contenido del presente documento.

David Duarte Sánchez

Cartago, 25 de septiembre de 2024

Céd: 3-0507-0982

Instituto Tecnológico de Costa Rica Escuela de Ingeniería Electrónica Trabajo Final de Graduación Acta de Aprobación

Defensa de Trabajo Final de Graduación Requisito para optar por el título de Ingeniero en Electrónica Grado Académico de Licenciatura

El Tribunal Evaluador aprueba la defensa del trabajo final de graduación denominado Desarrollo de un conjunto de flujos de trabajo para la implementación de software a bordo de computadoras de guía, navegación y control espacial, realizado por el señor David Duarte Sánchez y, hace constar que cumple con las normas establecidas por la Escuela de Ingeniería Electrónica del Instituto Tecnológico de Costa Rica.

Miembros del Tribunal Evaluador

Dr. Alfonso Chaves Jiménez Ing. William Marín Moreno
Profesor Lector Profesor Lector

Dr. Johan Carvajal Godínez
Profesor Asesor

Instituto Tecnológico de Costa Rica Escuela de Ingeniería Electrónica Trabajo Final de Graduación Tribunal Evaluador Acta de Evaluación

Defensa del Trabajo Final de Graduación Requisito para optar por el título de Ingeniero en Electrónica Grado Académico de Licenciatura

Nombre del proyecto: Desarrollo de un conjunto de flujos de trabajo para la implementación de software a bordo de computadoras de guía, navegación

Carné: 2017239606

David Duarte Sánchez

y control espacial

Estudiante:

Los miembros de este Tribunal hacen constar que este trabajo final de graduación ha sido aprobado y cumple con las normas establecidas por la Escuela de Ingeniería Electrónica

del Instituto Tecnológico de Costa Rica y es merecedor de la siguiente calificación:

| Nota del Trabajo Final de                     | Graduación:                                  |
|-----------------------------------------------|----------------------------------------------|
| Miembros del Tr                               | ibunal Evaluador                             |
| Dr. Alfonso Chaves Jiménez<br>Profesor Lector | Ing. William Marín Moreno<br>Profesor Lector |
|                                               | rvajal Godínez<br>r Asesor                   |

Cartago, 25 de septiembre de 2024

### Resumen

El resumen es la síntesis de lo que aparece en el resto del documento. Tiene que ser lo suficientemente conciso y claro para que alguien que lo lea sepa qué esperar del resto del trabajo, y se motive para leerla completamente. Usualmente resume lo más relevante de la introducción y contiene la conclusión más importante del trabajo.

Es usual agregar palabras clave, que son los temas principales tratados en el documento. El resumen queda fuera de la numeración del resto de secciones.

Evite utilizar referencias bibliográficas, tablas, o figuras en el resumen.

Palabras clave: GNC, Sistemas, procesadores embebidos, marcos de trabajo, model to model transofrmation, codigo embebido

### Abstract

Same content as the Spanish version, just in English. Check this site for some help with the translation. For instance, the following is the automatic translation from a previous version of the "Resumen".

The abstract is the synthesis of what appears in the rest of the document. It has to be concise and clear enough so that someone reading it knows what to expect from the rest of the text, and is motivated to read it in full. It usually summarizes the most relevant parts of the introduction and contains the most important conclusion of the work.

It is usual to add keywords, which are the main topics covered in the document. The abstract is left out of the numbering of the rest of the sections.

Avoid using bibliographical references, tables, or figures in the abstract.

**Keywords:** word 1, word 2,



### Agradecimientos

El resultado de este trabajo no hubiese sido posible sin el apoyo de Thevenin, Norton, Einstein y mi querido amigo Ohm.

Usualmente se agradece aquí a la empresa o investigador que dio la oportunidad de realizar el trabajo final de graduación.

No debe confundir el agradecimiento con la dedicatoria. La dedicatoria es usualmente una sola línea, con la persona a quien se dedica el trabajo.

El agradecimiento es un texto más elaborado, de caracter personal, en donde se expresa la gratitud por la oportunidad, el apoyo brindado, la inspiración ofrecida, el acompañamiento moral, etc.

David Duarte Sánchez

Cartago, 25 de septiembre de 2024

# Índice general

| Ín | Índice de figuras |                                                                               |    |  |  |  |  |  |  |
|----|-------------------|-------------------------------------------------------------------------------|----|--|--|--|--|--|--|
| Ín | dice              | de tablas                                                                     | IV |  |  |  |  |  |  |
| Re | evisaı            | ·                                                                             | V  |  |  |  |  |  |  |
| 1. | Intr              | oducción                                                                      | 1  |  |  |  |  |  |  |
|    | 1.1.              | Proceso de diseño de los sistemas de Guía, Navegación y Control espacial .    | 1  |  |  |  |  |  |  |
|    |                   | 1.1.1. Requerimientos de los sistemas                                         | 1  |  |  |  |  |  |  |
|    | 1.2.              | Sistemas embebidos para los sistemas GNC                                      | 2  |  |  |  |  |  |  |
|    |                   | 1.2.1. Marco de Trabajo Yocto Project                                         | 2  |  |  |  |  |  |  |
|    | 1.3.              | Donde se ubica dentro del flujo de control                                    | 3  |  |  |  |  |  |  |
|    | 1.4.              | eq:hardware en el loop                                                        | 3  |  |  |  |  |  |  |
|    | 1.5.              | Objetivos y estructura del documento                                          | 3  |  |  |  |  |  |  |
| 2. | Mar               | co teórico                                                                    | 5  |  |  |  |  |  |  |
|    | 2.1.              | Estimación                                                                    | 5  |  |  |  |  |  |  |
|    | 2.2.              | Control                                                                       | 6  |  |  |  |  |  |  |
|    | 2.3.              | Procesadores embebidos                                                        | 6  |  |  |  |  |  |  |
|    |                   | 2.3.1. Cortex-A9                                                              | 6  |  |  |  |  |  |  |
|    |                   | 2.3.2. Tarjeta de desarrollo ZedBoard                                         | 7  |  |  |  |  |  |  |
|    | 2.4.              | Marcos de trabajo                                                             | 8  |  |  |  |  |  |  |
|    |                   | 2.4.1. YOCTO                                                                  | 8  |  |  |  |  |  |  |
|    | 2.5.              | Transformación de modelo a modelo                                             | 8  |  |  |  |  |  |  |
|    |                   | 2.5.1. MATLAB Embedded Coder                                                  | 9  |  |  |  |  |  |  |
|    | 2.6.              | Código embebido                                                               | 9  |  |  |  |  |  |  |
|    | 2.7.              | Contenedores                                                                  | 9  |  |  |  |  |  |  |
|    | 2.8.              | protocolos de comunicacion $\ldots \ldots \ldots \ldots \ldots \ldots \ldots$ | 10 |  |  |  |  |  |  |
|    |                   | 2.8.1. UART                                                                   | 10 |  |  |  |  |  |  |
|    |                   | 2.8.2. SSH                                                                    | 10 |  |  |  |  |  |  |
|    | 2.9.              | Revisión literaria                                                            | 10 |  |  |  |  |  |  |
|    |                   | 2.9.1. Desarrollo de sistemas de navegación                                   | 10 |  |  |  |  |  |  |
|    |                   | 2.9.2. Transformación de Lenguaje de Bloques a Código C                       | 10 |  |  |  |  |  |  |
|    | 2.10              | Avances region to an CNCs                                                     | 11 |  |  |  |  |  |  |

Índice general

|            |       | 2.10.1. | Programación de Sistemas GNC                                   | 12         |
|------------|-------|---------|----------------------------------------------------------------|------------|
| 3.         | Tarj  | jeta de | desarrollo                                                     | 13         |
|            | 3.1.  | Selecci | ón de la tarjeta de desarrollo                                 | 13         |
|            |       | 3.1.1.  | Requerimientos de la aplicación                                | 13         |
|            |       | 3.1.2.  | Tarjetas candidatas                                            | 14         |
|            |       | 3.1.3.  | Criterios de comparación                                       | 16         |
|            | 3.2.  | Matriz  | z de Pugh                                                      | 18         |
|            | 3.3.  | Platafo | orma seleccionada                                              | 18         |
|            |       | 3.3.1.  | Especificaciones principales                                   | 18         |
|            | 3.4.  | Reflexi | ión final                                                      | 20         |
| 4.         | Fluj  | jo de t | rabajo para la implementación de software para GNC embe-       | -          |
|            | bido  | )       |                                                                | <b>2</b> 1 |
|            | 4.1.  | Flujo d | de trabajo de la aplicación Model 2 Model Transformation       | 22         |
|            | 4.2.  | Selecci | ión del caso de estudio                                        | 22         |
|            |       | 4.2.1.  | Simulacion del caso de estudio en Matlab Simulink              | 23         |
|            |       | 4.2.2.  | Simulink coder                                                 | 24         |
|            |       | 4.2.3.  | Definicio de paramtetros                                       | 24         |
|            |       | 4.2.4.  | Contenedor para compilacion de los binarios                    | 25         |
|            |       | 4.2.5.  | Compilacion de los binarios                                    | 25         |
|            | 4.3.  | Flujo d | de Trabajo Herramienta desarrollada por mi persona             | 25         |
|            |       | 4.3.1.  | Sistema operativo para desarrollo                              |            |
|            |       | 4.3.2.  | Generacion de un contenedor                                    | 26         |
|            |       | 4.3.3.  | Yocto Project                                                  | 26         |
|            |       | 4.3.4.  | creacion de una capa de yocto                                  |            |
|            |       | 4.3.5.  | Caso de estudio                                                | 27         |
|            |       | 4.3.6.  | Integración del programa generado a la capa de Yocto           | 27         |
|            |       | 4.3.7.  | Generacion de la imagen minima                                 |            |
|            |       | 4.3.8.  | Implementacion de la imagen minima en la tarjeta de desarrollo |            |
|            |       | 4.0.0   | zedboard                                                       |            |
|            |       | 4.3.9.  | Conexion de la tarjeta de desarrollo con el computador host    |            |
|            |       |         | Ejecución del caso de estudio y resultados                     |            |
|            |       |         | Comparacion de resultados                                      |            |
|            | 4.4.  | Reflexi | ion final                                                      | 29         |
| <b>5</b> . | Solu  | ıción p | propuesta                                                      | 30         |
| 6.         | Con   | clusio  | nes                                                            | 31         |
| Bi         | bliog | grafía  |                                                                | 32         |
| Α.         | Den   | nostrac | ción del teorema de Nyquist                                    | 34         |
| Ín         | dice  | alfabét | tico                                                           | 35         |

## Índice de figuras

| 4.1. | Diagrama | general | del | flujo | de | trabajo | pro | puesto |  |  |  |  |  |  |  | 2 |  |
|------|----------|---------|-----|-------|----|---------|-----|--------|--|--|--|--|--|--|--|---|--|
|      |          |         |     |       |    |         |     |        |  |  |  |  |  |  |  |   |  |

## Índice de tablas

| 2.1. | Especificaciones generales de la tarjeta de desarrollo ZeadBoard             | 7  |
|------|------------------------------------------------------------------------------|----|
| 3.1. | Matriz de Pugh para seleccionar la tarjeta de desarrollo que mejor de adapte |    |
|      | a los requerimientos del proyecto                                            | 18 |

### Revisar

### Capítulo 1

### Introducción

### 1.1. Proceso de diseño de los sistemas de Guía, Navegación y Control espacial

La implementación de sistemas GNC en sistemas embebidos, conlleva una combinación de hardware y software especializado, por un lado, los microcontroladores son los encargados de gestionar los cálculos, mientras que los sensores proporcionan distintos tipos de datos por medio de las entradas. Por otro lado, los sistemas en tiempo real garantizan la respuesta en el momento requerido. Las aplicaciones de estos se pueden observar en drones, satélites y sondas espaciales [MathWorks2024 ss].

Como se mencionó anteriormente los sistemas GNC son fundamentales en las misiones espaciales, están encargados de determinar la trayectoria óptima para cumplir los objetivos de la misión, además de calcular la secuencia de maniobras necesarias, determinar la posición, velocidad y orientación, también se encargan de aplicar las acciones correctivas necesarias para mantener la trayectoria [hewing2023enhancing].

#### 1.1.1. Requerimientos de los sistemas

Los requerimientos de los sistemas GNC incluyen: precisión para determinar la posición y orientación del vehículo con gran exactitud, robustez para funcionar de manera confiable y tolerar fallos o perturbaciones generadas por el entorno, autonomía para poder operar sin depender de la intervención humana, flexibilidad para adaptarse a diferentes fases de la misión y un bajo consumo de potencia para minimizar el uso de los recursos limitados a bordo.

Para cumplir con los requerimientos mencionados anteriormente se debe definir con precisión los requerimientos del sistema, como la precisión necesaria para determinar la posición del vehículo, la robustez del sistema para resistir fallos, las restricciones energéticas y de recursos computacionales a bordo. Una vez solventados estos requerimientos el sistema

1 Introducción 2

se plantea bajo una arquitectura modular la cual divide el sistema en bloques independientes para las funciones de guía, navegación y control, facilitando el desarrollo, prueba y mantenimiento [AEM2017].

#### 1.2. Sistemas embebidos para los sistemas GNC

El uso de sistemas embebidos ha transformado la navegación y el control aeroespacial. Estos sistemas integran hardware y software, permitiendo el procesamiento de datos en tiempo real, fundamental para la navegación precisa y el control de vuelo. Los sistemas embebidos gestionan sensores que recopilan información sobre altitud, velocidad y posición, permitiendo a pilotos y sistemas automáticos tomar decisiones rápidas y fundamentadas. Esta capacidad de respuesta es esencial en entornos cambiantes, como la aviación o el lanzamiento de cohetes. [Castao2014EstimacinDP]

Además, los sistemas embebidos facilitan la integración de múltiples funciones en un solo dispositivo, reduciendo el peso y volumen de los equipos a bordo, un factor crucial en la industria aeroespacial. Por ejemplo, en los sistemas de control de vuelo, los microcontroladores y procesadores embebidos pueden gestionar desde la navegación hasta la comunicación y el monitoreo de sistemas críticos, todo desde una única unidad. Esta integración mejora la eficiencia del espacio y minimiza la posibilidad de fallos al reducir el número de componentes individuales que podrían fallar. [Culp1993GuidanceAC]

Finalmente, la implementación de sistemas embebidos ha permitido avances significativos en la automatización y la inteligencia artificial aeroespacial. Los algoritmos embebidos procesan datos de manera eficiente, permitiendo la navegación autónoma y el control de vehículos sin intervención humana, especialmente relevante en misiones espaciales con comunicación limitada. Los sistemas embebidos mejoran la seguridad y eficiencia de las operaciones aeroespaciales, abriendo nuevas posibilidades para la exploración y el desarrollo de tecnologías futuras en este campo. [Falcoz2023GuidanceN]

#### 1.2.1. Marco de Trabajo Yocto Project

Yocto Project es una iniciativa de código abierto que proporciona un conjunto de herramientas y recursos para crear sistemas operativos Linux personalizados, especialmente diseñados para dispositivos embebidos. Su objetivo principal es facilitar el desarrollo de software y la integración de componentes en una amplia variedad de hardware, permitiendo a los desarrolladores construir imágenes de sistema adaptadas a sus necesidades específicas. Utiliza BitBake, una herramienta que permite definir recetas para la construcción y empaquetado de software, lo que otorga gran flexibilidad y personalización. [salvador2014embedded]

Además, soporta múltiples arquitecturas de hardware, como ARM, x86, MIPS y PowerPC, lo que lo hace adecuado para diferentes dispositivos, desde microcontroladores

1 Introducción 3

hasta sistemas más complejos. Al fomentar la reutilización de componentes y contar con una comunidad activa que contribuye con mejoras y documentación, el Yocto Project se convierte en una solución ideal para el desarrollo de sistemas operativos en aplicaciones de IoT, electrónica de consumo y automatización industrial. [vaduva2015learning]

#### 1.3. Donde se ubica dentro del flujo de control

Diagrama profe Johan (ver en proxima reunion)

#### 1.4. Hardware en el loop

El Hardware en el loop es una técnica fundamental en el desarrollo de sistemas GNC, ya que, permite simular el comportamiento del hardware en tiempo real, facilitando para los desarrolladores la prueba y validación del software sin requerir el hardware físico, es esta forma permite probar de forma exhaustiva el software asegurando el funcionamiento del hardware simulado y permite la validación de todo el sistema antes de su implementación final. Esta implementación genera una mayor precisión en las pruebas, la posibilidad de validar la autonomía del sistema, además de reducir significativamente el tiempo y los costos de implementación y prueba del hardware. En resumen, es una técnica esencial en el desarrollo de sistemas GNC espaciales, permitiendo una validación integral y eficiente de estos complejos sistemas antes de su despliegue en misiones reales [mihalivc2022hardware] [montoya2020advanced].

#### 1.5. Objetivos y estructura del documento

El objetivo principal de este proyecto es desarrollar un conjunto de flujos de trabajo para la implementacion de software a bordo de computadoras de guia, navegacion y control espacial. Para lograr este objetivo se persiguen tres objetivos especificos. El primero consiste en Identificar una plataforma de hardware para el desarrollo de un modelo de ingenieria de una computadora de navegacion espacial.

El segundo se encarga de Establecer flujos de trabajo para el prototipado de algoritmos de control de orientacion y navegacion para aplicaciones espaciales con hardware en el loop. Y por ultimo el tecero consiste en Evaluar los casos de uso de una computadora de navegacion y control espacial mediante la implementacion de una aplicacion de referencia demostrativa (caso de la IMU)

Este documento incluye lo siguiente: en el capitulo 2 se presenta el marco teorico, donde se esbozan los fundamentos de la propuesta realizada. En el capitulo 3 se detalla la solucion propuesta y el modelo implementado para la solucion del problema. En el capitulo 4 se

1 Introducción 4

presentan los resultados obtenidos. Por ultimo, el capitulo 5 se presenta las conclusiones de la investigación y trabajo realizado, así como recomendaciones y trabajo a futuro por desarrollar.

### Capítulo 2

### Marco teórico

En este capítulo se presentan los conceptos teóricos que subyacen la propuesta de desarrollo de un conjunto de flujos de trabajo para la implementación de software a bordo de computadoras de guía, navegación y control espacial. La información expuesta se deriva tanto de conocimientos propios como información bibliográfica.

#### 2.1. Estimación

La estimación implica el uso de modelos matemáticos y algoritmos para calcular las variables de estado del sistema. Estas variables son esenciales para comprender el comportamiento del sistema y para tomar decisiones informadas sobre su control. La estimación puede realizarse de dos maneras:

- Lazo abierto: En este enfoque, se utilizan modelos de estimación predefinidos sin retroalimentación, lo que significa que las estimaciones no se ajustan en función de las mediciones reales.
- Lazo cerrado: Este método ajusta las estimaciones en función de las mediciones reales y las salidas del sistema, lo que permite una mayor precisión y adaptabilidad.

Esta es crucial en aplicaciones donde las mediciones directas son difíciles o costosas de obtener, por ejemplo en los sistemas hidráulicos, la estimación de variables de estado permite optimiza el rendimiento y la eficiencia del sistema, asegurando que se mantengan las condiciones deseadas a pesar de las perturbaciones externas o errores en las mediciones [1]. La estimación es un componente clave en los sistemas de control, ya que facilita la comprensión y el manejo de sistemas complejos. Su implementación permite una operación más eficiente y efectiva, mejorando su capacidad de respuesta ante diversa condiciones operativas [2].

#### 2.2. Control

Como se mencionó anteriormente la estimación es un componente clave en los sistemas de control, ya que este se enfoca en el desarrollo y diseño de sistemas capaces de regular y controlar variables de un proceso de manera autónoma. Estos sistemas utilizan sensores, actuadores y algoritmos de control para mantener las variables de interés dentro de los rangos permitidos, mejorando de esta forma la eficiencia, precisión y confiabilidad de los procesos. Su aplicación abarca desde sistemas espaciales hasta biorreactores y sistemas de iluminación.

#### 2.3. Procesadores embebidos

Los procesadores embebidos son microprocesadores especializados en tareas dentro de un sistema más complejo. A diferencia de los procesadores de propósito general, estos están optimizados para ofrecer eficiencia energética, un tamaño compacto y costo reducido. Algunas de las características de los procesadores embebidos se presentan a continuación:

- Integración de periféricos: Incorporan periféricos específicos de la aplicación en un único chip, incluyendo temporizadores, puertos de entrada/salida y controladores de memoria.
- Arquitecturas de bajo Consumo: Diseñados para maximizar la duración de la batería en dispositivos portátiles, lo que es esencial para la operatividad de dispositivos móviles.
- Tamaño compacto: Su diseño permite reducir costos y facilitar la integración en espacios limitados, lo que los hace ideales para aplicaciones donde el espacio es crítico.
- Capacidad de respuesta en tiempo real: Pueden responder a eventos externos de manera predecible y determinista, lo que es crucial en aplicaciones que requieren una respuesta rápida y precisa.

#### 2.3.1. Cortex-A9

Los procesadores embebidos basados en la arquitectura ARM Cortex-A9 se utilizan en aplicaciones de alto rendimiento y capacidades avanzadas de procesamiento. Aunque esta arquitectura no es un procesador embebido, sino más bien una familia de núcleos de procesador diseñado por ARM Holdings, los SoC que incorporan estos núcleos han demostrado ser una solución popular para aplicaciones embebidas [3]. Algunas de sus características son :

- Arquitectura de 32 bits basada en ARMv7-A.
- Alto rendimiento adecuado para aplicaciones exigentes como sistemas operativos embebidos, procesamiento multimedia y gráficos.

• Características avanzadas como unidades de coma flotante, unidades de procesamiento NEON para procesamiento multimedia y soporte para virtualización.

Algunos SoC que incorporan núcleos Cortex-A9 son:

- Nvidia Tegra 3: Combina cuatro núcleos Cortex-A9 y una GPU.
- Texas Instruments OMAP 4: Familia de SoC que combina núcleos Cortex-A9 y DSP.
- Xilinx Zynq-7000: Integra núcleos Cortex-A9 con lógica programable FPGA.

#### 2.3.2. Tarjeta de desarrollo ZedBoard

La ZedBoard es una tarjeta de desarrollo basada en el Xilinx Zynq-7000 que como se mencionó anteriormente integra núcleos Cortex-A9 con la lógica programable para Field Programmable Gate Array (FPGA). Esta plataforma es ideal para prototipar aplicaciones en el ámbito de sistemas embebidos. La tabla 2.1 resume las especificaciones que posee la tarjeta de desarrollo ZedBoard.

Tabla 2.1: Especificaciones generales de la tarjeta de desarrollo ZeadBoard

| Especificación         | Detalles                                                      |
|------------------------|---------------------------------------------------------------|
| Procesador             | Xilinx Zynq-7000 (XC7Z020)                                    |
| Núcleos de Procesador  | ARM Cortex-A9 de doble núcleo                                 |
| Memoria DDR3           | 512 MB                                                        |
| Memoria Flash          | 256 MB QSPI                                                   |
| Almacenamiento         | Tarjeta SD de 4 GB                                            |
| Conectividad           | Ethernet $(10/100/1000 \text{ Mbps})$ , USB OTG 2.0, USB-UART |
| Salidas de Video       | HDMI (1080p), VGA de 8 bits, OLED 128x32                      |
| Audio                  | Códec de audio I2S                                            |
| Puertos GPIO           | 54 pines GPIO                                                 |
| Interfaz de JTAG       | Soporte para programación y depuración                        |
| Dimensiones            | 10.2  cm x  6.4  cm                                           |
| Fuente de Alimentación | 5V a través de conector de alimentación                       |
| Sistema Operativo      | Soporte para Linux y otros sistemas embebidos                 |
| Expansión              | Conectores Pmod y FMC para módulos adicionales                |

#### 2.4. Marcos de trabajo

Los marcos de trabajo en sistemas embebidos son conjuntos de herramientas y bibliotecas que facilitan el desarrollo de aplicaciones en estos sistemas. Estos proporcionan una estructura que permite abordar los desafíos específicos que presentan los sistemas embebidos.

Los sistemas embebidos interactúan con su entorno físico, lo que requiere un diseño que no solo considere los resultados de las operaciones, sino también el cumplimiento de plazos y restricciones específicas. En este contexto, las propiedades no funcionales, como el consumo energético, la latencia, la fiabilidad y el manejo de recursos, son críticas para el diseño y optimización del rendimiento general del sistema [4]. Los frameworks juegan un papel fundamental al proporcionar herramientas y bibliotecas predefinidas, permitiendo a los desarrolladores centrarse en la lógica de la aplicación en lugar de lidiar con los detalles de bajo nivel del hardware, lo que acelera el proceso de desarrollo y reduce la posibilidad de errores. Ejemplos de frameworks populares en sistemas embebidos incluyen Robot Operating System (ROS), utilizado en aplicaciones de robótica, y FreeRTOS, un sistema operativo de tiempo real diseñado para microcontroladores y sistemas embebidos [5].

#### 2.4.1. YOCTO

Yocto es un marco de trabajo (framework) popular utilizado en el desarrollo de sistemas embebidos, especialmente en la creación de distribuciones de Linux personalizadas para hardware específico. Yocto utiliza un proceso de construcción cruzada, lo que significa que el código se compila en una plataforma diferente a la que se ejecutará, permitiendo que el código se optimice para el hardware específico del sistema embebido [6].

Una de las principales ventajas de Yocto es su flexibilidad en la configuración del sistema, permitiendo a los desarrolladores seleccionar paquetes específicos, configurar opciones de compilación y personalizar el sistema operativo según sus necesidades. Además, Yocto fomenta la reutilización de código a través de capas, que son colecciones de recetas, configuraciones y parches que se pueden agregar o eliminar fácilmente del flujo de trabajo de construcción [6].

#### 2.5. Transformación de modelo a modelo

La transformación de modelo a modelo se refiere a un proceso en el que un modelo se convierte en otro, manteniendo la esencia de su estructura y funcionalidad, pero adaptándose a nuevas necesidades o contextos. Este concepto es fundamental en la Ingeniería de Software, especialmente dentro de la Arquitectura Dirigida por Modelos (MDA), donde se busca facilitar la interoperabilidad y la portabilidad de sistemas a través de la transformación de modelos independientes de la computación (CIM) a modelos independientes

de la plataforma (PIM) y viceversa.

- Modelos de Datos a Modelos de Aplicación:
- Modelos de Negocio a Modelos de Implementación
- Modelos UML a Código Fuente

Para efectos de este trabajo el área de interés serán la transformación de UML a Código Fuente.

#### 2.5.1. MATLAB Embedded Coder

El MATLAB Embedded Coder se adapta a esta definición de transformación de modelo a modelo, ya que permite a los usuarios generar código C y C++ a partir de modelos Simulink. Esto es especialmente útil en el desarrollo de sistemas embebidos, donde se requiere que los modelos de alto nivel se transformen en código que pueda ser ejecutado en hardware específico. Esta herramienta facilita la implementación de algoritmos y sistemas de control, asegurando que el modelo original se traduzca eficazmente en un formato que pueda ser utilizado en entornos de producción.

#### 2.6. Código embebido

El código embebido se refiere a un tipo de software diseñado para operar en dispositivos con recursos limitados, como microcontroladores y sistemas embebidos. Este código es fundamental en la programación de dispositivos electrónicos, permitiendo que estos realicen tareas específicas, como gestionar un sistema de automatización industrial o incluso operar en dispositivos móviles. Se caracteriza por su ejecución en dispositivos con recursos limitados, su capacidad para controlar dispositivos electrónicos, el uso de lenguajes de bajo nivel, la optimización de recursos y la necesidad de garantizar tiempos de respuesta determinísticos.

#### 2.7. Contenedores

para que sirven, ventajas y desventajas de su implementación caso de estudio

#### 2.8. protocolos de comunicación

#### 2.8.1. UART

#### 2.8.2. SSH

#### 2.9. Revisión literaria

En los últimos 4 años, las computadoras de guía, navegación y control han mostrado grandes avances en el desarrollo de sistemas autónomos.

#### 2.9.1. Desarrollo de sistemas de navegación

En 2022, se presentó un sistema de planificación y control de navegación para vehículos autónomos en entornos urbanos. Este sistema permite la planificación de rutas basadas en la posición actual del vehículo y su destino, utilizando un controlador clásico que asegura el seguimiento de la trayectoria mediante odometría y correcciones visuales. Los resultados se simularon utilizando herramientas como ROS y Gazebo, lo que demuestra la viabilidad de estos sistemas en entornos complejos [7].

#### 2.9.2. Transformación de Lenguaje de Bloques a Código C

La traducción de código de control de lenguaje de bloques a C implica un proceso de conversión donde cada bloque visual se asocia con una estructura de código en C. Esto se puede hacer utilizando herramientas de software que generan automáticamente el código C a partir de la lógica definida en el entorno de bloques. Este proceso no solo facilita la programación, sino que también permite la optimización del código generado para mejorar el rendimiento en sistemas de navegación autónoma.

#### **XOD**

XOD es un entorno de programación visual basado en bloques que permite a los usuarios crear programas para microcontroladores como Arduino. Este software genera automáticamente código en C++ a partir de la lógica definida en bloques. Los usuarios pueden conectar componentes gráficamente y, al finalizar, acceder al código generado, que es abierto y personalizable. XOD es gratuito y permite la creación de nuevos nodos para componentes específicos, lo que facilita la adaptación a diferentes proyectos [8].

#### Visual Microcontroller

Este software proporciona un lenguaje de programación gráfico para microcontroladores, desarrollado en C#. Utiliza una interfaz gráfica que permite a los usuarios diseñar diagramas que representan la lógica de control. El sistema compila el código a partir de diagramas gráficos, generando código intermedio en C antes de llegar al código hexadecimal necesario para la programación del microcontrolador [9].

#### LabVIEW

LabVIEW es un entorno de desarrollo que utiliza un enfoque gráfico para la programación. Aunque es más conocido en el ámbito de la ingeniería, también permite la generación de código en C. LabVIEW facilita la creación de aplicaciones de control y adquisición de datos, y su capacidad para traducir diagramas de bloques a código C lo convierte en una opción útil para proyectos que requieren un control preciso de hardware.

#### Simulink

Como se mencionó anteriormente, Simulink, parte de MATLAB, proporciona un entorno gráfico para modelar, simular y analizar sistemas dinámicos. Permite a los usuarios crear modelos utilizando bloques y, posteriormente, generar código C automáticamente a partir de estos modelos. Esta herramienta es especialmente valiosa en aplicaciones de ingeniería donde se requiere un alto grado de precisión y control sobre el comportamiento del sistema.

#### 2.10. Avances recientes en GNCs

En el marco del proyecto EROSS+ (European Robotic Orbital Support Services), se ha trabajado en el diseño de un sistema GNC altamente autónomo para misiones de servicio robótico en órbita. Este proyecto, que abarca desde 2021 hasta 2023, busca integrar técnicas avanzadas de navegación visual y control de cumplimiento para la captura y manipulación de satélites, mostrando un enfoque en la autonomía y la eficiencia operativa [10].

Otro desarrollo notable es el programa de NASA sobre GNC autónomo, que incluye sistemas para el transbordador espacial. Este programa se centra en la optimización de trayectorias de vuelo y la adaptación de sistemas GNC para diferentes condiciones de vuelo, lo que demuestra la importancia de la flexibilidad en el diseño de estos sistemas [11].

Además, la actividad VV4RTOS, apoyada por la Agencia Espacial Europea, se ha centrado en la verificación y validación de sistemas de control basados en optimización. Esto incluye el desarrollo de software GNC en tiempo real, lo que permite una validación más efectiva

y segura de los sistemas diseñados [12].

#### 2.10.1. Programación de Sistemas GNC

Los lenguajes de bloques, como Simulink, son comúnmente utilizados para diseñar y simular sistemas de control. Estos lenguajes permiten a los ingenieros visualizar el flujo de datos y las interacciones entre componentes de manera intuitiva. Sin embargo, la necesidad de traducir estos modelos a código C es crucial para su implementación en hardware real.

A pesar de los avances, existen desafíos significativos en la implementación de sistemas GNC. La variabilidad en los entornos operativos y la necesidad de adaptarse a condiciones cambiantes requieren algoritmos robustos y adaptativos. La optimización de estos sistemas es fundamental para asegurar su efectividad en misiones críticas.

Un estudio reciente sobre el sistema CubeNav destaca la importancia de desarrollar herramientas de análisis de navegación que faciliten las operaciones de GNC en misiones de CubeSats. Este enfoque busca reducir la curva de aprendizaje y minimizar errores humanos, lo que es esencial para misiones de bajo presupuesto y alta complejidad [12].

### Capítulo 3

### Tarjeta de desarrollo

En este capítulo se pretende identificar una plataforma de hardware para el desarrollo de un modelo de ingeniería de una computadora de guía, navegación y control espacial por sus siglas en ingles (GNC), para llevar a cabo este objetivo se plantean los requerimientos que se deben de tomar en cuenta para elegir una tarjeta de desarrollo que logre satisfacer las necesidades de este proyecto, seguido de esto se seleccionaran un grupo de tarjetas las cuales cumplan con los requerimientos previamente establecidos, estas serán comparadas para poder determinar cuál de las tarjetas de desarrollo seleccionadas puede cumplir de mejor forma la tarea seleccionada.

#### 3.1. Selección de la tarjeta de desarrollo

Para la selección de la tarjeta de desarrollo se partirá de la definición de los requerimientos de operación del sistema, esto tomando en cuenta las operaciones más comunes que realizan los sistemas GNC, una vez definidos los requerimientos, se seleccionaran al menos 3 tarjetas candidatas, esto con el fin de establecer los criterios de comparación para el desarrollo de una matriz de Pugh.

#### 3.1.1. Requerimientos de la aplicación

Al elegir una tarjeta de desarrollo para un sistema de guía, navegación y control (GNC) en aplicaciones espaciales, se deben de tener en cuenta varios factores clave. Dentro de ellos se encuentran el procesamiento, mas precisamente la capacidad de calculo, ya que estos sistemas reuqieren de un procesamiento intensivo para los calculos de trayectoria, estimacion de estado y control. Seguido de esto se debe de considerar que sea un sistema de baja latencia, ademas que el mismo tenga soporte para sensores y actuadores para poder mediir y controlar el sistema, ademas de esto los puertos de entrada y salida deben ofrecer la presicion necesaria ara leer los datos de los sensores que se conecten al mismo.

Por otro lado el sistema debe de contener capacidades de tiempo real estricto ya que los sistemas GNC deben de tomar desiciones criticas en el momento requerido. ademas de tener la capacidad de ejecutar un sistema opereativo de tiempo real (RTOS) o bien Linux en tiempo real. Tambien un aspecto importante a contener por la tarjeta de desarrollo es el consumo de energia, esto sin dejar de lado las capacidades de simulacion y pruebas, ya que, en la interfaz de simulacion la tarjeta se debe de poder conectar a un entorno de pruebas de hardware-in-the-loop por sus siglas en ingles (HIL), ademas de las capacidades de depuracion y monitoreo.

Finalmente se deben de tomar en cuenta aspectos como lo son el Tamanno, peso y forma de la trjeta buscando que las mismas contengan un tamanno compacto ya que los sistemas espaciales siempre se deben de integrar en espacios reducidos y la resistencia del mismo.

#### 3.1.2. Tarjetas candidatas

Bajo los requerimientos planteados anteriomente se eligieron las siguientes tarjetas de desarrollo, las mismas se presentaran con sus características.

#### Xilinx ZCU102 Evaluation Kit

La tarjeta de desarrollo ZCU102 contiene procesamiento basado en Zynq UltraScale+MPSoC, el cual combina un procesador ARM Cortex-A53 de 64 bits con una FPGA de alto rendimiento, la cual es excelente para el procesamiento en tiempo real y algorimos personalizados.

Por otro aldo esta ofrece una amplia gama de interfaces de comunicacion como: PCIe, Ethernet, I2C, SPI, UART, GPIO. En cuanto a la eficiencia energetica esta opcion contiene mecanismos para el control de energia, ademas de ser compatible con entornos de de simulacion y tiene interfaces JTAG oara una buena depuracion. finalmente es una tarjeta ampliamente utilizada en la industria en Sistemasd de prototipos avanzados y despliegue de HIL.

En sintesis esta opcion ofrece un procesamiento potente y versatil ademas de ser excelente para desarrollar y escalar sistemas GNC complejos, por otro lado es una tarjeta de desarrollo costosa.

#### **NVIDIA Jetson AGX Xavier**

Para el caso de la tarjeta AGX Xavier de NVIDIA incorpora una CPU ARM v8.2 de 64 bits y una GPU NVIDIA Volta, prestaciones las cuales se encargan de proporcionar un alto nivel de procesamiento de datos en paralelo especualmente utilizado para aplicaciones de vision por computador o inteligencia artificial para sistemas GNC.

Las interfases de comunicación presentes en esta tarjeta son puertos I2C, SPIm UART y

GPIO ademas de contener adicionalmente soporte nativo para camaras y sensores de alta gama. Ademas presenta capacidades en tiempo real ya que se puede implementar con el NVIDIA Jetpack SDK.

En cuanto a la eficiencia energetica, la misma posee un diseno optimizado para bajo consumo. ademas de ser compatible con interfases de pruebas y simulacion mediante el uso de entornos como Tensor RT y otras plataformas propietarias del desarrollador de la tarjeta de desarrollo.

Esta tarjeta es ideal para sistemas GNC con un procesamiento intensivo de datos ya sean de vision por computador o bien inteligencia artificial, por otro lado posee un desarrollo potente para el procesamiento de tares en paralelo o bien de aprendizaje reforzado, finalmente contiene un buen soporte para aplicaciones en tiempo real y simulaciones. Por otro lado contiene un bajo procesamiento logico comparado con las FPGA para aplicaciones en tiempo real extremo, y esta tarjeta de desarrollo se encuentra mas enfocada en el la implementacion de soluciones que requieran inteligencia artificial.

#### TMS320C6678 Development Kit

La tarjeta TMS320C6678 es basada en un procesador para procesamiento digital de senales (DSP) de 8 nucleos, esta enfocado a aplicaciones de procesamiento intensivo en tiempo real, soporta interfases como lo son Ethernet, SPI, UARTm I2C y GPIO, ademas de tener opciones para expandir la conectividad de la misma, por otro lado como mencionamos anteriormente es uno de los sistemas mas optimizados para el procesamiento en tiempo real por medio de la plataforma propietaria TI RTOS.

Sobre la eficiencia energetica, esta tarjeta de desarrollo ofrece herramientas especificas para la optimizacion del consumo de energia, hacinedola adecuada para entornos de consumo energetico restringido, finalmente es compatible con Code Composer Studio, el cual es un entorno de desarrollo integrado que facilita las labores de integracion, simulacion y depuracion. Por tanto podemos decir que es una tarjeta de desarrollo muy adecuada para los sistemas de procesamiento de senañes y control, tiene una gran capacidad para soportar aplicaciones industriarles y aeroespaciales. Por otro lado, podemos ver que es un plataforma menos flexible que una FPGA.

#### ZedBoard de Avnet

Para la tarjeta ZedBoard en cuanto a procesamiento tenemos que utiliza un procesador Xilinx Zynq-7000 APSoC el cual combina un procesador ARM Cortex-A9 dual core con una FPGA programable, de esta froma tomando el procesador ARM el cual es ideal para ejecutar algoritmos de control y logica de navegacion en un entrno de RTOS o bien Linux, por otro lado la FPGA Zynq-7000 permite la ejecucion de tareas de procesamiento paralelo en hardware como el filtrado de sennales o algoritmos de estimacion de estad, ofreciendo baja latencia y flexibilidad en tiempo real.

En cuanto a las interfases de entrada y salida, incluye varias opciones como lo son: GPIO, I2C, SPI, UART. Ademas de esto contiene puertos Ethernet, micro usb y HDMI los cuales resultan utiles para la comunicación externa y visualización de los sistemas de desarrollo.

La combinacion de un procesador ARM con una FPGA permite un equilibrio en el consumo de energia ya que la mayoria de tareas intensivas se pueden llevar a cabo en la FPGA y el SoC Zynq ofrece opciones de ahorro de energia lo cual siempre representa un beneficio para las aplicaciones embebidas. En cuanto a la pruebas y simulaciones cuenta con entornos como vivado y SDK de Xilinx esto con el fin de realizar simulaciones de HIL. Por otro lado ofrece aplicaciones para depuracion como lo es Jtag para el monitoreo en tiempo real de las aplicaciones ejecutandose en la FPGA y en el procesador ARM.

#### 3.1.3. Criterios de comparación

Una vez presentadas las terjetas de desarrollo candidatas se procede con la definición de los criterios de comparación: para este caso los criterios a tomar en cuenta son los siguientes:

- 1. Capacidad de procesamiento: La capacidad de procesamiento en dispositivos de desarrollo para sistemas GNC es crucial porque garantiza la ejecución en tiempo real de algoritmos complejos, como los de control y fusión de sensores, que son esenciales para la estabilidad y precisión del sistema. Permite procesar grandes volúmenes de datos de múltiples sensores de manera simultánea y rápida, ejecutar tareas en paralelo, y realizar cálculos intensivos como la planificación de trayectorias y control adaptativo. Además, un procesamiento robusto facilita la simulación HIL, asegurando pruebas y simulaciones realistas.
- 2. Soporte para sensores y actuadores: El soporte para sensores y actuadores es esencial en dispositivos de desarrollo para sistemas GNC porque estos sistemas dependen de la entrada de múltiples sensores como acelerómetros, giroscopios, GPs, entre otros, para monitorear y estimar la posición, orientación y velocidad del vehículo en tiempo real. La capacidad de interactuar directamente con estos sensores, y con actuadores que ejecutan las acciones de control, es fundamental para garantizar la retroalimentación continua y precisa necesaria para el correcto funcionamiento del sistema GNC. Interfaces como I2C, SPI, UART, y GPIO permiten esta integración, asegurando un control eficiente y adaptable.
- 3. Capacidad de trabajo en tiempo real: La capacidad de trabajo en tiempo real es vital en dispositivos de desarrollo para sistemas de guía, navegación y control (GNC) porque estos sistemas requieren respuestas inmediatas y precisas ante cambios en el entorno o en las condiciones del vehículo. Los algoritmos de control, como los de estabilidad y trayectoria, deben ejecutarse sin demoras para garantizar la seguridad y el rendimiento óptimo del sistema. Sin procesamiento en tiempo real, las decisiones

- de control podrían retrasarse, afectando la estabilidad y el control del vehículo, lo cual es crítico en aplicaciones como navegación autónoma o vuelo espacial.
- 4. Consumo de energia: El consumo de energía es crucial en dispositivos de desarrollo para sistemas de guía, navegación y control (GNC), especialmente en aplicaciones espaciales o autónomas, donde los recursos energéticos son limitados. Un consumo eficiente permite que el sistema funcione de manera prolongada sin comprometer su rendimiento, maximizando la duración de la misión y asegurando que los componentes críticos, como sensores y actuadores, siempre reciban suficiente energía. Además, la gestión adecuada del consumo evita el sobrecalentamiento y prolonga la vida útil de los dispositivos, lo que es fundamental en entornos de operación prolongada o difíciles de acceder.
- 5. Caracteristicas Fisicas: Las características físicas, como el tamaño, peso y forma, son importantes en dispositivos de desarrollo para sistemas de guía, navegación y control (GNC) porque estos sistemas suelen implementarse en entornos con restricciones de espacio y peso, como en vehículos aéreos, drones o satélites. Un dispositivo compacto y ligero facilita la integración en estos sistemas sin afectar su desempeño ni su capacidad de carga. Además, un diseño físico optimizado es clave para minimizar los efectos de vibraciones, choques o cambios de temperatura, asegurando un funcionamiento fiable en condiciones extremas.
- 6. Costo: El costo es un factor importante en dispositivos de desarrollo para sistemas de guía, navegación y control (GNC) porque influye directamente en la viabilidad económica del proyecto, especialmente en fases de prototipado o prueba. Un dispositivo con un costo adecuado permite realizar iteraciones y pruebas sin superar el presupuesto, facilitando el acceso a tecnologías avanzadas sin comprometer la calidad. Además, un costo equilibrado permite escalar el proyecto o implementar múltiples sistemas de prueba, optimizando el desarrollo sin sacrificar funcionalidad o capacidad técnica.
- 7. Escalabilidad del sistema: La escalabilidad del sistema es crucial en dispositivos de desarrollo para sistemas de guía, navegación y control (GNC) porque permite adaptar el hardware y software a medida que el proyecto crece en complejidad o requisitos técnicos. Un dispositivo escalable facilita la integración de nuevos sensores, algoritmos más avanzados o mayores capacidades de procesamiento sin necesidad de cambiar completamente la plataforma. Esto ahorra tiempo y costos, además de asegurar que el sistema pueda evolucionar para cumplir con las demandas de futuras fases del desarrollo o nuevas aplicaciones, manteniendo la flexibilidad y la eficiencia.

#### 3.2. Matriz de Pugh

**Tabla 3.1:** Matriz de Pugh para seleccionar la tarjeta de desarrollo que mejor de adapte a los requerimientos del proyecto

| Criterios                          | Peso | ZCU102 | AGX Xavier | TMS320C6678 | Zedboard |
|------------------------------------|------|--------|------------|-------------|----------|
| Capacidad de procesamiento         | 15   | 15     | 15         | 8           | 10       |
| Soporte para sensores              | 15   | 15     | 15         | 15          | 15       |
| Soporte para actuadores            | 15   | 15     | 15         | 15          | 15       |
| Soporte de sistemas de tiempo real | 20   | 20     | 20         | 15          | 20       |
| Caracteristicas Fisicas            | 10   | 4      | 7          | 10          | 10       |
| Costo de la tarjeta                | 15   | 7      | 10         | 10          | 15       |
| Escalabilidad del sistema          | 10   | 10     | 6          | 6           | 10       |

| Suma general |  |
|--------------|--|
| Posicion     |  |

| 86 | 88 | 79 | 95 |
|----|----|----|----|
| 3  | 2  | 4  | 1  |

Como se pudo observar en la Tabla 3.1, un claro ganador segun los requerimientos establecidos para este proyecto ha sido la tarjeta de desarrollo zedbaord ya que es la mejor opcion en cuanto a caracteristicas como lo son la capacidad de procesamiento y . . .

#### 3.3. Plataforma seleccionada

Como se pudo observar en la Tabla 3.1, la tarjeta de desarrollo seleccionada fue la Trajeta Zedboard de Avnet. La ZedBoard es una tarjeta de desarrollo basada en el SoC (System-on-Chip) Xilinx Zynq-7000. Diseñada para aplicaciones de desarrollo en sistemas embebidos y de procesamiento de señales, la ZedBoard combina la potencia de un procesador ARM con la flexibilidad de una FPGA (Field Programmable Gate Array), proporcionando una plataforma versátil para la investigación, el desarrollo y la prueba de diversas aplicaciones, incluidas las de guía, navegación y control (GNC).

#### 3.3.1. Especificaciones principales

Como se meciono en el capitulo 2 en la Tabla 2.1 y anteriormente en este capitulo la tarjeta en cuestion presenta las siguientes especificaciones principales.

#### Procesador y FPGA

SoC Xilinx Zynq-7000: La ZedBoard integra un procesador ARM Cortex-A9 dual-core junto con una FPGA programable de la serie 7-Series. ARM Cortex-A9: Ofrece un rendimiento de procesamiento general que puede ejecutar sistemas operativos como Linux o FreeRTOS, lo que es útil para tareas de control y procesamiento de datos. FPGA: La

FPGA proporciona capacidad para implementar lógica personalizada, lo que permite el desarrollo de algoritmos específicos en hardware para procesamiento en tiempo real y alta velocidad.

#### Interfaces de E/S

GPIO: General Purpose Input/Output, permite la interacción con una amplia gama de periféricos y sensores. I2C, SPI, UART: Protocolos de comunicación estándar que facilitan la integración con diversos dispositivos de sensor y actuadores. Ethernet: Conectividad de red para comunicación y transmisión de datos. USB: Puertos USB para conexión de dispositivos externos y almacenamiento. HDMI: Salida de video para visualización de datos y control gráfico. JTAG: Para depuración y programación de la FPGA y el procesador ARM.

#### Memoria

RAM: Incluye memoria DDR3 SDRAM para el procesador y la FPGA, proporcionando espacio suficiente para la ejecución de sistemas operativos y algoritmos complejos. Flash: Memoria flash para almacenamiento de configuraciones y datos persistentes.

#### Alimentación y Consumo de Energía

La ZedBoard se alimenta típicamente a través de una entrada de 5V, con un diseño que optimiza el consumo energético para aplicaciones de desarrollo. Sin embargo, el consumo real depende del uso de la FPGA y el procesador.

#### Tamaño y Factor de Forma

Dimensiones: Aproximadamente 15.24 cm x 22.86 cm (6 x 9 pulgadas), lo que la hace adecuada para prototipos sin ser excesivamente grande. Diseño: Compacta pero con suficiente espacio para interfaces y módulos adicionales.

#### Capacidades de Desarrollo

Entornos de Desarrollo: Compatible con Xilinx Vivado Design Suite y SDK, proporcionando herramientas avanzadas para diseño, simulación, y depuración. Ejemplos de Aplicaciones: Adecuada para aplicaciones que requieren procesamiento en paralelo, desarrollo de sistemas embebidos, y prueba de algoritmos de control.

#### 3.4. Reflexión final

Como se pudo observar a lo largo de este capitulo se analizaron los requerimientos de hardware que se deben de tomar en cuenta para el desaarrollo de este proyecto, seguido de esto se tomaron cuatros tarhjetas de desarrolo con el fin de elegir entre las que presentaran las prestaciones adecuadas para la tarea a realizar. Por un lado se tenian tarjetas muy potentes como xxxx y xxxx y por otro lado se tenian tarjetas de grandes dimenciones como la xxx y xxxx. Segun los parametros definidos se elige la tarjeta xxxx con numero de parte xxx para continuar con el desarrollo de este proyecto.

### Capítulo 4

## Flujo de trabajo para la implementación de software para GNC embebido

Como se pudo observar en el capítulo 3, se realizó la selección de la tarjeta de desarrollo Zedboard para el desarrollo del proyecto, además de esto uno de los parámetros que se tomó en cuenta fue la compatibilidad de esta tarjeta con el flujo de trabajo de Yocto Project, es por esto que en este capítulo se pretenden establecer los flujos de trabajo para el prototipado de algoritmos de control de orientación y navegación para aplicaciones espaciales. Esto mediante el uso de MATLAB Simulink para tomar un caso de estudio como ejemplo, seguido de esto convertir el código por medio de la transformación de modelo de Simulink a un modelo de código C, esto con el objetivo de poder embeber el código C en una imagen mínima por medio del flujo de trabajo de Yocto Project y finalmente probar el mismo en la tarjeta de desarrollo seleccionada en el capítulo 3 y de esta forma poder comparar los resultados obtenidos y el tiempo de ejecución que llevo la tarea en el computador y en el sistema embebido.



Figura 4.1: Diagrama general del flujo de trabajo propuesto

En la Figura 4.1, se muestra un diagrama del flujo de trabajo general. En este capítulo se trabajará en la sección remarcada en rojo la cual engloba la generación del modelo utili-

zado como caso de estudio, la validación del mismo en MATLAB Simulink, la generación de un código en lenguaje C y la incorporación del mismo en el flujo de trabajo de Yocto Project.

# 4.1. Flujo de trabajo de la aplicación Model 2 Model Transformation

Para poder embeber el sistema se debe de hacer uso del MATLAB Simulink Coder, el cual tiene la capacidad de convertir un sistema de conrtol generado en MATLAB Simulink, en un codigo C, algunos de los parametros que se pueden configurar en este convertidor de modelos son:

A lo largo de este capitulo se definiran los parametros que se deben de utilar y el funcionamiento de estos dentro de la generación del codigo C.

#### 4.2. Selección del caso de estudio

Como caso de estudio se selecciono una aplicacion la cual permitiera una comparacion de resultados antes del procesado y despues del mismo, es por esto que se decidio implementar un filtro de tipo xxx haciendo uso de los siguientes bloques de MATLAB Simulink.

- Onda seno
- Suma
- Función de transferencia
- Generador de archivo de salida

La configuración seleccionada para el primer generador de onda seno es:

- Amplitud = 1
- $\blacksquare$  Bias = 0
- Frecuencia = 1 rad/s
- Fase = 0
- Tiempo de muestreo = 0

Mientars que para la segunda onda se tiene la configuracion:

- Amplitud = 1
- $\blacksquare$  Bias = 0
- Frecuencia = 12 rad/s
- Fase = 0
- Tiempo de muestreo = 0

Esto con el objetivo de sumar las ondas y que las mismas (explicar que pasa al sumar dos ondas de distinta frecuencia)

Por otro lado la funcion de transferencia a utilizar sera:

ingresar la funcion de transferencia

esto con el fin de separar las frecuencias anteriormente sumadas y obtener una salida con la (describir que se espera a la salida)

Estos bloques mencionados anteriormente se lococan como se muestra en la Figura ??, de modo que se obtienen como salida del sistema 2 archivos, uno llamado xxx el cual contiene los datos crudos de la suma de las dos sennales y otro denomindado, xxxx el cual contiene los datos de la sennal filtrada por la funcion de tranferencia.

#### 4.2.1. Simulación del caso de estudio en Matlab Simulink

Utilizando el diagrama de la Figura ?? asi como usando los parametros configurados anteriormente se colocan dos bloques de grafico en el diagrama como se muestra en la Figura ??, esto con el objetivo de poder observar las senales de salida en cada uno de los puntos de interes.

(imagen compuesta por dos graficos uno al lado del otro donde a la derecha mostremos las senales sumadas y a la derecha las senales filtradas)

Como se puede observar en la Figura ?? se puede observar la salida de la suma de las dos senales senoidales, por otro lado en la Figura ?? se puede observar la salida de la funcion de transferencia.

#### Resultados obtenidos con la ejecución de la simulacionn

Como se menciono anteriormente los resultados obtenidos se pueden observar en la Figura ??, siendo la salida esperada de la funcion de transferencia ya que al ser un filtro paso xxx atenua las senales que sten por debajo de la frencuencia de corte que para este filtro es de xxx. Como la senal compuesta contiene una senal con frecuencia de xxxx y otra con frencuencia de xxxx es posible observar aun componentes de la frecuencia atenuada.

#### 4.2.2. Simulink coder

Una vez comprobado el comportamiento esperado por el caso de estudio se puede proceder con la ejecucion del flujo de trabajo de MATLAB Simulink coder, esto con el fin de transformar el modelo generado en Simulink a un modelo de lenguaje de programacion C. Cabe destacar que para esta implementacion se utilizo el diagrama que se muestra en la Figura ?? ya que el mismo solamente contiene los archivos con los datos numericos del sistema y no contiene las salidas graficas agregadas en 4.2.1.

### 4.2.3. Definicio de paramtetros

Para la definicion de parametros, se debe de estar en el entorno de MATLAB Simulink, una vez en el entorno mencionado anteriormente se debe ir a la pestanna denominada Aplicaciones, como se muestra en la Figura ??, se debera de seleccionar la aplicacion denominada Simulink Coder, cuando seleccionamos esta opcion se abrira una pestanna llamada Codigo C, como se pudo observar en la Figura ??, una vez estemos en la pestanna de codigo C, debemos de ir a la opcion de configuracion de parametros, tal y como se muestra en la Figura ??, una vez presionada la opcion se abre una ventana emergente como la que se muestra en la Figura ??, en la pestanna denominada Solver se deberan de proporcionar los datos de Tiempo de inicio y Tiempo de finalzacion de la simulacion.

#### seleccion del procesador objetivo

Continuando en la seccion de configuracion de parametros ahora debemos de ir a la pestanna llamada Hardware Implementation, en donde deberemos de colocar los datos de Device Vendor el cual para nuestro caso seria ARM Compatible y el Device Type que seria un ARM Cortex-A de 32-bits tal y como se muestra en la Figura ??.

#### Seleccion del tipo de archivo de construccion

Ahora bien, anteriormente configuramos los parametros de de tiempo de operacion y procesador de la tarjeta de desarrollo, ahora debemos de configurar el tipo de archivo que se utilizara para la generacion de los archivos, como se debera de realziar una compilacion cruzada se debe de elegit un tipo de archivo el cual nos permita compilar los binarios para la ejecucion del sistema sin importar el sistema operativo de la maquina host. Es por esto que se debe de seleccionar en la pestanna de Code Generation el Toolchain denominado CMake tal y como se muestra en la Figura ??.

#### Generacion de archivos de compilacion

Una vez configurados todos los parametros mencionados anteriormente debemos de proceder con la construcción de los archivos, para esto se debe de ir a la barra de tareas a la opción denominada como generar codigo, la misma se puede observar en la Figura ??.

### 4.2.4. Contenedor para compilación de los binarios

Para poder generar la compilacion cruzada es necesario crear un contenedor para poder utilizar Ubuntu 20.04 ya que esta version es la que presenta mayor compatibilidad con las dependencias contenidas en el flujo de trabajo de Yocto Porject que se utiliza.

Para poder generar esta contenedor se hace uso del comando que se muestra en ??, este comando se encarga de cnostruir la maquina dentro del entorno del contenedor.

#### Istalacion de programas en el contenedor

Una vez generado el contenedor debemos de instalar en el mismo xxxxx y xxxxx las cuales son herramientas que nos ayudaran a compilar el programa generado en ?? para la arquitectura del procesador.

### 4.2.5. Compilación de los binarios

Para la compilacion de los binaros se debera hace uso del comando xxx por el cual se construira el makefile, una vez generado el make file se ejecuto el comando xxxx el cual da como salida los binarios requeridos para la ejecucion del programa. Los mismos se observan como se muestra en la Figura ??.

Una vez compilados los binarios se puede continuar con el flujo que se presneta en el diagrama que se muestra en la Figura XX, lo cual seria la implementación de los binarios en una imagen de yocto.

# 4.3. Flujo de Trabajo Herramienta desarrollada por mi persona

Como se pudo observar anteriormente se realizo la compilacion cruzada de un caso de estudio, el mismo ahora se debe de implementar en un sistema operativo a la medida mediante el flujo de trabajo de Yocto Project, como se menciono en ??, yocto project es un marco de trabajo utilizado para el desarrollo de sistemas embebidos especializado en la cosntruccion de distribuciones de linux a la medida.

En el desarrollo de esta seccion se muestran los pasos que se siguieron para la generacion de la imagen minima, la integracion de una capa personalizada con el binario generado en ?? y la implementacion de la misma en la tarjeta de desarrollo seleccionada.

### 4.3.1. Sistema operativo para desarrollo

Como sistema operativo de desarrollo se utilizo Ubuntu 22.04 LTS, en una computadora con las siguientes características

- Procesador Intel Corei9-13980HX
- Almecenamiento 500 GB
- Memoria RAM 16 GB

#### 4.3.2. Generación de un contenedor

Para el desarrollo del marco de trabajo de Yocto se decidio implementar un contenedor, esto debido a que la version de yocto para la cual se encontraba un paquete de soporte para la tarjeta de desarrollo es Yocto Zeus 3.0, este fue liberado en el ano de xxxx por tanto no era soportado por la version de linux del computador de desarollo.

#### Creacion de un usuario no root

Para el uso del marco de trabajo de Yocto se debe de generar un usuario no root, (explicar por que yocto no puede correr en un usuario root)

# 4.3.3. Yocto Project

Como se observo en ??, yocto presenta flexibilidades a la hora de configurar un sistema permitiendo al desarrollador seleccionar paquetes especificos y personalizar el sistema operativo.

La version de yocto a utlizar se debe de clonar de ??, segido de esto se debe de ir al branch de la version mencionada en ?? (Yocto Zeus). Ademas de clonar este repositorio se debe de ingresar al directorio denominado xxx y clonar dentro de el el repositorio ?? el cual contiene en su branch xxx la version de bsp requerida para generar una imagen para la tarjeta de desarrollo.

Algunas configuraciones adicionales que se deben de realizar se muestran e ??.

### 4.3.4. creacion de una capa de yocto

Para la generacion de una capa de yocto primero se debe de inicializar el entorno de desarrollo esto mediante el comando que se muestra en ??, este se encarga de generar todos los archivos necesarios para poder hacer uso de las variables de entorno con las cuales opera el marco de trabajo de Yocto, seguido de esto se debe de utilizair el siguiente comando el cual se encargara de generar el arbol de directorios que se puede observar en la Figura ??. Una vez implementado este comando se debe de hacer uso de este comando para poder agregar la capa al archivo denominado xxxx el cual contiene todas las rutas de acceso a las capas requeridas para generar la imagen.

#### 4.3.5. Caso de estudio

En esta seccion se integrara el caso de estudio generado en ??, a un sistema operativo a la medida por medio de el marco de trabajo de Yocto Project, primeramente se generara una capa personalizada, seguido de esto se generara el archivo de instalacion con el cual la capa personalizada pasara a ser parte del sistema de archivos del sistema embebido, tambien se generara la imagen minima la cual consiste en un sistema de arranque y el sistema de archivos y finalmente se implementaran estos en la tarjeta de desarrollo seleccionada en ??.

## 4.3.6. Integración del programa generado a la capa de Yocto

Para la implementacion de la los binarios generados en ??, se deben de generar algunos directarios, esto con el objetivo de mantener un entorno limpio y ordenado, para contener todos los directorios se genera un directorio llamado xxxx el cual dentro del mismo debera de contener un directorio llamado xxx el cual se encargara de contener el archivo de configuracion de la capa llamado xxxx el cual se genera mediante el comando que se observa en ??, ademas de geenerar este archivo se debe de crear un directorio llamado xxxx que sera el encargado de contener los binarios compilados en ??.

#### .bb

Como se mencionó anteriormente el archivo llamado xxxx.bb es el encargado de la configuracion de la capa, el mismo contiene los comandos de instalacion y la direccion en donde se encontraran los binarios en el sistema de archivos de la imagen del sistema embebido.

La estructura que debe de contener ese archivo para instalar binarios en el sistema son las que se puden observar en ??.

### 4.3.7. Generacion de la imagen minima

Antes de generar la imagen minima se debe de tener en consideracion ejecutar la linea de comando que se muestra en ??, esto con el fin de generar archivos de xxxx en lugar de xxxx. Una vez generados estos cambios se debe de iniciar de nuevo el entorno por medio del comando ??, seguido de esto se debera de ejecutar el comando de xxx el cual se encarga de comenzar a generar la imagen minima.

# 4.3.8. Implementacion de la imagen minima en la tarjeta de desarrollo zedboard

Para la implementacion de la imagen minima en la tarjeta de desarrollo de deben de seguir los siguientes pasos en la maquina Host:

- 1. Se debe de formatear la tarjeta SD de al menos 4 GB, las pariticiones de la misma se tienen que observar de la siguiente forma
  - root = 100 MB FAT 32
  - File System = 3.5 GB ext6(linux filesystem format)
- 2. Seguido de esto se debe de ir a la ruta xxx/xxxx/xxxx/xxxx/xxxx y se deben de copiar los archivos de el contenedor a la maquina host mediante el comando que se muestra en ??, esto con el objetivo de poder enviar los archivos a la tarjeta SD

Para el sistema Root se deberan de copiar los archivos mediante el comando que se muestra en ??, por otro lado en la particion denominada xxxx se debe de copiar el archivo xxxx mediante el uso del comando xxxxx el cual se muestra en ??.

# 4.3.9. Conexion de la tarjeta de desarrollo con el computador host

(Imagen del diagrama de conexion de la tarjeta y el computador por medio de UART)

Seguido de esto se establecio la conexion por medio de SSH el cual como se menciona en ??, consiste en xxxxxxxx ademas de xxxxxx.

El diagrama de este protocolo de comunicación se puede observar en ??.

### 4.3.10. Ejecución del caso de estudio y resultados

Una vez implementada la imagen de Yocto en la tarjeta de desarrollo se puede ejecutar el caso de estudio por medio de xxxxxx, ademas de esto los resultados se pueden transmitir al computador por medio del comando xxxxxx, seguido de esto, haciendo uso de un codigo generado en python se pueden obtener los graficos de las sennales obtenidas mediante la ejecucion del binario contenido en la imagen minima.

(imagen que contenga los dos graficos, a la inquizarda el de las dos senales sumadas y a la derecha el de la senal filtrada)

### 4.3.11. Comparación de resultados

Como se pudo observar, con la comparacion realizada, obtenemos que los datos tiene una desviacion de xxxxx ademas de xxxxxx, es por esto que podemos determinar que la implementacion de sistemas de control es viable segun lo demuestra el caso de estudio.

## 4.4. Reflexion final

# Capítulo 5

# Solución propuesta

En este capítulo se exponen los diseños experimentales realizados para comprobar el funcionamiento correcto del sistema. Por ejemplo, si se realiza algún sistema con reconocimiento de patrones, usualmente esta sección involucra las llamadas matrices de confusión donde se compactan las estadísticas de reconocimiento alcanzadas. En circuitos de hardware, experimentos para determinar variaciones contra ruido, etc. También pueden ilustrarse algunos resultados concretos como ejemplo del funcionamiento de los algoritmos. Puede mostrar por medio de experimentos ventajas, desventajas, desempeño de su algoritmo, o comparaciones con otros algoritmos.

Recuerde que debe minimizar los "saltos" que el lector deba hacer en su documento. Por tanto, usualmente el análisis se coloca junto a tablasy figuras presentadas, y debe tener un orden de tal modo que se observe cómo los objetivos específicos y el objetivo general del proyecto de tesis se han cumplido.

# Capítulo 6

# Conclusiones

Las conclusiones no son un resumen de lo realizado sino a lo que ha llevado el desarrollo de la tesis, no perdiendo de vista los objetivos planteados desde el principio y los resultados obtenidos. En otras palabras, qué se concluye o a qué se ha llegado después de realizado la tesis de maestría. Un error común es "concluir" aspectos que no se desarrollaron en la tesis, como observaciones o afirmaciones derivadas de la teoría directamente. Esto último debe evitarse.

Es fundamental en este capítulo hacer énfasis y puntualizar los aportes específicos del trabajo.

Es usual concluir con lo que queda por hacer, o sugerencias para mejorar los resultados.

# Bibliografía

- [1] J. S. G. Merchán, M. F. Rodríguez, G. J. C. Méndez y M. F. H. Morales, «Evaluación de modelos aproximados para el diseño de control automático en sistemas de riego a canal abierto,» 2019. dirección: https://api.semanticscholar.org/CorpusID: 230388188.
- [2] F. Mesa, R. Ospina-Ospina y G. Correa-Vélez, «Estimación de variables de estado (LA y LC) en sistemas de control,» *Revista UIS Ingenierías*, 2020. dirección: https://api.semanticscholar.org/CorpusID: 228853996.
- [3] F. Schwiegelshohn y M. Hübner, «Design of an attention detection system on the Zynq-7000 SoC,» 2014 International Conference on ReConFigurable Computing and FPGAs (ReConFig14), págs. 1-6, 2014. dirección: https://api.semanticscholar.org/CorpusID:18920120.
- [4] P. G. de Aledo Marugán, «Simulación y verificación de propiedades no-funcionales para sistemas embebidos,» 2017. dirección: https://api.semanticscholar.org/CorpusID:67290306.
- [5] J. M. Herrera-López, A. Galán-Cuenca, I. García-Morales, M. Rollón, I. Rivas-Blanco y V. F. Muñoz, «Entorno de trabajo cíber-físico para cirugía laparoscópica,» Revista Iberoamericana de Automática e Informática industrial, 2023. dirección: https://api.semanticscholar.org/CorpusID:265202759.
- [6] A. Leppakoski, E. Salminen y T. D. Hämäläinen, «Framework for industrial embedded system product development and management,» 2013 International Symposium on System on Chip (SoC), págs. 1-6, 2013. dirección: https://api.semanticscholar.org/CorpusID:21473510.
- [7] C. Barrera-Ramírez, Ó. González-Miranda y J. M. Ibarra-Zannatha, «Sistema de planeación y control de navegación para un vehículo autónomo en un entorno urbano,» Pädi Boletín Científico de Ciencias Básicas e Ingenierías del ICBI, 2022. dirección: https://api.semanticscholar.org/CorpusID:260620410.
- [8] S. R. Sánchez, «Programación de laboratorios de biología portátiles abiertos basados en Arduino con el lenguaje de programación visual XOD,» 2020. dirección: https://api.semanticscholar.org/CorpusID:215856445.

Bibliografía 33

[9] C. Sacta y K. David, «Desarrollo de un lenguaje de programación gráfico para microcontroladores,» 2011. dirección: https://api.semanticscholar.org/CorpusID: 170649818.

- [10] D. Casu, V. Dubanchet, H. Renault, A. Comellini y P. Dandré, «EROSS+ Phase A/B1 Guidance, Navigation and Control design for In-Orbit Servicing,» Papers of ESA GNC-ICATT 2023, 2023. dirección: https://api.semanticscholar.org/CorpusID:267272107.
- [11] A. J. Bordano, G. G. Mcswain y S. T. Fernandes, «Autonomous Guidance, Navigation and Control,» 1991. dirección: https://api.semanticscholar.org/CorpusID:108853424.
- [12] P. Lourenço et al., «Verification & validation of optimisation-based control systems: methods and outcomes of VV4RTOS,» Papers of ESA GNC-ICATT 2023, 2023. dirección: https://api.semanticscholar.org/CorpusID:267287945.

# Apéndice A

# Demostración del teorema de Nyquist

El título anterior es solo un ejemplo ilustrativo. Éste teorema no ameritaría un apéndice pues es parte normal del currículum de Electrónica, pero apéndices usualmente involucran aspectos de esta índole, que se salen de la línea de la tesis, pero que es conveniente incluir por completitud.

Los anexos contienen toda información adicional que se considere pertinente agregar, como manuales de usuario, demostraciones matemáticas que se salen de la línea principal de la tesis, pero que pueden considerarse parte de los resultados del trabajo.

# Índice alfabético

objetivos, 3