jueves, 27 de febrero de 2020

Métodos numéricos y optimización: Método de la sección dorada


Este método de optimización es similar al método de Fibonacci, con la excepción que en el método de Fibonacci, el número total de experimentos a realizarse debe especificarse antes de iniciar el cálculo y para el cálculo de estos se utiliza la serie de números de Fibonacci.

En este método se inicia con N, el cual se asume como el número de experimentos que se han de llevar a cabo, hasta que se cumpla el diferencial establecido.

Procedimiento
1. Determinar el valor inicial XL y el valor final XU. Donde XL es el punto inferior del intervalo de búsqueda y XU es el punto superior. [XL, XU]

2. Calcular los puntos interiores X1 y X2 del intervalo de búsqueda.
X1=XL+d
X2=XU-d
d=0.618*(XU-XL)

0.618 es conocido como una de las soluciones de la proporción dorada o número áureo. De aquí proviene el nombre del método.

3. Evaluar la FO en X1 y en X2.

4. Repetir el método hasta |f(x1)-f(x2)|<error

En cada iteración se deben aplicar estas reglas para reducir el intervalo de búsqueda del punto óptimo.

Si f(x1)>f(x2) entonces el dominio de x a la izquierda de X2, [XL, X2] se puede eliminar, ya que no contiene el máximo. En este caso X2 será el nuevo XL en la siguiente iteración.

Si f(x2)>f(x1) entonces el dominio de x a la derecha de X1, [X1, XU] se puede eliminar, ya que no contiene el máximo. En este caso X1 será el nuevo XU en la siguiente iteración.

El siguiente ejercicio ejemplifica el uso del método utilizando EXCEL:

Considere la función: F(x)= 2*sen(x)-(x^2)/10 en el intervalo [0,4] con error=0.2




Métodos numéricos y optimización: Newton-Kantorovich

El método de Newton es un método numérico que se utiliza para encontrar ceros de una función. Sea F una función con dominio en todos los reales. Un punto x también perteneciente al dominio de los reales será un cero de F si: F(x)=0

El pseudocódigo para el método de Newton-Kantorovich es el siguiente:

Tomado de: https://www.u-cursos.cl/ingenieria/2010/2/MA3701/1/material_docente/bajar?id_material=329674

El siguiente ejercicio ejemplifica el uso del método: Considerese la siguiente función :
F(x)=(x^2)/2-Sen(x) con punto inicial X0=0.5 y con Error=0.00001

La plantilla de EXCEL con las ecuaciones y los resultados obtenidos es la siguiente:




Este método se puede aplicar a la búsqueda de los ceros del gradiente de una función con dominio en todos los reales. Es decir, se buscan los puntos estacionarios de la función.






Métodos numéricos y optimización: Técnica de búsqueda multivariable


Técnicas de búsqueda multivariable

Sea f(x1, x2,…, xn) donde x1, x2, ... y xn son variables de decisión, la técnica de búsqueda multivariable hace lo siguiente:

1. Se le asignan valores iniciales (x1, x2,..., xn) a las variables de decisión, configurando el punto inicial de salida.
Configurandose (x10, x20,…, xn0) como puntos iniciales.

2. Buscar por medio de un tanteo o aleatoriamente, valores desde el punto de partida hasta llegar a valores que optimicen la función objetivo.

3. Dependiendo del objetivo el cual puede ser: maximizar, minimizar, encontrar los ceros de la función, se asignan nuevos valores y se comparan las funciones objetivo, así:
Sí: 
f(x10, x20, x30)<= f(x11,x21,x31) 
f(x10, x20, x30)>= f(x11,x21,x31)

Se tiene el siguiente ejemplo en VBA:
Se quiere encontrar los puntos y el valor de la FO que maximizan la siguiente función:
f(x1,x2,x3)= (10 / 3) * x1 - (3 * x1 * x2) + (5 * x3 ^ 2) + (4 * x2)

Se puede programar el código VBA para hallar un basto conjunto de puntos en el espacio de la función de la siguiente manera:



