日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

ARM CPU神经网络自动调度

發布時間:2023/11/28 生活经验 62 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ARM CPU神经网络自动调度 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ARM CPU神經網絡自動調度
對特定設備和工作負載進行自動調整對于獲得最佳性能至關重要。這是一個有關如何通過RPC使用自動調度器為ARM CPU調整整個神經網絡的教程。
為了自動調整神經網絡,將網絡劃分為小的子圖,對其進行獨立調整。每個子圖被視為一個搜索任務。任務調度程序可以對時間進行分片,為這些任務動態分配時間資源。任務調度程序可以預測每個任務對端到端執行時間的影響,優先安排可以最大程度地減少執行時間的任務。
對于每個子圖,使用compute聲明tvm/python/topi,獲取張量表達式形式的計算DAG。然后,使用自動調度器來構造此DAG的搜索空間,搜索良好的調度(低級優化)。
與依靠手動模板定義搜索空間的基于模板的autotvm不同,自動調度程序不需要任何調度模板。換句話說,自動調度程序僅在其中使用計算聲明,tvm/python/topi而不使用現有的調度模板。
本文無法在Windows或最新版本的macOS上運行。要使其運行,需要將本文的內容包裝在一個if name == “main”:塊中。
import numpy as np

import tvm
from tvm import relay, auto_scheduler
import tvm.relay.testing
from tvm.contrib import graph_runtime
from tvm.contrib.utils import tempdir
定義網絡
首先,需要使用中繼前端API定義網絡。可以加載一些tvm.relay.testing預定義的網絡。可以從MXNet,ONNX,PyTorch和TensorFlow加載模型。
對于卷積神經網絡,盡管自動調度程序可以在任何布局下正常工作,發現使用NHWC布局通常可以實現最佳性能。使用自動調度程序對NHWC布局實施了更多優化。建議將模型轉換為NHWC布局以使用自動調度程序。可以使用ConvertLayout傳遞在TVM中進行布局轉換。
def get_network(name, batch_size, layout=“NHWC”, dtype=“float32”):
“”“Get the symbol definition and random weight of a network”""

# auto-scheduler prefers NHWC layout
if layout == "NHWC":image_shape = (224, 224, 3)
elif layout == "NCHW":image_shape = (3, 224, 224)
else:raise ValueError("Invalid layout: " + layout)input_shape = (batch_size,) + image_shape
output_shape = (batch_size, 1000)if name.startswith("resnet-"):n_layer = int(name.split("-")[1])mod, params = relay.testing.resnet.get_workload(num_layers=n_layer,batch_size=batch_size,layout=layout,dtype=dtype,image_shape=image_shape,)
elif name.startswith("resnet3d-"):n_layer = int(name.split("-")[1])mod, params = relay.testing.resnet.get_workload(num_layers=n_layer,batch_size=batch_size,layout=layout,dtype=dtype,image_shape=image_shape,)
elif name == "mobilenet":mod, params = relay.testing.mobilenet.get_workload(batch_size=batch_size, layout=layout, dtype=dtype, image_shape=image_shape)
elif name == "squeezenet_v1.1":assert layout == "NCHW", "squeezenet_v1.1 only supports NCHW layout"mod, params = relay.testing.squeezenet.get_workload(version="1.1",batch_size=batch_size,dtype=dtype,image_shape=image_shape,)
elif name == "inception_v3":input_shape = (batch_size, 3, 299, 299) if layout == "NCHW" else (batch_size, 299, 299, 3)mod, params = relay.testing.inception_v3.get_workload(batch_size=batch_size, dtype=dtype)
elif name == "mxnet":# an example for mxnet modelfrom mxnet.gluon.model_zoo.vision import get_modelassert layout == "NCHW"block = get_model("resnet50_v1", pretrained=True)mod, params = relay.frontend.from_mxnet(block, shape={"data": input_shape}, dtype=dtype)net = mod["main"]net = relay.Function(net.params, relay.nn.softmax(net.body), None, net.type_params, net.attrs)mod = tvm.IRModule.from_expr(net)return mod, params, input_shape, output_shape

啟動RPC跟蹤器
TVM使用RPC會話與ARM板進行通信。在調整期間,調諧器會將生成的代碼發送到電路板上,測量電路板上的代碼速度。
為了擴大調整范圍,TVM使用RPC Tracker來管理分布式設備。RPC跟蹤器是一個集中式控制器節點。可以將所有設備注冊到跟蹤器。例如,如果有10部電話,全部注冊到跟蹤器,行運行10次測量,從而加快了調諧過程。
要啟動RPC跟蹤器,在主機上運行此命令。在整個調整過程中都需要使用跟蹤器,需要為此命令打開一個新終端:
python -m tvm.exec.rpc_tracker --host=0.0.0.0 --port=9190
預期的輸出是
INFO:RPCTracker:bind to 0.0.0.0:9190
將設備注冊到RPC跟蹤器
將設備注冊到跟蹤器。第一步是為ARM設備構建TVM運行時。
? 對于Linux:遵循本節在設備上構建TVM運行時,在設備上構建TVM運行時。然后通過以下方式將設備注冊到跟蹤器
? python -m tvm.exec.rpc_server --tracker=[HOST_IP]:9190 --key=rasp4b-64
(替換[HOST_IP]為主機的IP地址)
? 對于Android:按照以下Readme在Android設備上安裝TVM RPC APK。確保可以通過android rpc測試。然后,已經注冊了設備。在調整過程中,必須轉到開發人員選項,啟用“更改時保持屏幕喚醒”并為手機充電以使其穩定。
注冊設備后,通過查詢rpc_tracker進行確認
python -m tvm.exec.query_rpc_tracker --host=0.0.0.0 --port=9190
例如,如果有2個Huawei mate10 pro,11個具有64位操作系統的Raspberry Pi 4B和2個rk3399,輸出可以是
Queue Status

key total free pending

mate10pro 2 2 0
rk3399 2 2 0
rasp4b-64 11 11 0

可以將多個設備注冊到跟蹤器,加快調諧過程中的測量速度。
設置調整選項
調整之前,應該應用一些配置。在這里,帶有64位操作系統(Ubuntu 20.04)的Raspberry Pi 4b 4GB主板為例。在設置中,應該相應地修改use_ndk目標和device_key。如果使用的是Android手機,設置為True。

DEVICE CONFIG

Replace “aarch64-linux-gnu” with the correct target of your board.

This target is used for cross compilation. You can query it by :code:gcc -v on your device.

FIXME(tmoreau89, merrymercy): We leave ‘-device=arm_cpu’ out of the target string

because we’re sharing x86 op strategy.

