Metodi Numerici Flashcards
def metodo_bisezione(fname, a, b, tolx,tolf):
“””
Implementa il metodo di bisezione per il calcolo degli zeri di un’equazione non lineare.
Parametri:
f: La funzione da cui si vuole calcolare lo zero.
a: L’estremo sinistro dell’intervallo di ricerca.
b: L’estremo destro dell’intervallo di ricerca.
tol: La tolleranza di errore.
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista di valori intermedi.
“””
fa=fname(a);
fb=fname(b);
if #to do
print(“Non è possibile applicare il metodo di bisezione \n”)
return None, None,None
it = 0
v_xk = []
maxit = math.ceil(math.log((b - a) / tolx) / math.log(2))-1
while : #to do
xk = #to do
v_xk.append(xk)
it += 1
fxk=fname(xk)
if fxk==0:
return xk, it, v_xk
if sign(fa)*sign(fxk)>0: # to do elif sign(fxk)*sign(fb)>0: # to do
serve a trovare uno zero di una funzione non lineare f(x) in intervallo [a, b]
def metodo_bisezione(fname, a, b, tolx,tolf):
“””
Implementa il metodo di bisezione per il calcolo degli zeri di un’equazione non lineare.
Parametri:
f: La funzione da cui si vuole calcolare lo zero.
a: L’estremo sinistro dell’intervallo di ricerca.
b: L’estremo destro dell’intervallo di ricerca.
tol: La tolleranza di errore.
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista di valori intermedi.
“””
fa=fname(a);
fb=fname(b);
if sign(fa) * sign(fb) > 0: #to do
print(“Non è possibile applicare il metodo di bisezione \n”)
return None, None,None
it = 0
v_xk = []
maxit = math.ceil(math.log((b - a) / tolx) / math.log(2))-1
while (b - a) > tolx and abs(fa) > tolf and it < maxit: #to do
xk = (a + b) / 2 #to do
v_xk.append(xk)
it += 1
fxk=fname(xk)
if fxk==0:
return xk, it, v_xk
if sign(fa)*sign(fxk)>0: a = xk # to do da zero fa = fxk # to do da zero elif sign(fxk)*sign(fb)>0: b = xk # to do da zero fb = fxk # to do da zero
return xk, it, v_xk
def falsi(fname, a, b, maxit, tolx,tolf):
“””
Implementa il metodo di falsa posizione per il calcolo degli zeri di un’equazione non lineare.
Parametri:
f: La funzione da cui si vuole calcolare lo zero.
a: L’estremo sinistro dell’intervallo di ricerca.
b: L’estremo destro dell’intervallo di ricerca.
tol: La tolleranza di errore.
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista di valori intermedi.
“””
fa=fname(a);
fb=fname(b);
if : #to do
print(“Non è possibile applicare il metodo di falsa posizione \n”)
return None, None,None
it = 0
v_xk = []
fxk=10
while : # to do
xk = #to do
v_xk.append(xk)
it += 1
fxk=fname(xk)
if fxk==0:
return xk, it, v_xk
# if sign(fa)*sign(fxk)>0: #to do #to do elif sign(fxk)*sign(fb)>0: #to do #to do
return xk, it, v_xk
utilizza metodo di falsa posizione per risolvere un sistema non lineare f(x) in intervallo [a, b]
def falsi(fname, a, b, maxit, tolx,tolf):
“””
Parametri:
f: La funzione da cui si vuole calcolare lo zero.
a: L’estremo sinistro dell’intervallo di ricerca.
b: L’estremo destro dell’intervallo di ricerca.
tol: La tolleranza di errore.
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista di valori intermedi.
“””
fa=fname(a);
fb=fname(b);
if fa * fb > 0: #to do
print(“Non è possibile applicare il metodo di falsa posizione \n”)
return None, None,None
it = 0
v_xk = []
fxk=10
while (b - a) > tolx and abs(fxk) > tolf and it < maxit: # to do
xk = (a * fb - b * fa) / (fb - fa) #to do
v_xk.append(xk)
it += 1
fxk=fname(xk)
if fxk==0:
return xk, it, v_xk
if sign(fa)*sign(fxk)>0: a = xk #to do da zero fa = fxk #to do da zero elif sign(fxk)*sign(fb)>0: b = xk #to do da zero fb = fxk #to do da zero
return xk, it, v_xk
def corde(fname,m,x0,tolx,tolf,nmax):
“””
Implementa il metodo delle corde per il calcolo degli zeri di un’equazione non lineare.
Parametri:
fname: La funzione da cui si vuole calcolare lo zero.
m: coefficiente angolare della retta che rimane fisso per tutte le iterazioni
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fx0=#to do
d=#to do
x1=#to do
fx1=fname(x1)
xk.append(x1)
it=1
while : x0= # to do fx0= #to do d= #to do ''' #x1= ascissa del punto di intersezione tra la retta che passa per il punto (xi,f(xi)) e ha pendenza uguale a m e l'asse x ''' x1=#to do fx1=fname(x1) it=it+1 xk.append(x1) if it==nmax: print('raggiunto massimo numero di iterazioni \n') return x1,it,xk
def corde(fname,m,x0,tolx,tolf,nmax):
“””
Implementa il metodo delle corde per il calcolo degli zeri di un’equazione non lineare.
Parametri:
fname: La funzione da cui si vuole calcolare lo zero.
m: coefficiente angolare della retta che rimane fisso per tutte le iterazioni
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fx0 = fname(x0) #to do
d = fx0 / m #to do
x1 = x0 - d #to do
fx1=fname(x1)
xk.append(x1)
it=1
while : x0 = x1 # to do fx0 = fname(x0) #to do d = fx0 / m #to do ''' #x1= ascissa del punto di intersezione tra la retta che passa per il punto (xi,f(xi)) e ha pendenza uguale a m e l'asse x ''' x1= x0 - d #to do fx1=fname(x1) it=it+1 xk.append(x1) if it==nmax: print('raggiunto massimo numero di iterazioni \n') return x1,it,xk
def newton(fname,fpname,x0,tolx,tolf,nmax):
“””
Implementa il metodo di Newton per il calcolo degli zeri di un’equazione non lineare.
Parametri:
fname: La funzione di cui si vuole calcolare lo zero.
fpname: La derivata prima della funzione di cui si vuole calcolare lo zero.
x0: iterato iniziale
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fx0=fname(x0)
if : #to do
print(“ derivata prima nulla in x0”)
return None, None,None
d=#to do x1=#to do fx1=fname(x1) xk.append(x1) it=1 while #to do : x0= #to do fx0= #to do if #to do: #Se la derivata prima e' pià piccola della precisione di macchina stop print(" derivata prima nulla in x0") return None, None,None d=#to do x1=#to do fx1=fname(x1) it=it+1 xk.append(x1) if it==nmax: print('raggiunto massimo numero di iterazioni \n') return x1,it,xk
def newton(fname,fpname,x0,tolx,tolf,nmax):
“””
Implementa il metodo di Newton per il calcolo degli zeri di un’equazione non lineare.
Parametri:
fname: La funzione di cui si vuole calcolare lo zero.
fpname: La derivata prima della funzione di cui si vuole calcolare lo zero.
x0: iterato iniziale
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fx0=fname(x0)
if fpname(x0) == 0: #TO DO
print(“ derivata prima nulla in x0”)
return None, None,None
d= fx0 / fpname(x0) #TO DO x1= x0 - d #TO DO fx1=fname(x1) xk.append(x1) it=1 while abs(x1 - x0) > tolx and abs(fx1) > tolf and it < nmax: #TO DO x0 = x1 #TO DO fx0 = fname(x0) #TO DO if abs(fpname(x0)) < 1e-12: #TO DO print(" derivata prima nulla in x0") return None, None,None d = fx0 / fpname(x0) #TO DO x1= x0 - d #TO DO fx1=fname(x1) it=it+1 xk.append(x1) if it==nmax: print('raggiunto massimo numero di iterazioni \n') return x1,it,xk
def secanti(fname,xm1,x0,tolx,tolf,nmax):
“””
Implementa il metodo delle secanti per il calcolo degli zeri di un’equazione non lineare.
Parametri:
fname: La funzione di cui si vuole calcolare lo zero.
xm1, x0: primi due iterati
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fxm1=#to do
fx0=#to do
d=#to do
x1=#to do;
xk.append(x1)
fx1=fname(x1);
it=1
while it<nmax and abs(fx1)>=tolf and abs(d)>=tolx*abs(x1): xm1=#to do x0=#to do fxm1=#to do) fx0=#to do d=#to do x1=#to do fx1=fname(x1) xk.append(x1); it=it+1; if it==nmax: print('Secanti: raggiunto massimo numero di iterazioni \n') return x1,it,xk
Implementa il metodo delle secanti per il calcolo degli zeri di un’equazione NON lineare.
def secanti(fname,xm1,x0,tolx,tolf,nmax):
“””
Parametri:
fname: La funzione di cui si vuole calcolare lo zero.
xm1, x0: primi due iterati
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[]
fxm1 = fname(xm1) #to do
fx0 = fname(x0) #to do
d = (fx0 - fxm1) / (x0 - xm1) #to do
x1 = x0 - fx0 / d #to do
xk.append(x1)
fx1=fname(x1);
it=1
while it<nmax and abs(fx1)>=tolf and abs(d)>=tolx*abs(x1): xm1 = x0 #to do x0 = x1 #to do fxm1 = fname(xm1) #to do fx0 = fname(x0) #to do d = (fx0 - fxm1) / (x0 - xm1) #to do x1 = x0 - fx0 / d #to do fx1=fname(x1) xk.append(x1); it=it+1; if it==nmax: print('Secanti: raggiunto massimo numero di iterazioni \n') return x1,it,xk
def newton_mod(fname,fpname,m,x0,tolx,tolf,nmax):
“””
Implementa il metodo di Newton modificato da utilizzato per il calcolo degli zeri di un’equazione non lineare
nel caso di zeri multipli.
Parametri:
fname: La funzione di cui si vuole calcolare lo zero.
fpname: La derivata prima della funzione di cui si vuole calcolare lo zero.
m: molteplicità della radice
x0: iterato iniziale
tolx: La tolleranza di errore tra due iterati successivi
tolf: tolleranza sul valore della funzione
nmax: numero massimo di iterazione
Restituisce:
Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi.
“””
xk=[] fx0=#to do if #to do : print(" derivata prima nulla in x0") return None, None,None d=#to do x1=#to do fx1=#to do xk.append(x1) it=1 while #to do : x0=#to do fx0=#to do if #to do: #Se la derivata prima e' pià piccola della precisione di macchina stop print(" derivata prima nulla in x0") return None, None,None d=#to do x1=#to do fx1=fname(x1) it=it+1 xk.append(x1) if it==nmax: print('raggiunto massimo numero di iterazioni \n') return x1,it,xk
def newton_mod(fname, fpname, m, x0, tolx, tolf, nmax):
“””
Implementa il metodo di Newton modificato per il calcolo degli zeri di un’equazione non lineare nel caso di zeri multipli.
Parametri: fname: La funzione di cui si vuole calcolare lo zero. fpname: La derivata prima della funzione di cui si vuole calcolare lo zero. m: molteplicità della radice. x0: iterato iniziale. tolx: La tolleranza di errore tra due iterati successivi. tolf: tolleranza sul valore della funzione. nmax: numero massimo di iterazioni. Restituisce: Lo zero approssimato della funzione, il numero di iterazioni e la lista degli iterati intermedi. """ xk = [] fx0 = fname(x0) #to do if fpname(x0) == 0: #to do print("derivata prima nulla in x0") return None, None, None d = fx0 / (m * fpname(x0)) #to do x1 = x0 - d #to do fx1 = fname(x1) #to do xk.append(x1) it = 1 while abs(x1 - x0) > tolx and abs(fx1) > tolf and it < nmax: #to do x0 = x1 #to do fx0 = fname(x0) #to do if abs(fpname(x0)) < 1e-12: #to do print("derivata prima nulla in x0") return None, None, None d = fx0 / (m * fpname(x0)) #to do x1 = x0 - d #to do fx1 = fname(x1) it += 1 xk.append(x1) if it == nmax: print('raggiunto massimo numero di iterazioni \n') return x1, it, xk
def jacobi(A,b,x0,toll,it_max):
errore=1000
d=np.diag(A)
n=A.shape[0]
invM=np.diag(1/d)
E=#to do
F=#to do
N=#to do
T=#to do
autovalori=np.linalg.eigvals(T)
raggiospettrale=#to do
print(“raggio spettrale jacobi”, raggiospettrale)
it=0
er_vet=[] while #to do: x=#to do errore=np.linalg.norm(x-x0)/np.linalg.norm(x) er_vet.append(errore) x0=x.copy() it=it+1 return x,it,er_vet
per risolvere sistemi lineari Ax = b
def jacobi(A,b,x0,toll,it_max):
errore=1000
d=np.diag(A)
n=A.shape[0]
invM=np.diag(1/d)
E = np.tril(A, -1)#TO DO
F = np.triu(A,1)#TO DO
N = -(E + F)#TO DO
T= np.dot(invM,N)#TO DO
autovalori=np.linalg.eigvals(T)
raggiospettrale = np.max(np.abs(autovalori))#TO DO
print(“raggio spettrale jacobi”, raggiospettrale)
it=0
er_vet=[] while it<=it_max and errore>=toll: #TO DO x= (b+np.dot(N,x0))/d.reshape(n,1)#TO DO errore=np.linalg.norm(x-x0)/np.linalg.norm(x) er_vet.append(errore) x0=x.copy() it=it+1 return x,it,er_vet
def gauss_seidel(A,b,x0,toll,it_max):
errore=1000
d=np.diag(A)
D=#to do
E=#to do
F=#to do
M=#to do
N=#to do
T=#to do
autovalori=np.linalg.eigvals(T)
raggiospettrale=#to do
print(“raggio spettrale Gauss-Seidel “,raggiospettrale)
it=0
er_vet=[]
while #to do:
temp=#to do
x= #to do
errore=np.linalg.norm(x-x0)/np.linalg.norm(x)
er_vet.append(errore)
x0=x.copy()
it=it+1
return x,it,er_vet
per risolvere sistemi lineari Ax = b
def gauss_seidel(A,b,x0,toll,it_max):
errore=1000
d=np.diag(A)
D=np.diag(d)#TO DO
E=np.tril(A,-1)#TO DO
F=np.triu(A,1)#TO DO
M=D+E#TO DO
N=-F#TO DO
T=np.dot(np.linalg.inv(M),N)#TO DO
autovalori=np.linalg.eigvals(T)
raggiospettrale=np.max(np.abs(autovalori)) #TO DO
print(“raggio spettrale Gauss-Seidel “,raggiospettrale)
it=0
er_vet=[]
while it<=it_max and errore>=toll: #TO DO
temp=b-np.dot(F,x0) #TO DO
x,flag=Lsolve(M,temp) #TO DO
errore=np.linalg.norm(x-x0)/np.linalg.norm(x)
er_vet.append(errore)
x0=x.copy()
it=it+1
return x,it,er_vet
def gauss_seidel_sor(A,b,x0,toll,it_max,omega):
errore=1000
d=#to donp.diag(A)
D=#to do
Dinv=#to do
E=#to do
F=#to do
Momega=D+omegaE
Nomega=(1-omega)D-omega*F
T=#to do
autovalori=np.linalg.eigvals(T)
raggiospettrale=np.max(np.abs(autovalori))
print(“raggio spettrale Gauss-Seidel SOR “, raggiospettrale)
M=D+E N=-F it=0 xold=x0.copy() xnew=x0.copy() er_vet=[] while #to do temp=#to do xtilde#to do xnew=#to do errore=np.linalg.norm(xnew-xold)/np.linalg.norm(xnew) er_vet.append(errore) xold=xnew.copy() it=it+1 return xnew,it,er_vet
risolvere sistemi lineari della forma Ax = b
# Ax=b. Questo metodo è una variante del metodo Gauss-Seidel che utilizza un fattore di rilassamento OMEGA per accellerare la convergenza
def gauss_seidel_sor(A,b,x0,toll,it_max,omega):
errore=1000
d=np.diag(A) #TO DO
D=np.diag(d) #TO DO
Dinv=np.diag(1/d)#TO DO
E=np.tril(A,-1)#TO DO
F=np.triu(A,1)#TO DO
Momega=D+omegaE
Nomega=(1-omega)D-omega*F
T= np.dot(np.linalg.inv(Momega),Nomega)#TO DO
autovalori=np.linalg.eigvals(T)
raggiospettrale=np.max(np.abs(autovalori))
print(“raggio spettrale Gauss-Seidel SOR “, raggiospettrale)
M=D+E N=-F it=0 xold=x0.copy() xnew=x0.copy() er_vet=[] while it<=it_max and errore>=toll:#TO DO temp=b-np.dot(F,xold)#TO DO xtilde,flag=Lsolve(M,temp)#TO DO xnew=(1-omega)*xold+omega*xtilde #TO DO errore=np.linalg.norm(xnew-xold)/np.linalg.norm(xnew) er_vet.append(errore) xold=xnew.copy() it=it+1 return xnew,it,er_vet
utilizzare il metodo del gradiente per trovare la soluzione
def steepestdescent(A,b,x0,itmax,tol):
n,m=A.shape if n!=m: print("Matrice non quadrata") return [],[]
# inizializzare le variabili necessarie
x = x0
r = A@x-b p = # to do it = 0 nb=np.linalg.norm(b) errore=np.linalg.norm(r)/nb vec_sol=[] vec_sol.append(x) vet_r=[] vet_r.append(errore) while #to do: it=it+1 Ap= #to do alpha = #to do x = # to do vec_sol.append(x) r=r+alpha*Ap errore=np.linalg.norm(r)/nb vet_r.append(errore) p =#to do return x,vet_r,vec_sol,it
utilizzare il metodo del gradiente per trovare la soluzione
def steepestdescent(A,b,x0,itmax,tol):
n,m=A.shape
if n!=m:
print(“Matrice non quadrata”)
return [],[]
# inizializzare le variabili necessarie TO DO
x = x0
r = A.dot(x)-b
p = -r
it = 0 nb=np.linalg.norm(b) errore=np.linalg.norm(r)/nb vec_sol=[] vec_sol.append(x) vet_r=[] vet_r.append(errore) while errore>= tol and it< itmax: # TO DO it=it+1 Ap=A.dot(p) #TO DO rTr=np.dot(r.T, r) #TO DO ** alpha = rTr / np.dot(p.T, Ap) #TO DO x = x + alpha*p #TO DO vec_sol.append(x) r=r+alpha*Ap errore=np.linalg.norm(r)/nb vet_r.append(errore) p = -r #TO DO return x,vet_r,vec_sol,it
utilizzare il metodo del gradiente coniugato per calcolare la soluzione
def conjugate_gradient(A,b,x0,itmax,tol):
n,m=A.shape
if n!=m:
print(“Matrice non quadrata”)
return [],[]
# inizializzare le variabili necessarie
x = x0
r = A@x-b p = -r it = 0 nb=np.linalg.norm(b) errore=np.linalg.norm(r)/nb vec_sol=[] vec_sol.append(x0) vet_r=[] vet_r.append(errore) while errore >= tol and it< itmax: it=it+1 Ap=#to do alpha = -#to do x =#to do vec_sol.append(x) rtr_old=r.T@r r=r+alpha*Ap gamma= #TO DO errore=np.linalg.norm(r)/nb vet_r.append(errore) p = #to do return x,vet_r,vec_sol,it
utilizzare il metodo del gradiente coniugato per trovare la soluzione
def conjugate_gradient(A, b, x0, itmax, tol):
n, m = A.shape
if n != m:
print(“Matrice non quadrata”)
return [], []
# inizializzare le variabili necessarie x = x0 r = A@x-b p = -r it = 0 nb = np.linalg.norm(b) errore = np.linalg.norm(r) / nb vec_sol = [] vec_sol.append(x0) vet_r = [] vet_r.append(errore)
# utilizzare il metodo del gradiente coniugato per calcolare la soluzione
while errore >= tol and it < itmax:
it = it + 1
Ap = A.dot(p) # added
alpha = r.T@r / (p.T@Ap) # added
x = x + alpha * p # added
vec_sol.append(x)
rtr_old = r.T@r
r = r + alpha * Ap
gamma = r.T@r / rtr_old # added
errore = np.linalg.norm(r) / nb
vet_r.append(errore)
p = -r + gamma * p # added
return x, vet_r, vec_sol, it
def eqnorm(A,b):
#Risolve un sistema sovradeterminato con il metodo delle equazioni normali
G=
f= L= U=L.T z= x= return x
Soluzione di un sistema sovradeterminato facendo uso delle equazioni normali
def eqnorm(A,b):
G=A.T@A #TO DO
print("Indice di condizionamento di G ",np.linalg.cond(G)) f=A.T@b #TO DO L=spLin.cholesky(G,lower=True) #TO DO z,flag=RisolviSis.Lsolve(L,f) #TO DO if flag==0: #TO DO DA ZERO x,flag=RisolviSis.Usolve(L.T,z) #TO DO return x
def qrLS(A,b):
#Risolve un sistema sovradeterminato con il metodo QR-LS
n=A.shape[1] # numero di colonne di A
Q,R=spLin.qr(A)
h=#to do
x,flag=SolveTriangular.Usolve( #to do)
residuo=np.linalg.norm(h[n:])**2
return x,residuo
Soluzione di un sistema sovradeterminato facendo uso della fattorizzazione QR
def qrLS(A,b):
n=A.shape[1] # numero di colonne di A
Q,R=spLin.qr(A)
h=Q.T@b #TO DO
x,flag=RisolviSis.Usolve(R[0:n,:],h[0:n]) #TO DO dentro parentesi
residuo=np.linalg.norm(h[n:])**2
return x,residuo
def SVDLS(A,b):
#Risolve un sistema sovradeterminato con il metodo SVD-LS
m,n=A.shape #numero di righe e numero di colonne di A
U,s,VT=spLin.svd(A) #Attenzione : Restituisce U, il numpy-array 1d che contiene la diagonale della matrice Sigma e VT=VTrasposta)
#Quindi
V=VT.T
thresh=np.spacing(1)ms[0] ##Calcolo del rango della matrice, numero dei valori singolari maggiori di una soglia
k=np.count_nonzero(s>thresh)
print(“rango=”,k)
d=#to do
d1=#to do
s1=#to do
#Risolve il sistema diagonale di dimensione kxk avene come matrice dei coefficienti la matrice Sigma
c=#to do
x=V[:,:k]@c
residuo=np.linalg.norm(d[k:])**2
return x,residuo
Soluzione di un sistema sovradeterminato facendo uso della fattorizzazione SVD
def SVDLS(A,b):
n=A.shape[1] # numero di colonne di A
U,s,VT=spLin.svd(A) #Attenzione : Restituisce U, Sigma e VT=VTrasposta)
V=VT.T
thresh=np.spacing(1)ms[0] ##Calcolo del rango della matrice, numero dei valori singolari maggiori di una soglia
k=np.count_nonzero(s>thresh)
print(“rango=”,k)
d=U.T@b #TO DO
d1=d[:k].reshape(k,1) #TO DO
s1=s[:k].reshape(k,1) #TO DO
#Risolve il sistema diagonale di dimensione kxk avene come matrice dei coefficienti la matrice Sigma
c=d1/s1 #TO DO
x=V[:,:k]@c
residuo=np.linalg.norm(d[k:])**2
return x,residuo
def plagr(xnodi,j):
“””
Restituisce i coefficienti del j-esimo pol di
Lagrange associato ai punti del vettore xnodi
“””
xzeri=np.zeros_like(xnodi)
n=xnodi.size
if j==0:
xzeri=xnodi[1:n]
else:
xzeri=np.append(#to do)
num=#to do den=#to do p=num/den return p
Funzioni per la costruzione del polinomio interpolatore nella base di Lagrange
def plagr(xnodi,k):
xzeri=np.zeros_like(xnodi)
n=xnodi.size
if k==0:
xzeri=xnodi[1:n]
else:
xzeri=np.append(xnodi[0:k],xnodi[k+1:n]) #TO DO dentro parentesi
num=np.poly(xzeri) #TO DO den=np.polyval(num,xnodi[k]) #TO DO p=num/den return p