Drew a circle for a specific point in my plot

조회 수: 75 (최근 30일)
Tiago Dias
Tiago Dias 2018년 7월 10일
댓글: Tiago Dias 2018년 7월 10일
Hi,
My objective is how to draw a circle for the min(PRESS). I wrote the following code for an ellipse, but I had to adjust the Xcenter and Ycenter handly, but I would rather do this in a automatically form, because if i change the min(PRESS) for example for the first two entries, the values changes and the elipse dont circle the point i want.
load('PRESS')
[mincumpress,nPC_imp] = min(PRESS(2:end,:))
x_aux = [0:maxpcs]';
figure
plot(x_aux,PRESS,'-b','LineWidth',2);
hold on
plot(x_aux,PRESS,'.r','MarkerSize',15);
yl = ylim; ylim([yl(1) yl(2)]);
xcenter = nPC_imp / xl(2) + 0.035
ycenter = mincumpress * (yl(2) - yl(1)) - 0.08
dim = [xcenter ycenter .05 .05];
annotation('ellipse',dim,'Color','red')
hold on
xlabel('PC Number'); ylabel('PRESS');title('PCA-CV (ckf)');
Thanks for your time
  댓글 수: 6
Tiago Dias
Tiago Dias 2018년 7월 10일
If You use viscircles, it does what I showed on the picture? a vertical elipse? or it really does an circle?
jonas
jonas 2018년 7월 10일
편집: jonas 2018년 7월 10일
Yea that's correct. Any method where the radius is connected to the axes will give that result, unless the xticks and yticks are equal. Your solution is very practical as the center is connected to the axes while the radius is 'disconnected' from the axes.

댓글을 달려면 로그인하십시오.

답변 (1개)

KSSV
KSSV 2018년 7월 10일
Let C be the point, where you want to draw a circle.
N = 10 ;
x = 1:N ;
y = rand(N,1) ;
[val,idx] = max(y) ;
C = [x(idx) y(idx)] ;
plot(x,y) ;
hold on
R = 0.1 ; % Radius of circle
th = linspace(0,2*pi) ;
xc = C(1)+R*cos(th) ;
yc = C(2)+R*sin(th) ;
plot(xc,yc,'r') ;
axis equal
  댓글 수: 3
KSSV
KSSV 2018년 7월 10일
YOu can go for markers with circle i.e O and specify its size.
Tiago Dias
Tiago Dias 2018년 7월 10일
yes, thats what I said to jonas on the previous answer

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Polar Plots에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by