视频一区视频二区在线观看_国产欧美激情在线观看_免费的av网址_莫妮卡裸全乳无删减电影_免费的一级黄色片_福利姬免费_欧美jizz19性欧美_在线观看免费视频国产_日本免费三级电影_亚洲tv在线_很黄很色的视频_亚洲免费视频一区_91黄色影视_草莓视频.www_成人欧美一区二区三区白人

你的位置:首頁 > 電路保護 > 正文

高斯濾波器的原理及實現過程

發布時間:2019-09-02 責任編輯:xueqi

【導讀】高斯濾波器是一種線性濾波器,能夠有效的抑制噪聲,平滑圖像。其作用原理和均值濾波器類似,都是取濾波器窗口內的像素的均值作為輸出。本文主要介紹了高斯濾波器的原理及其實現過程。
 
其窗口模板的系數和均值濾波器不同,均值濾波器的模板系數都是相同的為1;而高斯濾波器的模板系數,則隨著距離模板中心的增大而系數減小。所以,高斯濾波器相比于均值濾波器對圖像個模糊程度較小。
 
什么是高斯濾波器
 
既然名稱為高斯濾波器,那么其和高斯分布(正態分布)是有一定的關系的。一個二維的高斯函數如下:
 
 
其中(x,y)(x,y)為點坐標,在圖像處理中可認為是整數;σσ是標準差。要想得到一個高斯濾波器的模板,可以對高斯函數進行離散化,得到的高斯函數值作為模板的系數。例如:要產生一個3×33×3的高斯濾波器模板,以模板的中心位置為坐標原點進行取樣。模板在各個位置的坐標,如下所示(x軸水平向右,y軸豎直向下)
 
 
這樣,將各個位置的坐標帶入到高斯函數中,得到的值就是模板的系數。
對于窗口模板的大小為(2k+1)×(2k+1),模板中各個元素值的計算公式如下:
 
 
這樣計算出來的模板有兩種形式:小數和整數。
小數形式的模板,就是直接計算得到的值,沒有經過任何的處理;
 
整數形式的,則需要進行歸一化處理,將模板左上角的值歸一化為1,下面會具體介紹。使用整數的模板時,需要在模板的前面加一個系數,系數為
也就是模板系數和的倒數。
 
高斯模板的生成
 
知道模板生成的原理,實現起來也就不困難了
 
void generateGaussianTemplate(double window[][11], int ksize, double sigma)
{
    static const double pi = 3.1415926;
    int center = ksize / 2; // 模板的中心位置,也就是坐標的原點
    double x2, y2;
    for (int i = 0; i < ksize; i++)
    {
        x2 = pow(i - center, 2);
        for (int j = 0; j < ksize; j++)
        {
            y2 = pow(j - center, 2);
            double g = exp(-(x2 + y2) / (2 * sigma * sigma));
            g /= 2 * pi * sigma;
            window[i][j] = g;
        }
    }
    double k = 1 / window[0][0]; // 將左上角的系數歸一化為1
    for (int i = 0; i < ksize; i++)
    {
        for (int j = 0; j < ksize; j++)
        {
            window[i][j] *= k;
        }
    }
}
 
 
需要一個二維數組,存放生成的系數(這里假設模板的最大尺寸不會超過11);第二個參數是模板的大小(不要超過11);第三個參數就比較重要了,是高斯分布的標準差。
 
生成的過程,首先根據模板的大小,找到模板的中心位置ksize/2。然后就是遍歷,根據高斯分布的函數,計算模板中每個系數的值。
 
需要注意的是,最后歸一化的過程,使用模板左上角的系數的倒數作為歸一化的系數(左上角的系數值被歸一化為1),模板中的每個系數都乘以該值(左上角系數的倒數),然后將得到的值取整,就得到了整數型的高斯濾波器模板。
 
