Hello All, How are you?
I would like to compare every value of my vector x to the following statement: 0≤x≤P
If x is between 0 and P use this formula to calculate Zc
Zc = (M/P^2)*(2*P.*x - x.^2); % 0≤x≤P
If x is within P and 1, use this formula to calculate Zc
Zc = (M/(1-P)^2)*((1-2*P) + 2*P.*x - x.^2);% P≤x≤1
And I also would like to store the values of Zc from both formulas in a single variable Zc
How can I do this?
Please find the code below:
M = 4/100; % Max Camber.
P = 4/10; % Location of Max Camber.
tmax = 18/100; % Maximum airfoil thickness.
% Mean Camber Line.
x = [0:0.01:1];%chord.
if any(x == 0)
Zc = (M/P^2)*(2*P.*x - x.^2); % 0≤x≤P
else
Zc = (M/(1-P)^2)*((1-2*P) + 2*P.*x - x.^2);% P≤x≤1
end
Thank you in advance !

 채택된 답변

Rik
Rik 2021년 4월 9일

0 개 추천

This is the easiest way to do it vectorized:
Zc_0_to_P =@(x) (M/P^2)*(2*P.*x - x.^2); % 0≤x≤P
Zc_P_to_1 =@(x) (M/(1-P)^2)*((1-2*P) + 2*P.*x - x.^2);% P≤x≤1
x = 0:0.01:1;
%pre-allocate with NaN so we can spot skipped values (if any)
Zc=NaN(size(x));
L= 0<=x & x<=P;
Zc(L)=Zc_0_to_P(x(L));
L= P<=x & x<=1;%this overlaps with the previous condition for x=P
Zc(L)=Zc_P_to_1(x(L));

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Data Types에 대해 자세히 알아보기

제품

릴리스

R2021a

질문:

2021년 4월 8일

댓글:

2021년 4월 9일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by