La plantilla de EXCEL a utilizar estaría construida de la siguiente manera:


En este caso, bajo las condiciones del programa VBA, se generarían un total de 218 registros.

Este método analiza un rango amplio de datos que dependen de los intervalos de las variables en los ciclos FOR_NEXT.

En caso que se requiera encontrar el mínimo se debe programar la línea de reemplazo:
Application.WorksheetFunction.Min(Range("A3:D1000000"))

miércoles, 19 de febrero de 2020

Método para el planteamiento y desarrollo de problemas de programación

Desarrollo de un programa (software)

  1. Metodologías tradicionales: con énfasis en la planificación y el control en procesos predictivos y fijos.
  2. Metodologías ágiles: Se sugieren cuando los requisitos son desconocidos o cambiantes, se requieren en procesos adaptativos.
Etapas:

1. Identificación y delimitación del problema: Entendimiento de las necesidades del cliente.

Capturar los requisitos y requerimientos del software.
Elicitación de requisitos, entendido como el traspaso de información entre personas por medio de un lenguaje natural).

2. Diseño del programa: Codificar en lenguaje estructurado los requisitos (fase previa de desarrollo de software).

3. Desarrollo o codificación en un entorno de programación: Se debe garantizar que el programa diseñado este limitado, es decir con pasos finitos y definido, quiere decir que al ejecutar el programa en la mismas condiciones debe arrojar el mismo resultado.

4. Pruebas o Testing: Simulaciones del comportamiento de un algoritmo que permiten determinar la validez del mismo.


Programación estructurada

Programación estructurada:Técnicas para desarrollar algoritmos fáciles de escribir, verificar, leer y modificar. Utiliza:

  • Diseño descendente: etapas, de lo general al detalle.
  • Recursos abstractos: descomposición del problema.
  • estructuras básicas: secuenciales, selectivas, repetitivas y anidadas.
1. Estructuras secuenciales: Una acción se ejecuta detrás de la otra.

Pseudocódigo:
<acción 1>
<acción 2>
<acción 3>
<acción 4>
...
<acción N>

2. Estructuras selectivas: Una acción o acciones que deben cumplir una condición. Son de tipo:
  • Simples: Se cumple una condición, si no salta las acciones.
Pseudocódigo:
Si <Condición> entonces
     <Acción>
Fin Si
  • Dobles: Se evalúa una condición como verdadero o falso.
Pseudocódigo:
Si <Condición> entonces
     <Acción 1>
Si no
     <Acción 2>
Fin Si
  • Múltiples: Se ejecutarán una acciones u otras según el resultado que se obtenga al evaluar una expresión.
Pseudocódigo:
Según sea <Expresión> hacer
     <acción 1>
     <acción 2>
     <acción 3>
     <acción 4>
Si no
     <Acción N>
Fin Según

3. Estructuras repetitivas: Las acciones se repiten mientras o hasta que se cumpla una condición. Las cuales son:
  • Mientras: Las acciones del bucle se realizan cuando la condición es cierta. Además, se pregunta por la condición al principio, de donde se deduce que dichas acciones se podrían ejecutar N veces.
Pseudocódigo:
Mientras <Expresión lógica> hacer
     <Acciones>
Fin mientras
  • Hasta: Las acciones del interior del bucle se ejecutan una vez y continúan repitiendose mientras que la condición sea falsa. Se interroga por la condición al final del bucle.
Pseudocódigo:
Repetir
     <Acciones>
Hasta que <Expresión lógica>
  • Desde: Se utiliza cuando se conoce el número de veces que se va a iterar. La estructura "desde" comienza con un valor inicial y las acciones se ejecutan a menos que el valor inicial sea mayor que el valor final.
Pseudocódigo:
Desde valor<---valor inicial hasta valor final hacer
     <Acciones>
Fin desde

4. Estructuras anidadas: Tanto las estructuras selectivas como repetitivas pueden ser anidadas, e introducidas una al interior de otras.

Pseudocódigo:
Si <Condición 1> entonces
     <Acción 1>
