搜索
bottom↓
回复: 3

上传一个用AVR的大数计算仿真实例

[复制链接]

出0入0汤圆

发表于 2010-9-18 14:42:20 | 显示全部楼层 |阅读模式
得到ourDEV论坛的帮助,上次我成功安装了Proteus 7.7 sp2,一直想发帖感谢一下不辞辛苦的大侠们。

就上传一个我刚完成的实验吧:使用MPI和BIGD任意精度整型运算库的AVR测试程序,例子中包括了全部源码和仿真文件。而这里的MPI和BIGD是我分别从网上下载的两个大数运算库,虽然都适合实现一些数据加密的算法,但工作原理并不一样。我对MPI库做了一些修改,BIGD就基本没动,这些修改也是试验性质的,没有特别的意义。

大数运算是比较耗时的东西,在AVR上能转到什么程度取决于CPU主频和内存空间,使用前需要做实验决定功能的取舍。而这种实验本身又挺费时费力,所以希望这个例子能为有需求的朋友们提供些帮助啥的。

就这吧,有兴趣的朋友还可以把程序编译成PC上的.exe,看看比AVR快多少倍,:)。


虚拟终端的显示效果 (原文件名:avr-test-mpi and bd.gif)

源代码(按mega2561配置)和仿真文件。这里使用了AVR eclipse plugin,不是AVRStudio的项目,注意一下了。ourdev_584008IOF6N3.zip(文件大小:850K) (原文件名:avr-test-mpi and bd.zip)

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2010-9-18 18:33:52 | 显示全部楼层
这个耗时多久?俺不是指仿真。。

出0入0汤圆

 楼主| 发表于 2010-9-19 12:14:19 | 显示全部楼层
搞程序的时间差不多耗时一两个月吧,前阵子俺被封闭写东西,晚上闷在旅馆里没事就弄这个。

俺打算买块xmega的开发板,有空把它移过去,看看硬件环境上跑起来的真实速度。现在感觉做加减乘除还挺快,但是做1024位RSA显慢,最慢的是生成随机大素数,如果验证很严格的话,512位大素数能跑出好几分钟的壮观纪录来,在PC上还用不了1秒钟呢。

核心程序上MPI的代码已经比较适合在AVR上运转了,BIGD还有优化的余地,把“位 digit”的字长调整到16比特可以显著提高速度,减小代码体积。感兴趣的朋友不妨自己试着玩。:)
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-16 02:55

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表