現在この質問をフォロー中です
- フォローしているコンテンツ フィードに更新が表示されます。
- コミュニケーション基本設定に応じて電子メールを受け取ることができます。
Help in writing a function
2 ビュー (過去 30 日間)
古いコメントを表示
Hi everyone, I need to write a function to solve this system:
Until now all I can came up with was:
function dz = control1(v,z,parameters)
% gammaT=parameters(1);
phi_0=parameters(2);
psi_0=parameters(3);
psi_c0=parameters(4);
B=parameters(5);
Lc=parameters(6);
W=parameters(7);
H=parameters(8);
C = 0;
gammaT_max = 0.9;
gammaT_min = 0.61;
A = (gammaT_max - gammaT_min)/2; %amplitude
b = gammaT_max - ((gammaT_max - gammaT_min)/2);
hertz = 50;
w=hertz*2*pi;
gammaT = @(t) A*sin(w*t)+b
dz = zeros(2,1);
dz(1)=(1/(4*B*B*Lc))*(z(2)-gammaT(v)*(z(1))^0.5);
psi_c=psi_c0+H*(1+1.5*(z(2)/W-1)-0.5*(z(2)/W-1).^3);
dz(2) =(1/Lc)*(psi_c-z(1));
end
which is obviously wrong since gammaT = @(t) A*sin(w*t)+b shoouldn't be define this way.
I think gammaT should be written in that way but the time in the argument of the sin should be rearranged in some way I don't know
採用された回答
Star Strider
2020 年 10 月 31 日
‘which is obviously wrong since gammaT = @(t) A*sin(w*t)+b shoouldn't be define this way.’
Why? It appears to be coded correctly with respect to the posted image. It’s being evaluated with respect to your independent variable ‘v’, that appears to be correct. If it should actually be a different variable (such as time), it would be necessary to define the time in the context of the existing variables. We would need more information in order to help you with that.
For what it’s worth, the function runs without error for me using:
parameters = rand(8,1);
and:
[V,Z] = ode45(@(v,z)control1(v,z,parameters), [0 10], rand(2,1));
figure
plot(V, Z)
grid
.
30 件のコメント
Paul Rogers
2020 年 10 月 31 日
exactley, it's like yoou said, I need to be like
gammaT = (A*sin(w*t)+b)
where t is the time.
I attached al the files I use too run this function in the previous post
Star Strider
2020 年 10 月 31 日
Before I go through all the files, do you have a PDF of the system you’re modeling that you can attach here? (Reading it would likely be easier for me to understand, since I seriously doubt that what you’re doing is anywhere close to my areas of expertise.)
I’d like to see how ‘v’ and ‘t’ are related, or if they even are.
Paul Rogers
2020 年 10 月 31 日
編集済み: Paul Rogers
2020 年 10 月 31 日
yes, the sistem is the one described in eq. 1 and 2 but in eq. 1 Phi_t(Psi) = gamma_T*(Psi)^0.5.
In my case gammaT is a function of the time described by the equation:
gammaT = (A*sin(w*t)+b)
I forgot to link the article, it's just the system in the equation 1 and 2 withe the modification about gammaT
I can't upload the files I am using because I've reached the limit of 10 files, but they can be found in my previous post here:
https://www.mathworks.com/matlabcentral/answers/621798-problem-with-a-function#comment_1077308
Star Strider
2020 年 10 月 31 日
編集済み: Star Strider
2020 年 10 月 31 日
Thank you.
It will take me a bit to review that to understand how time relates to everything else. Compressors and the equations modeling them are entirely new to me.
EDIT — (31 Oct 2020 at 15:19)
Equation (6) may be important here:
since ξ is non-dimensional time. The equations for:
and:
would imply (to me) that they are functions indirectly of time, so whatever you are using to represent time (is it ‘v’?) would appear to me to be the argument to the function. .
I need a bit of clarification.
Paul Rogers
2020 年 10 月 31 日
I thank you, it's really important to me.
Anyway I did the functioons in the paper, but now too add something from me I need this small adjstment about gammaT, wich is noot a constant anymore but a function of the time
gammaT = A*sin(w*t)+b
Star Strider
2020 年 10 月 31 日
My poleasure!
Please see my previous Comment after EDIT that I just posted.
Star Strider
2020 年 11 月 1 日
I cannot find ‘gammaT’ in the paper, at least not by that name.
Can you reference an equation where it appears?
Paul Rogers
2020 年 11 月 1 日
編集済み: Paul Rogers
2020 年 11 月 1 日
gammaT in the paper is in table 1 and its value is 0.61.
The problem is I don't have to use gammaT as a constant like in the paper, but in my case gammaT varies with a form llike:
gammaT = A*sin(w*t)+b
where:
gammaT_max = 0.9;
gammaT_min = 0.61;
A = (gammaT_max - gammaT_min)/2; %amplitude
b = gammaT_max - ((gammaT_max - gammaT_min)/2);
hertz = 50;
w=hertz*2*pi;
Star Strider
2020 年 11 月 1 日
Are the values (range) of ‘A’ and ‘b’ between the limits (‘gammaT_min’ and ‘gammaT_max’) functions of or controlled by anything else, or any other variables or parameters (since ‘w’ appears to be fixed)?
Paul Rogers
2020 年 11 月 1 日
編集済み: Paul Rogers
2020 年 11 月 1 日
no, it's like you said, A’ and ‘b’ are between the limits (‘gammaT_min’ and ‘gammaT_max’),
Star Strider
2020 年 11 月 1 日
I’m a bit lost, here. The ‘gammaT’ function appears to be well-defined. In the code you originally posted, the code for ‘control1’ runs without error and appears to give acceptable results.
Is ‘gammaT’ supposed to be something else — some other function — or behave differently from what you coded it to be? Iy is certainly possible to define it as a constant if you want it to be constant, or to be something different from a sine curve (perhaps atan or tanh)?
I must be missing something, because I still don’t understand what the problem is.
Paul Rogers
2020 年 11 月 1 日
編集済み: Paul Rogers
2020 年 11 月 1 日
yes, I tought it was correct as I defind gammaT in control1, and the result looked acceptabe to me too.
The problem is in reality it's wrong, (my proofessor told me). When I plot this part (from general)
figure()
plot(time,psi,'b','Linewidth',3);
xlabel('Time (s)')
ylabel('$\Psi$','Interpreter','latex')
grid
I expect to see a function who has fluctuations like a sin and where I could see the 50Hz, but all I gget is a line with no meaning.
If in line 32 and 33 from general, I swithc from ode45 to ode113
[time1 ans1] = ode113(@(v,z)nocontrol(v,z,compressor_parameters),[0 t_c/timeRatio],[0 0]);
[time2 ans2] = ode113(@(v,z)control1(v,z,compressor_parameters),[t_c/timeRatio t_f/timeRatio],[real(ans1(end,1)) real(ans1(end,2))]);
I get a line which has the shape I expected (like a sinusoid), but still don't see the 50Hz. All I can count is 3 or 4 peaks in 2 seconds which is roughly 1.5-2.0Hz.
Paul Rogers
2020 年 11 月 1 日
so, with ode113 I get the shape I expected but stil I don't see the 50Hz.
At this point, I am starting to think that since I need to "see" 50Hz the time-step I need is 10ms at least, but when I open the time vector I se that time-step is at least one order more.
Now the problem could be this, but I really have no clue in how to improve the time discretization of an ode
Paul Rogers
2020 年 11 月 1 日
I think I got it, so, the function and stuff are well written, the prooblem is now the time step that the ode45 and the oders use. it's too big, infact if I simulate a low frequency, i.e. 0.001, I get the curve I expect.
Now I think I should open another topic asking how to improve the time resolution in an oode
Walter Roberson
2020 年 11 月 1 日
make your tspan a vector of 3 or more values instead of 2 values. The internal time step will be the same but you can can get results to whatever resolution you ask for.
Paul Rogers
2020 年 11 月 1 日
thanks, but how can I do this, I am really lost at this point.
this is where I call the function:
[time1 ans1] = ode113(@(v,z)nocontrol(v,z,compressor_parameters),[0 t_c/timeRatio],[0 0]);
[time2 ans2] = ode113(@(v,z)control1(v,z,compressor_parameters),[t_c/timeRatio t_f/timeRatio],[real(ans1(end,1)) real(ans1(end,2))]);
I really have no idea where to start now.
Here another call of the same function (it has a different name but the ssystem is the same):
[t,y]=ode113(@greitzer_Jerzak,[0 1200],[0,0]);
Star Strider
2020 年 11 月 1 日
If you want the time to go from 0 to 1200 with a step of 0.001:
tspan = linspace(0, 1200, 1200000);
Star Strider
2020 年 11 月 1 日
The [0 40] ‘tspan’ argument would be:
tspan = linspace(0, 40 , 40000);
to return solutions in steps of 0.001. The third argument here is simply the second argument x1000, to get that specific resolution.
Paul Rogers
2020 年 11 月 1 日
it's incredible, I don't understand.
If I put a frequency up to 0.1Hz I get the correct result, when I go to higher frequencies (50Hz) the system it's not working anymore.
Star Strider
2020 年 11 月 1 日
I don’t understand how that could be the situation, other than that you may be seeing ‘aliasing’.
One other option is to increase the length of the ‘tspan’ vectors, for example multiplying the third argument by 1000 to decrease the step size (using linspace) by 1000.
Paul Rogers
2020 年 11 月 1 日
if I put
hertz = 0.1;
in the function and
tspan = linspace(0, 100 , 600000);
[t,y]=ode113(@greitzer_Jerzak,[tspan],[0,0]);
in the main, I exacley get the result I expected, but if I want to investigate a higher frequency more appropriate for my studies, like 50hz, it doesn't work
Walter Roberson
2020 年 11 月 1 日
tspan = linspace(0, 40 , 40000);
should be
tspan = linspace(0, 40 , 40000+1);
because the endpoints are included in the count.
Paul Rogers
2020 年 11 月 1 日
tspan = linspace(0, 100 , 600000);
[t,y]=ode113(@greitzer_Jerzak,[tspan],[0,0]);
with this I have an incredible resultion, like 0.0001 in the time step, but it's stilll shoowing aliasing at 50Hz.
Paul Rogers
2020 年 11 月 1 日
thank you @Walter Roberson, but it doesn't change a thing. always good up to 0.1hz, but noot right for 50Hz
Paul Rogers
2020 年 11 月 2 日
編集済み: Paul Rogers
2020 年 11 月 2 日
the problem with the solution:
tspan = linspace(0, 100 , 600000);
[t,y]=ode113(@greitzer_Jerzak,[tspan],[0,0]);
is that the function is evalueted on the fixed points I specified, but the algoritm is still choosing its own points to solve the system.
Star Strider
2020 年 11 月 2 日
That’s how the MATLAB ODE solvers work.
They're adaptive internally with respect to the steps, and a vector of 3 or more elements for ‘tspan’ reports the outputs at the specified values of the independent variable.The ‘tspan’ vector otherwise doesn’t affect the internal workings of the ODE solvers, at least as I understand them.
Paul Rogers
2020 年 11 月 3 日
here is the solution I was looking for, so I can observe up tp 50Hz:
init=[0 0]';
options= odeset('MaxStep',0.001); %maximum time-step size
[t,y]=ode45(@greitzer_Jerzak,[0,20],init,options);
This solution allows me to chose the maximum step size of the time, evven if ode45 will still pick up its own points, but at least I make sure they are at a sample frequeny much higher so I can catch the frequencies I need.
thank you everybody, expecially to Star Strider who really put a lot of efford to point me in the right direction.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Ordinary Differential Equations についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!エラーが発生しました
ページに変更が加えられたため、アクションを完了できません。ページを再度読み込み、更新された状態を確認してください。
Web サイトの選択
Web サイトを選択すると、翻訳されたコンテンツにアクセスし、地域のイベントやサービスを確認できます。現在の位置情報に基づき、次のサイトの選択を推奨します:
また、以下のリストから Web サイトを選択することもできます。
最適なサイトパフォーマンスの取得方法
中国のサイト (中国語または英語) を選択することで、最適なサイトパフォーマンスが得られます。その他の国の MathWorks のサイトは、お客様の地域からのアクセスが最適化されていません。
南北アメリカ
- América Latina (Español)
- Canada (English)
- United States (English)
ヨーロッパ
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
アジア太平洋地域
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)