This repository downloads the Andrew dataset on global CO2 emissions from cement production from Zenodo. The dataset is converted to the PRIMAP2 format and provided in the csv based interchange format and the netCDF based native primap2 format. Several version of the dataset are available.
This repository downloads data on global CO2 emissions from cement production from Zenodo. The downloaded dataset can then be converted into CSV (.csv file extension) or NetCDF (.nc file extension) format. Converted data are available for the following versions:
| v231016 |Zenodo | | v230913 |Zenodo | | v230428 |Zenodo | | v220915 |Zenodo | | v220516 |Zenodo | The data management tool DataLad is used to version control the data sets. Commands to run the scripts are executed via the pydoit package.
This repository is a DataLad dataset. It provides
fine-grained data access down to the level of individual files, and allows for
tracking future updates. In order to use this repository for data retrieval,
DataLad is required. It is a free and open source
command line tool, available for all major operating systems, and builds up on
Git and git-annex to allow sharing,
synchronizing, and version controlling collections of large files.
Note that for simply downloading the dataset, Python and pydoit are not required.
A DataLad dataset can be cloned
by running
datalad clone
Do not use git clone to download the repository! This way DataLad will not have the necessary
information to run the program. Once a dataset is cloned, it is a light-weight directory on your local machine.
At this point, it contains only small metadata and information on the identity
of the files in the dataset, but not actual content of the (sometimes large)
data files.
dataland get <filename>
This command will trigger a download of the files, directories, or subdatasets
you have specified.
For example, the CSV file for the 2023/09/13 release can be downloaded with
datalad get extracted_data/v230913/Robbie_Andrew_Cement_Production_CO2_230913.csv
DataLad datasets can be updated. The command datalad update
will fetch
updates and store them on a different branch (by default
remotes/origin/master
). Running
datalad update --merge
will pull available updates and integrate them in one go.
DataLad datasets contain their history in the git log
. By running git
log
(or a tool that displays Git history) in the dataset or on specific
files, you can find out what has been done to the dataset or to individual
files by whom, and when.
For those who wish to contribute to the repository, below we go through the key commands you will need to use.
doit setup_env
This will download all files from Zenodo as they are for a specific version (note this version must already be in versions.py
, if you want to add a new version, see the section on adding a new version below).
doit download_version --version <YYMMDD>
doit read_version --version <YYMMDD>
To add a new version go to versions.py in the src directory and create a new value in the
versions
dictionary. Fill all the required information similar to the previous entries.
For example, the value v230913 in the versions dictionary describes the 13-Sep-2023 release.
versions = {
"v230913": {
'date': '13-Sep-2023',
'ver_str_long': 'version 230913',
'ver_str_short': '230913',
"folder": "v230913",
"transpose": False,
"filename": "0. GCP-CEM.csv",
'ref': '10.5281/zenodo.8339353',
'ref2': '10.5194/essd-11-1675-2019',
'title': 'Global CO2 emissions from cement production',
'institution': "CICERO - Center for International Climate Research",
'filter_keep': {},
'filter_remove': {},
'contact': "johannes.guetschow@climate-resource.com",
'comment': ("Published by Robbie Andrew, converted to PRIMAP2 format by "
"Johannes Gütschow"),
'unit': 'kt * CO2 / year',
'country_code': True,
},
}
Then run the two commands read_version
and download_version
as described in Contributing.
Show all doit commands
doit help
See a list with possible doit commands specific to this repository
doit list
Get help on a specific command
doit help <command>
Git repositories can configure clones of a dataset as remotes in order to fetch, pull, or push from and to them. A datalad sibling
is the equivalent of a git clone that is configured as a remote.
Query information about about all known siblings with
datalad siblings
Add a sibling to allow pushing to github
datalad siblings add --dataset . --name <name> --url git@github.com:JGuetschow/Global_CO2_from_cement_production.git
SSH-access is needed to run this command. Note that name can be freely chosen.
Push to the github repository
datalad push --to <name>
There always issues open regarding coding, some of them easy to resolve, some harder.
Contributing is ouf course not limited to the categories above. I you have ideas for improvements just open an issue or a discussion page to discuss you idea with the community.
As we have a datalad repository using github and gin the process of contributing code and data is a bit different from pure git repositories. As the data is only stored on gin, the gin repository is the source to start from. As gin currently has a problem with forks (the annexed data is not forked) we have to use branches for development and, thus, to contribute you first need to contact the maintainers to get write access to the gin repository. You have to clone the repository using ssh to be able to push to it. For that you first need to store your public ssh key on the gin server (settings -> SSH Keys).
Once you have everything set up you can create a new branch branch and work there. When you're done create a pull request to integrate your work into the main branch. This should be done first on github to allow for discussions and review (gin servers don't have the same review features). Afterwards the changes can be actually merged on gin (so that the annex is merged properly too).