// @(#)root/eve:$Id$
// Authors: Matevz Tadel & Alja Mrak-Tadel: 2006, 2007

/*************************************************************************
 * Copyright (C) 1995-2007, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#include "TEvePointSet.h"

#include "TEveManager.h"
#include "TEveProjectionManager.h"
#include "TEveTrans.h"

#include "TTree.h"
#include "TTreePlayer.h"
#include "TF3.h"

#include "TColor.h"


//==============================================================================
//==============================================================================
// TEvePointSet
//==============================================================================

//______________________________________________________________________________
//
// TEvePointSet is a render-element holding a collection of 3D points with
// optional per-point TRef and an arbitrary number of integer ids (to
// be used for signal, volume-id, track-id, etc).
//
// 3D point representation is implemented in base-class TPolyMarker3D.
// Per-point TRef is implemented in base-class TPointSet3D.
//
// By using the TEvePointSelector the points and integer ids can be
// filled directly from a TTree holding the source data.
// Setting of per-point TRef's is not supported.
//
// TEvePointSet is a TEveProjectable: it can be projected by using the
// TEveProjectionManager class.

ClassImp(TEvePointSet);

//______________________________________________________________________________
TEvePointSet::TEvePointSet(Int_t n_points, ETreeVarType_e tv_type) :
   TEveElement(fMarkerColor),
   TPointSet3D(n_points),
   TEvePointSelectorConsumer(tv_type),
   TEveProjectable(),
   TQObject(),

   fTitle          (),
   fIntIds         (0),
   fIntIdsPerPoint (0)
{
   // Constructor.

   fMarkerStyle = 20;

   // Override from TEveElement.
   fPickable = kTRUE;
}

//______________________________________________________________________________
TEvePointSet::TEvePointSet(const char* name, Int_t n_points, ETreeVarType_e tv_type) :
   TEveElement(fMarkerColor),
   TPointSet3D(n_points),
   TEvePointSelectorConsumer(tv_type),
   TEveProjectable(),
   TQObject(),

   fTitle          (),
   fIntIds         (0),
   fIntIdsPerPoint (0)
{
   // Constructor.

   fMarkerStyle = 20;
   SetName(name);

   // Override from TEveElement.
   fPickable = kTRUE;
}

//______________________________________________________________________________
TEvePointSet::TEvePointSet(const TEvePointSet& e) :
   TEveElement(e),
   TPointSet3D(e),
   TEvePointSelectorConsumer(e),
   TEveProjectable(),
   TQObject(),

   fTitle          (e.fTitle),
   fIntIds         (e.fIntIds ? new TArrayI(*e.fIntIds) : 0),
   fIntIdsPerPoint (e.fIntIdsPerPoint)
{
   // Copy constructor.
}

//______________________________________________________________________________
TEvePointSet::~TEvePointSet()
{
   // Destructor.

   delete fIntIds;
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSet::ClonePoints(const TEvePointSet& e)
{
   // Clone points and all point-related information from point-set 'e'.

   // TPolyMarker3D
   delete [] fP;
   fN = e.fN;
   if (fN > 0)
   {
      const Int_t nn = 3 * e.fN;
      fP = new Float_t [nn];
      for (Int_t i = 0; i < nn; i++) fP[i] = e.fP[i];
   } else {
      fP = 0;
   }
   fLastPoint = e.fLastPoint;

   // TPointSet3D
   CopyIds(e);

   // TEvePointSet
   delete fIntIds;
   fIntIds         = e.fIntIds ? new TArrayI(*e.fIntIds) : 0;
   fIntIdsPerPoint = e.fIntIdsPerPoint;
}

/******************************************************************************/

//______________________________________________________________________________
const TGPicture* TEvePointSet::GetListTreeIcon(Bool_t)
{
   // Return pointset icon.

   return TEveElement::fgListTreeIcons[3];
}

//______________________________________________________________________________
void TEvePointSet::Reset(Int_t n_points, Int_t n_int_ids)
{
   // Drop all data and set-up the data structures to recive new data.
   // n_points   specifies the initial size of the arrays.
   // n_int_ids  specifies the number of integer ids per point.

   delete [] fP; fP = 0;
   fN = n_points;
   if (fN) {
      fP = new Float_t [3*fN];
      memset(fP, 0, 3*fN*sizeof(Float_t));
   }
   fLastPoint = -1;
   ClearIds();
   delete fIntIds; fIntIds = 0;
   fIntIdsPerPoint = n_int_ids;
   if (fIntIdsPerPoint > 0) fIntIds = new TArrayI(fIntIdsPerPoint*fN);
   ResetBBox();
}

//______________________________________________________________________________
Int_t TEvePointSet::GrowFor(Int_t n_points)
{
   // Resizes internal array to allow additional n_points to be stored.
   // Returns the old size which is also the location where one can
   // start storing new data.
   // The caller is *obliged* to fill the new point slots.

   Int_t old_size = Size();
   Int_t new_size = old_size + n_points;
   SetPoint(new_size - 1, 0, 0, 0);
   if (fIntIds)
      fIntIds->Set(fIntIdsPerPoint * new_size);
   return old_size;
}

/******************************************************************************/

//______________________________________________________________________________
inline void TEvePointSet::AssertIntIdsSize()
{
   // Assert that size of IntId array is compatible with the size of
   // the point array.

   Int_t exp_size = GetN()*fIntIdsPerPoint;
   if (fIntIds->GetSize() < exp_size)
      fIntIds->Set(exp_size);
}

//______________________________________________________________________________
Int_t* TEvePointSet::GetPointIntIds(Int_t p) const
{
   // Return a pointer to integer ids of point with index p.
   // Existence of integer id array is checked, 0 is returned if it
   // does not exist.
   // Validity of p is *not* checked.

   if (fIntIds)
      return fIntIds->GetArray() + p*fIntIdsPerPoint;
   return 0;
}

//______________________________________________________________________________
Int_t TEvePointSet::GetPointIntId(Int_t p, Int_t i) const
{
   // Return i-th integer id of point with index p.
   // Existence of integer id array is checked, kMinInt is returned if
   // it does not exist.
   // Validity of p and i is *not* checked.

   if (fIntIds)
      return * (fIntIds->GetArray() + p*fIntIdsPerPoint + i);
   return kMinInt;
}

//______________________________________________________________________________
void TEvePointSet::SetPointIntIds(Int_t* ids)
{
   // Set integer ids for the last point that was registered (most
   // probably via TPolyMarker3D::SetNextPoint(x,y,z)).

   SetPointIntIds(fLastPoint, ids);
}

