벡터양자화 도와주세요 ㅠㅠ 엉엉
징징몬
벡터양자화 하는데 좀 도와주세요 ㅠㅠ
질문 내용 :
#include stdio.h
#include stdlib.h
#include math.h
void main()
{
file *fp1;
file *fp2;
int i,j;
int num1=0;
int num2=0;
int num3=0;
int num4=0;
int count2=0;
int count4=0;
double diff1=0;
double diff2=0;
double m1=0;
double m2=0;
double m3=0;
double m4=0;
unsigned char buff1[(512*512)/4][4];//image 4차원으로 읽어들이기
unsigned char buff2[(512*512)/4][4];
double c[1][4];
double c2[2][4];
double d[2][4];
double d2[2][4];
double count[(512*512)/4][1];
double count3[(512*512)/4][1];// 이전값과 현재값을 비교해서 0.001만들때 사용할것
unsigned char code2_4[2][4];
fp1=fopen(zero.img,rb);
fread(buff1,sizeof(unsigned char),512*512,fp1); //영상 4차원으로 읽어오기
for(i=0;i(512*512)/4;i++)
{
for (j=0;j4;j++)
{
c[0][j]+=buff1[i][j]; //초기 벡터 만들기위해서 더함
}
}
for (j=0;j4;j++)
{
c[0][j]=c[0][j]/((512*512)/4); // 초기 벡터 기준값
}
for (j=0;j4;j++)
{
c2[0][j]=c[0][j]-0.001;
c2[1][j]=c[0][j]+0.001;
}
for (i=0;i(512*512)/4;i++)
{
for (j=0;j4;j++)
{
m1+=(double)(buff1[i][j]-c2[0][j])*(buff1[i][j]-c2[0][j]);
m2+=(double)(buff1[i][j]-c2[1][j])*(buff1[i][j]-c2[1][j]);
if (m1m2)
{
d[0][j]+=buff1[i][j];
count[i][0]=0; // d[0][]인지 d[1][]인지 구분하기위해서
num1+=1;
}
else
{
d[1][j]+=buff1[i][j];
count[i][0]=1; // d[0][]인지 d[1][]인지 구분하기위해서
num2+=1;
}
}
}
for (j=0;j4;j++)
{
d[0][j]=d[0][j]/num1; // 1번째 새로 구해진 평균 기준값
d[1][j]=d[1][j]/num2;
}
num1=0;
num2=0;
for(i=0;i(512*512)/4;i++)
{
count2=(int)count[i][0];
if(count2=0)
{
for (j=0;j4;j++)
{
d2[0][j]+=buff1[i][j];
num3+=1;
}
}
else
{
for (j=0;j4;j++)
{
d2[1][j]+=buff1[i][j];
num4+=1;
}
}
}
for (i=0;i(512*512)/4;i++)
{
count2=(int)count[i][0];
for (j=0;j4;j++)
{
diff1+=(double)(buff1[i][j]-d[count2][j])*(buff1[i][j]-d[count2][j]);
}
}
for (j=0;j4;j++)
{
d2[0][j]=d2[0][j]/num3; // 2번째 새로 구해진 평균 기준값
d2[1][j]=d2[1][j]/num4;
}
num3=0;
num4=0;
for (i=0;i(512*512)/4;i++)
{
for (j=0;j4;j++)
{
m3+=(double)(buff1[i][j]-d2[0][j])*(buff1[i][j]-d2[0][j]);
m4+=(double)(buff1[i][j]-d2[1][j])*(buff1[i][j]-d2[1][j]);
pif (m3m4)
{
d2[0][j]+=buff1[i][j];
count3[i][0]=0; // d2[0][]인지 d[1][]인지 구분하기위해서
num1+=1;
}
else
{
d2[1][j]+=buff1[i][j];
count3[i][0]=1; // d2[0][]인지 d[1][]인지 구분하기위해서
num2+=1;
}
}
}
for (i=0;i(512*512)/4;i++)
{
count4=(int)count3[i][0];
for (j=0;j4;j++)
{
diff2+=(double)(buff1[i][j]-d2[count4][j])*(buff1[i][j]-d2[count4][j]);
}
}
for(i=0;i2;i++)
{
for (j=0;j4;j++)
{
code2_4[i][j]=(unsigned char)(d2[i][j]);
printf(%d ,code2_4[i][j]);
}
}
printf(different= %lf,((diff1-diff2)/diff1));
fp1=fopen(code2_4.img,wb);
fwrite(buff2,sizeof(unsigned char),(512*512)/4,fp2);
fclose(fp2);return 0;
}
왜 안돌아가는지 ㅠㅠ
고쳐주세요ㅠㅠ
이게 ((diff1-diff2)/diff1) 차이게 0.001이 되면 좋겠구요....
이 순서가 반복이되서 코드북 사이즈가 16이 되면 좋겠는데.
어떻게 해야하는지 자세히좀 알려주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |
2691450 | [visual c++ 툴]기초 질문 (3) | 해긴 | 2025-04-13 |