本文整理汇总了C++中BMP::init方法的典型用法代码示例。如果您正苦于以下问题:C++ BMP::init方法的具体用法?C++ BMP::init怎么用?C++ BMP::init使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类BMP
的用法示例。
在下文中一共展示了BMP::init方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: memset
int
main(int argc,char** argv){
quality=atof(argv[1]);
BMP fin2 (argv[2]);
BMP fin ;fin.init(fin2.w,fin2.h);
BMP fout2;fout2.init(fin2.w,fin2.h);
BMP fout;fout.init(fin2.w,fin2.h);
double in[8][8];
double out[8][8];
double out2[8][8];
int i,j,idx;
init_walsh();
init_dwt();
bmp_for(fin)
RGB2YUV(fin2(x,y),fin(x,y));
int num_dat[14];
double prob_dat[14];
int sum_dat[14];
double bit_dat[14];
memset(num_dat,0,sizeof(num_dat));
int num_totallen=0;
for(int c=0;c<3;c++){
for(int by=0;by<fin.h/8;by++)
for(int bx=0;bx<fin.w/8;bx++){
int num_codelen=0;
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
int x=bx*8+dx;
int y=by*8+dy;
in[ dy][ dx]=fin(x,y)[c];
// in[ dy][ dx]=255;
}
//dct(in,out);
//walsh(in,out);
// mprint(in);
//dwt(in,out);
haar(in,out);
// mprint(out);
// idwt(out,in);
// mprint(in);
// return 0;
// ihaar(out,in);
// mprint(in);
// return 0;
// if(c!=0)
mmap(out,(1.0/(qt[c][y][x]*quality))*);
mmap(out,round);
// mprint(out);
vector<RunBit> rvec;
vector<Code> cvec;
mkRunBit(out,rvec);
mkCode(rvec,cvec);
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
num_dat[(int)(log(fabs(out[dy][dx])+1.0)/log(2))]++;
}
// for(int i=0;i<rvec.size();i++)
// printf("%d %d\n",rvec[i].zero,rvec[i].code);
// printf("\n");
// for(int i=0;i<cvec.size();i++)
// printf("%d %x\n",cvec[i].len,cvec[i].code);
// return 0;
for(int i=0;i<cvec.size();i++)
num_codelen+=cvec[i].len;
double comprate=(double)(8*8*8)/(double)(num_codelen);
// if(comprate<3){
// mprint(out);
// for(int i=0;i<rvec.size();i++)
// printf("%d %d\n",rvec[i].zero,rvec[i].code);
// printf("\n");
// for(int i=0;i<cvec.size();i++)
// printf("%d %x\n",cvec[i].len,cvec[i].code);
// printf("\n");
// printf("comprate %f",comprate);
//.........这里部分代码省略.........
示例2: create
BMP* BMP::create(char* file)
{
BMP* bmp = new BMP();
bmp->init(file);
return bmp;
}
示例3: fin
int
main(int argc,char** argv){
BMP fin (argv[1]);
BMP fout;fout.init(fin.w,fin.h);
double (*in )[8];
double (*out )[8];
double (*out2)[8];
fftw_plan p ;
int i,j,idx;
in = (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
out = (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
out2= (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
for(int c=0;c<3;c++){
for(int by=0;by<fin.h/8;by++)
for(int bx=0;bx<fin.w/8;bx++){
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
int x=bx*8+dx;
int y=by*8+dy;
in[ dy][ dx]=fin(x,y)[c];
}
p = fftw_plan_r2r_2d( 8,8,
(double*)in, (double*)out,
FFTW_REDFT10,FFTW_REDFT10,
FFTW_ESTIMATE );
fftw_execute(p);
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
out[ dy][ dx]/=8*8*4;
}
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
// out[ dy][ dx]=round(out[ dy][ dx]/(qt[dy][dx]*quality));
out[ dy][ dx]=round(out[ dy][ dx]/2);
}
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
// out[ dy][ dx]*=qt[dy][dx]*quality;
out[ dy][ dx]*=2;
}
// for(int dy=0;dy<8;dy++)
// for(int dx=0;dx<8;dx++){
// printf("%04d\n",(int)out[ dy][ dx]);
// }
p = fftw_plan_r2r_2d( 8,8,
(double*)out, (double*)out2,
FFTW_REDFT01,FFTW_REDFT01,
FFTW_ESTIMATE );
fftw_execute(p);
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
int x=bx*8+dx;
int y=by*8+dy;
fout(x,y)[c]=lmt(out2[ dy][ dx]);
}
}
}
fout.write(argv[2]);
fftw_destroy_plan(p);
fftw_free(in);
fftw_free(out);
fftw_free(out2);
return true;
}