Si no
     Si <Condición 2> entonces
          <Acción 2>
     Si no
          Si <Condición 3> entonces
              <Acción 3>
          Si no
             <Acción n>
         Fin Si
     Fin Si
Fin Si

jueves, 13 de febrero de 2020

Métodos numéricos y optimización: Método de la secante

Método de la secante

El método de Newton para minimizar F utiliza la segunda derivada de F, de esta forma:
Si la segunda derivada no esta disponible, se puede intentar aproximar utilizando la información. En particular, se puede aproximar la segunda derivada con:


A esto se le conoce como el método de la secante, note que la ecuación requiere 2 puntos iniciales para empezar, para lo cual se denota X(-1) y X0, el algoritmo puede ser representado como:

El método de la secante usa la secante entre el punto (k-1) y el punto k para determinar el punto (k+1).

Ejercicio de aplicación
1. Utilizar el método de la secante para encontrar el punto mínimo de la función:
F(X)=X^3-12,2X^2+7,45X+42
Los valores iniciales son X0=12 y X(-1)=13 con una precisión de 10^(-5)

Como estrategia de solución de problemas a través del método de la secante, se recomienda construir la siguiente tabla en EXCEL para aplicar la técnica.


Una propuesta en VBA para solucionar el ejercicio con base en la plantilla sugerida puede ser la siguiente:





Métodos numéricos y optimización: Método de Newton

Método de Newton

Suponga que se tiene un problema con una función para una única variable x. Se asume que cada punto Xk puede ser calculado en F(Xk), F'(Xk) y F''(Xk). Se puede ajustar una función cuadrática a través de Xk que se acople a su primera y segunda derivada, esta función cuadrática es de la forma: 



Entonces en vez de optimizar F, se optimiza su aproximación Q, por lo tanto la condición de primer orden necesaria para optimizar Q es:



El pseudocódigo para este método es el siguiente:


El método de Newton también termina el procedimiento si se cumple la condición:
Valor absoluto(X(k+1)-Xk)<Error

Ejercicio de aplicación
1.Utilizar el método de Newton para encontrar el punto mínimo de la función:
F(X)=((X^2)/2)-sen(x)
El valor inicial es X0=0,5 con una precisión de 10^(-5)

2. Utilizar el método de Newton para encontrar el punto mínimo de la función:
F(X)=X^3-12,2X^2+7,45X+42
El valor inicial es X0=12 con una precisión de 10^(-5)

Para la solución de ejercicios por el método de Newton se sugiere utilizar el siguiente formato de tabla en EXCEL.



Se puede proponer un algoritmo en VBA para solucionar el ejercicio 1 a través de la tabla presentada con anterioridad:


Ejercicios adicionales método de Newton.





lunes, 10 de febrero de 2020

Métodos numéricos y optimización: Método de bisección

Método de bisección

En este método, la mitad del intervalo de incertidumbre es eliminado en cada iteración o paso. Se requieren 3 experimentos en el primer paso o iteración y 2 experimentos en pasos subsiguientes. Para desarrollar este método se tienen los siguientes pasos a continuación:

1. Dividir el intervalo inicial Lo=[a,b] en 4 partes iguales. Donde X0 es el punto medio y X1 y X2 son puntos de ese cuarto.

2. Evaluar la función f(x) en los 3 puntos interiores del intervalo X1, X0 y X2, es decir:
  • f1=f(X1)
  • f0=f(X0)
  • f2=f(X2)
3. Se deben evaluar los siguientes casos en los cuales se debe decidir que parte del intervalo se eliminara:
  • Si f2>f0>f1 entonces se elimina el intervalo [X0, b], por lo tanto X1=X0 y X0=b
  • Si f2<f0<f1 entonces se elimina el intervalo [a,X0], por lo tanto X0=a y X2=X0
  • Si f1>f0 y f2>f0 entonces se eliminan los intervalos [a,X1] y [X2,b] entonces X1=a y X2=b
