39 lines
1.7 KiB
C++
39 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}}}));
|
|
}
|