下面截圖生成的是,大小為3×3,σ=0.83×3,σ=0.8的模板
 
 
對上述解結果取整后得到如下模板:
 
 
這個模板就比較熟悉了,其就是根據σ=0.8的高斯函數生成的模板。
至于小數形式的生成也比較簡單,去掉歸一化的過程,并且在求解過程后,模板的每個系數要除以所有系數的和。具體代碼如下:
void generateGaussianTemplate(double window[][11], int ksize, double sigma)
{
    static const double pi = 3.1415926;
    int center = ksize / 2; // 模板的中心位置,也就是坐標的原點
    double x2, y2;
    double sum = 0;
    for (int i = 0; i < ksize; i++)
    {
        x2 = pow(i - center, 2);
        for (int j = 0; j < ksize; j++)
        {
            y2 = pow(j - center, 2);
            double g = exp(-(x2 + y2) / (2 * sigma * sigma));
            g /= 2 * pi * sigma;
            sum += g;
            window[i][j] = g;
        }
    }
    //double k = 1 / window[0][0]; // 將左上角的系數歸一化為1
    for (int i = 0; i < ksize; i++)
    {
        for (int j = 0; j < ksize; j++)
        {
            window[i][j] /= sum;
        }
    }
}
 
3×3,σ=0.8的小數型模板。
 
 
σσ值的意義及選取
 
通過上述的實現過程,不難發現,高斯濾波器模板的生成最重要的參數就是高斯分布的標準差σσ。標準差代表著數據的離散程度,如果σσ較小,那么生成的模板的中心系數較大,而周圍的系數較小,這樣對圖像的平滑效果就不是很明顯;反之,σσ較大,則生成的模板的各個系數相差就不是很大,比較類似均值模板,對圖像的平滑效果比較明顯。
 
來看下一維高斯分布的概率分布密度圖:
 
 
橫軸表示可能得取值x,豎軸表示概率分布密度F(x),那么不難理解這樣一個曲線與x軸圍成的圖形面積為1。σσ(標準差)決定了這個圖形的寬度,可以得出這樣的結論:σσ越大,則圖形越寬,尖峰越小,圖形較為平緩;σσ越小,則圖形越窄,越集中,中間部分也就越尖,圖形變化比較劇烈。這其實很好理解,如果sigma也就是標準差越大,則表示該密度分布一定比較分散,由于面積為1,于是尖峰部分減小,寬度越寬(分布越分散);同理,當σσ越小時,說明密度分布較為集中,于是尖峰越尖,寬度越窄!
 
于是可以得到如下結論:
σσ越大,分布越分散,各部分比重差別不大,于是生成的模板各元素值差別不大,類似于平均模板;
σσ越小,分布越集中,中間部分所占比重遠遠高于其他部分,反映到高斯模板上就是中心元素值遠遠大于其他元素值,于是自然而然就相當于中間值得點運算。
 
基于OpenCV的實現
 
