Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-11-2008, 22:30   #1
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
[Python]Trapezium rule

A parte l'orrida forma(che poi si puo sistemare).
Sto cercando di creare una funzione per la regola del trapezio di integrazione numerica.
con k=1,..,n


Codice PHP:
#!/usr/bin/env python 

def trapezium_rule(fab):
  
"Approximate the definite integral of f from a to b by Trapezium rule." 
  
return (a) * ((f(a) + f(b))/2)
  
"Approximate the definite integral of f from a to b(subdivided) by Trapezium rule. n is the numbers of partitions "  
def trapezium_plus(f,a,b,n):    
  
= (b-a)/2*
  res 

  x 
= {0:0}
  
  for 
i in range(1n):
      
tmp i*((b-a)/n)
      
x[i]= tmp
      
  x
[1] = f(x[1])
  
x[n] = f(x[n])
  
  for 
j in range(2n-1):
      
x[j] = f(x[j])    
      
  
out 0
  
  
for k in range(1n):
       
out += x[k]
       
  
res z*out    
  
return res
    
from math import sin
from math import pi
print 'BEGIN'
print 'integral of sin(x) from 0 to 2*pi:\n'
print '\n'
print trapezium_plus(sin02*pi30)
print 
'END' 
Il risultato che mi esce è però

Codice:
BEGIN
integral of sin(x) from 0 to 2*pi:



Traceback (most recent call last):
  File "trapezium.py", line 37, in <module>
    print trapezium_plus(sin, 0, 2*pi, 30)
  File "trapezium.py", line 19, in trapezium_plus
    x[n] = f(x[n])
KeyError: 30
Dove sbaglio??

Grazie
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go

Ultima modifica di The_ouroboros : 28-11-2008 alle 22:35.
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2008, 22:49   #2
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
in metacodice sarebbe:

Codice:
FUNCTION trapez(f,a,b,n)
  z = (b-a)/2*n
  FOR i=1:n
    x(i)=a+i*((b-a)/n)
  END
  res = f(x(1))+f(x(n))
  FOR i=2:n-1
    res = res + f(x(i))
  END
  res = res*z
RETURN res
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2008, 23:20   #3
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Prova così:
Codice:
def trapez(f, a, b, n):
  z = (b - a) / 2 * n
  for i in xrange(1, n + 1):
    x[i] = a + i * ((b - a) / n)
  res = f(x[1]) + f(x[n])
  for i in xrange(2, n):
    res += f(x[i])
  return res * z
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2008, 23:32   #4
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
grazie... mi ero un po impantanato in una cavolata
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2008, 23:41   #5
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Codice:
#!/usr/bin/env python 

def trapezium_rule(f, a, b):
  "Approximate the definite integral of f from a to b by Trapezium rule." 
  return (b - a) * ((f(a) + f(b))/2)
  
"Approximate the definite integral of f from a to b(subdivided) by Trapezium rule. n is the numbers of partitions "  
def trapezium_plus(f,a,b,n):	
  z = (b-a)/2*n 
  res = z 
  x = {0:0}
  
  for i in range(1, n+1):
  	x[i]= a + i*((b-a)/n)
  	
  res = f(x[1]) + f(x[n])
  
  for j in range(2, n):
  	x[j] = 2 * f(x[j])	
  
  for k in range(1, n):
  	 res += x[k]	
  	 
  return res * z
  
"by cdimauro"    
def trapez(f, a, b, n):
  x = {0:0}
  z = (b - a) / 2 * n
  for i in xrange(1, n + 1):
    x[i] = a + i * ((b - a) / n)
  res = f(x[1]) + f(x[n])
  for i in xrange(2, n):
    res += f(x[i])
  return res * z
	
from math import sin
from math import pi

n = input ('Number of iteration?')
print 'BEGIN'
print '\nWith', n, ' iteration'
print '\nIntegral of sin(x) from 0 to 2*pi(ref from Simpson):\t 2.5648942583e-16'
print '\nIntegral of sin(x) from 0 to 2*pi(trapezium_plus):\t' , trapezium_plus(sin, 0, 2*pi, n)
print '\nIntegral of sin(x) from 0 to 2*pi(trapez):\t' , trapez(sin, 0, 2*pi, n)
print '\nEND'
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go

Ultima modifica di The_ouroboros : 28-11-2008 alle 23:52.
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
EcoFlow, il Black Friday porta grande ri...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 21:20.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v