4. Probar el nuevo intervalo L=b-a que satisfaga el criterio de convergencia L<=Error, si converge se detiene el procedimiento, de lo contrario L=Lo y se regresa al paso 1 del procedimiento.

El siguiente es un ejercicio de ejemplo, que ayudará a entender mejor la aplicación de el método:

Hallar el mínimo de la función objetivo f(x)=x(x-1.5) en el intervalo [0,1], con un 10% de exactitud del valor.

El método de bisección es un método más complejo que la búsqueda exhaustiva, requiere un conjunto más amplio de pruebas y cálculos más extensos. Por lo tanto, para estructurar una base para el algoritmo, se trazará un plan de posición de todas las variables respectivas en la hoja de calculo de EXCEL.
Este plan se compone de los siguientes elementos:
las variables a,b y error están en las celdas B2, B3 y B4 respectivamente y son las celdas de entrada del sistema.
En la fila 5 se tienen las etiquetas de resultados:
Valor puntos: es el valor de la partición del intervalo en 4 partes.
Iteración: cada paso que realiza el algoritmo.
a, x1, x0, x2 y b son los puntos x del intervalo de evaluación del óptimo.
F(x1), F(x2) y F(x0) es la función objetivo evaluada en cada punto del intervalo.
Decisión: evalúa el criterio de convergencia.
Caso: es cada opción para la eliminación de una parte del intervalo (ver paso 3 del procedimiento).


El algoritmo en VBA es el siguiente, nótese que se definen 4 variables y se les asigna una posición en la hoja. La fila 6 se programa por fuera del ciclo FOR_NEXT.





El resultado una vez implementado el algoritmo es el siguiente:





Métodos numéricos y optimización: Búsqueda exhaustiva

Búsqueda Exhaustiva

Este método puede ser utilizado para resolver problemas donde el intervalo en el cual se encuentra el punto óptimo es conocido y es finito.

Si se definen dos puntos: un punto inicial y un punto final en el intervalo de incertidumbre donde se cree esta el óptimo, el método de búsqueda consiste en evaluar la función objetivo en un número predeterminado de puntos equiespaciados en este intervalo.

En general, si la función es evaluada en n-puntos equiespaciados en el intervalo que se denotará como Lo=punto final - punto inicial, entonces el punto óptimo que satisface la función se denotará como Xj.

Si la función es evaluada en todos los n-puntos simultáneamente, este método puede ser llamado método de búsqueda simultánea.

El siguiente es un ejercicio de ejemplo, que ayudará a entender mejor la aplicación de el método:

Hallar el mínimo de la función objetivo f(x)=x(x-1.5) en el intervalo [0,1], con un 10% de exactitud del valor.

En EXCEL se puede construir una herramienta simple que ayude con esta situación. Para ello, se deben generar varias posiciones clave: Exactitud del valor celda (B2), Valor de a celda (B3) y Valor de b celda (B4). estos serán los valores de entrada para el método.

Por otro lado en la fila 5, se generarán los títulos de los resultados que se esperan.


Tras realizar un pequeño programa en VBA, se consiguen los resultados para esta función.


Note por favor, que se requiere definir 4 variables,  la ubicación de los valores del error, a y b debe ser explícita y asignada por el valor de la celda a la que pertenece.
De igual forma, se requiere un ciclo FOR_NEXT para rellenar las columnas A, B y C con las soluciones de búsqueda.
En medio del ciclo se encuentra la función a la cual se le aplica el método de búsqueda. El método termina cuando alcanza el límite superior y es cuando se busca el máximo o el mínimo requerido para la función. Esto se puede lograr implementando dentro del código una función +max() o +min() que hallé dichos valores.



Ejercicios de método de bisección que se pueden resolver por método de búsqueda exhaustiva.


sábado, 8 de febrero de 2020

Introducción a los métodos numéricos y optimización

¿Qué son los métodos numéricos?

Los métodos numéricos constituyen unas técnicas o algoritmos mediante las cuales es posible obtener soluciones numéricas de un problema matemático en diversas áreas.

