婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 如何在向量化NumPy數(shù)組上進行移動窗口

如何在向量化NumPy數(shù)組上進行移動窗口

熱門標簽:江西省地圖標注 外呼系統(tǒng)哪些好辦 武漢外呼系統(tǒng)平臺 如何申請400電話費用 沈陽防封電銷卡品牌 富錦商家地圖標注 沈陽人工外呼系統(tǒng)價格 池州外呼調(diào)研線路 沈陽外呼系統(tǒng)呼叫系統(tǒng)

今天很有可能你已經(jīng)做了一些使用滑動窗口(也稱為移動窗口)的事情,而你甚至不知道它。例如:許多編輯算法都是基于移動窗口的。

在GIS中做地形分析的大多數(shù)地形柵格度量(坡度、坡向、山坡陰影等)都基于滑動窗口。很多情況下,對格式化為二維數(shù)組的數(shù)據(jù)進行分析時,都很有可能涉及到滑動窗口。

滑動窗口操作非常普遍,非常有用。它們也很容易在Python中實現(xiàn)。學習如何實現(xiàn)移動窗口將把你的數(shù)據(jù)分析和爭論技能提升到一個新的水平。

什么是滑動窗?

下面的例子顯示了一個3×3(3×3)滑動窗口。用紅色標注的數(shù)組元素是目標元素。這是滑動窗口將計算的新度量的數(shù)組位置。例如,在下面的圖像中,我們可以計算灰色窗口中9個元素的平均值(平均值也是8),并將其分配給目標元素,用紅色標出。你可以計算最小值(0)、最大值(16)或其他一些指標,而不是平均值。對數(shù)組中的每個元素都這樣做。

就是這樣。這就是滑動窗口的基本原理。當然,事情可能變得更加復(fù)雜。有限差分方法可以用于時間和空間數(shù)據(jù)。邏輯可以實現(xiàn)。可以使用更大的窗口大小或非正方形窗口。你懂的。但在其核心,移動窗口分析可以簡單地總結(jié)為鄰居元素的平均值。

需要注意的是,必須為邊緣元素設(shè)置特殊的調(diào)整,因為它們沒有9個相鄰元素。因此,許多分析都排除了邊緣元素。為簡單起見,我們將在本文中排除邊緣元素。

樣例數(shù)組

3x3的滑動窗口

創(chuàng)建一個NumPy數(shù)組

為了實現(xiàn)一些簡單的示例,讓我們創(chuàng)建上面所示的數(shù)組。首先,導(dǎo)入numpy。

import numpy as np

然后使用arange創(chuàng)建一個7×7的數(shù)組,值范圍從1到48。另外,創(chuàng)建另一個包含無數(shù)據(jù)值的數(shù)組,該數(shù)組的形狀和數(shù)據(jù)類型與初始數(shù)組相同。在本例中,我使用-1作為無數(shù)據(jù)值。

a = np.arange(49).reshape((7, 7)) 
b = np.full(a.shape, -1.0)

我們將使用這些數(shù)組來開發(fā)下面的滑動窗口示例。

通過循環(huán)實現(xiàn)滑動窗口

毫無疑問,你已經(jīng)聽說過Python中的循環(huán)很慢,應(yīng)該盡可能避免。特別是在使用大型NumPy數(shù)組時。這是完全正確。盡管如此,我們將首先看一個使用循環(huán)的示例,因為這是一種簡單的方法來概念化在移動窗口操作中發(fā)生的事情。在你通過循環(huán)示例掌握了概念之后,我們將繼續(xù)使用更有效的向量化方法。

要實現(xiàn)移動窗口,只需循環(huán)遍歷所有內(nèi)部數(shù)組元素,識別所有相鄰元素的值,并在特定的計算中使用這些值。

通過行和列偏移量可以很容易地識別相鄰值。3×3窗口的偏移量如下所示。

行偏移

列偏移

循環(huán)中NumPy移動窗口的Python代碼

我們可以用三行代碼實現(xiàn)一個移動窗口。這個例子在滑動窗口內(nèi)計算平均值。首先,循環(huán)遍歷數(shù)組的內(nèi)部行。其次,循環(huán)遍歷數(shù)組的內(nèi)部列。第三,在滑動窗口內(nèi)計算平均值,并將值賦給輸出數(shù)組中相應(yīng)的數(shù)組元素。

