0

私は、電磁波の分野で知られている逆ソース問題を含むプロジェクトに取り組んできました。私が抱えている問題はそれです; 2D空間で3つのポイントを定義する必要があります。これらのポイントには、もちろんax、y座標と、その現在の値を定義する値が必要です。このような:

A1(2,3)=1
A2(2,-2)=2
and so on.

また、この周りに円を定義し、200ポイントに分割する必要があります。最初のポイントのようになります; 言うR=2 ; B1(2,0) ;B50(0,2);B100(-2,0)など。

今、MATLABでスペースを定義し、それを丸で囲むのに本当に苦労しています。だから私が求めているのは、2D空間を定義し、私が説明した方法でそれを行うのを手伝うことです。助けてくれてありがとう!

4

2 に答える 2

0

この種のコードが使用される可能性があります。grid変数エディターで見てください。

grid = zeros(50, 50);
R = 10;
angles = (1:200)/2/pi;
x = cos(angles)*R;
y = sin(angles)*R;

center = [25 20];

for n=1:length(angles)   
    grid(center(1)+1+round(x(n)), center(2)+1+round(y(n))) = 1;
end

必要に応じて十分な大きさのグリッドを定義する必要があります。

于 2011-10-18T15:04:49.387 に答える
0

これが役立つかもしれない完全な例です:

%# points
num = 3;
P = [2 3; 2 -2; -1 1];          %# 2D points coords
R = [2.5 3 3];                  %# radii of circles around points

%# compute circle points
theta = linspace(0,2*pi,20)';   %'
unitCircle = [cos(theta) sin(theta)];
C = zeros(numel(theta),2,num);
for i=1:num
    C(:,:,i) = bsxfun(@plus, R(i).*unitCircle, P(i,:));
end

%# prepare plot
xlims = [-6 6]; ylims = [-6 6];
line([xlims nan 0 0],[0 0 nan ylims], ...
    'LineWidth',2, 'Color',[.2 .2 .2])
axis square, grid on
set(gca, 'XLim',xlims, 'YLim',ylims, ...
    'XTick',xlims(1):xlims(2), 'YTick',xlims(1):xlims(2))
title('Cartesian Coordinate System')
xlabel('x-coords'), ylabel('y-coords')

hold on

%# plot centers
plot(P(:,1), P(:,2), ...
    'LineStyle','none', 'Marker','o', 'Color','m')
str = num2str((1:num)','A%d');    %'
text(P(:,1), P(:,2), , str, ...
    'HorizontalAlignment','left', 'VerticalAlignment','bottom')

%# plot circles
clr = lines(num);
h = zeros(num,1);
for i=1:num
    h(i) = plot(C(:,1,i), C(:,2,i), ...
        'LineStyle','-', 'Marker','.', 'Color',clr(i,:));
end
str = num2str((1:num)','Circle %d');    %'
legend(h, str, 'Location','SW')

hold off

スクリーンショット

于 2011-10-27T08:16:03.560 に答える