jjzjj

Windows系统下进行NIST测试

Mayfyi 2023-12-12 原文

1.软件安装使用

首先下载Cygwin【官网】,点击setup-x86_64.exe,然后开始安装

安装过程可以在网上找教程,比如【Cygwin安装教程】
找了很多教程,因为他们在gcc这一块的描述很含糊,且gcc组件实在众多,所以我用的是上述教程,基本上安装界面也是相同的,选定版本号后,点击下一步,就会自动安装组件了(此处建议添加make组件,如果有的话),Cygwin安装告一段落。
接着来下载NIST的源代码
NIST的官网,点击下载download

举个例子,刚刚Cygwin的安装地址,我选择的是D:/NIST/Cygwin,那么下载的压缩包:sts-2_1_2,进行解压的位置也是D:/NIST,一般这个时候,D:\NIST\sts-2.1.2\sts-2.1.2目录下有一个makefile文件,可以尝试着运行Cygwin文件,进入该文件,即cd D:/NIST/sts-2.1.2/sts-2.1.2,然后输入make。如果你make成功了,恭喜,下一个段落可以直接跳过了,如果你没有成功,请看下一个段落!
make不成功的原因,网上说是因为之前Cygwin安装组件时没有添加“make”,只要在安装时添加,即可make成功,但这个我还没有尝试,不清楚~~。我的解决办法是下载make组件,选择后缀名为.gz的最新版本"make-4.4.tar.gz",
将其解压到Cygwin目录下,我的是D:/NIST/Cygwin,然后在Cygwin控制界面,输入cd D:/NIST/Cygwin/make-4.4,进入目录后,输入第一条命令“./configure” ,然后等待,正常情况下不会报错,但是我的最后一行报错了,不过没有影响,很神奇!;然后输入第二条命令:“./build.sh ”,没有报错的话,在make-4.4目录下,你应该可以找到一个make.exe,将其移动到Cygwin的bin文件夹下(说是可以在任何路径下都使用make,但我没感觉到……)。此时,你的make应该可以成功了!遵循上个段落的方法,试一下吧!
如果你的
make成功
后,你可以在sts-2.1.2目录下找到assess.exe(我的目录是D:\NIST\sts-2.1.2\sts-2.1.2),此时说明安装成功。

2.NIST随机数测试

首先通过软件生成一个随机数txt文件,注意文件中数的之间不要有空格,文件大小应该要大于或等于1M(bits),我使用的是matlab生成0-1比特流,有1000000。如下图所示:
(这里有个小插曲,我之前保存文件在D:\NIST\sts-2.1.2\sts-2.1.2\data目录下时,Cygwin一直显示file error,但是我保存在D:\NIST\sts-2.1.2\sts-2.1.2目录下,就成功了,不理解)


第一条命令“./assess.exe 1000000”,数字显示比特流的位数
然后Enter Choice:0,接着输入txt文件的绝对地址D:/NIST/sts-2.1.2/sts-2.1.2/output.txt,
15个测试,选择一个,我选择1;Select Test ,(我不知道啥意思),选择0;How many?好像是指比特流的个数,因为我只生成了1000000个bit,上述大小已选择1000000,所以我只能填1,不然数据不够;Select Input mode:我测试的是0-1bit,选择0,Binary适合何种数据,暂时还没查。

显示Complete,表示成功,可以在D:\NIST\sts-2.1.2\sts-2.1.2\experiments\AlgorithmTesting目录下找到两个文件,测试工作告一段落,下篇博客更新得到的数据文件如何分析!

参考文献有:https://blog.csdn.net/zhaomengszu/article/details/79384050

有关Windows系统下进行NIST测试的更多相关文章

  1. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  2. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  3. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  4. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  5. ruby - Ruby 的 Hash 在比较键时使用哪种相等性测试? - 2

    我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。

  6. ruby - RSpec - 使用测试替身作为 block 参数 - 2

    我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere

  7. ruby - Sinatra:运行 rspec 测试时记录噪音 - 2

    Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/

  8. ruby - 如何进行排列以有效地定制输出 - 2

    这是一道面试题,我没有答对,但还是很好奇怎么解。你有N个人的大家庭,分别是1,2,3,...,N岁。你想给你的大家庭拍张照片。所有的家庭成员都排成一排。“我是家里的friend,建议家庭成员安排如下:”1岁的家庭成员坐在这一排的最左边。每两个坐在一起的家庭成员的年龄相差不得超过2岁。输入:整数N,1≤N≤55。输出:摄影师可以拍摄的照片数量。示例->输入:4,输出:4符合条件的数组:[1,2,3,4][1,2,4,3][1,3,2,4][1,3,4,2]另一个例子:输入:5输出:6符合条件的数组:[1,2,3,4,5][1,2,3,5,4][1,2,4,3,5][1,2,4,5,3][

  9. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  10. ruby - 即使失败也继续进行多主机测试 - 2

    我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r

随机推荐