blob: 2c91bd1e2fa36d43f3f961696c49b41d77509d54 [file] [log] [blame]
// 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 <memory>
#include <vector>
#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<IRContext> 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