File: ParameterTreeBuilder.h

package info (click to toggle)
bornagain 23.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 103,936 kB
  • sloc: cpp: 423,131; python: 40,997; javascript: 11,167; awk: 630; sh: 318; ruby: 173; xml: 130; makefile: 51; ansic: 24
file content (85 lines) | stat: -rw-r--r-- 3,351 bytes parent folder | download | duplicates (2)
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
//  ************************************************************************************************
//
//  BornAgain: simulate and fit reflection and scattering
//
//! @file      GUI/Model/Job/ParameterTreeBuilder.h
//! @brief     Defines class ParameterTreeBuilder.
//!
//! @homepage  http://www.bornagainproject.org
//! @license   GNU General Public License v3 or higher (see COPYING)
//! @copyright Forschungszentrum Jülich GmbH 2018
//! @authors   Scientific Computing Group at MLZ (see CITATION, AUTHORS)
//
//  ************************************************************************************************

#ifndef BORNAGAIN_GUI_MODEL_JOB_PARAMETERTREEBUILDER_H
#define BORNAGAIN_GUI_MODEL_JOB_PARAMETERTREEBUILDER_H

#include <QString>

class BackgroundItem;
class BeamDistributionItem;
class DetectorItem;
class DoubleProperty;
class FootprintItem;
class InstrumentItem;
class Interference2DAbstractLatticeItem;
class ItemWithParticles;
class JobItem;
class OffspecDetectorItem;
class ParameterContainerItem;
class ParameterItem;
class ParameterLabelItem;
class ParticleLayoutItem;
class ScanItem;
class VectorProperty;

//! The ParameterTreeBuilder contains helper functions to create container
//! with ParameterItems. The ParameterItem appears in RealTimeView and provides real
//! time tuning of SampleItem and InstrumentItem.

class ParameterTreeBuilder {
public:
    ParameterTreeBuilder(JobItem* jobItem);

    void build();

private:
    //! add the job's materials
    void addMaterials();

    //! add the job's sample
    void addSample();
    void addInstrument();
    void addParameterItem(ParameterLabelItem* parent, DoubleProperty& d, const QString& label = "");
    void addParameterItem(ParameterLabelItem* parent, VectorProperty& d);
    void addMagnetizationNoZ(ParameterLabelItem* parent, VectorProperty& d);
    ParameterContainerItem* parameterContainerItem();
    bool allowMagneticFields() const;

    void addInterference(ParameterLabelItem* layoutLabel, const ParticleLayoutItem* layout);

    //! Returns the top label which was created for the particle
    ParameterLabelItem* addItemWithParticles(ParameterLabelItem* parentLabel, ItemWithParticles* p,
                                             bool enableAbundance);
    void addLattice(ParameterLabelItem* parentLabel, const Interference2DAbstractLatticeItem* itf);
    void addRotation(ParameterLabelItem* parentLabel, ItemWithParticles* p);

    void addBeamDistribution(ParameterLabelItem* parentLabel,
                             BeamDistributionItem* distributionItem, const QString& label,
                             bool withMean = true);

    void addScanDistributions(ParameterLabelItem* parent, ScanItem* scanItem);

    void addDetector(ParameterLabelItem* parentLabel, DetectorItem* detector);
    void addOffspecDetector(ParameterLabelItem* parentLabel, OffspecDetectorItem* detector);
    void addBackground(ParameterLabelItem* instrumentLabel, BackgroundItem* backgroundItem);
    void addFootprint(ParameterLabelItem* instrumentLabel, FootprintItem* footprintItem);
    void addScanFootprint(ParameterLabelItem* instrumentLabel, ScanItem* scanItem);
    void addPolarization(ParameterLabelItem* instrumentLabel, InstrumentItem* instrument);

private:
    JobItem* m_job_item;
};

#endif // BORNAGAIN_GUI_MODEL_JOB_PARAMETERTREEBUILDER_H