target = tvm.target.Target(“llvm -mtriple=aarch64-linux-gnu -mattr=+neon”)

Also replace this with the device key in your tracker

device_key = “rasp4b-64”

Set this to True if you use ndk tools for cross compiling

And also set the environment variable below to point to the cross compiler

use_ndk = False

os.environ[“TVM_NDK_CC”] = “/usr/bin/aarch64-linux-gnu-g++”

TUNING OPTION

network = “mobilenet”
batch_size = 1
layout = “NHWC”
dtype = “float32”
log_file = “%s-%s-B%d-%s.json” % (network, layout, batch_size, target.kind.name)
提取搜索任務
接下來,從網絡中提取搜索任務及其權重。任務的權重是該任務的子圖在整個網絡中的出現次數。通過使用權重,將網絡的端到端延遲近似為sum(latency[t] * weight[t]),其中latency[t]是任務的延遲,weight[t]是任務的權重。任務調度程序僅優化此目標。

Extract tasks from the network

print(“Extract tasks…”)
mod, params, input_shape, output_shape = get_network(network, batch_size, layout, dtype=dtype)
tasks, task_weights = auto_scheduler.extract_tasks(mod[“main”], params, target)

for idx, task in enumerate(tasks):
print("========== Task %d (workload key: %s) ==========" % (idx, task.workload_key))
print(task.compute_dag)
出去:
Extract tasks…
========== Task 0 (workload key: [“d7b65649a4dd54becea0a52aabbc5af5”, 1, 1000, 1, 1000]) ==========
placeholder = PLACEHOLDER [1, 1000]
T_softmax_maxelem(i0) max= placeholder[i0, k]
T_softmax_exp(i0, i1) = tir.exp((placeholder[i0, i1] - T_softmax_maxelem[i0]))
T_softmax_expsum(i0) += T_softmax_exp[i0, k]
T_softmax_norm(i0, i1) = (T_softmax_exp[i0, i1]/T_softmax_expsum[i0])

========== Task 1 (workload key: [“9847f8cc0b305137f49f2c5c0c8ab25d”, 1, 1024, 1000, 1024, 1000, 1, 1000]) ==========
placeholder = PLACEHOLDER [1, 1024]
placeholder = PLACEHOLDER [1000, 1024]
T_dense(i, j) += (placeholder[i, k]*placeholder[j, k])
placeholder = PLACEHOLDER [1000]
T_add(ax0, ax1) = (T_dense[ax0, ax1] + placeholder[ax1])

========== Task 2 (workload key: [“69115f188984ae34ede37c3b8ca40b43”, 1, 7, 7, 1024, 1, 1, 1, 1024]) ==========
placeholder = PLACEHOLDER [1, 7, 7, 1024]
tensor(ax0, ax1, ax2, ax3) += placeholder[ax0, ((ax17) + rv0), ((ax27) + rv1), ax3]
tensor(ax0, ax1, ax2, ax3) = (tensor[ax0, ax1, ax2, ax3]/(float32((select((bool)1, ((ax1 + 1)*7), (((ax1 + 1)7) + 1)) - (ax17)))*float32((select((bool)1, ((ax2 + 1)*7), (((ax2 + 1)7) + 1)) - (ax27)))))

========== Task 3 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 7, 7, 1024, 1, 1, 1024, 1024, 1, 1, 1, 1024, 1, 7, 7, 1024]) ==========
placeholder = PLACEHOLDER [1, 7, 7, 1024]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 1024, 1024]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 1024]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 4 (workload key: [“06fce76bd84cb904eee50b905ca9449a”, 1, 7, 7, 1024, 3, 3, 1024, 1, 1, 1, 1, 1024, 1, 7, 7, 1024]) ==========
placeholder = PLACEHOLDER [1, 7, 7, 1024]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 8)) && (i2 >= 1)) && (i2 < 8)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 1024, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, (i + di), (j + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 1024]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 5 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 7, 7, 512, 1, 1, 512, 1024, 1, 1, 1, 1024, 1, 7, 7, 1024]) ==========
placeholder = PLACEHOLDER [1, 7, 7, 512]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 512, 1024]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 1024]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 6 (workload key: [“c87ba68bc180312f5716af09a77ca15b”, 1, 14, 14, 512, 3, 3, 512, 1, 1, 1, 1, 512, 1, 7, 7, 512]) ==========
placeholder = PLACEHOLDER [1, 14, 14, 512]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 15)) && (i2 >= 1)) && (i2 < 15)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 512, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, ((i2) + di), ((j2) + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 512]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 7 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 14, 14, 512, 1, 1, 512, 512, 1, 1, 1, 512, 1, 14, 14, 512]) ==========
placeholder = PLACEHOLDER [1, 14, 14, 512]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 512, 512]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 512]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 8 (workload key: [“06fce76bd84cb904eee50b905ca9449a”, 1, 14, 14, 512, 3, 3, 512, 1, 1, 1, 1, 512, 1, 14, 14, 512]) ==========
placeholder = PLACEHOLDER [1, 14, 14, 512]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 15)) && (i2 >= 1)) && (i2 < 15)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 512, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, (i + di), (j + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 512]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 9 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 14, 14, 256, 1, 1, 256, 512, 1, 1, 1, 512, 1, 14, 14, 512]) ==========
placeholder = PLACEHOLDER [1, 14, 14, 256]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 256, 512]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 512]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 10 (workload key: [“c87ba68bc180312f5716af09a77ca15b”, 1, 28, 28, 256, 3, 3, 256, 1, 1, 1, 1, 256, 1, 14, 14, 256]) ==========
placeholder = PLACEHOLDER [1, 28, 28, 256]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 29)) && (i2 >= 1)) && (i2 < 29)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 256, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, ((i2) + di), ((j2) + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 256]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 11 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 28, 28, 256, 1, 1, 256, 256, 1, 1, 1, 256, 1, 28, 28, 256]) ==========
placeholder = PLACEHOLDER [1, 28, 28, 256]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 256, 256]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 256]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 12 (workload key: [“06fce76bd84cb904eee50b905ca9449a”, 1, 28, 28, 256, 3, 3, 256, 1, 1, 1, 1, 256, 1, 28, 28, 256]) ==========
placeholder = PLACEHOLDER [1, 28, 28, 256]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 29)) && (i2 >= 1)) && (i2 < 29)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 256, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, (i + di), (j + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 256]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 13 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 28, 28, 128, 1, 1, 128, 256, 1, 1, 1, 256, 1, 28, 28, 256]) ==========
placeholder = PLACEHOLDER [1, 28, 28, 128]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 128, 256]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 256]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 14 (workload key: [“c87ba68bc180312f5716af09a77ca15b”, 1, 56, 56, 128, 3, 3, 128, 1, 1, 1, 1, 128, 1, 28, 28, 128]) ==========
placeholder = PLACEHOLDER [1, 56, 56, 128]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 57)) && (i2 >= 1)) && (i2 < 57)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 128, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, ((i2) + di), ((j2) + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 128]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 15 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 56, 56, 128, 1, 1, 128, 128, 1, 1, 1, 128, 1, 56, 56, 128]) ==========
placeholder = PLACEHOLDER [1, 56, 56, 128]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 128, 128]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 128]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 16 (workload key: [“06fce76bd84cb904eee50b905ca9449a”, 1, 56, 56, 128, 3, 3, 128, 1, 1, 1, 1, 128, 1, 56, 56, 128]) ==========
placeholder = PLACEHOLDER [1, 56, 56, 128]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 57)) && (i2 >= 1)) && (i2 < 57)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 128, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, (i + di), (j + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 128]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 17 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 56, 56, 64, 1, 1, 64, 128, 1, 1, 1, 128, 1, 56, 56, 128]) ==========
placeholder = PLACEHOLDER [1, 56, 56, 64]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 64, 128]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 128]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 18 (workload key: [“c87ba68bc180312f5716af09a77ca15b”, 1, 112, 112, 64, 3, 3, 64, 1, 1, 1, 1, 64, 1, 56, 56, 64]) ==========
placeholder = PLACEHOLDER [1, 112, 112, 64]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 113)) && (i2 >= 1)) && (i2 < 113)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 64, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, ((i2) + di), ((j2) + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 64]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 19 (workload key: [“6b7583cf23c7c37d3212cad9d06e58c1”, 1, 112, 112, 32, 1, 1, 32, 64, 1, 1, 1, 64, 1, 112, 112, 64]) ==========
placeholder = PLACEHOLDER [1, 112, 112, 32]
PaddedInput(i0, i1, i2, i3) = placeholder[i0, i1, i2, i3]
placeholder = PLACEHOLDER [1, 1, 32, 64]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, (yy + ry), (xx + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 1, 1, 64]
T_add(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 20 (workload key: [“06fce76bd84cb904eee50b905ca9449a”, 1, 112, 112, 32, 3, 3, 32, 1, 1, 1, 1, 32, 1, 112, 112, 32]) ==========
placeholder = PLACEHOLDER [1, 112, 112, 32]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 113)) && (i2 >= 1)) && (i2 < 113)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 32, 1]
DepthwiseConv2d(b, i, j, c) += (PaddedInput[b, (i + di), (j + dj), c]*placeholder[di, dj, c, 0])
placeholder = PLACEHOLDER [1, 1, 1, 32]
T_add(ax0, ax1, ax2, ax3) = (DepthwiseConv2d[ax0, ax1, ax2, ax3] + placeholder[ax0, 0, 0, ax3])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)

