Skip to content

Commit

Permalink
Fix histogram bug in libpymo (#3733)
Browse files Browse the repository at this point in the history
Signed-off-by: Kyunggeun Lee <[email protected]>
  • Loading branch information
quic-kyunggeu authored Jan 15, 2025
1 parent ec09a37 commit 6f4f408
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 3 deletions.
2 changes: 1 addition & 1 deletion ModelOptimizations/DlQuantization/src/math_functions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -391,7 +391,7 @@ void GetHistogram_cpu(const DTYPE* data, int cnt, uint32_t histogram[PDF_SIZE],
{
// Map a floating point number to the appropriate bucket.
int index =
is_signed ? round(data[i] / bucket_size - pdf_offset) : round(std::abs(data[i]) / bucket_size - pdf_offset);
is_signed ? floor(data[i] / bucket_size - pdf_offset) : floor(std::abs(data[i]) / bucket_size - pdf_offset);

// Add to histogram, if inside the histogram range.
if (index >= 0 && index < PDF_SIZE)
Expand Down
4 changes: 2 additions & 2 deletions ModelOptimizations/DlQuantization/src/math_functions.cu
Original file line number Diff line number Diff line change
Expand Up @@ -174,8 +174,8 @@ __global__ static void histogramCountKernel(const DTYPE* data,
{
// Map a floating point number to the appropriate bucket.
int index = is_signed ?
round(data[i] / bucket_size - histogram_offset) :
round(abs(data[i]) / bucket_size - histogram_offset);
floor(data[i] / bucket_size - histogram_offset) :
floor(abs(data[i]) / bucket_size - histogram_offset);

// Add to histogram, if inside the histogram range.
if (index >= 0 && index < PDF_SIZE)
Expand Down
21 changes: 21 additions & 0 deletions TrainingExtensions/torch/test/python/v1/test_quantizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@
from torchvision import models

import aimet_common.libpymo as libpymo
from aimet_common.aimet_tensor_quantizer import AimetTensorQuantizer

from aimet_common.defs import QuantScheme, QuantizationDataType, MAP_ROUND_MODE_TO_PYMO
from aimet_common.quantsim_config.utils import get_path_for_per_channel_config
Expand Down Expand Up @@ -5362,3 +5363,23 @@ def forward_pass(model, args):
sim.compute_encodings(forward_pass, None)

assert sim.model.compare.output_quantizers[0].enabled == False


@pytest.mark.parametrize('device', ['cpu', 'cuda'])
def test_histogram(device):
if device == 'cuda' and not torch.cuda.is_available():
pytest.skip()

"""
libpymo histogram should produce the same histogram as torch.histc
"""
x = torch.arange(-512, 513, dtype=torch.float, device=device)

# NOTE: libpymo histogram is hard-coded to use 3x of the range of the first input
ground_truth = torch.histc(x, bins=512, min=x.min() * 3, max=x.max() * 3)

q = AimetTensorQuantizer(libpymo.QuantizationMode.QUANTIZATION_TF_ENHANCED)
q.updateStats(x, x.is_cuda)
prob = torch.tensor([prob for _, prob in q.getStatsHistogram()], device=device)

assert torch.equal(prob * 1025, ground_truth)

0 comments on commit 6f4f408

Please sign in to comment.