/**
* Copyright (c) 2025 Huawei Technologies Co., Ltd.
* This program is free software, you can redistribute it and/or modify it under the terms and conditions of
* CANN Open Software License Agreement Version 2.0 (the "License").
* Please refer to the License for details. You may not use this file except in compliance with the License.
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
* See LICENSE in the root of the software repository for the full text of the License.
*/
#include <gtest/gtest.h>
#include "graph/tensor.h"
#define private public
#define protected public
#define ENABLE_TILING_DEBUG
#include "tiling_api.h"
#include "platform_stub.h"
#include "tiling/platform/platform_ascendc.h"
#include "include/adv_api/conv/conv3d/conv3d_tilingdata.h"
#include "include/adv_api/conv/conv3d/conv3d_tiling.h"
#include "impl/adv_api/tiling/conv/conv3d_tiling_util.h"
#include "include/adv_api/conv/conv3d/conv3d_tiling_base.h"
#include "impl/adv_api/tiling/conv/conv3d_tiling_algorithm.h"

using namespace std;
using namespace Conv3dTilingApi;
using namespace ConvCommonApi;
using namespace matmul_tiling;

class TestConv3dTiling : public testing::Test {
protected:
    static void SetUpTestCase() {}
    static void TearDownTestCase() {}
    virtual void SetUp() {}
    virtual void TearDown() {}
    uint64_t l1Size = 524288 - 256;
    uint64_t l0cSize = 131072;
    uint64_t l0aSize = 65536;
    uint64_t l0bSize = 65536;
    const char *socVersion = "Ascend910B4";
    platform_ascendc::PlatformAscendC *ascendcPlatform =
        platform_ascendc::PlatformAscendCManager::GetInstance(socVersion);
};

void SetPlatFormInfo(Conv3dTiling* testTiling)
{
    testTiling->platformInfo.l1Size = L1_SIZE;
    testTiling->platformInfo.l0ASize = L0A_SIZE;
    testTiling->platformInfo.l0BSize = L0B_SIZE;
    testTiling->platformInfo.l0CSize = L0C_SIZE;
    testTiling->platformInfo.ubSize = UB_SIZE;
    testTiling->platformInfo.btSize = BT_SIZE;
    testTiling->platformInfo.fbSize = FB_SIZE;
}

void SetSingleOutputShapeInTest(Conv3dTilingApi::Conv3dTiling &testTiling)
{
    int64_t orgHo = (testTiling.shapeInfo.orgHi + testTiling.attrInfo.padUp + testTiling.attrInfo.padDown -
             testTiling.attrInfo.dilationH * (testTiling.shapeInfo.orgkH - 1) - 1) / testTiling.attrInfo.strideH + 1;
    int64_t orgWo = (testTiling.shapeInfo.orgWi + testTiling.attrInfo.padLeft + testTiling.attrInfo.padRight -
             testTiling.attrInfo.dilationW * (testTiling.shapeInfo.orgkW - 1) - 1) / testTiling.attrInfo.strideW + 1;

    int64_t singleM = orgHo * orgWo;
    int64_t singleDo = (testTiling.shapeInfo.orgDi + testTiling.attrInfo.padHead + testTiling.attrInfo.padTail -
                        testTiling.attrInfo.dilationD * (testTiling.shapeInfo.orgkD - 1) - 1) / testTiling.attrInfo.strideD + 1;

    testTiling.SetSingleOutputShape(testTiling.shapeInfo.orgCo, singleDo, singleM);
    testTiling.SetGroups(1);
    testTiling.attrInfo.groupOpt = 1;
    testTiling.shapeInfo.cinOpt = testTiling.shapeInfo.orgCi;
    testTiling.shapeInfo.coutOpt = testTiling.shapeInfo.orgCo;
    int64_t singleCoreGroupOpt = CeilDiv(testTiling.attrInfo.groupOpt, 1);
    // testTiling.SetOptGroupInfo(static_cast<int64_t>(testTiling.attrInfo.groupOpt),
    //                                 singleCoreGroupOpt,
    //                                 static_cast<int64_t>(testTiling.shapeInfo.cinOpt),
    //                                 static_cast<int64_t>(testTiling.shapeInfo.coutOpt));
}

void SetType(Conv3dTilingApi::Conv3dTiling &testTiling)
{
    testTiling.SetWeightType(TPosition::GM, ConvFormat::FRACTAL_Z_3D, ConvDtype::BF16);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    if (testTiling.hasBias) {
        testTiling.SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::FLOAT32);
    }
}

