Skip to content
Snippets Groups Projects
Select Git revision
  • ae9868f9f220a0ce02a4f3bff7e8c29b024b6843
  • master default protected
  • gec-95-add-filter-skymodel
  • gec-105-lint-skymodel-filter
  • add-coverage-badge
  • releases/1.6
  • releases/1.5
  • rap-457-implement-ci-v2
  • test_heroku
  • action-python-publish
  • v1.7.1
  • v1.7.0
  • v1.6.2
  • v1.6.1
  • v1.6.post1
  • v1.6
  • v1.5.1
  • v1.5.0
  • v1.4.11
  • v1.4.10
  • v1.4.9
  • v1.4.8
  • v1.4.7
  • v1.4.6
  • v1.4.5
  • v1.4.4
  • v1.4.3
  • v1.4.2
  • v1.4.1
  • v1.4.0
30 results

LSMTool

  • Clone with SSH
  • Clone with HTTPS
  • LSMTool: the LOFAR Sky Model Tool

    LSMTool allows the manipulation of LOFAR sky models (in the makesourcedb format).

    Author:

    • David Rafferty

    Based on contributed scripts by:

    • Bjoern Adebahr
    • Francesco de Gasperin
    • Reinout van Weeren

    Contents:

    • docs/: documentation
    • tests/: contains test sky models and scripts useful for validation
    • bin/: contains lsmtool executable
    • lsmtool/: contains the main LSMTool scripts
    • lsmtool/operations/: contains the modules for operations
    • parsets/: some example parsets

    The following operations are available:

    • SELECT: Select sources by source or patch properties
    • REMOVE: Remove sources by source or patch properties
    • TRANSFER: Transfer a patch scheme from one sky model to another
    • GROUP: Group sources into patches
    • UNGROUP: Remove patches
    • MOVE: Move a source or patch position
    • MERGE: Merge two or more patches into one
    • CONCATENATE: Concatenate two sky models
    • ADD: Add a source
    • SETPATCHPOSITIONS: Calculate and set patch positions
    • PLOT: Plot the sky model
    • COMPARE: Compare source fluxes and positions of two sky models

    For details, please see the full documentation.

    Installation

    LSMTool is already installed on the LOFAR CEP3 cluster. Users on CEP3 should run the following commands before using LSMTool:

    source ~rafferty/init_lsmtool

    If you want to install LSMTool yourself, follow the instructions below.

    Dependencies

    Downloading and Installing

    Get the latest developer version by cloning the git repository:

    git clone https://github.com/darafferty/LSMTool.git

    Then install with:

    cd LSMTool
    python setup.py install

    If you have a C++11-compliant compiler, you can build a faster version of the mean shift grouping algorithm with:

    cd LSMTool
    python setup.py install --build_c_extentions

    Note that the C++ version will give slightly different results compared to the Python version, but such differences are not expected to be important in practice.

    Testing

    You can test that the installation worked with:

    python setup.py test

    If no errors occur, LSMTool is installed correctly.

    Usage

    The LSMTool executable can be used from the command line with a parset that defines the steps to be done. E.g.:

    $ lsmtool model.sky lsmtool.parset

    The parset follows the usual NDPPP/BBS format. E.g.:

    # Select individual sources with Stokes I fluxes above 1 Jy
    LSMTool.Steps.select.Operation = SELECT
    LSMTool.Steps.select.FilterExpression = I > 1.0 Jy
    LSMTool.Steps.select.OutFile = out_model.sky

    LSMTool can also be used in Python scripts by importing the lsmtool module. E.g.:

    >>> import lsmtool
    >>> skymod = lsmtool.load('model.sky')
    >>> skymod.select('I > 1.0 Jy')
    >>> skymod.write('out_model.sky')

    For further details, please see the full documentation.