for i in range(1, a.shape[0]-1):
    for j in range(1, a.shape[1]-1): 
        b[i, j] = (a[i-1, j-1] + a[i-1, j] + a[i-1, j+1] + a[i, j-1] + a[i, j] + a[i, j+1] + a[i+1, j-1] + a[i+1, j] + a[i+1, j+1]) / 9.0

循環(huán)后結(jié)果

你將注意到結(jié)果與輸入數(shù)組具有相同的值,但是外部元素沒有被分配數(shù)據(jù)值,因為它們不包含9個相鄰元素。

[[-1. -1. -1. -1. -1. -1. -1.]
 [-1. 8. 9. 10. 11. 12. -1.]
 [-1. 15. 16. 17. 18. 19. -1.]
 [-1. 22. 23. 24. 25. 26. -1.]
 [-1. 29. 30. 31. 32. 33. -1.] 
 [-1. 36. 37. 38. 39. 40. -1.]
 [-1. -1. -1. -1. -1. -1. -1.]]

向量化滑動窗口

Python中的數(shù)組循環(huán)通常計算效率低下。通過對通常在循環(huán)中執(zhí)行的操作進行向量化,可以提高效率。移動窗口矢量化可以通過同時抵消數(shù)組內(nèi)部的所有元素來實現(xiàn)。

如下圖所示。每個圖像都有相應(yīng)的索引。你將注意到最后一張圖像索引了所有內(nèi)部元素,并且對應(yīng)的圖像索引了每個相鄰元素的偏移量。



從左到右的偏移索引:[1:-1,:-2],[1:-1,2:],[2 :, 2:]



從左到右的偏移索引:[2 :,:-2],[2 :, 1:-1],[:-2,1:-1]




從左到右的偏移索引:[:-2,2:],[:-2,:-2],[1:-1、1:-1]

Numpy數(shù)組上的向量化移動窗口的Python代碼

有了上述偏移量,我們現(xiàn)在可以輕松地在一行代碼中實現(xiàn)滑動窗口。 只需將輸出數(shù)組的所有內(nèi)部元素設(shè)置為根據(jù)相鄰元素計算所需輸出的函數(shù)。

b[1:-1, 1:-1] = (a[1:-1, 1:-1] + a[:-2, 1:-1] + a[2:, 1:-1] + a[1:-1, :-2] + a[1:-1, 2:] + a[2:, 2:] + a[:-2, :-2] + a[2:, :-2] + a[:-2, 2:]) / 9.0

矢量化滑動窗口結(jié)果

如你所見,這將得到與循環(huán)相同的結(jié)果。

[[-1. -1. -1. -1. -1. -1. -1.]
 [-1. 8. 9. 10. 11. 12. -1.]
 [-1. 15. 16. 17. 18. 19. -1.]
 [-1. 22. 23. 24. 25. 26. -1.]
 [-1. 29. 30. 31. 32. 33. -1.]
 [-1. 36. 37. 38. 39. 40. -1.]
 [-1. -1. -1. -1. -1. -1. -1.]]

速度比較

上述兩種方法產(chǎn)生相同的結(jié)果,但哪一種更有效?我計算了從5行到100列的數(shù)組的每種方法的速度。每種方法對每個測試100次。下面是每種方法的平均時間。

很明顯,向量化的方法更加有效。隨著數(shù)組大小的增加,循環(huán)的效率呈指數(shù)級下降。另外,需要注意的是,一個包含10,000個元素(100行和100列)的數(shù)組非常小。

總結(jié)

移動窗口計算在許多數(shù)據(jù)分析工作流程中非常常見。這些計算是非常有用的,非常容易實現(xiàn)。然而,使用循環(huán)來實現(xiàn)滑動窗口操作是非常低效的。

向量化的移動窗口實現(xiàn)不僅更高效,而且使用更少的代碼行。一旦掌握了實現(xiàn)滑動窗口的向量化方法,就可以輕松有效地提高工作流程的速度。

補充:Python學習筆記——Numpy數(shù)組的移動滑窗,使用as_strided實現(xiàn)