void TestTilingResult(int64_t ret, Conv3dTilingApi::Conv3dTiling &testTiling)
{
    EXPECT_EQ(ret, 0);
    EXPECT_NE(testTiling.l1TilingInfo.kAL1, 0);
    if (testTiling.l1TilingInfo.isWeightBypass) {
        EXPECT_EQ(testTiling.l1TilingInfo.kBL1, 0);
        EXPECT_EQ(testTiling.l1TilingInfo.nBL1Value, 0);
    } else {
        EXPECT_NE(testTiling.l1TilingInfo.kBL1, 0);

        EXPECT_NE(testTiling.l1TilingInfo.nBL1Value, 0);
        int multiDivFlag = (testTiling.l1TilingInfo.nBL1Value % testTiling.l0TilingInfo.nL0 == 0) | 
                            (testTiling.l1TilingInfo.nBL1Value % testTiling.cubeInfo.n0 == 0);
        EXPECT_EQ(multiDivFlag, 1);
    }
    
    EXPECT_NE(testTiling.l1TilingInfo.mAL1Value, 0);
    int multiDivFlag = (testTiling.l1TilingInfo.mAL1Value % testTiling.l0TilingInfo.mL0 == 0) | 
                        (testTiling.l1TilingInfo.mAL1Value % testTiling.cubeInfo.m0 == 0);
    EXPECT_EQ(multiDivFlag, 1);

    EXPECT_NE(testTiling.l0TilingInfo.mL0, 0);
    EXPECT_EQ(testTiling.l0TilingInfo.mL0 % testTiling.cubeInfo.m0, 0);
    EXPECT_NE(testTiling.l0TilingInfo.kL0, 0);
    EXPECT_EQ(testTiling.l0TilingInfo.kL0 % testTiling.cubeInfo.k0, 0);
    EXPECT_NE(testTiling.l0TilingInfo.nL0, 0);
    EXPECT_EQ(testTiling.l0TilingInfo.nL0 % testTiling.cubeInfo.n0, 0);
}

#if (defined(__NPU_ARCH__) && (__NPU_ARCH__ == 2201))
TEST_F(TestConv3dTiling, L0Range_cout_prime)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->shapeInfo.singleM = 32;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 11;
    testTiling->hasBias = true;

    algo.InitPingPong();
    EXPECT_EQ(algo.doubleBufferValue.pbAL1, 2);

    algo.GetL0TilingRange();
    std::vector<uint64_t> expRes0 = {16, 32};
    std::vector<uint64_t> expRes1 = {16, 32, 64, 128, 176};
    EXPECT_EQ(algo.l0TilingRange.mL0Range, expRes0);
    EXPECT_EQ(algo.l0TilingRange.nL0Range, expRes1);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

TEST_F(TestConv3dTiling, L0Range_m_prime)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 2;
    testTiling->shapeInfo.singleM = 11 * testTiling->cubeInfo.m0;
    testTiling->hasBias = true;

    algo.InitPingPong();
    algo.GetL0TilingRange();
    std::vector<uint64_t> expRes0 = {16, 32, 64, 128, 176};
    std::vector<uint64_t> expRes1 = {16, 32};
    EXPECT_EQ(algo.l0TilingRange.mL0Range, expRes0);
    EXPECT_EQ(algo.l0TilingRange.nL0Range, expRes1);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

TEST_F(TestConv3dTiling, L0Tiling_larger_cout1)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 64;
    testTiling->shapeInfo.singleM = 4 * testTiling->cubeInfo.m0;
    testTiling->hasBias = true;

    algo.InitPingPong();
    algo.GetL0TilingRange();
    std::vector<uint64_t> expRes0 = {16, 32, 64};
    std::vector<uint64_t> expRes1 = {16, 32, 64, 128, 256, 512, 1024};
    algo.L0TilingDecision();
    bool flag = std::find(expRes0.begin(), expRes0.end(), algo.l0TilingParams.mL0) != expRes0.end();
    EXPECT_EQ(flag, true);
    flag = std::find(expRes1.begin(), expRes1.end(), algo.l0TilingParams.nL0) != expRes1.end();
    EXPECT_EQ(flag, true);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

