Gromacs  2018.8
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
List of all members | Classes | Public Member Functions
gmx::AnalysisDataWeightedHistogramModule Class Reference

#include <gromacs/analysisdata/modules/histogram.h>

+ Inheritance diagram for gmx::AnalysisDataWeightedHistogramModule:
+ Collaboration diagram for gmx::AnalysisDataWeightedHistogramModule:

Description

Data module for per-frame weighted histograms.

Output data contains the same number of frames and data sets as the input data. Each frame contains the histogram(s) for the points in that frame, interpreted such that the first column passed to pointsAdded() determines the bin and the rest give weights to be added to that bin (input data should have at least two colums, and at least two columns should be added at the same time). Each input data set is processed independently into the corresponding output data set. All input columns for a data set are averaged into the same histogram. The number of columns for all data sets equals the number of bins in the histogram.

The histograms are accumulated in double precision, even if the output data is in single precision.

Classes

class  Impl
 Private implementation class for AnalysisDataWeightedHistogramModule. More...
 

Public Member Functions

 AnalysisDataWeightedHistogramModule ()
 Creates a histogram module with undefined bins. More...
 
 AnalysisDataWeightedHistogramModule (const AnalysisHistogramSettings &settings)
 Creates a histogram module with defined bin parameters. More...
 
void init (const AnalysisHistogramSettings &settings)
 (Re)initializes the histogram from settings. More...
 
AbstractAverageHistogramaverager ()
 Returns the average histogram over all frames. More...
 
const AnalysisHistogramSettingssettings () const
 Returns bin properties for the histogram. More...
 
virtual int frameCount () const
 Returns the total number of frames in the data. More...
 
virtual int flags () const
 Returns properties supported by the module. More...
 
virtual bool parallelDataStarted (AbstractAnalysisData *data, const AnalysisDataParallelOptions &options)
 Called (once) for parallel data when the data has been set up. More...
 
virtual void frameStarted (const AnalysisDataFrameHeader &header)
 Called at the start of each data frame. More...
 
virtual void pointsAdded (const AnalysisDataPointSetRef &points)
 Called one or more times during each data frame. More...
 
virtual void frameFinished (const AnalysisDataFrameHeader &header)
 Called when a data frame is finished. More...
 
virtual void frameFinishedSerial (int frameIndex)
 Called in sequential order for each frame after they are finished. More...
 
virtual void dataFinished ()
 Called (once) when no more data is available. More...
 
- Public Member Functions inherited from gmx::AbstractAnalysisData
bool isMultipoint () const
 Whether the data can have multiple points in the same column in the same frame. More...
 
int dataSetCount () const
 Returns the number of data sets in the data object. More...
 
int columnCount (int dataSet) const
 Returns the number of columns in a data set. More...
 
int columnCount () const
 Returns the number of columns in the data. More...
 
AnalysisDataFrameRef tryGetDataFrame (int index) const
 Access stored data. More...
 
AnalysisDataFrameRef getDataFrame (int index) const
 Access stored data. More...
 
bool requestStorage (int nframes)
 Request storage of frames. More...
 
void addModule (AnalysisDataModulePointer module)
 Adds a module to process the data. More...
 
void addColumnModule (int col, int span, AnalysisDataModulePointer module)
 Adds a module that processes only a subset of the columns. More...
 
void applyModule (IAnalysisDataModule *module)
 Applies a module to process data that is ready. More...
 

Additional Inherited Members

- Public Types inherited from gmx::IAnalysisDataModule
enum  Flag {
  efAllowMultipoint = 1<<0, efOnlyMultipoint = 1<<1, efAllowMulticolumn = 1<<2, efAllowMissing = 1<<3,
  efAllowMultipleDataSets = 1<<4
}
 Possible flags for flags(). More...
 
- Protected Member Functions inherited from gmx::AbstractAnalysisData
 AbstractAnalysisData ()
 Initializes a new analysis data object. More...
 
void setDataSetCount (int dataSetCount)
 Sets the number of data sets. More...
 
void setColumnCount (int dataSet, int columnCount)
 Sets the number of columns for a data set. More...
 
void setMultipoint (bool bMultipoint)
 Sets whether the data has multiple points per column in a frame. More...
 
AnalysisDataModuleManagermoduleManager ()
 Returns the module manager to use for calling notification methods.
 
const AnalysisDataModuleManagermoduleManager () const
 Returns the module manager to use for calling notification methods.
 

Constructor & Destructor Documentation

gmx::AnalysisDataWeightedHistogramModule::AnalysisDataWeightedHistogramModule ( )

Creates a histogram module with undefined bins.

Bin parameters must be defined with init() before data input is started.

gmx::AnalysisDataWeightedHistogramModule::AnalysisDataWeightedHistogramModule ( const AnalysisHistogramSettings settings)
explicit

Creates a histogram module with defined bin parameters.

