讲述清楚,简单易懂的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使用手册的更多相关文章

  1. FREERTOS 手册阅读笔记

    郑重声明,版权所有! 转载需说明. FREERTOS堆栈大小的单位是word,不是byte. 根据处理器架构优化系统的任务优先级不能超过32,If the architecture optimized ...

  2. JS魔法堂:不完全国际化&本地化手册 之 理論篇

    前言  最近加入到新项目组负责前端技术预研和选型,其中涉及到一个熟悉又陌生的需求--国际化&本地化.熟悉的是之前的项目也玩过,陌生的是之前的实现仅仅停留在"有"的阶段而已. ...

  3. 转职成为TypeScript程序员的参考手册

    写在前面 作者并没有任何可以作为背书的履历来证明自己写作这份手册的分量. 其内容大都来自于TypeScript官方资料或者搜索引擎获得,期间掺杂少量作者的私见,并会标明. 大部分内容来自于http:/ ...

  4. Redis学习手册(目录)

    为什么自己当初要选择Redis作为数据存储解决方案中的一员呢?现在能想到的原因主要有三.其一,Redis不仅性能高效,而且完全免费.其二,是基于C/C++开发的服务器,这里应该有一定的感情因素吧.最后 ...

  5. JS魔法堂:不完全国际化&本地化手册 之 实战篇

    前言  最近加入到新项目组负责前端技术预研和选型,其中涉及到一个熟悉又陌生的需求--国际化&本地化.熟悉的是之前的项目也玩过,陌生的是之前的实现仅仅停留在"有"的阶段而已. ...

  6. Windows API 函数列表 附帮助手册

    所有Windows API函数列表,为了方便查询,也为了大家查找,所以整理一下贡献出来了. 帮助手册:700多个Windows API的函数手册 免费下载 API之网络函数 API之消息函数 API之 ...

  7. linux命令在线手册

    下面几个网址有一些 Linux命令的在线手册,而且还是中文的,还可以搜索.非常方便 Linux命令手册 Linux命令大全 Linux中文man在线手册 每日一linux命令

  8. Mysql完全手册(笔记二,使用数据与性能优化)

    一.使用数据 1.使用变量 MySQL也可以让我们以用户自定义的变量来存储select查询的结果,以便在将来select查询中使用.它们只会在客户会话期间存在,但是它们提供一个方便有效的方法来连接查询 ...

  9. html javascript css3 php3.2.3离线手册

    各位新年快乐! 愿大家"愿有前程可奔赴,也有岁月可回头"! 发现个离线手册很全的网站,分享大家,也mark自用. http://www.shouce.ren/ 手册网

随机推荐

  1. ImportError: cannot import name descriptor_pb2

    重新编译protobuf 下载地址:https://github.com/google/protobuf $cd /path/protobuf/python $python setup.py buil ...

  2. python异常提示表

    Python常见的异常提示及含义对照表如下: 异常名称 描述 BaseException 所有异常的基类 SystemExit 解释器请求退出 KeyboardInterrupt 用户中断执行(通常是 ...

  3. BZOJ4891 TJOI2017龙舟(Polllard-Rho)

    对给定模数分解质因数后约分即可.依然常数巨大过不了. #include<iostream> #include<cstdio> #include<cmath> #in ...

  4. Sightseeing tour HDU - 1956(混合欧拉回路)

    题意: 有n个点,m条边,其中有单向边和双向边,求是否存在欧拉回路 解析: 刚开始想...判断一下每个点的度数不就好了...emm..还是年轻啊.. 判断是解决不了问题的,因为可能会有某两个点冲突,比 ...

  5. Educational Codeforces Round 4 B. HDD is Outdated Technology

    题目链接:http://codeforces.com/problemset/problem/612/B 解题思路: 一开始看错了题意,他要求的是从1-n所耗费的时间,n表示的是数值而不是下标, 实现代 ...

  6. day27 封装

    广义上的面向对象的封装: 代码的保护,面向对象思想本身就是一种封装 只让自己的对象调用自己类的方法 狭义的封装: 面向对象的三大特性之一,其他两个是继承和多态. 属性和方法都可以藏起来不让你看到 cl ...

  7. 【POJ1456】Supermarket(贪心)

    BUPT2017 wintertraining(16) #4 F POJ - 1456 题意 每个商品有过期日期和价格,每天可以卖一个商品,必须在过期前出售才能收益,求最大收益. 题解 贪心,按价格排 ...

  8. 洛谷P3195 玩具装箱TOY

    题目大意: 有n个数,要将他们分成若干段,每一段的cost定义为: cost=r-l+ΣCk (k∈[r,l]) 该段的最终花费是:(cost-L)^2; 给出L,n,C(1~n),总共的最小花费. ...

  9. C# ADO.NET与面向对象

    软件开发的三层:界面层,业务逻辑层,数据访问层: 数据访问层:项目添加App_Code文件夹: 实体类:根据数据库表结构,类名和数据库表名一致: 每个成员变量要与数据库表的列相对应,对象正好可以列为一 ...

  10. module模块和包(十七)

    在前面的几个章节中我们脚本上是用 python 解释器来编程,如果你从 Python 解释器退出再进入,那么你定义的所有的方法和变量就都消失了. 为此 Python 提供了一个办法,把这些定义存放在文 ...