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

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

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

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

String

Stringは、ゼロ以上の文字から連続してできた文字の集合を扱うデータ型です。基本的にテキストを表すために使われます。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

C++

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

Q&A

解決済

2回答

918閲覧

for文を正常に動作させたい

0sashimi

総合スコア2

for

for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

String

Stringは、ゼロ以上の文字から連続してできた文字の集合を扱うデータ型です。基本的にテキストを表すために使われます。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

C++

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

0グッド

0クリップ

投稿2021/12/20 04:10

forループが継続しない

OpenCVを利用して画像から特徴点の抽出をおこなうプログラムを作成しています.利用する画像サンプルが多いので,stringを利用して上手く自動化できればと考えていましたが,うまく動作できませんでした.

発生している問題・エラーメッセージ

想定している分のforループが実行されない.画像の読み込み,特徴抽出,書き出しといった動作はしてくれるものの,ループ自体が7回目の段階で終了してしまう.

ソースコード

C++

1#include <string.h> 2#include <iostream> 3#include <fstream> 4#include <opencv2/opencv.hpp> 5#include <opencv2/core.hpp> 6#include <opencv2/features2d/features2d.hpp> 7#include <opencv2/highgui/highgui.hpp> 8#include <opencv2/xfeatures2d/nonfree.hpp> 9#include <opencv2/imgcodecs.hpp> 10 11using namespace cv; 12using namespace std; 13 14int main() { 15 16 auto algorithm = KAZE::create();//auto型:変数の型を推測? 17 18 vector<KeyPoint> keypoint1; 19 Mat color_image, gray_image, descriptor1, dest1; 20 string filename, exportname, writename; 21 int count = 0; 22 23 for (int j = 1; j < 6; j++) { 24 for (int i = 1; i < 9; i++) { 25 26 filename = "./true/test" + to_string(j) + "-" + to_string(i) + ".bmp"; 27 exportname = "./true_res/test" + to_string(j) + "-" + to_string(i) + "_result.bmp"; 28 29 30 //画像指定 31 color_image = imread(filename, 1); 32 if (color_image.empty()) { 33 return -1; 34 } 35 36 //resize(color_image, color_image, Size(), 0.5, 0.5); 37 38 cvtColor(color_image, gray_image, COLOR_RGB2GRAY); 39 normalize(gray_image, gray_image, 0, 255, NORM_MINMAX); 40 41 42 algorithm->detect(gray_image, keypoint1); 43 algorithm->compute(gray_image, keypoint1, descriptor1); 44 45 drawKeypoints(color_image, keypoint1, dest1); 46 47 imshow("result2", dest1); 48 imwrite(exportname, dest1); 49 waitKey(50); 50 51 writename = "./true_kp_res/test" + to_string(j) + "-" + to_string(i) + "_kp.csv"; 52 ofstream ofs(writename); 53 54 for (const auto& p : keypoint1) { 55 ofs << p.pt.x << "," << p.pt.y << "," << p.angle << endl; 56 count++; 57 } 58 59 60 } 61 } 62 return 0; 63}

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

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

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

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

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

int32_t

2021/12/20 04:15

color_image.empty() で return -1 しているかどうかは調べましたか?
0sashimi

2021/12/20 04:21

今確認してきましたが,おっしゃる通りでした.この部分でreturn -1していました.
int32_t

2021/12/20 04:25

回答書いておきます。
guest

回答2

0

ベストアンサー

c++

1 color_image = imread(filename, 1); 2 if (color_image.empty()) { 3 return -1; 4 }

この return -1 で関数を抜けているのでしょう。そのときの filename を調べて、対応するファイルがなかったり壊れてたりしないか確認しましょう。

投稿2021/12/20 04:26

編集2021/12/20 04:27
int32_t

総合スコア20888

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

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

0sashimi

2021/12/20 04:29

使用していたサンプルリストを確認したところ,xxx_1-7.bmpが欠落していました. 回答ありがとうございました.
guest

0

for (int j = 1; j < 6; j++) {

CとかC++の入門サイトを見て、for文がどういう動作をするのか調べてみよう。
この文は、j が1から始まって5まで(6未満)、5回のループを回るってことになってます

投稿2021/12/20 04:16

y_waiwai

総合スコア87782

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問