-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #79 from ACDguide/paola_create
Paola create
- Loading branch information
Showing
8 changed files
with
191 additions
and
197 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
# Choosing a directory structure and filenames | ||
|
||
The names you choose for files and directories and generally the way you organise your data, i.e. your directory structure, can help navigating the data, provide extra information, avoid confusion and avoid the user ending up accessing the wrong data. In many cases the best file organisation will depend on the specific research project and the actual server where the data is stored. The global Climate Modelling Intercomparison Project (CMIP) has adopted a **Data Reference Syntax (DRS)**, based on the **controlled vocabularies (CVs)** used in model metadata, to define their file names and directory structures. | ||
Here we list a few guidelines and tips to help you decide. | ||
|
||
## General considerations | ||
* Familiarise yourself with the storage system, make sure you are storing the files in the most appropriate place, get to know if the storage is backed up or not, check what your allocation is, and also what rules or best practices apply. | ||
* Take into account how yourself or others might want to use the data, this is particularly important when deciding the DRS but also how to divide data across files for big datasets as model output. Doing so at the start of the project will spare you lots of time you might otherwise spend re-processing all your files. | ||
* Be consistent, this applies both to the organisation and the naming, consistency is essential for the data to be machine-readable, i.e. data which is easy to access by coding. In fact, use community standards and/or controlled vocabularies wherever possible. | ||
* Consider adding a `readme` file in the main directory, including an explanation of the DRS and the naming conventions, abbreviation and/or codes you used. If you used standards and controlled vocabularies all you have to do is to include a link to them. | ||
|
||
## Directory structure | ||
|
||
![Example of directory structure](../images/example_drs.png) | ||
|
||
The figure above shows an example of an organised working directory for a model output. | ||
|
||
**Things to consider:** | ||
|
||
* Try to organise files in directories based on type and how you process them | ||
for the final output. Also consider how others might use them: are they going to be used for analysis or they could be used as forcing or restart files for a model? | ||
* If there is an existing DRS defined for an analogous data product (e.g. input data to a climate analysis workflow), would it help yourself and others to structure your output following a similar convention? | ||
* Think of the way you would access these directories in a code, as an example having the variable directories using exactly the same name as the actual variable. | ||
* Make sure your code is separate from your data, you want to be able to use something like git to version control it and possibly GitHub to back it up easily. | ||
* Have at least one `readme` file with detailed metadata, possibly more if you have a lot of directories/files. You cannot realistically use git for managing versions of data but you can use git to version control your `readme` files. | ||
* Review at regular intervals what you are keeping, what needs to be removed and how things are organised. | ||
|
||
**Reference examples:** | ||
|
||
* The CMIP6 DRS is defined in the [CMIP6 Controlled Vocabularies document](https://docs.google.com/document/d/1h0r8RZr_f3-8egBMMh7aqLwy3snpD6_MrDz1q8n5XUk/edit), starting on p.13. | ||
* The [CORDEX DRS](http://is-enes-data.github.io/CORDEX_adjust_drs.pdf) builds on the CMIP DRS to apply to regional climate models. | ||
|
||
## File naming | ||
You can use filenames to include information as: | ||
|
||
* project, simulation and/or experiment acronyms, you might have to use a combination of them | ||
* spatial coverage: the region or coordinates range covered by the data, could also be a specific domain for climate model data, e.g., ocean, land etc. | ||
* grid: could be either a grid label or spatial resolution | ||
* temporal coverage: a specific year/date or a temporal range | ||
* temporal frequency: monthly, daily etc. | ||
* type of data: again this depends on context, if the same directory contains data from different instrumentations it is important to specify the instrument in the name. For coupled model output this could be the model component, if you are using one file per variable, the variable name | ||
* version: this is really important if you are sharing the data even if only 1 version exists at the time | ||
* correct file extension | ||
|
||
# Tips for machine-readable files | ||
* avoid special characters: ~ ! @ # $ % ^ & * ( ) ` ; < > ? , [ ] { } ‘ “ | ||
* do not use spaces to separate words; use underscores "_" or dashes "-" or CamelCase | ||
* use YYYYMMDD for dates, it will sort your files in chronological order, absolutely avoid "Jan, Feb, .." for months as they are much harder to code for. | ||
* for number sequences, use leading zeros: so 001, 002,.. 020,.. 103 rather than 1, 2,.. 20, .. 103 | ||
* try to avoid overly long names - for a single file directory keep it under 255 characters, for paths 30000. | ||
* avoid having a large number of files in a single directory, but also an excessive number of directories with one file each | ||
* always include file extension, some software can recognise files from their header, but this is not always the case | ||
|
||
## Online Resources | ||
We partially based this page on the resources listed below, and recommend checking them for more insight and advice. | ||
|
||
* [Best practice to organise your data](https://www.earthdatascience.org/courses/intro-to-earth-data-science/open-reproducible-science/get-started-open-reproducible-science/best-practices-for-organizing-open-reproducible-science/) - part of an Open reproducible science course from the University of Colorado | ||
* [Software Carpentry video covering DRS best practices](https://youtu.be/3MEJ38BO6Mo) | ||
* [Best file naming practice handout (pdf) from Standford University](https://stanford.box.com/shared/static/yl5a04udc7hff6a61rc0egmed8xol5yd.pdf) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters