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
|
/****************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd
** All rights reserved.
** For any questions to The Qt Company, please use contact form at http://qt.io
**
** This file is part of the Qt Data Visualization module.
**
** Licensees holding valid commercial license for Qt may use this file in
** accordance with the Qt License Agreement provided with the Software
** or, alternatively, in accordance with the terms contained in a written
** agreement between you and The Qt Company.
**
** If you have questions regarding the use of this file, please use
** contact form at http://qt.io
**
****************************************************************************/
/*
* Galaxy creation code obtained from http://beltoforion.de/galaxy/galaxy_en.html
* Thanks to Ingo Berg, great work.
* Licensed under a Creative Commons Attribution 3.0 License
* http://creativecommons.org/licenses/by/3.0/
*/
#ifndef CUMULATIVEDISTRIBUTOR_H
#define CUMULATIVEDISTRIBUTOR_H
#include <QtCore/qglobal.h>
#include <QtGui/QVector2D>
#include <QtCore/QVector>
class CumulativeDistributor
{
public:
typedef qreal (CumulativeDistributor::*dist_fun_t)(qreal x);
CumulativeDistributor();
virtual ~CumulativeDistributor();
qreal PropFromVal(qreal fVal);
qreal ValFromProp(qreal fVal);
void setupRealistic(qreal I0, qreal k, qreal a, qreal RBulge, qreal min,
qreal max, int nSteps);
qreal valFromProp(qreal fVal);
private:
dist_fun_t m_pDistFun;
qreal m_fMin;
qreal m_fMax;
qreal m_fWidth;
int m_nSteps;
// parameters for realistic star distribution
qreal m_I0;
qreal m_k;
qreal m_a;
qreal m_RBulge;
QVector<qreal> m_vM1;
QVector<qreal> m_vY1;
QVector<qreal> m_vX1;
QVector<qreal> m_vM2;
QVector<qreal> m_vY2;
QVector<qreal> m_vX2;
void buildCDF(int nSteps);
qreal IntensityBulge(qreal R, qreal I0, qreal k);
qreal IntensityDisc(qreal R, qreal I0, qreal a);
qreal Intensity(qreal x);
};
#endif // CUMULATIVEDISTRIBUTOR_H
|