forked from openvinotoolkit/openvino
-
Notifications
You must be signed in to change notification settings - Fork 0
/
int4.cpp
31 lines (24 loc) · 940 Bytes
/
int4.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// Copyright (C) 2018-2024 Intel Corporation
// SPDX-License-Identifier: Apache-2.0
//
#include <gtest/gtest.h>
#include "common_test_utils/test_tools.hpp"
#include "openvino/op/constant.hpp"
#include "openvino/runtime/tensor.hpp"
using namespace ov;
using namespace std;
TEST(int4, convert_i4_to_string) {
vector<uint8_t> values{171, 16};
auto constant = make_shared<ov::op::v0::Constant>(element::i4, Shape{3}, &values[0]);
vector<string> ref{"-5", "-6", "0"};
for (size_t i = 0; i < 3; ++i) {
EXPECT_EQ(constant->convert_value_to_string(i), ref[i]);
}
}
TEST(int4, tensor_or_constant_size) {
vector<uint8_t> values{171, 16};
auto constant = make_shared<ov::op::v0::Constant>(element::i4, Shape{3}, &values[0]);
EXPECT_EQ(2, constant->get_byte_size());
ov::Tensor runtime_tensor(ov::element::i4, ov::Shape{3});
EXPECT_EQ(constant->get_byte_size(), runtime_tensor.get_byte_size());
}