function on separate interval

4 ビュー (過去 30 日間)
Oluwaseun Lijoka
Oluwaseun Lijoka 2016 年 3 月 25 日
コメント済み: Oluwaseun Lijoka 2016 年 3 月 26 日
Hello there, I have a function f(x,t) defined on (0,1). The function is however discontinuous at x=1/2 such that we have two separate values f1(x,t) for x in (0,1/2) and f2(x,t) for x in (1/2, 1). How do I program this function with M function file that takes input x and t?. Arbitrary function can be used to explain. Thanks a lot
  4 件のコメント
Walter Roberson
Walter Roberson 2016 年 3 月 25 日
Is x a scalar or a vector?
Oluwaseun Lijoka
Oluwaseun Lijoka 2016 年 3 月 26 日
x is allowed to be a vector. Mostly computed via quadrature.@Robertson

サインインしてコメントする。

採用された回答

Ced
Ced 2016 年 3 月 25 日
編集済み: Ced 2016 年 3 月 25 日
This means that you have defined a function with an output (in your case the variable f), but have not assigned it. This would happen if x does not fall into any of your cases.
Your if conditions are a bit strange.
(x<=1/2) will return 0 if false, 1 if true. So, if e.g. x = 0, then x(x<=1/2) = x(1) = 0, which is considered false instead of true.
This should work better:
function f = exact_soln(x,t,c_1,c_2)
fn=@(x)sin(2*pi*x);
if x <= 0.5 % domain section 1
f= 0.5*(fn(x+c_1*t) + fn(x-c_1*t));
else % domain section 2, 0.5 < x
f= 0.5*(fn(x+c_2*t) + fn(x-c_2*t));
end
end
Having an else statement ensures that no matter x, f will always get a value.
Note that the boundaries x == 0 and x == 1 are actually not checked! If you need your wave to stop there, you could either add more if/else statements, or simply bound x before hand, i.e.
x = max(min(x,1),0);
  1 件のコメント
Oluwaseun Lijoka
Oluwaseun Lijoka 2016 年 3 月 25 日
Thanks Ced, I actually extended the solution by f=0 elsewhere before but your idea is simple and better. I also like the idea of bounding x as well. Thanks a lot.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeMatrix Indexing についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by