Public Types | Public Member Functions | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
ProjectorBase Class Reference

The base class for the Projector hierarchy. More...

#include <ProjectorBase.h>

Inheritance diagram for ProjectorBase:
Inheritance graph
[legend]
Collaboration diagram for ProjectorBase:
Collaboration graph
[legend]

Public Types

typedef void(Observer::* Action )(const Observable *)
 The member function of the Observer that is called.
typedef std::list< Observer * > ObserverList_t
 The type of STL container to maintain list of Observer objects.

Public Member Functions

void addObserver (Observer *)
 Adds an Observer to the Observer list.
virtual void addValues (const std::vector< double > &v)
 Add values to the projection.
virtual void checkScaling ()
 Checks for scaling the display of the axis range.
virtual ProjectorBaseclone ()=0
 The clone function returns an object of its own kind which is a copy of this object at this moment.
virtual DataSourcecreateNTuple () const =0
 Creates an NTuple representation of the projected values.
virtual NTuplecreateNTupleWith (const std::vector< TupleCut > &cut_list) const
 Creates a NTuple from the projector's DataSource object using cut_list for not including rows that do not pass the cuts.
virtual const DataSourcecreateOldStyleNTuple () const
virtual Range dataRangeOn (Axes::Type) const =0
 Returns the range of the raw data.
virtual void fillColumnAfterCuts (const std::string &column, std::vector< double > &columnData) const
 Fill the vector with values from named column with the present set of cuts applied.
virtual double getAverage (Axes::Type axis) const
 Get the Average of all projected values on the specified axis.
virtual const std::vector
< std::string > & 
getAxisBindings () const
 Returns the axis bindings.
virtual AxisModelBasegetAxisModel (Axes::Type axis) const
 Get the AxisModel for axis axis.
virtual double getBinWidth (Axes::Type axis) const
 Returns the bin width of the axis.
virtual int getMinEntries ()
 Get the minimum entries/bin.
virtual NTuplegetNTupleAfterCuts () const
 Template for projectors that can return subsets of the NTuple used by the DataRep.
virtual int getNumberOfBins (Axes::Type) const
 Returns the number of bins.
virtual int getNumberOfEntries () const =0
 Returns the total number of entries that went into creating the projected values.
const ObserverList_tgetObservers () const
 Returns the list of observers.
virtual double getOffset (Axes::Type axis) const
 Returns the offset of the axis.
virtual int getOverflow () const =0
 Returns the number of overflow.
const std::vector< std::string > & getPointReps () const
 Return the vector of Point Reps.
virtual double getPosOn (Axes::Type) const =0
 Returns the minimum positive value.
const DataSourcegetProjectedValues () const
 Returns DataSource representation of projected values.
virtual const RangegetRange (Axes::Type) const
 Returns the Range along the specified axis.
virtual double getRMS (Axes::Type axis)
 Returns the RMS.
const std::vector< unsigned int > & getShape ()
 Get the shape of the projected values.
virtual const std::string & getTitle () const =0
 Finds the title of the plot.
virtual int getUnderflow () const =0
 Returns the number of underflow.
virtual const std::string & getXLabel () const =0
 Finds the X axis label of the plot.
virtual const std::string & getYLabel (bool flag=false) const =0
 Finds the Y axis label of the plot.
const std::vector< double > & getZAfterTransform (TransformBase *transform)
 Return Z values after binary transform.
virtual const std::string & getZLabel () const
 Finds the Z axis label of the plot.
virtual double getZValue (double x, double y) const
 Get the z value at the specified point (x,y).
const std::vector< double > & getZValues ()
 Return all Z values.
virtual bool hasDataSourceBindings () const
 Returns true if projector has binding to a DataSource.
virtual int indexOf (const std::string &label) const
 Returns the index of the label.
virtual bool isAxisBinned (const std::string &axis) const
 Returns true if specified axis is binned.
bool isDirty () const
 Returns true if the projector has been marked dirty.
virtual bool isEmpty () const =0
 Returns true if the data source used by this projector is empty.
virtual bool isImageConvertable () const
 Returns true if the projected values can converted to an image.
virtual bool isValueBinned () const
 Returns true if the projected values are the result of binning.
virtual void matrixTranspose (bool yes)
 Transposes the X and Y axis.
virtual void normalizeTo (const ProjectorBase *target)
 Sets the target of normalization.
virtual void normalizeTo (double norm)
 Sets a scale factor on the output so that the number of entries appears to be number.
virtual void notifyObservers () const
 Notifies Observer objects of a change.
