0

デカルトシステムで与えられるいくつかの点座標を対数極デカルトシステムに変換したいと思います。

ただし、atan操作を適切に実行する方法がわかりません。

現在、次のようにやっていますが、かなり醜いようです。

   Xlp = zeros(n, 2);
   Xlp(:, 1) = log(sqrt(Xt(:, 1).^2 + Xt(:, 2).^2));
   sel = Xlp(:, 1) >= 0 && Xlp(:, 2) >= 0;
   Xlp(sel, 2) = atan(Xt(sel, 2) / Xt(sel, 1));
   sel = Xlp(:, 1) >= 0 && Xlp(:, 2) < 0;
   Xlp(sel, 2) = repmat(2*pi, size(sel), 1) + atan(Xt(sel, 2) / Xt(sel, 1));
   sel = Xlp(:, 1) < 0 && Xlp(:, 2) >= 0;
   Xlp(sel, 2) = repmat(pi, size(sel), 1) + atan(Xt(sel, 2) / Xt(sel, 1));
   sel = Xlp(:, 1) < 0 && Xlp(:, 2) < 0;
   Xlp(sel, 2) = repmat(pi, size(sel), 1) + atan(Xt(sel, 2) / Xt(sel, 1));

入力ポイントはXtにあり、最初の列はX座標値で、2番目の列はY座標値です。Xlpには、距離に対応する最初の列と角度に対応する2番目の列として指定された対数極座標が含まれます。

4

2 に答える 2

3

やる

[THETA,RHO] = cart2pol(X,Y)
RHO=log(RHO)

于 2010-11-14T12:13:28.390 に答える
2

atan2()を使用して、このすべてのハードワークを実行してください。

于 2010-11-13T11:57:37.213 に答える