NEXOCLOM: Neutral EXosphere and CLOud Model
Dr. Mathew Burger, Space Telescope Science Institute

Documentation
https://nexoclom.readthedocs.io/en/latest/ (Reasonably complete and up to date).
This part about writing inputfiles is particularly useful.
Installation
The easiest way to install is to create a fresh venv or conda environment and
use:
pip install nexoclom
There is configuration work that will need to be completed before nexoclom
can be used. This process is given in detail below, although it is likely to
change soon.
I am working on a script to clean up the installation process
- Install Anaconda Python (version >= 3.8):
- Download the installer from:
https://www.anaconda.com/distribution/
- double-click the installer to install. This installs anaconda python in
$HOME/anaconda3 and does not need sysadmin privileges.
- Verify it works: Open a new terminal window and start
ipython
. You should
see something like this:
(base) [sunra m🍔 /~/]$ ipython
Python 3.8.8 (default, Apr 13 2021, 12:59:45)
Type 'copyright', 'credits' or 'license' for more information
IPython 7.32.0 -- An enhanced Interactive Python. Type '?' for help.
In [1]:
- NOTE: I think Anaconda python likes the bash shell, but there
are probably ways around that.
-
Create a new python environment with the model.
-
Download the file nexoclom_environment.yml
-
In a text editor, update the last four lines
prefix: /user/mburger/anaconda3/envs/nexoclom/bin/python
variables:
PGDATA: /user/mburger/.postgres/main
NEXOCLOMCONFIG : /user/mburger/.nexoclom
For prefix, you want $HOME/anaconda3/...
, but $HOME
needs to be the
specific path.
-
Create the envirnoment:
(base) [sunra m🍔 /~/]$ conda env create -f nexoclom_environment.yml
-
To use this environment run:
(base) [sunra m🍔 /~/]$ conda activate nexoclom
WARNING: overwriting environment variables set in the machine
overwriting variable PGDATA
Activating nexoclom sets the environment variables PGDATA
and
NEXOCLOMCONFIG
None of this will work if the correct environment is not active. You will
know it's active because your prompt will change and python
will point to a
different executable:
(nexoclom) [sunra m🍔 /~/]$ which python
/Users/mburger/anaconda/envs/nexoclom/bin/python
-
To turn it off run:
(nexoclom) [sunra m🍔 /~/]$ conda deactivate
-
Create the .nexoclom file
- In your home directory create a file called
.nexoclom
with the
following lines:
savepath = <fullpath>/modeloutputs
datapath = <fullpath>/ModelData
database = thesolarsystemmb
mesdatapath = <fullpath>/UVVSData
mesdatabase = messengeruvvsdb
<fullpath>
does not need to be the same in all lines, but the directories all
need to be valid.
-
Initialize the postgres server if necessary:
- In your
.bashrc
or .bash_profile
file (the file that runs when you
start a terminal window) add the line:
export PGDATA=/Users/mburger/.postgres/main
(This step technically isn't needed because the environment variable gets
set when you activate the environment). - Execute the following commands
(nexoclom) [sunra m🍔 /~/]$ initdb -D $PGDATA
(nexoclom) [sunra m🍔 /~/]$ pg_ctl -l $PGDATA/logfile start
(nexoclom) [sunra m🍔 /~/]$ createdb <username>
(nexoclom) [sunra m🍔 /~/]$ createdb thesolarsystemmb
(nexoclom) [sunra m🍔 /~/]$ createdb messengeruvvsdb
-
Find <username>
with
(nexoclom) [sunra m🍔 /~/]$ echo $USER
-
This needs to match database in the .nexoclom
file
-
This needs to match mesdatabase in the .nexoclom
file
-
Configure the MESSENGER UVVS database if you will be making comparisons to
MASCS/UVVS data. Unfortunately, the data products being used here are not
publicly available (I don't own this data reduction). UVVS data is available
from the Planetary Data System, but it would
take some work to get it integrated into the database. We could probably work
something out if you want to compare with the data.
- Download the MESSENGERdata package if you're authorized (email
Matthew Burger)
- Put the file in the
mesdatapath
directory and untar it.
(nexoclom) [sunra m🍔 /~/]$ tar -xvzf Level1.tar.gz
- Then run:
(nexoclom) [sunra m🍔 /~/]$ ipython
Python 3.8.13 | packaged by conda-forge | (default, Mar 25 2022, 06:06:49)
Type 'copyright', 'credits' or 'license' for more information
IPython 8.2.0 -- An enhanced Interactive Python. Type '?' for help.
In [1]: from MESSENGERuvvs import initialize_MESSENGERdata
In [2]: initialize_MESSENGERdata()
This will take a while to run (hours probably).
-
To install updates, run:
(nexoclom) [sunra m🍔 /~/]$ pip install --upgrade nexoclom
(nexoclom) [sunra m🍔 /~/]$ pip install --upgrade MESSENGERuvvs
or to update everything:
(nexoclom) [sunra m🍔 /~/]$ conda env update -f nexoclom_environment.yml
-
There are some test files at https://github.com/mburger-stsci/nexoclom/tree/master/test_files/. Download them to any
working directory. Edit the model_testing.py
so that inputfile points to
directory with the Ca.isotropic.flat.input
. Then do:
(nexoclom) [sunra m🍔 /~/]$ python model_testing.py
This should produce something that looks like https://www.stsci.edu/~mburger/nexoclom/Ca_Oribt3576_nexoclom.html
Contributing
We love contributions! nexoclom is open source,
built on open source, and we'd love to have you hang out in our community.
Imposter syndrome disclaimer: We want your help. No, really.
There may be a little voice inside your head that is telling you that you're not
ready to be an open source contributor; that your skills aren't nearly good
enough to contribute. What could you possibly offer a project like this one?
We assure you - the little voice in your head is wrong. If you can write code at
all, you can contribute code to open source. Contributing to open source
projects is a fantastic way to advance one's coding skills. Writing perfect code
isn't the measure of a good developer (that would disqualify all of us!); it's
trying to create something, making mistakes, and learning from those
mistakes. That's how we all improve, and we are happy to help others learn.
Being an open source contributor doesn't just mean writing code, either. You can
help out by writing documentation, tests, or even giving feedback about the
project (and yes - that includes giving feedback about the contribution
process). Some of these contributions may be the most valuable to the project as
a whole, because you're coming to the project with fresh eyes, so you can see
the errors and assumptions that seasoned contributors have glossed over.
Note: This disclaimer was originally written by
Adrienne Lowe for a
PyCon talk, and was adapted by
nexoclom based on its use in the README file for the
MetPy project.