BornAgain  1.19.0
Simulate and fit neutron and x-ray scattering at grazing incidence
DataItem.h
Go to the documentation of this file.
1 // ************************************************************************************************
2 //
3 // BornAgain: simulate and fit reflection and scattering
4 //
5 //! @file GUI/coregui/Models/DataItem.h
6 //! @brief Declares class DataItem
7 //!
8 //! @homepage http://www.bornagainproject.org
9 //! @license GNU General Public License v3 or higher (see COPYING)
10 //! @copyright Forschungszentrum Jülich GmbH 2018
11 //! @authors Scientific Computing Group at MLZ (see CITATION, AUTHORS)
12 //
13 // ************************************************************************************************
14 
15 #ifndef BORNAGAIN_GUI_COREGUI_MODELS_DATAITEM_H
16 #define BORNAGAIN_GUI_COREGUI_MODELS_DATAITEM_H
17 
18 #include "Device/Data/OutputData.h"
21 #include <QDateTime>
22 #include <mutex>
23 
24 class ImportDataInfo;
25 class InstrumentItem;
26 
27 //! Provides common functionality for IntensityDataItem and SpecularDataItem
28 
29 class BA_CORE_API_ DataItem : public SessionItem, public SaveLoadInterface {
30 private:
31  static const QString P_FILE_NAME;
32 
33 public:
34  static const QString P_AXES_UNITS;
35 
36  OutputData<double>* getOutputData() { return m_data.get(); }
37  const OutputData<double>* getOutputData() const { return m_data.get(); }
38 
39  //! The given pointer becomes owned by this class!!
40  virtual void setOutputData(OutputData<double>* data) = 0;
41 
42  //! Sets the raw data vector from external source
43  //! Checks only the equality of data size,
44  //! no dimension checks are applied.
45  void setRawDataVector(std::vector<double> data);
46 
48  QString fileName() const override;
49  void setFileName(const QString& filename);
50  QDateTime lastModified() const override;
51  bool containsNonXMLData() const override;
52  bool load(const QString& projectDir) override;
53  bool save(const QString& projectDir) override;
54 
55  void setLastModified(const QDateTime& dtime);
56 
57  QString selectedAxesUnits() const;
58 
59  virtual void setXaxisTitle(const QString& title) = 0;
60  virtual void setYaxisTitle(const QString& title) = 0;
61  virtual void setAxesRangeToData() = 0;
62  virtual void updateAxesUnits(const InstrumentItem* instrument) = 0;
63  virtual std::vector<int> shape() const = 0;
64 
65  //! Resets data to the state defined by user (imported)
66  //! data.
67  virtual void reset(ImportDataInfo data) = 0;
68 
69 protected:
70  DataItem(const QString& modelType);
71 
72  std::unique_ptr<OutputData<double>> m_data; //!< simulation results
73  QDateTime m_last_modified;
74  std::mutex m_update_data_mutex;
75 };
76 
77 #endif // BORNAGAIN_GUI_COREGUI_MODELS_DATAITEM_H
Defines and implements templated class OutputData.
Defines save/load interface.
Defines class SessionItem.
Provides common functionality for IntensityDataItem and SpecularDataItem.
Definition: DataItem.h:29
virtual void setAxesRangeToData()=0
OutputData< double > * getOutputData()
Definition: DataItem.h:36
virtual void updateAxesUnits(const InstrumentItem *instrument)=0
static const QString P_FILE_NAME
Definition: DataItem.h:31
QDateTime m_last_modified
Definition: DataItem.h:73
virtual void setXaxisTitle(const QString &title)=0
virtual std::vector< int > shape() const =0
std::mutex m_update_data_mutex
Definition: DataItem.h:74
virtual void setYaxisTitle(const QString &title)=0
static const QString P_AXES_UNITS
Definition: DataItem.h:34
std::unique_ptr< OutputData< double > > m_data
simulation results
Definition: DataItem.h:72
virtual void reset(ImportDataInfo data)=0
Resets data to the state defined by user (imported) data.
const OutputData< double > * getOutputData() const
Definition: DataItem.h:37
Carries information about loaded data.
Purely virtual interface to handle non-XML data save and load.
virtual QString fileName() const =0
Reports file name to save/load non-XML data.
virtual bool load(const QString &projectDir)=0
Loads non-XML data from projectDir and returns success flag.
virtual bool containsNonXMLData() const =0
Checks if object owns non-XML data.
virtual QDateTime lastModified() const =0
Indicates last modification timepoint.
virtual bool save(const QString &projectDir)=0
Saves non-XML data in projectDir and returns success flag.
std::string filename(const std::string &path)
Returns path without directory part ("Foo/Bar/Doz.int.gz" -> "Doz.int.gz")
QString projectDir(const QString &projectFileName)
Returns project directory deduced from project file name.