Feature #833

Add functions to public Gammalib API

Added by Deil Christoph about 11 years ago. Updated over 10 years ago.

Status:ClosedStart date:04/12/2013
Priority:NormalDue date:
Assigned To:Knödlseder Jürgen% Done:

50%

Category:-
Target version:00-08-00
Duration:

Description

As discussed in issues #558 and #832, the gammalib API will contain functions (currently it only contains classes).

Here’s an example of a function that should be available, as it’s used all the time for gamma-ray data analysis:
https://github.com/cdeil/gammalib/compare/significance

TODOs:
  • Decide on naming convention for functions and how to expose them in C++ (namespace or prefix).
  • Expose the function in Python (add Swig wrapper)
  • Document function coding conventions.

For the Li & Ma significance function specifically I can write unit tests (I just adapted some Python code I had, I didn’t even check yet if it works).


Recurrence

No recurrence.


Subtasks

Action #835: Expose the function in Python (add Swig wrapper)ClosedKnödlseder Jürgen

Action #836: Document function coding conventionsClosedKnödlseder Jürgen

Action #837: Move GWcslib trigonometric functions into public namespac...ClosedKnödlseder Jürgen

Action #834: Decide on naming convention for functions and how to expo...Closed

History

#1 Updated by Deil Christoph about 11 years ago

In the significance branch I linked to the li_ma_significance function works:

In [3]: gammalib.li_ma_significance(10, 20, 0.1)
Out[3]: 3.6850322319420274

I’ll now try to put it in a gamma namespace and see if the Makefiles work.

#2 Updated by Knödlseder Jürgen about 11 years ago

  • % Done changed from 0 to 10

I just wrote up a Naming conventions draft in the Wiki.

#3 Updated by Knödlseder Jürgen about 11 years ago

  • Target version set to 00-08-00

#4 Updated by Knödlseder Jürgen about 11 years ago

Christoph Deil wrote:

TODOs:
  • Decide on naming convention for functions and how to expose them in C++ (namespace or prefix).
  • Expose the function in Python (add Swig wrapper)
  • Document function coding conventions.

TODOs are “Actions” in the Redmine tracker that are appended to a feature. Just created these actions, can now be easily see in the Agile taskboard: https://cta-redmine.irap.omp.eu/rb/taskboards/23

#5 Updated by Deil Christoph about 11 years ago

I just updated https://github.com/cdeil/gammalib/compare/significance .
It was just for me to play around with tough ... we don’t have to merge it.
I can add this function properly once the functions in gammalib issues have been decided.

One question I have is whether e.g. the gammln function in GNumerics should be in the gammalib namespace and if it should be part of the public GammaLib API. I think it currently is included by GammaLib.hpp, but maybe it shouldn’t, because it is an internal implementation detail?

#6 Updated by Knödlseder Jürgen about 11 years ago

I would make it public using the gammalib namespace, as somebody may need it for his own calculations. For the moment there is just a single function in GNumerics, but the idea was to add more ... (for example your Li and Ma function).

#7 Updated by Knödlseder Jürgen about 11 years ago

Created branch function-namespace where all GTools constants are now in gammalib namespace.

Port now the GTools into the gammalib namespace.

#8 Updated by Knödlseder Jürgen about 11 years ago

Christoph Deil wrote:

I just updated https://github.com/cdeil/gammalib/compare/significance .
It was just for me to play around with tough ... we don’t have to merge it.
I can add this function properly once the functions in gammalib issues have been decided.

One question I have is whether e.g. the gammln function in GNumerics should be in the gammalib namespace and if it should be part of the public GammaLib API. I think it currently is included by GammaLib.hpp, but maybe it shouldn’t, because it is an internal implementation detail?

I now placed all constants and functions in the gammalib namespace. Pushed in devel.

You may now add your function, the only question being: where? In fact, I renamed GNumerics to GMath, as the only function that was in there was an elementary mathematical functions. I also added a bunch of other mathematical functions that were in GTools and GWcslib, so that they are now centralized. I also moved all mathematical constants from GTools to GMath.

The Li and Ma function would not be a mathematical function. It could go in GTools (there are still other functions in there, mostly string and conversion function, but also functions for analytical power law integrations, for example).

#9 Updated by Knödlseder Jürgen about 11 years ago

  • Status changed from In Progress to Feedback

#10 Updated by Deil Christoph about 11 years ago

Is it possible to make the C++ and Python API consistent by putting the functions and constants also in a gammalib namespace?
At the moment they are in the top-level namespace (and not reachable via `from gammalib import *` I believe):
```
In [8]: import gammalib

In [9]: gammalib.gammln(42)
Out9: 114.03421178150786

In [10]: gammalib.gammalib
Out10: <module 'gammalib’ from '/usr/local/gamma/lib/python2.7/site-packages/gammalib/__init__.pyc’>
```

#11 Updated by Knödlseder Jürgen about 11 years ago

Christoph Deil wrote:

Is it possible to make the C++ and Python API consistent by putting the functions and constants also in a gammalib namespace?
At the moment they are in the top-level namespace (and not reachable via `from gammalib import *` I believe):
```
In [8]: import gammalib

In [9]: gammalib.gammln(42)
Out9: 114.03421178150786

In [10]: gammalib.gammalib
Out10: <module 'gammalib’ from '/usr/local/gamma/lib/python2.7/site-packages/gammalib/__init__.pyc’>
```

This is done now, and merged in the devel branch. Have a look at the new matrix_howto.py file in the examples/python folder to see this at work.

#12 Updated by Knödlseder Jürgen over 10 years ago

  • Status changed from Feedback to Closed
  • Assigned To set to Knödlseder Jürgen

Also available in: Atom PDF