TEST_F(TestConv3dTiling, L0Tiling_larger_m)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 4;
    testTiling->shapeInfo.singleM = 64 * testTiling->cubeInfo.m0;
    testTiling->hasBias = true;

    algo.InitPingPong();
    algo.GetL0TilingRange();
    std::vector<uint64_t> expRes0 = {16, 32, 64, 128, 256, 512, 1024};
    std::vector<uint64_t> expRes1 = {16, 32, 64};
    algo.L0TilingDecision();
    bool flag = std::find(expRes0.begin(), expRes0.end(), algo.l0TilingParams.mL0) != expRes0.end();
    EXPECT_EQ(flag, true);
    flag = std::find(expRes1.begin(), expRes1.end(), algo.l0TilingParams.nL0) != expRes1.end();
    EXPECT_EQ(flag, true);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

TEST_F(TestConv3dTiling, L0Range_normal)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 16;
    testTiling->shapeInfo.singleM = 16 * testTiling->cubeInfo.m0;
    testTiling->hasBias = true;

    algo.InitPingPong();
    algo.GetL0TilingRange();
    std::vector<uint64_t> expRes0 = {16, 32, 64, 128, 256};
    std::vector<uint64_t> expRes1 = {16, 32, 64, 128, 256};
    algo.L0TilingDecision();
    bool flag = std::find(expRes0.begin(), expRes0.end(), algo.l0TilingParams.mL0) != expRes0.end();
    EXPECT_EQ(flag, true);
    flag = std::find(expRes1.begin(), expRes1.end(), algo.l0TilingParams.nL0) != expRes1.end();
    EXPECT_EQ(flag, true);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

TEST_F(TestConv3dTiling, GetL0Tiling_normal)
{
    Conv3dTilingApi::Conv3dTiling* testTiling = new Conv3dTilingApi::Conv3dTiling(*ascendcPlatform);

    SetPlatFormInfo(testTiling);
    testTiling->SetWeightType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling->SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::BF16);
    testTiling->GetCubeInfo();
    Conv3dTilingApi::Conv3dTilingAlgorithm algo(testTiling);

    testTiling->shapeInfo.orgHi = 32;
    testTiling->shapeInfo.orgWi = 32;
    testTiling->shapeInfo.singlekH = 3;
    testTiling->attrInfo.dilationH = 1;
    testTiling->attrInfo.strideH = 1;
    testTiling->shapeCalc.orgWo = 8;
    testTiling->shapeCalc.singleCo1 = 16;
    testTiling->shapeInfo.singleM = 16 * testTiling->cubeInfo.m0;
    testTiling->hasBias = true;

    algo.InitPingPong();
    int64_t ret = algo.GetL0Tiling();
    EXPECT_EQ(ret, 0);

    if (testTiling != nullptr) {
        delete testTiling;
        testTiling = nullptr;
    }
}

// TestCase for Networks
TEST_F(TestConv3dTiling, TilingUtil)
{
    int64_t res = LCM(2, 3);
    EXPECT_EQ(res, 6);

    // test LCM 0
    res = LCM(3, 0);
    EXPECT_EQ(res, 1);

    // test CeilDiv 0
    res = CeilDiv(3, 0);
    EXPECT_EQ(res, 0);

    // test AlignB 0
    res = AlignB(3, 0);
    EXPECT_EQ(res, 0);

    // test Gcd 0
    res = Gcd(3, 0);
    EXPECT_EQ(res, 3);
}

// TestCase for TilingInitConv3dTilingBase
TEST_F(TestConv3dTiling, TilingInitConv3dTilingBase)
{
    // ascendc platform
    fe::PlatFormInfos platformInfo;
    auto plat = platform_ascendc::PlatformAscendC(&platformInfo);
    Conv3dTilingApi::Conv3dTiling testTiling2(plat);

    Conv3dTilingApi::PlatformInfo platform;
    Conv3dTilingApi::Conv3dTiling testTiling3(platform);
}