========== Task 21 (workload key: [“98418eda02701ddd175ad50e364a0638”, 1, 224, 224, 3, 3, 3, 3, 32, 1, 112, 1, 1, 1, 112, 1, 1, 1, 112, 112, 32]) ==========
placeholder = PLACEHOLDER [1, 224, 224, 3]
PaddedInput(i0, i1, i2, i3) = tir.if_then_else(((((i1 >= 1) && (i1 < 225)) && (i2 >= 1)) && (i2 < 225)), placeholder[i0, (i1 - 1), (i2 - 1), i3], 0f)
placeholder = PLACEHOLDER [3, 3, 3, 32]
Conv2dOutput(nn, yy, xx, ff) += (PaddedInput[nn, ((yy2) + ry), ((xx2) + rx), rc]*placeholder[ry, rx, rc, ff])
placeholder = PLACEHOLDER [1, 112, 1, 1]
T_multiply(ax0, ax1, ax2, ax3) = (Conv2dOutput[ax0, ax1, ax2, ax3]*placeholder[ax0, ax1, 0, 0])
placeholder = PLACEHOLDER [1, 112, 1, 1]
T_add(ax0, ax1, ax2, ax3) = (T_multiply[ax0, ax1, ax2, ax3] + placeholder[ax0, ax1, 0, 0])
T_relu(ax0, ax1, ax2, ax3) = max(T_add[ax0, ax1, ax2, ax3], 0f)
調優與評估
設置一些選項來優化和啟動搜索任務
? num_measure_trials是在調整期間可以使用的測量試驗的次數。可以將其設置為較小的數字(例如200)以進行快速演示。實際上,建議將其設置為,通常足以使搜索收斂。例如,resnet-50中有29個任務,可以將其設置為20000。可以根據時間預算調整此參數800 * len(tasks)。
? 此外,用于RecordToFile將測量記錄轉儲到日志文件中,這些測量記錄可用于最好地查詢歷史記錄,恢復搜索以及以后進行更多分析。
? 有關更多參數auto_scheduler.TuningOptions, 參見auto_scheduler.LocalRunner。
自動調整后,使用發現的最佳時間表來編譯網絡。在自動調整期間,所有測量記錄都將轉儲到日志文件中,可以讀取日志文件并加載最佳調度。
def tune_and_evaluate():
print(“Begin tuning…”)
tuner = auto_scheduler.TaskScheduler(tasks, task_weights)
tune_option = auto_scheduler.TuningOptions(
num_measure_trials=200, # change this to 20000 to achieve the best performance
runner=auto_scheduler.RPCRunner(
device_key,
host=“0.0.0.0”,
port=9191,
timeout=30,
repeat=1,
min_repeat_ms=200,
enable_cpu_cache_flush=True,
),
measure_callbacks=[auto_scheduler.RecordToFile(log_file)],
)

tuner.tune(tune_option)# Compile with the history best
print("Compile...")
with auto_scheduler.ApplyHistoryBest(log_file):with tvm.transform.PassContext(opt_level=3, config={"relay.backend.use_auto_scheduler": True}):lib = relay.build(mod, target=target, params=params)# Export library
tmp = tempdir()
if use_ndk:from tvm.contrib import ndkfilename = "net.so"lib.export_library(tmp.relpath(filename), ndk.create_shared)
else:filename = "net.tar"lib.export_library(tmp.relpath(filename))# Upload module to device
print("Upload...")
remote = auto_scheduler.utils.request_remote(device_key, "0.0.0.0", 9191, timeout=10000)
remote.upload(tmp.relpath(filename))
rlib = remote.load_module(filename)# Create graph runtime
ctx = remote.cpu()
module = graph_runtime.GraphModule(rlib["default"](ctx))
data_tvm = tvm.nd.array((np.random.uniform(size=input_shape)).astype(dtype))
module.set_input("data", data_tvm)# Evaluate
print("Evaluate inference time cost...")
ftimer = module.module.time_evaluator("run", ctx, repeat=3, min_repeat_ms=500)
prof_res = np.array(ftimer().results) * 1e3  # convert to millisecond
print("Mean inference time (std dev): %.2f ms (%.2f ms)" % (np.mean(prof_res), np.std(prof_res))
)

