/usr/include/openturns/ProcessSample.hxx is in libopenturns-dev 1.3-3.
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 | // -*- C++ -*-
/**
* @file ProcessSample.hxx
* @brief ProcessSample class
*
* Copyright (C) 2005-2014 Airbus-EDF-Phimeca
*
* This library is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* along with this library. If not, see <http://www.gnu.org/licenses/>.
*
* @author schueller
* @date 2012-02-17 19:35:43 +0100 (Fri, 17 Feb 2012)
*/
#ifndef OPENTURNS_PROCESSSAMPLE_HXX
#define OPENTURNS_PROCESSSAMPLE_HXX
#include "PersistentObject.hxx"
#include "NumericalPoint.hxx"
//#include "TimeGrid.hxx"
#include "Field.hxx"
#include "NumericalSample.hxx"
#include "Collection.hxx"
#include "PersistentCollection.hxx"
BEGIN_NAMESPACE_OPENTURNS
/**
* @class ProcessSample
*
* An interface for time series
*/
class ProcessSample
: public PersistentObject
{
CLASSNAME;
public:
/** Some typedefs to ease reading */
typedef Collection<NumericalSample> NumericalSampleCollection;
typedef PersistentCollection<NumericalSample> NumericalSamplePersistentCollection;
/** Default constructor */
ProcessSample();
/** Constructors */
ProcessSample(const UnsignedLong size,
const Field & field);
ProcessSample(const Mesh & mesh,
const UnsignedLong size,
const UnsignedLong dimension);
/** Partial copy constructor */
void add(const Field & field);
#ifndef SWIG
/** Operators accessors */
void setField (const UnsignedLong i, const Field & field);
Field getField (const UnsignedLong i) const;
NumericalSample & operator[] (const UnsignedLong i);
const NumericalSample & operator[] (const UnsignedLong i) const;
#endif
/** Method __getitem__() for Python */
Field __getitem__ (const UnsignedLong i) const;
/** Method __setitem__() is for Python */
void __setitem__(const UnsignedLong i,
const Field & field);
/** Virtual constructor */
virtual ProcessSample * clone() const;
/** String converter */
String __repr__() const;
String __str__(const String & offset = "") const;
/** Time grid accessors */
RegularGrid getTimeGrid() const;
/** Mesh accessors */
Mesh getMesh() const;
/** Size accessor */
UnsignedLong getSize() const;
/** Dimension accessor */
UnsignedLong getDimension() const;
/** Mean accessor */
Field computeMean() const;
/** Temporal mean accessor */
NumericalSample computeTemporalMean() const;
/** Spatial mean accessor */
NumericalSample computeSpatialMean() const;
/** Method computeQuantilePerComponent() gives the quantile per component of the sample */
Field computeQuantilePerComponent(const NumericalScalar prob) const;
/** Draw a marginal of the timeSerie */
Graph drawMarginal(const UnsignedLong index = 0) const;
/** Method save() stores the object through the StorageManager */
void save(Advocate & adv) const;
/** Method load() reloads the object from the StorageManager */
void load(Advocate & adv);
private:
/** Mesh on which the ProcessSample focuses */
Mesh mesh_;
/** NumericalSample collection of all the fields */
NumericalSamplePersistentCollection data_;
}; /* class ProcessSample */
END_NAMESPACE_OPENTURNS
#endif /* OPENTURNS_PROCESSSAMPLE_HXX */
|