virtual Range preferredRange (Axes::Type) const
 Returns the preferred Range.
virtual void prepareValues ()
 Informs the projector to prepare its projected values for plotting.
 ProjectorBase ()
 The default constructor.
void removeObserver (Observer *)
 Removes an Observer from the Observer list.
virtual void reset ()
 Resets the bins.
virtual void setAxisBinding (const std::string &axis, const std::string &label)
 Sets the axis binding.
virtual void setAxisBindings (const std::vector< std::string > &bindings)
 Sets the axis binding.
virtual void setAxisModel (Axes::Type axis, AxisModelBase *)
 Sets the AxisModel for axis axis.
virtual const RangesetBinWidth (Axes::Type axis, double width)
 Sets the bin width.
virtual const RangesetBinWidth (Axes::Type axis, int parm, bool dragging)
 Sets the bin width.
virtual void setDirty (bool value=true)
 Sets the dirty flag to value.
virtual void setMinEntries (int entries)
 Set the minimum entries/bin.
virtual void setNormalizing (bool on)
 Sets the scaling number of entries on if on is true, otherwise turns if off.
virtual void setNumberOfBins (Axes::Type axis, unsigned int number)
 Sets the number of bins.
virtual void setOffset (const std::string &axis, int parm, bool dragging)
 Sets the bin offset.
virtual void setOffset (Axes::Type axis, double offset)
 Sets the bin offset.
virtual void setRange (Axes::Type axis, bool const_width=true)
 Sets the range of the selected axis.
virtual void update (const Observable *)
 Implements the Observer pattern.
virtual Range valueRange () const =0
 Finds the range of the projected values.
virtual bool wantsScaleFactor (const std::string &axis) const
 Returns whether the projector wants scale factor.
virtual void willDelete (const Observable *)
 Notifies this Observer object that one of its Observable objects is about to be deleted.
virtual ~ProjectorBase ()
 The virtual destructor.

Protected Member Functions

virtual void addPointReps ()=0
 Function to add the acceptable point reps.
void notifyObservers (Action action) const
 An internal method to iterate over all observers and to send the message action.
 ProjectorBase (const ProjectorBase &projector)
 The copy constructor.

Protected Attributes

std::vector< std::string > m_pointreps
 Vector of acceptable PointReps.
DataSourcem_proj_values
 The NTuple representing the result of the projection.
const ProjectorBasem_target
 The target projector.
AxisModelBasem_x_axis
 The AxisModel along the X axis.
AxisModelBasem_y_axis
 The AxisModel along the Y axis.
AxisModelBasem_z_axis
 The AxisModel along the Z axis.
std::string m_z_label
 Dummy member so that getZLabel can return a reference.
std::vector< double > m_zval
 Sorted Z values in this projector.

Private Attributes

bool m_isDirty
 Marks the object as dirty.

Detailed Description

The base class for the Projector hierarchy.

Derived classes create DataSource of projected values. The format of the NTuple is either DataPoint2DTuple or DataPoint3DTuple. There are multiple clients of NTuple including a derived class RepBase, the the function fitters.

This base class also declares the virtual interface to inquiring about the range of the projected values which must be implemented in the derived classes. The Projectors can find the range much more efficiently than clients using iterators to projected values.

Author
Stephane Bonneaud ganda.nosp@m.lf@s.nosp@m.lac.s.nosp@m.tanf.nosp@m.ord.e.nosp@m.du
Xie Fang xiefa.nosp@m.ng@s.nosp@m.tanfo.nosp@m.rd.e.nosp@m.du
Paul F. Kunz Paul_.nosp@m.Kunz.nosp@m.@slac.nosp@m..sta.nosp@m.nford.nosp@m..edu
Matan Shacham matan.nosp@m.@sla.nosp@m.c.sta.nosp@m.nfor.nosp@m.d.edu
Oded Wurman owurm.nosp@m.an@s.nosp@m.tanfo.nosp@m.rd.e.nosp@m.du

Definition at line 56 of file ProjectorBase.h.

Member Typedef Documentation

typedef void( Observer::* Action)(const Observable *)
inherited

The member function of the Observer that is called.

Definition at line 86 of file Observable.h.

typedef std::list< Observer * > ObserverList_t
inherited

The type of STL container to maintain list of Observer objects.

Definition at line 45 of file Observable.h.

Constructor & Destructor Documentation

ProjectorBase ( const ProjectorBase projector)
protected

The copy constructor.

Definition at line 48 of file ProjectorBase.cxx.

The default constructor.

Definition at line 39 of file ProjectorBase.cxx.