在生成高斯模板好,其簡單的實現和其他的空間濾波器沒有區別,具體代碼如下:
void GaussianFilter(const Mat &src, Mat &dst, int ksize, double sigma)
{
    CV_Assert(src.channels() || src.channels() == 3); // 只處理單通道或者三通道圖像
    const static double pi = 3.1415926;
    // 根據窗口大小和sigma生成高斯濾波器模板
    // 申請一個二維數組,存放生成的高斯模板矩陣
    double **templateMatrix = new double*[ksize];
    for (int i = 0; i < ksize; i++)
        templateMatrix[i] = new double[ksize];
    int origin = ksize / 2; // 以模板的中心為原點
    double x2, y2;
    double sum = 0;
    for (int i = 0; i < ksize; i++)
    {
        x2 = pow(i - origin, 2);
        for (int j = 0; j < ksize; j++)
        {
            y2 = pow(j - origin, 2);
            // 高斯函數前的常數可以不用計算,會在歸一化的過程中給消去
            double g = exp(-(x2 + y2) / (2 * sigma * sigma));
            sum += g;
            templateMatrix[i][j] = g;
        }
    }
    for (int i = 0; i < ksize; i++)
    {
        for (int j = 0; j < ksize; j++)
        {
            templateMatrix[i][j] /= sum;
            cout << templateMatrix[i][j] << " ";
        }
        cout << endl;
    }
    // 將模板應用到圖像中
    int border = ksize / 2;
    copyMakeBorder(src, dst, border, border, border, border, BorderTypes::BORDER_REFLECT);
    int channels = dst.channels();
    int rows = dst.rows - border;
    int cols = dst.cols - border;
    for (int i = border; i < rows; i++)
    {
        for (int j = border; j < cols; j++)
        {
            double sum[3] = { 0 };
            for (int a = -border; a <= border; a++)
            {
                for (int b = -border; b <= border; b++)
                {
                    if (channels == 1)
                    {
                        sum[0] += templateMatrix[border + a][border + b] * dst.at<uchar>(i + a, j + b);
                    }
                    else if (channels == 3)
                    {
                        Vec3b rgb = dst.at<Vec3b>(i + a, j + b);
                        auto k = templateMatrix[border + a][border + b];
                        sum[0] += k * rgb[0];
                        sum[1] += k * rgb[1];
                        sum[2] += k * rgb[2];
                    }
                }
            }
            for (int k = 0; k < channels; k++)
            {
                if (sum[k] < 0)
                    sum[k] = 0;
                else if (sum[k] > 255)
                    sum[k] = 255;
            }
            if (channels == 1)
                dst.at<uchar>(i, j) = static_cast<uchar>(sum[0]);
            else if (channels == 3)
            {
                Vec3b rgb = { static_cast<uchar>(sum[0]), static_cast<uchar>(sum[1]), static_cast<uchar>(sum[2]) };
                dst.at<Vec3b>(i, j) = rgb;
            }
        }
    }
    // 釋放模板數組
    for (int i = 0; i < ksize; i++)
        delete[] templateMatrix[i];
    delete[] templateMatrix;
}
 
只處理單通道或者三通道圖像,模板生成后,其濾波(卷積過程)就比較簡單了。不過,這樣的高斯濾波過程,其循環運算次數為m×n×ksize2,其中m,n為圖像的尺寸;ksize為高斯濾波器的尺寸。這樣其時間復雜度為O(ksize2),隨濾波器的模板的尺寸呈平方增長,當高斯濾波器的尺寸較大時,其運算效率是極低的。為了,提高濾波的運算速度,可以將二維的高斯濾波過程分解開來。
 
分離實現高斯濾波
 
由于高斯函數的可分離性,尺寸較大的高斯濾波器可以分成兩步進行:首先將圖像在水平(豎直)方向與一維高斯函數進行卷積;然后將卷積后的結果在豎直(水平)方向使用相同的一維高斯函數得到的模板進行卷積運算。具體實現代碼如下:
 