// TestCase for TilingSetFuncTest
TEST_F(TestConv3dTiling, TilingSetFuncTest)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    EXPECT_EQ(testTiling.shapeInfo.orgHi, 32);
    EXPECT_EQ(testTiling.shapeInfo.orgkD, 1);
    EXPECT_EQ(testTiling.shapeInfo.singlekW, 2);

    testTiling.SetPadding(1, 2, 3, 4, 5, 6);
    testTiling.SetDilation(7, 8, 9);
    testTiling.SetStride(2, 2, 1);

    EXPECT_EQ(testTiling.attrInfo.padTail, 2);
    EXPECT_EQ(testTiling.attrInfo.dilationW, 9);
    EXPECT_EQ(testTiling.attrInfo.strideH, 2);

    testTiling.SetSingleOutputShape(11, 12, 15, 15);
    testTiling.SetHF32(true, false);
    EXPECT_EQ(testTiling.shapeInfo.singleHo, 15);
    EXPECT_EQ(testTiling.shapeInfo.singleM, 225);
    EXPECT_EQ(testTiling.attrInfo.hf32Enable, true);

    // invalid group cal
    Conv3DOriGroupInfo oriGroupInfo;
    oriGroupInfo.groups = 0;
    oriGroupInfo.cin = 1;
    oriGroupInfo.cout = 1;
    oriGroupInfo.dtype = ConvDtype::FLOAT16;
    Conv3DGroupOptInfo groupOptInfo;
    // bool res = testTiling.CalOptGroupParams(oriGroupInfo, groupOptInfo);
    // EXPECT_EQ(res, false);

    oriGroupInfo;
    oriGroupInfo.groups = 1;
    oriGroupInfo.cin = 1;
    oriGroupInfo.cout = 1;
    oriGroupInfo.dtype = ConvDtype::INT8;
    groupOptInfo;
    // res = testTiling.CalOptGroupParams(oriGroupInfo, groupOptInfo);
    // EXPECT_EQ(res, false);

    oriGroupInfo;
    oriGroupInfo.groups = 3;
    oriGroupInfo.cin = 2;
    oriGroupInfo.cout = 2;
    oriGroupInfo.dtype = ConvDtype::FLOAT16;
    groupOptInfo;
    // res = testTiling.CalOptGroupParams(oriGroupInfo, groupOptInfo);
    // EXPECT_EQ(res, false);

    // group = 1 cal
    oriGroupInfo.groups = 1;
    oriGroupInfo.cin = 1;
    oriGroupInfo.cout = 1;
    oriGroupInfo.dtype = ConvDtype::FLOAT16;
    // res = testTiling.CalOptGroupParams(oriGroupInfo, groupOptInfo);
    // EXPECT_EQ(res, true);
    // EXPECT_EQ(groupOptInfo.groupOpt, 1);

    // group > 1 cal
    oriGroupInfo.groups = 2;
    oriGroupInfo.cin = 2;
    oriGroupInfo.cout = 2;
    oriGroupInfo.dtype = ConvDtype::FLOAT16;
    // res = testTiling.CalOptGroupParams(oriGroupInfo, groupOptInfo);
    // EXPECT_EQ(res, true);
    // EXPECT_EQ(groupOptInfo.cinOpt, 2);
}

