Metadata-Version: 2.1
Name: suncasa
Version: 1.0.8
Summary: "SunCASA: CASA-based Python package for reducing, analyzing, and visualizing solar dynamic spectroscopic imaging data at radio wavelengths"
Home-page: https://github.com/suncasa/suncasa
Author: The EOVSA team
Author-email: sijie.yu@njit.edu
License: BSD 2-Clause
Keywords: solar physics,solar,science,sun,wcs,coordinates
Platform: any
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.8
Classifier: Topic :: Scientific/Engineering :: Physics
Provides: suncasa
Requires-Python: !=3.7.*,<3.11,>=3.6
Description-Content-Type: text/markdown
License-File: LICENSE.rst
Requires-Dist: sunpy[all]
Requires-Dist: PyQt5>=5.15.2
Requires-Dist: h5py
Requires-Dist: hvpy
Provides-Extra: eovsa
Requires-Dist: eovsapy; extra == "eovsa"
Requires-Dist: aipy-eovsa; extra == "eovsa"
Provides-Extra: casa
Requires-Dist: casatools; extra == "casa"
Requires-Dist: casatasks; extra == "casa"
Requires-Dist: casadata; extra == "casa"
Requires-Dist: casaviewer; extra == "casa"
Requires-Dist: casaplotms; extra == "casa"
Provides-Extra: asdf
Requires-Dist: asdf>=2.6.0; extra == "asdf"
Provides-Extra: dask
Requires-Dist: dask[array]>=2.0.0; extra == "dask"
Provides-Extra: database
Requires-Dist: sqlalchemy>=1.3.4; extra == "database"
Provides-Extra: image
Requires-Dist: scikit-image>=0.16.0; extra == "image"
Requires-Dist: scipy>=1.3.0; extra == "image"
Requires-Dist: sunpy>=2.0.0; extra == "image"
Provides-Extra: jpeg2000
Requires-Dist: glymur!=0.9.0,>=0.8.18; extra == "jpeg2000"
Provides-Extra: map
Requires-Dist: matplotlib>=3.1.0; extra == "map"
Requires-Dist: scipy>=1.3.0; extra == "map"
Requires-Dist: sunpy>=2.0.0; extra == "map"
Requires-Dist: ndcube>=1.4.2; extra == "map"
Provides-Extra: net
Requires-Dist: beautifulsoup4>=4.8.0; extra == "net"
Requires-Dist: drms>=0.6.1; extra == "net"
Requires-Dist: pandas>=0.24.0; extra == "net"
Requires-Dist: python-dateutil>=2.8.0; extra == "net"
Requires-Dist: tqdm>=4.32.1; extra == "net"
Requires-Dist: zeep>=3.4.0; extra == "net"
Provides-Extra: timeseries
Requires-Dist: h5netcdf>=0.8.1; extra == "timeseries"
Requires-Dist: h5py>=3.1.0; extra == "timeseries"
Requires-Dist: matplotlib>=3.1.0; extra == "timeseries"
Requires-Dist: pandas>=0.24.0; extra == "timeseries"
Provides-Extra: visualization
Requires-Dist: matplotlib>=3.1.0; extra == "visualization"
Provides-Extra: tests
Requires-Dist: jplephem; extra == "tests"
Requires-Dist: pytest-astropy>=0.8; extra == "tests"
Requires-Dist: hypothesis>=6.0.0; extra == "tests"
Requires-Dist: pytest-doctestplus>=0.5; extra == "tests"
Requires-Dist: pytest-mock; extra == "tests"
Requires-Dist: pytest-mpl>=0.12; extra == "tests"
Requires-Dist: pytest-intercept-remote>=1.2; extra == "tests"
Requires-Dist: tox; extra == "tests"
Provides-Extra: docs
Requires-Dist: astroquery; extra == "docs"
Requires-Dist: jplephem; extra == "docs"
Requires-Dist: packaging; extra == "docs"
Requires-Dist: reproject; extra == "docs"
Requires-Dist: ruamel.yaml; extra == "docs"
Requires-Dist: sphinx; extra == "docs"
Requires-Dist: sphinx-automodapi; extra == "docs"
Requires-Dist: sphinx-changelog>=1.1.0rc1; extra == "docs"
Requires-Dist: sphinx-gallery>=0.9.0; extra == "docs"
Requires-Dist: sunpy-sphinx-theme; extra == "docs"
Provides-Extra: dev
Requires-Dist: eovsapy; extra == "dev"
Requires-Dist: aipy-eovsa; extra == "dev"
Requires-Dist: casatools; extra == "dev"
Requires-Dist: casatasks; extra == "dev"
Requires-Dist: casadata; extra == "dev"
Requires-Dist: casaviewer; extra == "dev"
Requires-Dist: casaplotms; extra == "dev"
Requires-Dist: asdf>=2.6.0; extra == "dev"
Requires-Dist: dask[array]>=2.0.0; extra == "dev"
Requires-Dist: sqlalchemy>=1.3.4; extra == "dev"
Requires-Dist: scikit-image>=0.16.0; extra == "dev"
Requires-Dist: scipy>=1.3.0; extra == "dev"
Requires-Dist: sunpy>=2.0.0; extra == "dev"
Requires-Dist: glymur!=0.9.0,>=0.8.18; extra == "dev"
Requires-Dist: matplotlib>=3.1.0; extra == "dev"
Requires-Dist: scipy>=1.3.0; extra == "dev"
Requires-Dist: sunpy>=2.0.0; extra == "dev"
Requires-Dist: ndcube>=1.4.2; extra == "dev"
Requires-Dist: beautifulsoup4>=4.8.0; extra == "dev"
Requires-Dist: drms>=0.6.1; extra == "dev"
Requires-Dist: pandas>=0.24.0; extra == "dev"
Requires-Dist: python-dateutil>=2.8.0; extra == "dev"
Requires-Dist: tqdm>=4.32.1; extra == "dev"
Requires-Dist: zeep>=3.4.0; extra == "dev"
Requires-Dist: h5netcdf>=0.8.1; extra == "dev"
Requires-Dist: h5py>=3.1.0; extra == "dev"
Requires-Dist: matplotlib>=3.1.0; extra == "dev"
Requires-Dist: pandas>=0.24.0; extra == "dev"
Requires-Dist: matplotlib>=3.1.0; extra == "dev"
Requires-Dist: jplephem; extra == "dev"
Requires-Dist: pytest-astropy>=0.8; extra == "dev"
Requires-Dist: hypothesis>=6.0.0; extra == "dev"
Requires-Dist: pytest-doctestplus>=0.5; extra == "dev"
Requires-Dist: pytest-mock; extra == "dev"
Requires-Dist: pytest-mpl>=0.12; extra == "dev"
Requires-Dist: pytest-intercept-remote>=1.2; extra == "dev"
Requires-Dist: tox; extra == "dev"
Requires-Dist: astroquery; extra == "dev"
Requires-Dist: jplephem; extra == "dev"
Requires-Dist: packaging; extra == "dev"
Requires-Dist: reproject; extra == "dev"
Requires-Dist: ruamel.yaml; extra == "dev"
Requires-Dist: sphinx; extra == "dev"
Requires-Dist: sphinx-automodapi; extra == "dev"
Requires-Dist: sphinx-changelog>=1.1.0rc1; extra == "dev"
Requires-Dist: sphinx-gallery>=0.9.0; extra == "dev"
Requires-Dist: sunpy-sphinx-theme; extra == "dev"
Provides-Extra: all
Requires-Dist: eovsapy; extra == "all"
Requires-Dist: aipy-eovsa; extra == "all"
Requires-Dist: casatools; extra == "all"
Requires-Dist: casatasks; extra == "all"
Requires-Dist: casadata; extra == "all"
Requires-Dist: casaviewer; extra == "all"
Requires-Dist: casaplotms; extra == "all"
Requires-Dist: asdf>=2.6.0; extra == "all"
Requires-Dist: dask[array]>=2.0.0; extra == "all"
Requires-Dist: sqlalchemy>=1.3.4; extra == "all"
Requires-Dist: scikit-image>=0.16.0; extra == "all"
Requires-Dist: scipy>=1.3.0; extra == "all"
Requires-Dist: sunpy>=2.0.0; extra == "all"
Requires-Dist: glymur!=0.9.0,>=0.8.18; extra == "all"
Requires-Dist: matplotlib>=3.1.0; extra == "all"
Requires-Dist: scipy>=1.3.0; extra == "all"
Requires-Dist: sunpy>=2.0.0; extra == "all"
Requires-Dist: ndcube>=1.4.2; extra == "all"
Requires-Dist: beautifulsoup4>=4.8.0; extra == "all"
Requires-Dist: drms>=0.6.1; extra == "all"
Requires-Dist: pandas>=0.24.0; extra == "all"
Requires-Dist: python-dateutil>=2.8.0; extra == "all"
Requires-Dist: tqdm>=4.32.1; extra == "all"
Requires-Dist: zeep>=3.4.0; extra == "all"
Requires-Dist: h5netcdf>=0.8.1; extra == "all"
Requires-Dist: h5py>=3.1.0; extra == "all"
Requires-Dist: matplotlib>=3.1.0; extra == "all"
Requires-Dist: pandas>=0.24.0; extra == "all"
Requires-Dist: matplotlib>=3.1.0; extra == "all"

