I'm trying to surf a function f that takes 2 values: 1 if (x,y) is in A and 2 if (x,y) is in B. How can I do that? I attach also a drawing for x,y.

 採用された回答

Torsten
Torsten 2023 年 5 月 21 日

0 投票

Define the function as
f = @(x,y) (y>=2*x) + 2*(y<2*x);
and make a surface plot.

17 件のコメント

Alexandra Roxana
Alexandra Roxana 2023 年 5 月 21 日
編集済み: Alexandra Roxana 2023 年 5 月 21 日
But the function doesn't depend on x and y. It is a constant function. And I want to go further with more triangles dividing the domain. And to make it have a different value within each triangle.
Torsten
Torsten 2023 年 5 月 21 日
編集済み: Torsten 2023 年 5 月 21 日
The function has exactly the values you want:
f = @(x,y) (y>=2*x) + 2*(y<2*x);
f(0,1)
ans = 1
f(1,0)
ans = 2
But I admit: Defining a function with prescribed values on each triangle of a triangulation will soon become a hard job. And I really don't understand what it should be good for ...
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 21 日
I want the value to be 1 in every x and y, not just x=0 and y=1.
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 21 日
I've been thinking of this problem for weeks and can't seem to come to some results.
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 21 日
編集済み: Alexandra Roxana 2023 年 5 月 21 日
Long story short: I want to calculate the pressure on each triangle from the red domain. The left-hand side of the formula is the pressure on each triangle; the right-hand side is the sum of values of each node from the triangle. The thing is the pressure is constant on each triangle and it has to look like that in the surf. Before it looked like a continuous function which isn't right. And I wanted at first to begin with a simple example.
Torsten
Torsten 2023 年 5 月 21 日
f = @(x,y) (y>=2*x) + 2*(y<2*x);
x = linspace(0,1,100);
y = linspace(0,2,100);
[X,Y] = ndgrid(x,y);
surf(X,Y,f(X,Y))
shading interp
colorbar
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 22 日
It looks really good but there's a slight problem: what can I modify so I can see only the two triangles in the figure? It must look like a jump from 1 to 2.
Star Strider
Star Strider 2023 年 5 月 22 日
Use the view function.
Torsten
Torsten 2023 年 5 月 22 日
Or:
f = @(x,y) (y>=2*x) + 2*(y<2*x);
x = linspace(0,1,100);
y = linspace(0,2,100);
[X,Y] = ndgrid(x,y);
contourf(X,Y,f(X,Y))
colorbar
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 22 日
No, it has to look like the first one without the middle part, in 3D also.
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 22 日
Probably the function has to be modified, I momentarily don't see how.
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 22 日
The marked part must not appear
Torsten
Torsten 2023 年 5 月 22 日
You might want to play with this representation:
x1 = [0,0,1];
y1 = [0,2,2];
z1 = [1,1,1];
x2 = [0,1,1];
y2 = [0,0,2];
z2 = [2,2,2];
hold on
s1 = fill3(x1,y1,z1,'r');
s2 = fill3(x2,y2,z2,'b');
hold off
view(25,45)
zlim ([0 3])
rotate(s1,[0 0 1],180)
rotate(s2,[0 0 1],180)
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 23 日
編集済み: Alexandra Roxana 2023 年 5 月 23 日
Unfortunately that's not going to help me very much because I want to go further and do the same thing but with more triangles like in this case and in each triangle the function to have a different value:
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 23 日
編集済み: Alexandra Roxana 2023 年 5 月 23 日
Thank you for all your help!
Alexandra Roxana
Alexandra Roxana 2023 年 5 月 27 日
The method from the link seems to work; however I'm a bit confused with the values of n1, n2 and n3. I don't know what values I should put: if I put [1,1,1] the first coordinates are different, the rest is the same as should be. So I'm guessing the choice of n1, n2 and n3 is wrong.

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

その他の回答 (0 件)

カテゴリ

製品

リリース

R2017a

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by