1fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#
2fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# Copyright (C) 2017 The Android Open Source Project
3fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#
4fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# Licensed under the Apache License, Version 2.0 (the "License");
5fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# you may not use this file except in compliance with the License.
6fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# You may obtain a copy of the License at
7fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#
8fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#      http://www.apache.org/licenses/LICENSE-2.0
9fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#
10fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# Unless required by applicable law or agreed to in writing, software
11fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# distributed under the License is distributed on an "AS IS" BASIS,
12fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# See the License for the specific language governing permissions and
14fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# limitations under the License.
15fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang#
16fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang
17fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangmodel = Model()
18fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangi1 = Input("op1", "TENSOR_QUANT8_ASYMM", "{1, 2, 3, 3}, 0.5, 0")
19297c580a2d2da2839d936437bf4e3a4c64034950I-Jui (Ray) Sungf1 = Parameter("op2", "TENSOR_QUANT8_ASYMM", "{3, 1, 1, 3}, 0.5, 0", [10, 40, 70, 20, 50, 80, 30, 60, 90])
20297c580a2d2da2839d936437bf4e3a4c64034950I-Jui (Ray) Sungb1 = Parameter("op3", "TENSOR_INT32", "{3}, 0.25, 0", [0, 0, 0])
21fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangpad0 = Int32Scalar("pad0", 0)
22fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangact = Int32Scalar("act", 0)
23fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangstride = Int32Scalar("stride", 1)
24238a880d67b3aa5650ad52037fe1c25b1750eca9Miao Wangoutput = Output("op4",  "TENSOR_QUANT8_ASYMM", "{1, 2, 3, 3}, 1.0, 0")
25fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang
26fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangmodel = model.Operation("CONV_2D", i1, f1, b1, pad0, pad0, pad0, pad0, stride, stride, act).To(output)
27fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang
28fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# Example 1. Input in operand 0,
29fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwanginput0 = {i1: # input 0
30fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang          [  1,   2,   3,   4,   5,   6,   7,   8,   9,
31297c580a2d2da2839d936437bf4e3a4c64034950I-Jui (Ray) Sung            10,  11,  12,  13,  14,  15,  16,  17,  18]}
32fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang
33fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangoutput0 = {output: # output 0
34238a880d67b3aa5650ad52037fe1c25b1750eca9Miao Wang           [  75,  90,  105,
35238a880d67b3aa5650ad52037fe1c25b1750eca9Miao Wang              165, 203, 240,
36fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang              255, 255, 255,
37fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang              255, 255, 255,
38fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang              255, 255, 255,
39fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang              255, 255, 255]
40fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang          }
41fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang
42fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwang# Instantiate an example
43fdd5f3a78c7cf2c74340e30ca58ccf1b611a4ce2leozwangExample((input0, output0))
44