~ProjectorBase ( )
virtual

The virtual destructor.

Definition at line 59 of file ProjectorBase.cxx.

References ProjectorBase::m_proj_values.

Member Function Documentation

void addObserver ( hippodraw::Observer observer)
inherited
virtual void addPointReps ( )
protectedpure virtual
void addValues ( const std::vector< double > &  v)
virtual

Add values to the projection.

This method is provided as convenience for derived classes that respond to it. The implementation in this class does nothing.

Reimplemented in StHist2DProjector, and StHist1DProjector.

Definition at line 330 of file ProjectorBase.cxx.

void checkScaling ( )
virtual

Checks for scaling the display of the axis range.

This base class implementation does nothing. Derived classes should override this method if scaling of the axis is meaningful to them.

Reimplemented in Hist1DProjImp, BinningProjector, and Hist2DProjImp.

Definition at line 416 of file ProjectorBase.cxx.

virtual ProjectorBase* clone ( )
pure virtual
virtual DataSource* createNTuple ( ) const
pure virtual

Creates an NTuple representation of the projected values.

Derived classes should create a representation appropriate for their projection. They should at least include the coordinates, the width of the coordinates, the value and the error on the value.

Implemented in MapMatrixProjector, FunctionProjector, BinningProjector, EqualEntriesHist1DProjector, Map1Projector, MeshProjector, Map2Projector, Map3Projector, and LineProjector.

NTuple * createNTupleWith ( const std::vector< TupleCut > &  cut_list) const
virtual

Creates a NTuple from the projector's DataSource object using cut_list for not including rows that do not pass the cuts.

Note
This base class implementation returns a null pointer.

Reimplemented in NTupleProjector.

Definition at line 356 of file ProjectorBase.cxx.

const DataSource * createOldStyleNTuple ( ) const
virtual
virtual Range dataRangeOn ( Axes::Type  ) const
pure virtual
void fillColumnAfterCuts ( const std::string &  column,
std::vector< double > &  columnData 
) const
virtual

Fill the vector with values from named column with the present set of cuts applied.

This default implementation does nothing.

Reimplemented in NTupleProjector.

Definition at line 349 of file ProjectorBase.cxx.

Referenced by DataRep::fillColumnAfterCuts().

double getAverage ( Axes::Type  axis) const
virtual

Get the Average of all projected values on the specified axis.

Todo:
this should be computed externally with the iterators
Todo:
Resolve if this method should be done exterior to the projector class by a functor using iterators.

Reimplemented in NTupleProjector, MapMatrixProjector, StHist2DProjector, Map1Projector, EqualEntriesHist1DProjector, DyHist1DProjector, and StHist1DProjector.

Definition at line 278 of file ProjectorBase.cxx.

Referenced by AverageTextRep::drawProjectedValues().

const vector< string > & getAxisBindings ( ) const
virtual

Returns the axis bindings.

Returns the name associated with each axis. This member function should only be called with a derived class which can process it in a meaningful way. thus if this method is called on this base class, an assertion is raised.

Reimplemented in NTupleProjector.

Definition at line 99 of file ProjectorBase.cxx.

Referenced by VariableMesh::setAxisBindings(), and XYPlot::setAxisBindings().

AxisModelBase * getAxisModel ( Axes::Type  axis) const
virtual
double getBinWidth ( Axes::Type  axis) const
virtual

Returns the bin width of the axis.

Not all projectors has a notation of a bin width. This interface is declared for those that do. The implementation in this base class is to does nothing.

Reimplemented in MapMatrixProjector, EqualEntriesHist1DProjector, and BinningProjector.

Definition at line 316 of file ProjectorBase.cxx.

Referenced by PyDataRep::getBinWidth(), and CompositePlotter::getBinWidth().

int getMinEntries ( )
virtual

Get the minimum entries/bin.

Reimplemented in BinningProjector.

Definition at line 531 of file ProjectorBase.cxx.

Referenced by CompositePlotter::getMinEntries().

NTuple * getNTupleAfterCuts ( ) const
virtual

Template for projectors that can return subsets of the NTuple used by the DataRep.

Reimplemented in NTupleProjector.

Definition at line 342 of file ProjectorBase.cxx.

Referenced by DataRep::getNTupleAfterCuts().

int getNumberOfBins ( Axes::Type  ) const
virtual

Returns the number of bins.

Returns the number of bins on the specified axis. The result is 0 if the axis is not binned.

Reimplemented in MapMatrixProjector, and BinningProjector.

Definition at line 116 of file ProjectorBase.cxx.

virtual int getNumberOfEntries ( ) const
pure virtual

