魚眼画像、全方位画像の展開プログラミング

39 views (last 30 days)
takumi honda
takumi honda on 14 Oct 2019
Commented: takumi honda on 25 Oct 2019
魚眼画像、全方位画像、を展開する構文を作りたいのですが、計算上は理解できているのですが、構文に起こせません。お教えいただけると幸いです。
  10 Comments
Kenta
Kenta on 19 Oct 2019
ありがとうございます。返信が遅れてしまい、申し訳ございません。
リンクの情報を教えていただき、ありがとうございます。いろいろと勉強させていただきました。

Sign in to comment.

Accepted Answer

Takashi Ueno
Takashi Ueno on 16 Oct 2019
興味があったのでちょっと作ってみましたが、こんな感じでしょうか?
雑にお絵描きして元画像を作ったので、結果も歪んでますが、参考にしていただければ。
使用した画像は添付しておきます。
clear
close all
I=imread('test.png');
I=rgb2gray(I);
figure
imshow(I)
% 切り出し中心
c=[190,198];
% 切り出し半径
R=175;
% 分割の角度数
angles=360;
% 極座標の設定
theta=linspace(0,2*pi,angles);
rho=1:R;
theta_array=kron(theta,ones(1,length(rho)));
rho_array=repmat(rho,1,angles);
% 極座標から直交座標に変換
[x,y]=pol2cart(theta_array,rho_array);
% 原点を画像中心から左上(1,1)にオフセット
x_f=x+c(2);
y_f=y+c(1);
% 直交座標は小数になるので、bilinearでの内挿を作成
F = griddedInterpolant(double(I));
% クエリ点の値の取得
I2=F(y_f',x_f');
% I2は1次元配列なのでreshape
I2=reshape(I2,length(x_f)/angles,angles);
figure
imshow(I2/255)
  4 Comments
takumi honda
takumi honda on 21 Oct 2019
返信遅れてしまい申し訳ありません。きれいな半球レンズを想定しています

Sign in to comment.

More Answers (1)

takumi honda
takumi honda on 22 Oct 2019
Takashi Uenoさん 追加でお伺いしたいのですが、一度グレースケール化するのはなぜでしょうか? カラーで表示がしたいと考えています。 知識不足で申し訳ありません。
  2 Comments
takumi honda
takumi honda on 25 Oct 2019
ありがとうございます。

Sign in to comment.

Community Treasure Hunt

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

Start Hunting!