本文来源电子发烧友社区,作者:李先生, 帖子地址:https://bbs.elecfans.com/jishu_2287285_1_1.html
前言
准备工作
整数运算性能测试Dhrystone
修改代码
编译运行
测试结果
结果对比
浮点运算性能测试whetstone
修改代码
编译运行
测试结果
结果对比
Linpack浮点
修改代码
编译运行
测试结果
结果对比
livermore数值计算
修改代码
编译运行
测试结果
结果对比
前言
能按照https://bbs.elecfans.com/jishu_2286643_1_1.html介绍的进行应用开发
下载代码
http://www.roylongbottom.org.uk/classic_benchmarks.tar.gz
解压文件夹,并导入到开发板的~目录下。
Dhrystone是于1984年由Reinhold P. Weicker设计的一套综合的基准程序,该程序用来测试CPU(整数)计算性能。其输出结果为每秒钟运行Dhrystone的次数,即每秒钟迭代主循环的次数。
代码结构
代码位于source_code文件夹下
common_64bit/
common_32bit
|
//getSecs()
local_time()
start_time()
end_time()
getDetails()
|
|
|
|
|
ldhrystone2/dhry_2.c
|
算法无需修改
|
|
|
|
|
ldhrystone2/dhry_1.c
|
main按需修改
|
|
|
|
|
l将common_64bit/cpuidh.h复制到dhrystone2下
l将common_64bit/cpuidc64.c复制到dhrystone2下
1.注释掉int getDetails()函数,我们这里不获取CPU对应的信息。
l修改dhry_1.c
因为没有实现getDetails,注释掉如下代码.
#if 0
getDetails();
for (i=1; i<10; i++)
{
printf("%sn", configdata);
}
printf("n");
fprintf (Ap, " #####################################################nn");
for (i=1; i<10; i++)
{
fprintf(Ap, "%s n", configdata);
}
fprintf (Ap, "n");
printf("##########################################n");
#endif
如下地方语法错误
#endif "Register option Selected."改为
#endif // "Register option Selected."
前面添加接口函数申明
void local_time();
void start_time();
void end_time();
两处printf ("Ptr_Comp: * %dn", (int) Ptr_Glob->Ptr_Comp);改为
printf ("Ptr_Comp: * %pn", Ptr_Glob->Ptr_Comp);
编译运行
gcc *.c -o test
./test
打印如下
提高优化等级
gcc *.c -o test -O3
./test
打印如下
测试结果会添加到文件Dhry.txt中
测试结果
|
默认
|
-O3
|
DMIPS
|
627.69
|
1964.01
|
|
|
|
http://www.roylongbottom.org.uk/dhrystone%20results.htm
可以看到和Atom N455 32b接近。
浮点运算性能测试whetstone
修改代码
代码结构
代码位于source_code文件夹下
common_64bit/
common_32bit
|
CPU相关信息获取和时间测量接口
|
//getSecs()
local_time()
start_time()
end_time()
getDetails()
|
|
|
|
whetstone/whets.c
|
main按需修改
|
|
|
|
|
l将common_64bit/cpuidh.h复制到whetstone下
l将common_64bit/cpuidc64.c复制到whetstone下
1.注释掉int getDetails()函数,我们这里不获取CPU对应的信息。
lWhets.c
注释掉以下代码
#if 0
getDetails();
for (i=1; i<10; i++)
{
printf("%sn", configdata);
}
local_time();
printf("n");
printf("##########################################n");
printf("%s Precision C Whetstone Benchmark %s, %sn", Precision, opt, timedaa
y);
#endif
前面添加接口函数申明
void local_time();
void start_time();
void end_time();
在#include "cpuidh.h"后包含math.h
#include "cpuidh.h"
#include
编译运行
gcc *.c -o test -lm
./test打印如下
提高优化等级
gcc *.c -o test -lm -O3
./test
打印如下
测试结果会记录到文件whets.txt中
测试结果
默认
-O3
MWIPS
347.498
833.258
结果对比
http://www.roylongbottom.org.uk/whetstone%20results.htm
看到和Pentium III相当
Linpack是国际上使用最广泛的测试高性能计算机系统浮点性能的基准测试。通过对高性能计算机采用高斯消元法求解一元N次稠密线性代数方程组的测试,评价高性能计算机的浮点计算性能。Linpack的结果按每秒浮点运算次数(flops)表示。
修改代码
代码结构
代码位于source_code文件夹下
common_64bit/
common_32bit
CPU相关信息获取和时间测量接口
//getSecs()
local_time()
start_time()
end_time()
getDetails()
linpack/linpack.c
main按需修改
l将common_64bit/cpuidh.h复制到linpack下
l将common_64bit/cpuidc64.c复制到linpack下
1.注释掉int getDetails()函数,我们这里不获取CPU对应的信息。
llinpack.c
注释掉以下代码
#if 0
getDetails();
for (i=1; i<10; i++)
{
printf("%sn", configdata);
}
printf("n");
printf("##########################################n");
#endif
前面添加接口函数申明
void local_time();
void start_time();
void end_time();
在#include "cpuidh.h"后包含string.h
#include "cpuidh.h"
#include
main原型函数添加返回类型int
gcc *.c -o test
./test打印如下
提高优化等级
gcc *.c -o test -O3
./test
打印如下
测试结果会记录到文件Linpack.txt中
测试结果
默认
-O3
MFLOPS
40.19
123.77
http://www.roylongbottom.org.uk/linpack%20results.htm
和Celeron A相当
修改代码
代码结构
代码位于source_code文件夹下
common_64bit/
common_32bit
CPU相关信息获取和时间测量接口
//getSecs()
local_time()
start_time()
end_time()
getDetails()
livermore_loops/lloops.c
main按需修改
l将common_64bit/cpuidh.h复制到livermore_loops下
l将common_64bit/cpuidc64.c复制到livermore_loops下
1.注释掉int getDetails()函数,我们这里不获取CPU对应的信息。
llloops.c
注释掉以下代码
#if 0
getDetails();
for (i=1; i<10; i++)
{
printf("%sn", configdata);
}
printf("n");
fprintf (outfile, " #####################################################n\
n");
for (i=1; i<10; i++)
{
fprintf(outfile, "%s n", configdata);
}
fprintf (outfile, "n");
#endif
前面添加接口函数申明
void local_time();
void start_time();
void end_time();
在#include "cpuidh.h"后包含string.h
#include "cpuidh.h"
#include
main原型函数添加返回类型int
gcc *.c -o test -lm
./test打印如下
测试结果会记录到文件LLloops.txt中
默认
-O3
MFLOPS
82.47
结果对比
http://www.roylongbottom.org.uk/livermore%20loops%20results.htm
与Pentium Pro相当
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
RISC-V
+关注
关注
41文章
1904浏览量
45045 -
赛昉科技
+关注
关注
3文章
126浏览量
14134
发布评论请先 登录
相关推荐
信用卡大小的 RISC-V 单板计算机介绍
信用卡大小的 RISC-V 单板计算机 —— Mars
Mars 由深圳市群芯闪耀科技有限公司(Milk-V)设计并推出,搭载赛昉科技
发表于 04-12 16:39
【昉·星光 2 高性能RISC-V单板计算机体验】为 Ubuntu 安装 Docker 及常用软件
【昉·星光 2 高性能RISC-V单板计算机体验】为 Ubuntu 安装 Docker 及常用软件
目的
为了更好的利用
发表于 02-21 17:54
【昉·星光 2 高性能RISC-V单板计算机体验】VisionFive2开箱+安装Ubuntu
【昉·星光 2 高性能RISC-V单板计算机体验】VisionFive2开箱+安装Ubuntu
前言
很感谢
发表于 02-21 17:49
【昉·星光 2 高性能RISC-V单板计算机体验】+6手把手实战Linux控制小车
体验】4连接HDMI显示图形界面 - RISC-V技术论坛
【昉·星光 2 高性能RISC-V单板计算机
发表于 10-12 10:05
VisionFive 2单板计算机成功支持Docker容器解决方案
赛昉科技进一步获取。
关于 VisionFive 2
VisionFive 2 是全球第一款集成 3D GPU 的高性能量产 RISC-V 单板计算
发表于 09-08 11:45
【RISC-V + OpenCV 计算机视觉】用 VisionFive 2 昉·星光 2 进行物体识别
广泛应用于视频监控、自动驾驶等领域。
基于Debain操作系统和OpenCV框架,赛昉科技在VisionFive 2(昉·星光 2)RISC-V
发表于 09-08 11:42
【昉·星光 2 高性能RISC-V单板计算机体验】原创3 控制螺旋桨电路的升力大小
控制螺旋桨电路的升力大小,昉·星光 2 高性能RISC-V单板计算机反应敏捷,控制到位,值得上手!
GPIO接口也非常多,非常全。如下图:
发表于 08-31 16:45
【昉·星光 2 高性能RISC-V单板计算机体验】+1控制小车前进后退
感谢 电子发烧友论坛网
感谢 上海赛昉科技有限公司
下面用GPIO方式控制小车前进与后退,如视频所示。
GPIO接口控制效果不错,接下来再用这款“单板计算机”做一些项目。
发表于 08-30 20:15
【RISC-V专题】昉·星光 2(VisionFive 2)RISC-V单板计算机免费试用
VisionFive 2是全球首款集成3D GPU的高性能量产RISC-V 单板计算机 。与上一代相比,VisionFive 2全面升级,在处理器工作频率、多媒体处理能力、可扩展性等方面都有显着提升
发表于 05-16 11:26
评论