//______________________________________________________________________________
void TEvePointSet::SetPointIntIds(Int_t n, Int_t* ids)
{
   // Set integer ids for point with index n.

   if (!fIntIds) return;
   AssertIntIdsSize();
   Int_t* x = fIntIds->GetArray() + n*fIntIdsPerPoint;
   for (Int_t i=0; i<fIntIdsPerPoint; ++i)
      x[i] = ids[i];
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSet::SetMarkerStyle(Style_t mstyle)
{
   // Set marker style, propagate to projecteds.

   static const TEveException eh("TEvePointSet::SetMarkerStyle ");

   std::list<TEveProjected*>::iterator pi = fProjectedList.begin();
   while (pi != fProjectedList.end())
   {
      TEvePointSet* pt = dynamic_cast<TEvePointSet*>(*pi);
      if (pt)
      {
         pt->SetMarkerStyle(mstyle);
         pt->StampObjProps();
      }
      ++pi;
   }
   TAttMarker::SetMarkerStyle(mstyle);
}

//______________________________________________________________________________
void TEvePointSet::SetMarkerSize(Size_t msize)
{
   // Set marker size, propagate to projecteds.

   static const TEveException eh("TEvePointSet::SetMarkerSize ");

   std::list<TEveProjected*>::iterator pi = fProjectedList.begin();
   while (pi != fProjectedList.end())
   {
      TEvePointSet* pt = dynamic_cast<TEvePointSet*>(*pi);
      if (pt)
      {
         pt->SetMarkerSize(msize);
         pt->StampObjProps();
      }
      ++pi;
   }
   TAttMarker::SetMarkerSize(msize);
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSet::Paint(Option_t*)
{
   // Paint point-set.

   PaintStandard(this);
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSet::InitFill(Int_t subIdNum)
{
   // Initialize point-set for new filling.
   // subIdNum gives the number of integer ids that can be assigned to
   // each point.

   if (subIdNum > 0) {
      fIntIdsPerPoint = subIdNum;
      if (!fIntIds)
         fIntIds = new TArrayI(fIntIdsPerPoint*GetN());
      else
         fIntIds->Set(fIntIdsPerPoint*GetN());
   } else {
      delete fIntIds; fIntIds = 0;
      fIntIdsPerPoint = 0;
   }
}

//______________________________________________________________________________
void TEvePointSet::TakeAction(TEvePointSelector* sel)
{
   // Called from TEvePointSelector when internal arrays of the tree-selector
   // are filled up and need to be processed.
   // Virtual from TEvePointSelectorConsumer.

   static const TEveException eh("TEvePointSet::TakeAction ");

   if(sel == 0)
      throw(eh + "selector is <null>.");

   Int_t    n = sel->GetNfill();
   Int_t  beg = GrowFor(n);

   // printf("TEvePointSet::TakeAction beg=%d n=%d size=%d nsubid=%d dim=%d\n",
   //        beg, n, Size(), sel->GetSubIdNum(), sel->GetDimension());

   Double_t *vx = sel->GetV1(), *vy = sel->GetV2(), *vz = sel->GetV3();
   Float_t  *p  = fP + 3*beg;

   switch(fSourceCS) {
      case kTVT_XYZ:
         while(n-- > 0) {
            p[0] = *vx; p[1] = *vy; p[2] = *vz;
            p += 3;
            ++vx; ++vy; ++vz;
         }
         break;
      case kTVT_RPhiZ:
         while(n-- > 0) {
            p[0] = *vx * TMath::Cos(*vy); p[1] = *vx * TMath::Sin(*vy); p[2] = *vz;
            p += 3;
            ++vx; ++vy; ++vz;
         }
         break;
      default:
         throw(eh + "unknown tree variable type.");
   }

   if (fIntIds) {
      Double_t** subarr = new Double_t* [fIntIdsPerPoint];
      for (Int_t i=0; i<fIntIdsPerPoint; ++i) {
         subarr[i] = sel->GetVal(sel->GetDimension() - fIntIdsPerPoint + i);
         if (subarr[i] == 0)
            throw(eh + "sub-id array not available.");
      }
      Int_t* ids = fIntIds->GetArray() + fIntIdsPerPoint*beg;
      n = sel->GetNfill();
      while (n-- > 0) {
         for (Int_t i=0; i<fIntIdsPerPoint; ++i) {
            ids[i] = TMath::Nint(*subarr[i]);
            ++subarr[i];
         }
         ids += fIntIdsPerPoint;
      }
      delete [] subarr;
   }
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSet::CopyVizParams(const TEveElement* el)
{
   // Copy visualization parameters from element el.

   const TEvePointSet* m = dynamic_cast<const TEvePointSet*>(el);
   if (m)
   {
      TAttMarker::operator=(*m);
      fOption = m->fOption;
   }

   TEveElement::CopyVizParams(el);
}

//______________________________________________________________________________
void TEvePointSet::WriteVizParams(std::ostream& out, const TString& var)
{
   // Write visualization parameters.

   TEveElement::WriteVizParams(out, var);

   TAttMarker::SaveMarkerAttributes(out, var);
}

//******************************************************************************

//______________________________________________________________________________
TClass* TEvePointSet::ProjectedClass(const TEveProjection*) const
{
   // Virtual from TEveProjectable, returns TEvePointSetProjected class.

   return TEvePointSetProjected::Class();
}

//______________________________________________________________________________
void TEvePointSet::PointSelected(Int_t id)
{
   // Virtual method of base class TPointSet3D. The function call is
   // invoked with secondary selection in TPointSet3DGL.

   Emit("PointSelected(Int_t)", id);
   TPointSet3D::PointSelected(id);
}


//==============================================================================
//==============================================================================
// TEvePointSetArray
//==============================================================================

//______________________________________________________________________________
//
// An array of point-sets with each point-set playing a role of a bin
// in a histogram. When a new point is added to a TEvePointSetArray,
// an additional separating quantity needs to be specified: it
// determines into which TEvePointSet (bin) the point will actually be
// stored. Underflow and overflow bins are automatically created but
// they are not drawn by default.
//
// By using the TEvePointSelector the points and the separating
// quantities can be filled directly from a TTree holding the source
// data.
// Setting of per-point TRef's is not supported.
//
// After the filling, the range of separating variable can be
// controlled with a slider to choose a sub-set of PointSets that are
// actually shown.
//

ClassImp(TEvePointSetArray);

//______________________________________________________________________________
TEvePointSetArray::TEvePointSetArray(const char* name,
                                     const char* title) :
   TEveElement(fMarkerColor),
   TNamed(name, title),

   fBins(0), fDefPointSetCapacity(128), fNBins(0), fLastBin(-1),
   fMin(0), fCurMin(0), fMax(0), fCurMax(0),
   fBinWidth(0),
   fQuantName()
{
   // Constructor.
}

//______________________________________________________________________________
TEvePointSetArray::~TEvePointSetArray()
{
   // Destructor: deletes the fBins array. Actual removal of
   // elements done by TEveElement.

   // printf("TEvePointSetArray::~TEvePointSetArray()\n");
   delete [] fBins; fBins = 0;
}

//______________________________________________________________________________
void TEvePointSetArray::RemoveElementLocal(TEveElement* el)
{
   // Virtual from TEveElement, provide bin management.

   for (Int_t i=0; i<fNBins; ++i) {
      if (fBins[i] == el) {
         fBins[i] = 0;
         break;
      }
   }
}

//______________________________________________________________________________
void TEvePointSetArray::RemoveElementsLocal()
{
   // Virtual from TEveElement, provide bin management.

   delete [] fBins; fBins = 0; fLastBin = -1;
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSetArray::SetMarkerColor(Color_t tcolor)
{
   // Set marker color, propagate to children.

   static const TEveException eh("TEvePointSetArray::SetMarkerColor ");

   for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i) {
      TAttMarker* m = dynamic_cast<TAttMarker*>((*i)->GetObject(eh));
      if (m && m->GetMarkerColor() == fMarkerColor)
         m->SetMarkerColor(tcolor);
   }
   TAttMarker::SetMarkerColor(tcolor);
}

//______________________________________________________________________________
void TEvePointSetArray::SetMarkerStyle(Style_t mstyle)
{
   // Set marker style, propagate to children.

   static const TEveException eh("TEvePointSetArray::SetMarkerStyle ");

   for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i) {
      TAttMarker* m = dynamic_cast<TAttMarker*>((*i)->GetObject(eh));
      if (m && m->GetMarkerStyle() == fMarkerStyle)
         m->SetMarkerStyle(mstyle);
   }
   TAttMarker::SetMarkerStyle(mstyle);
}

//______________________________________________________________________________
void TEvePointSetArray::SetMarkerSize(Size_t msize)
{
   // Set marker size, propagate to children.

   static const TEveException eh("TEvePointSetArray::SetMarkerSize ");

   for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i) {
      TAttMarker* m = dynamic_cast<TAttMarker*>((*i)->GetObject(eh));
      if (m && m->GetMarkerSize() == fMarkerSize)
         m->SetMarkerSize(msize);
   }
   TAttMarker::SetMarkerSize(msize);
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSetArray::TakeAction(TEvePointSelector* sel)
{
   // Called from TEvePointSelector when internal arrays of the tree-selector
   // are filled up and need to be processed.
   // Virtual from TEvePointSelectorConsumer.

   static const TEveException eh("TEvePointSetArray::TakeAction ");

   if (sel == 0)
      throw eh + "selector is <null>.";

   Int_t n = sel->GetNfill();

   // printf("TEvePointSetArray::TakeAction n=%d\n", n);

   Double_t *vx = sel->GetV1(), *vy = sel->GetV2(), *vz = sel->GetV3();
   Double_t *qq = sel->GetV4();

   if (qq == 0)
      throw eh + "requires 4-d varexp.";

   switch (fSourceCS)
   {
      case kTVT_XYZ:
      {
         while (n-- > 0)
         {
            Fill(*vx, *vy, *vz, *qq);
            ++vx; ++vy; ++vz; ++qq;
         }
         break;
      }
      case kTVT_RPhiZ:
      {
         while (n-- > 0)
         {
            Fill(*vx * TMath::Cos(*vy), *vx * TMath::Sin(*vy), *vz, *qq);
            ++vx; ++vy; ++vz; ++qq;
         }
         break;
      }
      default:
      {
         throw eh + "unknown tree variable type.";
      }
   }
}

/******************************************************************************/

//______________________________________________________________________________
Int_t TEvePointSetArray::Size(Bool_t under, Bool_t over) const
{
   // Get the total number of filled points.
   // 'under' and 'over' flags specify if under/overflow channels
   // should be added to the sum.

   Int_t size = 0;
   const Int_t min = under ? 0 : 1;
   const Int_t max = over  ? fNBins : fNBins - 1;
   for (Int_t i = min; i < max; ++i)
   {
      if (fBins[i])
         size += fBins[i]->Size();
   }
   return size;
}

//______________________________________________________________________________
void TEvePointSetArray::InitBins(const char* quant_name,
                                 Int_t nbins, Double_t min, Double_t max)
{
   // Initialize internal point-sets with given binning parameters.
   // The actual number of bins is nbins+2, bin 0 corresponding to
   // underflow and bin nbin+1 to owerflow pointset.

   static const TEveException eh("TEvePointSetArray::InitBins ");

   if (nbins < 1) throw eh + "nbins < 1.";
   if (min > max) throw eh + "min > max.";

   RemoveElements();

   fQuantName = quant_name;
   fNBins     = nbins + 2; // under/overflow
   fLastBin   = -1;
   fMin = fCurMin = min;
   fMax = fCurMax = max;
   fBinWidth  = (fMax - fMin)/(fNBins - 2);

   fBins = new TEvePointSet* [fNBins];

   for (Int_t i = 0; i < fNBins; ++i)
   {
      fBins[i] = new TEvePointSet
         (Form("Slice %d [%4.3lf, %4.3lf]", i, fMin + (i-1)*fBinWidth, fMin + i*fBinWidth),
          fDefPointSetCapacity);
      fBins[i]->SetMarkerColor(fMarkerColor);
      fBins[i]->SetMarkerStyle(fMarkerStyle);
      fBins[i]->SetMarkerSize(fMarkerSize);
      AddElement(fBins[i]);
   }

   fBins[0]->SetName("Underflow");
   fBins[0]->SetRnrSelf(kFALSE);

   fBins[fNBins-1]->SetName("Overflow");
   fBins[fNBins-1]->SetRnrSelf(kFALSE);
}

//______________________________________________________________________________
Bool_t TEvePointSetArray::Fill(Double_t x, Double_t y, Double_t z, Double_t quant)
{
   // Add a new point. Appropriate point-set will be chosen based on
   // the value of the separating quantity 'quant'.
   // If the selected bin does not have an associated TEvePointSet
   // the point is discarded and false is returned.

   fLastBin = TMath::FloorNint((quant - fMin)/fBinWidth) + 1;

   if (fLastBin < 0)
   {
      fLastBin = 0;
   }
   else if (fLastBin > fNBins - 1)
   {
      fLastBin = fNBins - 1;
   }

   if (fBins[fLastBin] != 0)
   {
      fBins[fLastBin]->SetNextPoint(x, y, z);
      return kTRUE;
   }
   else
   {
      return kFALSE;
   }
}

//______________________________________________________________________________
void TEvePointSetArray::SetPointId(TObject* id)
{
   // Set external object id of the last added point.

   if (fLastBin >= 0)
      fBins[fLastBin]->SetPointId(id);
}

//______________________________________________________________________________
void TEvePointSetArray::CloseBins()
{
   // Call this after all the points have been filled.
   // At this point we can calculate bounding-boxes of individual
   // point-sets.

   for (Int_t i=0; i<fNBins; ++i)
   {
      if (fBins[i] != 0)
      {
         fBins[i]->SetTitle(Form("N=%d", fBins[i]->Size()));
         fBins[i]->ComputeBBox();
      }
   }
   fLastBin = -1;
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSetArray::SetOwnIds(Bool_t o)
{
   // Propagate id-object ownership to children.

   for (Int_t i=0; i<fNBins; ++i)
   {
      if (fBins[i] != 0)
         fBins[i]->SetOwnIds(o);
   }
}

/******************************************************************************/

//______________________________________________________________________________
void TEvePointSetArray::SetRange(Double_t min, Double_t max)
{
   // Set active range of the separating quantity.
   // Appropriate point-sets are tagged for rendering.
   // Over/underflow point-sets are left as they were.

   using namespace TMath;

   fCurMin = min; fCurMax = max;
   Int_t  low_b = Max(0,        FloorNint((min-fMin)/fBinWidth)) + 1;
   Int_t high_b = Min(fNBins-2, CeilNint ((max-fMin)/fBinWidth));

   for (Int_t i = 1; i < fNBins - 1; ++i)
   {
      if (fBins[i] != 0)
         fBins[i]->SetRnrSelf(i>=low_b && i<=high_b);
   }
}


//==============================================================================
//==============================================================================
// TEvePointSetProjected
//==============================================================================

//______________________________________________________________________________
//
// Projected copy of a TEvePointSet.

ClassImp(TEvePointSetProjected);

//______________________________________________________________________________
TEvePointSetProjected::TEvePointSetProjected() :
   TEvePointSet  (),
   TEveProjected ()
{
   // Default contructor.
}

//______________________________________________________________________________
void TEvePointSetProjected::SetProjection(TEveProjectionManager* proj,
                                          TEveProjectable* model)
{
   // Set projection manager and projection model.
   // Virtual from TEveProjected.

   TEveProjected::SetProjection(proj, model);
   CopyVizParams(dynamic_cast<TEveElement*>(model));
}

//______________________________________________________________________________
void TEvePointSetProjected::SetDepthLocal(Float_t d)
{
   // Set depth (z-coordinate) of the projected points.

   SetDepthCommon(d, this, fBBox);

   Int_t    n = Size();
   Float_t *p = GetP() + 2;
   for (Int_t i = 0; i < n; ++i, p+=3)
      *p = fDepth;
}

//______________________________________________________________________________
void TEvePointSetProjected::UpdateProjection()
{
   // Re-apply the projection.
   // Virtual from TEveProjected.

   TEveProjection &proj = * fManager->GetProjection();
   TEvePointSet   &ps   = * dynamic_cast<TEvePointSet*>(fProjectable);
   TEveTrans      *tr   =   ps.PtrMainTrans(kFALSE);

   Int_t n = ps.Size();
   Reset(n);
   fLastPoint = n - 1;
   Float_t *o = ps.GetP(), *p = GetP();
   for (Int_t i = 0; i < n; ++i, o+=3, p+=3)
   {
      proj.ProjectPointfv(tr, o, p, fDepth);
   }
}

//______________________________________________________________________________
void TEvePointSetProjected::PointSelected(Int_t id)
{
   // Virtual method of base class TPointSet3D.
   // Forward to projectable.

   TEvePointSet *ps = dynamic_cast<TEvePointSet*>(fProjectable);
   ps->PointSelected(id);
}
 TEvePointSet.cxx:1
 TEvePointSet.cxx:2
 TEvePointSet.cxx:3
 TEvePointSet.cxx:4
 TEvePointSet.cxx:5
 TEvePointSet.cxx:6
 TEvePointSet.cxx:7
 TEvePointSet.cxx:8
 TEvePointSet.cxx:9
 TEvePointSet.cxx:10
 TEvePointSet.cxx:11
 TEvePointSet.cxx:12
 TEvePointSet.cxx:13
 TEvePointSet.cxx:14
 TEvePointSet.cxx:15
 TEvePointSet.cxx:16
 TEvePointSet.cxx:17
 TEvePointSet.cxx:18
 TEvePointSet.cxx:19
 TEvePointSet.cxx:20
 TEvePointSet.cxx:21
 TEvePointSet.cxx:22
 TEvePointSet.cxx:23
 TEvePointSet.cxx:24
 TEvePointSet.cxx:25
 TEvePointSet.cxx:26
 TEvePointSet.cxx:27
 TEvePointSet.cxx:28
 TEvePointSet.cxx:29
 TEvePointSet.cxx:30
 TEvePointSet.cxx:31
 TEvePointSet.cxx:32
 TEvePointSet.cxx:33
 TEvePointSet.cxx:34
 TEvePointSet.cxx:35
 TEvePointSet.cxx:36
 TEvePointSet.cxx:37
 TEvePointSet.cxx:38
 TEvePointSet.cxx:39
 TEvePointSet.cxx:40
 TEvePointSet.cxx:41
 TEvePointSet.cxx:42
 TEvePointSet.cxx:43
 TEvePointSet.cxx:44
 TEvePointSet.cxx:45
 TEvePointSet.cxx:46
 TEvePointSet.cxx:47
 TEvePointSet.cxx:48
 TEvePointSet.cxx:49
 TEvePointSet.cxx:50
 TEvePointSet.cxx:51
 TEvePointSet.cxx:52
 TEvePointSet.cxx:53
 TEvePointSet.cxx:54
 TEvePointSet.cxx:55
 TEvePointSet.cxx:56
 TEvePointSet.cxx:57
 TEvePointSet.cxx:58
 TEvePointSet.cxx:59
 TEvePointSet.cxx:60
 TEvePointSet.cxx:61
 TEvePointSet.cxx:62
 TEvePointSet.cxx:63
 TEvePointSet.cxx:64
 TEvePointSet.cxx:65
 TEvePointSet.cxx:66
 TEvePointSet.cxx:67
 TEvePointSet.cxx:68
 TEvePointSet.cxx:69
 TEvePointSet.cxx:70
 TEvePointSet.cxx:71
 TEvePointSet.cxx:72
 TEvePointSet.cxx:73
 TEvePointSet.cxx:74
 TEvePointSet.cxx:75
 TEvePointSet.cxx:76
 TEvePointSet.cxx:77
 TEvePointSet.cxx:78
 TEvePointSet.cxx:79
 TEvePointSet.cxx:80
 TEvePointSet.cxx:81
 TEvePointSet.cxx:82
 TEvePointSet.cxx:83
 TEvePointSet.cxx:84
 TEvePointSet.cxx:85
 TEvePointSet.cxx:86
 TEvePointSet.cxx:87
 TEvePointSet.cxx:88
 TEvePointSet.cxx:89
 TEvePointSet.cxx:90
 TEvePointSet.cxx:91
 TEvePointSet.cxx:92
 TEvePointSet.cxx:93
 TEvePointSet.cxx:94
 TEvePointSet.cxx:95
 TEvePointSet.cxx:96
 TEvePointSet.cxx:97
 TEvePointSet.cxx:98
 TEvePointSet.cxx:99
 TEvePointSet.cxx:100
 TEvePointSet.cxx:101
 TEvePointSet.cxx:102
 TEvePointSet.cxx:103
 TEvePointSet.cxx:104
 TEvePointSet.cxx:105
 TEvePointSet.cxx:106
 TEvePointSet.cxx:107
 TEvePointSet.cxx:108
 TEvePointSet.cxx:109
 TEvePointSet.cxx:110
 TEvePointSet.cxx:111
 TEvePointSet.cxx:112
 TEvePointSet.cxx:113
 TEvePointSet.cxx:114
 TEvePointSet.cxx:115
 TEvePointSet.cxx:116
 TEvePointSet.cxx:117
 TEvePointSet.cxx:118
 TEvePointSet.cxx:119
 TEvePointSet.cxx:120
 TEvePointSet.cxx:121
 TEvePointSet.cxx:122
 TEvePointSet.cxx:123
 TEvePointSet.cxx:124
 TEvePointSet.cxx:125
 TEvePointSet.cxx:126
 TEvePointSet.cxx:127
 TEvePointSet.cxx:128
 TEvePointSet.cxx:129
 TEvePointSet.cxx:130
 TEvePointSet.cxx:131
 TEvePointSet.cxx:132
 TEvePointSet.cxx:133
 TEvePointSet.cxx:134
 TEvePointSet.cxx:135
 TEvePointSet.cxx:136
 TEvePointSet.cxx:137
 TEvePointSet.cxx:138
 TEvePointSet.cxx:139
 TEvePointSet.cxx:140
 TEvePointSet.cxx:141
 TEvePointSet.cxx:142
 TEvePointSet.cxx:143
 TEvePointSet.cxx:144
 TEvePointSet.cxx:145
 TEvePointSet.cxx:146
 TEvePointSet.cxx:147
 TEvePointSet.cxx:148
 TEvePointSet.cxx:149
 TEvePointSet.cxx:150
 TEvePointSet.cxx:151
 TEvePointSet.cxx:152
 TEvePointSet.cxx:153
 TEvePointSet.cxx:154
 TEvePointSet.cxx:155
 TEvePointSet.cxx:156
 TEvePointSet.cxx:157
 TEvePointSet.cxx:158
 TEvePointSet.cxx:159
 TEvePointSet.cxx:160
 TEvePointSet.cxx:161
 TEvePointSet.cxx:162
 TEvePointSet.cxx:163
 TEvePointSet.cxx:164
 TEvePointSet.cxx:165
 TEvePointSet.cxx:166
 TEvePointSet.cxx:167
 TEvePointSet.cxx:168
 TEvePointSet.cxx:169
 TEvePointSet.cxx:170
 TEvePointSet.cxx:171
 TEvePointSet.cxx:172
 TEvePointSet.cxx:173
 TEvePointSet.cxx:174
 TEvePointSet.cxx:175
 TEvePointSet.cxx:176
 TEvePointSet.cxx:177
 TEvePointSet.cxx:178
 TEvePointSet.cxx:179
 TEvePointSet.cxx:180
 TEvePointSet.cxx:181
 TEvePointSet.cxx:182
 TEvePointSet.cxx:183
 TEvePointSet.cxx:184
 TEvePointSet.cxx:185
 TEvePointSet.cxx:186
 TEvePointSet.cxx:187
 TEvePointSet.cxx:188
 TEvePointSet.cxx:189
 TEvePointSet.cxx:190
 TEvePointSet.cxx:191
 TEvePointSet.cxx:192
 TEvePointSet.cxx:193
 TEvePointSet.cxx:194
 TEvePointSet.cxx:195
 TEvePointSet.cxx:196
 TEvePointSet.cxx:197
 TEvePointSet.cxx:198
 TEvePointSet.cxx:199
 TEvePointSet.cxx:200
 TEvePointSet.cxx:201
 TEvePointSet.cxx:202
 TEvePointSet.cxx:203
 TEvePointSet.cxx:204
 TEvePointSet.cxx:205
 TEvePointSet.cxx:206
 TEvePointSet.cxx:207
 TEvePointSet.cxx:208
 TEvePointSet.cxx:209
 TEvePointSet.cxx:210
 TEvePointSet.cxx:211
 TEvePointSet.cxx:212
 TEvePointSet.cxx:213
 TEvePointSet.cxx:214
 TEvePointSet.cxx:215
 TEvePointSet.cxx:216
 TEvePointSet.cxx:217
 TEvePointSet.cxx:218
 TEvePointSet.cxx:219
 TEvePointSet.cxx:220
 TEvePointSet.cxx:221
 TEvePointSet.cxx:222
 TEvePointSet.cxx:223
 TEvePointSet.cxx:224
 TEvePointSet.cxx:225
 TEvePointSet.cxx:226
 TEvePointSet.cxx:227
 TEvePointSet.cxx:228
 TEvePointSet.cxx:229
 TEvePointSet.cxx:230
 TEvePointSet.cxx:231
 TEvePointSet.cxx:232
 TEvePointSet.cxx:233
 TEvePointSet.cxx:234
 TEvePointSet.cxx:235
 TEvePointSet.cxx:236
 TEvePointSet.cxx:237
 TEvePointSet.cxx:238
 TEvePointSet.cxx:239
 TEvePointSet.cxx:240
 TEvePointSet.cxx:241
 TEvePointSet.cxx:242
 TEvePointSet.cxx:243
 TEvePointSet.cxx:244
 TEvePointSet.cxx:245
 TEvePointSet.cxx:246
 TEvePointSet.cxx:247
 TEvePointSet.cxx:248
 TEvePointSet.cxx:249
 TEvePointSet.cxx:250
 TEvePointSet.cxx:251
 TEvePointSet.cxx:252
 TEvePointSet.cxx:253
 TEvePointSet.cxx:254
 TEvePointSet.cxx:255
 TEvePointSet.cxx:256
 TEvePointSet.cxx:257
 TEvePointSet.cxx:258
 TEvePointSet.cxx:259
 TEvePointSet.cxx:260
 TEvePointSet.cxx:261
 TEvePointSet.cxx:262
 TEvePointSet.cxx:263
 TEvePointSet.cxx:264
 TEvePointSet.cxx:265
 TEvePointSet.cxx:266
 TEvePointSet.cxx:267
 TEvePointSet.cxx:268
 TEvePointSet.cxx:269
 TEvePointSet.cxx:270
 TEvePointSet.cxx:271
 TEvePointSet.cxx:272
 TEvePointSet.cxx:273
 TEvePointSet.cxx:274
 TEvePointSet.cxx:275
 TEvePointSet.cxx:276
 TEvePointSet.cxx:277
 TEvePointSet.cxx:278
 TEvePointSet.cxx:279
 TEvePointSet.cxx:280
 TEvePointSet.cxx:281
 TEvePointSet.cxx:282
 TEvePointSet.cxx:283
 TEvePointSet.cxx:284
 TEvePointSet.cxx:285
 TEvePointSet.cxx:286
 TEvePointSet.cxx:287
 TEvePointSet.cxx:288
 TEvePointSet.cxx:289
 TEvePointSet.cxx:290
 TEvePointSet.cxx:291
 TEvePointSet.cxx:292
 TEvePointSet.cxx:293
 TEvePointSet.cxx:294
 TEvePointSet.cxx:295
 TEvePointSet.cxx:296
 TEvePointSet.cxx:297
 TEvePointSet.cxx:298
 TEvePointSet.cxx:299
 TEvePointSet.cxx:300
 TEvePointSet.cxx:301
 TEvePointSet.cxx:302
 TEvePointSet.cxx:303
 TEvePointSet.cxx:304
 TEvePointSet.cxx:305
 TEvePointSet.cxx:306
 TEvePointSet.cxx:307
 TEvePointSet.cxx:308
 TEvePointSet.cxx:309
 TEvePointSet.cxx:310
 TEvePointSet.cxx:311
 TEvePointSet.cxx:312
 TEvePointSet.cxx:313
 TEvePointSet.cxx:314
 TEvePointSet.cxx:315
 TEvePointSet.cxx:316
 TEvePointSet.cxx:317
 TEvePointSet.cxx:318
 TEvePointSet.cxx:319
 TEvePointSet.cxx:320
 TEvePointSet.cxx:321
 TEvePointSet.cxx:322
 TEvePointSet.cxx:323
 TEvePointSet.cxx:324
 TEvePointSet.cxx:325
 TEvePointSet.cxx:326
 TEvePointSet.cxx:327
 TEvePointSet.cxx:328
 TEvePointSet.cxx:329
 TEvePointSet.cxx:330
 TEvePointSet.cxx:331
 TEvePointSet.cxx:332
 TEvePointSet.cxx:333
 TEvePointSet.cxx:334
 TEvePointSet.cxx:335
 TEvePointSet.cxx:336
 TEvePointSet.cxx:337
 TEvePointSet.cxx:338
 TEvePointSet.cxx:339
 TEvePointSet.cxx:340
 TEvePointSet.cxx:341
 TEvePointSet.cxx:342
 TEvePointSet.cxx:343
 TEvePointSet.cxx:344
 TEvePointSet.cxx:345
 TEvePointSet.cxx:346
 TEvePointSet.cxx:347
 TEvePointSet.cxx:348
 TEvePointSet.cxx:349
 TEvePointSet.cxx:350
 TEvePointSet.cxx:351
 TEvePointSet.cxx:352
 TEvePointSet.cxx:353
 TEvePointSet.cxx:354
 TEvePointSet.cxx:355
 TEvePointSet.cxx:356
 TEvePointSet.cxx:357
 TEvePointSet.cxx:358
 TEvePointSet.cxx:359
 TEvePointSet.cxx:360
 TEvePointSet.cxx:361
 TEvePointSet.cxx:362
 TEvePointSet.cxx:363
 TEvePointSet.cxx:364
 TEvePointSet.cxx:365
 TEvePointSet.cxx:366
 TEvePointSet.cxx:367
 TEvePointSet.cxx:368
 TEvePointSet.cxx:369
 TEvePointSet.cxx:370
 TEvePointSet.cxx:371
 TEvePointSet.cxx:372
 TEvePointSet.cxx:373
 TEvePointSet.cxx:374
 TEvePointSet.cxx:375
 TEvePointSet.cxx:376
 TEvePointSet.cxx:377
 TEvePointSet.cxx:378
 TEvePointSet.cxx:379
 TEvePointSet.cxx:380
 TEvePointSet.cxx:381
 TEvePointSet.cxx:382
 TEvePointSet.cxx:383
 TEvePointSet.cxx:384
 TEvePointSet.cxx:385
 TEvePointSet.cxx:386
 TEvePointSet.cxx:387
 TEvePointSet.cxx:388
 TEvePointSet.cxx:389
 TEvePointSet.cxx:390
 TEvePointSet.cxx:391
 TEvePointSet.cxx:392
 TEvePointSet.cxx:393
 TEvePointSet.cxx:394
 TEvePointSet.cxx:395
 TEvePointSet.cxx:396
 TEvePointSet.cxx:397
 TEvePointSet.cxx:398
 TEvePointSet.cxx:399
 TEvePointSet.cxx:400
 TEvePointSet.cxx:401
 TEvePointSet.cxx:402
 TEvePointSet.cxx:403
 TEvePointSet.cxx:404
 TEvePointSet.cxx:405
 TEvePointSet.cxx:406
 TEvePointSet.cxx:407
 TEvePointSet.cxx:408
 TEvePointSet.cxx:409
 TEvePointSet.cxx:410
 TEvePointSet.cxx:411
 TEvePointSet.cxx:412
 TEvePointSet.cxx:413
 TEvePointSet.cxx:414
 TEvePointSet.cxx:415
 TEvePointSet.cxx:416
 TEvePointSet.cxx:417
 TEvePointSet.cxx:418
 TEvePointSet.cxx:419
 TEvePointSet.cxx:420
 TEvePointSet.cxx:421
 TEvePointSet.cxx:422
 TEvePointSet.cxx:423
 TEvePointSet.cxx:424
 TEvePointSet.cxx:425
 TEvePointSet.cxx:426
 TEvePointSet.cxx:427
 TEvePointSet.cxx:428
 TEvePointSet.cxx:429
 TEvePointSet.cxx:430
 TEvePointSet.cxx:431
 TEvePointSet.cxx:432
 TEvePointSet.cxx:433
 TEvePointSet.cxx:434
 TEvePointSet.cxx:435
 TEvePointSet.cxx:436
 TEvePointSet.cxx:437
 TEvePointSet.cxx:438
 TEvePointSet.cxx:439
 TEvePointSet.cxx:440
 TEvePointSet.cxx:441
 TEvePointSet.cxx:442
 TEvePointSet.cxx:443
 TEvePointSet.cxx:444
 TEvePointSet.cxx:445
 TEvePointSet.cxx:446
 TEvePointSet.cxx:447
 TEvePointSet.cxx:448
 TEvePointSet.cxx:449
 TEvePointSet.cxx:450
 TEvePointSet.cxx:451
 TEvePointSet.cxx:452
 TEvePointSet.cxx:453
 TEvePointSet.cxx:454
 TEvePointSet.cxx:455
 TEvePointSet.cxx:456
 TEvePointSet.cxx:457
 TEvePointSet.cxx:458
 TEvePointSet.cxx:459
 TEvePointSet.cxx:460
 TEvePointSet.cxx:461
 TEvePointSet.cxx:462
 TEvePointSet.cxx:463
 TEvePointSet.cxx:464
 TEvePointSet.cxx:465
 TEvePointSet.cxx:466
 TEvePointSet.cxx:467
 TEvePointSet.cxx:468
 TEvePointSet.cxx:469
 TEvePointSet.cxx:470
 TEvePointSet.cxx:471
 TEvePointSet.cxx:472
 TEvePointSet.cxx:473
 TEvePointSet.cxx:474
 TEvePointSet.cxx:475
 TEvePointSet.cxx:476
 TEvePointSet.cxx:477
 TEvePointSet.cxx:478
 TEvePointSet.cxx:479
 TEvePointSet.cxx:480
 TEvePointSet.cxx:481
 TEvePointSet.cxx:482
 TEvePointSet.cxx:483
 TEvePointSet.cxx:484
 TEvePointSet.cxx:485
 TEvePointSet.cxx:486
 TEvePointSet.cxx:487
 TEvePointSet.cxx:488
 TEvePointSet.cxx:489
 TEvePointSet.cxx:490
 TEvePointSet.cxx:491
 TEvePointSet.cxx:492
 TEvePointSet.cxx:493
 TEvePointSet.cxx:494
 TEvePointSet.cxx:495
 TEvePointSet.cxx:496
 TEvePointSet.cxx:497
 TEvePointSet.cxx:498
 TEvePointSet.cxx:499
 TEvePointSet.cxx:500
 TEvePointSet.cxx:501
 TEvePointSet.cxx:502
 TEvePointSet.cxx:503
 TEvePointSet.cxx:504
 TEvePointSet.cxx:505
 TEvePointSet.cxx:506
 TEvePointSet.cxx:507
 TEvePointSet.cxx:508
 TEvePointSet.cxx:509
 TEvePointSet.cxx:510
 TEvePointSet.cxx:511
 TEvePointSet.cxx:512
 TEvePointSet.cxx:513
 TEvePointSet.cxx:514
 TEvePointSet.cxx:515
 TEvePointSet.cxx:516
 TEvePointSet.cxx:517
 TEvePointSet.cxx:518
 TEvePointSet.cxx:519
 TEvePointSet.cxx:520
 TEvePointSet.cxx:521
 TEvePointSet.cxx:522
 TEvePointSet.cxx:523
 TEvePointSet.cxx:524
 TEvePointSet.cxx:525
 TEvePointSet.cxx:526
 TEvePointSet.cxx:527
 TEvePointSet.cxx:528
 TEvePointSet.cxx:529
 TEvePointSet.cxx:530
 TEvePointSet.cxx:531
 TEvePointSet.cxx:532
 TEvePointSet.cxx:533
 TEvePointSet.cxx:534
 TEvePointSet.cxx:535
 TEvePointSet.cxx:536
 TEvePointSet.cxx:537
 TEvePointSet.cxx:538
 TEvePointSet.cxx:539
 TEvePointSet.cxx:540
 TEvePointSet.cxx:541
 TEvePointSet.cxx:542
 TEvePointSet.cxx:543
 TEvePointSet.cxx:544
 TEvePointSet.cxx:545
 TEvePointSet.cxx:546
 TEvePointSet.cxx:547
 TEvePointSet.cxx:548
 TEvePointSet.cxx:549
 TEvePointSet.cxx:550
 TEvePointSet.cxx:551
 TEvePointSet.cxx:552
 TEvePointSet.cxx:553
 TEvePointSet.cxx:554
 TEvePointSet.cxx:555
 TEvePointSet.cxx:556
 TEvePointSet.cxx:557
 TEvePointSet.cxx:558
 TEvePointSet.cxx:559
 TEvePointSet.cxx:560
 TEvePointSet.cxx:561
 TEvePointSet.cxx:562
 TEvePointSet.cxx:563
 TEvePointSet.cxx:564
 TEvePointSet.cxx:565
 TEvePointSet.cxx:566
 TEvePointSet.cxx:567
 TEvePointSet.cxx:568
 TEvePointSet.cxx:569
 TEvePointSet.cxx:570
 TEvePointSet.cxx:571
 TEvePointSet.cxx:572
 TEvePointSet.cxx:573
 TEvePointSet.cxx:574
 TEvePointSet.cxx:575
 TEvePointSet.cxx:576
 TEvePointSet.cxx:577
 TEvePointSet.cxx:578
 TEvePointSet.cxx:579
 TEvePointSet.cxx:580
 TEvePointSet.cxx:581
 TEvePointSet.cxx:582
 TEvePointSet.cxx:583
 TEvePointSet.cxx:584
 TEvePointSet.cxx:585
 TEvePointSet.cxx:586
 TEvePointSet.cxx:587
 TEvePointSet.cxx:588
 TEvePointSet.cxx:589
 TEvePointSet.cxx:590
 TEvePointSet.cxx:591
 TEvePointSet.cxx:592
 TEvePointSet.cxx:593
 TEvePointSet.cxx:594
 TEvePointSet.cxx:595
 TEvePointSet.cxx:596
 TEvePointSet.cxx:597
 TEvePointSet.cxx:598
 TEvePointSet.cxx:599
 TEvePointSet.cxx:600
 TEvePointSet.cxx:601
 TEvePointSet.cxx:602
 TEvePointSet.cxx:603
 TEvePointSet.cxx:604
 TEvePointSet.cxx:605
 TEvePointSet.cxx:606
 TEvePointSet.cxx:607
 TEvePointSet.cxx:608
 TEvePointSet.cxx:609
 TEvePointSet.cxx:610
 TEvePointSet.cxx:611
 TEvePointSet.cxx:612
 TEvePointSet.cxx:613
 TEvePointSet.cxx:614
 TEvePointSet.cxx:615
 TEvePointSet.cxx:616
 TEvePointSet.cxx:617
 TEvePointSet.cxx:618
 TEvePointSet.cxx:619
 TEvePointSet.cxx:620
 TEvePointSet.cxx:621
 TEvePointSet.cxx:622
 TEvePointSet.cxx:623
 TEvePointSet.cxx:624
 TEvePointSet.cxx:625
 TEvePointSet.cxx:626
 TEvePointSet.cxx:627
 TEvePointSet.cxx:628
 TEvePointSet.cxx:629
 TEvePointSet.cxx:630
 TEvePointSet.cxx:631
 TEvePointSet.cxx:632
 TEvePointSet.cxx:633
 TEvePointSet.cxx:634
 TEvePointSet.cxx:635
 TEvePointSet.cxx:636
 TEvePointSet.cxx:637
 TEvePointSet.cxx:638
 TEvePointSet.cxx:639
 TEvePointSet.cxx:640
 TEvePointSet.cxx:641
 TEvePointSet.cxx:642
 TEvePointSet.cxx:643
 TEvePointSet.cxx:644
 TEvePointSet.cxx:645
 TEvePointSet.cxx:646
 TEvePointSet.cxx:647
 TEvePointSet.cxx:648
 TEvePointSet.cxx:649
 TEvePointSet.cxx:650
 TEvePointSet.cxx:651
 TEvePointSet.cxx:652
 TEvePointSet.cxx:653
 TEvePointSet.cxx:654
 TEvePointSet.cxx:655
 TEvePointSet.cxx:656
 TEvePointSet.cxx:657
 TEvePointSet.cxx:658
 TEvePointSet.cxx:659
 TEvePointSet.cxx:660
 TEvePointSet.cxx:661
 TEvePointSet.cxx:662
 TEvePointSet.cxx:663
 TEvePointSet.cxx:664
 TEvePointSet.cxx:665
 TEvePointSet.cxx:666
 TEvePointSet.cxx:667
 TEvePointSet.cxx:668
 TEvePointSet.cxx:669
 TEvePointSet.cxx:670
 TEvePointSet.cxx:671
 TEvePointSet.cxx:672
 TEvePointSet.cxx:673
 TEvePointSet.cxx:674
 TEvePointSet.cxx:675
 TEvePointSet.cxx:676
 TEvePointSet.cxx:677
 TEvePointSet.cxx:678
 TEvePointSet.cxx:679
 TEvePointSet.cxx:680
 TEvePointSet.cxx:681
 TEvePointSet.cxx:682
 TEvePointSet.cxx:683
 TEvePointSet.cxx:684
 TEvePointSet.cxx:685
 TEvePointSet.cxx:686
 TEvePointSet.cxx:687
 TEvePointSet.cxx:688
 TEvePointSet.cxx:689
 TEvePointSet.cxx:690
 TEvePointSet.cxx:691
 TEvePointSet.cxx:692
 TEvePointSet.cxx:693
 TEvePointSet.cxx:694
 TEvePointSet.cxx:695
 TEvePointSet.cxx:696
 TEvePointSet.cxx:697
 TEvePointSet.cxx:698
 TEvePointSet.cxx:699
 TEvePointSet.cxx:700
 TEvePointSet.cxx:701
 TEvePointSet.cxx:702
 TEvePointSet.cxx:703
 TEvePointSet.cxx:704
 TEvePointSet.cxx:705
 TEvePointSet.cxx:706
 TEvePointSet.cxx:707
 TEvePointSet.cxx:708
 TEvePointSet.cxx:709
 TEvePointSet.cxx:710
 TEvePointSet.cxx:711
 TEvePointSet.cxx:712
 TEvePointSet.cxx:713
 TEvePointSet.cxx:714
 TEvePointSet.cxx:715
 TEvePointSet.cxx:716
 TEvePointSet.cxx:717
 TEvePointSet.cxx:718
 TEvePointSet.cxx:719
 TEvePointSet.cxx:720
 TEvePointSet.cxx:721
 TEvePointSet.cxx:722
 TEvePointSet.cxx:723
 TEvePointSet.cxx:724
 TEvePointSet.cxx:725
 TEvePointSet.cxx:726
 TEvePointSet.cxx:727
 TEvePointSet.cxx:728
 TEvePointSet.cxx:729
 TEvePointSet.cxx:730
 TEvePointSet.cxx:731
 TEvePointSet.cxx:732
 TEvePointSet.cxx:733
 TEvePointSet.cxx:734
 TEvePointSet.cxx:735
 TEvePointSet.cxx:736
 TEvePointSet.cxx:737
 TEvePointSet.cxx:738
 TEvePointSet.cxx:739
 TEvePointSet.cxx:740
 TEvePointSet.cxx:741
 TEvePointSet.cxx:742
 TEvePointSet.cxx:743
 TEvePointSet.cxx:744
 TEvePointSet.cxx:745
 TEvePointSet.cxx:746
 TEvePointSet.cxx:747
 TEvePointSet.cxx:748
 TEvePointSet.cxx:749
 TEvePointSet.cxx:750
 TEvePointSet.cxx:751
 TEvePointSet.cxx:752
 TEvePointSet.cxx:753
 TEvePointSet.cxx:754
 TEvePointSet.cxx:755
 TEvePointSet.cxx:756
 TEvePointSet.cxx:757
 TEvePointSet.cxx:758
 TEvePointSet.cxx:759
 TEvePointSet.cxx:760
 TEvePointSet.cxx:761
 TEvePointSet.cxx:762
 TEvePointSet.cxx:763
 TEvePointSet.cxx:764
 TEvePointSet.cxx:765
 TEvePointSet.cxx:766
 TEvePointSet.cxx:767
 TEvePointSet.cxx:768
 TEvePointSet.cxx:769
 TEvePointSet.cxx:770
 TEvePointSet.cxx:771
 TEvePointSet.cxx:772
 TEvePointSet.cxx:773
 TEvePointSet.cxx:774
 TEvePointSet.cxx:775
 TEvePointSet.cxx:776
 TEvePointSet.cxx:777
 TEvePointSet.cxx:778
 TEvePointSet.cxx:779
 TEvePointSet.cxx:780
 TEvePointSet.cxx:781
 TEvePointSet.cxx:782
 TEvePointSet.cxx:783
 TEvePointSet.cxx:784
 TEvePointSet.cxx:785
 TEvePointSet.cxx:786
 TEvePointSet.cxx:787
 TEvePointSet.cxx:788
 TEvePointSet.cxx:789
 TEvePointSet.cxx:790
 TEvePointSet.cxx:791
 TEvePointSet.cxx:792
 TEvePointSet.cxx:793
 TEvePointSet.cxx:794
 TEvePointSet.cxx:795
 TEvePointSet.cxx:796
 TEvePointSet.cxx:797
 TEvePointSet.cxx:798
 TEvePointSet.cxx:799
 TEvePointSet.cxx:800
 TEvePointSet.cxx:801
 TEvePointSet.cxx:802
 TEvePointSet.cxx:803
 TEvePointSet.cxx:804
 TEvePointSet.cxx:805
 TEvePointSet.cxx:806
 TEvePointSet.cxx:807
 TEvePointSet.cxx:808
 TEvePointSet.cxx:809
 TEvePointSet.cxx:810
 TEvePointSet.cxx:811
 TEvePointSet.cxx:812
 TEvePointSet.cxx:813
 TEvePointSet.cxx:814
 TEvePointSet.cxx:815
 TEvePointSet.cxx:816
 TEvePointSet.cxx:817
 TEvePointSet.cxx:818
 TEvePointSet.cxx:819
 TEvePointSet.cxx:820
 TEvePointSet.cxx:821
 TEvePointSet.cxx:822
 TEvePointSet.cxx:823
 TEvePointSet.cxx:824
 TEvePointSet.cxx:825
 TEvePointSet.cxx:826
 TEvePointSet.cxx:827