// TestCase for checkInvalidTest
TEST_F(TestConv3dTiling, checkInvalidTest1)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetHF32(true, true);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest2)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(-2);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest3)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, -4, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest4)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, -1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest5)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, -2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest6)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, -5, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // outshape invalid
    testTiling.SetOrgInputShape(4, 5, 2, 32);
    testTiling.SetOrgWeightShape(1152, 1, 8, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // load3dv2 invalid
    testTiling.SetOrgInputShape(4, 5, 256, 256);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 65, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // load3dv2 invalid
    testTiling.SetOrgInputShape(4, 5, 256, 256);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 266, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // load3dv2 invalid
    testTiling.SetOrgInputShape(4, 5, 256, 256);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 267, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // load3dv2 invalid
    testTiling.SetOrgInputShape(4, 5, 666, 256);
    testTiling.SetOrgWeightShape(1152, 1, 555, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

TEST_F(TestConv3dTiling, checkInvalidTest7)
{
    // invalid single shape
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, -2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    bool ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);

    // invalid single shape
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(-1, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    testTiling.SetGroups(1);
    SetType(testTiling);

    ret1 = testTiling.CheckInputParam();
    EXPECT_EQ(ret1, false);
}

// TestCase for Networks
TEST_F(TestConv3dTiling, NetWorks_001)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_002)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 16, 26, 36);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_003)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 4, 32, 32);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling); 
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_004)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 18, 130, 130);
    testTiling.SetOrgWeightShape(240, 4, 4, 4);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 4, 4, 4);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 2);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_005)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 10, 66, 66);
    testTiling.SetOrgWeightShape(240, 4, 4, 4);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 4, 4, 4);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 2);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_006)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 6, 34, 34);
    testTiling.SetOrgWeightShape(240, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_007)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 6, 34, 34);
    testTiling.SetOrgWeightShape(120, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_008)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(120, 4, 32, 32);
    testTiling.SetOrgWeightShape(240, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_009)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_010)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);
    
    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_011)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 17, 257, 257);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_012)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_013)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_014)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 9, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_015)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 9, 129, 129);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_016)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_017)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_018)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 5, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_019)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 65, 65);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_020)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_021)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_022)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(8, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_023)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 5, 32, 32);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_024)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 3, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_025)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 3, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_026)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 1, 257, 257);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_027)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 3, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_028)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 3, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_029)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 1, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_030)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 1, 129, 129);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_031)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 3, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_032)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 3, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_033)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 1, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_034)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 1, 65, 65);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_035)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 3, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_036)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 1, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_037)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 3, 32, 32);
    testTiling.SetOrgWeightShape(8, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_038)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 1, 32, 32);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_039)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 26, 134, 134);
    testTiling.SetOrgWeightShape(64, 7, 7, 7);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 7, 7, 7);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_040)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(64, 22, 130, 130);
    testTiling.SetOrgWeightShape(64, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_041)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(64, 20, 128, 128);
    testTiling.SetOrgWeightShape(64, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_042)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 22, 66, 66);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_043)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 20, 64, 64);
    testTiling.SetOrgWeightShape(128, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_044)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 22, 34, 34);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_045)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 20, 32, 32);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_046)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 20, 32, 32);
    testTiling.SetOrgWeightShape(1364, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_047)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(682, 20, 32, 32);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_048)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 22, 18, 18);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_049)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 20, 16, 16);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_050)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 20, 16, 16);
    testTiling.SetOrgWeightShape(2730, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_051)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1365, 20, 16, 16);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}