Numpy中移動滑窗的實現(xiàn)

為何需要移動滑窗

在量化投資分析過程中,對歷史數(shù)據(jù)進行分析是一個必不可少的步驟。滑窗在歷史數(shù)據(jù)分析中的重要性不言而喻。譬如移動平均、指數(shù)平滑移動平均、MACD、DMA等等價格指標的計算都無一例外需要用到滑窗。

作為一種非常受歡迎的數(shù)據(jù)分析工具,pandas中提供了專門的滑窗類:DataFrame.rolling()。通過這個滑窗類,可以非常容易地實現(xiàn)移動平均等等算法,但是,在某些情況下,Pandas的運行速度還是不夠,需要借助Numpy的高效率進一步提升速度,這時候就需要在Numpy中實現(xiàn)滑窗了。

Numpy中的移動滑窗

可惜Numpy并沒有提供直接簡單的滑窗方法,如果使用for-loop來實現(xiàn)滑窗,不僅效率打折扣,而且內(nèi)存占用也非常大。實際上,Numpy提供了一個非常底層的函數(shù)可以用來生成滑窗:Numpy.lib.stride_tricks.as_stried。

移動滑窗的as_strided實現(xiàn)方法

舉一個例子,首先生成一個5000行200列的二維數(shù)組,我們需要在這個二維數(shù)組上生成一個寬度為200的滑窗,也就是說,第一個窗口包含前0~199行數(shù)據(jù),第二個窗口包含1~200行,第三個窗口包含2~201行,以此類推,一共4801組:

In [106]: d = np.random.randint(100, size=(5000,200))

如果使用as_strided函數(shù)生成上述滑窗,需要用下面的代碼,它生成一個三維數(shù)組,包括4801組200X200的矩陣,每一組200X200的矩陣代表一組滑窗:

In [107]: %timeit sd = as_strided(d, (4801,200,200), (200*8, 200*8, 8))
5.97 µs ± 33.2 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)

我們再嘗試一下用for-loop的方法生成一個滑窗檢驗一下前面生成的滑窗是否正確:

In [108]: %%timeit
     ...: sd2 = np.zeros((4801,200,200))
     ...: for i in range(4801):
     ...:     sd2[i] = d[i:i+200]
     ...: 
722 ms ± 98.8 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)

In [109]: np.allclose(sd, sd2)
Out[109]: True

從上面的代碼可以看出,使用as_strided生成一組滑窗,速度竟然是for-loop的十萬倍以上!那么as_strided是如何做到的呢?

關(guān)于as_strided函數(shù)的詳細解析

as_strided是怎么回事呢?看它的函數(shù)解釋:

Signature: as_strided(x, shape=None, strides=None, subok=False, writeable=True)
Docstring:
Create a view into the array with the given shape and strides.

.. warning:: This function has to be used with extreme care, see notes.

Parameters
----------
x : ndarray
Array to create a new.
shape : sequence of int, optional
The shape of the new array. Defaults to "x.shape".
strides : sequence of int, optional
The strides of the new array. Defaults to "x.strides".
subok : bool, optional
If True, subclasses are preserved.
writeable : bool, optional
If set to False, the returned array will always be readonly. Otherwise it will be writable if the original array was. It is advisable to set this to False if possible (see Notes).

Returns
-------
view : ndarray

這個函數(shù)接受的第一個參數(shù)是一個數(shù)組,第二個參數(shù)是輸出的數(shù)據(jù)shape,第三個參數(shù)是stride。要控制數(shù)據(jù)的輸出,shape和stride都非常重要

shape的含義非常簡單,就是指輸出的數(shù)據(jù)的行、列、層數(shù),這個參數(shù)是一個元組,元組的元素數(shù)量等于數(shù)組的維度。

而stride的含義就相對復(fù)雜一些,其實它的含義是指“步幅”,意思是每一個維度的數(shù)據(jù)在內(nèi)存上平移的字節(jié)數(shù)量。

因為數(shù)組在內(nèi)存中的存放方式是一維線性方式存放的,因此要訪問數(shù)組中的某個數(shù)字就需要知道平移到哪一個內(nèi)存單元,ndarray通過stride“步幅”來指定這個平移的幅度。

