Código de Python - Regla de Simpson

sin imagen de perfil

Regla de Simpsongráfica de visualizaciones


Python

Publicado el 19 de Abril del 2013 por Abraham (21 códigos)
29.733 visualizaciones desde el 19 de Abril del 2013
Código que ejecuta la Regla de Simpson para Integración Numérica. El usuario ingresa n puntos conocidos, y el valor del codominio para los puntos medios que se necesitan para la regla entre cada par de puntos conocido se obtiene mediante Interpolación de Lagrange. Utiliza Numpy 1.7.0 para interpolación.
Escrito en Python 2.7.3

Versión 1

Publicado el 19 de Abril del 2013gráfica de visualizaciones de la versión: Versión 1
29.734 visualizaciones desde el 19 de Abril del 2013
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
# -*- coding: UTF-8 -*-
 
# REGLA DE SIMPSON
# Abraham Teran
 
import numpy as np
 
def prod(A):
    a = 1
    for i in range(len(A)):
        a = a*A[i]
    return a
 
def lagrange(A,n):
    results = []
    lfun = np.arange((len(A[0]))**2,dtype=float)
    lfun.shape = (len(A[0]),len(A[0]))\
 
    for i in range(len(A[0])):
        for j in range(len(lfun)):
            if i == j:  lfun[i,j] = 1
            else:   lfun[i,j] = (n-A[0][j])/(A[0][i]-A[0][j])\
 
    for i in range(len(A[1])):
        results.append(prod(lfun[i])*A[1][i])\
 
    return sum(results)
 
def main():
    cantPoints = input("Ingrese cantidad de puntos conocidos> ")\
 
    if cantPoints < 2:
        print "\nCANTIDAD DE PUNTOS CONOCIDOS >= 2\n"
        main()\
 
    integs = []
    points = [[],[]]
    midPoints = [[],[]]\
 
    for i in range(cantPoints):
        print "\n( x",i,",y",i,")"
        x = float(input("Ingrese 'x'> "))
        y = float(input("Ingrese 'y'> "))
        points[0].append(x)
        points[1].append(y)\
 
    for i in range(len(points[0])-1):
        midPoints[0].append((points[0][i+1]+points[0][i])/2)
        midPoints[1].append(lagrange(points,midPoints[0][i]))\
 
    for i in range(len(midPoints[0])):
        intg = ((points[0][i+1]-points[0][i])/6)*\
               (points[1][i]+(4*midPoints[1][i])+points[1][i+1])
        integs.append(intg)\
 
    print "\n\tIntegral: ",sum(integs)
    raw_input()
 
print "\n\tREGLA DE SIMPSON\n\n"
main()



Comentarios sobre la versión: Versión 1 (0)


No hay comentarios
 

Comentar la versión: Versión 1

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s2358