Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
nomad-lab
parser-gromos
Commits
7ec3aa19
Commit
7ec3aa19
authored
Sep 10, 2020
by
temok-mx
Browse files
Updated README.md; added metadata.yml; the lead branch is now master, inactive branches became tags
parent
b7d913f0
Changes
3
Hide whitespace changes
Inline
Side-by-side
.gitlab-ci.yml
deleted
100644 → 0
View file @
b7d913f0
stages
:
-
test
testing
:
stage
:
test
script
:
-
cd .. && rm -rf nomad-lab-base
-
git clone --recursive git@gitlab.mpcdf.mpg.de:nomad-lab/nomad-lab-base.git
-
cd nomad-lab-base
-
git submodule foreach git checkout master
-
git submodule foreach git pull
-
sbt gromos/full:test
only
:
-
master
tags
:
-
test
-
spec2
README.md
View file @
7ec3aa19
# GROMOS Parser
[
NOMAD Laboratory CoE
](
http://nomad-coe.eu
)
parser for
[
GROMOS
](
http://www.gromos.net
)
## Version 0.0.2
This is a NOMAD parser for
[
GROMOS
](
http://www.gromos.net/
)
. It will read GROMOS input and
output files and provide all information in NOMAD's unified Metainfo based Archive format.
This is the parser for GROMOS and MD++ codes in
[
GROMOS
](
http://www.gromos.net
)
.
The official version lives at:
## Preparing code input and output file for uploading to NOMAD
git clone git@gitlab.mpcdf.mpg.de:nomad-lab/parser-gromos.git
NOMAD accepts
`.zip`
and
`.tar.gz`
archives as uploads. Each upload can contain arbitrary
files and directories. NOMAD will automatically try to choose the right parser for you files.
For each parser (i.e. for each supported code) there is one type of file that the respective
parser can recognize. We call these files
`mainfiles`
as they typically are the main
output file a code. For each
`mainfile`
that NOMAD discovers it will create an entry
in the database that users can search, view, and download. NOMAD will associate all files
in the same directory as files that also belong to that entry. Parsers
might also read information from these auxillary files. This way you can add more files
to an entry, even if the respective parser/code might not directly support it.
You can browse it at:
For gromos please provide at least the files from this table if applicable to your
calculations (remember that you can provide more files if you want):
https://gitlab.rzg.mpg.de/nomad-lab/parser-gromos
It relies on having the nomad-meta-info and the python-common repositories one level higher.
The simplest way to have this is to check out nomad-lab-base recursively:
git clone --recursive git@gitlab.mpcdf.mpg.de:nomad-lab/nomad-lab-base.git
To create an upload with all calculations in a directory structure:
This parser will be in the directory parsers/gromos of this repository.
```
zip -r <upload-file>.zip <directory>/*
```
## Running and Testing the Parser
### Requirements
The required python packages can be installed with (see
[
python-common
](
https://gitlab.rzg.mpg.de/nomad-lab/python-common
)
):
Go to the
[
NOMAD upload page
](
https://nomad-lab.eu/prod/rae/gui/uploads
)
to upload files
or find instructions about how to upload files from the command line.
pip install -r nomad-lab-base/python-common/requirements.txt
## Using the parser
### Usage
GROMOS MD log output files can be parsed with
:
You can use NOMAD's parsers and normalizers locally on your computer. You need to install
NOMAD's pypi package
:
python GROMOSParser.py [path/toFile]
```
pip install nomad-lab
```
### Test Files
Example log output files of GROMOS can be found in the directory test/examples.
More details about the calculations and files are explained in README file of test/examples.
To parse code input/output from the command line, you can use NOMAD's command line
interface (CLI) and print the processing results output to stdout:
```
nomad parse --show-archive <path-to-file>
```
To parse a file in Python, you can program something like this:
```
python
import
sys
from
nomad.cli.parse
import
parse
,
normalize_all
# match and run the parser
backend
=
parse
(
sys
.
argv
[
1
])
# run all normalizers
normalize_all
(
backend
)
# get the 'main section' section_run as a metainfo object
section_run
=
backend
.
resource
.
contents
[
0
].
section_run
[
0
]
# get the same data as JSON serializable Python dict
python_dict
=
section_run
.
m_to_dict
()
```
## Developing the parser
Also install NOMAD's pypi package:
```
pip install nomad-lab
```
Clone the parser project and install it in development mode:
```
git clone https://gitlab.mpcdf.mpg.de/nomad-lab/parser-gromos parser-gromos
pip install -e parser-gromos
```
Running the parser now, will use the parser's Python code from the clone project.
metadata.yml
0 → 100644
View file @
7ec3aa19
code-label
:
GROMOS
code-label-style
:
All in capitals
code-url
:
http://www.gromos.net/
parser-dir-name
:
dependencies/parsers/gromos/
parser-git-url
:
https://gitlab.mpcdf.mpg.de/nomad-lab/parser-gromos
parser-specific
:
'
'
table-of-files
:
'
'
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment