40 lines
1.7 KiB
C++
40 lines
1.7 KiB
C++
|
//===- MatrixTest.cpp - Tests for QuasiPolynomial -------------------------===//
|
||
|
//
|
||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include "mlir/Analysis/Presburger/GeneratingFunction.h"
|
||
|
#include "./Utils.h"
|
||
|
#include <gmock/gmock.h>
|
||
|
#include <gtest/gtest.h>
|
||
|
|
||
|
using namespace mlir;
|
||
|
using namespace presburger;
|
||
|
using namespace mlir::presburger::detail;
|
||
|
|
||
|
TEST(GeneratingFunctionTest, sum) {
|
||
|
GeneratingFunction gf1(2, {1, -1},
|
||
|
{makeFracMatrix(3, 2, {{1, 2}, {5, 7}, {2, 6}}),
|
||
|
makeFracMatrix(3, 2, {{5, 2}, {5, 3}, {7, 2}})},
|
||
|
{{{3, 6}, {7, 2}}, {{2, 8}, {6, 3}}});
|
||
|
GeneratingFunction gf2(2, {1, 1},
|
||
|
{makeFracMatrix(3, 2, {{6, 2}, {1, 4}, {2, 6}}),
|
||
|
makeFracMatrix(3, 2, {{3, 2}, {6, 9}, {2, 5}})},
|
||
|
{{{3, 7}, {5, 1}}, {{5, 2}, {6, 2}}});
|
||
|
|
||
|
GeneratingFunction sum = gf1 + gf2;
|
||
|
EXPECT_EQ_REPR_GENERATINGFUNCTION(
|
||
|
sum, GeneratingFunction(2, {1, -1, 1, 1},
|
||
|
{makeFracMatrix(3, 2, {{1, 2}, {5, 7}, {2, 6}}),
|
||
|
makeFracMatrix(3, 2, {{5, 2}, {5, 3}, {7, 2}}),
|
||
|
makeFracMatrix(3, 2, {{6, 2}, {1, 4}, {2, 6}}),
|
||
|
makeFracMatrix(3, 2, {{3, 2}, {6, 9}, {2, 5}})},
|
||
|
{{{3, 6}, {7, 2}},
|
||
|
{{2, 8}, {6, 3}},
|
||
|
{{3, 7}, {5, 1}},
|
||
|
{{5, 2}, {6, 2}}}));
|
||
|
}
|