[转]NOI_Linux Arbiter使用手册
讲述清楚,简单易懂的Arbiter使用手册
转载自 https://www.cnblogs.com/gengchen/p/7761565.html
Arbiter 系统使用说明
Overview
- Arbiter是NOI系列赛事的官方评测软件, 由北航的相关人员开发。
- 在OIer会经历的几场大型比赛中, 除了省选和PKUSC/THUSC不使用Arbiter评测, 其他比赛(如CTSC, WC, NOI, NOIP)全部使用Arbiter进行官方评测, 最终成绩也以Arbiter评测结果为准。
- 网络上一直没有清晰的Arbiter使用说明....所以提供一份。
Install
- Arbiter内置在了NOI Linux发行版中, 可以自行前往NOI官网下载。
- 其他下载方式尚不明确。
Usage
- 首先新建一场比赛, 选择一个已经创建的文件夹作为比赛文件夹, Arbiter会自行在该目录下创建几个子文件夹.
- 几个子文件夹的功能如下:
evaldata
: 数据文件夹,所有题目的数据直接放在这一个文件夹中, 不建单独的子文件夹, 每个文件的格式形如:test1.in
,test1.ans
, 注意这里的答案文件必须用.ans
作为后缀.- 如果你的题目的原始数据是以
.out
作为后缀名, 你可以使用附件一中的Python批量修改。 players:
选手源代码文件夹, 首先建立一个日期文件夹, 如day1
(注: 若已经在arbiter中新建了一天的比赛, 那么这个文件夹会被自动创建), 然后把各个选手的源程序分别建立单独的文件夹放进day1
文件夹。- 在每个选手的文件夹中, 选手需要对于每个题目创建子文件夹, 并把源程序放到子文件夹中.
result
: 评测结果文件夹, 每个以选手名称作为名称的文件夹是评测结果文件, 不需要操作人员手动修改.ps
: 评测结果文件夹, 以.ps
文件可视化呈现的选手测试点详细测试情况, 不需要操作人员手动修改, 在打印比赛结果
按钮被操作后会自动创建.
- 在配置完毕数据和选手源程序之后, 在考试页面建立一天的考试, 在下面再分别建立试题, 每个试题按照要求设置即可.
- 在选手界面, 选择
导入名单
, 导入csv
文件的选手名单, 或者直接手动建立选手. 选手的信息分为选手名称和选手编号, 其中选手编号必须和players
中的文件夹名称相同. - 选择考试, 点击测评即可。
- 注意这个软件设计的非常辣鸡, 测评的时候不要乱动鼠标, 不然会当机。
Appendix
#coding:utf-8
import os
def filerename(filepath,srctype,destype):
for path,dirlist,filelist in os.walk(filepath):
for file in filelist:
#防止文件名中包含.
fullist = file.split('.')
namelist = fullist[0:-1]
filename = ''
for i in namelist:
filename = filename + i + '.'
# print (filename)
curndir = os.getcwd() #获取当前路径
# print (curndir)
os.chdir(path) #设置当前路径为目标目录
newdir = os.getcwd() #验证当前目录
# print (newdir)
filetype = file.split('.')[-1] #获取目标文件格式
if filetype == srctype: #修改目标目录下指定后缀的文件(包含子目录)
os.rename(file,filename+destype)
if srctype == '*': #修改目标目录下所有文件后缀(包含子目录)
os.rename(file,filename+destype)
if srctype == 'null': #修改目标目录下所有无后缀文件(包含子目录)
if len(fullist) == 1:
os.rename(file,file+'.'+destype)
os.chdir(curndir) #回到之前的路径
filerename('.','out','ans')
"执行python change.py即可
[附]转载自另一位大佬xjzsq
坑爹测评软件arbiter使用指南
by xjzsq
S1:在试题摘要的空白处单击右键点击添加考试
S2:在考试上单击右键点击添加试题
S3:修改试题名称为测试数据和代码的名称
S4:修改测试数据个数/分值
S5:修改时间限制和内存限制
S6:选择比较方式,看情况选择,因为比较方式已经被坑了N次了
(比较方式一般会在试题pdf第一页中的题目信息中给出,写在比较方式一栏中,
比如“全文比较”或者“SPJ”(貌似目前没法测SPJ))
S7:保存!!!
一定在文件-保存那里保存一下,不然所做的更改下次打开就会被还原,已经被坑了N次了...
S8:导入测试数据:将测试数据直接放到evaldata文件夹下
(文件名格式必须是试题名称+测试点编号.in和.ans,如果是.out的话,
可以用批处理改,在有.out的文件夹下建立一个文本文件,然后打开输入:
ren *.out *.ans ,就可以转换为.ans文件)
S9:导入选手:在试题评测中选择添加选手,然后输入姓名和编号,
这里为了方便都输入一样的即可。
S10:把选手的程序复制到player文件夹下,文件夹名为选手编号,
在选手文件夹下建立三个子文件夹,名称为题目名称,在这些文件夹中
放入对应程序,名称为 试题名称.c/cpp/pas
S11:评测:选择评测场数,然后在选手的名字前面打勾,之后点击“评测选定选手”
即可评测
S12:查看结果:
选择成绩统计,在试题评测中选好场数,然后点击“打印当日选手
成绩”,选择打印到文件即可打印,结果打印到ps文件夹下(分场分选手的子文件夹)
S13:测评完毕,保存工程
注:
1.如果闪退,则说明测试数据有问题(比如.out忘记转成.ans之类的)。
2.测评完以后,如果选手对应的成绩还是0的话,可以到成绩统计那一栏去看一下,有可能成绩统计那里能正确显示成绩
3.可以到result/day_/选手名/文件夹下查看评测过程的日志,可以在不用打印的情况下方便的看到评测过程。
4.如果评测失败可以到评测日志看一下,很有可能是编译错误(目前不要在编译选项里面填任何东西,不然会编译失败...)
5.最好在评测选手程序前先评测一下标程,确认比较方式是否适合,如果标程没有AC的话,请尝试选择其他比较方式(最好选择和答案对应的比较方式,比如如果输出一个数字,就选择单行单数字等等)
6.在修改比较方式之后,最好先保存,然后退出arbiter再重新打开比赛,然后在确认一下比较方式是否已经改变,因为arbiter比较坑的缘故,有时改变比较方式之后会没有效果,必须重新打开工程才能确认比较方式是否已经改变。
[转]NOI_Linux Arbiter使用手册的更多相关文章
- FREERTOS 手册阅读笔记
郑重声明,版权所有! 转载需说明. FREERTOS堆栈大小的单位是word,不是byte. 根据处理器架构优化系统的任务优先级不能超过32,If the architecture optimized ...
- JS魔法堂:不完全国际化&本地化手册 之 理論篇
前言 最近加入到新项目组负责前端技术预研和选型,其中涉及到一个熟悉又陌生的需求--国际化&本地化.熟悉的是之前的项目也玩过,陌生的是之前的实现仅仅停留在"有"的阶段而已. ...
- 转职成为TypeScript程序员的参考手册
写在前面 作者并没有任何可以作为背书的履历来证明自己写作这份手册的分量. 其内容大都来自于TypeScript官方资料或者搜索引擎获得,期间掺杂少量作者的私见,并会标明. 大部分内容来自于http:/ ...
- Redis学习手册(目录)
为什么自己当初要选择Redis作为数据存储解决方案中的一员呢?现在能想到的原因主要有三.其一,Redis不仅性能高效,而且完全免费.其二,是基于C/C++开发的服务器,这里应该有一定的感情因素吧.最后 ...
- JS魔法堂:不完全国际化&本地化手册 之 实战篇
前言 最近加入到新项目组负责前端技术预研和选型,其中涉及到一个熟悉又陌生的需求--国际化&本地化.熟悉的是之前的项目也玩过,陌生的是之前的实现仅仅停留在"有"的阶段而已. ...
- Windows API 函数列表 附帮助手册
所有Windows API函数列表,为了方便查询,也为了大家查找,所以整理一下贡献出来了. 帮助手册:700多个Windows API的函数手册 免费下载 API之网络函数 API之消息函数 API之 ...
- linux命令在线手册
下面几个网址有一些 Linux命令的在线手册,而且还是中文的,还可以搜索.非常方便 Linux命令手册 Linux命令大全 Linux中文man在线手册 每日一linux命令
- Mysql完全手册(笔记二,使用数据与性能优化)
一.使用数据 1.使用变量 MySQL也可以让我们以用户自定义的变量来存储select查询的结果,以便在将来select查询中使用.它们只会在客户会话期间存在,但是它们提供一个方便有效的方法来连接查询 ...
- html javascript css3 php3.2.3离线手册
各位新年快乐! 愿大家"愿有前程可奔赴,也有岁月可回头"! 发现个离线手册很全的网站,分享大家,也mark自用. http://www.shouce.ren/ 手册网
随机推荐
- Conjugate Function
共轭函数 共轭函数的定义: 设函数f:Rn→R,定义函数f∗:Rn→R为: f∗(y)=sup(<y,x>−f(x)) x∈D 此函数称为函数f的共轭函数.即函数yx和函数f(x)之间差 ...
- echarts之简单的入门——【二】再增加一个柱状图和图例组件
echarts之简单的入门——[一]做个带时间轴的柱状统计图 现在需求说,我需要知道日答题总次数和活跃人数,那么我们如何在上面的图表中增加一个柱状图呢? 如果你看过简单入门中的配置项手册中series ...
- 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...
- Java 8 的 Metaspace
Java 8 的 Metaspace https://www.cnblogs.com/xrq730/p/8688203.html 被废弃的持久代 想起之前面试的时候有面试官问起过我一个问题:Java ...
- MT【8】和e有关的一个极限
解答: 评:这里涉及到e有关的极限的单调性,求导数得:
- Leetcode 1.两数之和 By Python
思路 很容易想到的方法是二重循环遍历一遍,但是会很慢 把加法变减法可以大大加速 代码 class Solution: def twoSum(self, nums, target): "&qu ...
- 【BZOJ4821】[SDOI2017]相关分析(线段树)
[BZOJ4821][SDOI2017]相关分析(线段树) 题面 BZOJ 洛谷 题解 看看询问要求的东西是什么.把所有的括号拆开,不难发现要求的就是\(\sum x,\sum y,\sum xy,\ ...
- [luogu1131][bzoj1060][ZJOI2007]时态同步【树形DP】
传送门:https://www.luogu.org/problemnew/show/P1131 题目大意 给你一棵树,每条边有边权,要求增加一些边的边权,使得根节点到每个叶子节点的距离相等,求出最少共 ...
- 洛谷 P2158 [SDOI2008]仪仗队 解题报告
P2158 [SDOI2008]仪仗队 题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线 ...
- Linux 系统缓存机制学习
前言:本文为参考他人的文章,是一篇学习记录型博客.理解linux的系统缓存机制有助于理解elasticsearch实时更新的原理. 一.缓存机制 为了提高文件系统性能,内核利用一部分物理内存分配出缓冲 ...