벡터양자화 도와주세요 ㅠㅠ 엉엉
징징몬
벡터양자화 하는데 좀 도와주세요 ㅠㅠ
질문 내용 :
#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이 되면 좋겠는데.
어떻게 해야하는지 자세히좀 알려주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2704529 | 메모리 동적 할당 관련해서 질문 있습니다~ | 궁수자리 | 2025-08-11 |
2704497 | int double char 같은것좀 좀만 더 가르쳐 주세요 (6) | 로지 | 2025-08-10 |
2704473 | 구조체 배열 초기화 질문 | 꽃은별 | 2025-08-10 |
2704445 | 배열과 조건문에 관한질문 (3) | 찬솔큰 | 2025-08-10 |
2704417 | 이진 트리 깊이 값 구하는것 질문입니다. | 푸른잎 | 2025-08-10 |
2704391 | 자료 유형에 관련된 문제입니다. (2) | 늘솜 | 2025-08-09 |
2704365 | c언어 문제안되서물어봅니다 (3) | 맑은가람 | 2025-08-09 |
2704338 | 다항식의 뺄셈에 대해 질문드립니다... (1) | 여자 | 2025-08-09 |
2704311 | 센서를 이용한 라인 주행인데 명령어좀 알려주세요 ㅠ_ㅠ (3) | 초록이 | 2025-08-09 |
2704284 | 배열for문;; (3) | 은솜 | 2025-08-08 |
2704255 | readline(int fd, char *buf, int nbytes)함수를 구현하는법좀..ㅠㅠ | 파라나 | 2025-08-08 |
2704196 | 간단한 c언어좀 만들어주세요 (2) | 슬S2아 | 2025-08-08 |
2704118 | 성적에서 등수 구하기 (4) | 딥레드 | 2025-08-07 |
2704062 | 알고리즘 알려주세요 | 나리 | 2025-08-06 |
2704035 | 답은 나오는데 과정에서 `` 약간 이상합니다.ㅎㅎ 답만나와버려요 | 핫블랙 | 2025-08-06 |
2703979 | 문자열 EEPROM 작성 방법 문의드립니다. | 그녀는귀여웠다 | 2025-08-06 |
2703954 | 키보드를 입력하면 캐릭터를 움직이기 질문 (7) | 좋아해 | 2025-08-05 |
2703924 | 계속 에러가... (4) | 눈꽃 | 2025-08-05 |
2703897 | 배열의 최댓값과 최솟값 차이 구하기 (1) | 하늬 | 2025-08-05 |
2703869 | C언어 질문입니다 급해용!!! ㅠㅠ (2) | 덕이 | 2025-08-05 |