質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

11833閲覧

openCV 画素の書き換え

north_redwings

総合スコア32

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2018/06/04 23:52

編集2018/06/05 00:06

微分フィルタを画像にかけるプログラムを書いています。
流れは以下の通りです。

1.Vec3b型の2次元配列BGRに画素を代入する
(ただし,1回り大きく配列を取り, 周辺の画素を全て0に設定する)
2.縦方向の微分フィルタと横方向の微分フィルタとで分けて別々にかける
3.Vec3b型の2次元配列BGR_h, BGR_vに画素を代入する
4.BGR_h, BGR_vの値をImg_h, Img_vの画素に代入し, 書き換える

しかし、何度試しても画像が変わりません。
色々デバッグして画素は変わっている気がするのですが...

C++

1#include <opencv2/core/core.hpp> 2#include <opencv2/highgui/highgui.hpp> 3#include <iostream> 4 5using namespace std; 6using namespace cv; 7 8int main(int argc, char* argv[]) 9{ 10 Mat Img = imread("lena.jpeg"); 11 12 double h_filter[3][3] = { {-0.125, -0, -0.125}, {-0.25, 0, 0.25}, {-0.125, 0, 0.125} }; 13 double v_filter[3][3] = { {0.125, 0.25, 0.125}, {0, 0, 0}, {-0.125, -0.25, -0.125} }; 14 15 int width = Img.cols; 16 int height = Img.rows; 17 18 Vec3b BGR[width+2][height+2], BGR_h[width][height], BGR_v[width][height]; 19 int row, col; 20 21 for (row=0; row<height; row++){ 22 for (col=0; col<width; col++){ 23 BGR[row+1][col+1] = Img.at<Vec3b>(row, col); 24 25 BGR[0][col] = Vec3b(0, 0, 0); 26 BGR[height][col] = Vec3b(0, 0, 0); 27 BGR[row][0] = Vec3b(0, 0, 0); 28 BGR[row][width] = Vec3b(0, 0, 0); 29 } 30 } 31 int i, j; 32 for (row=0; row<height; row++) { 33 for (col=0; col<width; col++) { 34 35 for (i=0; i<3; i++) { 36 for (j=0; j<3; j++) { 37 BGR_h[row][col] += BGR[row+1-i+1][col-1+j+1] * h_filter[i][j]; 38 BGR_v[row][col] += BGR[row+1-i+1][col-1+j+1] * v_filter[i][j]; 39 } 40 } 41 } 42 } 43 44 Mat Img_h = Img, Img_v = Img; 45 for (row=0; row<height; row++){ 46 for (col=0; col<width; col++){ 47 48 // Img.at<Vec3b>(row, col) = Vec3b(0,0,0); 49 cout << "Img_h.at<Vec3b>(" << row <<"," << col << ")="<< Img_h.at<Vec3b>(row, col) << endl; 50 // Img_h.at<Vec3b>(row, col) = BGR_h[row][col]; 51 Img_h.at<Vec3b>(row, col) = Vec3b(0, 0, 0); 52 // cout << "BGR_h[row][col] = " << BGR_h[row][col] << endl; 53 cout << "代入後Img_h.at<Vec3b>(" << row <<"," << col << ")=" << Img_h.at<Vec3b>(row, col) << endl;; 54 55 cout <<"\n"; 56 57 Img_v.at<Vec3b>(row, col) = BGR_v[row][col]; 58 } 59 } 60 61 62 // int bgr = BGR_h[4][4][0]; 63 // cout << BGR_h[4][4]*3 << endl; 64 // cout << bgr << endl; 65 66 imshow("test", Img); 67 imshow("test_h", Img_h); 68 imshow("test_v", Img_v); 69 70 int key = waitKey(1000000); 71 72 return 0; 73} 74

とりあえず全てBGR_hはVec3b(0,0,0)で変更する様にしてでバックしてます。
ターミナルでの表示は,

Img_h.at<Vec3b>(0,0)=[12, 16, 35] 代入後Img_h.at<Vec3b>(0,0)=[0, 0, 0] Img_h.at<Vec3b>(0,1)=[15, 19, 38] 代入後Img_h.at<Vec3b>(0,1)=[0, 0, 0] Img_h.at<Vec3b>(0,2)=[10, 14, 32] 代入後Img_h.at<Vec3b>(0,2)=[0, 0, 0] Img_h.at<Vec3b>(0,3)=[12, 15, 36] 代入後Img_h.at<Vec3b>(0,3)=[0, 0, 0] Img_h.at<Vec3b>(0,4)=[9, 15, 34] 代入後Img_h.at<Vec3b>(0,4)=[0, 0, 0] Img_h.at<Vec3b>(0,5)=[13, 16, 37] 代入後Img_h.at<Vec3b>(0,5)=[0, 0, 0] Img_h.at<Vec3b>(0,6)=[9, 16, 33] 代入後Img_h.at<Vec3b>(0,6)=[0, 0, 0] Img_h.at<Vec3b>(0,7)=[9, 16, 33] 代入後Img_h.at<Vec3b>(0,7)=[0, 0, 0] Img_h.at<Vec3b>(0,8)=[11, 15, 33] 代入後Img_h.at<Vec3b>(0,8)=[0, 0, 0] Img_h.at<Vec3b>(0,9)=[11, 15, 34] 代入後Img_h.at<Vec3b>(0,9)=[0, 0, 0] Img_h.at<Vec3b>(0,10)=[9, 13, 31] 代入後Img_h.at<Vec3b>(0,10)=[0, 0, 0] ~~~ 以下同様

イメージ説明
結果はこの様な形でそもそも元の画像も微妙に変わってしまっています...

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

C++

1 Mat Img_h = Img, Img_v = Img;

上記箇所において、コピーしているつもりかと思われますが、実際はデータはコピーされていません。

浅いコピーと深いコピー参照。

C++

1 Mat Img_h, Img_v; 2 Img.copyTo(Img_h); 3 Img.copyTo(Img_v);

とするのがご要望の動作(深いコピー)になります。

投稿2018/06/05 01:44

kazto

総合スコア7196

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

north_redwings

2018/06/05 02:05

なるほど!!!コピーに種類があってそこが問題だったんですね… もう一つ、よろしければ質問させてください。画像が正方形でない場合(上記もそうです)、右側が失われて左側が繰り返されています。どこが問題なのでしょうか?
kazto

2018/06/05 02:25

それは、デバッグしてみないと、コードレビューだけではつらいっすねぇ。。。 すぐにも動かす環境作れませんし。 でも、以下のインデックスの取り方がなんとなく変な気がします。 この辺を中心にデバッグしてみてはいかがでしょうか。 BGR_h[row][col] += BGR[row+1-i+1][col-1+j+1] * h_filter[i][j]; BGR_v[row][col] += BGR[row+1-i+1][col-1+j+1] * v_filter[i][j];
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問