// 分離的計算
void separateGaussianFilter(const Mat &src, Mat &dst, int ksize, double sigma)
{
    CV_Assert(src.channels()==1 || src.channels() == 3); // 只處理單通道或者三通道圖像
    // 生成一維的高斯濾波模板
    double *matrix = new double[ksize];
    double sum = 0;
    int origin = ksize / 2;
    for (int i = 0; i < ksize; i++)
    {
        // 高斯函數前的常數可以不用計算,會在歸一化的過程中給消去
        double g = exp(-(i - origin) * (i - origin) / (2 * sigma * sigma));
        sum += g;
        matrix[i] = g;
    }
    // 歸一化
    for (int i = 0; i < ksize; i++)
        matrix[i] /= sum;
    // 將模板應用到圖像中
    int border = ksize / 2;
    copyMakeBorder(src, dst, border, border, border, border, BorderTypes::BORDER_REFLECT);
    int channels = dst.channels();
    int rows = dst.rows - border;
    int cols = dst.cols - border;
    // 水平方向
    for (int i = border; i < rows; i++)
    {
        for (int j = border; j < cols; j++)
        {
            double sum[3] = { 0 };
            for (int k = -border; k <= border; k++)
            {
                if (channels == 1)
                {
                    sum[0] += matrix[border + k] * dst.at<uchar>(i, j + k); // 行不變,列變化;先做水平方向的卷積
                }
                else if (channels == 3)
                {
                    Vec3b rgb = dst.at<Vec3b>(i, j + k);
                    sum[0] += matrix[border + k] * rgb[0];
                    sum[1] += matrix[border + k] * rgb[1];
                    sum[2] += matrix[border + k] * rgb[2];
                }
            }
            for (int k = 0; k < channels; k++)
            {
                if (sum[k] < 0)
                    sum[k] = 0;
                else if (sum[k] > 255)
                    sum[k] = 255;
            }
            if (channels == 1)
                dst.at<uchar>(i, j) = static_cast<uchar>(sum[0]);
            else if (channels == 3)
            {
                Vec3b rgb = { static_cast<uchar>(sum[0]), static_cast<uchar>(sum[1]), static_cast<uchar>(sum[2]) };
                dst.at<Vec3b>(i, j) = rgb;
            }
        }
    }
    // 豎直方向
    for (int i = border; i < rows; i++)
    {
        for (int j = border; j < cols; j++)
        {
            double sum[3] = { 0 };
            for (int k = -border; k <= border; k++)
            {
                if (channels == 1)
                {
                    sum[0] += matrix[border + k] * dst.at<uchar>(i + k, j); // 列不變,行變化;豎直方向的卷積
                }
                else if (channels == 3)
                {
                    Vec3b rgb = dst.at<Vec3b>(i + k, j);
                    sum[0] += matrix[border + k] * rgb[0];
                    sum[1] += matrix[border + k] * rgb[1];
                    sum[2] += matrix[border + k] * rgb[2];
                }
            }
            for (int k = 0; k < channels; k++)
            {
                if (sum[k] < 0)
                    sum[k] = 0;
                else if (sum[k] > 255)
                    sum[k] = 255;
            }
            if (channels == 1)
                dst.at<uchar>(i, j) = static_cast<uchar>(sum[0]);
            else if (channels == 3)
            {
                Vec3b rgb = { static_cast<uchar>(sum[0]), static_cast<uchar>(sum[1]), static_cast<uchar>(sum[2]) };
                dst.at<Vec3b>(i, j) = rgb;
            }
        }
    }
    delete[] matrix;
}
 
代碼沒有重構較長,不過其實現原理是比較簡單的。首先得到一維高斯函數的模板,在卷積(濾波)的過程中,保持行不變,列變化,在水平方向上做卷積運算;接著在上述得到的結果上,保持列不邊,行變化,在豎直方向上做卷積運算。這樣分解開來,算法的時間復雜度為O(ksize)O(ksize),運算量和濾波器的模板尺寸呈線性增長。
在OpenCV也有對高斯濾波器的封裝GaussianBlur,其聲明如下:
CV_EXPORTS_W void GaussianBlur( InputArray src, OutputArray dst, Size ksize,
                                double sigmaX, double sigmaY = 0,
                                int borderType = BORDER_DEFAULT );
 
二維高斯函數的標準差在x和y方向上應該分別有一個標準差,在上面的代碼中一直設其在x和y方向的標準是相等的,在OpenCV中的高斯濾波器中,可以在x和y方向上設置不同的標準差。
 
下圖是自己實現的高斯濾波器和OpenCV中的GaussianBlur的結果對比
 
 
上圖是5×5,σ=0.8的高斯濾波器,可以看出兩個實現得到的結果沒有很大的區別。
 
總結
高斯濾波器是一種線性平滑濾波器,其濾波器的模板是對二維高斯函數離散得到。由于高斯模板的中心值最大,四周逐漸減小,其濾波后的結果相對于均值濾波器來說更好。
 
