亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? linear.cc

?? pixil 最新的嵌入linux 應(yīng)用程序集,別的地方很難下載
?? CC
字號(hào):
/* *  linear.cc */#include <math.h>#include <iostream.h>#include "linear.hh"void LowPass_5pt(const Image_YUV<Pixel>& img,Image_YUV<Pixel>& dest){  // Get image parameters and assure that they are in the right format.  ImageParam_YUV param;  img.GetParam(param);  ImageParam_YUV param2;  dest.GetParam(param2);  assert(param.chroma ==Chroma444);  assert(param2.chroma==Chroma444);  assert(&img != &dest);  // Lowpass needs two image buffers for correct operation.  // Give hint as the destination image will be completely overwritten.  dest.Hint_ContentsIsNotUsedAnymore();  Pixel*const* yp2  = dest.AskFrameY();  Pixel*const* up2  = dest.AskFrameU();  Pixel*const* vp2  = dest.AskFrameV();  const Pixel*const* yp  = img.AskFrameY_const();  const Pixel*const* up  = img.AskFrameU_const();  const Pixel*const* vp  = img.AskFrameV_const();  /* Do lowpass filtering.     We filter all of the image except a one pixel wide border because the     filter size is 3x3. This border will simply be copied from the original     image.  */       int w = param.width;  int h = param.height;  for (int y=1;y<param.height-1;y++)    for (int x=1;x<param.width-1;x++)      {	yp2[y][x] = (  yp[y-1][x  ] +		       yp[y+1][x  ] +		       yp[y  ][x-1] +		       yp[y  ][x+1] +		     4*yp[y  ][x  ]    +4)/8;	up2[y][x] = (  up[y-1][x  ] + 		       up[y+1][x  ] +		       up[y  ][x-1] +		       up[y  ][x+1] +		     4*up[y  ][x  ]    +4)/8;	vp2[y][x] = (  vp[y-1][x  ] +		       vp[y+1][x  ] +		       vp[y  ][x-1] +		       vp[y  ][x+1] +		     4*vp[y  ][x  ]    +4)/8;      }  // Copy border from old image to filtered one.  for (int x=0;x<param.width;x++)    {      yp2[  0][x]=yp[  0][x]; up2[  0][x]=up[  0][x]; vp2[  0][x]=vp[  0][x];      yp2[h-1][x]=yp[h-1][x]; up2[h-1][x]=up[h-1][x]; vp2[h-1][x]=vp[h-1][x];    }  for (int y=0;y<param.height;y++)    {      yp2[y][  0]=yp[y][  0]; up2[y][0  ]=up[y][  0]; vp2[y][  0]=vp[y][  0];      yp2[y][w-1]=yp[y][w-1]; up2[y][w-1]=up[y][w-1]; vp2[y][w-1]=vp[y][w-1];    }}void LowPass_3x3mean(const Image_YUV<Pixel>& img,Image_YUV<Pixel>& dest){  // Get image parameters and assure that they are in the right format.  ImageParam_YUV param;  img.GetParam(param);  ImageParam_YUV param2;  dest.GetParam(param2);  assert(param.chroma ==Chroma444);  assert(param2.chroma==Chroma444);  assert(&img != &dest);  // Lowpass needs two image buffers for correct operation.  // Give hint as the destination image will be completely overwritten.  dest.Hint_ContentsIsNotUsedAnymore();  Pixel*const* yp2  = dest.AskFrameY();  Pixel*const* up2  = dest.AskFrameU();  Pixel*const* vp2  = dest.AskFrameV();  const Pixel*const* yp  = img.AskFrameY_const();  const Pixel*const* up  = img.AskFrameU_const();  const Pixel*const* vp  = img.AskFrameV_const();  /* Do lowpass filtering.     We filter all of the image except a one pixel wide border because the     filter size is 3x3. This border will simply be copied from the original     image.  */       int w = param.width;  int h = param.height;  for (int y=1;y<param.height-1;y++)    for (int x=1;x<param.width-1;x++)      {	yp2[y][x] = (  yp[y-1][x-1] +		       yp[y-1][x  ] +		       yp[y-1][x+1] +		       yp[y  ][x-1] +		       yp[y  ][x  ] +		       yp[y  ][x+1] +		       yp[y+1][x-1] +		       yp[y+1][x  ] +		       yp[y+1][x+1]    +4)/9;	up2[y][x] = (  up[y-1][x-1] +		       up[y-1][x  ] +		       up[y-1][x+1] +		       up[y  ][x-1] +		       up[y  ][x  ] +		       up[y  ][x+1] +		       up[y+1][x-1] +		       up[y+1][x  ] +		       up[y+1][x+1]    +4)/9;	vp2[y][x] = (  vp[y-1][x-1] +		       vp[y-1][x  ] +		       vp[y-1][x+1] +		       vp[y  ][x-1] +		       vp[y  ][x  ] +		       vp[y  ][x+1] +		       vp[y+1][x-1] +		       vp[y+1][x  ] +		       vp[y+1][x+1]    +4)/9;      }  // Copy border from old image to filtered one.  for (int x=0;x<param.width;x++)    {      yp2[  0][x]=yp[  0][x]; up2[  0][x]=up[  0][x]; vp2[  0][x]=vp[  0][x];      yp2[h-1][x]=yp[h-1][x]; up2[h-1][x]=up[h-1][x]; vp2[h-1][x]=vp[h-1][x];    }  for (int y=0;y<param.height;y++)    {      yp2[y][  0]=yp[y][  0]; up2[y][0  ]=up[y][  0]; vp2[y][  0]=vp[y][  0];      yp2[y][w-1]=yp[y][w-1]; up2[y][w-1]=up[y][w-1]; vp2[y][w-1]=vp[y][w-1];    }}template <class Pel> void ConvolveH(const Bitmap<Pel>& src,Bitmap<Pel>& dst,				    const Array<double>& filter,bool useborder){  int left = -filter.AskBase();  int right=  filter.AskSize()-left-1;  int border=0;  if (useborder) border=src.AskBorderWidth();  int xs = -border+left; if (xs<0) xs=0;  int xe = src.AskWidth()-1+border-right; if (xe>src.AskWidth()-1) xe=src.AskWidth()-1;  // cout << "H-Filtering from " << xs << " to " << xe << endl;  int h = src.AskHeight();  int borderw = src.AskBorderWidth();  dst.Create(xe-xs+1,h,1,1,borderw);  const double* f = filter.Data_const();  const Pel*const* sp = src.AskFrame_const();        Pel*const* dp = dst.AskFrame();  for (int y=-borderw;y<h+borderw;y++)    for (int x=xs;x<=xe;x++)      {	double sum=0.0;	for (int xx=-left;xx<=right;xx++)	  sum += f[xx]*sp[y][x+xx];    	dp[y][x-xs] = (Pel)sum;      }}template <class Pel> void ConvolveV(const Bitmap<Pel>& src,Bitmap<Pel>& dst,				    const Array<double>& filter,bool useborder){  int top   = -filter.AskBase();  int bottom=  filter.AskSize()-top-1;  int border=0;  if (useborder) border=src.AskBorderWidth();  int ys = -border+top; if (ys<0) ys=0;  int ye = src.AskHeight()-1+border-bottom; if (ye>src.AskHeight()-1) ye=src.AskHeight()-1;  // cout << "V-Filtering from " << ys << " to " << ye << endl;  int w = src.AskWidth();  int borderw = src.AskBorderWidth();  dst.Create(w,ye-ys+1,1,1,borderw);  const double* f = filter.Data_const();  const Pel*const* sp = src.AskFrame_const();        Pel*const* dp = dst.AskFrame();  for (int y=ys;y<=ye;y++)    for (int x=-borderw;x<w+borderw;x++)      {	double sum=0.0;	for (int yy=-top;yy<=bottom;yy++)	  sum += f[yy]*sp[y+yy][x];    	dp[y-ys][x] = (Pel)sum;      }}template <class Pel> void ConvolveHV(const Bitmap<Pel>& src,Bitmap<Pel>& dst,				     const Array<double>& filter,bool useborder){  Bitmap<Pel> tmpbm;  ConvolveH(src,tmpbm,filter,useborder);  ConvolveV(tmpbm,dst,filter,useborder);}void NormalizeFilter(Array<double>& filter){  double sum=0.0;  int i0 = filter.AskStartIdx();  int i1 = filter.AskEndIdx();  double* f = filter.Data();  for (int i=i0;i<=i1;i++)    sum += f[i];  const double fact = 1.0/sum;  for (int i=i0;i<=i1;i++)    f[i] *= fact;}void CreateGaussFilter(Array<double>& filter,double sigma,double cutoffval,bool normalize){#define MAXRANGE 100  double filt[MAXRANGE];  double minus_twosigma2inv = -1.0/(2*sigma*sigma);  int lastidx=MAXRANGE-1;  for (int i=0;i<MAXRANGE;i++)    {      filt[i] = exp(i*i*minus_twosigma2inv);      if (filt[i] < cutoffval)	{ lastidx = i-1; break; }    }  if (lastidx==MAXRANGE-1)    throw "CreateGaussFilter(): Gauss filter is too wide.";  filter.Create(2*lastidx+1 , -lastidx);  double* f = filter.Data();  for (int i=0;i<=lastidx;i++)    f[-i]=f[i]=filt[i];  if (normalize) NormalizeFilter(filter);}void CreateGaussDerivFilter(Array<double>& filter,double sigma,double cutoffval=0.01){  CreateGaussFilter(filter,sigma,cutoffval,false);  for (int i=filter.AskStartIdx();i<=filter.AskEndIdx();i++)    filter.Data()[i] *= i;  // normalize  double sum=0.0;  int i0 = filter.AskStartIdx();  int i1 = filter.AskEndIdx();  double* f = filter.Data();  for (int i=i0;i<=i1;i++)    sum += i*f[i];  const double fact = 1.0/sum;  for (int i=i0;i<=i1;i++)    f[i] *= fact;}template class Array<double>;template void ConvolveH (const Bitmap<Pixel>&,Bitmap<Pixel>&,const Array<double>&,bool);template void ConvolveV (const Bitmap<Pixel>&,Bitmap<Pixel>&,const Array<double>&,bool);template void ConvolveHV(const Bitmap<Pixel>&,Bitmap<Pixel>&,const Array<double>&,bool);template void ConvolveH (const Bitmap<double>&,Bitmap<double>&,const Array<double>&,bool);template void ConvolveV (const Bitmap<double>&,Bitmap<double>&,const Array<double>&,bool);template void ConvolveHV(const Bitmap<double>&,Bitmap<double>&,const Array<double>&,bool);#include "libvideogfx/containers/array.cc"

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av网站在线观看| 久久精品水蜜桃av综合天堂| 六月丁香婷婷久久| 国产精品久久看| 欧美三级电影网站| 国产一区二三区| 亚洲国产精品久久久男人的天堂 | 国产宾馆实践打屁股91| 亚洲人成电影网站色mp4| 91精品国产欧美一区二区18| 成人国产精品视频| 蜜乳av一区二区| 国产日韩影视精品| 91麻豆蜜桃一区二区三区| 亚洲国产精品一区二区久久| 日韩精品在线一区| 成人网在线免费视频| 亚洲精品成人天堂一二三| 51午夜精品国产| 成人免费毛片片v| 亚洲影视在线观看| 欧美一二三四区在线| 成人国产精品免费观看动漫| 日韩不卡一区二区三区 | 亚洲高清免费视频| 欧美大尺度电影在线| 97se亚洲国产综合在线| 国产一区二区在线看| 亚洲高清不卡在线| 亚洲欧美区自拍先锋| 国产精品二区一区二区aⅴ污介绍| 欧美视频一区在线| 国产在线看一区| 日韩国产精品久久久久久亚洲| 国产精品乱子久久久久| 日韩三级av在线播放| 欧美日韩不卡一区二区| proumb性欧美在线观看| 国产美女精品在线| 日韩成人午夜精品| 三级久久三级久久久| 舔着乳尖日韩一区| 偷拍亚洲欧洲综合| 国产在线一区二区综合免费视频| 成人激情av网| 日韩欧美国产麻豆| 欧美—级在线免费片| 国产精品欧美久久久久一区二区| 中文字幕日韩一区| 亚洲蜜桃精久久久久久久| 久久久一区二区三区捆绑**| 亚洲欧洲成人精品av97| 一区在线观看免费| 亚洲永久免费视频| 男女视频一区二区| 国模无码大尺度一区二区三区| 国内精品伊人久久久久av一坑 | 免费一级欧美片在线观看| 日韩avvvv在线播放| 亚洲精品一区二区三区蜜桃下载| 中文在线一区二区| 麻豆91小视频| 欧美三级视频在线播放| 久久久精品中文字幕麻豆发布| 亚洲国产日日夜夜| 99精品国产视频| 成人激情av网| 国产精品一卡二卡在线观看| 欧美精品一区二| 精品欧美久久久| 国产日韩欧美不卡| 日韩一级大片在线| 日韩一级免费观看| 国产精品拍天天在线| 国产欧美一区二区三区鸳鸯浴 | 日产欧产美韩系列久久99| 亚洲成人av福利| 美国毛片一区二区| 懂色av一区二区夜夜嗨| 91在线丨porny丨国产| 7777精品伊人久久久大香线蕉完整版 | 欧美一区二区三区视频免费| 欧美亚洲一区二区三区四区| 亚洲精品va在线观看| 亚洲va中文字幕| 久久99深爱久久99精品| 亚洲福利一二三区| xnxx国产精品| 在线综合+亚洲+欧美中文字幕| 精品美女被调教视频大全网站| 国产精品久久久久久久久快鸭| 色综合天天综合色综合av| 亚洲成av人影院| 欧美va天堂va视频va在线| 国产三级精品三级在线专区| 亚洲在线视频网站| 欧美精品一级二级三级| 国产性色一区二区| 日韩中文字幕1| 一本色道久久综合狠狠躁的推荐| 精品欧美一区二区在线观看 | 久久久久88色偷偷免费| 一区二区三区自拍| 东方aⅴ免费观看久久av| 911精品国产一区二区在线| 日韩毛片视频在线看| 国产一区二区三区av电影| 欧美丰满美乳xxx高潮www| 亚洲色图在线视频| 国产激情精品久久久第一区二区 | 国产精品传媒在线| 精品一区精品二区高清| 欧美日韩高清一区二区三区| 中文字幕在线不卡视频| 国产精品888| 精品国产三级a在线观看| 偷拍与自拍一区| 在线亚洲人成电影网站色www| 中文字幕欧美国产| 国产成人av一区二区三区在线| 欧美一区二区久久| 午夜精品福利一区二区三区av | 欧美日本视频在线| 亚洲高清免费观看高清完整版在线观看 | 91视频你懂的| 中文字幕精品一区二区三区精品| 国产综合成人久久大片91| 91精品国产欧美一区二区成人| 视频一区二区国产| 91精品国产色综合久久ai换脸| 亚洲国产成人高清精品| 在线中文字幕一区| 一区二区三区精品视频| 色综合网站在线| 亚洲最新视频在线播放| 91国内精品野花午夜精品| 亚洲视频中文字幕| 一本久道中文字幕精品亚洲嫩| 亚洲欧美偷拍另类a∨色屁股| 色综合久久久久综合体桃花网| 最新国产成人在线观看| 91女人视频在线观看| 亚洲男女一区二区三区| 一本久久a久久精品亚洲| 亚洲一区二区av在线| 欧美日本一道本在线视频| 日韩黄色一级片| 精品女同一区二区| 国产乱码精品一区二区三区av | 国产精品毛片大码女人| 99九九99九九九视频精品| 亚洲三级小视频| 欧美性大战久久久久久久蜜臀| 亚洲高清久久久| 欧美一区二区日韩一区二区| 99久久精品免费| 亚洲午夜在线电影| 欧美一区二区网站| 国产精品资源在线看| 国产精品久久久久一区| 日本高清视频一区二区| 日韩黄色在线观看| 久久亚洲综合av| 91麻豆国产福利在线观看| 午夜av一区二区三区| 久久亚洲私人国产精品va媚药| 99久久久国产精品| 五月激情丁香一区二区三区| 久久综合999| 色琪琪一区二区三区亚洲区| 免费成人美女在线观看| 国产人成亚洲第一网站在线播放| 99国产精品99久久久久久| 亚洲bdsm女犯bdsm网站| 久久噜噜亚洲综合| 成人av资源在线观看| 午夜av一区二区三区| 国产丝袜欧美中文另类| 欧美亚洲综合在线| 韩日av一区二区| 一区二区三区中文字幕| 精品免费国产二区三区| 91老司机福利 在线| 麻豆国产精品官网| 亚洲欧美日韩久久| 精品人在线二区三区| 色婷婷综合久久久| 国产在线视频一区二区| 亚洲图片欧美视频| 国产人伦精品一区二区| 欧美日韩成人综合| www.欧美日韩| 精品综合久久久久久8888| 一区二区三区蜜桃网| 中文字幕不卡一区| 欧美v国产在线一区二区三区| 欧美在线观看18| 成人午夜激情片| 另类欧美日韩国产在线| 亚洲国产精品久久一线不卡|