We do not run the tuning in our webpage server since the server doesn’t have a Raspberry Pi,

or device tracker running.

Uncomment the following line to run it by yourself.

tune_and_evaluate()

筆記
調整打印的信息
在調整期間,控制臺上會打印很多信息。用于調試目的。最重要的信息是任務調度程序的輸出。下表是示例輸出。

下表列出了所有任務的延遲和(估計)速度。列出了所有任務的測量試驗分配。最后一行顯示這些任務的總加權延遲,可以粗略估計網絡的端到端執行時間。最后一行還顯示測量試驗的總數,自動調整所花費的總時間以及要調整的下一個任務的ID。
也將出現一些“ dmlc :: Error”錯誤,自動調度程序將嘗試一些無效的調度。如果可以繼續進行調整,可以放心地忽略,這些錯誤與主要過程是隔離的。
筆記
提前終止調整
可以通過強制終止此過程來提前終止調整。只要在日志文件中為每個任務至少獲得一個有效的調度,就應該能夠進行編譯(下面的部分)。
其他技巧

  1. 在調整期間,自動調度器需要編譯許多程序并從中提取功能。該部分占用大量CPU,建議使用具有多個內核的高性能CPU,加快搜索速度。
  2. 可以 用來提取大型日志文件,而僅保存最有用的記錄。python3 -m tvm.auto_scheduler.measure_record --mode distill -i log.json
  3. 可以從上一個日志文件繼續搜索。load_log_file在function中創建任務調度程序時,只需添加一個新參數run_tuning。
    tuner = auto_scheduler.TaskScheduler(tasks, task_weights, load_log_file=log_file)
  4. 如果有多個目標CPU,可以全部用于測量以并行化測量。檢查了解如何使用RPC跟蹤器和RPC服務器。要在自動調度使用RPC跟蹤,用auto_scheduler.RPCRunner,更換轉輪TuningOptions 。

總結

以上是生活随笔為你收集整理的ARM CPU神经网络自动调度的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

