// Copyright (c) 2017 Google Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include #include #include #include "gmock/gmock.h" #include "source/opt/dominator_analysis.h" #include "source/opt/pass.h" #include "test/opt/assembly_builder.h" #include "test/opt/function_utils.h" #include "test/opt/pass_fixture.h" #include "test/opt/pass_utils.h" namespace spvtools { namespace opt { namespace { using ::testing::UnorderedElementsAre; using PassClassTest = PassTest<::testing::Test>; /* Generated from the following GLSL #version 440 core layout(location = 0) out vec4 v; layout(location = 1) in vec4 in_val; void main() { for (int i = 0; i < in_val.x; ++i) { for (int j = 0; j < in_val.y; j++) { } } for (int i = 0; i < in_val.x; ++i) { for (int j = 0; j < in_val.y; j++) { } break; } int i = 0; while (i < in_val.x) { ++i; for (int j = 0; j < 1; j++) { for (int k = 0; k < 1; k++) { } break; } } i = 0; while (i < in_val.x) { ++i; continue; for (int j = 0; j < 1; j++) { for (int k = 0; k < 1; k++) { } break; } } v = vec4(1,1,1,1); } */ TEST_F(PassClassTest, BasicVisitFromEntryPoint) { const std::string text = R"( OpCapability Shader %1 = OpExtInstImport "GLSL.std.450" OpMemoryModel Logical GLSL450 OpEntryPoint Fragment %4 "main" %20 %141 OpExecutionMode %4 OriginUpperLeft OpSource GLSL 440 OpName %4 "main" OpName %8 "i" OpName %20 "in_val" OpName %28 "j" OpName %45 "i" OpName %56 "j" OpName %72 "i" OpName %85 "j" OpName %93 "k" OpName %119 "j" OpName %127 "k" OpName %141 "v" OpDecorate %20 Location 1 OpDecorate %141 Location 0 %2 = OpTypeVoid %3 = OpTypeFunction %2 %6 = OpTypeInt 32 1 %7 = OpTypePointer Function %6 %9 = OpConstant %6 0 %16 = OpTypeFloat 32 %18 = OpTypeVector %16 4 %19 = OpTypePointer Input %18 %20 = OpVariable %19 Input %21 = OpTypeInt 32 0 %22 = OpConstant %21 0 %23 = OpTypePointer Input %16 %26 = OpTypeBool %36 = OpConstant %21 1 %41 = OpConstant %6 1 %140 = OpTypePointer Output %18 %141 = OpVariable %140 Output %142 = OpConstant %16 1 %143 = OpConstantComposite %18 %142 %142 %142 %142 %4 = OpFunction %2 None %3 %5 = OpLabel %8 = OpVariable %7 Function %28 = OpVariable %7 Function %45 = OpVariable %7 Function %56 = OpVariable %7 Function %72 = OpVariable %7 Function %85 = OpVariable %7 Function %93 = OpVariable %7 Function %119 = OpVariable %7 Function %127 = OpVariable %7 Function OpStore %8 %9 OpBranch %10 %10 = OpLabel OpLoopMerge %12 %13 None OpBranch %14 %14 = OpLabel %15 = OpLoad %6 %8 %17 = OpConvertSToF %16 %15 %24 = OpAccessChain %23 %20 %22 %25 = OpLoad %16 %24 %27 = OpFOrdLessThan %26 %17 %25 OpBranchConditional %27 %11 %12 %11 = OpLabel OpStore %28 %9 OpBranch %29 %29 = OpLabel OpLoopMerge %31 %32 None OpBranch %33 %33 = OpLabel %34 = OpLoad %6 %28 %35 = OpConvertSToF %16 %34 %37 = OpAccessChain %23 %20 %36 %38 = OpLoad %16 %37 %39 = OpFOrdLessThan %26 %35 %38 OpBranchConditional %39 %30 %31 %30 = OpLabel OpBranch %32 %32 = OpLabel %40 = OpLoad %6 %28 %42 = OpIAdd %6 %40 %41 OpStore %28 %42 OpBranch %29 %31 = OpLabel OpBranch %13 %13 = OpLabel %43 = OpLoad %6 %8 %44 = OpIAdd %6 %43 %41 OpStore %8 %44 OpBranch %10 %12 = OpLabel OpStore %45 %9 OpBranch %46 %46 = OpLabel OpLoopMerge %48 %49 None OpBranch %50 %50 = OpLabel %51 = OpLoad %6 %45 %52 = OpConvertSToF %16 %51 %53 = OpAccessChain %23 %20 %22 %54 = OpLoad %16 %53 %55 = OpFOrdLessThan %26 %52 %54 OpBranchConditional %55 %47 %48 %47 = OpLabel OpStore %56 %9 OpBranch %57 %57 = OpLabel OpLoopMerge %59 %60 None OpBranch %61 %61 = OpLabel %62 = OpLoad %6 %56 %63 = OpConvertSToF %16 %62 %64 = OpAccessChain %23 %20 %36 %65 = OpLoad %16 %64 %66 = OpFOrdLessThan %26 %63 %65 OpBranchConditional %66 %58 %59 %58 = OpLabel OpBranch %60 %60 = OpLabel %67 = OpLoad %6 %56 %68 = OpIAdd %6 %67 %41 OpStore %56 %68 OpBranch %57 %59 = OpLabel OpBranch %48 %49 = OpLabel %70 = OpLoad %6 %45 %71 = OpIAdd %6 %70 %41 OpStore %45 %71 OpBranch %46 %48 = OpLabel OpStore %72 %9 OpBranch %73 %73 = OpLabel OpLoopMerge %75 %76 None OpBranch %77 %77 = OpLabel %78 = OpLoad %6 %72 %79 = OpConvertSToF %16 %78 %80 = OpAccessChain %23 %20 %22 %81 = OpLoad %16 %80 %82 = OpFOrdLessThan %26 %79 %81 OpBranchConditional %82 %74 %75 %74 = OpLabel %83 = OpLoad %6 %72 %84 = OpIAdd %6 %83 %41 OpStore %72 %84 OpStore %85 %9 OpBranch %86 %86 = OpLabel OpLoopMerge %88 %89 None OpBranch %90 %90 = OpLabel %91 = OpLoad %6 %85 %92 = OpSLessThan %26 %91 %41 OpBranchConditional %92 %87 %88 %87 = OpLabel OpStore %93 %9 OpBranch %94 %94 = OpLabel OpLoopMerge %96 %97 None OpBranch %98 %98 = OpLabel %99 = OpLoad %6 %93 %100 = OpSLessThan %26 %99 %41 OpBranchConditional %100 %95 %96 %95 = OpLabel OpBranch %97 %97 = OpLabel %101 = OpLoad %6 %93 %102 = OpIAdd %6 %101 %41 OpStore %93 %102 OpBranch %94 %96 = OpLabel OpBranch %88 %89 = OpLabel %104 = OpLoad %6 %85 %105 = OpIAdd %6 %104 %41 OpStore %85 %105 OpBranch %86 %88 = OpLabel OpBranch %76 %76 = OpLabel OpBranch %73 %75 = OpLabel OpStore %72 %9 OpBranch %106 %106 = OpLabel OpLoopMerge %108 %109 None OpBranch %110 %110 = OpLabel %111 = OpLoad %6 %72 %112 = OpConvertSToF %16 %111 %113 = OpAccessChain %23 %20 %22 %114 = OpLoad %16 %113 %115 = OpFOrdLessThan %26 %112 %114 OpBranchConditional %115 %107 %108 %107 = OpLabel %116 = OpLoad %6 %72 %117 = OpIAdd %6 %116 %41 OpStore %72 %117 OpBranch %109 %109 = OpLabel OpBranch %106 %108 = OpLabel OpStore %141 %143 OpReturn OpFunctionEnd )"; // clang-format on std::unique_ptr context = BuildModule(SPV_ENV_UNIVERSAL_1_1, nullptr, text, SPV_TEXT_TO_BINARY_OPTION_PRESERVE_NUMERIC_IDS); Module* module = context->module(); EXPECT_NE(nullptr, module) << "Assembling failed for shader:\n" << text << std::endl; const Function* f = spvtest::GetFunction(module, 4); DominatorAnalysis* analysis = context->GetDominatorAnalysis(f); EXPECT_TRUE(analysis->Dominates(5, 10)); EXPECT_TRUE(analysis->Dominates(5, 14)); EXPECT_TRUE(analysis->Dominates(5, 11)); EXPECT_TRUE(analysis->Dominates(5, 29)); EXPECT_TRUE(analysis->Dominates(5, 33)); EXPECT_TRUE(analysis->Dominates(5, 30)); EXPECT_TRUE(analysis->Dominates(5, 32)); EXPECT_TRUE(analysis->Dominates(5, 31)); EXPECT_TRUE(analysis->Dominates(5, 13)); EXPECT_TRUE(analysis->Dominates(5, 12)); EXPECT_TRUE(analysis->Dominates(5, 46)); EXPECT_TRUE(analysis->Dominates(5, 50)); EXPECT_TRUE(analysis->Dominates(5, 47)); EXPECT_TRUE(analysis->Dominates(5, 57)); EXPECT_TRUE(analysis->Dominates(5, 61)); EXPECT_TRUE(analysis->Dominates(5, 59)); EXPECT_TRUE(analysis->Dominates(5, 58)); EXPECT_TRUE(analysis->Dominates(5, 60)); EXPECT_TRUE(analysis->Dominates(5, 48)); EXPECT_TRUE(analysis->Dominates(5, 73)); EXPECT_TRUE(analysis->Dominates(5, 77)); EXPECT_TRUE(analysis->Dominates(5, 75)); EXPECT_TRUE(analysis->Dominates(5, 106)); EXPECT_TRUE(analysis->Dominates(5, 110)); EXPECT_TRUE(analysis->Dominates(5, 107)); EXPECT_TRUE(analysis->Dominates(5, 108)); EXPECT_TRUE(analysis->Dominates(5, 109)); EXPECT_TRUE(analysis->Dominates(5, 74)); EXPECT_TRUE(analysis->Dominates(5, 86)); EXPECT_TRUE(analysis->Dominates(5, 90)); EXPECT_TRUE(analysis->Dominates(5, 87)); EXPECT_TRUE(analysis->Dominates(5, 94)); EXPECT_TRUE(analysis->Dominates(5, 98)); EXPECT_TRUE(analysis->Dominates(5, 95)); EXPECT_TRUE(analysis->Dominates(5, 97)); EXPECT_TRUE(analysis->Dominates(5, 96)); EXPECT_TRUE(analysis->Dominates(5, 88)); EXPECT_TRUE(analysis->Dominates(5, 76)); EXPECT_TRUE(analysis->Dominates(10, 14)); EXPECT_TRUE(analysis->Dominates(10, 11)); EXPECT_TRUE(analysis->Dominates(10, 29)); EXPECT_TRUE(analysis->Dominates(10, 33)); EXPECT_TRUE(analysis->Dominates(10, 30)); EXPECT_TRUE(analysis->Dominates(10, 32)); EXPECT_TRUE(analysis->Dominates(10, 31)); EXPECT_TRUE(analysis->Dominates(10, 13)); EXPECT_TRUE(analysis->Dominates(10, 12)); EXPECT_TRUE(analysis->Dominates(10, 46)); EXPECT_TRUE(analysis->Dominates(10, 50)); EXPECT_TRUE(analysis->Dominates(10, 47)); EXPECT_TRUE(analysis->Dominates(10, 57)); EXPECT_TRUE(analysis->Dominates(10, 61)); EXPECT_TRUE(analysis->Dominates(10, 59)); EXPECT_TRUE(analysis->Dominates(10, 58)); EXPECT_TRUE(analysis->Dominates(10, 60)); EXPECT_TRUE(analysis->Dominates(10, 48)); EXPECT_TRUE(analysis->Dominates(10, 73)); EXPECT_TRUE(analysis->Dominates(10, 77)); EXPECT_TRUE(analysis->Dominates(10, 75)); EXPECT_TRUE(analysis->Dominates(10, 106)); EXPECT_TRUE(analysis->Dominates(10, 110)); EXPECT_TRUE(analysis->Dominates(10, 107)); EXPECT_TRUE(analysis->Dominates(10, 108)); EXPECT_TRUE(analysis->Dominates(10, 109)); EXPECT_TRUE(analysis->Dominates(10, 74)); EXPECT_TRUE(analysis->Dominates(10, 86)); EXPECT_TRUE(analysis->Dominates(10, 90)); EXPECT_TRUE(analysis->Dominates(10, 87)); EXPECT_TRUE(analysis->Dominates(10, 94)); EXPECT_TRUE(analysis->Dominates(10, 98)); EXPECT_TRUE(analysis->Dominates(10, 95)); EXPECT_TRUE(analysis->Dominates(10, 97)); EXPECT_TRUE(analysis->Dominates(10, 96)); EXPECT_TRUE(analysis->Dominates(10, 88)); EXPECT_TRUE(analysis->Dominates(10, 76)); EXPECT_TRUE(analysis->Dominates(14, 11)); EXPECT_TRUE(analysis->Dominates(14, 29)); EXPECT_TRUE(analysis->Dominates(14, 33)); EXPECT_TRUE(analysis->Dominates(14, 30)); EXPECT_TRUE(analysis->Dominates(14, 32)); EXPECT_TRUE(analysis->Dominates(14, 31)); EXPECT_TRUE(analysis->Dominates(11, 29)); EXPECT_TRUE(analysis->Dominates(11, 33)); EXPECT_TRUE(analysis->Dominates(11, 30)); EXPECT_TRUE(analysis->Dominates(11, 32)); EXPECT_TRUE(analysis->Dominates(11, 31)); EXPECT_TRUE(analysis->Dominates(29, 33)); EXPECT_TRUE(analysis->Dominates(29, 30)); EXPECT_TRUE(analysis->Dominates(29, 32)); EXPECT_TRUE(analysis->Dominates(29, 31)); EXPECT_TRUE(analysis->Dominates(33, 30)); EXPECT_TRUE(analysis->Dominates(12, 46)); EXPECT_TRUE(analysis->Dominates(12, 50)); EXPECT_TRUE(analysis->Dominates(12, 47)); EXPECT_TRUE(analysis->Dominates(12, 57)); EXPECT_TRUE(analysis->Dominates(12, 61)); EXPECT_TRUE(analysis->Dominates(12, 59)); EXPECT_TRUE(analysis->Dominates(12, 58)); EXPECT_TRUE(analysis->Dominates(12, 60)); EXPECT_TRUE(analysis->Dominates(12, 48)); EXPECT_TRUE(analysis->Dominates(12, 73)); EXPECT_TRUE(analysis->Dominates(12, 77)); EXPECT_TRUE(analysis->Dominates(12, 75)); EXPECT_TRUE(analysis->Dominates(12, 106)); EXPECT_TRUE(analysis->Dominates(12, 110)); EXPECT_TRUE(analysis->Dominates(12, 107)); EXPECT_TRUE(analysis->Dominates(12, 108)); EXPECT_TRUE(analysis->Dominates(12, 109)); EXPECT_TRUE(analysis->Dominates(12, 74)); EXPECT_TRUE(analysis->Dominates(12, 86)); EXPECT_TRUE(analysis->Dominates(12, 90)); EXPECT_TRUE(analysis->Dominates(12, 87)); EXPECT_TRUE(analysis->Dominates(12, 94)); EXPECT_TRUE(analysis->Dominates(12, 98)); EXPECT_TRUE(analysis->Dominates(12, 95)); EXPECT_TRUE(analysis->Dominates(12, 97)); EXPECT_TRUE(analysis->Dominates(12, 96)); EXPECT_TRUE(analysis->Dominates(12, 88)); EXPECT_TRUE(analysis->Dominates(12, 76)); EXPECT_TRUE(analysis->Dominates(46, 50)); EXPECT_TRUE(analysis->Dominates(46, 47)); EXPECT_TRUE(analysis->Dominates(46, 57)); EXPECT_TRUE(analysis->Dominates(46, 61)); EXPECT_TRUE(analysis->Dominates(46, 59)); EXPECT_TRUE(analysis->Dominates(46, 58)); EXPECT_TRUE(analysis->Dominates(46, 60)); EXPECT_TRUE(analysis->Dominates(46, 48)); EXPECT_TRUE(analysis->Dominates(46, 73)); EXPECT_TRUE(analysis->Dominates(46, 77)); EXPECT_TRUE(analysis->Dominates(46, 75)); EXPECT_TRUE(analysis->Dominates(46, 106)); EXPECT_TRUE(analysis->Dominates(46, 110)); EXPECT_TRUE(analysis->Dominates(46, 107)); EXPECT_TRUE(analysis->Dominates(46, 108)); EXPECT_TRUE(analysis->Dominates(46, 109)); EXPECT_TRUE(analysis->Dominates(46, 74)); EXPECT_TRUE(analysis->Dominates(46, 86)); EXPECT_TRUE(analysis->Dominates(46, 90)); EXPECT_TRUE(analysis->Dominates(46, 87)); EXPECT_TRUE(analysis->Dominates(46, 94)); EXPECT_TRUE(analysis->Dominates(46, 98)); EXPECT_TRUE(analysis->Dominates(46, 95)); EXPECT_TRUE(analysis->Dominates(46, 97)); EXPECT_TRUE(analysis->Dominates(46, 96)); EXPECT_TRUE(analysis->Dominates(46, 88)); EXPECT_TRUE(analysis->Dominates(46, 76)); EXPECT_TRUE(analysis->Dominates(50, 47)); EXPECT_TRUE(analysis->Dominates(50, 57)); EXPECT_TRUE(analysis->Dominates(50, 61)); EXPECT_TRUE(analysis->Dominates(50, 59)); EXPECT_TRUE(analysis->Dominates(50, 58)); EXPECT_TRUE(analysis->Dominates(50, 60)); EXPECT_TRUE(analysis->Dominates(47, 57)); EXPECT_TRUE(analysis->Dominates(47, 61)); EXPECT_TRUE(analysis->Dominates(47, 59)); EXPECT_TRUE(analysis->Dominates(47, 58)); EXPECT_TRUE(analysis->Dominates(47, 60)); EXPECT_TRUE(analysis->Dominates(57, 61)); EXPECT_TRUE(analysis->Dominates(57, 59)); EXPECT_TRUE(analysis->Dominates(57, 58)); EXPECT_TRUE(analysis->Dominates(57, 60)); EXPECT_TRUE(analysis->Dominates(61, 59)); EXPECT_TRUE(analysis->Dominates(48, 73)); EXPECT_TRUE(analysis->Dominates(48, 77)); EXPECT_TRUE(analysis->Dominates(48, 75)); EXPECT_TRUE(analysis->Dominates(48, 106)); EXPECT_TRUE(analysis->Dominates(48, 110)); EXPECT_TRUE(analysis->Dominates(48, 107)); EXPECT_TRUE(analysis->Dominates(48, 108)); EXPECT_TRUE(analysis->Dominates(48, 109)); EXPECT_TRUE(analysis->Dominates(48, 74)); EXPECT_TRUE(analysis->Dominates(48, 86)); EXPECT_TRUE(analysis->Dominates(48, 90)); EXPECT_TRUE(analysis->Dominates(48, 87)); EXPECT_TRUE(analysis->Dominates(48, 94)); EXPECT_TRUE(analysis->Dominates(48, 98)); EXPECT_TRUE(analysis->Dominates(48, 95)); EXPECT_TRUE(analysis->Dominates(48, 97)); EXPECT_TRUE(analysis->Dominates(48, 96)); EXPECT_TRUE(analysis->Dominates(48, 88)); EXPECT_TRUE(analysis->Dominates(48, 76)); EXPECT_TRUE(analysis->Dominates(73, 77)); EXPECT_TRUE(analysis->Dominates(73, 75)); EXPECT_TRUE(analysis->Dominates(73, 106)); EXPECT_TRUE(analysis->Dominates(73, 110)); EXPECT_TRUE(analysis->Dominates(73, 107)); EXPECT_TRUE(analysis->Dominates(73, 108)); EXPECT_TRUE(analysis->Dominates(73, 109)); EXPECT_TRUE(analysis->Dominates(73, 74)); EXPECT_TRUE(analysis->Dominates(73, 86)); EXPECT_TRUE(analysis->Dominates(73, 90)); EXPECT_TRUE(analysis->Dominates(73, 87)); EXPECT_TRUE(analysis->Dominates(73, 94)); EXPECT_TRUE(analysis->Dominates(73, 98)); EXPECT_TRUE(analysis->Dominates(73, 95)); EXPECT_TRUE(analysis->Dominates(73, 97)); EXPECT_TRUE(analysis->Dominates(73, 96)); EXPECT_TRUE(analysis->Dominates(73, 88)); EXPECT_TRUE(analysis->Dominates(73, 76)); EXPECT_TRUE(analysis->Dominates(75, 106)); EXPECT_TRUE(analysis->Dominates(75, 110)); EXPECT_TRUE(analysis->Dominates(75, 107)); EXPECT_TRUE(analysis->Dominates(75, 108)); EXPECT_TRUE(analysis->Dominates(75, 109)); EXPECT_TRUE(analysis->Dominates(106, 110)); EXPECT_TRUE(analysis->Dominates(106, 107)); EXPECT_TRUE(analysis->Dominates(106, 108)); EXPECT_TRUE(analysis->Dominates(106, 109)); EXPECT_TRUE(analysis->Dominates(110, 107)); EXPECT_TRUE(analysis->Dominates(77, 74)); EXPECT_TRUE(analysis->Dominates(77, 86)); EXPECT_TRUE(analysis->Dominates(77, 90)); EXPECT_TRUE(analysis->Dominates(77, 87)); EXPECT_TRUE(analysis->Dominates(77, 94)); EXPECT_TRUE(analysis->Dominates(77, 98)); EXPECT_TRUE(analysis->Dominates(77, 95)); EXPECT_TRUE(analysis->Dominates(77, 97)); EXPECT_TRUE(analysis->Dominates(77, 96)); EXPECT_TRUE(analysis->Dominates(77, 88)); EXPECT_TRUE(analysis->Dominates(74, 86)); EXPECT_TRUE(analysis->Dominates(74, 90)); EXPECT_TRUE(analysis->Dominates(74, 87)); EXPECT_TRUE(analysis->Dominates(74, 94)); EXPECT_TRUE(analysis->Dominates(74, 98)); EXPECT_TRUE(analysis->Dominates(74, 95)); EXPECT_TRUE(analysis->Dominates(74, 97)); EXPECT_TRUE(analysis->Dominates(74, 96)); EXPECT_TRUE(analysis->Dominates(74, 88)); EXPECT_TRUE(analysis->Dominates(86, 90)); EXPECT_TRUE(analysis->Dominates(86, 87)); EXPECT_TRUE(analysis->Dominates(86, 94)); EXPECT_TRUE(analysis->Dominates(86, 98)); EXPECT_TRUE(analysis->Dominates(86, 95)); EXPECT_TRUE(analysis->Dominates(86, 97)); EXPECT_TRUE(analysis->Dominates(86, 96)); EXPECT_TRUE(analysis->Dominates(86, 88)); EXPECT_TRUE(analysis->Dominates(90, 87)); EXPECT_TRUE(analysis->Dominates(90, 94)); EXPECT_TRUE(analysis->Dominates(90, 98)); EXPECT_TRUE(analysis->Dominates(90, 95)); EXPECT_TRUE(analysis->Dominates(90, 97)); EXPECT_TRUE(analysis->Dominates(90, 96)); EXPECT_TRUE(analysis->Dominates(87, 94)); EXPECT_TRUE(analysis->Dominates(87, 98)); EXPECT_TRUE(analysis->Dominates(87, 95)); EXPECT_TRUE(analysis->Dominates(87, 97)); EXPECT_TRUE(analysis->Dominates(87, 96)); EXPECT_TRUE(analysis->Dominates(94, 98)); EXPECT_TRUE(analysis->Dominates(94, 95)); EXPECT_TRUE(analysis->Dominates(94, 97)); EXPECT_TRUE(analysis->Dominates(94, 96)); EXPECT_TRUE(analysis->Dominates(98, 95)); EXPECT_TRUE(analysis->StrictlyDominates(5, 10)); EXPECT_TRUE(analysis->StrictlyDominates(5, 14)); EXPECT_TRUE(analysis->StrictlyDominates(5, 11)); EXPECT_TRUE(analysis->StrictlyDominates(5, 29)); EXPECT_TRUE(analysis->StrictlyDominates(5, 33)); EXPECT_TRUE(analysis->StrictlyDominates(5, 30)); EXPECT_TRUE(analysis->StrictlyDominates(5, 32)); EXPECT_TRUE(analysis->StrictlyDominates(5, 31)); EXPECT_TRUE(analysis->StrictlyDominates(5, 13)); EXPECT_TRUE(analysis->StrictlyDominates(5, 12)); EXPECT_TRUE(analysis->StrictlyDominates(5, 46)); EXPECT_TRUE(analysis->StrictlyDominates(5, 50)); EXPECT_TRUE(analysis->StrictlyDominates(5, 47)); EXPECT_TRUE(analysis->StrictlyDominates(5, 57)); EXPECT_TRUE(analysis->StrictlyDominates(5, 61)); EXPECT_TRUE(analysis->StrictlyDominates(5, 59)); EXPECT_TRUE(analysis->StrictlyDominates(5, 58)); EXPECT_TRUE(analysis->StrictlyDominates(5, 60)); EXPECT_TRUE(analysis->StrictlyDominates(5, 48)); EXPECT_TRUE(analysis->StrictlyDominates(5, 73)); EXPECT_TRUE(analysis->StrictlyDominates(5, 77)); EXPECT_TRUE(analysis->StrictlyDominates(5, 75)); EXPECT_TRUE(analysis->StrictlyDominates(5, 106)); EXPECT_TRUE(analysis->StrictlyDominates(5, 110)); EXPECT_TRUE(analysis->StrictlyDominates(5, 107)); EXPECT_TRUE(analysis->StrictlyDominates(5, 108)); EXPECT_TRUE(analysis->StrictlyDominates(5, 109)); EXPECT_TRUE(analysis->StrictlyDominates(5, 74)); EXPECT_TRUE(analysis->StrictlyDominates(5, 86)); EXPECT_TRUE(analysis->StrictlyDominates(5, 90)); EXPECT_TRUE(analysis->StrictlyDominates(5, 87)); EXPECT_TRUE(analysis->StrictlyDominates(5, 94)); EXPECT_TRUE(analysis->StrictlyDominates(5, 98)); EXPECT_TRUE(analysis->StrictlyDominates(5, 95)); EXPECT_TRUE(analysis->StrictlyDominates(5, 97)); EXPECT_TRUE(analysis->StrictlyDominates(5, 96)); EXPECT_TRUE(analysis->StrictlyDominates(5, 88)); EXPECT_TRUE(analysis->StrictlyDominates(5, 76)); EXPECT_TRUE(analysis->StrictlyDominates(10, 14)); EXPECT_TRUE(analysis->StrictlyDominates(10, 11)); EXPECT_TRUE(analysis->StrictlyDominates(10, 29)); EXPECT_TRUE(analysis->StrictlyDominates(10, 33)); EXPECT_TRUE(analysis->StrictlyDominates(10, 30)); EXPECT_TRUE(analysis->StrictlyDominates(10, 32)); EXPECT_TRUE(analysis->StrictlyDominates(10, 31)); EXPECT_TRUE(analysis->StrictlyDominates(10, 13)); EXPECT_TRUE(analysis->StrictlyDominates(10, 12)); EXPECT_TRUE(analysis->StrictlyDominates(10, 46)); EXPECT_TRUE(analysis->StrictlyDominates(10, 50)); EXPECT_TRUE(analysis->StrictlyDominates(10, 47)); EXPECT_TRUE(analysis->StrictlyDominates(10, 57)); EXPECT_TRUE(analysis->StrictlyDominates(10, 61)); EXPECT_TRUE(analysis->StrictlyDominates(10, 59)); EXPECT_TRUE(analysis->StrictlyDominates(10, 58)); EXPECT_TRUE(analysis->StrictlyDominates(10, 60)); EXPECT_TRUE(analysis->StrictlyDominates(10, 48)); EXPECT_TRUE(analysis->StrictlyDominates(10, 73)); EXPECT_TRUE(analysis->StrictlyDominates(10, 77)); EXPECT_TRUE(analysis->StrictlyDominates(10, 75)); EXPECT_TRUE(analysis->StrictlyDominates(10, 106)); EXPECT_TRUE(analysis->StrictlyDominates(10, 110)); EXPECT_TRUE(analysis->StrictlyDominates(10, 107)); EXPECT_TRUE(analysis->StrictlyDominates(10, 108)); EXPECT_TRUE(analysis->StrictlyDominates(10, 109)); EXPECT_TRUE(analysis->StrictlyDominates(10, 74)); EXPECT_TRUE(analysis->StrictlyDominates(10, 86)); EXPECT_TRUE(analysis->StrictlyDominates(10, 90)); EXPECT_TRUE(analysis->StrictlyDominates(10, 87)); EXPECT_TRUE(analysis->StrictlyDominates(10, 94)); EXPECT_TRUE(analysis->StrictlyDominates(10, 98)); EXPECT_TRUE(analysis->StrictlyDominates(10, 95)); EXPECT_TRUE(analysis->StrictlyDominates(10, 97)); EXPECT_TRUE(analysis->StrictlyDominates(10, 96)); EXPECT_TRUE(analysis->StrictlyDominates(10, 88)); EXPECT_TRUE(analysis->StrictlyDominates(10, 76)); EXPECT_TRUE(analysis->StrictlyDominates(14, 11)); EXPECT_TRUE(analysis->StrictlyDominates(14, 29)); EXPECT_TRUE(analysis->StrictlyDominates(14, 33)); EXPECT_TRUE(analysis->StrictlyDominates(14, 30)); EXPECT_TRUE(analysis->StrictlyDominates(14, 32)); EXPECT_TRUE(analysis->StrictlyDominates(14, 31)); EXPECT_TRUE(analysis->StrictlyDominates(11, 29)); EXPECT_TRUE(analysis->StrictlyDominates(11, 33)); EXPECT_TRUE(analysis->StrictlyDominates(11, 30)); EXPECT_TRUE(analysis->StrictlyDominates(11, 32)); EXPECT_TRUE(analysis->StrictlyDominates(11, 31)); EXPECT_TRUE(analysis->StrictlyDominates(29, 33)); EXPECT_TRUE(analysis->StrictlyDominates(29, 30)); EXPECT_TRUE(analysis->StrictlyDominates(29, 32)); EXPECT_TRUE(analysis->StrictlyDominates(29, 31)); EXPECT_TRUE(analysis->StrictlyDominates(33, 30)); EXPECT_TRUE(analysis->StrictlyDominates(12, 46)); EXPECT_TRUE(analysis->StrictlyDominates(12, 50)); EXPECT_TRUE(analysis->StrictlyDominates(12, 47)); EXPECT_TRUE(analysis->StrictlyDominates(12, 57)); EXPECT_TRUE(analysis->StrictlyDominates(12, 61)); EXPECT_TRUE(analysis->StrictlyDominates(12, 59)); EXPECT_TRUE(analysis->StrictlyDominates(12, 58)); EXPECT_TRUE(analysis->StrictlyDominates(12, 60)); EXPECT_TRUE(analysis->StrictlyDominates(12, 48)); EXPECT_TRUE(analysis->StrictlyDominates(12, 73)); EXPECT_TRUE(analysis->StrictlyDominates(12, 77)); EXPECT_TRUE(analysis->StrictlyDominates(12, 75)); EXPECT_TRUE(analysis->StrictlyDominates(12, 106)); EXPECT_TRUE(analysis->StrictlyDominates(12, 110)); EXPECT_TRUE(analysis->StrictlyDominates(12, 107)); EXPECT_TRUE(analysis->StrictlyDominates(12, 108)); EXPECT_TRUE(analysis->StrictlyDominates(12, 109)); EXPECT_TRUE(analysis->StrictlyDominates(12, 74)); EXPECT_TRUE(analysis->StrictlyDominates(12, 86)); EXPECT_TRUE(analysis->StrictlyDominates(12, 90)); EXPECT_TRUE(analysis->StrictlyDominates(12, 87)); EXPECT_TRUE(analysis->StrictlyDominates(12, 94)); EXPECT_TRUE(analysis->StrictlyDominates(12, 98)); EXPECT_TRUE(analysis->StrictlyDominates(12, 95)); EXPECT_TRUE(analysis->StrictlyDominates(12, 97)); EXPECT_TRUE(analysis->StrictlyDominates(12, 96)); EXPECT_TRUE(analysis->StrictlyDominates(12, 88)); EXPECT_TRUE(analysis->StrictlyDominates(12, 76)); EXPECT_TRUE(analysis->StrictlyDominates(46, 50)); EXPECT_TRUE(analysis->StrictlyDominates(46, 47)); EXPECT_TRUE(analysis->StrictlyDominates(46, 57)); EXPECT_TRUE(analysis->StrictlyDominates(46, 61)); EXPECT_TRUE(analysis->StrictlyDominates(46, 59)); EXPECT_TRUE(analysis->StrictlyDominates(46, 58)); EXPECT_TRUE(analysis->StrictlyDominates(46, 60)); EXPECT_TRUE(analysis->StrictlyDominates(46, 48)); EXPECT_TRUE(analysis->StrictlyDominates(46, 73)); EXPECT_TRUE(analysis->StrictlyDominates(46, 77)); EXPECT_TRUE(analysis->StrictlyDominates(46, 75)); EXPECT_TRUE(analysis->StrictlyDominates(46, 106)); EXPECT_TRUE(analysis->StrictlyDominates(46, 110)); EXPECT_TRUE(analysis->StrictlyDominates(46, 107)); EXPECT_TRUE(analysis->StrictlyDominates(46, 108)); EXPECT_TRUE(analysis->StrictlyDominates(46, 109)); EXPECT_TRUE(analysis->StrictlyDominates(46, 74)); EXPECT_TRUE(analysis->StrictlyDominates(46, 86)); EXPECT_TRUE(analysis->StrictlyDominates(46, 90)); EXPECT_TRUE(analysis->StrictlyDominates(46, 87)); EXPECT_TRUE(analysis->StrictlyDominates(46, 94)); EXPECT_TRUE(analysis->StrictlyDominates(46, 98)); EXPECT_TRUE(analysis->StrictlyDominates(46, 95)); EXPECT_TRUE(analysis->StrictlyDominates(46, 97)); EXPECT_TRUE(analysis->StrictlyDominates(46, 96)); EXPECT_TRUE(analysis->StrictlyDominates(46, 88)); EXPECT_TRUE(analysis->StrictlyDominates(46, 76)); EXPECT_TRUE(analysis->StrictlyDominates(50, 47)); EXPECT_TRUE(analysis->StrictlyDominates(50, 57)); EXPECT_TRUE(analysis->StrictlyDominates(50, 61)); EXPECT_TRUE(analysis->StrictlyDominates(50, 59)); EXPECT_TRUE(analysis->StrictlyDominates(50, 58)); EXPECT_TRUE(analysis->StrictlyDominates(50, 60)); EXPECT_TRUE(analysis->StrictlyDominates(47, 57)); EXPECT_TRUE(analysis->StrictlyDominates(47, 61)); EXPECT_TRUE(analysis->StrictlyDominates(47, 59)); EXPECT_TRUE(analysis->StrictlyDominates(47, 58)); EXPECT_TRUE(analysis->StrictlyDominates(47, 60)); EXPECT_TRUE(analysis->StrictlyDominates(57, 61)); EXPECT_TRUE(analysis->StrictlyDominates(57, 59)); EXPECT_TRUE(analysis->StrictlyDominates(57, 58)); EXPECT_TRUE(analysis->StrictlyDominates(57, 60)); EXPECT_TRUE(analysis->StrictlyDominates(61, 59)); EXPECT_TRUE(analysis->StrictlyDominates(48, 73)); EXPECT_TRUE(analysis->StrictlyDominates(48, 77)); EXPECT_TRUE(analysis->StrictlyDominates(48, 75)); EXPECT_TRUE(analysis->StrictlyDominates(48, 106)); EXPECT_TRUE(analysis->StrictlyDominates(48, 110)); EXPECT_TRUE(analysis->StrictlyDominates(48, 107)); EXPECT_TRUE(analysis->StrictlyDominates(48, 108)); EXPECT_TRUE(analysis->StrictlyDominates(48, 109)); EXPECT_TRUE(analysis->StrictlyDominates(48, 74)); EXPECT_TRUE(analysis->StrictlyDominates(48, 86)); EXPECT_TRUE(analysis->StrictlyDominates(48, 90)); EXPECT_TRUE(analysis->StrictlyDominates(48, 87)); EXPECT_TRUE(analysis->StrictlyDominates(48, 94)); EXPECT_TRUE(analysis->StrictlyDominates(48, 98)); EXPECT_TRUE(analysis->StrictlyDominates(48, 95)); EXPECT_TRUE(analysis->StrictlyDominates(48, 97)); EXPECT_TRUE(analysis->StrictlyDominates(48, 96)); EXPECT_TRUE(analysis->StrictlyDominates(48, 88)); EXPECT_TRUE(analysis->StrictlyDominates(48, 76)); EXPECT_TRUE(analysis->StrictlyDominates(73, 77)); EXPECT_TRUE(analysis->StrictlyDominates(73, 75)); EXPECT_TRUE(analysis->StrictlyDominates(73, 106)); EXPECT_TRUE(analysis->StrictlyDominates(73, 110)); EXPECT_TRUE(analysis->StrictlyDominates(73, 107)); EXPECT_TRUE(analysis->StrictlyDominates(73, 108)); EXPECT_TRUE(analysis->StrictlyDominates(73, 109)); EXPECT_TRUE(analysis->StrictlyDominates(73, 74)); EXPECT_TRUE(analysis->StrictlyDominates(73, 86)); EXPECT_TRUE(analysis->StrictlyDominates(73, 90)); EXPECT_TRUE(analysis->StrictlyDominates(73, 87)); EXPECT_TRUE(analysis->StrictlyDominates(73, 94)); EXPECT_TRUE(analysis->StrictlyDominates(73, 98)); EXPECT_TRUE(analysis->StrictlyDominates(73, 95)); EXPECT_TRUE(analysis->StrictlyDominates(73, 97)); EXPECT_TRUE(analysis->StrictlyDominates(73, 96)); EXPECT_TRUE(analysis->StrictlyDominates(73, 88)); EXPECT_TRUE(analysis->StrictlyDominates(73, 76)); EXPECT_TRUE(analysis->StrictlyDominates(75, 106)); EXPECT_TRUE(analysis->StrictlyDominates(75, 110)); EXPECT_TRUE(analysis->StrictlyDominates(75, 107)); EXPECT_TRUE(analysis->StrictlyDominates(75, 108)); EXPECT_TRUE(analysis->StrictlyDominates(75, 109)); EXPECT_TRUE(analysis->StrictlyDominates(106, 110)); EXPECT_TRUE(analysis->StrictlyDominates(106, 107)); EXPECT_TRUE(analysis->StrictlyDominates(106, 108)); EXPECT_TRUE(analysis->StrictlyDominates(106, 109)); EXPECT_TRUE(analysis->StrictlyDominates(110, 107)); EXPECT_TRUE(analysis->StrictlyDominates(77, 74)); EXPECT_TRUE(analysis->StrictlyDominates(77, 86)); EXPECT_TRUE(analysis->StrictlyDominates(77, 90)); EXPECT_TRUE(analysis->StrictlyDominates(77, 87)); EXPECT_TRUE(analysis->StrictlyDominates(77, 94)); EXPECT_TRUE(analysis->StrictlyDominates(77, 98)); EXPECT_TRUE(analysis->StrictlyDominates(77, 95)); EXPECT_TRUE(analysis->StrictlyDominates(77, 97)); EXPECT_TRUE(analysis->StrictlyDominates(77, 96)); EXPECT_TRUE(analysis->StrictlyDominates(77, 88)); EXPECT_TRUE(analysis->StrictlyDominates(74, 86)); EXPECT_TRUE(analysis->StrictlyDominates(74, 90)); EXPECT_TRUE(analysis->StrictlyDominates(74, 87)); EXPECT_TRUE(analysis->StrictlyDominates(74, 94)); EXPECT_TRUE(analysis->StrictlyDominates(74, 98)); EXPECT_TRUE(analysis->StrictlyDominates(74, 95)); EXPECT_TRUE(analysis->StrictlyDominates(74, 97)); EXPECT_TRUE(analysis->StrictlyDominates(74, 96)); EXPECT_TRUE(analysis->StrictlyDominates(74, 88)); EXPECT_TRUE(analysis->StrictlyDominates(86, 90)); EXPECT_TRUE(analysis->StrictlyDominates(86, 87)); EXPECT_TRUE(analysis->StrictlyDominates(86, 94)); EXPECT_TRUE(analysis->StrictlyDominates(86, 98)); EXPECT_TRUE(analysis->StrictlyDominates(86, 95)); EXPECT_TRUE(analysis->StrictlyDominates(86, 97)); EXPECT_TRUE(analysis->StrictlyDominates(86, 96)); EXPECT_TRUE(analysis->StrictlyDominates(86, 88)); EXPECT_TRUE(analysis->StrictlyDominates(90, 87)); EXPECT_TRUE(analysis->StrictlyDominates(90, 94)); EXPECT_TRUE(analysis->StrictlyDominates(90, 98)); EXPECT_TRUE(analysis->StrictlyDominates(90, 95)); EXPECT_TRUE(analysis->StrictlyDominates(90, 97)); EXPECT_TRUE(analysis->StrictlyDominates(90, 96)); EXPECT_TRUE(analysis->StrictlyDominates(87, 94)); EXPECT_TRUE(analysis->StrictlyDominates(87, 98)); EXPECT_TRUE(analysis->StrictlyDominates(87, 95)); EXPECT_TRUE(analysis->StrictlyDominates(87, 97)); EXPECT_TRUE(analysis->StrictlyDominates(87, 96)); EXPECT_TRUE(analysis->StrictlyDominates(94, 98)); EXPECT_TRUE(analysis->StrictlyDominates(94, 95)); EXPECT_TRUE(analysis->StrictlyDominates(94, 97)); EXPECT_TRUE(analysis->StrictlyDominates(94, 96)); EXPECT_TRUE(analysis->StrictlyDominates(98, 95)); } } // namespace } // namespace opt } // namespace spvtools