seal_fhe 0.8.1

This crate contains Rust bindings for Microsoft's SEAL Fully Homomorphic Encryption (FHE) library.
Documentation
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT license.

#pragma once

#include "seal/util/defines.h"
#include <cmath>
#include <random>

namespace seal
{
    namespace util
    {
        class ClippedNormalDistribution
        {
        public:
            using result_type = double;

            using param_type = ClippedNormalDistribution;

            ClippedNormalDistribution(result_type mean, result_type standard_deviation, result_type max_deviation);

            template <typename RNG>
            SEAL_NODISCARD inline result_type operator()(RNG &engine, const param_type &parm) noexcept
            {
                param(parm);
                return operator()(engine);
            }

            template <typename RNG>
            SEAL_NODISCARD inline result_type operator()(RNG &engine) noexcept
            {
                result_type mean = normal_.mean();
                while (true)
                {
                    result_type value = normal_(engine);
                    result_type deviation = std::abs(value - mean);
                    if (deviation <= max_deviation_)
                    {
                        return value;
                    }
                }
            }

            SEAL_NODISCARD inline result_type mean() const noexcept
            {
                return normal_.mean();
            }

            SEAL_NODISCARD inline result_type standard_deviation() const noexcept
            {
                return normal_.stddev();
            }

            SEAL_NODISCARD inline result_type max_deviation() const noexcept
            {
                return max_deviation_;
            }

            SEAL_NODISCARD inline result_type min() const noexcept
            {
                return normal_.mean() - max_deviation_;
            }

            SEAL_NODISCARD inline result_type max() const noexcept
            {
                return normal_.mean() + max_deviation_;
            }

            SEAL_NODISCARD inline param_type param() const noexcept
            {
                return *this;
            }

            inline void param(const param_type &parm) noexcept
            {
                *this = parm;
            }

            inline void reset() noexcept
            {
                normal_.reset();
            }

        private:
            std::normal_distribution<result_type> normal_;

            result_type max_deviation_;
        };
    } // namespace util
} // namespace seal