高斯濾波器最重要的參數就是高斯分布的標準差σσ,標準差和高斯濾波器的平滑能力有很大的能力,σσ越大,高斯濾波器的頻帶就較寬,對圖像的平滑程度就越好。通過調節σσ參數,可以平衡對圖像的噪聲的抑制和對圖像的模糊。
特別推薦
技術文章更多>>
技術白皮書下載更多>>
熱門搜索

關閉

?

關閉

色哟哟网页 | av色图| 男男视频肉 | 天天色天 | 女性裸体无遮挡胸 | 三级性生活片 | 精品精品精品 | 麻豆影视在线观看 | 免费看片网站av | 艳魔大战2春荡女淫三级 | 91视频一区二区 | 欧美另类z0zx974| 97自拍视频| 亚洲av电影一区二区 | 亚洲爱色| 午夜亚洲一区 | 欧美zzoo| 亚洲福利免费 | 在线性视频 | 日韩成人av在线播放 | 草草影院av | 国产情侣91 | 厨房掀开馊了裙子挺进 | 久久看视频 | 男女免费视频 | 中文字幕无码精品亚洲资源网久久 | 我和岳交换夫妇爽4p晓娟小说 | 国产激情av | 亚洲视频 一区 | 综合伊人 | 国产做受高潮动漫 | 亚州av一区二区 | 成人做爰69片免费看 | 正在播放日韩精品 | 国产熟妇另类久久久久 | 欧美一级性片 | 五月香婷婷| 波多野结衣成人在线 | 天堂中文资源在线观看 | www.天天操.com | 一边亲一边摸一边脱一边免费 | 日韩精品视频在线观看免费 | 艳魔大战2春荡女淫三级 | 国产18照片色桃 | 萌白酱福利视频 | 美女高潮流白浆 | 中文字幕人妻一区 | 国产精品99久久免费黑人人妻 | 女人十八毛片嫩草av | 国产中文字幕免费 | 久久亚洲av无码西西人体 | 国产精品99久久久久久久久 | 成年人在线网站 | 黄色高清视频在线观看 | 狠狠干夜夜 | 久久中文字幕影院 | 久久人人爽爽人人爽人人片av | 国产精品人人妻人人爽人人牛 | 国产精品99久久久久久久久 | 中文字幕日韩在线视频 | 91春色| 一区二区三区观看 | 久久疯狂做爰流白浆xx | 中文字幕xxx| 女性裸体无遮挡胸 | 亚洲欧美日韩精品 | 日本三级韩国三级美三级91 | 草免费视频 | 斑马电影街 | 黄色的片片片片 | 男男双性顶撞喘嗯啊 | 超碰在线91| 在线免费毛片 | 日本精品视频在线观看 | 禁欲总裁被揉裆呻吟故事动漫 | 在线国产日韩 | 毛片链接| 久久看视频 | 成人一区在线观看 | 五月婷婷综合激情 | 香蕉污视频 | 在线观看黄色网 | 日韩亚洲一区二区 | 美女高潮流白浆 | av不卡在线看 | 欧美国产日韩一区二区 | 男人添女人荫蒂视频 | 黑人精品xxx一区一二区 | 草莓视频www二区在线观看 | 欧美一卡二卡三卡 | 被c到喷水嗯h厨房交换视频 | 黄视频在线免费 | 91高清在线免费观看 | 亚州黄色 | 日韩aaaaaa | 老太色hd色老太hd | 欧美一级性片 | 欧美一卡二卡三卡 | 精品精品精品 | 欧美性生交xxxxxdddd | 草莓视频www二区在线观看 | 综合伊人| 91视频中文字幕 | 久久国产精品免费视频 | 亚洲超碰在线观看 | 一本高清dvd在线播放 | 在线无限看免费粉色视频 | 成人深夜网站 | 欧美操老女人 | 男人的天堂在线 | 久久av在线| 亚洲成人免费av | 九九热只有精品 | 第一次处破女h圆房~h嗯啊 | 91视频在线免费观看 | 中文字幕视频在线 | 黄页网站免费观看 | 女性裸体无遮挡胸 | 色五丁香 | 精品人妻一区二区色欲产成人 | 中文字幕亚洲一区二区三区五十路 | 中文字幕日韩在线视频 | 99这里只有 | 激情综合激情 | 草免费视频 | 久热精品在线观看 | 操白丝美女 | 女性裸体无遮挡胸 | 正在播放日韩精品 | 中文字幕亚洲无线码在线一区 | 在线无限看免费粉色视频 | 亚洲欧洲自拍 | 国产精品第二页 | 在线观看免费观看 | 大陆一级片 | 美日韩精品视频 | 久久国产精品免费视频 | 五月中文字幕 | 亚洲天堂一区 | free性video法国极品 | 久久中文字幕影院 | 欧美男人操女人 | 天堂网在线播放 | 正在播放日韩精品 | 美国禽片禁式1一9 | 91欧美视频| 久久免费少妇高潮久久精品99 | 日本三级韩国三级美三级91 | 日韩在线二区 | 在线观看免费观看 | 欧美精品成人在线 | 男女免费视频 | 麻豆影视在线观看 | 黄色高清视频在线观看 | 国产精品吴梦梦 | 日本大尺度激情做爰hd | 成人一区在线观看 | 成人黄色一级电影 | www.av在线播放 | 亚洲天堂一区 | 欧美怡红院一区二区三区 | 男生操女生的视频软件 | 亚洲系列 | 久久亚洲av无码精品色午夜麻豆 | 男女免费视频 | 日韩精品免费一区二区夜夜嗨 | 日韩精品免费一区二区夜夜嗨 | 亚洲欧美在线综合 | 成人9ⅰ免费影视网站 | 午夜影院污 | 日韩精品免费一区二区夜夜嗨 | 精品久久五月天 | 中文字幕精品亚洲 | 亚洲不卡视频 | 色综合中文字幕 | 国内精品在线观看视频 | 艳魔大战2春荡女淫三级 | 久久疯狂做爰流白浆xx | 中文字幕亚洲一区二区三区五十路 | 中文字幕人妻一区 | 欧美性生交xxxxxdddd | 韩国一级淫片免费看 | 精品中文视频 | 精品国产xxx| 黄色三级图片 | 亚欧中文字幕 | 久久免费少妇高潮久久精品99 | 国产精品久久久久久久久久久久久 | 亚洲精品二区三区 | 日本大尺度激情做爰hd | 精品久久久久久久久久久久久久久久久 | 一级黄色小视频 | 男男视频肉 | 99插插插| 日韩精品免费在线 | 精品精品精品 | 女明星yin乱聚会 | 久久亚洲av无码精品色午夜麻豆 | 亚洲色图首页 | 亚州av一区二区 | 久久99久久99精品免观看 | 国产情侣91| 在线国产视频 | 国产最新精品 | 成人黄色一级电影 | 亚洲 欧美 激情 另类 | 亚洲系列 | 国产做受高潮动漫 | a久久久久 | 国产午夜性春猛交ⅹxxx | a视频在线看| 国产精品操 | 日韩亚洲一区二区 | 国产乱码精品一区二区三区忘忧草 | 超碰人人人 | 久操资源 | 波多野结衣成人在线 | 国产片大尺度裸露床戏 | 日韩久久成人 | 男生操女生的视频软件 | 在线观看黄色小说 | 久久国产精品免费视频 | 日韩久久成人 | 亚洲最新网址 | 久久精品国产亚洲av麻豆色欲 | 欧美精品成人在线 | 极品美女在线 | 超碰在线1 | 波多野结衣在线看 | 国产探花在线精品一区二区 | 亚洲不卡视频 | 不用播放器的av网站 | 国产成人短视频在线观看 | 亚州av一区二区 | sleepless动漫在线观看免费 | 人人爱人人看 | 日韩精品免费一区二区夜夜嗨 | av老司机在线观看 | 黄色小说在线观看视频 | 萌白酱福利视频 | 91国产丝袜播放在线 | 亚洲精品99 | 二区三区 | 班长露出强行被男生揉 | 91高清在线免费观看 | 中文字幕xxx | 久久这里只有精品99 | 国产成人啪精品午夜在线观看 | 久久亚洲av无码精品色午夜麻豆 | www.男人天堂 | 国产探花在线精品一区二区 | 99视频在线看| 亚洲一二三区av | 三年中文在线观看中文版 | 香蕉污视频 | 婷婷射图| 久热精品在线观看 | 波多野结衣在线看 | 欧美怡红院一区二区三区 | 国产精品入口麻豆 | 波多野结衣在线看 | 国产成人啪精品午夜在线观看 | 国av在线| 91人人澡 | aaa一区二区三区 | 8x8x华人永久免费视频 | 成人9ⅰ免费影视网站 | a久久久久 | 日本亲与子乱ay中文 | 草莓视频www二区在线观看 | 日韩综合在线视频 | 日韩成人av在线播放 | 国产精品人妻 | 男人添女人荫蒂视频 | free性video法国极品 | 久久精品国产亚洲av麻豆色欲 | 日本精品视频在线观看 | 久久99久久99精品免观看 | 国产精品99久久免费黑人人妻 | 粉色视频免费 | 国产精品自拍99 | 三年中文在线观看中文版 | 欧美国产日韩一区二区 | 久艹视频在线观看 | 女明星yin乱聚会 | 午夜国产一级 | 爆操杨幂| 天天爽天天干 | 成人黄色一级电影 | 黑人精品xxx一区一二区 | 亚洲 欧美 激情 另类 | 久久九九国产 | 国产精品久久久久久久久久久久久 | 久草精品视频 | 中文字幕在线高清 | 欧美国产日韩一区二区 | 久久免费少妇高潮久久精品99 | 久久国产精品免费视频 | 欧美视频你懂的 | 国产精品人人妻人人爽人人牛 | 久久久久91视频 | 久久久久久国产精品视频 | 正在播放日韩精品 | 精品久久99 | 少妇搡bbbb搡bbb搡小说 | 波多野结衣1区 | 国产情侣91| 久久免费国产 | 五月丁香啪啪 | 天天爽天天干 | 超碰在线1| 亚洲精品99 | 欧美精品成人在线 | 五月天色人阁 | 日批免费在线观看 | 在线国产日韩 | 自拍偷拍第二页 | 中文字幕婷婷 | 故意穿暴露被强好爽 | 日韩精品免费一区二区夜夜嗨 | 午夜亚洲一区 | 欧美日韩综合一区二区三区 | 短裙公车被强好爽h吃奶视频 | 日韩免费黄色片 | 国产三级视频在线 | 三上悠亚痴汉电车 | 一本久久久 | 老太色hd色老太hd | 久久人人爽爽人人爽人人片av | 国产无遮挡在线观看 | 国产精品最新 | 五月在线视频 | 亚洲白浆| 色狠狠一区二区三区 | 黑人操亚洲女人 | 美女高潮流白浆 | 男男双性顶撞喘嗯啊 | 禁欲总裁被揉裆呻吟故事动漫 | 精品久久99 | 黄色三级图片 | 五月天色人阁 | 亚洲 欧美 激情 另类 | 精品视频久久 | 久久亚洲av无码精品色午夜麻豆 | 成年人在线网站 | 麻豆亚洲av熟女国产一区二 | 丁香六月久久 | 中文字幕亚洲一区二区三区五十路 | 黑人精品xxx一区一二区 | 日韩爱爱网址 | 色性av | www.国产视频 | 韩国裸体美女 | 在线亚洲欧洲 | 天堂中文资源在线观看 | 亚洲视频 一区 | 天堂网在线播放 | 亚洲第一二三四区 | 人妻无码久久精品人妻 | 欧美一卡二卡三卡 | 韩国一级淫片免费看 | 亚洲777| 嫩草影院一区二区 | 国产精品操 | 国产精品99久久免费黑人人妻 | 中文字幕精品亚洲 | 中文字幕无码精品亚洲资源网久久 | 亚洲图片综合网 | 中文字幕精品亚洲 | 黄色综合网 | 国产午夜性春猛交ⅹxxx | 97中文在线| 久久亚洲av无码西西人体 | 国产精品原创 | 韩国裸体美女 | 在线黄色小说 | 国产成人啪精品午夜在线观看 | 玖玖色在线| 欧美激情站 | 调教骚受| 精品久久久久久久久久久久久久久久久 | 亚洲欧洲自拍 | 日批的视频| av老司机在线观看 | 欧美同性视频 | 正在播放日韩精品 | 亚洲综合视频一区 | 亚洲一本 | 中文字幕日韩在线视频 | 被c到喷水嗯h厨房交换视频 | 日韩亚洲一区二区 | 综合久久久久久久 | 午夜资源站 | xxxx69日本 | 黑人操亚洲女人 | 亚洲欧洲自拍 | 视频一区视频二区在线观看 | 色哟哟网页 | 第一次处破女h圆房~h嗯啊 | 午夜草逼 | 女主播裸身做直播大全 | 国产探花在线精品一区二区 | 欧美大成色www永久网站婷 | 久久综合欧美 | 日本女优黄色 | 被c到喷水嗯h厨房交换视频 | 99插插插| 天堂中文资源在线观看 | 亚洲欧美日韩精品 | 91偷拍视频| 欧美爱爱爱 | 厨房掀开馊了裙子挺进 | 大陆一级片 | 精品精品精品 | 成人做爰69片免费看 | 麻豆影视在线观看 | 久艹视频在线观看 | 亚洲白浆| 黄色的片片片片 | 黄色高清视频在线观看 | 精品黑人| 亚洲一区二区三区乱码 | 国产精品99久久久久久久久 | 高潮小视频 | 欧美黄色片| 国产91丝袜在线播放九色 | 被c到喷水嗯h厨房交换视频 | 台湾av在线播放 | 绝顶高潮videos合集 | 国产精品99久久免费黑人人妻 | a级在线观看 | 草莓视频www二区在线观看 | 日本大尺度激情做爰hd | av老司机在线观看 | 日本三级韩国三级美三级91 | 波多野结衣在线看 | 成人一区在线观看 | 亚洲成人av电影 | 三级黄色的 | 女性裸体无遮挡胸 | 国产成年人免费视频 | a视频在线看 | 亚洲av电影一区二区 | 波多野结衣人妻 | 美足av电影| 黑人精品xxx一区一二区 | 91手机在线| 男男双性顶撞喘嗯啊 | aaa一区二区三区 | 国产三级精品视频 | 成人av无码一区二区三区 | 亚洲一二三区av | 日韩精品视频在线观看免费 | 国产成年人免费视频 | 一区二区三区观看 | 新天堂在线资源 | 国产69xx| 国产精品99久久免费黑人人妻 | 亚洲欧美在线综合 | 密臀av在线 | 绝顶高潮videos合集 | 国产午夜性春猛交ⅹxxx | 中文字幕无码精品亚洲资源网久久 | 人人澡人人爽 | 一边亲一边摸一边脱一边免费 | 一级黄色小视频 | 午夜窝窝 | 国产午夜性春猛交ⅹxxx | 精品人妻一区二区色欲产成人 | 草莓视频www二区在线观看 | 91高清在线免费观看 | 欧美大成色www永久网站婷 | 精品黑人 | 正在播放日韩精品 | 国产精品人人妻人人爽人人牛 | 在线观看黄色网 | 玖玖色在线 | 欧美国产日韩一区二区 | 在线国产日韩 | 国产成人无码一区二区三区在线 | 久久人人爽爽人人爽人人片av | 中文字幕婷婷 | 久久久久久国产精品视频 | 日本精品视频在线观看 | 五月丁香啪啪 | 一本久久久 | 人人爱爱| 欧美操老女人 |