Aller au contenu
View in the app

A better way to browse. Learn more.

Next

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

[MATLAB] Javelot

Featured Replies

Posté(e)

Salut, notre professeur nous propose un projet sous Matlab MAIS LE problème que j'ai affronté c'est que la fonction ne s'affiche pas.

Svp est ce que vous pouvez le courigé si c'etais possible:

% boucle i de balayage des valeurs de dθ/dt(t=0)

for i=-2:2

% boucle m de balayage des valeurs de θ(τ0)

for m=1:17;

y=zeros(100,6);

final=0;

y(1,5)=m*5/180*pi; % angle θ initial (de 5° à 85 ° par pas de 5°)

options = odeset('RelTol',1e-4);

[t,y] = ode45('equations',[0 10],[0 25*cos(y(1,5)) 2 25*sin(y(1,5)) y(1,5) i],options);

e=size(y);

% boucle k enregistre à quel pas de temps k le javelot atteint le sol

for k=1:e(1);

if (y(k,3)>0) & (y(k+1,3)<0)

final=k;

break;

end

end

% fin boucle k

% Le vecteur à 3 dimensions range contiendra les résultats finaux

range(1,m,i+3)=m*5; % angle θ initial en degrés

range(2,m,i+3)=-y(final,3)*(y(final+1,1)-y(final,1))/(y(final+1,3)-y(final,3))+y(final,1);

range(3,m,i+3)=i; % vitesse angulaire dθ/dt(t=0) initiale

axis([0 150 0 50]);

title(['Trajectoire pour une vitesse angulaire \theta/dt=,int2str(i),'rad/sec]);

xlabel(['Portée [m]= ',int2str(range(2,m,i+3))]);

ylabel('Hauteur [m]');

comet(y(1:final+1,1),y(1:final+1,3));

plot(y(1:final+1,1),y(1:final+1,3));

hold on % force chacune des trajectoires à s'imprimer sur la même figure

end

% fin boucle m

hold off

end

% fin boucle i

for i=-2:2

plot(range(1,:,i+3),range(2,:,i+3),'LineWidth',2);

hold on;

end

title('Diagramme Portée en fonction de Angle Attaque \theta ');

xlabel('Angle \theta [°]');

ylabel('Portée[m]');

%Sauvegarde dans le fichier javlot.txt de la portée du javelot en fonction de θ(t=0) pour

chacune des 5 valeurs initiales de dθ/dt(t=0)

fid = fopen('c:\javelot.txt','w');

fprintf(fid,'angle deg; portée ; dteta/dt(t=0)\n');

fprintf(fid,'% 6.2f ; %6.2f ; %6.2f \n',range);

fclose(fid);

hold off;

Le fichier equation.m dont le module de résolution ode45.m a besoin est donné par:

function z = equation(t,y)

z = zeros(6,1);

Delta=0.255;

Speed = sqrtm(y(2)*y(2) + y(4)*y(4));

Phi = atan(y(4)/y(2));

Alpha = sin(y(5) - Phi);

Drag = 0.00024*exp(5.157*abs(Alpha));

Lift = 0.0;

if Alpha > 0.001

Lift = 0.0127*exp(1.34*log(abs(Alpha)));

end

z(1) = y(2);

z(2) = - (Drag*y(2)*Speed + Lift*y(4)*Speed)/0.80625;

z(3) = y(4);

z(4) = - (Drag*y(4)*Speed - Lift*y(2)*Speed)/0.80625 - 9.81;

z(5) = y(6);

z(6) = - Delta*Speed*Speed*(Drag*sin(Alpha) + Lift*cos(Alpha))/0.42;

J'att vos répense

Archivé

Ce sujet est désormais archivé et ne peut plus recevoir de nouvelles réponses.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.