1 function etude_support(a,b,n)
\r
2 % compare l'effet sur la qualité de l'interpolation
\r
3 % des points de Tchebychev et
\r
4 % de points régulièrement répartis dans [a,b].
\r
7 % n est un entier naturel
\r
8 % tel que x0,...,xn sont les points d'interpolation
\r
9 % choisis dans [a,b] selon les deux variantes à comparer.
\r
11 % variables de sortie
\r
12 % On visualise; on pourra capter l'image produite
\r
13 % et éventuellement renvoyer son handle.
\r
16 % ************ Fonctions auxiliaires utilisées ***************
\r
18 % diff_div_dist, eval_horner
\r
20 % *********************************************************
\r
22 % Paramètres modifiables
\r
24 nmax=19; % nb de points d'interpolation
\r
25 N=100; % détermine la taille des vecteurs à représenter
\r
27 % Contrôles d'entrée
\r
29 % nombre d'arguments
\r
31 error('Nombre des arguments incorrects');
\r
34 % autres tests éventuels
\r
36 error('Modifiez le paramètre nmax en tete de fichier')
\r
39 error('Choisissez un intervalle conventionnel')
\r
42 % Corps d'algorithme
\r
44 % préparation des deux familles de points de support
\r
46 % points régulièrement répartis
\r
48 % points de Tchebychev
\r
49 x2=(b-a)/2*cos(pi/2*(2.*i+1)/(n+1))+(b+a)/2;
\r
51 % détermination des images d'un vecteur x
\r
52 % par la fonction proposée;
\r
53 % on pourrait rajouter un champ de saisie
\r
54 % de la fonction à interpoler.
\r
58 % détermination des polynomes d'interpolation
\r
59 % et des images du vecteur x obtenues par eux.
\r
60 y1=exp(x1);y2=exp(x2);
\r
61 d1=diff_div_dist(x1,y1);d2=diff_div_dist(x2,y2);
\r
62 Y1=eval_horner(X,x1(1:n),d1);
\r
63 Y2=eval_horner(X,x2(1:n),d2);
\r
65 % calcul des écarts entre fonction exacte
\r
66 % et polynomes d'interpolation
\r
67 E1=abs(Y-Y1);E2=abs(Y-Y2);
\r
69 % calibrage des images
\r
70 maxy=max(max(E1),max(E2));
\r
72 lim=[a-bordx b+bordx 0 1.1*maxy];
\r
75 % représentation de E1 et E2
\r
79 title(['Erreurs d''interpolation à ' num2str(n+1) ' points pour exponentielle']);
\r
80 legend('Cas de points régulièrement répartis',0);
\r
85 legend('Cas de points de Tchebychev',0);
\r
90 legend('Erreurs comparées',0);
\r
105 % sortie des résultats
\r
109 % fin de fonction()
\r