在as_strided函數(shù)中,stride也是一個元組,其元素的數(shù)量必須跟shape的元素數(shù)量相同,每一個元素就代表該維度的每一個數(shù)據(jù)相對前一個數(shù)據(jù)的內(nèi)存間隔。

舉個例子:

In [188]: d = np.random.randint(10, size=(5,3))

In [189]: d
Out[189]: 
array([[4, 4, 6],
       [2, 9, 3],
       [5, 1, 1],
       [2, 0, 0],
       [9, 2, 3]])


地址0 地址1 地址2 地址3 地址4 地址5 地址6 地址7 地址8 地址9 地址A 地址B 地址C 地址D 地址E
4 4 5 2 9 3 5 1 1 2 0 0 9 2 3

我們之所以看到一個二維數(shù)組,是因為numpy數(shù)組的shape為(5, 3),stride為(24, 8),意思是說,我們看到的數(shù)據(jù)有5行3列,對應(yīng)shape的(5, 3),每一行與前一行間隔24個字節(jié)(其實就是三個數(shù)字,因為每一個int類型占據(jù)8字節(jié),而每一列數(shù)字比前一列相差8字節(jié)(1個數(shù)字)

理解上面的含義以后,也就能理解如何生成一個數(shù)據(jù)滑窗了,如果我們需要生成一個2X3的數(shù)據(jù)滑窗,在d上滑動,實際上可以生成一個4組,2行3列的數(shù)據(jù)視圖,第一組覆蓋d的第0、1兩行,第二層覆蓋d的第1、2兩行,第三層覆蓋d的第2、3兩行……這樣就形成了數(shù)據(jù)滑窗的效果,我們只要在新的數(shù)據(jù)視圖上遍歷,就能遍歷整個滑窗。這樣做的好處是,在整個遍歷的過程中完全不需要對數(shù)據(jù)進行任何移動或復(fù)制的操作,因此速度飛快。

根據(jù)上面的思路,我們需要生成一個新的數(shù)據(jù)視圖,其shape為(4, 2, 3)代表4組(從頭到尾滑動4次),2行3列(滑窗的尺寸)

接下來需要確定stride,如前所述stride同樣是一個包含三個元素的元組,第一個元素是兩層數(shù)據(jù)之間的內(nèi)存間隔,由于我們的滑窗每滑動一次下移一行,因此層stride應(yīng)該是平移三個數(shù)字,也就是24個字節(jié),行stride和列stride與原來的行列stride一致,因為我們需要原樣看到按順序的數(shù)字,因此,新的stride就是:(24, 24, 8)

我們來看看這個新的數(shù)據(jù)視圖是什么樣子:

In [190]: as_strided(d, shape=(4,2,3), strides=(24,24,8))
Out[190]: 
array([[[4, 4, 6],
        [2, 9, 3]],

       [[2, 9, 3],
        [5, 1, 1]],

       [[5, 1, 1],
        [2, 0, 0]],

       [[2, 0, 0],
        [9, 2, 3]]])

看!一個數(shù)據(jù)滑窗正確地出現(xiàn)了!

使用as_strided函數(shù)的危險之處

使用s_strided函數(shù)的最大問題是內(nèi)存讀取風險,在as_strided生成新的視圖時,由于直接操作內(nèi)存地址(這一點像極了C的指針操作),而且它并不會檢查內(nèi)存地址是否越界,因此如果稍有不慎,就會讀到別的內(nèi)存地址。關(guān)鍵是,如果不設(shè)置可讀參數(shù),還能直接對內(nèi)存中的數(shù)據(jù)進行操作,這樣就帶來了無比大的風險。了解這個風險對正確操作至關(guān)重要!

例如,使用下面的stride會直接溢出到其他的未知內(nèi)存地址上,并讀取它的值,甚至還可以直接修改它:

In [194]: as_strided(d, shape=(5,2,3), strides=(24,24,8))
Out[194]: 
array([[[               4,                4,                6],
        [               2,                9,                3]],

       [[               2,                9,                3],
        [               5,                1,                1]],

       [[               5,                1,                1],
        [               2,                0,                0]],

       [[               2,                0,                0],
        [               9,                2,                3]],

       [[               9,                2,                3],
        [2251799813685248,            18963,                0]]])

這時對象的第五組就映射到了三個未知的內(nèi)存地址上,如果不慎修改了這三個地址上的內(nèi)容,就可能造成難以預(yù)料的問題,如程序崩潰等。

所以,官方才在文檔中鄭重地警告:如果有可能,盡量避免使用as_strided函數(shù)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • numpy 聲明空數(shù)組詳解
  • Numpy將二維數(shù)組添加到空數(shù)組的實現(xiàn)
  • 在NumPy中創(chuàng)建空數(shù)組/矩陣的方法
  • NumPy實現(xiàn)ndarray多維數(shù)組操作
  • 如何將numpy二維數(shù)組中的np.nan值替換為指定的值
  • 解決numpy數(shù)組互換兩行及賦值的問題
  • python 將numpy維度不同的數(shù)組相加相乘操作
  • python numpy.power()數(shù)組元素求n次方案例
  • Python 用NumPy創(chuàng)建二維數(shù)組的案例
  • Numpy ndarray 多維數(shù)組對象的使用
  • 淺談Python numpy創(chuàng)建空數(shù)組的問題

標簽:銅川 通遼 潛江 呂梁 阿里 常德 黑龍江 株洲

巨人網(wǎng)絡(luò)通訊聲明:本文標題《如何在向量化NumPy數(shù)組上進行移動窗口》,本文關(guān)鍵詞  如,何在,向,量化,NumPy,數(shù)組,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何在向量化NumPy數(shù)組上進行移動窗口》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何在向量化NumPy數(shù)組上進行移動窗口的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品入口麻豆九色| 亚洲大片免费看| 最好看的中文字幕久久| 偷拍自拍另类欧美| 高清国产一区二区三区| 欧美日韩精品一区二区三区蜜桃| 久久久91精品国产一区二区三区| 亚洲国产成人精品视频| 91偷拍与自偷拍精品| 久久亚洲一区二区三区四区| 亚洲一区二区三区四区在线免费观看| 国产在线观看免费一区| 67194成人在线观看| 亚洲一卡二卡三卡四卡| 成人综合日日夜夜| 亚洲精品一线二线三线无人区| 午夜精品影院在线观看| 色老汉一区二区三区| 欧美国产一区在线| 国产一区二区美女诱惑| 日韩欧美中文字幕一区| 日日夜夜免费精品视频| 欧美在线观看视频一区二区| ...av二区三区久久精品| 成人av动漫网站| 国产丝袜美腿一区二区三区| 国产精品综合av一区二区国产馆| 日韩美一区二区三区| 日韩高清不卡在线| 91精品欧美福利在线观看| 石原莉奈在线亚洲二区| 欧美一区二区三区四区视频| 全部av―极品视觉盛宴亚洲| 欧美一区日本一区韩国一区| 日韩国产欧美在线视频| 日韩女优制服丝袜电影| 美女网站色91| 国产色综合久久| 成人成人成人在线视频| 亚洲人妖av一区二区| 色先锋aa成人| 性欧美疯狂xxxxbbbb| 欧美一区二区二区| 国模少妇一区二区三区| 中文一区一区三区高中清不卡| 99麻豆久久久国产精品免费 | 国产激情91久久精品导航 | 国产不卡免费视频| 日本一区二区三区电影| 色先锋aa成人| 日韩av一区二区在线影视| 日韩精品在线一区| 本田岬高潮一区二区三区| 亚洲精品一二三| 日韩欧美一区中文| www.日韩av| 婷婷开心激情综合| 久久亚洲综合色一区二区三区| av亚洲精华国产精华精华| 亚洲第一会所有码转帖| 久久久久国产一区二区三区四区| 91女厕偷拍女厕偷拍高清| 日本麻豆一区二区三区视频| 国产精品水嫩水嫩| 欧美性猛片xxxx免费看久爱| 韩国欧美国产1区| 亚洲一区二区在线视频| 精品日韩一区二区三区| 日本大香伊一区二区三区| 免费欧美高清视频| 亚洲欧美另类图片小说| 精品91自产拍在线观看一区| 日本久久精品电影| 国产裸体歌舞团一区二区| 亚洲制服欧美中文字幕中文字幕| 一本大道久久a久久精品综合| 99re这里只有精品6| 亚洲国产精品ⅴa在线观看| 精品一区中文字幕| 日韩一区二区三区电影在线观看| 欧美韩国一区二区| 日本91福利区| 精品国产一区二区在线观看| 日韩专区中文字幕一区二区| 久久国产视频网| 亚洲国产成人私人影院tom| 7878成人国产在线观看| 成人av电影在线| 国产一区在线视频| 丝袜诱惑制服诱惑色一区在线观看| 久久久精品欧美丰满| 欧美一二三区在线| 欧美视频中文字幕| 99久久精品国产导航| 国产成人av电影| 国产在线一区观看| 六月丁香婷婷色狠狠久久| 亚洲一级二级三级| 一区二区三区影院| 成人免费在线播放视频| 久久精品人人做人人综合| 日韩精品一区二区三区中文精品| 91精品婷婷国产综合久久竹菊| 色综合视频一区二区三区高清| 成人精品小蝌蚪| 成人午夜视频网站| 国产一区二区三区久久久| 麻豆精品一区二区三区| 热久久久久久久| 香港成人在线视频| 亚洲成人午夜电影| 亚洲国产中文字幕| 婷婷丁香激情综合| 日韩高清欧美激情| 久久成人18免费观看| 国产一区二区精品久久91| 国产精品亚洲第一| 不卡一区中文字幕| 91国产精品成人| 在线观看一区二区视频| 欧美日本视频在线| 69久久99精品久久久久婷婷| 日韩视频一区在线观看| 精品99999| 国产精品久久久99| 一区二区三区在线视频免费 | 91久久一区二区| 欧美日韩精品一区二区天天拍小说 | 日韩一区在线播放| 一区二区三区久久| 日韩av一区二区三区四区| 激情综合色综合久久综合| 成人aaaa免费全部观看| 欧洲国内综合视频| 日韩亚洲欧美在线| 国产亚洲成年网址在线观看| 综合av第一页| 日韩国产精品91| 成人a区在线观看| 欧美日韩精品免费观看视频| 欧美精品一区二区三区在线播放| 国产精品入口麻豆原神| 日韩精品免费专区| 国产福利一区二区三区视频| 一本到高清视频免费精品| 91麻豆精品久久久久蜜臀 | 91精彩视频在线| 欧美白人最猛性xxxxx69交| 国产精品国产自产拍高清av| 日韩电影在线看| 成人a级免费电影| 欧美一级日韩一级| 亚洲男人都懂的| 国产成人午夜99999| 欧美性受xxxx黑人xyx性爽| 国产三级精品三级| 青娱乐精品视频| 欧美在线观看视频一区二区| 久久久www成人免费无遮挡大片| 亚洲一区二区三区免费视频| 粉嫩aⅴ一区二区三区四区五区| 欧美日本一区二区| 综合激情成人伊人| 国产一区二区电影| 欧美一级爆毛片| 亚洲一区二区三区视频在线 | 91国偷自产一区二区开放时间 | 91毛片在线观看| 久久久av毛片精品| 蜜桃视频在线一区| 欧美群妇大交群中文字幕| 亚洲少妇中出一区| 岛国一区二区三区| 久久久精品影视| 国内外成人在线视频| 日韩片之四级片| 日本亚洲三级在线| 欧美欧美午夜aⅴ在线观看| 一区av在线播放| 色婷婷综合久久久久中文一区二区| 亚洲国产激情av| 丁香另类激情小说| 国产亚洲1区2区3区| 国产精品1区二区.| 久久久精品国产免费观看同学| 激情综合色播五月| 26uuu精品一区二区| 国模娜娜一区二区三区| 久久久蜜臀国产一区二区| 极品美女销魂一区二区三区免费| 欧美成人精品1314www| 蜜臀av性久久久久蜜臀aⅴ| 欧美精品第1页| 天天影视涩香欲综合网| 欧美福利视频导航| 青青草原综合久久大伊人精品| 精品日韩在线观看| 国产精品自拍av| 亚洲同性gay激情无套| 91原创在线视频|