-
Notifications
You must be signed in to change notification settings - Fork 0
/
MaxLikeListDrivePhotV2.tex.txt
196 lines (165 loc) · 12.3 KB
/
MaxLikeListDrivePhotV2.tex.txt
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
183
184
185
186
187
188
189
190
191
192
193
194
195
196
From: Martin Kunz <m.kunz@sussex.ac.uk>
Date: 28 March 2009 15:15:26 GMT
To: Seb Oliver <S.Oliver@sussex.ac.uk>
Cc: Anthony Smith <A.J.Smith@Sussex.ac.uk>, Robin Smith <ras35@sussex.ac.uk>, Isaac Roseboom <I.G.Roseboom@sussex.ac.uk>, Lingyu Wang <lingyu.wang@imperial.ac.uk>
Subject: Re: Simultaneous linear photometry method
Dear All,
I extended the notes a bit, making the maximum likelihood solution a bit more explicit and writing some (abstract) stuff about the Bayesian approach.
Maybe all interested parties could meet for a chat after Easter to discuss some more explicit aspects of the Bayesian formalism, e.g. concerning priors on the fluxes?
Cheers,
Martin
% document history
% Seb 18/03/09: original notes
% Tony 18/03/09: fixed some latex problems (v1)
% Martin 28/03/09: added some Bayesian formalism (v2)
\documentclass{article}
\begin{document}
\section{Notes about point-source fitting and noise}
\subsection{Definitions and units}
A point source of flux density $f$ (SI units $Wm^{-2}Hz^{-1}$) gives an intensity $I$ (SI units $Wm^{-2}Hz^{-1}sr^{-1}$) at a position ${\bf r}$ relative to the centre of the source in the focal plane of the telescope $I$, where
\begin{equation} I({\bf r})=P({\bf r})f \label{eqn:intensity}\end{equation} and the Point Spread Function $P$ is an inverse solid angle (SI units of $sr^{-1}$ and is normalised so
\begin{equation}\int_\infty P\, d\Omega=1.\label{eqn:intennorm}\end{equation}
When recorded by a detector we receive a signal $s=\int_{\rm pix}{I}\,d\Omega$ (units of flux density). Usually the detectors have a small solid angle $\Delta\Omega$ so $s\approx I\Delta\Omega$ and in any case the function $P$ and calibration can usually defined in such a way that that is exact. Data is often represented either as an intensity or as a flux per pixel
\begin{equation}
I({\bf r})=\frac{s}{\Delta{\Omega}}=P({\bf r})f.
\end{equation}
A common approach for estimating fluxes is aperture photometry in which one sums up the flux per pixel and we can see
\begin{equation}
\sum{s}=f\sum{P({\bf r})\Delta{\Omega}}.
\end{equation}
So if the sum is taken over all pixels this tends to the true flux. It is often convenient to use an alternative normalisation of PSF:
$P^\prime=P({\bf r})\Delta{\Omega}$, where $P^\prime$ (with units of per pixel) has
\begin{equation}\sum P^\prime=1\label{eqn:fluxnorm}\end{equation} in which case
\begin{equation}s({\bf r})=P^\prime({\bf r}) f\label{eqn:pix}\end{equation}
which has the same form as Equation \ref{eqn:intensity}
\subsection{Optimal Weighting}
We will consider our data ${\bf d}$ is a measurement of the signal (which might be the intensity $I$ or the flux per pixel $s$) subject to an error $\sigma$. Any element of $d_i$ can be used to estimate the flux $f^\prime=d_i/P_i$ (where $P_i$ should normalised as appropriate for flux-per-pixel, Eqn. \ref{eqn:fluxnorm}, or intensity normalisation, Eqn. \ref{eqn:intennorm}). The error in that estimate $\sigma_f=\sigma_i/P_i$
A simple method for combining data to estimate the flux of a single source would be to construct a weighted sum of these estimates
\begin{equation}
\hat{f}=\frac{\sum_i w_i\, d_i/P_i}{\sum_i w_i}.
\end{equation}
For un-correlated errors the error the maximum likelihood estimator for $f$ is when the weights are set to the inverse of the variance i.e. $w_i=P_i^2/\sigma_i^2$. Then this estimator is
\begin{equation}
\hat{f}=\frac{\sum_i P_i\, d_i/\sigma_i^2}{\sum_i P_i^2/\sigma_i^2}
\end{equation}
with variance
\begin{equation}
\sigma^2_{\hat{f}}=\frac{1}{\sum_i w_i^2}=\left(\sum_i{\frac{P_i^2}{\sigma_i^2}}\right)^{-1}
\end{equation}
If the variances per detector element are constant
\begin{equation}
\hat{f}=\frac{\sum_i P_i\, d_i}{\sum_i P_i^2}
\end{equation}
and
\begin{equation}
\sigma^2_{\hat{f}}=\frac{{\sigma_i^2}}{\sum_i P_i^2}.
\end{equation}
This explains the basis of many source extraction methods where and image is filtered by the point spread function and shows that the required scaling between such a convolved map and point source flux and the noise per detector and the resulting variance in the flux is ${{1}}/{\sum_i P_i^2}$, if the point-spread function has been properly normalised.
When I have some spare time I might play around and see what this normalisation factor is for certain PSF geometries and pixel scales.
\section{Basic Linear Method}
Our data ${\bf d}$ is a vector of $M$ elements from $M$ (good) detector readouts. For example ${\bf d}$ might come from an $n_1\times n_2$ image i.e. with $n_1\times n_2=M$ pixels. The detectors are located at positions $({\bf x,y})$. Our model assumes this data to be formed by a number $N$ of point sources with known positions, ${\bf (u,v)}$, and with unknown flux, $f_i$, all the fluxes are thus a $N$ element vector ${\bf f(u,v)}$. Each source $i$ makes a contribution to the data given by the response function $P({\bf x}-u_i, {\bf y}-v_i)$ and the data is given by
\begin{equation}
d_j=\sum_i{P(x_j-u_i, y_j-v_i)}f_i+n_j \label{eqn:lin1}
\end{equation}
where $\delta_j$ is an additional noise contribution
i.e.
\begin{equation}
{\bf d}=P({\bf \Delta X},{\bf \Delta Y}){\bf f}+{\bf n}
\label{eqn:linprf}\end{equation}
where ${\bf {\Delta X}}$ and ${\bf \Delta Y}$ are $(M\times N)$ matrices giving the offset between detectors and sources. This is a linear equation of the form
\begin{equation}
{\bf d}={\bf A}{\bf f}+{\bf n}\label{eqn:matrix}
\end{equation}
and thus the maximum likelihood solution is
\begin{equation}
{\bf \hat{f}}=({\bf A}^T{\bf N}^{-1}{\bf A})^{-1}\, {\bf A}^T{\bf N}^{-1}{\bf
d}
\end{equation}
Where ${\bf N}$ is the covariance matrix. This matrix equation can be solved
efficiently by a Conjugate Gradient method.
Let us write the above more explicitely, by defining the theoretical
value $\hat{\bf d}$ for the data given the flux ${\bf f}$ and the model
as $\hat{\bf d} = A {\bf f}$. The covariance matrix is then
\[
\langle ({\bf d}-\hat{\bf d}) ({\bf d}-\hat{\bf d}^T)\rangle
= \langle {\bf n} {\bf n}^T \rangle
= {\bf N}
\]
as expected. To derive the maximum likelihood solution, we write down the
likelihood as the Gaussian probability function for the data given the fluxes,
\[
L(f) = p(d|f) \propto |{\bf N}|^{-1/2}
\exp\left\{-\frac{1}{2}({\bf d}-\hat{\bf d})^T {\bf N}^{-1} ({\bf d}-\hat{\bf d}) \right\}
\]
Defining $\chi^2=({\bf d}-\hat{\bf d})^T {\bf N}^{-1} ({\bf d}-\hat{\bf d})$ we
see at the maximum of the likelihood we require
\[
\frac{\partial \chi^2}{\partial f} = 0 .
\]
Written explicitely in terms of components (with summation over repeated indices
implied), this becomes
\[
\frac{\partial}{\partial f_m} \left[ (d_i-A_{ij} f_j) (N^{-1})_{ik} (d_k-A_{kl} f_l) \right]
= -2 A_{im} (N^{-1})_{ik}(d_k-A_{kl} f_l) = 0
\]
The solution of this equation is the one given above.
\section{Advances}
\subsection{Background or other source terms}
We can add in other additive model contributions to the signal in an obvious way, by including extra terms in equation \ref{eqn:linprf} and calculating the matrix ${\bf A}$ accordingly with the vector ${\bf f}$ then representing all the model parameters, not just the point source fluxes. E.g. a constant background would be a single extra element in the sources `fluxes' vector ${\bf f}$ with a corresponding row of $(1,1,1,...,1)$ in the transfer matrix ${\bf A}$. More complicated model backgrounds with more parameters can be included by adding extra terms to ${\bf f}$ and ${\bf A}$.
\subsection{Solving for unknown PRF}
If the PRF, $P$ function is unknown.
I can see how to do this iteratively with the same linear methods. i.e. a) assume PRF, b) fit fluxes c) fix flux d) fit PRF e) fix PRF f) fit fluxes etc. Ideally they could be done simultaneously but I think that is non-linear.
If we consider the PRF to be a tabulated, pixelated, function ${\bf P}({\bf \Delta x}, {\bf \Delta y})$ (e.g. a PRF map) with components $P_k( \Delta x, \Delta y_k)$. We rewrite Equation \ref{eqn:lin1} as
\begin{equation}
d_j=\sum_k{f^\prime(x_j-\Delta x_k, y_j-\Delta y_k)}P_k+n_j \label{eqn:lin2}
\end{equation}
Where $f^\prime(u,v)$ is the sum of the fluxes of sources at the ``pixel" with coordinates $(u,v)$. So we get
\begin{equation}
{\bf d}={\bf f}^\prime({\bf u},{\bf v}){\bf P}+{\bf n}\label{eqn:linprf2}
\end{equation}
this is the same form as equation \ref{eqn:matrix} but with the PRF function ${\bf P}$ replacing the source fluxes $f$ and ${\bf A_{jk}}$ now representing the fluxes of all sources at the position that contributes to the detector $j$ according to the PRF defined at $P_k$. This can be solved using the same linear methods.
\subsection{Using prior information on source flux}
This could be very powerful (may even remove some of these biases). It would really seriously advance the field. One way of doing this might be to multiply the posterior flux distribution functions by the prior. However, this is unsatisfactory in a number of ways, e.g. it doesn't take into account the simultaneous fitting of all the point sources and it doesn't provide any consistency with the observed data.
A better method is to treat the prior knowledge of the flux as additional (but uncorrelated) data. So we add additional terms to the data vector ${\bf d}$, the transfer matrix ${\bf A}$ and (diagonal) terms to the covariance matrix ${\bf N}$. E.g. if we had prior flux information on the third source $i=3$ estimating its flux to be $s$ with $\sigma^2_s$ we would add $s$ to the end of data vector ${\bf d}$ and an extra $N$ element row $(0,0,1,0,0,...,0)$ to the matrix ${\bf A}$, so it is now $(M+1 \times N)$ and we would add an extra row and column to the covariance matrix ${\bf M}$ containing just $\sigma^2$ on the diagonal point.
\subsection{Fitting the noise}
Martin mentioned this before Xmas. May be hard. Probably the impact and wow factor of this would be less than 1) so probably lower priority
\subsection{Bayesian formalism}
In the Baysian formalism, we are interested in the posterior for the fluxes, which
is the probability of the fluxes given the data, $p(f|d)$. Using Bayes theorem, we
can rewrite this as (I am sorry, I am too lazy to put all the boldface commands in --
everything in this paragraph is boldface)
\[
p(f|d) = p(d|f) \frac{p(f)}{p(d)} \propto L(f) \pi(f)
\]
where we renamed the likelihood $p(d|f) \equiv L(f)$ and the prior $p(f)\equiv \pi(f)$
for easier identification. Additionally we dropped the constant factor $p(d)$ which is
relevant only if things depend on further quantities (like e.g. the noise model) but not
when estimating $f$ for everything else fixed.
The prior is now an integral part of the final equation, and we can try to find the
maximum of the posterior above by deriving it with respect to $f$. If the prior is
independent of $f$ we recover the maximum likelihood solution as above. However, in
general the maximum of the posterior will be elsewhere, and also in general the
solution will be harder to find (depending on the prior). Also, for a Baysian the
{\em maximum} of the posterior is not really relevant, instead (s)he prefers to
derive confidence limits.
In principle we can always solve for $f$ with a Monte Carlo method which basically
just tries all possible $f$ (preferably in a somewhat clever way) and so maps
the posterior. Confidence limits can then be inferred by integrating out the variables
that we are not interested in. However, in my (MK) limited experience, MC methods
have be sophisticated {\em and} fast to get anywhere in such high-dimensional spaces
as those here (in other words, I haven't yet found a good one). Remember, the dimensionality
of the space here is the number of dimensions of $f$, i.e. the number of fluxes,
and that's for the simplest case. But it's an interesting and generally important problem.
In general we are being simplistic if we write $p(f|d)$, since we also assumed known
matrices $A$ and $N$, and should really have written $p(f|d,A,N)$, and the above
changes to
\[
p(f|d,A,N) = p(d|f,A,N) \frac{p(f|A,N)}{p(d|A,N)} .
\]
Thus, if the noise is unknown, we have to move $N$ to the left hand side, and if
the PRF is unknown, we have to move $A$ to the lhs. Then we can try to estimate
everything on the lhs simultaneously, by applying Bayes theorem again, and expressing
things in terms of the likelihood $p(d|f,A,N)$ times diverse priors.
The last paragraph is very abstract, but I did not want to go into more details
without knowing which cases are interesting, and how to model them.
\end{document}