Developer Guide

Getting started

This guide is for developers who want to contribute to the FDP project, and this guide describes the development workflow on the PPPL Linux cluster. If you simply want to use FDP on the PPPL Linux cluster, see the user guide.

The FDP code repository is hosted on GitHub: https://github.com/Fusion-Data-Platform/fdp

To participate in the FDP project as a developer, you must create a GitHub account. The FDP project uses GitHub and Git for collaborative development and version control.

Configure Git

On the PPPL Linux cluster, load the module git/1.8.0.2 (on Red Hat 6 systems, use git/2.4.2):

[sunfire08:~] % module avail git
--------------------- /usr/pppl/Modules/modulefiles -------------------
git/1.7.4.1(default)     git/1.8.0.2      git/2.4.2

[sunfire08:~] % module load git/1.8.0.2

[sunfire08:~] % module list
Currently Loaded Modulefiles:
1) torque/2.5.2      3) ppplcluster/1.1
2) moab/5.4.0        4) git/1.8.0.2

You may want to add the module load command to your shell start-up files: ~/.cshrc for csh/tcsh or ~/.bash_profile for bash.

Next, you must configure Git with your name and email (the same email associated with your GitHub account):

[sunfire08:~] % git config --global user.name "John Doe"
[sunfire08:~] % git config --global user.email "JohnDoe@email.com"

Also, you may want to set a default editor (e.g. vi, emacs, nedit) for Git comments:

[sunfire08:~] % git config --global core.editor nedit

You can inspect your Git configuration in the file ~/.gitconfig. For more information about Git configuration, see https://help.github.com/articles/set-up-git/ or https://git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup

Clone the FDP repository