Returns the total number of entries that went into creating the projected values.

It is up to derived classes to interpret what this means. Some may find it meaningless and raise an exception and/or assertion.

Implemented in NTupleProjector, FunctionProjector, StHist2DProjector, StHist1DProjector, and LineProjector.

Referenced by TotalTextRep::drawProjectedValues(), BinningProjector::normalize(), and QtDisplay::numberOfEntries().

const Observable::ObserverList_t & getObservers ( ) const
inherited

Returns the list of observers.

Definition at line 60 of file Observable.cxx.

double getOffset ( Axes::Type  axis) const
virtual

Returns the offset of the axis.

Not all projectors has a notation of a bin width. This interface is declared for those that do. The implementation in this base class is to does nothing.

Reimplemented in MapMatrixProjector, and BinningProjector.

Definition at line 268 of file ProjectorBase.cxx.

Referenced by CompositePlotter::getOffset().

virtual int getOverflow ( ) const
pure virtual
const vector< string > & getPointReps ( ) const

Return the vector of Point Reps.

Definition at line 335 of file ProjectorBase.cxx.

References ProjectorBase::m_pointreps.

virtual double getPosOn ( Axes::Type  ) const
pure virtual
const DataSource * getProjectedValues ( ) const
const Range & getRange ( Axes::Type  axis) const
virtual
double getRMS ( Axes::Type  axis)
virtual

Returns the RMS.

Returns the root mean square of the data points along the axis axis.

Requests:
Can do better than use only the projected values in some derived classes.

Definition at line 289 of file ProjectorBase.cxx.

References ProjectorBase::getProjectedValues(), ProjectorHelper::stdCoord(), and hippodraw::Axes::X.

const std::vector< unsigned int > & getShape ( )

Get the shape of the projected values.

Used to export FITS file.

Definition at line 444 of file ProjectorBase.cxx.

References ProjectorBase::getProjectedValues(), and DataSource::getShape().

Referenced by ProjectorBase::getZValues().

virtual const std::string& getTitle ( ) const
pure virtual

Finds the title of the plot.

Implemented in NTupleProjector, FunctionProjector, StHist2DProjector, StHist1DProjector, and LineProjector.

virtual int getUnderflow ( ) const
pure virtual
virtual const std::string& getXLabel ( ) const
pure virtual

Finds the X axis label of the plot.

A plotter may ask the projector for the default label.

Implemented in NTupleProjector, MapMatrixProjector, FunctionProjector, Map1Projector, StHist2DProjector, StHist1DProjector, and LineProjector.

Referenced by CompositePlotter::getLabel().

virtual const std::string& getYLabel ( bool  flag = false) const
pure virtual

Finds the Y axis label of the plot.

Derived classes should return a label for the Y axis that is meaningful for the kind of projection. The argument flag can be used to distinguish between two possible labels, depending on some state of the projector.

Implemented in NTupleProjector, MapMatrixProjector, FunctionProjector, Map1Projector, EqualEntriesHist1DProjector, StHist2DProjector, DyHist1DProjector, StHist1DProjector, and LineProjector.

Referenced by CompositePlotter::getLabel().

const std::vector< double > & getZAfterTransform ( TransformBase transform)

Return Z values after binary transform.

Todo:
This is the only method in all the classes of this directory that needs a heder file from transform directory. Is there a better way?

Definition at line 456 of file ProjectorBase.cxx.

References ProjectorBase::getZValue(), BinaryTransform::inverseTransform(), and ProjectorBase::m_zval.

const std::string & getZLabel ( ) const
virtual

Finds the Z axis label of the plot.

A plotter may ask the projector for the default label.

Todo:
Change to fetch labels by AxesType or its replacement.

Reimplemented in MapMatrixProjector, FunctionProjector, Profile2DProjector, Hist2DProjImp, MeshProjector, and Map3Projector.

Definition at line 302 of file ProjectorBase.cxx.

References ProjectorBase::m_z_label.

Referenced by NTupleProjector::getAverage(), and CompositePlotter::getLabel().

double getZValue ( double  x,
double  y 
) const
virtual

Get the z value at the specified point (x,y).

Reimplemented in MapMatrixProjector, BinningProjector, MeshProjector, and Map3Projector.

Definition at line 323 of file ProjectorBase.cxx.

Referenced by ProjectorBase::getZAfterTransform(), and CompositePlotter::getZValue().

const std::vector< double > & getZValues ( )
bool hasDataSourceBindings ( ) const
virtual

Returns true if projector has binding to a DataSource.

