/usr/include/paraview/Cosmo/HaloCenterFinder.h is in paraview-dev 4.0.1-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 | /*=========================================================================
Copyright (c) 2007, Los Alamos National Security, LLC
All rights reserved.
Copyright 2007. Los Alamos National Security, LLC.
This software was produced under U.S. Government contract DE-AC52-06NA25396
for Los Alamos National Laboratory (LANL), which is operated by
Los Alamos National Security, LLC for the U.S. Department of Energy.
The U.S. Government has rights to use, reproduce, and distribute this software.
NEITHER THE GOVERNMENT NOR LOS ALAMOS NATIONAL SECURITY, LLC MAKES ANY WARRANTY,
EXPRESS OR IMPLIED, OR ASSUMES ANY LIABILITY FOR THE USE OF THIS SOFTWARE.
If software is modified to produce derivative works, such modified software
should be clearly marked, so as not to confuse it with the version available
from LANL.
Additionally, redistribution and use in source and binary forms, with or
without modification, are permitted provided that the following conditions
are met:
- Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
- Neither the name of Los Alamos National Security, LLC, Los Alamos National
Laboratory, LANL, the U.S. Government, nor the names of its contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY LOS ALAMOS NATIONAL SECURITY, LLC AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL LOS ALAMOS NATIONAL SECURITY, LLC OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
=========================================================================*/
// .NAME HaloCenterFinder - find the particle in the center of halo particles
//
// HaloCenterFinder takes location data and a means of recognizing individual
// halos within the location and finds the most bound particle or the most
// connect particle.
//
// The class can be called with an array of locations, or can be called with
// all locations on a processor and two arrays used to thread halos through
// all particles. The first array gives the index of the first particle
// in the halo and the second array takes that index and gives the index
// of the next particle in the halo. Follow this until -1 which is the
// end of the halo.
//
// Can operate on FOF halos, subhalos or SOD halos depending on the form
// of the input.
#ifndef HaloCenterFinder_h
#define HaloCenterFinder_h
#ifdef USE_VTK_COSMO
#include "CosmoDefinition.h"
#else
#include "Definition.h"
#endif
#include "ChainingMesh.h"
#include <string>
#include <vector>
using namespace std;
#ifdef USE_VTK_COSMO
class COSMO_EXPORT HaloCenterFinder {
#else
class HaloCenterFinder {
#endif
public:
HaloCenterFinder();
~HaloCenterFinder();
// Set parameters for sizes of the dead/alive space
void setParameters(
POSVEL_T bb, // Inter particle distance for halos
POSVEL_T distConvertFactor); // Scale positions by
// Set alive particle vectors which were created elsewhere
void setParticles(
long particleCount,
POSVEL_T* xLoc,
POSVEL_T* yLoc,
POSVEL_T* zLoc,
POSVEL_T* massHalo,
ID_T* id);
// Find the halo centers using most bound particle (N^2/2)
int mostBoundParticleN2(POTENTIAL_T* minPotential);
// Initial guess of A* contains an actual part and an estimated part
int mostBoundParticleAStar(POTENTIAL_T* minPotential);
// Calculate actual values between particles within a bucket
void aStarThisBucketPart(
ChainingMesh* haloChain, // Buckets of particles
int* bucketID, // Map from particle to bucket
POSVEL_T* estimate); // Running minimum potential
// Calculate actual values for 26 neighbors in the center of halo
// Level 1 refinement done for initial guess
void aStarActualNeighborPart(
ChainingMesh* haloChain, // Buckets of particles
int* minActual, // Range for doing actual vs estimated
int* maxActual,
int* refineLevel, // Refinement level of each particle
POSVEL_T* estimate); // Running minimum potential
// Calculate estimated values for 26 neighbors around the edges of halo
// Level 0 refinement done for initial guess
void aStarEstimatedNeighborPart(
ChainingMesh* haloChain, // Buckets of particles
int* minActual, // Range for doing actual vs estimated
int* maxActual,
int* refineLevel, // Refinement level of each particle
POSVEL_T* estimate, // Running minimum potential
POSVEL_T boundarySize); // Boundary around bucket for estimation
// Calculate estimates for all buckets beyond the 27 closest
void aStarEstimatedPart(
ChainingMesh* haloChain, // Buckets of particles
POSVEL_T* estimate); // Running minimum potential
// Refinement of 0 to 1
void refineAStarLevel_1(
ChainingMesh* haloChain, // Buckets of particles
int bi, // Bucket containing particle to refine
int bj,
int bk,
int* minActual, // Range for doing actual vs estimated
int* maxActual,
int minParticle, // Particle to refine
POSVEL_T* estimate, // Running minimum potential
POSVEL_T boundarySize); // Boundary around bucket for estimation
// Refinement of 1 to N
void refineAStarLevel_N(
ChainingMesh* haloChain, // Buckets of particles
int bi, // Bucket containing particle to refine
int bj,
int bk,
int minParticle, // Particle to refine
POSVEL_T* estimate, // Running minimum potential
int winDelta); // Number of buckets to refine out to
// Find the halo centers using most connected particle (N^2/2)
int mostConnectedParticleN2();
int mostConnectedParticleChainMesh();
// Build a chaining mesh of halo particles
ChainingMesh* buildChainingMesh(
POSVEL_T chainSize);
private:
int myProc; // My processor number
int numProc; // Total number of processors
string outFile; // File of particles written by this processor
POSVEL_T boxSize; // Physical box size of the data set
POSVEL_T deadSize; // Border size for dead particles
POSVEL_T bb; // Interparticle distance for halos
POSVEL_T distFactor; // Scale positions by, used in chain size
long particleCount; // Total particles on this processor
POSVEL_T* xx; // X location for particles on this processor
POSVEL_T* yy; // Y location for particles on this processor
POSVEL_T* zz; // Z location for particles on this processor
POSVEL_T* mass; // mass for particles on this processor
ID_T* tag; // Id tag for particles on this processor
};
#endif
|