fix(python): register hlfhelinalg dialect

This commit is contained in:
youben11
2021-11-03 09:58:23 +01:00
committed by Ayoub Benaissa
parent 5999d402ec
commit 97ee8134ed
10 changed files with 93 additions and 11 deletions

View File

@@ -0,0 +1,19 @@
#ifndef ZAMALANG_C_DIALECT_HLFHELINALG_H
#define ZAMALANG_C_DIALECT_HLFHELINALG_H
#include "mlir-c/IR.h"
#include "mlir-c/Registration.h"
#include "mlir/IR/Diagnostics.h"
#include "mlir/Support/LLVM.h"
#ifdef __cplusplus
extern "C" {
#endif
MLIR_DECLARE_CAPI_DIALECT_REGISTRATION(HLFHELinalg, hlfhelinalg);
#ifdef __cplusplus
}
#endif
#endif // ZAMALANG_C_DIALECT_HLFHELINALG_H

View File

@@ -15,6 +15,7 @@ declare_mlir_python_extension(ZamalangBindingsPythonExtension.Core
CompilerAPIModule.cpp
EMBED_CAPI_LINK_LIBS
ZAMALANGCAPIHLFHE
ZAMALANGCAPIHLFHELINALG
ZAMALANGCAPISupport
)

View File

@@ -5,6 +5,7 @@
#include "mlir-c/Registration.h"
#include "mlir/Bindings/Python/PybindAdaptors.h"
#include "zamalang-c/Dialect/HLFHE.h"
#include "zamalang-c/Dialect/HLFHELinalg.h"
#include "llvm-c/ErrorHandling.h"
#include "llvm/Support/Signals.h"
@@ -28,6 +29,9 @@ PYBIND11_MODULE(_zamalang, m) {
MlirDialectHandle hlfhe = mlirGetDialectHandle__hlfhe__();
mlirDialectHandleRegisterDialect(hlfhe, context);
mlirDialectHandleLoadDialect(hlfhe, context);
MlirDialectHandle hlfhelinalg = mlirGetDialectHandle__hlfhelinalg__();
mlirDialectHandleRegisterDialect(hlfhelinalg, context);
mlirDialectHandleLoadDialect(hlfhelinalg, context);
},
"Register Zamalang dialects on a PyMlirContext.");

View File

@@ -1,10 +1,2 @@
set(LLVM_OPTIONAL_SOURCES HLFHE.cpp)
add_mlir_public_c_api_library(ZAMALANGCAPIHLFHE
HLFHE.cpp
LINK_LIBS PUBLIC
MLIRCAPIIR
HLFHEDialect
)
add_subdirectory(HLFHE)
add_subdirectory(HLFHELinalg)

View File

@@ -0,0 +1,10 @@
set(LLVM_OPTIONAL_SOURCES HLFHE.cpp)
add_mlir_public_c_api_library(ZAMALANGCAPIHLFHE
HLFHE.cpp
LINK_LIBS PUBLIC
MLIRCAPIIR
HLFHEDialect
)

View File

@@ -0,0 +1,10 @@
set(LLVM_OPTIONAL_SOURCES HLFHELinalg.cpp)
add_mlir_public_c_api_library(ZAMALANGCAPIHLFHELINALG
HLFHELinalg.cpp
LINK_LIBS PUBLIC
MLIRCAPIIR
HLFHELinalgDialect
)

View File

@@ -0,0 +1,16 @@
#include "zamalang-c/Dialect/HLFHELinalg.h"
#include "mlir/CAPI/IR.h"
#include "mlir/CAPI/Registration.h"
#include "mlir/CAPI/Support.h"
#include "zamalang/Dialect/HLFHELinalg/IR/HLFHELinalgDialect.h"
#include "zamalang/Dialect/HLFHELinalg/IR/HLFHELinalgOps.h"
#include "zamalang/Dialect/HLFHELinalg/IR/HLFHELinalgTypes.h"
using namespace mlir::zamalang::HLFHELinalg;
//===----------------------------------------------------------------------===//
// Dialect API.
//===----------------------------------------------------------------------===//
MLIR_DEFINE_CAPI_DIALECT_REGISTRATION(HLFHELinalg, hlfhelinalg,
HLFHELinalgDialect)

View File

@@ -1,5 +1,5 @@
import pytest
from mlir.ir import Context
from mlir.ir import Context, RankedTensorType, Location
from zamalang import register_dialects
from zamalang.dialects import hlfhe
@@ -12,6 +12,17 @@ def test_eint(width):
assert eint.__str__() == f"!HLFHE.eint<{width}>"
@pytest.mark.parametrize("shape", [(1,), (2,), (1, 1), (1, 2), (2, 1), (3, 3, 3)])
def test_eint_tensor(shape):
with Context() as ctx, Location.unknown(context=ctx):
register_dialects(ctx)
eint = hlfhe.EncryptedIntegerType.get(ctx, 3)
tensor = RankedTensorType.get(shape, eint)
assert (
tensor.__str__() == f"tensor<{'x'.join(map(str, shape))}x!HLFHE.eint<{3}>>"
)
@pytest.mark.parametrize("width", [0, 8, 10, 12])
def test_invalid_eint(width):
ctx = Context()

View File

@@ -44,6 +44,15 @@ VALID_INPUTS = [
""",
id="add_eint_int_cst",
),
pytest.param(
"""
func @main(%a0: tensor<4x!HLFHE.eint<2>>, %a1: tensor<4xi3>) -> tensor<4x!HLFHE.eint<2>> {
%1 = "HLFHELinalg.add_eint_int"(%a0, %a1) : (tensor<4x!HLFHE.eint<2>>, tensor<4xi3>) -> tensor<4x!HLFHE.eint<2>>
return %1: tensor<4x!HLFHE.eint<2>>
}
""",
id="add_eint_int_1D",
),
]
INVALID_INPUTS = [
@@ -56,6 +65,16 @@ INVALID_INPUTS = [
""",
id="eint<0>",
),
pytest.param(
"""
func @main(%a0: tensor<2x2x3x4x!HLFHE.eint<2>>, %a1: tensor<2x2x2x4xi3>) -> tensor<2x2x3x4x!HLFHE.eint<2>> {
// expected-error @+1 {{'HLFHELinalg.add_eint_int' op has the dimension #2 of the operand #1 incompatible with other operands, got 2 expect 1 or 3}}
%1 = "HLFHELinalg.add_eint_int"(%a0, %a1) : (tensor<2x2x3x4x!HLFHE.eint<2>>, tensor<2x2x2x4xi3>) -> tensor<2x2x3x4x!HLFHE.eint<2>>
return %1 : tensor<2x2x3x4x!HLFHE.eint<2>>
}
""",
id="incompatible dimensions",
),
]