This base class implementation returns false. Derived classes that have DataSource binding should override this member function and return true.

Reimplemented in NTupleProjector.

Definition at line 518 of file ProjectorBase.cxx.

Referenced by BinningProjectorXML::createChildren().

int indexOf ( const std::string &  label) const
virtual

Returns the index of the label.

For example, the column index.

Reimplemented in NTupleProjector.

Definition at line 309 of file ProjectorBase.cxx.

bool isAxisBinned ( const std::string &  axis) const
virtual

Returns true if specified axis is binned.

An axis that is binned responds to the width and offset controls. This base class implementation returns false.

Reimplemented in Profile2DProjector, EqualEntriesHist1DProjector, DyHist1DProjector, DyHist2DProjector, StHist2DProjector, StHist1DProjector, and ProfileProjector.

Definition at line 121 of file ProjectorBase.cxx.

Referenced by CompositePlotter::getBinWidth(), CompositePlotter::getOffset(), DisplayController::isAxisBinned(), DisplayController::setBinner(), and BinningProjector::setBinnerOn().

bool isDirty ( ) const

Returns true if the projector has been marked dirty.

A dirty projector is one whose projected values are invalid because of some change (e.g., an axis range has changed.)

Definition at line 70 of file ProjectorBase.cxx.

References ProjectorBase::m_isDirty.

Referenced by Profile2DProjector::dataRangeOn(), DataRep::isDirty(), Map2Projector::prepareValues(), MeshProjector::prepareValues(), BinningProjector::prepareValues(), MapMatrixProjector::prepareValues(), and Profile2DProjector::valueRange().

virtual bool isEmpty ( ) const
pure virtual

Returns true if the data source used by this projector is empty.

Returns true if the data source used by this projector is empty, otherwise returns true. The data source is empty, i.e. has no data, then many member functions of this class can not respond with meaning full results.

Implemented in NTupleProjector, FunctionProjector, StHist2DProjector, LineProjector, and StHist1DProjector.

Referenced by DataRep::hasZeroRows().

bool isImageConvertable ( ) const
virtual

Returns true if the projected values can converted to an image.

Returns true if this projected values can be converted to an image. An image is defined as a regular grid of values. As a convenience to implementers of derived classes, this base class method returns false.

Reimplemented in MapMatrixProjector, and BinningProjector.

Definition at line 538 of file ProjectorBase.cxx.

bool isValueBinned ( ) const
virtual

Returns true if the projected values are the result of binning.

The implementation in this base class returns false. It maybe overridden in derived classes that do binning.

Reimplemented in Hist2DProjImp, and Hist1DProjImp.

Definition at line 126 of file ProjectorBase.cxx.

Referenced by BinningProjector::normalizeTo().

void matrixTranspose ( bool  yes)
virtual

Transposes the X and Y axis.

The implementation in this base class does nothing.

Reimplemented in MapMatrixProjector.

Definition at line 109 of file ProjectorBase.cxx.

void normalizeTo ( const ProjectorBase target)
virtual

Sets the target of normalization.

The meaning of normalizing the projected values of one projector to another one depends on the derived class. This implementation in this base does nothing.

Reimplemented in BinningProjector.

Definition at line 409 of file ProjectorBase.cxx.

void normalizeTo ( double  norm)
virtual

Sets a scale factor on the output so that the number of entries appears to be number.

This feature might be used, for example, to compare two histograms that have different number of entries by normalizing one to the other.

Reimplemented in BinningProjector.

Definition at line 388 of file ProjectorBase.cxx.

void notifyObservers ( ) const
virtualinherited

Notifies Observer objects of a change.

If interval counting is disabled, then Observer::Update is sent immediately. If interval counting is enabled, then the current count is incremented. If the current count is equal to the interval count, then the Observer::update message is sent and the current count reset to 0.

Reimplemented in NTuple, RootNTuple, NumArrayTuple, ListTuple, and FitsNTuple.

Definition at line 93 of file Observable.cxx.

References Observer::update().

