-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit ca86012
Showing
206 changed files
with
27,763 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
# Sphinx build info version 1 | ||
# This file records the configuration used when building these files. When it is not found, a full rebuild will be done. | ||
config: 292c2c4c18973b0c51527665131fea15 | ||
tags: 645f666f9bcd5a90fca523b33c5a78b7 |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Large diffs are not rendered by default.
Oops, something went wrong.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Large diffs are not rendered by default.
Oops, something went wrong.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
281 changes: 281 additions & 0 deletions
281
.doctrees/nbsphinx/test_Bayesian_inference_MITbag_EOS.ipynb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,281 @@ | ||
{ | ||
"cells": [ | ||
{ | ||
"cell_type": "markdown", | ||
"id": "edb2cf2a", | ||
"metadata": {}, | ||
"source": [ | ||
"## MIT bag EOS Inference pipline" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "7bc633d3", | ||
"metadata": {}, | ||
"source": [ | ||
"The MIT bag model, which has commonly been applied to strange quark stars, relates pressure to energy density with the simple equation of state $p=\\frac{\\epsilon}{3}-\\frac{4B}{3}$. There is only one parameter, the \"bag constant\" $B$. This represents the vacuum energy density, which creates a \"bag\" in which quarks are confined. See [Chodos et al. (1974)](https://doi.org/10.1103/PhysRevD.9.3471).\n", | ||
"\n", | ||
"In this notebook, we use our Bayesian inference code to constrain the value of $B$ using observations." | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "acdcb64a", | ||
"metadata": {}, | ||
"source": [ | ||
"### (a) Import packages" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"id": "f6f20856", | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"import InferenceWorkflow.BayesianSampler as sampler\n", | ||
"import InferenceWorkflow.Likelihood as likelihood\n", | ||
"import InferenceWorkflow.prior as prior\n", | ||
"import math\n", | ||
"import numpy as np\n", | ||
"import EOSgenerators.MITbag_EOS as MITbag\n", | ||
"from TOVsolver.unit import MeV, fm, g_cm_3, dyn_cm_2, km, Msun\n", | ||
"import TOVsolver.main as main" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "edfa0f72", | ||
"metadata": {}, | ||
"source": [ | ||
"### (b) Set up priors" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "38136542", | ||
"metadata": {}, | ||
"source": [ | ||
"Next, we need to set up the priors. We first use a parameters array to specify the variable name. This process should be consistent with what you need to call them.\n", | ||
"\n", | ||
"Define a prior transform function to define prior. Cube is a set of random numbers from 0 to 1. This prior setting is the standard set-up of UltraNest package, since we are using UltraNest to do nest-sampling.\n", | ||
"\n", | ||
"We provided two options call from prior:\"normal_Prior\" and \"flat_prior\".\n", | ||
"\n", | ||
"We note that since we are doing Equation of state inference from mass-radius data of neutron star measurement. The central density of the star should be also sampled. Otherwise, this will be a partially-defined prior that did not span all of the parameter space, and proved to be different from full-scope inference.\n", | ||
"\n", | ||
"This request will randomly generate a density from a EoS range, however, this process is not that trivial, since we need to determine the upper limit of the central density of the compact star --- different equations of state will predict different upper bounds, so here we need to use the prior-setting EoS parameters computing the mass-radius curve for this equation of state, then find out the last stable point of this equation of state (first mass points that give the direvative to be negative). We can find that index with the len() function, then reset this max_d to be upper limit of this density range.\n" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"id": "2b87dd3b", | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"parameters = ['B','d1']\n", | ||
"\n", | ||
"def prior_transform(cube):\n", | ||
" params = cube.copy()\n", | ||
" params[0] = prior.flat_prior(20,100,cube[0])\n", | ||
"\n", | ||
" B = params[0]\n", | ||
" \n", | ||
" epsilon,p = MITbag.MITbag_compute_EOS(B)\n", | ||
"\n", | ||
" RFSU2R = [] \n", | ||
" MFSU2R = []\n", | ||
" density = np.logspace(14.3, 15.6, 50) \n", | ||
" if all(x<y for x,y in zip(epsilon[:], epsilon[1:])) and all(x<y for x, y in zip(p[:], p[1:])):\n", | ||
" MR = main.OutputMR(\"\",epsilon,p).T \n", | ||
" \n", | ||
" else:\n", | ||
" MR = []\n", | ||
" if len(MR) == False: \n", | ||
" params[1] = 0\n", | ||
" #this line for showing how to add one more observation\n", | ||
" else:\n", | ||
" \n", | ||
" for i in range(len(MR[1])):\n", | ||
" RFSU2R.append(MR[1][i])\n", | ||
" MFSU2R.append(MR[0][i]) \n", | ||
" if i > 20 and MR[0][i] - MR[0][i-1]< 0: \n", | ||
" break\n", | ||
" if len(MFSU2R)==False:\n", | ||
" params[1] = 0\n", | ||
" #params[3] = 0\n", | ||
" #this line for showing how to add one more observation\n", | ||
" else:\n", | ||
" max_index = len(MFSU2R)\n", | ||
" max_d = np.log10(density[max_index-1])\n", | ||
" params[1] = 14.3 + (max_d - 14.3) * cube[1]\n", | ||
" #params[3] = 14.3 + (max_d - 14.3) * cube[3]\n", | ||
" #this line for showing how to add one more observation\n", | ||
" return params" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "6f8e4822", | ||
"metadata": {}, | ||
"source": [ | ||
"In the upper part, we define a flat (uniform) prior for the parameters in the strangeon matter equation of state, due to the lack of constraints from terrestrial experiments.\n", | ||
"\n", | ||
"Note that the above code is an example of Bayesian analysis for a given mass and radius observation measurement.\n", | ||
"For example, if you use the NICER data for the measurements of J0030, then you should define another parameter, except the strangeon EOS parameters, e.g. \"d1\" for the centre density of this measurement, in the meantime add \"params[2]\" to this code.\n", | ||
"\n", | ||
"If you further consider the adjoint analysis with J0030+J0740, then you should define the other two parameters, e.g. \"d1\" and \"d2\" for the centre density of these two measurements, in the meantime add \"params[3]\" to the above code." | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "53ab6d43", | ||
"metadata": {}, | ||
"source": [ | ||
"### (c) Set up likehood" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "3bfd12ff", | ||
"metadata": {}, | ||
"source": [ | ||
"We need to set up a likelihood, Using standard definition way of UltraNest, that is below.\n", | ||
"\n", | ||
"Here the likelihood is generated from a simulated mass radius measurement, which is 𝑀=1.4𝑀⊙\n", | ||
" and 𝑅=13\n", | ||
" km, With a 5% Mass radius measurement uncertainty, \n", | ||
" \n", | ||
" so here\n", | ||
" \n", | ||
" likelihood.MRlikihood_Gaussian\n", | ||
" \n", | ||
"function will be use for our likelihood, please check [likelihood.MRlikihood_Gaussian](https://github.com/ChunHuangPhy/CompactOject/blob/main/InferenceWorkflow/Likelihood.py) to see the original code, and more choice of likelihood. eg:\n", | ||
"\n", | ||
"1.If we have some real mass-radius measurements, say PSR J0030 or PSR J0740, come from NICER, a KDE kernel could be trained to feed into\n", | ||
"\n", | ||
"likelihood.MRlikihood_kernel(eps_total,pres_total,x,d1)\n", | ||
"\n", | ||
"set the KDE kernel as a input for this function\n", | ||
"\n", | ||
"2.If we gain measurement from radio-timing, say only measure the neutron star mass, then\n", | ||
"\n", | ||
"likelihood.Masslikihood_Gaussian(eps_total,pres_total,x,d1)\n", | ||
"\n", | ||
"Which will give the likelihood from single mass measurement, x is the parameters of that measurement, you should specify where this measurement mass is located and what is the sigma width of this mass measurement.\n", | ||
"\n", | ||
"3.If we have nuclear measurements, and want to constrain this RMF model by nuclear properties like K(The Incompressibility of nuclear matter),J ( the symmetry energy at saturation density) and L( the slope of symmetry energy at saturation density). You can choose:\n", | ||
"\n", | ||
"likelihood.Kliklihood(theta,K_low,K_up)\n", | ||
"likelihood.Jliklihood(theta,K_low,K_up)\n", | ||
"likelihood.Lliklihood(theta,K_low,K_up)\n", | ||
"\n", | ||
"We are defaulting a hard-cut flat constrain, so if you don't like this default hard cut, also could define the likelihood by youself with similiar style.\n", | ||
"\n", | ||
"4.If we have a Tidal measurements from Gravitational wave detector, we can use it to do constraint:\n", | ||
"\n", | ||
"likelihood.TidalLikihood_kernel(eps_total,pres_total,x,d1)\n", | ||
"\n", | ||
"Where x is sampled distribution from real measurements, the standard is\n", | ||
"\n", | ||
"kernel, chrip = x,\n", | ||
"\n", | ||
"where the kernel is a whole set sampling from GW event, that is [chrip mass, M2/M1, tidal of M1, tidal of M2] four quantities. Chrip is the single smapling that comes only the chrip mass sampling." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"id": "0d3a8359", | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"import scipy.stats as stats\n", | ||
"\n", | ||
"\n", | ||
"def likelihood_transform(theta):\n", | ||
" # This is a demonstration code for only introduce one constraint from one mass-radius observation.\n", | ||
" # Could be very easy to implement more constraint from nuclear quantity, since that do not need to\n", | ||
" # sample more central density of real neutron star. If user want to expand to two mass radius measurement \n", | ||
" # the code could be:\n", | ||
" \n", | ||
" B, d1 = theta\n", | ||
" \n", | ||
" ####################################################################################################################\n", | ||
" ############ This is the block to compute out all the EoS you need based on your parameters#########################\n", | ||
"\n", | ||
" epsilon,p = MITbag.MITbag_compute_EOS(B)\n", | ||
"\n", | ||
" ####################################################################################################################\n", | ||
" \n", | ||
" probMRgaussian = likelihood.MRlikihood_Gaussian(epsilon,p,(1.4,13,0.07,0.65),d1)\n", | ||
" \n", | ||
" prob = probMRgaussian\n", | ||
" \n", | ||
" return prob" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "4a3802c4", | ||
"metadata": {}, | ||
"source": [ | ||
"### (d) Set up sampler" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"id": "76bce7fb", | ||
"metadata": {}, | ||
"source": [ | ||
"Here next, we define sampler, there is two different sampler we provided for. \n", | ||
"\n", | ||
"Considering where you need resume file:\n", | ||
"\n", | ||
"sampler.UltranestSampler and sampler.UltranestSamplerResume\n", | ||
"\n", | ||
"Here since it is our first run, so we only use first one. Some of the sampler parameters is requested, first is step number, our choice for UltraNest sampler is slicesampler, which could easily be sliced up your total computation load, and parallelize, speed up sampling. So step as suggested by documentation of UltraNest, we use 2*len(parameters).\n", | ||
"\n", | ||
"live_point we set 2000, it will influence the sampling precision, We suggest for 7 dimension space, maybe 5000 is a better choice, however, since my computer only have limited resources, we set 2000.\n", | ||
"\n", | ||
"max_calls set 10000, it is how many iteration after it will stop, we suggest to set this number significantly higher, otherwise maybe will broken before the inference converging to a definite value. That result will be un-phyiscal." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 5, | ||
"id": "f05849a0", | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"step = 2 * len(parameters)\n", | ||
"live_point = 400\n", | ||
"\n", | ||
"max_calls = 60000\n", | ||
"samples = sampler.UltranestSampler(parameters,likelihood_transform,prior_transform,step,live_point,max_calls)\n" | ||
] | ||
} | ||
], | ||
"metadata": { | ||
"kernelspec": { | ||
"display_name": "Python 3 (ipykernel)", | ||
"language": "python", | ||
"name": "python3" | ||
}, | ||
"language_info": { | ||
"codemirror_mode": { | ||
"name": "ipython", | ||
"version": 3 | ||
}, | ||
"file_extension": ".py", | ||
"mimetype": "text/x-python", | ||
"name": "python", | ||
"nbconvert_exporter": "python", | ||
"pygments_lexer": "ipython3", | ||
"version": "3.12.2" | ||
} | ||
}, | ||
"nbformat": 4, | ||
"nbformat_minor": 5 | ||
} |
Oops, something went wrong.