¿Para qué sirven los métodos numéricos?

  1. Son herramientas poderosas para la solución de problemas (manejo de sistemas de ecuaciones grandes, manejo de no linealidades y solución de geometrías complicadas).
  2. Posibilidad de solución de problemas mediante paquetes, o permite el propio diseño de programas
  3. Medio para reforzar la comprensión de las matemáticas y su aplicación en un campo.

¿Qué problemas se pueden resolver con los métodos numéricos?
  • Raíces de ecuaciones
  • Sistemas de ecuaciones algebraicas lineales
  • Problemas de optimización
  • Ajuste de curvas
  • Otros métodos de integración, diferenciación y ecuaciones diferenciales

Áreas posibles de aplicación de los métodos numéricos
  • Transferencia de calor
  • Operaciones unitarias
  • Modelación de sistemas físicos y sociales
  • Análisis de series de tiempo y comportamientos
  • Problemas aplicados a la industria y a la economía
¿Qué es un modelo matemático?

Se define como una formulación o ecuación que expresa las características esenciales de un sistema físico o de un proceso en términos matemáticos. Consiste en la definición de una variable dependiente y n-números de variables independientes en su expresión. 
La variable Y es la característica que refleja el estado de un sistema, mientras que las variables X reflejan las propiedades de sistema en términos de dimensiones de tiempo o espacio, son todas las que actúan sobre el sistema.

Características de un modelo matemático
  • Describe un proceso o sistema natural en términos matemáticos.
  • Representa una idealización y una simplificación de la realidad. Es decir, ignora los detalles insignificantes del proceso y se concentra en manifestaciones esenciales.
  • Finalmente, conduce a resultados reproducibles y, en consecuencia, llega a emplearse con la finalidad de predecir.
Soluciones analìticas y numéricas
  1. Solución analítica: Se tiene un modelo matemático simple y se pueden aplicar técnicas matemáticas del calculo, trigonometría y otras, para encontrar la solución y saber cómo se comporta el modelo.  
  2. Solución numérica: Para modelos complejos, con muchas variables, es difícil de encontrar su solución por vía analítica, se aplican métodos específicos los cuales encuentran un número aproximado de la solución.






Funciones básicas en EXCEL

La celda en EXCEL

Una celda en Excel es la intersección de una fila y una columna. Una celda puede contener texto, números, fecha, instrucciones, funciones u otros datos. También se puede combinar el cálculo con datos o instrucciones dispuestas en otras hojas del libro.
Fijar celdas en Excel: Para fijar celdas en Excel se debe añadir el carácter $ (F4) $A$1
  • Si el carácter se ubica solo al lado izquierdo de la fila, se bloquea la fila pero no la columna (A$1)
  • Si el carácter se ubica solo al lado izquierdo de la columna, se bloquea solo la columna no la fila ($A1)
Operadores matemáticos


Funciones en EXCEL

1. SUMA: La función SUMA, una de las funciones matemáticas y trigonométricas, suma valores. Puede sumar valores individuales, referencias o rangos de celda o una combinación de las tres. Por ejemplo:
=SUMA(A2:A10)
=SUMA(A2:A10, C2:C10)

2. SI: Comparaciones lógicas entre un valor y lo que se espera. Por esto, una instrucción SI puede tener dos resultados. El primer resultado es si la comparación es Verdadera y el segundo si la comparación es Falsa.
Por ejemplo, =SI(C2="Sí",1,2)

3. Si. Error: SIERROR(valor; valor_si_error)
La sintaxis de la función SI.ERROR tiene los siguientes argumentos:
Valor  Obligatorio:Es el argumento donde busca un error.
Valor_si_error: Obligatorio. Es el valor que se devuelve si la fórmula se evalúa como un error. Se evalúan los tipos de error siguientes: #N/A, #¡VALOR!, #¡REF!, #¡DIV/0!, #¡NUM!, #¿NOMBRE? o #¡NULO!.