Referenced by XyPlotter::addDataRep(), XyPlotter::addDataRepStacked(), FunctionController::addFunctionRep(), StHist1DProjector::addValues(), StHist2DProjector::addValues(), XyPlotter::autoScale(), Inspector::contourLevelsTextBox_returnPressed(), Inspector::contourSlider_valueChanged(), Inspector::contourTextBox_returnPressed(), FunctionRep::fitFunction(), XyPlotter::removeDataRep(), FunctionRep::restoreParameters(), DataRep::set(), CutPlotter::setActive(), PlotterBase::setAspectRatio(), XyPlotter::setAutoRanging(), XyPlotter::setBoxEdge(), QtDisplay::setContourLevels(), CutPlotter::setCutColor(), XyPlotter::setCutEnabled(), XyPlotter::setCutInverted(), XyPlotter::setCutRangeAt(), ProjectorBase::setDirty(), DataRep::setErrorDisplay(), XyPlotter::setHighRange(), PlotterBase::setLabel(), XyPlotter::setLabel(), DataSource::setLabelAt(), DataSource::setLabels(), XyPlotter::setLowRange(), DataSource::setName(), DisplayController::setNTuple(), FunctionRep::setParameters(), DyHistogram::setPointRep(), DyHistogramEqualEntries::setPointRep(), DataRep::setPointRep(), TextPlotter::setRepColor(), DataRep::setRepColor(), DataRep::setRepSize(), DataRep::setRepStyle(), XyPlotter::setReverse(), XyPlotter::setScaling(), XyPlotter::setShowGrid(), DataSource::setTitle(), PlotterBase::setTitle(), XyPlotter::setTransform(), XyPlotter::setValueRep(), NTupleProjector::update(), BinningProjector::update(), DataRep::update(), PlotterBase::update(), CutPlotter::update(), CutPlotter::updateTargets(), DataRep::~DataRep(), DataSource::~DataSource(), PlotterBase::~PlotterBase(), and RTuple::~RTuple().

void notifyObservers ( Action  action) const
protectedinherited

An internal method to iterate over all observers and to send the message action.

Definition at line 72 of file Observable.cxx.

Range preferredRange ( Axes::Type  axis) const
virtual

Returns the preferred Range.

Returns the Range preferred by the projector. The default implementation in this base class is to return full range of the data on the axis. Derived classes, may need to override this implementation.

Reimplemented in MapMatrixProjector, MeshProjector, Hist2DProjImp, and Hist1DProjImp.

Definition at line 163 of file ProjectorBase.cxx.

References ProjectorBase::dataRangeOn(), Range::length(), Range::low(), Range::setHigh(), Range::setLow(), and hippodraw::Axes::Y.

Referenced by DataRep::preferredRange().

void prepareValues ( )
virtual

Informs the projector to prepare its projected values for plotting.

This base class implementation sets the dirty flag to false indicating that the values are already prepared. Projectors that need to calculate the projected values should override this method and also set the dirty flag to false. For example, a projector might accumulate data into bins, and the position of the bin and its number of entries are used for the projected values.

Reimplemented in MapMatrixProjector, BinningProjector, EqualEntriesHist1DProjector, Map1Projector, MeshProjector, Map2Projector, Map3Projector, and LineProjector.

Definition at line 65 of file ProjectorBase.cxx.

References ProjectorBase::setDirty().

Referenced by DataRep::createNTuple(), ProjectorBase::createOldStyleNTuple(), FunctionProjector::fitFunction(), DataRep::getProjectedValues(), and FunctionProjector::initializeFunction().

void removeObserver ( hippodraw::Observer observer)
inherited
void reset ( )
virtual

Resets the bins.

This interface is for the StHist1DProjector

Reimplemented in StHist1DProjector, BinningProjector, and Hist1DProjImp.

Definition at line 262 of file ProjectorBase.cxx.

Referenced by CompositePlotter::reset().

void setAxisBinding ( const std::string &  axis,
const std::string &  label 
)
virtual

Sets the axis binding.

Sets binding of the axis with name axis to entity with name label. It is expected that this member function will only be called on a derived class which can process it in a meaningful way. Thus if this method is called on this base class, an assertion is thrown.

Reimplemented in NTupleProjector.

Definition at line 84 of file ProjectorBase.cxx.

void setAxisBindings ( const std::vector< std::string > &  bindings)
virtual

Sets the axis binding.

Sets binding of all axis entities with name in the vector. This member function should only be called with a derived class which can process it in a meaningful way. Thus if this method is called on this base class, an assertion is thrown.

Reimplemented in NTupleProjector.

Definition at line 92 of file ProjectorBase.cxx.

void setAxisModel ( Axes::Type  axis,
AxisModelBase axis_model 
)
virtual

Sets the AxisModel for axis axis.

Reimplemented in BinningProjector.

Definition at line 192 of file ProjectorBase.cxx.

References ProjectorBase::m_x_axis, ProjectorBase::m_y_axis, ProjectorBase::m_z_axis, hippodraw::Axes::X, hippodraw::Axes::Y, and hippodraw::Axes::Z.

Referenced by DataRep::setAxisModel().