TEST_F(TestConv3dTiling, NetWorks_052)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 12, 18, 18);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_053)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 10, 16, 16);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_054)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 18, 18);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_055)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 16, 16);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_056)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 16, 16);
    testTiling.SetOrgWeightShape(2730, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_057)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1365, 5, 16, 16);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_058)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(64, 22, 130, 130);
    testTiling.SetOrgWeightShape(3, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_059)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_060)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_061)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 17, 257, 257);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_062)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_063)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_064)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 9, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_065)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 9, 129, 129);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_066)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_067)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_068)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 5, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_069)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_070)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 65, 65);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_071)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_072)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_073)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 5, 32, 32);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_074)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 5, 32, 32);
    testTiling.SetOrgWeightShape(4, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_075)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_076)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_077)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_078)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_079)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_080)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_081)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_082)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_083)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_084)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 11, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_085)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 9, 128, 128);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_086)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_087)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_088)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 17, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_089)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_090)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 256, 256);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_091)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_092)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_093)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 256, 256);
    testTiling.SetOrgWeightShape(128, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_094)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_095)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(3, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    testTiling.hasBias = 1; 
    SetType(testTiling);
    SetSingleOutputShapeInTest(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_096)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 120, 32, 32);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_097)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(320, 25, 40, 64);
    testTiling.SetOrgWeightShape(320, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_098)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(640, 25, 20, 32);
    testTiling.SetOrgWeightShape(640, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);
    
    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_099)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_100)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 5, 8);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_101)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(320, 25, 40, 64);
    testTiling.SetOrgWeightShape(320, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_102)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(640, 25, 20, 32);
    testTiling.SetOrgWeightShape(640, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_103)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_104)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 5, 8);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_105)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 8, 40, 64);
    testTiling.SetOrgWeightShape(512, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_106)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 8, 80, 128);
    testTiling.SetOrgWeightShape(512, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_107)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 8, 160, 256);
    testTiling.SetOrgWeightShape(256, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_108)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 8, 320, 512);
    testTiling.SetOrgWeightShape(128, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_109)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 8, 320, 512);
    testTiling.SetOrgWeightShape(3, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_110)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 1, 40, 64);
    testTiling.SetOrgWeightShape(512, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_111)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 1, 80, 128);
    testTiling.SetOrgWeightShape(512, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_112)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 1, 160, 256);
    testTiling.SetOrgWeightShape(256, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_113)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 1, 320, 512);
    testTiling.SetOrgWeightShape(128, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_114)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 1, 320, 512);
    testTiling.SetOrgWeightShape(3, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_115)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 4, 32, 32);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_116)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 18, 130, 130);
    testTiling.SetOrgWeightShape(240, 4, 4, 4);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 4, 4, 4);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 2);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_117)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 10, 66, 66);
    testTiling.SetOrgWeightShape(240, 4, 4, 4);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 4, 4, 4);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 2);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_118)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 6, 34, 34);
    testTiling.SetOrgWeightShape(240, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_119)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(240, 6, 34, 34);
    testTiling.SetOrgWeightShape(120, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_120)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(120, 4, 32, 32);
    testTiling.SetOrgWeightShape(240, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_121)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 16, 224, 224);
    testTiling.SetOrgWeightShape(768, 2, 16, 16);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 2, 16, 16);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(16, 16, 2);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_122)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 35, 192, 192);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_123)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 35, 192, 192);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_124)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 33, 193, 193);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_125)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 35, 96, 96);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_126)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 35, 96, 96);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_127)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 33, 96, 96);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_128)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 33, 97, 97);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_129)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 48, 48);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_130)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 19, 48, 48);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_131)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 48, 48);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_132)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 17, 49, 49);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_133)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 11, 24, 24);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_134)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 19, 48, 48);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_135)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 11, 24, 24);
    testTiling.SetOrgWeightShape(8, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_136)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 9, 24, 24);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_137)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 9, 24, 24);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_138)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 19, 320, 320);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_139)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 320, 320);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_140)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 17, 321, 321);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_141)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 160, 160);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_142)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 160, 160);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_143)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 17, 160, 160);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_144)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 161, 161);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_145)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 11, 80, 80);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_146)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 11, 80, 80);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_147)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 9, 80, 80);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_148)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 9, 81, 81);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_149)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 40, 40);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_150)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 40, 40);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_151)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 40, 40);
    testTiling.SetOrgWeightShape(8, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_152)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 5, 40, 40);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_153)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 5, 40, 40);
    testTiling.SetOrgWeightShape(1152, 1, 2, 2);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 2, 2);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_154)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(3, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_155)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_156)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 17, 257, 257);
    testTiling.SetOrgWeightShape(128, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_157)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_158)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 11, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_159)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 9, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_160)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 9, 129, 129);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_161)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_162)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_163)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 5, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_164)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_165)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 65, 65);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(2, 2, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_166)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_167)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_168)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(8, 5, 32, 32);
    testTiling.SetOrgWeightShape(8, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_169)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 5, 32, 32);
    testTiling.SetOrgWeightShape(4, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_170)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(4, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_171)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_172)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_173)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_174)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_175)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_176)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 32, 32);
    testTiling.SetOrgWeightShape(512, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_177)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 7, 32, 32);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_178)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 5, 64, 64);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_179)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 11, 64, 64);
    testTiling.SetOrgWeightShape(512, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_180)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 9, 128, 128);
    testTiling.SetOrgWeightShape(512, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_181)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_182)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_183)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(512, 17, 128, 128);
    testTiling.SetOrgWeightShape(256, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_184)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 128, 128);
    testTiling.SetOrgWeightShape(256, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_185)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 256, 256);
    testTiling.SetOrgWeightShape(256, 1, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_186)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_187)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_188)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(256, 17, 256, 256);
    testTiling.SetOrgWeightShape(128, 1, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 1, 1, 1);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_189)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(128, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_190)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(128, 19, 256, 256);
    testTiling.SetOrgWeightShape(3, 3, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 3, 3);

    testTiling.SetPadding(0, 0, 1, 1, 1, 1);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1; 
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_largeK_noFullLoad_001)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(16, 7, 256, 32);
    testTiling.SetOrgWeightShape(1024, 7, 7, 7);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 7, 7, 7);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_largeK_noFullLoad_002)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(17, 7, 256, 32);
    testTiling.SetOrgWeightShape(1024, 7, 5, 5);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 7, 5, 5);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, NetWorks_largeK_noFullLoad_003)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(16, 7, 64, 128);
    testTiling.SetOrgWeightShape(1024, 7, 3, 3);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 7, 3, 3);

    testTiling.SetPadding(0, 0, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 1;
    SetType(testTiling);

    int64_t ret1 = testTiling.GetTiling(tilingData);
    TestTilingResult(ret1, testTiling);
}