# suncasa

[![pypi](https://img.shields.io/pypi/v/suncasa.svg)](https://pypi.python.org/pypi/suncasa/)

[suncasa](https://github.com/suncasa/suncasa-src) is a Python wrapper around [CASA](https://casa.nrao.edu/) for
importing, calibrating, synthesis imaging and visualizing solar spectral imaging data. CASA is one of the leading
software tools for "supporting the data post-processing needs of the next generation of radio astronomical telescopes
such as ALMA and VLA, an international effort led by
the [National Radio Astronomy Observatory (NRAO)](https://public.nrao.edu/). The current version of CASA uses Python 3.6
to 3.8 on most of the platforms. More information about the compatibility of CASA can be found
on [CASA Compatibility](https://casadocs.readthedocs.io/en/latest/notebooks/introduction.html#Compatibility/).
> **_NOTE:_** CASA is available ONLY on unix-based platforms, and therefore, so as for suncasa. CASA software is compatible with multiple LINUX and Mac computer operating systems, as well as multiple versions of Python. Please refer to the [Compatibility Matrix](https://casadocs.readthedocs.io/en/latest/notebooks/introduction.html#Compatibility) for detailed information on the Operating Systems and Python versions expected to work with current and future versions of CASA.

> **_NOTE:_**  If you're using Windows, you'll need to install a virtual machine running a Linux system. For detailed instructions, please refer to this [guidance](https://docs.google.com/document/d/1DuRoVSVEwHOSIntbYYecXYxC8_pKt-oJ2UK_Q5Ye-vE/edit?usp=sharing).

In principle, suncasa an casa can be installed easily using [pip](https://pypi.org/project/suncasa/), assuming the right
python version is in use. However, YMMV if your do not have prerequisite environment configured.The followinig tutorial
demonstrates the installation of **suncasa** in **python 3.8** environment on **MacOS 12** and **Ubuntu 18.04.6 LTS**.

Full installation instructions of the standalone CASA package (as a Linux (.tar) or Mac (.dmg) files) including the
build-in Python environment are available from NRAO [Downloads](http://casa.nrao.edu/casa_obtaining.shtml)
page ([http://casa.nrao.edu/casa_obtaining.shtml](http://casa.nrao.edu/casa_obtaining.shtml))

The CASA 6.x series is also available as modular packages, giving users the flexibility to build CASA tools and tasks in
their own Python environment. This includes the casatools, casatasks, and casampi modules, allowing for core data
processing capabilities in parallel.

<hr />

**If you want to use full funtionalities provided by the standalone CASA, please go through all steps.**

**If you just want to install SUNCASA with the modular CASA option in the usual "Pythonic" manner, after Step 1 (Python
installation), you can skip Step 2 and go directly to Step 3.**

<hr />

## Step 1: Python 3.8 Installation[](#installation)

(Adapted from [this tutorial](https://casadocs.readthedocs.io/en/latest/notebooks/introduction.html#id1))

### Prerequisite OS Libraries[](#Prerequisite-OS-Libraries)

CASA requires certain libraries be installed in the users operating system. Some may already be present by default. In
case they are not, the following list should be checked before using CASA or if errors are encountered at runtime.
Commands and package names are for Red Hat Linux, but equivalents can be found for other Linux distributions.

**On Linux:**

A system administrator may be required to install OS libraries. One can
use [yum](https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/system_administrators_guide/ch-yum) (
RHEL) or [apt-get](https://help.ubuntu.com/community/AptGet/Howto) (Ubuntu) to install the missing libraries. For
example, for RHEL8 the following OS libraries should be installed:

```bash
sudo yum install libgfortran3
sudo yum install ImageMagick*
sudo yum install xorg-x11-server-Xvfb
sudo yum install compat-libgfortran-48
sudo yum install libnsl
sudo yum install libcanberra-gtk2
```

For modular CASA, one must supply their own Python environment. There are many, including ipython and Jupyter, here is a
basic example for
RHEL8 ([yum](https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/system_administrators_guide/ch-yum))
and Ubuntu ([apt-get](https://help.ubuntu.com/community/AptGet/Howto)), respectively.

```bash
sudo yum install python38-devel
```

```bash
sudo apt install python3.8 python3.8-venv python3-venv
```

**On Macintosh:**

Install [XQuartz](https://www.xquartz.org/)
and [Xcode](https://apps.apple.com/us/app/xcode/id497799835?mt=12).

[comment]: <> (gcc &#40;[brew]&#40;https://brew.sh/&#41; install&#41;,)

Same as for Linux, one must supply their own Python environment for modular CASA. Here is an example for MacOS to
install python 3.8 using PyEnv.

Clone pyenv to a local directory (e.g., `$HOME/.pyenv`):

```bash
git clone https://github.com/pyenv/pyenv.git $HOME/.pyenv
```

Set up your shell environment for Pyenv. Assuming you are using **bash**, add the configuration commands to `~/.bashrc`
by running the following in your terminal:

~~~bash
bash
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc
echo 'command -v pyenv >/dev/null || export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc
echo 'eval "$(pyenv init -)"' >> ~/.bashrc
~~~

Install the Python 3.8.

```bash
pyenv install 3.8.16
```

> **_Troubleshooting:_** If you encounter an error that "C compiler cannot create executables" then the simplest way to solve this is to reinstall Apple's [Xcode](https://apps.apple.com/us/app/xcode/id497799835?mt=12). Xcode is a tool created by Apple that includes all the C libraries and other tools that Python uses when it runs on MacOS. Xcode is a whopping 11 gigabytes, but you'll want to be up-to-date. You may want to run this while you're sleeping. Once it is done, just re-run the above `pyenv install 3.8.16` and it should now work.

Now you can set this version of Python to be the **current** version of Python MacOS uses. This setting is temporary.

```bash
pyenv global 3.8.16
```

If you want to set this version of Python to the the **default** version of Python, add the configuration command
to `~/.bashrc`.

```bash
echo 'pyenv global 3.8.16' >> ~/.bashrc
```

### Step 2: CASA (Standalone Monolithic Distribution) Installation [](#Monolithic-CASA-Distribution)

Download the standalone CASA package (as a Linux (.tar) or Mac (.dmg) files) including the build-in Python environment
following
[http://casa.nrao.edu/casa_obtaining.shtml](http://casa.nrao.edu/casa_obtaining.shtml).

**On Linux:**

1. Download the .tar file and place it in a work directory (e.g. `$HOME/casa`).

2. From a Linux terminal window:
   ~~~ bash
   tar -xvf casa-xyz.tar.xz
   $HOME/casa/casa-xyz/bin/casa
   ~~~ 
3. Add casa to environment `PATH`. Assuming you are using *bash*, add the configuration commands to `~/.bashrc` by
   running the following in your terminal:

   ~~~ bash
   echo 'export CASAROOT="$HOME/casa/casa-xyz/"' >> ~/.bashrc
   echo 'export PATH="$PATH:$CASAROOT/bin"' >> ~/.bashrc
   ~~~


4. Restart your shell for the `PATH` changes to take effect.

  ```sh
  exec "$SHELL"
  ```    

You can now start casa.

  ```sh
  casa
  ```  

The one caveat is that CASA on Linux currently will not run if the Security-Enhanced Linux option of the linux operating
system is set to enforcing. For the non-root install to work, SElinux must be set to disabled or permissive (in _
/etc/selinux/config_) or you must run (as root): `$: setsebool -P allow_execheap=1`. Otherwise, you will encounter
errors like:

error while loading shared libraries: /opt/casa/casa-20.0.5653-001/lib/liblapack.so.3.1.1: cannot restore segment prot
after reloc: Permission denied_

> **_WARNING:_** By default, python 3.6 (and earlier versions of python 3) include the current working directory in the python path at startup. Any script in that directory with the same name as a standard python module or a CASA module will be detected and used by python instead of the code that is delivered with CASA. Protections have been included for files called “new.py” and “pickle.py”, but other scripts may cause problems with the CASA startup. For example, do not include a file named runpy.py in the working directory.

**On Macintosh:**

1. Download the .dmg disk image file

2. Double click on the disk image file (if your browser does not automatically open it).

3. Drag the CASA application to the _Applications_ folder of your hard disk.

4. Eject the CASA disk image.

5. Double click the CASA application to run it for the first time. If the OS does not allow you to install apps from
   non-Apple sources, please Change the settings in “System Preferences-> Security & Privacy -> General” and “Allow
   applications downloaded from: Mac App store and identified developers”.

6. Optional: Create symbolic links to the CASA version and its executables (Administrator privileges are required),
   which will allow you to run `casa`, `casaviewer`, `casaplotms`, etc. from any terminal command line. To do so, run

```console
 !create-symlinks
```   

### Step 3: Install SUNCASA (along with CASA modular version) [](#Modular-Packages)

Pip wheels for casatools, casatasks, as well as suncasa are available as Python 3 modules. This allows simple
installation and import into standard Python environments. Make sure you have set up your machine with the _necessary
prerequisite libraries_ first. Then a separate installation of desired modules (from a unix terminal window) as follows.
First create a Python virtual environment named `suncasaenv` under the `$HOME` directory:

```bash
cd $HOME
python3.8 -m venv suncasaenv
```

> **_NOTE:_**  We strongly recommend using a Python virtual environment to prevent breaking any packages within a pre-existing Python environment.

Then use [pip](https://pypi.org/project/suncasa/) to install suncasa within the newly-created virtual environment:

```bash
source suncasaenv/bin/activate
pip install --upgrade pip
pip install suncasa
```

> **_NOTE:_**  If this does not work, it could be due to unsuccessful installation of some dependencies. Running these commands should address this.

```bash
pip install casatasks
pip install casatools
pip install casadata
pip install PyQt5
pip install sunpy[all]
pip install suncasa
```

To exit the python venv, type `deactivate` from the terminal. However, the rest of this tutorial **assumes the venv is
active** (to reactivate, type `source $HOME/suncasaenv/bin/activate`)

You can update suncasa to its latest version by running:

```bash
pip install --upgrade suncasa
```

**Sanity check**

With the pip installation, suncasa as well as CASA may be used in a standard Pythonic manner. For example, suncasa
modules and CASA tasks can be invoked using “import”, while CASA tools first need to be instantiated:

```console
(suncasaenv) $ ipython
In [1]: import suncasa
In [2]: help(suncasa)
In [3]: import casatasks
In [4]: help(casatasks)
```

The use of python3 venv is a simple built-in method of containerizing the pip install such that multiple versions of
suncasa can be kept on a single machine in different environments. In addition, suncasa is built and tested using
standard python 3.8 libraries (backward compatible) which can be replicated with a fresh venv, keeping the libraries
needed for suncasa isolated from other libraries which may already be installed on your machine.

Note that you need to have `ipython` installed in your environment to run the above commands. If you don't have it, run

```bash
pip install ipython
```

**Add EOVSA to CASA observatories list**

The following command creates a configuration file to define the EOVSA instrument so that CASA is aware of it. We plan
to add EOVSA officially to the CASA distribution in the future, after which this step is unnecessary.

```bash
printf "import sys \nimport os \nimport sysconfig \nimport casatools \nimport casadata \nimport time \nlogfile='casalog-{}.log'.format(time.strftime('%%Y%%m%%d-%%H',time.localtime())) \ntelemetry_enabled = False \ncrashreporter_enabled = True \ntb=casatools.table() \nospathsep = os.path.sep \nlibpath = sysconfig.get_paths()['purelib'] \nobsdict = {'MJD': 57447.0, 'Name': 'EOVSA', 'Type': 'WGS84', 'Long': -118.287, \n            'Lat': 37.2332, 'Height': 1207.13, 'X': 0.0, 'Y': 0.0, 'Z': 0.0,  \n            'Source': 'Dale Gary'} \nobstable = os.path.join(casadata.datapath,'geodetic','Observatories') \ntb.open(obstable, nomodify=True) \nif 'EOVSA' not in tb.getcol('Name'): \n    print('Adding EOVSA to the Observatories') \n    tb.close() \n    tb.open(obstable, nomodify=False) \n    nrows = tb.nrows() \n    tb.addrows(1) \n    for k in obsdict.keys(): \n        tb.putcell(k, nrows, obsdict[k])     \ntb.close() \n" > $HOME/.casa/config.py
```

***Last but not least, add the `site-packages` path where the suncasa and its dependent packages installedd to the
Monolithic CASA***

```bash
echo "sitepackagepath = '$HOME/suncasaenv/lib/python3.8/site-packages'" >> $HOME/.casa/config.py
echo "if sitepackagepath not in sys.path:" >> $HOME/.casa/config.py
echo "    sys.path.append(sitepackagepath)"     >> $HOME/.casa/config.py
```

> **_note:_** The `sitepackagepath` may varies for python versions on different platforms.


**Note for Mac M1 users**: For macOS 12 on an ARM-based M1 chip, users will need to install the wheels of CASA version
11 for intel architecture. For that, we recommend to install [Apple Rosetta](https://support.apple.com/en-us/HT211861) to enable a Mac with Apple silicon to use
apps made for an Intel processor ([How-to](https://medium.com/mkdir-awesome/how-to-install-x86-64-homebrew-packages-on-apple-m1-macbook-54ba295230f)). 

By now you can use the following command to pip install the CASA wheels:

```bash
arch -x86_64 python3.8 -m pip install ...
```