const Range & setBinWidth ( Axes::Type  axis,
double  width 
)
virtual

Sets the bin width.

Sets the bin width to width along the axis axis.

Not all projectors has a notation of a bin width. This interface is declared for those that do. The implementation in this base class is to does nothing.

Reimplemented in MapMatrixProjector, EqualEntriesHist1DProjector, Profile2DProjector, Hist2DProjImp, and BinningProjector.

Definition at line 234 of file ProjectorBase.cxx.

Referenced by CompositePlotter::setBinWidth().

const Range & setBinWidth ( Axes::Type  axis,
int  parm,
bool  dragging 
)
virtual

Sets the bin width.

This method is intended to be used in conjunction with a slider widget in a graphical user interface. The slider range is assumed to be 0 to 100 with the current value at parm. If the slider is still being dragged, then dragging is true, otherwise it is false. A derived class determines withs own bin width based on the width it had when slider dragging first started. and the current position of the slider. The implementation in this base class does nothing.

Reimplemented in EqualEntriesHist1DProjector, Profile2DProjector, DyHist2DProjector, and BinningProjector.

Definition at line 242 of file ProjectorBase.cxx.

References ProjectorBase::getRange(), and ProjectorBase::m_x_axis.

void setDirty ( bool  value = true)
virtual

Sets the dirty flag to value.

Definition at line 75 of file ProjectorBase.cxx.

References ProjectorBase::m_isDirty, and Observable::notifyObservers().

Referenced by StHist1DProjector::addValues(), StHist2DProjector::addValues(), Profile2DProjector::dataRangeOn(), FunctionProjector::fitFunction(), StHist1DProjector::getAverage(), StHist2DProjector::getAverage(), BinningProjector::normalize(), LineProjector::prepareValues(), Map3Projector::prepareValues(), Map2Projector::prepareValues(), MeshProjector::prepareValues(), Map1Projector::prepareValues(), EqualEntriesHist1DProjector::prepareValues(), BinningProjector::prepareValues(), ProjectorBase::prepareValues(), MapMatrixProjector::prepareValues(), StHist1DProjector::reset(), FunctionProjector::restoreParameters(), NTupleProjector::setAxisBinding(), BinningProjector::setBinnerOn(), ProfileProjector::setBinnerRange(), DyHist2DProjector::setBinnerRange(), DyHist1DProjector::setBinnerRange(), StHist1DProjector::setBinnerRange(), StHist2DProjector::setBinnerRange(), Profile2DProjector::setBinnerRange(), BinningProjector::setBinWidth(), Hist2DProjImp::setBinWidth(), Profile2DProjector::setBinWidth(), EqualEntriesHist1DProjector::setBinWidth(), DataRep::setDirty(), BinningProjector::setMinEntries(), MapMatrixProjector::setNTuple(), NTupleProjector::setNTuple(), DyHist2DProjector::setOffset(), BinningProjector::setOffset(), Hist2DProjImp::setOffset(), Profile2DProjector::setOffset(), FunctionProjector::setParameters(), Profile2DProjector::setRange(), FunctionProjector::setRange(), ProjectorBase::setRange(), NTupleProjector::update(), and BinningProjector::willDelete().

void setMinEntries ( int  entries)
virtual

Set the minimum entries/bin.

Reimplemented in BinningProjector.

Definition at line 525 of file ProjectorBase.cxx.

Referenced by CompositePlotter::setMinEntries().

void setNormalizing ( bool  on)
virtual

Sets the scaling number of entries on if on is true, otherwise turns if off.

Reimplemented in BinningProjector.

Definition at line 395 of file ProjectorBase.cxx.

void setNumberOfBins ( Axes::Type  axis,
unsigned int  number 
)
virtual

Sets the number of bins.

Sets the number of bins along the axis axis to number.

Not all projectors has a notation of a bin width. This interface is declared for those that do. The implementation in this base class is to does nothing.

Reimplemented in MapMatrixProjector.

Definition at line 228 of file ProjectorBase.cxx.

Referenced by CompositePlotter::setNumberOfBins().

void setOffset ( const std::string &  axis,
int  parm,
bool  dragging 
)
virtual

Sets the bin offset.

See Also
setBinWidth ( const std::string &, int, bool )

Reimplemented in Profile2DProjector, BinningProjector, and DyHist2DProjector.

Definition at line 248 of file ProjectorBase.cxx.

Referenced by CompositePlotter::setOffset(), and DisplayController::setOffset().

void setOffset ( Axes::Type  axis,
double  offset 
)
virtual

Sets the bin offset.

