A notebook of useful things

Category: Statistics

The APC cluster (3): Montepython with Euclid likelihoods

The latest public release of Montepython includes Euclid likelihoods for the redshift survey (euclid_pk) and the cosmic shear survey (euclid_lensing).

The __init__.py  file needs to be edited because of Python syntax issues. If you try to use it as provided, you will get two errors messages.

File "/home/[APClogin]/montepython/montepython/likelihoods/euclid_pk/__init__.py", line 224, in loglkl
k_sigma = np.zeros(2.*self.nbin+1, 'float64')
TypeError: 'float' object cannot be interpreted as an index

The problem here is the decimal point after the 2, which makes it a float, when it is being used to create an index, which must be an integer.

Correction:
k_sigma = np.zeros(2*self.nbin+1, 'float64')

The second error is caused once again by an unnecessary decimal point in the index:
File "/home/[APClogin]/montepython/montepython/likelihoods/euclid_pk/__init__.py", line 330, in integrand
return self.k_fid[:]**2/(2.*pi)**2*((self.tilde_P_th[:,index_z,index_mu] - self.tilde_P_fid[:,index_z,index_mu])**2/((2./self.V_survey[index_z])*(self.tilde_P_th[:,index_z,index_mu] + self.P_shot[index_z])**2 + (self.alpha[:,2.*index_z+1,index_mu]*self.tilde_P_th[:,index_z,index_mu])**2
*self.k_fid[:]**3/2./pi**2
*self.nbin*log(self.kmax/self.kmin)))
IndexError: only integers, slices (`:`), ellipsis (`...`), numpy.newaxis (`None`) and integer or boolean arrays are valid indice

Correction:
return self.k_fid[:]**2/(2.*pi)**2*((self.tilde_P_th[:,index_z,index_mu] - self.tilde_P_fid[:,index_z,index_mu])**2/((2/self.V_survey[index_z])*
(self.tilde_P_th[:,index_z,index_mu] + self.P_shot[index_z])**2 + (self.alpha[:,2*index_z+1,index_mu]*self.tilde_P_th[:,index_z,index_mu])**2
*self.k_fid[:]**3/2./pi**2*
self.nbin*log(self.kmax/self.kmin)))

The Champernowne and Copeland-Erdős constants in Python

Python is a great tool. One of the best things about it, as anyone who’s used it will tell you, is the vast collection of useful libraries.

The mathematics libraries include a bewildering array of functions, but they were missing two important ones: the Champernowne constant, and the  Copeland-Erdős constant. So I did my bit for the community and wrote two modules to output these numbers to any desired digit.

David Gawen Champernowne (1912-2000)

Paul Erdős (1913-1996)

Arthur Herbert Copeland (1898-1970)

The modules are included in a package called idmaths, which is available on Github.

Here’s some sample code.



Loading

Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

Forecasting an election result

In the run-up to the French presidential election in mid-2017, G. Elliott Morris at The Crosstab published some interesting forecasts using simulated Dirichlet draws. The post in question is no longer online. It was previously available on http://www.thecrosstab.com/2017/02/14/france-2017-methodology .

The method itself is fairly well-known (see e.g. Rigdon et al. 2009, A Bayesian Prediction Model for the U.S. Presidential Election ).

I thought it would be interesting to apply the technique when the poll samples and voter base are both tiny. So I did it for Malta, which held a snap election in June 2017. The main problem here is the inconsistency of the polls. For the last few data points, I used a series of voluntary online surveys carried out by a Facebook group calling themselves MaltaSurvey. In hindsight, the survey results appear to have been biased, but at the time there was no way of knowing how to model this bias.

So, without further ado, here is the link to the code on Github.

 

 

 

Probably not Thomas Bayes

Anyone who has Googled “Thomas Bayes” or searched Wikipedia will have come across this picture.

Thomas_Bayes

Most sites helpfully note that this is not an authentic portrait. The costume is anachronistic, and the illustration first appears about two hundred years after Bayes’s death. In fact there is no known portrait of probably the greatest name in probability and statistical theory.

We know very little about Thomas Bayes.

We do know that he was the son of Joshua and Ann Bayes, and was born in London or possibly Herfordshire, most likely in 1701. In 1719, he began to study logic and theology at the University of Edinburgh. When Bayes graduated, his father was the minister of the Presbyterian meeting house in Leather Lane. By 1731, Bayes moved to Tunbridge Wells, Kent, and became the Presbyterian minister of the Mount Sion chapel.

While there, Bayes published his first known work in 1731.  This is a theological rather than a mathematical text, with the rather self-explanatory title of Divine Benevolence or an Attempt to Prove That the Principal End of the Divine Providence and Government is the Happiness of His Creatures. 

His second work was published anonymously in 1736. It was called An Introduction to the Doctrine of Fluxions, and a Defence of the Mathematicians Against the Objections of the Author of the Analyst.

It is an interesting work which gives a glimpse of academic debate in 18th century England. In it, Bayes contradicts the criticisms of Bishop George Berkeley (author of The Analyst), who attacked the logical foundation of Isaac Newton’s calculus (“fluxions”). It contained enough mathematics in the introduction for Bayes to be elected Fellow of the Royal Society in 1742.

In 1752, Bayes retired from his ministry, but remained in Tunbridge Wells for the rest of his life.

Now begins the most interesting chapter of Bayes’s life as a scientist. He became interested in probability. It was a race against death.

Bayes became ill and executed his will on 12th December, 1760. Most of his estate was bequeathed to his brothers, sisters, nephews, and cousins. He also divided 200 pounds between John Boyl and and a certain Reverend Richard Price.

Bayes died in Tunbridge Wells, Kent on 7th April, 1761. After his death, the Reverend Richard Price received Bayes’ manuscript on probability. Richard Price edited the manuscript and introduced Bayes’ theorem to the Royal Statistical Society.

It was called Essay Towards Solving a Problem in the Doctrine of Chances and was published in the Philosophical Transactions of the Royal Society in 1763.

Bayes_diagram

Diagram to illustrate Proposition 10 in the essay

I will leave the last word to the Revered Price himself:

Every judicious person will be sensible that the problem now mentioned is by no means merely a curious speculation in the doctrine of chances, but necessary to be solved in order to a sure foundation for all our reasonings concerning past facts, and what is likely to be hereafter. Common sense is indeed sufficient to show us that, from the observation of what has in former instances been the consequence of a certain cause or action, one may make a judgement what is likely to be the consequence of it another time and that the larger number of experiments we have to support a conclusion, so much more the reason we have to take it for granted. But it is certain that we cannot determine, at least not to any nicety, in what degree repeated experiments confirm a conclusion, without the particular discussion of the beforementioned problem; which, therefore, is necessary to be considered by any that would give a clear account of the strength of analogical or inductive reasoning; concerning, which at present, we seem to know little more than that it does sometimes in fact convince us, and at other times not; and that, as it is the means of acquainting us with many truths, of which otherwise we must have been ignorant; so it is, in all probability, the source of many errors, which perhaps might in some measure be avoided, if the force that this sort of reasoning ought to have with us were more distinctly and clearly understood.

© 2024 Ivan Debono

Theme by Anders NorénUp ↑