EllipseAnnulusPixelRegion¶
- class regions.EllipseAnnulusPixelRegion(center, inner_width, outer_width, inner_height, outer_height, angle=<Quantity 0. deg>, meta=None, visual=None)[source]¶
Bases:
AsymmetricAnnulusPixelRegionA elliptical annulus in pixel coordinates.
- Parameters:
- center
PixCoord The position of the center of the elliptical annulus.
- inner_widthfloat
The inner width of the elliptical annulus (before rotation) in pixels.
- outer_widthfloat
The outer width of the elliptical annulus (before rotation) in pixels.
- inner_heightfloat
The inner height of the elliptical annulus (before rotation) in pixels.
- outer_heightfloat
The outer height of the elliptical annulus (before rotation) in pixels.
- angle
Quantity, optional The rotation angle of the elliptical annulus, measured anti-clockwise. If set to zero (the default), the width axis is lined up with the x axis.
- meta
RegionMetaordict, optional A dictionary that stores the meta attributes of the region.
- visual
RegionVisualordict, optional A dictionary that stores the visual meta attributes of the region.
- center
Examples
from astropy.coordinates import Angle from regions import PixCoord, EllipseAnnulusPixelRegion import matplotlib.pyplot as plt fig, ax = plt.subplots(1, 1) reg = EllipseAnnulusPixelRegion(PixCoord(6, 6), inner_width=5.5, outer_width=8.5, inner_height=3.5, outer_height=6.5, angle=Angle('45deg')) patch = reg.plot(ax=ax, facecolor='none', edgecolor='red', lw=2, label='Ellipse Annulus') ax.legend(handles=(patch,), loc='upper center') ax.set_xlim(-5, 20) ax.set_ylim(-5, 20) ax.set_aspect('equal')
(
Source code,png,hires.png,pdf,svg)
Attributes Summary
The rotation angle measured anti-clockwise as a
astropy.units.Quantityangle.The center pixel position as a
PixCoord.The inner height (before rotation) in pixels as a float.
The inner width (before rotation) in pixels as a float.
The outer height (before rotation) in pixels as a float.
The outer width (before rotation) in pixels as a float.
Methods Summary
to_sky(wcs)Return a region defined in sky coordinates.
to_spherical_sky([wcs, ...])Convert to an equivalent spherical
SphericalSkyRegioninstance.Attributes Documentation
- angle¶
The rotation angle measured anti-clockwise as a
astropy.units.Quantityangle.
- inner_height¶
The inner height (before rotation) in pixels as a float.
- inner_width¶
The inner width (before rotation) in pixels as a float.
- outer_height¶
The outer height (before rotation) in pixels as a float.
- outer_width¶
The outer width (before rotation) in pixels as a float.
Methods Documentation
- to_spherical_sky(wcs=None, include_boundary_distortions=False, discretize_kwargs=None)[source]¶
Convert to an equivalent spherical
SphericalSkyRegioninstance.- Parameters:
- wcs
WCSinstance, optional The world coordinate system transformation to use to convert between sky and pixel coordinates. Required if transforming with boundary distortions (if
include_boundary_distortionsis True). Ignored if boundary distortions not included.- include_boundary_distortionsbool, optional
If True, accounts for boundary boundary distortions in spherical to planar conversions, by discretizing the boundary and converting the boundary polygon. Default is False, which converts to an equivalent idealized shape.
- discretize_kwargsdict, optional
Optional keyword arguments to pass to discretize_boundary() method if including boundary distortions.
- wcs
- Returns:
- spherical_sky_region
SphericalSkyRegion A spherical sky region, with an equivalent shape (if
include_boundary_distortionsis False), or a discretized polygon of the boundary (ifinclude_boundary_distortionsis True).
- spherical_sky_region