このプログラムをさらに改良し、ヒストグラム(グレースケール画像のヒストグラム)から、最小値、最大値、平均値、分散、中央値、最頻値の6つの統計量を計算・表示するプログラムを作成しなさい。
といった問題なのですが、誰か詳しい方教えてくれませんか。
#include <stdio.h>
#include <opencv.hpp>
#pragma warning(disable: 4996)
using namespace cv;
int main(int argc, char** argv)
{
//画像データ用変数の宣言
Mat src_img;
//画像データの読み込み
src_img = imread("C:\\opencv4.3.0\\sources\\samples\\lena.jpg", 0);
int m = src_img.cols; //画像の幅(列)xを取得
int n = src_img.rows; //画像の高さ(行)yを取得
int hist[256]; //ヒストグラム(度数分布表)用の配列
FILE* fp;
fp = fopen("histogram.txt", "w+"); // ファイルを開く
//配列histを初期化
for (int i = 0; i <= 255; i++) {
hist[i] = 0;
}
//ヒストグラム(度数分布表)の作成
for (int y = 0; y < n; y++) {
for (int x = 0; x < m; x++) {
hist[src_img.data[y * src_img.step + x]] ++; //ある画素値の度数を計数
}
}
//度数分布表の書き込み
for (int i = 0; i <= 255; i++) {
printf("%d %d\n", i, hist[i]);
fprintf(fp, "%d %d\n", i, hist[i]);
}
fclose(fp); // ファイルを閉じる
//画像の表示用ウィンドウを生成
namedWindow("TEST_IMAGE", WINDOW_AUTOSIZE);
//画像の表示
imshow("TEST_IMAGE", src_img);
//キー入力待ち
waitKey(0);
return 0;
}
No.1ベストアンサー
- 回答日時:
画像処理はあまり詳しくないので自信はありませんが、
ヒストグラム配列 hist から統計量を計算するならば
画素値の最小値 = hist で最初に 0 でない位置
画素値の最大値 = hist で最後に 0 でない位置
画素値の平均値 = Σ[i=0..255](i * hist[i]) / 画素数
画素値の分散 = Σ[i=0..255]( hist[i]*(i - 平均値)^2 ) / 画素数
画素値の中央値 = Σ[i=0..x]hist[i] が 画素数/2 を超える最小の x
画素値の最頻値 = hist 内で最大数の位置
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- Perl 画像が表示でnull; this.src 1 2022/04/19 11:31
- JavaScript アップロードファイルの種類によって処理を分岐させたいのですが書き方が分からずアドバイスお願いします 4 2023/06/17 19:12
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- その他(プログラミング・Web制作) pythonのグローバル変数 2 2022/11/25 18:02
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- Java javaでのプログラム(配列)について質問です. 2 2022/10/14 22:27
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- HTML・CSS CSSが効かずどのように指定すれば良いか分からないのでアドバイスお願い致します 2 2023/06/07 12:25
- C言語・C++・C# このプログラミングの問題を教えて欲しいです。 キーボードから整数kを入力し、kが配列aの中に何個存在 2 2022/12/19 22:50
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語での引数の省略方法
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
複数桁10進数の*桁目だけを抽出...
-
if と配列の組み合わせ
-
実数の整数部,小数部の取得
-
Arduinoのプログラムにエラーが...
-
数字列を3桁ごとにカンマで区切...
-
system関数がうまくいかない
-
アスタリスクでダイヤ型を作る
-
main関数以外での結果の表示?
-
read関数をノンブロッキングで...
-
プログラミング☆
-
c++でテンプレートのコードでわ...
-
ラップ関数とはどんなものですか?
-
c言語の配列を使ってサイコロを...
-
このプログラミング誰か教えて...
-
ファイル操作を教えてください
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
へんな現象
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
if と配列の組み合わせ
-
C言語での奇数の和
-
C言語 配列と関数の練習問題
-
ラップ関数とはどんなものですか?
-
(int *)の意味
-
C言語
-
実数の整数部,小数部の取得
-
足して100になるような乱数のア...
-
卒業研究でよく分からないとこ...
-
数字列を3桁ごとにカンマで区切...
-
c言語
-
std::set<int> で、ある値が何...
-
比較回数と交換回数表示について
おすすめ情報