벡터양자화 도와주세요 ㅠㅠ 엉엉
징징몬
벡터양자화 하는데 좀 도와주세요 ㅠㅠ
질문 내용 :
#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이 되면 좋겠는데.
어떻게 해야하는지 자세히좀 알려주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |
2675193 | 연습문제 17-1 질문입니다. | 한별나라 | 2024-11-15 |