Git clones repositories into a new directory in your current directory. In the right column of the FDP repo page (https://github.com/Fusion-Data-Framework/fdp), you can find the HTTPS URL (https://github.com/Fusion-Data-Framework/fdp.git) to clone FDP to your local directory

[sunfire08:~] % ls -d fdp
ls: fdp: No such file or directory

[sunfire08:~] % git clone https://github.com/Fusion-Data-Framework/fdp.git
Cloning into 'fdp'...
remote: Counting objects: 619, done.
remote: Total 619 (delta 0), reused 0 (delta 0), pack-reused 619
Receiving objects: 100% (619/619), 783.01 KiB, done.
Resolving deltas: 100% (279/279), done.

[sunfire08:~] % ls -d fdp
fdp/

Cloning via SSH is also feasible: https://help.github.com/articles/set-up-git/#next-steps-authenticating-with-github-from-git

Finally, add your new FDP directory to the PYTHONPATH environment variable:

[sunfire08:~] % setenv PYTHONPATH ${HOME}/fdp:$PYTHONPATH

[sunfire08:~] % echo $PYTHONPATH
/u/drsmith/fdp:<other directories>

You may want to add this action to your shell start-up files, as described above. In bash, use the export command to set PYTHONPATH.

Git workflow for FDP development

(1) Create a development branch (here, we call it devbranch) and checkout the new branch:

[sunfire08:~] % cd fdp

[sunfire08:~/fdp] % git branch
* master

[sunfire08:~/fdp] % git branch devbranch

[sunfire08:~/fdp] % git branch
devbranch
* master

[sunfire08:~/fdp] % git checkout devbranch
Switched to branch 'devbranch'

[sunfire08:~/fdp] % git branch
* devbranch
master

Devbranch initializes as a copy of master. git branch lists branches in your local repository, and the asterisk denotes the active branch. You can switch between local branches with git checkout <LocalBranchName>.

(2) Push devbranch to the remote FDP repository at GitHub (you may need to enter your GitHub username and password):

[sunfire08:~/fdp] % git push origin devbranch
Total 0 (delta 0), reused 0 (delta 0)
To https://github.com/Fusion-Data-Framework/fdp.git
 * [new branch]      devbranch -> devbranch

devbranch is now listed in the FDP repository at GitHub. origin is the alias for the remote GitHub repository. You can view your remote repositories and aliases with git remote -v.

(3) Proceed with FDP development within devbranch: commit changes, add/delete files, and push updates to GitHub.

As you complete small tasks, you should commit changes to your local repository with git commit -a -m '<mymessage>'. Also, each commit requires a short message describing the changes:

[sunfire02:~/fdp] % git commit -a -m 'added dictionary rows in logbook.py'
[devbranch bb6c58a] added dictionary rows in logbook.py
1 file changed, 16 insertions(+), 21 deletions(-)

If you do not specify a commit message with -m option, then Git will open your default editor and ask for a commit message (see Configure Git above). The -a option commits all file changes throughout the branch index, not simply your current directory. The branch index is the list of files Git tracks in the branch. git commit -a tracks changes to files in the branch index, so you must add new files to the index and remove deleted files from the index. You can view the branch index with git ls-files, and you can add new files to the index and remove deleted files from the index with git add -A:

[sunfire02:~/fdp] % touch temp.py

[sunfire02:~/fdp] % ls temp.py
temp.py

[sunfire02:~/fdp] % git ls-files temp.py

[sunfire02:~/fdp] % git add -A

[sunfire02:~/fdp] % git ls-files temp.py
temp.py

Note that temp.py appeared in the index only after the command git add -A. Similarly, deleted files stay in the index until the git add -A is given.

When you complete a large task, you should “push” changes to the devbranch on GitHub with git push:

[sunfire05:~/fdp] % git push origin devbranch
Counting objects: 10, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (6/6), done.
Writing objects: 100% (6/6), 1.30 KiB, done.
Total 6 (delta 3), reused 0 (delta 0)
To https://github.com/Fusion-Data-Framework/fdp.git
    129c5d9..a166825 devbranch -> devbranch

Again, “origin” signifies the branches on the remote GitHub repo.

(4) While you are working locally in devbranch, others may be modifying master at GitHub. When you are ready to merge devbranch into master, you should first merge the latest version of master from GitHub into your local devbranch. To retrieve the latest version of master from GitHub, use git fetch:

[sunfire05:~/fdp] % git fetch origin master
From https://github.com/Fusion-Data-Framework/fdp
* branch            master     -> FETCH_HEAD

Next, verify that you are in devbranch and merge origin/master into devbranch:

[sunfire08:~/fdp] % git branch
* devbranch
master

[sunfire05:~/fdp] % git merge origin/master

Next, push your local devbranch to devbranch on GitHub:

[sunfire05:~/fdp] % git push origin devbranch

Finally, on the GitHub website, in the devbranch area, submit a pull request to pull devbranch into master.

Package reference

Subpackage fdp.classes

fdp.classes contains FDP source code.

Subpackage fdp.methods

fdp.methods contains methods for FDP objects (e.g. a plot method, >>> mpts.te.plot()). Methods can be specified at different levels: global, machine-specific, or diagnostic-specific.

Class Fdp

class fdp.classes.fdp.Fdp[source]

The primary data object in FDP and the top-level container for machines.

An instance of fdp.classes.fdp.Fdp is mapped to the top-level fdp package in fdp.__init__.py.

Usage:

>>> import fdp
>>> dir(fdp)
['cmod', 'diiid', 'nstxu']
>>> nstxu = fdp.nstxu

Class Machine

class fdp.classes.machine.Machine(name='nstxu', shotlist=[], xp=[], date=[])[source]

Factory root class that contains shot objects and MDS access methods.

Note that fdf.factory.Machine is exposed in fdf.__init__, so fdf.Machine is valid.

Usage:

>>> import fdf
>>> nstxu = fdf.nstxu
>>> nstxu.s140000.logbook()
>>> nstxu.addshots(xp=1048)
>>> nstxu.s140000.mpts.plot()
>>> nstxu.listshot()

Machine class contains a model shot object: nstxu.s0

Shot data can be accessed directly through the Machine class:

>>> nstxu.s141398
>>> nstxu.s141399
addshot(shotlist=[], date=[], xp=[], verbose=False)[source]

Load shots into the Machine class

Usage

>>> nstxu.addshot([140000 140001])
>>> nstxu.addshot(xp=1032)
>>> nstxu.addshot(date=20100817, verbose=True)

Note: You can reference shots even if the shots have not been loaded.

filter_shots(date=[], xp=[])[source]

Get a Machine-like object with an immutable shotlist for XP(s) or date(s)

Class Logbook

class fdp.classes.logbook.Logbook(name='nstxu', root=None)[source]

Class Shot

class fdp.classes.shot.Shot(shot, root=None, parent=None)[source]

Class Container

class fdp.classes.container.Container(module_tree, top=False, **kwargs)[source]

Container class

Class Signal

class fdp.classes.fdpsignal.Signal(**kwargs)[source]

sig=fdp.Signal(signal_ndarray, units=’m/s’, axes=[‘radius’,’time’], axes_values=[ax1_1Darray, ax2_1Darray], axes_units=[‘s’,’cm’]

e.g.: mds.Signal(np.arange((20*10)).reshape((10,20)), units=’keV’, axes=[‘radius’,’time’], axes_values=[100+np.arange(10)*5, np.arange(20)*0.1], axes_units=[‘s’,’cm’])

or an empty signal: s=mds.Signal() default axes order=[time, space] sig=fdp.Signal(units=’m/s’, axes=[‘radius’,’time’], axes_values=[radiusSignal, timeSignal])

Class Node

class fdp.classes.node.Node(element, parent=None)[source]

Node class

Module fdp.classes.fdp_globals

Package-level attributes, methods, and FdfError class

Created on Thu Jun 18 11:18:16 2015

@author: ktritz

fdp.classes.fdp_globals.EVENT_SERVERS = {'ltx': 'lithos.pppl.gov:8000', 'nstxu': 'skylark.pppl.gov:8501'}

Dictionary: machine-name key paired to MDS server

fdp.classes.fdp_globals.FDP_DIR = '/u/drsmith/fdp/fdp/classes/..'

Path string: top-level directory for FDF package

exception fdp.classes.fdp_globals.FdpError(message='')[source]

Error class for FDF package

Usage:

raise FdfError('error message')
exception fdp.classes.fdp_globals.FdpWarning(message='')[source]

Warning class for FDF package

Usage:

raise FdpWarning('warning message')
fdp.classes.fdp_globals.LOGBOOK_CREDENTIALS = {'nstxu': {'username': 'drsmith', 'database': 'nstxlogs', 'server': 'sql2008.pppl.gov\\sql2008', 'table': 'entries', 'password': 'pfcworld', 'port': '62917'}}

Dictionary: machine-name key paired with logbook login credentials

Module fdp.classes.factory

Created on Thu Jun 18 10:38:40 2015 @author: ktritz