Sets the offset of bins by fraction offset of the bin width.

Not all projectors has a notation of a bin width. This interface is declared for those that do. The implementation in this base class is to does nothing.

Reimplemented in MapMatrixProjector, Profile2DProjector, Hist2DProjImp, and BinningProjector.

Definition at line 256 of file ProjectorBase.cxx.

void setRange ( Axes::Type  axis,
bool  const_width = true 
)
virtual

Sets the range of the selected axis.

The base class implementation only sets the dirty flag. Derived classes may need to do more. The option bool parameter if true indicates a binning projector should hold the bin width parameter constant.

Reimplemented in FunctionProjector, Profile2DProjector, Hist2DProjImp, Hist1DProjImp, and ProfileProjector.

Definition at line 133 of file ProjectorBase.cxx.

References ProjectorBase::m_z_axis, ProjectorBase::setDirty(), hippodraw::Axes::X, hippodraw::Axes::Y, and hippodraw::Axes::Z.

Referenced by DataRep::setRange().

void update ( const Observable )
virtual

Implements the Observer pattern.

The implementation in this abstract base class does nothing. Derived class may override this method if they are observers.

Implements Observer.

Reimplemented in BinningProjector, NTupleProjector, Profile2DProjector, DyHist1DProjector, DyHist2DProjector, and ProfileProjector.

Definition at line 402 of file ProjectorBase.cxx.

virtual Range valueRange ( ) const
pure virtual

Finds the range of the projected values.

It is up to derived classes to determine what this means.

Todo:
Resolve if this method should be here.

Implemented in MapMatrixProjector, FunctionProjector, MeshProjector, EqualEntriesHist1DProjector, Hist1DProjImp, Hist2DProjImp, Map1Projector, Map2Projector, Profile2DProjector, Map3Projector, LineProjector, and ProfileProjector.

bool wantsScaleFactor ( const std::string &  axis) const
virtual

Returns whether the projector wants scale factor.

Returns true if the projector wants to scale the axis, otherwise returns false. A projector supporting a histogram, for example, would want to scale the Y axis by the bin width in order to show entries per bin instead of density. This base class implementation always returns false.

Reimplemented in Hist2DProjImp, and Hist1DProjImp.

Definition at line 364 of file ProjectorBase.cxx.

Referenced by CompositePlotter::checkAxisScaling().

void willDelete ( const Observable )
virtualinherited

Notifies this Observer object that one of its Observable objects is about to be deleted.

Since most Observable objects are owned by its Observer, it is the Observer that issued the delete. Thus the default implementation here does nothing. Derived classes that observe objects owned by another should implement this method to remove the Observable from the list they are observing.

Reimplemented in ViewBase, FunctionRep, BinningProjector, NTupleProjector, Profile2DProjector, DyHist1DProjector, DyHist2DProjector, TextPlotter, CutPlotter, and ProfileProjector.

Definition at line 25 of file Observer.cxx.

Referenced by DataRep::~DataRep(), DataSource::~DataSource(), NTuple::~NTuple(), PlotterBase::~PlotterBase(), RootNTuple::~RootNTuple(), and RTuple::~RTuple().

Member Data Documentation

bool m_isDirty
private

Marks the object as dirty.

A projection is marked dirty if some change was made that requires re-calculating the projection.

Definition at line 65 of file ProjectorBase.h.

Referenced by ProjectorBase::isDirty(), and ProjectorBase::setDirty().

std::vector< std::string > m_pointreps
protected
DataSource* m_proj_values
protected
const ProjectorBase* m_target
protected

The target projector.

Use of the target depends on derived classes. Target projector are observed, thus some of the implement is define in this base class.

Definition at line 110 of file ProjectorBase.h.

Referenced by BinningProjector::normalize(), BinningProjector::normalizeTo(), BinningProjector::update(), and BinningProjector::willDelete().

AxisModelBase* m_x_axis
protected
AxisModelBase* m_y_axis
protected
AxisModelBase* m_z_axis
protected
std::string m_z_label
protected

Dummy member so that getZLabel can return a reference.

Todo:
Remove when getLabel takes axis argument

Definition at line 101 of file ProjectorBase.h.

Referenced by ProjectorBase::getZLabel().

std::vector< double > m_zval
mutableprotected

Sorted Z values in this projector.

Used to export FITS file.

Definition at line 119 of file ProjectorBase.h.

Referenced by ProjectorBase::getZAfterTransform(), and ProjectorBase::getZValues().


The documentation for this class was generated from the following files:

Generated for HippoDraw Class Library by doxygen