
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
2バイト画像のバイトオーダーは確認されましたか
Big Endian か Little Endian か
ご回答ありがとうございます。
読み込む画像が1バイトの画像になってました。
1バイト毎読み込むように変えたらうまくいきました。
誠にありがとうございました。
No.1
- 回答日時:
それで具体的に質問したいことは何でしょう?
これだけの情報だと、あなたの作ったプログラムが間違っているとしか答えようが無いと思いますが・・・
この回答への補足
回答ありがとうございます。
下記のプログラムを作成したのですが、間違いがありますでしょうか?
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h>
int main(int argc, char *argv[]) {
char infile[256], histogramfile[256];
int mszx, mszy;
short *inputimg;
int *histogram;
short max;
int i;
short bin_width,bin_num;
FILE *fp;
if (argc != 6) {
printf("Usage: %s (入力画像ファイル) (ヒストグラムファイル) (画像サイズX) (画像サイズY) (区関数) \n", argv[0]);
exit(0);
}
strcpy(infile,argv[1]); /*入力画像ファイル名をinfileに代入*/
strcpy(histogramfile,argv[2]); /*ヒストグラムファイル名をhistogramfileに代入*/
mszx = atoi(argv[3]); /*画像のx方向の画素数をmszxに代入*/
mszy = atoi(argv[4]); /*画像のy方向の画素数をmszyに代入*/
bin_width = atoi(argv[5]); /*区間の幅をbin_widthに代入*/
printf("INPUT ORIGINAL IMAGE = %s \n", infile);
printf("Histogram FILE = %s \n", histogramfile);
printf("size X= %d \n", mszx);
printf("size Y= %d \n", mszy);
printf("bin width= %d \n", bin_width);
/*----------画像のメモリ領域確保 入力画像をメモリに記憶する領域を確保する.---------------*/
inputimg = (short*)malloc(mszx * mszy * sizeof(short));
/*-----------原画像読み込み ヘッダ無しの2バイト画像データファイルを読み込む.-------------*/
if((fp=fopen(infile,"rb")) == NULL) {
printf("OPEN FAILED %s\n", infile);
exit(0);
}
fread(inputimg, sizeof(short), mszx * mszy, fp);
fclose(fp);
/*------------データ区間数の設定 画像値の最大値を求めて区関数を設定する.----------*/
max = 0;
for (i = 0; i < mszx * mszy; i++) {
if ( inputimg[i] > max ){
max = inputimg[i];
}
}
printf("max = %d\n",max);
bin_num = max / bin_width + 1;
printf("bins num= %d\n",bin_num);
/*-----------ヒストグラムのメモリ領域確保 ヒストグラムデータをメモリに記憶する領域を確保する.----------*/
histogram = (int*)malloc(bin_num * sizeof(int));
/*------------ヒストグラムの初期化 ヒストグラムのメモリ領域を0で初期化する.--------------*/
for (i = 0; i < bin_num; i++) {
histogram[i] = 0;
}
/*-------------画像処理 (ヒストグラム作成)-------------*/
for (i = 0; i < mszx * mszy; i++) {
histogram[ (short)( (float) inputimg[i] / (float) bin_width ) ] ++;
}
/*-------------ヒストグラム書き出し------------*/
if((fp=fopen(histogramfile,"wt")) == NULL) {
printf("OPEN FAILED %s\n", histogramfile);
exit(0);
}
fprintf(fp,"Histogram INPUT IMAGE %s \n",infile);
for (i = 0; i < bin_num; i++) {
fprintf(fp,"%d %d \n",i,histogram[i]);
}
fclose(fp);
/*----------メモリ領域開放 確保していたメモリ領域を開放する.------------*/
free(inputimg);
free(histogram);
return 0;
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイルの開き方
-
CASLIIのプログラム(並び替え...
-
socketでの複数NICの扱い
-
VBAでユーザーフォームが自動的...
-
Excelで4096点以上のFFTの方法
-
あるプログラムのコマンドライ...
-
未使用の変数を一括検索する方法
-
OS入ってる機器のソフト・アプ...
-
XnViewにwebpを「いつも開く」...
-
セーブの仕方を教えて下さい
-
VB.NETで、プログラム上から新...
-
TMBMSRV.exeによるCPU使用率上昇
-
プログラムから開く・・・DPP
-
べき乗
-
自動クエリとはどういうもので...
-
Google カレンダーの商用利用
-
VB6から他のプログラムを強制終...
-
クリックするとページ内で説明...
-
excelのexe化について
-
正しい五十音順について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ファイルの開き方
-
あるプログラムのコマンドライ...
-
OS入ってる機器のソフト・アプ...
-
Excelで4096点以上のFFTの方法
-
読み込み中にアクセス違反が発...
-
銃を発砲するならともかく、日...
-
VBAにてメール作成した際、一部...
-
ドロップダウンリストの文字を...
-
PICマイコンのコピー(クローン...
-
UWSCで指定のフォルダを開きたい。
-
XnViewにwebpを「いつも開く」...
-
Excelに埋め込んだVBAのプログ...
-
「Outlookが他のプログラムによ...
-
visual studio 2019を使ってい...
-
未使用の変数を一括検索する方法
-
powered byの表記について
-
VBAでユーザーフォームが自動的...
-
画像を読み込むのと取り込むの...
-
VC++コンソールアプリでウイン...
-
Google カレンダーの商用利用
おすすめ情報