av噜噜噜在线播放 | 中文在线亚洲 | 久久国产成人午夜av影院潦草 | 日韩av免费在线看 | 国产精品理论在线观看 | 天堂在线免费视频 | 视频91在线 | 97成人精品区在线播放 | 免费国产黄线在线观看视频 | 欧美va日韩va | 国产精品亚洲视频 | 国产在线精品视频 | 在线视频你懂 | 国产精品亚州 | 97福利社| 手机在线欧美 | 中文字幕免费观看全部电影 | 国产精品1区2区3区 久久免费视频7 | www.xxxx欧美| 天天舔天天搞 | 国产资源精品在线观看 | 人人爱在线视频 | 亚洲精品网站 | 日韩91精品 | 97在线影院 | 美女国产免费 | 成人a在线观看 | 久久午夜精品视频 | 国产高清免费在线观看 | 国产精品久久久久久久久久东京 | 天堂av高清| 日韩欧美视频二区 | 国产91九色蝌蚪 | 亚洲欧美日本国产 | 国产精成人品免费观看 | av一区二区三区在线播放 | 久久久久综合视频 | 欧美大香线蕉线伊人久久 | 亚洲精品男人天堂 | 国产成人区 | 亚洲精品视频第一页 | 天堂激情网| 国产精品久久久免费 | 亚洲成人av电影 | 欧美日韩在线观看一区二区三区 | 国产一区黄色 | 激情欧美丁香 | 国产小视频在线看 | 99精品欧美一区二区三区黑人哦 | 日韩中文字幕视频在线 | 亚洲人成人99网站 | 国产不卡精品 | 日韩精品短视频 | 日韩av二区 | 国产18精品乱码免费看 | 亚洲国产成人精品在线 | 九九九热精品免费视频观看 | 操少妇视频 | 国产原创在线观看 | 欧美黄色高清 | 久久精品中文 | 西西www4444大胆视频 | 精品久久中文 | 亚洲人久久久 | 亚洲精品中文字幕视频 | 狠狠色丁香久久综合网 | 不卡av免费在线观看 | 日韩欧美网站 | 亚洲欧美视频在线 | 日日爽天天爽 | 国产又粗又猛又黄视频 | 伊人天天狠天天添日日拍 | 国产婷婷视频在线 | 最新国产在线视频 | 精品国偷自产在线 | 国产91影视 | 国产成人精品午夜在线播放 | 九色91福利 | 日日爽夜夜操 | 久久在线精品视频 | 亚洲精品国产综合久久 | 日韩电影在线一区 | 中字幕视频在线永久在线观看免费 | 99视频精品免费视频 | 久久高清免费视频 | 日韩xxx视频 | 国产成人精品a | 日韩免费一级电影 | 天天综合网 天天综合色 | 手机看片中文字幕 | 亚洲少妇影院 | 91欧美日韩国产 | 国产精品一区免费观看 | 亚洲国产成人av网 | 久久视频这里只有精品 | 91免费试看 | 成人日韩av | 91av视频在线观看免费 | 国产高清av免费在线观看 | 中文字幕在线看视频 | 免费观看一级 | 久久久久久久久久亚洲精品 | 亚洲国产精品99久久久久久久久 | 狠狠色丁香久久婷婷综合丁香 | 又黄又刺激又爽的视频 | 热久久免费视频 | 亚洲国产精品人久久电影 | 激情av资源 | 久久99中文字幕 | 黄色毛片大全 | 夜夜看av | 久久成人高清视频 | 久久久国产精品人人片99精片欧美一 | 毛片888| 日韩色高清 | 久久国内精品99久久6app | 免费日韩视 | 日韩av免费大片 | 99久久日韩精品视频免费在线观看 | 久久夜色精品国产欧美乱极品 | 天天爱天天爽 | 黄污视频网站大全 | 欧美另类网站 | 99久久久精品 | 久久综合网色—综合色88 | 成人免费观看网站 | 日本动漫做毛片一区二区 | 久久久亚洲麻豆日韩精品一区三区 | 久久久久久久久亚洲精品 | 久久精品aaa | 国产精品久久久久影院 | 99热在线观看 | 中文字幕日本特黄aa毛片 | 国产精品自拍在线 | 99爱视频在线观看 | 精品字幕在线 | 999色视频 | 欧美成人精品三级在线观看播放 | 国产一区二区久久精品 | 婷婷色吧 | 亚洲欧美经典 | 国产精品久久久久一区 | 婷婷色综合 | 久久国产成人午夜av影院潦草 | 在线韩国电影免费观影完整版 | 视频二区在线 | 久久久精品国产免费观看一区二区 | 91完整视频 | 国产精品日韩久久久久 | 久久五月网 | 亚洲视频久久久久 | 超碰.com| 美女黄网久久 | 毛片精品免费在线观看 | 国产一二区精品 | 精品国模一区二区三区 | 国产91精品一区二区麻豆亚洲 | 久久99视频精品 | 青青草国产精品视频 | 国产97av| 99久久影院 | 成人久久综合 | 久久久免费高清视频 | 亚洲九九| 国产精品永久久久久久久久久 | bayu135国产精品视频 | 国产精品99久久久久久宅男 | 国偷自产中文字幕亚洲手机在线 | 青青草在久久免费久久免费 | 亚洲精品免费观看视频 | 韩日av在线 | 成全在线视频免费观看 | 欧美xxxxx在线视频 | 一区二区在线影院 | 欧美另类网站 | 色婷婷色 | 亚洲国产97在线精品一区 | 中文字幕最新精品 | 亚洲精品乱码白浆高清久久久久久 | 综合伊人av | 97超级碰碰碰视频在线观看 | 天天翘av | 国产97在线观看 | 黄色网在线免费观看 | 国产美女精品人人做人人爽 | 91免费视频网站在线观看 | 久久国产系列 | 天天干天天摸天天操 | 久久久人人爽 | 96av麻豆蜜桃一区二区 | 久久综合久久综合久久 | 91久久偷偷做嫩草影院 | 欧美在线一二区 | 成人小电影在线看 | 在线观看中文字幕2021 | 国产中文字幕视频 | 波多野结衣在线播放一区 | 色偷偷人人澡久久超碰69 | 97精品国自产拍在线观看 | 天天爱天天操天天射 | 天堂av影院 | 亚洲欧美国产精品久久久久 | 玖玖爱免费视频 | 亚洲黄色av网址 | 97福利在线观看 | 福利一区二区三区四区 | 国产精品久久久久永久免费观看 | 久久久久久99精品 | 亚洲国产日韩在线 | 成人久久毛片 | 探花视频在线观看免费版 | 人人干干人人 | 天天操天天干天天操天天干 | av成人动漫 | a黄在线观看 | 国产精品欧美在线 | 中文av在线播放 | 日本黄色一级电影 | 日韩中文字幕免费视频 | 性色av香蕉一区二区 | 国产色视频123区 | 亚州国产精品视频 | 日韩超碰 | 99视频在线 | 999男人的天堂 | 久久97超碰| 国产一级二级在线观看 | 中文字幕日韩免费视频 | 久久久久久久久久影视 | 国产麻豆精品久久一二三 | 国产精品美女毛片真酒店 | 久久久久久久久久久免费视频 | 99精品国产福利在线观看免费 | www.成人sex | 国产美女久久久 | 黄色动态图xx | 五月天久久久 | 超碰在线97观看 | 久草在线高清视频 | 五月天久久综合 | 久久久久久影视 | 国产精品一区二区在线观看 | 国产欧美精品一区二区三区 | 九九热国产视频 | 97超碰成人| 日日夜夜国产 | 国产精品一区二区在线观看 | 久久精品一区二区三区视频 | 国产成人av一区二区三区在线观看 | 亚洲 欧美日韩 国产 中文 | 欧美少妇xx | 久久久黄视频 | 91男人影院 | 国产精品日韩高清 | 亚洲蜜桃在线 | 涩涩资源网 | 园产精品久久久久久久7电影 | 国产色婷婷在线 | 97超碰超碰 | 91成人免费观看视频 | 亚洲精品自在在线观看 | 亚洲成人黄色在线观看 | 免费一区在线 | 又长又大又黑又粗欧美 | 91丨九色丨国产丨porny精品 | 91亚洲精品乱码久久久久久蜜桃 | 夜夜操夜夜干 | 国产乱码精品一区二区三区介绍 | 国产日韩精品在线观看 | 91视频下载 | 波多野结衣综合网 | 久青草电影 | 一级黄色片在线免费观看 | 午夜电影中文字幕 | 国产日产精品一区二区三区四区的观看方式 | 精品一区二区日韩 | 中文字幕视频免费观看 | 69xx视频| 日韩精品在线看 | 国产在线自 | 狠狠干.com | 99免费国产 | 操操日日 | 欧美亚洲精品在线观看 | 99久久这里有精品 | 亚洲激情视频在线观看 | 91麻豆传媒 | 亚洲精品视频在 | 久久夜色网 | 国产成人一区二区三区在线观看 | 日韩69av | 日韩中字在线 | 国产精品美女久久久久久久 | 91色一区二区三区 | 最近更新的中文字幕 | 久久精品91久久久久久再现 | 久久精品国产免费看久久精品 | 808电影免费观看三年 | 欧美亚洲三级 | 欧美孕妇与黑人孕交 | 久久久精选 | 亚洲乱码久久 | 丁香综合网 | 99免费看片 | 国产午夜精品免费一区二区三区视频 | 在线观看日韩国产 | 91成人精品| 色香com.| 日韩免费二区 | 国产色在线视频 | 操操操人人人 | 亚洲 欧洲 国产 精品 | 日本久久久精品视频 | av在线网站大全 | 久久久久久激情 | 欧美精品久久久久久久久久丰满 | 国产成人在线观看 | 国产麻豆视频网站 | 天天射天天爱天天干 | 奇米导航| 亚洲精品国产区 | 悠悠av资源片| 精品毛片一区二区免费看 | 蜜桃视频精品 | 中文字幕免费不卡视频 | 五月宗合网 | 亚洲国产经典视频 | 激情av综合 | 国内精品久久久久影院日本资源 | 91精品一区二区三区蜜臀 | 国产成人精品一区二区三区免费 | 韩日电影在线 | 97超碰超碰久久福利超碰 | 久久久.com| 天天操天天干天天爽 | 91精品在线免费视频 | 亚洲 中文字幕av | 久久综合久久综合这里只有精品 | 日韩精品无| 国产亚洲精品电影 | 日日爽夜夜爽 | 久久久久久久久久久电影 | 国产一级免费视频 | 中文字幕首页 | 久久黄色成人 | 中文av在线免费观看 | 日日添夜夜添 | 国产69熟 | 丁香花在线视频观看免费 | 黄色网址国产 | 天天久久综合 | 亚洲狠狠婷婷综合久久久 | 国产无遮挡又黄又爽馒头漫画 | 中文字幕a∨在线乱码免费看 | 免费高清av在线看 | 国产糖心vlog在线观看 | 五月天丁香视频 | 中文字幕日韩高清 | 久久久久国产成人精品亚洲午夜 | 中文字幕乱码日本亚洲一区二区 | 日韩专区一区二区 | 久久午夜影院 | 麻豆视频免费入口 | 五月婷丁香| 亚洲欧美日韩国产精品一区午夜 | 国产精品久久久久婷婷二区次 | 国产高清在线精品 | 国产精品激情偷乱一区二区∴ | 人人插超碰 | 午夜国产一区二区三区四区 | 色91av| 久久99久久99免费视频 | 久久综合毛片 | 久久99精品久久久久久清纯直播 | 免费的黄色的网站 | 999超碰| 中文字幕中文字幕在线中文字幕三区 | 久久激情电影 | 97品白浆高清久久久久久 | 91麻豆精品国产91久久久使用方法 | 国产福利小视频在线 | 高清中文字幕 | 夜夜摸夜夜爽 | 国产精品久久久久久久久久久久午夜片 | 五月天色丁香 | 日韩一区二区三 | 日韩欧美久久 | 96国产在线 | 深夜福利视频一区二区 | 人成在线免费视频 | 久久不卡视频 | 不卡视频在线 | www免费视频com━ | 亚洲最新av在线 | 日操干| 欧美日韩免费在线观看视频 | 欧美高清视频不卡网 | 91最新中文字幕 | 草久视频在线观看 | 91黄在线看 | 日韩视频中文字幕在线观看 | 中文字幕日韩免费视频 | 激情综合狠狠 | 黄色大片av| 欧美精品在线一区 | 91在线免费观看国产 | 丁香六月伊人 | 一区二区免费不卡在线 | 激情久久久久 | 免费日韩一区二区三区 | 国产在线国偷精品产拍免费yy | 亚洲欧美va | 久久久视频在线 | 国产精品69久久久久 | 很黄很黄的网站免费的 | 久久99久久99 | 婷婷99 | 黄色精品网站 | 久久伊人精品一区二区三区 | 狠狠干狠狠操 | 91精品伦理| 在线视频日韩欧美 | 成人久久综合 | 色综合天天综合 | 国产午夜精品福利视频 | 亚洲欧美偷拍另类 | 国产美女视频免费 | 在线探花 | 在线观看理论 | 美国三级黄色大片 | 在线观看视频亚洲 | 亚洲精品高清视频 | 蜜桃视频成人在线观看 | 国产v在线 | 亚洲精品五月 | 国产成人精品综合久久久久99 | 日韩高清dvd| 国产高清免费视频 | 亚欧日韩av| 日韩av电影国产 | 国产精品一区二区果冻传媒 | 国产裸体视频网站 | 国产一区二区久久精品 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 久久艹国产视频 | www.色com| 91亚洲欧美激情 | 欧美一区二区三区在线 | 国产日韩欧美自拍 | 精品自拍av | 亚洲国产字幕 | 在线a亚洲视频播放在线观看 | 国产精品免费看久久久8精臀av | 日韩在线视频网站 | 日日摸日日添日日躁av | 久草在线视频首页 | 免费成人av| 成人资源在线观看 | 日韩不卡高清视频 | 精品国内 | 日韩色综合| 1000部国产精品成人观看 | 狠狠操操操 | 激情av五月婷婷 | 四虎国产免费 | 在线观看中文字幕视频 | 91亚洲激情 | 成人网在线免费视频 | 在线观看欧美成人 | 国产永久免费 | 99久久精品无免国产免费 | 国产色黄网站 | 成人亚洲欧美 | 婷婷六月激情 | 91精品国产99久久久久久红楼 | 免费观看久久 | 亚洲激情网站免费观看 | 人人爽人人澡人人添人人人人 | 成年人在线 | 青青久视频 | 久久激情五月激情 | 国产成人在线播放 | 中文字幕成人网 | 午夜视频在线观看网站 | 在线高清 | 国产精品私人影院 | 中文字幕在线视频免费播放 | 国产精品黄色 | 日韩高清无线码2023 | 在线观看免费成人av | 亚洲亚洲精品在线观看 | 天天五月天色 | 丁香六月婷婷开心 | 98超碰在线观看 | www操操 | 天天操天天操天天爽 | 久精品视频在线 | av中文字幕av| 久久国产精品视频免费看 | 亚洲免费资源 | 日本精品一区二区三区在线观看 | 欧美视频日韩 | 国产综合久久 | 天天天干天天天操 | 91久色蝌蚪 | 国产破处在线视频 | 激情五月婷婷网 | 亚洲精品字幕在线观看 | 日本乱码在线 | 欧美日韩精| 黄色一级网 | 女人18毛片a级毛片一区二区 | 少妇视频一区 | 亚洲国产成人久久综合 | 国产一区二区成人 | 插婷婷 | 亚洲第五色综合网 | 亚洲精品午夜久久久久久久久久久 | 91成人免费电影 | 久久精品一区二区三区四区 | 激情婷婷欧美 | 亚洲另类视频 | av午夜电影| 欧美污污视频 | 粉嫩av一区二区三区免费 | 狠狠色丁香久久婷婷综合丁香 | 久久久久久免费网 | 超碰97成人 | 免费视频你懂得 | 欧美综合干 | 久久久久久视频 | 欧美日韩国产综合一区二区 | 日韩黄色影院 | 91男人影院 | 97精品国产一二三产区 | 国产97在线观看 | 久久经典国产 | 久久视频6 | 五月婷婷在线视频 | 亚洲午夜精品一区 | 少妇视频在线播放 | 91久久久国产精品 | 国产在线一区二区三区播放 | 亚洲国产精品500在线观看 | 99久久这里有精品 | 在线看片一区 | 欧美天堂久久 | 色97在线| 黄色免费在线看 | 国产精品videossex国产高清 | 久久久久久久久久久综合 | 国产精品久久一区二区三区, | 国产.精品.日韩.另类.中文.在线.播放 | 亚洲精品玖玖玖av在线看 | 91看毛片| 国产精品18久久久久久首页狼 | 日韩精品第1页 | 视频精品一区二区三区 | 综合国产在线 | 天天操比 | 操久久免费视频 | 久久99精品国产99久久 | 国内精品久久久久久久影视简单 | 久久99久久99精品中文字幕 | www黄色软件 | 激情五月婷婷综合网 | 亚洲精品乱码久久久久v最新版 | 国产精品白丝jk白祙 | 国产精品系列在线 | 丁香色婷婷| 欧美日产一区 | 精品国产亚洲一区二区麻豆 | 这里只有精品视频在线 | 国产精品欧美日韩在线观看 | 五月天亚洲综合 | 久久久免费毛片 | 在线观看视频91 | 九九热精品视频在线播放 | 97热在线观看 | 色多多在线观看 | 美女视频黄免费网站 | 中文字幕在线免费观看视频 | 欧美吞精 | 国产一级二级在线观看 | 天天综合网在线观看 | 亚洲视屏在线播放 | 91免费试看 | 精品久久久久免费极品大片 | av动态图片 | 婷婷午夜 | 国产精品久久亚洲 | 九九一级片 | 麻豆久久久久 | 中文字幕888 | 夜夜骑日日 | 四虎在线观看精品视频 | 亚洲午夜久久久久久久久 | 成人av网站在线播放 | 91在线视频网址 | 美女一二三区 | 亚洲精品在线观看免费 | 99久久99久久精品国产片 | 美女网站视频免费都是黄 | 亚洲专区欧美专区 | 国产一区在线播放 | 亚洲精品在线国产 | www.五月天激情 | 五月婷婷丁香六月 | 天堂视频中文在线 | 天天干天天射天天插 | 成年人黄色大全 | 国产91在线看| 日韩欧美不卡 | 深爱开心激情 | 久久九九久久精品 | 99久久精品国产观看 | 欧美伦理电影一区二区 | 国产精品一区二区三区免费视频 | 91精品啪| 最新中文字幕在线资源 | 久久女同性恋中文字幕 | 涩涩网站在线播放 | 在线观看中文字幕网站 | 日本天天色 | 日韩精品免费在线观看 | 久草精品视频在线观看 | 狠狠色丁香婷婷综合基地 | 91精品天码美女少妇 | 久久玖| 丁香五香天综合情 | 国产手机视频在线播放 | 最新国产在线视频 | 亚洲日本欧美在线 | www.伊人色.com | 中文字幕乱码视频 | 日批视频在线 | 91av蜜桃| 天干啦夜天干天干在线线 | 四虎影视成人精品国库在线观看 | 日韩r级在线 | 干天天| 国产精品综合在线观看 | 久久av网 | www.在线看片.com | 精品久久久久久久久久久久久 | 激情久久久久 | 婷婷中文字幕 | 综合网色| 日韩精品亚洲专区在线观看 | 国产尤物一区二区三区 | 天天干天天操天天入 | 美女久久久久久久久久 | 91禁在线看 | 久久高清国产视频 | 亚洲精品久久久久中文字幕二区 | 九九免费精品 | 在线看毛片网站 | 夜夜爽www | 久久精品亚洲综合专区 | 亚洲精品乱码久久 | 天天干天天碰 | 亚洲精品国产精品乱码在线观看 | 日韩网 | 国产精品久久久亚洲 | 亚洲精品综合欧美二区变态 | 91香蕉视频在线下载 | 亚洲一区黄色 | 在线性视频日韩欧美 | 久久久影视 | 色a网| 麻豆首页 | 国产免费激情久久 | 六月丁香激情综合色啪小说 | 国产福利av在线 | 在线观看久久久久久 | 日韩欧美电影网 | 日本公妇在线观看高清 | 国产精品一区欧美 | 中文字幕在线视频一区 | 免费看污片 | av免费看在线 | 黄色av三级在线 | 精品国产网址 | 日韩一区二区三区免费视频 | 六月丁香在线观看 | 91精品国产91久久久久福利 | www九九热 | av天天草 | 久久精品影视 | av看片网 | wwwwww色 | 日韩免费在线观看 | 四虎影视国产精品免费久久 | 五月婷影院| 中文字幕 第二区 | 国产一区二区在线播放视频 | 91日韩在线视频 | 精品在线亚洲视频 | 欧美在线1 | 国产一区二区三区网站 | 一区二区三区免费在线 | 91精品国产福利在线观看 | 亚洲黄色一级电影 | 黄色软件在线观看视频 | 视频一区二区国产 | 又黄又网站 | 天天射天天干天天操 | 一本一本久久a久久精品综合妖精 | 狠狠色伊人亚洲综合网站野外 | 成年人av在线播放 | 国产精品一区二区三区免费看 | 91男人影院| 中文字幕高清在线播放 | 97色在线观看| 日韩欧美视频一区二区 | 色婷婷狠| 日韩激情视频 | 亚洲精品视频网站在线观看 | 奇米影视四色8888 | 国产午夜精品久久久久久久久久 | 久久99精品国产99久久6尤 | 成人黄色在线视频 | 黄色av网站在线观看免费 | www.91av在线 | 在线观看视频一区二区 | 国产成人精品亚洲日本在线观看 | 国产99久久精品一区二区永久免费 | 久久你懂得 | 久久久精品成人 | 午夜精品一区二区三区在线视频 | 日日日干 | 国产在线va | 久久er99热精品一区二区 | 男女精品久久 | 91成人亚洲 | 国产精品久久久久久久久搜平片 | 亚洲精品高清一区二区三区四区 | 亚洲视频在线播放 | 在线亚洲播放 | 在线av资源 | 一本一本久久a久久 | 欧美日韩在线视频一区 | 亚洲永久精品视频 | 操操操天天操 | 人人狠狠综合久久亚洲 | 色99导航 | 亚洲精品午夜国产va久久成人 | 日韩欧在线| 日日干影院 | 国产成人精品亚洲a | 亚洲视频99 | 亚洲欧美日韩国产 | 亚洲人成综合 | 欧美日韩中文字幕在线视频 | 精品国偷自产国产一区 | 国产手机免费视频 | 亚洲一级黄色片 | 亚洲精品国产精品国自产 | 国产资源| 久久中文欧美 | 亚洲综合色网站 | www.黄色片.com| 欧美精品第一 | 手机av在线不卡 | 一级一片免费观看 | 一级黄色片在线免费看 | 高清一区二区三区av | 超碰97人人爱 | 一区二区三区四区五区六区 | 99精品视频在线看 | 91在线观看黄| 亚洲国产日韩av | av免费网页 | 丁香五月亚洲综合在线 | 国产精品手机看片 | 97麻豆视频| 久久av免费观看 | 色中文字幕在线观看 | 2019中文字幕第一页 | 国产精品久久久久免费 | 久热免费在线 | 亚洲精品黄 | 国产一区二区久久 | 欧美日韩中 | 国产激情小视频在线观看 | 亚洲精品自拍 | 激情欧美丁香 | 久久人人干 | 亚洲黄色一级视频 | 伊人黄色网| 亚洲香蕉在线观看 | 日韩精品免费一线在线观看 | 日日干美女 | 国产成人精品一区二区三区网站观看 | 99久久精品久久久久久清纯 | 久久免费观看少妇a级毛片 久久久久成人免费 | 久久伊人精品一区二区三区 | 天天搞天天干天天色 | 久久久精品日本 | 狠狠狠色丁香婷婷综合久久五月 | 日韩性久久 | 欧美国产日韩一区二区三区 | www.久久久精品 | 亚洲第一av在线播放 | 国产成人精品一区二区三区免费 | 亚洲久草在线 | 日韩免费三区 | 超碰在线网 | 人人擦 | 日韩精品在线视频免费观看 | 91精品国产91p65| 日韩国产欧美在线播放 | 国产精品成人av在线 | 国产精品视频最多的网站 | 国产中的精品av小宝探花 | 欧美日韩国产二区三区 | 久久视频网 | 中文字幕免费高清在线观看 | 91av99| 99精品一级欧美片免费播放 | 国产精品麻豆99久久久久久 | 国产一卡久久电影永久 | 久久精品中文字幕 | 日韩成人看片 | 日本黄色大片免费 | 91成人看片 | 欧美片一区二区三区 | 欧美日本高清视频 | 欧美色黄 | 狠狠狠色丁香综合久久天下网 | 在线免费观看欧美日韩 | 丁香六月激情婷婷 | 就要干b | 娇妻呻吟一区二区三区 | 日本黄区免费视频观看 | 欧美性色黄大片在线观看 | 91高清一区 | 国产伦理久久 | 在线 影视 一区 | 久久精品国产美女 | 日韩精品视频久久 | 成人日批视频 | 天天看天天操 | 天天婷婷 | www.五月天婷婷.com | 精品你懂的 | 久久久精品 一区二区三区 国产99视频在线观看 | 午夜国产福利在线观看 | 天天干天天操 | 夜夜爽天天爽 | 中文字幕一区二区三 | 四虎影视欧美 | 日本精品视频一区二区 | 亚色视频在线观看 | 国产一区二区视频在线 | 亚洲欧洲中文日韩久久av乱码 | 综合天天 | 在线婷婷 | 射综合网 | 日韩网站免费观看 | 国产午夜在线观看视频 | 欧美网址在线观看 | 91看片黄色| 久久久精品国产一区二区电影四季 | 91cn国产在线| 九九热在线观看视频 | 成年人免费电影 | 国产成人亚洲在线观看 | 精品久久亚洲 | 2022中文字幕在线观看 | 国产伦精品一区二区三区高清 | 久草视频99 | 欧美一区二区三区在线 | 97视频免费在线看 | 久章草在线观看 | 伊人六月 | 国产成人黄色 | 一区二区在线电影 | 久久精品福利 | 久草在线资源观看 | 精品99视频 | 免费人成网 | 精品一区电影国产 | 日韩免费一级电影 | 99久热在线精品视频 | 亚洲欧美视频一区二区三区 | 天天亚洲| 亚洲 中文 欧美 日韩vr 在线 | 国产成人黄色av | 亚洲午夜精品久久久 | 久久精品99精品国产香蕉 | 日韩精品专区 | 99精品一区二区 | 久久视频国产精品免费视频在线 | 日韩国产精品久久久久久亚洲 | 少妇高潮流白浆在线观看 | 在线亚洲成人 | 亚洲 欧美 变态 国产 另类 | 黄色免费看片网站 | 国产在线p | 伊人www22综合色 | 91九色丨porny丨丰满6 | 国内精品久久久久影院男同志 | 91精品国产91久久久久福利 | 日韩精品免费在线观看视频 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 91毛片在线观看 | 欧美性黄网官网 | 六月丁香激情网 | 欧美一区免费观看 | 色综合天天色 | 亚洲 欧美 精品 | 99精品免费网 | 香蕉影院在线播放 | 婷婷丁香国产 | 国产在线精品视频 | 色在线国产 | 日本精品免费看 | 日韩成人看片 | 蜜臀av在线一区二区三区 | 精品久久一二三区 | 亚洲va在线va天堂va偷拍 | 欧美色伊人 | 色人久久 | 欧洲性视频 | 夜夜爱av | 日韩色一区二区三区 | 成人影视片 | 91综合视频在线观看 | 91精品无人成人www | 国产精品第52页 | 国产麻豆精品在线观看 | av大片网址 | 91激情小视频| 国产成人精品久久亚洲高清不卡 | 日韩视频www | 免费高清无人区完整版 | 日韩一区二区免费在线观看 | 黄p在线播放 | 91chinese在线| 在线一区二区三区 | 天天射天天干天天 | 国产精品久久久毛片 | 天天操夜操视频 | 9i看片成人免费看片 | 4438全国亚洲精品在线观看视频 | 久久精品综合一区 | 五月婷婷在线观看视频 | 99热在线这里只有精品 | 不卡视频在线 | 最新中文在线视频 | 开心激情婷婷 | 在线精品视频免费播放 | 99精品久久99久久久久 | 亚洲观看黄色网 | 国产精品专区在线观看 | 91免费网址| 国产一区国产二区在线观看 | 日韩有码在线观看视频 | 亚洲电影免费 | 国产一区高清在线观看 | 天天躁日日躁狠狠躁 | 99精品欧美一区二区 | 一级黄色毛片 | 国内外成人在线 | 成人在线视频免费看 | 天天操偷偷干 | av电影中文字幕在线观看 | 亚洲禁18久人片 | 五月婷婷视频 | 国产精品免费久久久久久久久久中文 | 久久国产免费视频 | 久久视精品 | 国产精品99久久久久久武松影视 | 黄色视屏av | 免费在线观看一区二区三区 | wwwww.国产| 国产a免费 | a级国产片 | 在线99热 | 高清国产午夜精品久久久久久 | 亚洲精品午夜久久久久久久久久久 | 97精品超碰一区二区三区 | 日韩高清不卡一区二区三区 | 国产乱对白刺激视频在线观看女王 | 欧美日韩国产一区二区三区 | 国产色啪| 麻豆成人在线观看 | 成片免费观看视频大全 | avwww在线观看 | 精品91久久久久 | 亚洲国产一区二区精品专区 | 亚洲男男gaygay无套同网址 | 日韩丝袜 | 成人在线观看你懂的 | 一级黄网| 国产亚洲综合精品 | 久久色视频 |