![]() |
![]() |
![]() |
|||||||||||||||||
![]() |
![]() |
![]() |
|||||||||||||||||
![]() |
|
![]() |
|||||||||||||||||
![]() |
![]() |
![]() |
![]() |
healpix.core
|
Field Summary | |
---|---|
static int |
ns_max
The Constant ns_max. |
int |
nside
The nside. |
static int[] |
nsidelist
Available nsides ..always poer of 2 .. |
static String |
REVISION
the actual version from SVN |
static double |
z0
The Constant z0. |
Constructor Summary | |
---|---|
HealpixIndex()
Default constructor nside = 1024. |
|
HealpixIndex(int nSIDE2)
Construct healpix routines tied to a given nside |
Method Summary | |
---|---|
long |
ang2pix_nest(double theta,
double phi)
renders the pixel number ipix ( scheme as defined for object) for a pixel which contains a point on a sphere at coordinates theta and phi, given the map resolution parameter nside |
long |
ang2pix_ring(double theta,
double phi)
renders the pixel number ipix (RING scheme) for a pixel which contains a point on a sphere at coordinates theta and phi, given the map resolution parametr nside the computation is made to the highest resolution available (nside=8192) and then degraded to that required (by integer division) this doesn't cost more, and it makes sure that the treatement of round-off will be consistent for every resolution |
SpatialVector |
Ang2Vec(double theta,
double phi)
calculates vector corresponding to angles theta (co-latitude measured from North pole, in [0,pi] radians) phi (longitude measured eastward in [0,2pi] radians) North pole is (x,y,z) = (0, 0, 1) |
static double |
angDist(SpatialVector v1,
SpatialVector v2)
calculates angular distance (in radians) between 2 Vectors v1 and v2 In general dist = acos(v1.v2) except if the vectors are almost aligned |
static int |
bitdiff(long nside1,
long nside2)
return difference of number of bits in pixels of two nsides. |
static int |
calculateNSide(double pixsize)
calculate required nside given pixel size in arcsec |
SpatialVector[] |
corners_nest(int pix,
int step)
Returns set of points along the boundary of the given pixel in NEST scheme. |
SpatialVector[] |
corners_ring(long pix,
int step)
Returns set of points along the boundary of the given pixel in RING scheme. |
SpatialVector |
crossProduct(SpatialVector v1,
SpatialVector v2)
calculate cross product of two vectors |
double |
dotProduct(SpatialVector v1,
SpatialVector v2)
calculates a dot product (inner product) of two 3D vectors the result is double |
static long[] |
getChildrenAt(long nside,
long pix,
int requiredNside)
for a given pixel list all children pixels for it. |
int |
getOrder()
Gets the order value |
static double |
getPixRes(long nside)
calculates angular resolution of the pixel map in arc seconds. |
LongRangeSet |
InRing_nested_longset(int nside,
long iz,
double phi0,
double dphi)
returns the list of pixels in NEST scheme with latitude in [phi0 - dpi, phi0 + dphi] on the ring iz in [1, 4*nside -1 ] The pixel id numbers are in [0, 12*nside^2 - 1] the indexing is in RING, unless nest is set to 1 |
ArrayList<Long> |
inRing(long iz,
double phi0,
double dphi,
boolean nest)
Deprecated. use InRingLongSet |
ArrayList<Long> |
inRing(long iz,
double phi0,
double dphi,
boolean nest,
boolean conservative)
Deprecated. Use the InRingLongSet instead. |
void |
InRing(long nside,
long iz,
double phi0,
double dphi,
LongRangeSetBuilder res)
returns the list of pixels in RING scheme with latitude in [phi0 - dpi, phi0 + dphi] on the ring iz in [1, 4*nside -1 ] The pixel id numbers are in [0, 12*nside^2 - 1] the indexing is in RING, unless nest is set to 1 NOTE: this is the f90 code 'in_ring' method ported to java with 'conservative' flag to false |
ArrayList<Long> |
inRingCxx(long nside,
long iz,
double phi0,
double dphi,
boolean nest)
Deprecated. Don't use anymore, was only for |
LongRangeSet |
InRingLongSet(long nside,
long iz,
double phi0,
double dphi)
returns the list of pixels in RING scheme with latitude in [phi0 - dpi, phi0 + dphi] on the ring iz in [1, 4*nside -1 ] The pixel id numbers are in [0, 12*nside^2 - 1] the indexing is in RING, unless nest is set to 1 NOTE: this is the f90 code 'in_ring' method ported to java with 'conservative' flag to false |
double[] |
integration_limits_in_costh(int i_th)
integration limits in cos(theta) for a given ring i_th, i_th > 0 |
double[] |
intrs_intrv(double[] d1,
double[] d2)
computes the intersection di of 2 intervals d1 (= [a1,b1]) and d2 (= [a2,b2]) on the periodic domain (=[A,B] where A and B arbitrary) ni is the resulting number of intervals (0,1, or 2) if a1 |
static double |
log2(double num)
Log base two |
List<Long> |
neighbours_nest(long ipix)
returns 7 or 8 neighbours of any pixel in the nested scheme The neighbours are ordered in the following way: First pixel is the one to the south ( the one west of the south direction is taken for pixels that don't have a southern neighbour). |
long |
nest2ring(long ipnest)
performs conversion from NESTED to RING pixel number |
long |
next_in_line_nest(long nside,
long ipix)
calculates the pixel that lies on the East side (and the same latitude) as the given NESTED pixel number - ipix |
static long |
npix2Nside(long npix)
returns nside such that npix = 12*nside^2 nside should by power of 2 and smaller than ns_max if not return -1 |
static long |
nside2Npix(int nside)
calculates npix such that npix = 12*nside^2 nside should be a power of 2, and smaller than ns_max otherwise return -1 |
static int |
nside2order(int nside)
Gets the order from the nside |
static long |
parentAt(long child,
int childnside,
int requirednside)
return the parent PIXEL of a given pixel at some higher NSIDE. |
double[] |
pix2ang_nest(long ipix)
Convert from pix number to angle renders theta and phi coordinates of the nominal pixel center for the pixel number ipix (NESTED scheme) given the map resolution parameter nside |
double[] |
pix2ang_ring(long ipix)
Convert from pix number to angle renders theta and phi coordinates of the nominal pixel center for the pixel number ipix (RING scheme) given the map resolution parameter nside |
SpatialVector |
pix2vec_nest(long pix)
Converts pix number in NEST scheme to the unit vector |
SpatialVector |
pix2vec_ring(long pix)
Converts pix number in RING scheme to the unit vector |
double[] |
pixel_boundaries(double i_th,
double i_phi,
int i_zone,
double cos_theta)
calculate the points of crossing for a given theata on the boundaries of the pixel - returns the left and right phi crossings |
void |
printVec(double[] vec)
Prints the vec. |
LongRangeSet |
query_disc(int nside,
SpatialVector vector,
double radius,
int nest,
int inclusive)
generates in the RING or NESTED scheme all pixels that lies within an angular distance Radius of the center. |
LongRangeSet |
query_polygon(int nside,
ArrayList<Object> vlist,
long nest,
long inclusive)
finds pixels that lie within a CONVEX polygon defined by its vertex on sphere |
LongRangeSet |
query_strip(int nside,
double theta1,
double theta2,
long nest)
finds pixels having a colatitude (measured from North pole) : theta1 < colatitude < theta2 with o < theta1 < theta2 < pi if theta2 < theta1 then pixels with 0 < colatitude < theta2 or theta1 < colatitude < pi are returned |
LongRangeSet |
query_triangle(int nside,
SpatialVector v1,
SpatialVector v2,
SpatialVector v3,
long nest,
long inclusive)
generates a list of pixels that lie inside a triangle defined by the three vertex vectors |
int |
ring(long ipix)
return ring number for given pix in ring scheme |
long |
ring2nest(long ipring)
performs conversion from RING to NESTED pixel number |
long |
ringNum(int nside,
double z)
returns the ring number in {1, 4*nside - 1} calculated from z coordinate |
void |
setOrder(int order)
Sets the order |
static double |
surfaceTriangle(SpatialVector v1,
SpatialVector v2,
SpatialVector v3)
calculates the surface of spherical triangle defined by vertices v1,v2,v3 Algorithm: finds triangle sides and uses l'Huilier formula to compute "spherical excess" = surface area of triangle on a sphere of radius one see, eg Bronshtein, Semendyayev Eq 2.86 half perimeter hp = 0.5*(side1+side2+side3) l'Huilier formula x0 = tan( hp/2.) x1 = tan((hp - side1)/2.) x2 = tan((hp - side2)/2.) x3 = tan((hp - side3)/2.) |
long |
vec2pix_nest(SpatialVector vec)
Converts the unit vector to pix number in NEST scheme |
long |
vec2pix_ring(SpatialVector vec)
Converts the unit vector to pix number in RING scheme |
double[] |
Vect2Ang(SpatialVector v)
converts a SpatialVector in a tuple of angles tup[0] = theta co-latitude measured from North pole, in [0,PI] radians, tup[1] = phi longitude measured eastward, in [0,2PI] radians |
SpatialVector |
vector(double theta,
double phi)
Construct a SpatialVector from the angle (theta,phi) |
Methods inherited from class java.lang.Object |
---|
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String REVISION
public static final int ns_max
public static int[] nsidelist
public static final double z0
public int nside
Constructor Detail |
---|
public HealpixIndex()
public HealpixIndex(int nSIDE2) throws Exception
nSIDE2
- resolution number
Exception
Method Detail |
---|
public static int nside2order(int nside)
nside
-
public static double log2(double num)
num
-
public long ang2pix_nest(double theta, double phi) throws Exception
theta
- angle (along meridian), in [0,Pi], theta=0 : north polephi
- angle (along parallel), in [0,2*Pi]
Exception
public double[] pix2ang_nest(long ipix) throws Exception
ipix
- pixel index number
Exception
public double[] pix2ang_ring(long ipix) throws Exception
ipix
- pixel index number
Exception
public long ang2pix_ring(double theta, double phi) throws Exception
theta
- angle (along meridian), in [0,Pi], theta=0 : north polephi
- angle (along parallel), in [0,2*Pi]
Exception
public long nest2ring(long ipnest) throws Exception
ipnest
- pixel NEST index number
Exception
public long ring2nest(long ipring) throws Exception
ipring
- pixel RING index number
Exception
public double[] integration_limits_in_costh(int i_th)
i_th
- ith ring
public double[] pixel_boundaries(double i_th, double i_phi, int i_zone, double cos_theta)
i_th
- ith pixeli_phi
- phi anglei_zone
- ith zone (0,...,3), a quarter of spherecos_theta
- theta cosinus
public int ring(long ipix) throws Exception
ipix
- pixel index number in ring scheme
Exception
public SpatialVector vector(double theta, double phi)
SpatialVector
from the angle (theta,phi)
theta
- angle (along meridian), in [0,Pi], theta=0 : north polephi
- angle (along parallel), in [0,2*Pi]
SpatialVector
public long vec2pix_nest(SpatialVector vec) throws Exception
vec
- SpatialVector
Exception
public long vec2pix_ring(SpatialVector vec) throws Exception
vec
- SpatialVector
Exception
public SpatialVector pix2vec_nest(long pix) throws Exception
pix
- pixel index number in nest scheme
SpatialVector
Exception
public SpatialVector pix2vec_ring(long pix) throws Exception
pix
- pixel index number in ring scheme
SpatialVector
Exception
public SpatialVector[] corners_nest(int pix, int step) throws Exception
pix
- pixel index number in nest schemestep
-
SpatialVector
for each points
Exception
public SpatialVector[] corners_ring(long pix, int step) throws Exception
pix
- pixel index number in ring schemestep
-
SpatialVector
for each points
Exception
public static double getPixRes(long nside)
nside
-
public static int calculateNSide(double pixsize)
pixsize
- in arcsec
public SpatialVector Ang2Vec(double theta, double phi)
theta
- angle (along meridian), in [0,Pi], theta=0 : north polephi
- angle (along parallel), in [0,2*Pi]
IllegalArgumentException
public double[] Vect2Ang(SpatialVector v)
v
- SpatialVector
public static long npix2Nside(long npix)
npix
- long the number of pixels in the map
public static long nside2Npix(int nside)
nside
- long the map resolution
public static double surfaceTriangle(SpatialVector v1, SpatialVector v2, SpatialVector v3) throws Exception
v1
- SpatialVectorv2
- SpatialVectorv3
- SpatialVector vertices of the triangle
Exception
public static double angDist(SpatialVector v1, SpatialVector v2) throws Exception
v1
- SpatialVectorv2
- SpatialVector
Exception
public double dotProduct(SpatialVector v1, SpatialVector v2) throws Exception
v1
- 3d Vector of Number Objects (Double, long .. )v2
- 3d Vector
Exception
public SpatialVector crossProduct(SpatialVector v1, SpatialVector v2)
v1
- SpatialVectorv2
- SpatialVector
public LongRangeSet query_disc(int nside, SpatialVector vector, double radius, int nest, int inclusive)
nside
- long map resolutionvector
- Vector3d pointing to the disc centerradius
- double angular radius of the disk (in RADIAN )nest
- int 0 (default) if output is in RING scheme, if set to 1
output is in NESTEDinclusive
- int 0 (default) only pixsels whose center lie in the triangle
are listed, if set to 1, all pixels overlapping the triangle
are listed
public long ringNum(int nside, double z)
nside
- long resolutionz
- double z coordinate
public ArrayList<Long> inRing(long iz, double phi0, double dphi, boolean nest)
iz
- long ring numberphi0
- doubledphi
- doublenest
- boolean format flag
IllegalArgumentException
public ArrayList<Long> inRing(long iz, double phi0, double dphi, boolean nest, boolean conservative)
iz
- long ring numberphi0
- doubledphi
- doublenest
- boolean format flagconservative
- if true, include every intersected pixels, even if pixel
CENTER is not in the range [phi_low, phi_hi]. If not, strict :
include only pixels whose CENTER is in [phi_low, phi_hi]
IllegalArgumentException
public LongRangeSet InRing_nested_longset(int nside, long iz, double phi0, double dphi) throws Exception
nside
- long the map resolutioniz
- long ring numberphi0
- doubledphi
- double
Exception
public LongRangeSet InRingLongSet(long nside, long iz, double phi0, double dphi)
nside
- long the map resolutioniz
- long ring numberphi0
- doubledphi
- double
public void InRing(long nside, long iz, double phi0, double dphi, LongRangeSetBuilder res)
nside
- long the map resolutioniz
- long ring numberphi0
- doubledphi
- doubleres
- resultpublic ArrayList<Long> inRingCxx(long nside, long iz, double phi0, double dphi, boolean nest)
nside
- long the map resolutioniz
- long ring numberphi0
- doubledphi
- doublenest
- boolean format flag
IllegalArgumentException
public long next_in_line_nest(long nside, long ipix) throws Exception
nside
- long resolutionipix
- long pixel number
Exception
IllegalArgumentException
public LongRangeSet query_polygon(int nside, ArrayList<Object> vlist, long nest, long inclusive) throws Exception
nside
- the map resolutionvlist
- ArrayList of vectors defining the polygon verticesnest
- if set to 1 use NESTED schemeinclusive
- if set 1 returns all pixels crossed by polygon boundaries
Exception
public void printVec(double[] vec)
vec
- the vecpublic LongRangeSet query_triangle(int nside, SpatialVector v1, SpatialVector v2, SpatialVector v3, long nest, long inclusive) throws Exception
nside
- long map resolution parameterv1
- Vector3d defines one vertex of the trianglev2
- Vector3d another vertexv3
- Vector3d yet another onenest
- long 0 (default) RING numbering scheme, if set to 1 the NESTED
scheme will be used.inclusive
- long 0 (default) only pixels whose centers are inside the
triangle will be listed, if set to 1 all pixels overlaping the
triangle will be listed
Exception
- if the triangle is degeneratedpublic double[] intrs_intrv(double[] d1, double[] d2)
d1
- double[] first intervald2
- double[] second interval
public LongRangeSet query_strip(int nside, double theta1, double theta2, long nest) throws Exception
nside
- long the map resolution parametertheta1
- lower edge of the colatitudetheta2
- upper edge of the colatitudenest
- long if = 1 result is in NESTED scheme
Exception
public List<Long> neighbours_nest(long ipix) throws Exception
ipix
- long pixel number
Exception
IllegalArgumentException
public static long parentAt(long child, int childnside, int requirednside) throws Exception
child
- the pixelchildnside
- nside of the pixelrequirednside
- nside to upgrade to
Exception
public static int bitdiff(long nside1, long nside2)
nside1
- nside2
-
public static long[] getChildrenAt(long nside, long pix, int requiredNside) throws Exception
nside
- nside of pixpix
- the pixelrequiredNside
- the nside you want the children at
Exception
public int getOrder()
public void setOrder(int order)
order
-
|
"Built from revision exported" | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
![]() |
![]() |
![]() |
||||
![]() |
|
![]() |
||||
![]() |
![]() |
![]() |
||||
![]() |
|
![]() |
||||
![]() |
![]() |
![]() |
||||
![]() |
![]() |
![]() |