Users running a real-time observing session with the Photon Ranch web application need to verify the quality of their incoming images. QuickAnalysis is a server for running image analysis tasks that will make this verification faster and easier than having users download images for local analysis.
This repository defines the server-side image analysis for Photon Ranch observing sessions. To assess the quality of incoming images, users can get a line profile for a given line, as well as statistics (mean, mode, median, min, max, std, median abs deviation) or a histogram of their image or of a rectangular subregion of their image.
Example use of the different API endpoints in the frontend are shown below.
This application is designed to work with the AWS configuration used by photon ranch. Ensure your system has the appropriate photon ranch AWS credentials and config files in order to run this application on your machine.
Set up a virtual environment
Using a virtual environment is highly recommended. Create and activate the virtual environment with python >= 3.7 and install the dependencies in requirements.txt
.
(venv) python -m pytest
(venv) python application.py
The quickanalysis server should now be accessible from http://127.0.0.1:5000!
Deployment happens automatically when changes are pushed to the main, dev, or test branches. But you can also manually deploy the application using the Elastic Beanstalk CLI.
You will need the Elastic Beanstalk (eb) CLI, which should be available if you installed everything in requirements.txt.
Otherwise, run $ pip install awsebcli
.
Additionally, ensure that you have AWS credentials configured on your machine.
If this is a new environment, initialize Elastic Beanstalk with $ eb init
.
Select the region us-east-1
, select the quickanalysis
application, select no
for CodeCommit.
We currently have three environments: quickanalysis-test
, quickanalysis-dev
, and quickanalysis-prod
.
Ensure the one you want to use is selected with $ eb list
, or select one with $ eb use [environment]
.
With CLI initialized and configured, we can deploy by running $ eb deploy
.
For more information on using the eb CLI, please refer to the AWS documentation.
Monitoring and debugging are both possible through the Elastic Beanstalk console.
You can navigate to the console on your own, or with the eb CLI by running $ eb console
.
Logs can also be retrieved directly in your terminal with $ eb logs
.
This server is accessible at http://quickanalysis.photonranch.org/. Available endpoints are described below:
- POST
/lineprofile
-
Description: Given the filename of an image in Photon Ranch and a line (start and end point), return an array of intensities. The points defining the line are relative to the image dimensions. (e.g. (0.5, 0.5) would be a point in the middle of the image.)
-
Authorization required: No
-
Request body:
- start (dict): 'x' and 'y' values for the line start point, in [0, 1]
- end (dict): Same as start
- full_filename (str): Photon Ranch filename in S3, including the extension.
- s3_directory (str): the 'folder' that the image resides in s3. [ data | info-images | allsky ]
-
Responses:
- 200: Returns a JSON body with the following:
- success (boolean): Successful line profile
- start (dict): Same as request body
- end (dict): Same as request body
- data (list): of intensity values between start and end point
- 400: Image does not exist or validation error
- 500: Exception
- 200: Returns a JSON body with the following:
-
Example request:
#python 3.7 import requests, json url = "http://quickanalysis.photonranch.org/lineprofile" body = json.dumps({ "full_filename": "tst-test-20201112-00000058-EX10.fits.bz2", "s3_directory": "data", # return the intensity profile for the line spanning the top left to bottom right corners. "start": { "x": 0, "y": 0, }, "end": { "x": 1, "y": 1, } }) requests.post(url, body).json() """ { "success": true, "data": [ ... 260.0, 255.0, 237.0 ... ], "start": [ 0, 0 ], "end": [ 1, 1 ] } """
-
GET
/lineprofiledisplay
- Description: Visualizes the line for line profile described above
- Authorization required: No
- Request body:
- x0 (float): 'x' value for the line start point
- x1 (float): 'x' value for the line end point
- y0 (float): 'y' value for the line start point
- y1 (float): 'y' value for the line end point
- filename (str): Photon Ranch filename in S3, including the extension.
- s3_directory (str): The 'folder' that the image resides in s3. [ data | info-images | allsky ]
- Responses:
- 200: Returns a base 64 string representing a png of a line profile plot
- Example request:
#python 3.7 import requests, json url = "http://quickanalysis.photonranch.org/lineprofiledisplay" body = json.dumps({ "filename": "tst-test-20201112-00000058-EX10.fits.bz2", "s3_directory": "data", # return the intensity profile for the line spanning the top left to bottom right corners. "x0": 0, "y0": 0, "x1": 1, "y1": 1, }) requests.post(url, body).json()
-
POST
/statistics
- Description: Returns statistics for an image or rectangular subregion.
- Authorization required: No
- Request body:
- subregion (dict): Optional description of the subregion including:
- x0 (float): 'x' value for the rectangle left edge
- x1 (float): 'x' value for the rectangle right edge
- y0 (float): 'y' value for the rectangle top edge
- y1 (float): 'y' value for the rectangle bottom edge
- full_filename (str): Photon Ranch filename in S3, including the extension.
- s3_directory (str): The 'folder' that the image resides in s3. [ data | info-images | allsky ]
- subregion (dict): Optional description of the subregion including:
- Responses:
- 200: Returns a JSON body of stats floats including median, mean, mode, min, max, std, median abs deviation (see example below)
- 400: Image does not exist.
- Example request:
#python 3.7 import requests, json url = "http://quickanalysis.photonranch.org/statistics" body = json.dumps({ "full_filename": "tst-test-20201112-00000058-EX10.fits.bz2", "s3_directory": "data", }) requests.post(url, body).json() """ { "success": True, "stats": { "median": 158, "mean": 176.539, "mode": 155, "min": 51, "max": 64963, "std": 218.401, "median_abs_deviation": 12, } "params": json.loads(request.data) } """
-
POST
/histogram-clipped
- Description: Returns histogram statistics for an image or rectangular subregion.
- Authorization required: No
- Request body:
- clip_percent (float): percentile value of intensity to define min and max range of histogram
- subregion (dict): Optional description of the subregion including:
- x0 (float): 'x' value for the rectangle left edge
- x1 (float): 'x' value for the rectangle right edge
- y0 (float): 'y' value for the rectangle top edge
- y1 (float): 'y' value for the rectangle bottom edge
- full_filename (str): Photon Ranch filename in S3, including the extension.
- s3_directory (str): The 'folder' that the image resides in s3. [ data | info-images | allsky ]
- Responses:
- 200: Returns a JSON body of counts, edges, and stats floats including median, mean, mode, min, max, (see example below)
- 400: Image does not exist.
- Example request:
#python 3.7 import requests, json url = "http://quickanalysis.photonranch.org/histogram-clipped" body = json.dumps({ "full_filename": "tst-test-20201112-00000058-EX10.fits.bz2", "s3_directory": "data", "clip_percent": 0.001, }) requests.post(url, body).json() """ { "success": True, "histogram": { "edges": [106, 107, ... 1405], "counts": [415, 438, ....4152], "stats": { "median": 158, "mean": 176.539, "mode": 155, "min": 51, "max": 64963, } }, "params": json.loads(request.data) } """
-