KaliVeda
Toolkit for HIC analysis
MicroStat_example.C

Calculate 12C*->3-alpha decay & compare alpha KE with exact microcanonical distribution

Example of use of MicroStat::mdweight class, which can generate events according to the molecular dynamics ensemble i.e. fixed total energy and zero total momentum.

By default, 10**5 events are generated for the 3-alpha decay of a Carbon-12 nucleus with E*=50 MeV.

A histogram is filled with the kinetic energy distribution of one of the alpha particles, which is then fitted using the exact microcanonical probability distribution for a classical gas of 3 equal-mass particles.

To execute this function do

$ kaliveda
kaliveda[0] .L MicroStat_example.C+
kaliveda[1] example()
#include "KVNucleus.h"
#include "KVNucleusEvent.h"
#include "mdweight.h"
#include "TH1F.h"
#include "TF1.h"
#include "TStyle.h"
#include "TStopwatch.h"
double edist(double* x, double* par)
{
// microcanonical energy distribution for gas of identical
// (same mass) particles.
//
// p0 = normalisation
// p1 = Etot
// p2 = number of particles
double E = x[0];
double k = par[2] / (par[2] - 1.);
if (E > 0 && E < par[1] / k) {
double w = par[0] * pow(E / pow(par[1], 3), 0.5);
w *= pow((1. - k * E / par[1]), (3.*par[2] - 8.) / 2.);
return w;
}
return 0.;
}
void example(double E0 = 50, int nevents = 100000)
{
TStopwatch timer;
// 12C* -> 3(4He)
// compound nucleus = carbon
KVNucleus CN(6, 12);
CN.SetExcitEnergy(E0);
// decay products
KVNucleus* n = decay.AddParticle();
n->SetZandA(2, 4);
n = decay.AddParticle();
n->SetZandA(2, 4);
n = decay.AddParticle();
n->SetZandA(2, 4);
Double_t etot = E0 + decay.GetChannelQValue();
if (etot <= 0) {
printf("Break-up channel is not allowed\n");
return;
}
gps.SetWeight(&decay, etot);
gps.initGenerateEvent(&decay);
TH1F* h1 = new TH1F("h1", "Kinetic energy of alpha particle 3", 200, 0, etot * 2. / 3.);
h1->Sumw2();
while (nevents--) {
gps.GenerateEvent(&decay, &event);
h1->Fill(event.GetParticle(3)->GetKE());
}
h1->Draw();
TF1* EDis = new TF1("EDis", edist, 0., etot, 3);
EDis->SetNpx(500);
EDis->SetParLimits(0, 0, 1.e+08);
EDis->SetParLimits(1, 0, 2 * etot);
EDis->FixParameter(2, 3);
h1->Fit(EDis, "EM");
timer.Print();
}
double Double_t
winID w
R__EXTERN TStyle * gStyle
An event container for KVNucleus objects.
Description of properties and kinematics of atomic nuclei.
Definition: KVNucleus.h:126
void GenerateEvent(KVEvent *partition, KVEvent *event)
Definition: StatWeight.cpp:79
Calculate molecular dynamics ensemble weights for events .
Definition: mdweight.h:20
void resetGenerateEvent()
Definition: mdweight.cpp:171
void initGenerateEvent(KVEvent *partition)
Definition: mdweight.cpp:153
virtual void SetWeight(KVEvent *e, Double_t E)
Definition: mdweight.cpp:120
virtual void SetNpx(Int_t npx=100)
virtual void SetParLimits(Int_t ipar, Double_t parmin, Double_t parmax)
virtual void FixParameter(Int_t ipar, Double_t value)
virtual TFitResultPtr Fit(const char *formula, Option_t *option="", Option_t *goption="", Double_t xmin=0, Double_t xmax=0)
void Draw(Option_t *option="") override
virtual Int_t Fill(const char *name, Double_t w)
virtual void Sumw2(Bool_t flag=kTRUE)
void Print(Option_t *option="") const override
void SetOptFit(Int_t fit=1)
RVec< PromoteTypes< T0, T1 > > pow(const T0 &x, const RVec< T1 > &v)
Double_t x[n]
const Int_t n
TH1F * h1
constexpr Double_t E()