mirror of
https://bitbucket.org/cosmicvoids/vide_public.git
synced 2025-07-06 08:11:12 +00:00
Imported healpix tree
This commit is contained in:
parent
4182c30485
commit
4bfb62f177
136 changed files with 26534 additions and 0 deletions
94
external/healpix/Healpix_cxx/healpix_map.cc
vendored
Normal file
94
external/healpix/Healpix_cxx/healpix_map.cc
vendored
Normal file
|
@ -0,0 +1,94 @@
|
|||
/*
|
||||
* This file is part of Healpix_cxx.
|
||||
*
|
||||
* Healpix_cxx is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Healpix_cxx is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with Healpix_cxx; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*
|
||||
* For more information about HEALPix, see http://healpix.jpl.nasa.gov
|
||||
*/
|
||||
|
||||
/*
|
||||
* Healpix_cxx is being developed at the Max-Planck-Institut fuer Astrophysik
|
||||
* and financially supported by the Deutsches Zentrum fuer Luft- und Raumfahrt
|
||||
* (DLR).
|
||||
*/
|
||||
|
||||
/*
|
||||
* Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008 Max-Planck-Society
|
||||
* Author: Martin Reinecke
|
||||
*/
|
||||
|
||||
#include "healpix_map.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
template<typename T> void Healpix_Map<T>::Import_degrade
|
||||
(const Healpix_Map<T> &orig, bool pessimistic)
|
||||
{
|
||||
planck_assert(nside_<orig.nside_,"Import_degrade: this is no degrade");
|
||||
int fact = orig.nside_/nside_;
|
||||
planck_assert (orig.nside_==nside_*fact,
|
||||
"the larger Nside must be a multiple of the smaller one");
|
||||
pix2xyf to_xyf = (scheme_==RING) ?
|
||||
&Healpix_Map::ring2xyf : &Healpix_Map::nest2xyf;
|
||||
xyf2pix from_xyf = (orig.scheme_==RING) ?
|
||||
&Healpix_Map::xyf2ring : &Healpix_Map::xyf2nest;
|
||||
|
||||
int minhits = pessimistic ? fact : 1;
|
||||
#pragma omp parallel
|
||||
{
|
||||
int m;
|
||||
#pragma omp for schedule (static)
|
||||
for (m=0; m<npix_; ++m)
|
||||
{
|
||||
int x,y,f;
|
||||
(this->*to_xyf)(m,x,y,f);
|
||||
int hits = 0;
|
||||
double sum = 0;
|
||||
for (int j=fact*y; j<fact*(y+1); ++j)
|
||||
for (int i=fact*x; i<fact*(x+1); ++i)
|
||||
{
|
||||
int opix = (orig.*from_xyf)(i,j,f);
|
||||
if (!approx<double>(orig.map[opix],Healpix_undef))
|
||||
{
|
||||
++hits;
|
||||
sum += orig.map[opix];
|
||||
}
|
||||
}
|
||||
map[m] = T((hits<minhits) ? Healpix_undef : sum/hits);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template void Healpix_Map<float>::Import_degrade
|
||||
(const Healpix_Map<float> &orig, bool pessimistic);
|
||||
template void Healpix_Map<double>::Import_degrade
|
||||
(const Healpix_Map<double> &orig, bool pessimistic);
|
||||
|
||||
template<typename T> void Healpix_Map<T>::minmax (T &Min, T &Max) const
|
||||
{
|
||||
Min = T(1e30); Max = T(-1e30);
|
||||
for (int m=0; m<npix_; ++m)
|
||||
{
|
||||
T val = map[m];
|
||||
if (!approx<double>(val,Healpix_undef))
|
||||
{
|
||||
if (val>Max) Max=val;
|
||||
if (val<Min) Min=val;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template void Healpix_Map<float>::minmax (float &Min, float &Max) const;
|
||||
template void Healpix_Map<double>::minmax (double &Min, double &Max) const;
|
Loading…
Add table
Add a link
Reference in a new issue