4. BUSCARV o CONSULTARV, una de las funciones de buscar y de referencia, cuando necesite buscar elementos de una tabla o un rango por fila.
Hay cuatro partes de la información que necesita para crear la sintaxis de BUSCARV:
  • El valor que desea buscar, también conocido como el valor de búsqueda.
  • El rango donde se encuentra el valor de búsqueda. Recuerde que el valor de búsqueda debe estar siempre en la primera columna del rango para que BUSCARV funcione correctamente.
  • El número de columna del rango que contiene el valor devuelto. Por ejemplo, si especifica B2: D11 como el rango, B se debe contar como la primera columna, C como la segunda y así sucesivamente.
  • Opcionalmente, puede especificar VERDADERO si desea una coincidencia aproximada o FALSO si desea una coincidencia exacta del valor devuelto. Si no especifica nada, el valor predeterminado siempre será VERDADERO o la coincidencia aproximada.
5. Funciones matemáticas

Ejercicio
Con el fin de clasificar el sorgo, como materia prima utilizada en una industria procesadora de alimentos balanceados para animales, para un bache de 3 toneladas. La materia prima es clasificada de acuerdo a su composición proteica, como: óptima con una composición entre el 11 y 15%, aceptable con una composición entre el 10 y 7%, y pésima con una composición inferior al 6%. La materia prima clasificada como pésima, y cuya composición es superior al 4%, se realiza un mezclado con otros granos, para que finalmente sea clasificada como aceptable, y posteriormente, pueda ser utilizada en el proceso productivo.

En el siguiente vídeo se puede ver una aplicación de las diferentes funciones en EXCEL.


Diagramas de flujo

Definición

Un diagrama de flujo u organigrama es una representación diagramática que ilustra la secuencia de las operaciones que se realizarán para conseguir la solución de un problema. Estos diagramas de flujo desempeñan un papel vital en la programación de un problema y facilitan la comprensión de problemas complicados.
Es la presentación gráfica de sistemas, es una forma ampliamente utilizada como herramienta de  análisis,  ya que permite identificar aspectos relevantes de una manera rápida y simple.

El diagrama de flujo representa la forma más tradicional para especificar los detalles algorítmicos de un proceso.
Características y ventajas
  • Es una representación gráfica de las secuencias de un proceso, presenta información clara, ordenada y concisa.
  • Permite visualizar las frecuencias y relaciones entre las etapas indicadas.
  • Se pueden detectar problemas, desconexiones, pasos de escaso valor añadido etc.
  • Compara y contrasta el flujo actual del proceso contra el flujo ideal, para identificar oportunidades de mejora.
  • Identifica los lugares y posiciones donde los datos adicionales pueden ser recopilados e investigados.
  • Ayuda a entender el proceso completo.
  • Permite comprender de forma rápida y amena los procesos. 


  Procedimiento
  • Establecer el alcance del proceso a describir. De esta manera quedará fijado el comienzo y el final del diagrama.
  • Identificar y listar las principales actividades/subprocesos que están incluidos en el proceso a describir y su orden cronológico.  Si el nivel de detalle definido incluye actividades menores, listarlas también.  
  • Identificar y listar los puntos de decisión. 
  • Construir el diagrama respetando la secuencia cronológica y asignando los correspondientes símbolos.
  • Asignar un título al diagrama y verificar que esté completo y describa con exactitud el proceso elegido. 
Reglas de los diagramas de flujo


  1. Deben escribirse de arriba hacia abajo, y/o de izquierda a derecha.
  2. Los símbolos se unen con líneas, las cuales tienen en la punta una flecha que indica la dirección que fluye la información procesos
  3. Se debe evitar el cruce de líneas, para lo cual se quisiera separar el flujo del diagrama a un sitio distinto, se pudiera realizar utilizando los conectores
  4. No deben quedar líneas de flujo sin conectar
  5. Todo texto escrito dentro de un símbolo debe ser legible, preciso, evitando el uso de muchas palabras.
  6. Todos los símbolos pueden tener más de una línea de entrada, a excepción del símbolo final.
  7. Solo los símbolos de decisión pueden y deben tener más de una línea de flujo de salida.
Simbología

Ejemplos