TEST_F(TestConv3dTiling, Beyond_Input_Attr_Upper_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    testTiling.SetPadding(1000001, 1, 0, 0, 0, 0);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetPadding(1, 1000001, 0, 0, 0, 0);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1000001, 1, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1000001, 1, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Beyond_Org_Input_Upper_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    testTiling.SetOrgInputShape(1000001, 25, 10, 16);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetOrgInputShape(1280, 1000001, 10, 16);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetOrgInputShape(1280, 25, 1000001, 16);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetOrgInputShape(1280, 25, 10, 1000001);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1000001, 3, 1, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetPadding(1000000, 1000000, 0, 0, 0, 0);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 1000001, 1, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Set_Org_Input_Negative_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    testTiling.SetOrgWeightShape(-1, 3, 1, 1);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Set_Single_Input_Illegal_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    testTiling.SetSingleWeightShape(30, 3, 1, 1);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetSingleWeightShape(25, 3, 1, 1);
    testTiling.SetSingleOutputShape(1281, 23, 160);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Set_Input_Format_Illegal_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    testTiling.SetWeightType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetWeightType(TPosition::GM, ConvFormat::FRACTAL_Z_3D, ConvDtype::BF16);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NCDHW, ConvDtype::BF16);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetWeightType(TPosition::GM, ConvFormat::FRACTAL_Z_3D, ConvDtype::BF16);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::BF16);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDHWC, ConvDtype::BF16);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Set_Input_Dtype_Illegal_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0;
    SetType(testTiling);

    testTiling.SetWeightType(TPosition::GM, ConvFormat::FRACTAL_Z_3D, ConvDtype::FLOAT32);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::FLOAT32);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::FLOAT32);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetWeightType(TPosition::GM, ConvFormat::FRACTAL_Z_3D, ConvDtype::FLOAT32);
    testTiling.SetInputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::FLOAT32);
    testTiling.SetOutputType(TPosition::GM, ConvFormat::NDC1HWC0, ConvDtype::FLOAT32);
    testTiling.SetBiasType(TPosition::GM, ConvFormat::ND, ConvDtype::FLOAT32);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Beyond_Input_Attr_Load3D_Limits_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 256, 1);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 64, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);
    testTiling.SetOrgWeightShape(1280, 3, 512, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 512, 1);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);

    testTiling.SetPadding(1, 1, 0, 0, 0, 0);
    testTiling.SetDilation(1, 1, 1);
    testTiling.SetStride(1, 1, 1);
    testTiling.SetOrgWeightShape(1280, 3, 255, 17);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 255, 17);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Beyond_Org_Output_Upper_Error)
{
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    testTiling.SetOrgInputShape(1280, 2000000, 10, 16);
    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetOrgInputShape(1280, 25, 2000000, 16);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);

    testTiling.SetOrgInputShape(1280, 25, 10, 2000000);
    ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}

TEST_F(TestConv3dTiling, Check_Ascend910_93)
{
    const char *socVersion1 = "Ascend910_93";
    platform_ascendc::PlatformAscendC *ascendcPlatform1 =
        platform_ascendc::PlatformAscendCManager::GetInstance(socVersion1);
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform1);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, 0);
}
#endif

#if defined(__NPU_ARCH__) && __NPU_ARCH__ == 2002
TEST_F(TestConv3dTiling, Soc_Error)
{
    const char *socVersion1 = "Ascend310P3";
    platform_ascendc::PlatformAscendC *ascendcPlatform1 =
        platform_ascendc::PlatformAscendCManager::GetInstance(socVersion1);
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform1);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}
#endif

#if defined(__NPU_ARCH__) && (__NPU_ARCH__ == 3102 || __NPU_ARCH__ == 3510)
TEST_F(TestConv3dTiling, Soc_Error1)
{
    const char *socVersion1 = "AscendError";
    platform_ascendc::PlatformAscendC *ascendcPlatform1 =
        platform_ascendc::PlatformAscendCManager::GetInstance(socVersion1);
    optiling::TConv3DApiTiling tilingData;
    Conv3dTilingApi::Conv3dTiling testTiling(*ascendcPlatform1);
    testTiling.SetOrgInputShape(1280, 25, 10, 16);
    testTiling.SetOrgWeightShape(1280, 3, 1, 1);
    testTiling.SetSingleWeightShape(testTiling.shapeInfo.orgCi, 3, 1, 1);

    SetSingleOutputShapeInTest(testTiling);
    testTiling.hasBias = 0; 
    SetType(testTiling);

    int64_t ret = testTiling.GetTiling(tilingData);
    EXPECT_EQ(ret, -1);
}
#endif