C# 随机数生成 Mersenne Twister 马特赛特旋转演算法 梅森旋转算法

NuGet安装MathNet.Numerics

引用:

using MathNet.Numerics.Random;

csharp 复制代码
        /// <summary>
        /// 包括lower,不包括upper
        /// </summary>
        /// <param name="lower"></param>
        /// <param name="upper"></param>
        /// <param name="randomResult"></param>
        public static void GetRandom(int lower,int upper,out int randomResult)
        {
            var random = new MersenneTwister(RandomSeed.Robust()); 
            randomResult= random.Next(lower, upper);
        }

Mersenne Twister算法是一种伪随机数发生器,名字来源于其周期长度通常取自Mersenne质数。它是由Makoto Matsumoto(松本)和Takuji Nishimura(西村)于1997年开发的,基于有限二进制字段上的矩阵线性再生。它的主要作用是生成伪随机数,并修正了古老随机数生成算法的许多缺陷。

Mersenne Twister算法利用线性反馈移位寄存器(LFSR)生成随机数。这个寄存器的反馈函数是某些位的简单异或,这些位也被称为抽头序列。一个n位的LFSR能在重复之前产生2n-1位长的伪随机序列。只有具有特定抽头序列的LFSR才能通过所有2n-1个内部状态,产生2^n-1位长的伪随机序列,这个输出序列就称为m序列。为了使LFSR成为最大周期的LFSR,由抽头序列加上常数1形成的多项式必须是本原多项式。

Mersenne Twister算法具有一些显著的优点。它生成的随机数质量好,随机性高,可以在计算机上容易实现,占用内存较少。与其他已使用的伪随机数发生器相比,它的运行速度更快,周期更长,可以达到2^19937-1,并且具有623维均匀分布的性质。对于一般的应用来说,这个周期长度已经足够了。此外,它的序列关联较小,能通过很多随机性测试。在计算机科学和工程领域,Mersenne Twister算法被广泛用于需要产生随机数的情况。

相关推荐
CoovallyAIHub9 小时前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉
CoovallyAIHub9 小时前
CVPR 2026 | GS-CLIP:3D几何先验+双流视觉融合,零样本工业缺陷检测新SOTA,四大3D工业数据集全面领先!
深度学习·算法·计算机视觉
有意义11 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户7268761033713 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect13 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
唐青枫15 小时前
C#.NET Channel 深入解析:高性能异步生产者消费者模型实战
c#·.net
小峥降临1 天前
Rokid UXR 的手势追踪虚拟中更真实的手实战开发【含 工程源码 和 最终完成APK】
c#
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 天前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研