1.Realizar un diagrama de flujo en donde se pide la edad del usuario. Si es mayor de edad se debe indicar que lo es.

2.Realizar un diagrama de flujo en donde se pide a un sistema un número al azar entre 1 y 6, y se lanza un dado. Si ambos números son iguales indicar acierto, sino desacierto.


3.Realizar un diagrama de flujo donde se indique cuál de dos números es el mayor.
Ejercicios con diagramas de flujo

1. Se pide leer tres notas del alumno, calcular su definitiva en un rango de 0-5 y enviar un mensaje donde diga si el alumno aprobó o reprobó el curso.

2. Se desea escribir un algoritmo que pida la altura de una persona, si la altura es menor o igual a 150 cm envíe el mensaje: Persona de altura baja; si la altura está entre 151 y 170 escriba el mensaje: Persona de altura media y si la altura es mayor al 171 escriba el mensaje: Persona alta.

3. Dados N valores, diseñe un algoritmo que haga el siguiente proceso:

Si el valor es menor que cero calcular su cubo.
Si el valor está entre 0 y 100 calcular su cuadrado.
Si el valor está entre 101 y 1000 calcular su raíz cuadrada.

4. Elaborar un algoritmo que muestre los enteros desde 1 hasta N y sus cuadrados, calculados solamente con sumas.

5. Partiendo de la función Y = 7X!, elaborar un algoritmo que calcule todos los posibles valores de Y, sabiendo que X puede tomar el valor de cualquier múltiplo entero de 7 en el rango [0,1000].

6. Un vendedor desea calcular la comisión total sobre la venta de varios artículos. Al vendedor le corresponde el 10% de comisión sobre artículos, cuyo precio es menor o igual a $1.000 y el 7% de comisión sobre aquellos artículos cuyo precio sea mayor de $1.000. Elabore un algoritmo para obtener la comisión total, si se conoce que el vendedor hizo N ventas.

7. Se desea obtener el promedio de notas de N grupos que están en un mismo año escolar, sabiendo que cada grupo puede tener M alumnos, cada alumno puede cursar K materias y en todas las asignaturas se promedian tres calificaciones. Hacer un algoritmo que calcule el promedio de cada alumno, el promedio de cada grupo y el promedio de los grupos.

8. Hacer un algoritmo que ordene ascendentemente los números N1, N2, N3, N4, N5 ingresados por un usuario.

9. Dados 3 números, deducir cuál es el central.

10. Calcular la raíz cuadrada de un número y escribir su resultado.

11. Determinar el precio de un billete de ida y vuelta en bus, conociendo la distancia a recorrer y sabiendo que si el número de días de estancia es superior a siete y la distancia superior a 800 kilómetros, el billete tiene una reducción del 30%. El precio por kilómetro es de $250.

12. Se desea realizar una estadística de los pesos de los alumnos de un colegio de acuerdo a la siguiente tabla:
Alumnos menos 40 kg
Alumnos entre 40 kg y 50 kg
Alumnos entre 50 kg y 60 kg
Alumnos superior a 60 kg
La entrada de los pesos de los alumnos se terminará cuando se introduzca el valor -99. Se desea obtener cuántos alumnos hay en cada una de las filas.

13. Hacer un diagrama de flujo y escribir un pseudocódigo para el acto de lavar los platos de una comida.

14. Hacer un diagrama de flujo y escribir un pseudocódigo para realizar una llamada telefónica desde un teléfono público.

15. Hacer un diagrama de flujo y escribir un algoritmo que calcule la superficie de un triángulo en función de su base y su altura.

16. Hacer un diagrama de flujo y escribir un pseudocódigo que permita emitir la factura correspondiente a una compra de un artículo determinado del que se adquieren una o varias unidades. El IVA a aplicar es del 19% y si el precio bruto (precio venta * (1 + IVA)) es mayor a $100000, se aplicará un descuento del 5%.



Covid 19 Práctica Rmarkdown

covid covid Julian Uribe 2023-12-05 ## ── Attaching core tidyverse...