forked from christophersanborn/Radiative3D
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sources.hpp
182 lines (148 loc) · 6.6 KB
/
sources.hpp
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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
// sources.hpp
//
// This file defines a base class for a whole hierarchy of classes to
// represent seismic sources. The basic "family" of these sources will
// divide principally over those sources that are "events" in the
// sense of an earthquake or explosion event, and those that are
// "scatterers" in the sense of treating a scattering event as a
// source of re-radiated phonons.
//
// The principle deriviative files to this file are: events.hpp, and
// scatterers.hpp.
//
// Generally, a code module that needs "sources" will not include this
// file directly, but will include either (or both) of events.hpp or
// scatterers.hpp. Those files, in turn, include this file.
//
//
#ifndef SOURCES_H_
#define SOURCES_H_
//
#include <iostream> // TODO: drop after prototyping ends
#include <vector>
#include "geom.hpp"
#include "raytype.hpp"
#include "probability.hpp"
//////
// CLASSES: Forward Declarations
//
// FROM OTHER HEADERS: (Referenced here by pointer only -
// no need to include full header.)
class Phonon; /* Defined in phonon.hpp */
//////
// TYPEDEFS:
//
//////
// CLASSES: Definitions
//
// CLASS: Sources::PhononSource
// ENCAPS:
// A very generic base class of a Phonon Source. Doesn't even
// include the probability function. (because at this point the
// dimensionality of the funciton isn't known. Could be
// single-type, or P-S, or scattering PP, SS, PS, SP, etc.)
// FEATURES:
// * Static member to maintain take-off angle list.
//
class PhononSource {
protected:
// :::::::::::::::::::::::::::::::::::::::::::::::
// ::: Internal Typedefs (PhononSource Class) :::
// :::::::::::::::::::::::::::::::::::::::::::::::
/*
// DEPRECATED - REMOVE
typedef Real Probability;
typedef std::vector<Probability> ProbabilityArray;
typedef std::vector<ProbabilityArray> ProbabilityMatrix;
*/
protected:
// ::::::::::::::::::::::::::::::::::::::::::::
// ::: Static Members (PhononSource Class) :::
// ::::::::::::::::::::::::::::::::::::::::::::
static int nTOA;
static S2::S2Set * pTOA; // Pointer to class-level take-off-angle
// array. Defines set of take-off angles
// to be used by all PhononSource
// objects. Needs to be initialized by
// Set_TOA_Array() at some point prior to
// construction of first object.
public:
// ::::::::::::::::::::::::::::::::::::::::::::
// ::: Static Methods (PhononSource Class) :::
// ::::::::::::::::::::::::::::::::::::::::::::
static void Set_TOA_Array(S2::S2Set * toa) {
pTOA = toa;
nTOA = pTOA->size();
}
protected:
// :::::::::::::::::::::::::::::::::::::::::
// ::: Member Data (PhononSource Class) :::
// :::::::::::::::::::::::::::::::::::::::::
// PROBABILITIES:
//
// A Probability Distribution (ProbDist object) is an array of
// values corresponding to the directions in the TOA array that
// encode the probability of a phonon taking flight at that
// particular Take-Off Angle. The PhononSource class maintans a set
// (vector) of these distributions, corresponding to a plurality of
// possible output conditions. (E.g., an event-source generated
// phonon might begin life as either a P or as an S phonon, and the
// distributions would be different for each case.)
//
// In addition to the set of probability distributions, an
// additional set of probability arrays is maintained, called "Whole
// Probabilities" (they are still "distributions," but I use the
// terminology "arrays" here because they are defined over a set of
// conditions rather than over the range of ToA's). The "whole"
// probabilities define the probability of a phonon assuming each of
// the states described by the separate Probability Distributions.
// (E.g., for an event source, the WholeProbs arrays contain
// elements for the "whole" probabilities of generating a P phonon
// vs. an S phonon, etc.) The WholeProbs array is vectorised (ie,
// we maintain a set of WholeProbs arrays, not just a single array)
// because the probabilities of generation in each condition might
// be dependent on some input state. (This is not the case for
// event-source generation, so the vector is length one, but for
// scattering sources, the available output condtions depends on
// input condition. Ie, a phonon arriving as a P phonon has a
// different set of output possibilities compared with one arriving
// as an S phonon.)
std::vector<ProbDist> mPDists; // The Distributions. These
// encode the "shape," if you
// will, of the radiation/spray
// patterns.
std::vector<ProbDist> mWholeProbs; // The Whole Probs
// Array(s). These encode the
// relative probabilities of
// each "shape" defined in the
// mPDists distributions.
// The process of "spraying" a phonon is then a two-step process
// where we first randomly choose which "shape," or mPDist
// Distribution, to use. This first choice is made based on the
// relative probabilities contained in the mWholeProbs arrays. And
// then the next step is to randomly choose a Take-Off Angle, based
// on the probabilities encoded in the chosen mPDist distribution.
// This will give us both an output state (are we P? are we S?) and
// an output direction, and thus a Phonon can be generated and
// returned with those properties set.
public:
// ::::::::::::::::::::::::::::::::::::::::::
// ::: Constructors (PhononSource Class) :::
// ::::::::::::::::::::::::::::::::::::::::::
PhononSource(int nraytypes_in, int nraytypes_out);
// :::::::::::::::::::::::::::::::::::::::::::::::::
// ::: Produce-Something Methods (PhononSource) :::
// :::::::::::::::::::::::::::::::::::::::::::::::::
Phonon GenerateRandomPhonon(raytype inray);
// ::::::::::::::::::::::::::::::::::::::::::::
// ::: Output Methods (PhononSource Class) :::
// ::::::::::::::::::::::::::::::::::::::::::::
void output_wholespace_prob_matrix();
void output_differential_probabilities(raytype inray, raytype outray,
const char* symbol = "c",
Real scalefactor = 0.2);
void output_random_rayset(int nrays, raytype inray = RAY_NA);
};
///
#endif //#ifndef SOURCES_H_
//