Member Function Documentation

AbstractAverageHistogram & gmx::AnalysisDataWeightedHistogramModule::averager ( )

Returns the average histogram over all frames.

Can be called already before the histogram is calculated to customize the way the average histogram is calculated.

See Also
AbstractAverageHistogram
void gmx::AnalysisDataWeightedHistogramModule::dataFinished ( )
virtual

Called (once) when no more data is available.

Exceptions
unspecifiedCan throw any exception required by the implementing class to report errors.

Implements gmx::AnalysisDataModuleParallel.

int gmx::AnalysisDataWeightedHistogramModule::flags ( ) const
virtual

Returns properties supported by the module.

The return value of this method should not change after the module has been added to a data (this responsibility can, and in most cases must, be delegated to the user of the module).

The purpose of this method is to remove the need for common checks for data compatibility in the classes that implement the interface. Instead, AbstractAnalysisData performs these checks based on the flags provided.

Does not throw.

Implements gmx::AnalysisDataModuleParallel.

int gmx::AnalysisDataWeightedHistogramModule::frameCount ( ) const
virtual

Returns the total number of frames in the data.

Returns
The total number of frames in the data.

This function returns the number of frames that the object has produced. If requestStorage() has been successfully called, tryGetDataframe() or getDataFrame() can be used to access some or all of these frames.

Does not throw.

Derived classes should implement this to return the number of frames. The frame count should not be incremented before tryGetDataFrameInternal() can return the new frame. The frame count must be incremented before AnalysisDataModuleManager::notifyFrameFinish() is called.

Implements gmx::AbstractAnalysisData.

void gmx::AnalysisDataWeightedHistogramModule::frameFinished ( const AnalysisDataFrameHeader header)
virtual

Called when a data frame is finished.

Parameters
[in]headerHeader information for the frame that is ending.
Exceptions
unspecifiedCan throw any exception required by the implementing class to report errors.

Implements gmx::AnalysisDataModuleParallel.

void gmx::AnalysisDataWeightedHistogramModule::frameFinishedSerial ( int  frameIndex)
virtual

Called in sequential order for each frame after they are finished.

Parameters
[in]frameIndexIndex of the next finished frame.
Exceptions
unspecifiedCan throw any exception required by the implementing class to report errors.

This method is called after frameFinished(), but with an additional constraint that it is always called in serial and with an increasing frameIndex. Parallel data modules need this to serialize their data for downsteam serial modules; AnalysisDataModuleSerial provides an empty implementation, as there frameFinished() can be used for the same purpose.

Implements gmx::AnalysisDataModuleParallel.

void gmx::AnalysisDataWeightedHistogramModule::frameStarted ( const AnalysisDataFrameHeader frame)
virtual

Called at the start of each data frame.

Parameters
[in]frameHeader information for the frame that is starting.
Exceptions
unspecifiedCan throw any exception required by the implementing class to report errors.

Implements gmx::AnalysisDataModuleParallel.

void gmx::AnalysisDataWeightedHistogramModule::init ( const AnalysisHistogramSettings settings)

(Re)initializes the histogram from settings.

bool gmx::AnalysisDataWeightedHistogramModule::parallelDataStarted ( AbstractAnalysisData data,
const AnalysisDataParallelOptions options 
)
virtual

Called (once) for parallel data when the data has been set up.

Parameters
[in]dataData object to which the module is added.
[in]optionsParallelization properties of the input data.
Returns
true if the module can process the input in non-sequential order.
Exceptions
APIErrorif the provided data is not compatible.
unspecifiedCan throw any exception required by the implementing class to report errors.

This method is called instead of dataStarted() if the input data has the capability to present data in non-sequential order. If the method returns true, then the module accepts this and frame notification methods may be called in that non-sequential order. If the method returns false, then the frame notification methods are called in sequential order, as if dataStarted() had been called.

See dataStarted() for general information on initializing the data. That applies to this method as well, with the exception that calling AbstractAnalysisData::requestStorage() is currently not very well supported (or rather, accessing the requested storage doesn't work).

Implements gmx::AnalysisDataModuleParallel.

void gmx::AnalysisDataWeightedHistogramModule::pointsAdded ( const AnalysisDataPointSetRef points)
virtual

Called one or more times during each data frame.

Parameters
[in]pointsSet of points added (also provides access to frame-level data).
Exceptions
APIErrorif the provided data is not compatible.
unspecifiedCan throw any exception required by the implementing class to report errors.

Can be called once or multiple times for a frame. For all data objects currently implemented in the library (and all objects that will use AnalysisDataStorage for internal implementation), it is called exactly once for each frame if the data is not multipoint, but currently this restriction is not enforced.

Implements gmx::AnalysisDataModuleParallel.

const AnalysisHistogramSettings & gmx::AnalysisDataWeightedHistogramModule::settings ( ) const

Returns bin properties for the histogram.


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