Skip to main content

A module containing useful methods for working with fact

Project description

A python package with utils to work with the FACT Imaging Cerenkov Telescope

install with

$ pip install pyfact

This takes automatically care of the dependencies which are installable with pip.

However, if you want to use the GUI Event Viewer you will need to install Tk before you install matplotlib as it depends on the tkagg backend.

functions:

fact includes several functions to convert the times used in fact data to more standard formats and vice versa.

e.g. :

from fact import run2dt

# convert fact fNight format to python datetime object:
date = run2dt("20150101")

Submodules

plotting

Utils for plotting data into a FACT camera view. Based on matplotlib.

import matplotlib.pyplot as plt
import fact.plotting as factplot
from numpy.random import normal

# create some pseudo data with shape (10, 1440):
data = normal(30, 5, (10, 1440))

factplot.camera(data[0])
plt.show()

Or you can start an interactive Viewer which lets you click through the events and save the images:

from fact.plotting import Viewer
from numpy.random import poisson

# pseudo data:
data = poisson(30, (10, 1440))

# call the Viewer with data and a label for the colorbar:
Viewer(data, "label")

There are also functions to get the camera_geometry from the delivered source file:

from fact.plotting import get_pixel_coords

pixel_x, pixel_y = get_pixel_coords()

factdb

This module contains peewee Models for our factdata MySQL database. These were automatically created by peewee and provide means to query this database in python without writing raw sql queries.

For example, to get the total number of runs take by FACT you can do:

from fact.factdb import connect_database, RunInfo

connect_database()  # this uses the credentials module if no config is given

num_runs = RunInfo.select().count()

A few convenience functions are already implemented. To get a pandas.DataFrame containing the observation time per source and runtype, you can do:

from fact.factdb import connect_database, get_ontime_per_source_and_runtype

connect_database()

num_runs = RunInfo.select().count()
print(get_ontime_by_source_and_runtype())

auxservices

Utilities to read in our aux fits files into pandas dataframes.

from fact.auxservices import MagicWeather
from datetime import date

weather = MagicWeather(auxdir='/fact/aux/')

df = weather.read_date(date(2016, 1, 1))

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyfact-0.10.3.tar.gz (79.3 kB view details)

Uploaded Source

File details

Details for the file pyfact-0.10.3.tar.gz.

File metadata

  • Download URL: pyfact-0.10.3.tar.gz
  • Upload date:
  • Size: 79.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pyfact-0.10.3.tar.gz
Algorithm Hash digest
SHA256 fad01853102292c8ef878b69e7b468f7c483d5ea26df931fa92302632510d5e6
MD5 66734c542943f629a7049c8c9ed9059f
BLAKE2b-256 117d751eda4bdec7fad3d54ccbee61da4b6caa76b67dc2edf96315a1b36d9473

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page