Package of utility files for working with CMT 2.0 from NeurIPS 2014.
Project description
CMTUTILS
28th October 2014 Neil D. Lawrence
As well as pandas and the standard numpy/scipy stack, the library has the following dependencies: lxml
, openpyxl
, gdata
, pods
pip install lxml
pip install openpyxl
pip install gdata
pip install pods
In 2014 Corinna Cortes and I
were NIPS program Co-Chairs. Alan Saul was our Program Manager. As part of the
process we wrote a lot of scripts for processing the data. The scripts I wrote
used the IPython notebook
(now Project Jupyter) and
pandas
. It was always my intention to summarise this work in case others find
it useful. It is also quite a good document for summarising what is involved in
program chairing a major conference like NIPS.
In May 2021, I separated out the utility files used for the notebooks into a separate python module. The library, cmtutils
, which manages the submissions. For
reviewer management (which was the first thing written) the scripts are based
around a local mirror of the CMT user data base in SQLite. For review management
we moved things much more towards pandas
and used CMT as the central
repository of reviews, exporting them on a daily basis.
A lot of communication was required between CMT through imports and exports. Some of the links used for CMT exports are available [here](http://nbviewer.ipython.org/github/sods/conference/blob/master/Useful Links.ipynb). The various tasks are structured in IPython notebooks in the conference repo. The code used was first written for the NIPS 2014 conference, but ideas were based on experience from using CMT for AISTATS 2012 and some preliminary code written then (for example for importing the XML formatted version of Excel that CMT uses).
Right from the start it was felt that being able to import and export
information to Google spreadsheets would be very useful. With this in mind an
interface between pandas
and Google sheets was created (initially just for
reading, then later for updating). This made it much easier to import reviewer
suggestions and export information about paper statuses to reviewers. That
software has been spun out as part of a suite of tools for Open Data
Science that is
available on github here. These notebooks are
also available in their own github repository for conference
software.
A note on the code. A lot of this code was written 'live' as reviews were coming
in or as a crisis required averting. The original code for sharing information
via Google spreadsheets was written across two or three days whilst on a family
holiday in the Catskills. Much of the code could do with rewriting, and this is
an ongoing process that I hope other conference chairs or program managers will
contribute to. It is shared here as a record of the work required for a
conference like NIPS as well as in the hope that it will be useful for others.
It is not shared as an example of 'best practice' in python coding. There are
some parts I'm proud of and others I'm not. However, I think it is a very good
example of how the notebook can be used with python and pandas
to do 'live'
data processing of some importance whilst under a great deal of pressure. I
can't imagine having done it quite like this with a different suite of tools.
As well as the installed files, you need to create a file called .cmt_user.cfg
in your home directory and give it the following fields:
# This is a user's personal configuration file for CMT
[conference]
short_name = NIPS
year = 2014
chair_email = program-chairs@nips.cc
[cmt]
export_directory =
[gmail]
account =
name =
password =
[google docs]
# Here include the spreadsheet keys of program committee and reviewer candiates
program_committee_key =
reviewer_candidate_key =
buddy_pair_key =
global_results_key =
[review data]
directory =
file = all_reviews.pickle
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cmtutils-0.1.1.tar.gz
.
File metadata
- Download URL: cmtutils-0.1.1.tar.gz
- Upload date:
- Size: 32.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 48ce6efb635e2fefd86808f333fc1183d03d521d3b0cb1ab07d0d0059352a241 |
|
MD5 | 706229bc4c40daa84671bf821d239d3b |
|
BLAKE2b-256 | cd678b6b3f7b7b46a7513c6c628caf952604d99c2873efe5fc1507461c8c341f |
File details
Details for the file cmtutils-0.1.1-py2.py3-none-any.whl
.
File metadata
- Download URL: cmtutils-0.1.1-py2.py3-none-any.whl
- Upload date:
- Size: 31.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3fc862b8bf720e44d87f6bc312d74dfff8b992da3639d1b34777614d5eb03dac |
|
MD5 | eed40e9559fc0be0b886e1a2310357b1 |
|
BLAKE2b-256 | 23dd923c4e228a3aad502c79cec7f2002d9d53b5a604dd49684383b646722b7e |