Los Metodos Numricos y La Computadora
Los Metodos Numricos y La Computadora
Los Metodos Numricos y La Computadora
PROGRAMACIÓN ESTRUCTURADA
La programación estructurada es un conjunto de reglas que desarrollan
en el programador los hábitos para lograr un buen estilo. Es bastante
flexible para permitir considerable creatividad y expresión personal, sus
reglas imponen suficientes restricciones para hacer que los programas
resultantes sean muy superiores a sus versiones no estructuradas. En
particular, el producto terminado es mucho más elegante y fácil de
entender.
La idea clave detrás de la programación estructurada es que cualquier
algoritmo numérico requiere tan sólo de tres estructuras de control
fundamentales: secuencia, selección y repetición. Limitándonos a dichas
estructuras el programa resultante será claro
y fácil de seguir.
Solución
DO
INPUT a, b, c
r1 = (—b + SQRT (b 2 — 4ac))/(2a)
r2 = (—b — SQRT (b 2 — 4ac))/(2a)
DISPLAY r1, r2
DISPLAY ‘¿Repetir? Conteste sí o no’
INPUT respuesta
IF respuesta = ‘no’ EXIT
ENDDO
PROGRAMACIÓN MODULAR
Los programas de computación se dividen en subprogramas más
pequeños, o módulos que pueden desarrollarse y probarse por
separado. A esta forma de trabajar se le llama programación modular.
La principal cualidad de los módulos es que son tan independientes y
autosuficientes como sea posible. Además, en general, están diseñados
para llevar a cabo una función específica y bien definida, y tienen un
punto de entrada y un punto de salida. Los módulos a menudo son
cortos (50 a 100 instrucciones) y están bien enfocados.
El principal elemento de programación usado para representar módulos
es el procedimiento. Un procedimiento es un conjunto de instrucciones
para computadora que juntas realizan una tarea dada.
Se emplean comúnmente dos tipos de procedimientos: funciones y
subrutinas. Las primeras normalmente dan un solo resultado, mientras
que las últimas dan varios.
Además, hay que mencionar que gran parte de la programación
relacionada con paquetes de software como Excel y MATLAB implica el
desarrollo de subprogramas. Así, los macros de Excel y las funciones de
MATLAB están diseñadas para recibir información, llevar a cabo un
cálculo y dar un resultado. De manera que el pensamiento modular
también es consistente con la manera en que se programa en
ambientes de paquetes.
Excel
Excel es una hoja de cálculo producida por Microsoft Inc. Las hojas de
cálculo son un tipo especial de software para matemáticas que permite
al usuario ingresar y realizar cálculos en renglones y columnas de datos.
Como tales, son una versión computarizada de una gran hoja de
contabilidad en la que se lleva a cabo una gran cantidad de cálculos
interrelacionados. Puesto que cuando se modifica un valor de la hoja,
hay que actualizar todos los cálculos, las hojas de cálculo son ideales
para hacer análisis del tipo.
Excel cuenta con varios recursos numéricos interconstruidos como
resolución de ecuaciones, ajuste de curvas y optimización. Incluye
también VBA como un lenguaje de macro que sirve para hacer cálculos
numéricos. Por último, tiene varias herramientas
para la visualización como diagramas y gráficas tridimensionales, que
son un valioso complemento para el análisis numérico.
MATLAB
MATLAB es el principal producto de software de Mathworks, Inc.,
fundada por los analistas numéricos Cleve Moler y John N. Little. Como
su nombre lo indica, MATLAB se desarrolló originalmente como un
laboratorio para matrices. Hoy, el elemento principal de MATLAB sigue
siendo la matriz. La manipulación matemática de matrices se ha
realizado muy adecuadamente en un ambiente interactivo fácil de
utilizar. A esta manipulación matricial, MATLAB agrega varias funciones
numéricas, cálculos simbólicos y herramientas para visualización. En
consecuencia, la versión actual representa un ambiente computacional
bastante amplio.
Además, se pueden escribir programas como los llamados archivos M (
m-files) que sirven para realizar cálculos numéricos.
Seudocódigo Matlab
IF condición THEN if b ~= 0
Bloque verdadero r1 = —c / b;
ENDIF end
IF condición THEN if a < 0
Bloque verdadero b = sqrt(abs(a));
ELSE else
Bloque falso b = sqrt(a);
ENDIF end
Inicio
entero i=0
flotante tempo, e
doble funcionData(doble x)
retorno cos(x) - pow(x,3)
fin funcion(funcionDada)
doble derivadaFuncionDada(doble x)
reorne -sin(x) - (3.0*x*x)
fin funcion(derivadaFuncionDada)
leer x
Haga
tempo=x
x=x-funcionData(x)/derivadaFuncionDada(x)
e=absoluto((x-tempo)/x)
Imprima "x",i, "=",x, "error", "=",e
i=i+1
Mientras(x<>tempo y i<100
Si(i==100)Entonces
Imprima "No converge"
sino
Imprima x
Fin si
Fin