Skip to content

LovisottoSantiago/TPF_CTEDyA_COM1_LovisottoSantiago

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Trabajo Final: Complejidad Temporal, Estructura de Datos y Algoritmos | UNAJ

Este proyecto corresponde al Trabajo Final de la materia "Complejidad Temporal, Estructura de Datos y Algoritmos" de la Universidad Nacional Arturo Jauretche, realizado durante el 2do año de la carrera Ingeniería en Informática. Los invito a leer los archivos "ENUNCIADO, INFORME Y PRESENTACIÓN", incluídos en el repositorio.

Descripción del Proyecto

El objetivo principal fue desarrollar una aplicación que permita gestionar procesos simulados utilizando estrategias de planificación de CPU. El sistema implementa algoritmos de planificación basados en estructuras de datos Heaps, diseñadas para soportar las operaciones requeridas por los algoritmos Shortest Job First (SJF) y Preemptive Priority Scheduling (PPCSA), el trabajo ya nos brinda la estructura general del sistema y el front-end.

Funcionalidades

  1. Carga de Dataset (incluída en el trabajo): Permite seleccionar un archivo en formato .csv con los datos de procesos (nombre, tiempo de CPU, prioridad).
  2. Algoritmos de Planificación (implementadas):
    • SJF: Utiliza una MinHeap para ejecutar los procesos con menor tiempo de CPU primero.
    • PPCSA: Utiliza una MaxHeap para priorizar procesos con mayor prioridad.
  3. Consultas (implementadas):
    • Consulta 1: Obtiene las hojas de las Heaps generadas.
    • Consulta 2: Calcula la altura de las Heaps mediante operadores de desplazamiento.
    • Consulta 3: Muestra los procesos organizados por niveles dentro de las Heaps.
  4. Simulación Gráfica (incluída en el trabajo): Visualización del estado de ejecución para 1 o 5 CPUs.
  5. Reinicio del Sistema (incluída en el trabajo): Permite reiniciar la simulación para realizar nuevas configuraciones.

Capturas del proyecto

Pantalla de Inicio Selección de Archivo Simulación con 5 CPUs Consulta 1 Pantalla de Reinicio

Implementación

Estructuras de Datos

  • Heap Genérica: Implementación eficiente que unifica MinHeap y MaxHeap (se selecciona el tipo mediante un bool en el constructor), eliminando redundancia.
    • Métodos principales: ConstruirHeap, Heapify, Insertar, Eliminar, EsVacia, Tamaño.
    • Basado en un árbol binario completo, garantizando una complejidad O(log N) para operaciones críticas.

Lógica de Cálculo

  • Elegí usar operadores de desplazamiento para calcular logaritmos en vez de utilizar Math.log(), mejorando la eficiencia y compatibilidad.

Pantallas de la Aplicación

  • Inicio: Selección de archivo .csv.
  • Simulación: Visualización de CPUs y resultados de planificación.
  • Consultas: Visualización detallada de las hojas, alturas y niveles de las Heaps.

Tecnologías Utilizadas

  • Lenguaje: C#
  • Frameworks: .NET
  • Herramientas Gráficas: Windows Forms

Conclusión

Este proyecto permitió afianzar conocimientos sobre estructuras de datos y algoritmos de planificación. La implementación de Heaps genéricas optimizó el diseño, facilitando la expansión futura y mejorando la eficiencia del sistema.

Referencias

About

Trabajo final de la materia CTEDyA UNAJ.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages