Jpp 19.3.0-rc.4
the software that should make you happy
Loading...
Searching...
No Matches
JCALIBRATE::JK40Parameters Struct Reference

Fit parameters for two-fold coincidence rate due to K40. More...

#include <JFitK40.hh>

Inheritance diagram for JCALIBRATE::JK40Parameters:
JCALIBRATE::JK40Parameters_t JCALIBRATE::JModel_t JCALIBRATE::JModel

Public Member Functions

 JK40Parameters ()
 Default constructor.
 
size_t getN () const
 Get number of fit parameters.
 
int getIndex (JParameter_t JK40Parameters::*p) const
 Get index of parameter.
 
double getValue (const double ct) const
 Get K40 coincidence rate as a function of cosine angle between PMT axes.
 
const JK40Parameters_tgetGradient (const double ct) const
 Get gradient.
 
const JK40Parameters_tgetK40Parameters () const
 Get K40 parameters.
 
void setK40Parameters (const JK40Parameters_t &parameters)
 Set K40 parameters.
 
void reset ()
 Reset.
 

Static Public Member Functions

static const JK40ParametersgetInstance ()
 Get default values.
 

Public Attributes

JParameter_t R
 maximal coincidence rate [Hz]
 
JParameter_t p1
 1st order angle dependence coincidence rate
 
JParameter_t p2
 2nd order angle dependence coincidence rate
 
JParameter_t p3
 3rd order angle dependence coincidence rate
 
JParameter_t p4
 4th order angle dependence coincidence rate
 
JParameter_t cc
 fraction of signal correlated background
 
JParameter_t bc
 constant background
 

Private Attributes

JK40Parameters_t gradient
 

Detailed Description

Fit parameters for two-fold coincidence rate due to K40.

Definition at line 698 of file JFitK40.hh.

Constructor & Destructor Documentation

◆ JK40Parameters()

JCALIBRATE::JK40Parameters::JK40Parameters ( )
inline

Default constructor.

Definition at line 704 of file JFitK40.hh.

705 {}

Member Function Documentation

◆ getInstance()

static const JK40Parameters & JCALIBRATE::JK40Parameters::getInstance ( )
inlinestatic

Get default values.

The default parameter values are set to those obtained from a designated simulation of K40 decays (see http://wiki.km3net.de/index.php/OMGsim_simulations_for_K40_fit).
If you change these values, you may also want to change the corresponding values in JK40DefaultSimulator.hh.

Returns
parameters

Definition at line 717 of file JFitK40.hh.

718 {
719 static JK40Parameters parameters;
720
721 parameters.R .set(18.460546);
722 parameters.p1.set( 3.0767);
723 parameters.p2.set(-1.2078);
724 parameters.p3.set( 0.9905);
725 parameters.p4.set( 0.9379);
726 parameters.cc.set( 0.0);
727 parameters.bc.set( 0.0);
728
729 return parameters;
730 }
JK40Parameters()
Default constructor.
Definition JFitK40.hh:704

◆ getN()

size_t JCALIBRATE::JK40Parameters::getN ( ) const
inline

Get number of fit parameters.

Returns
number of parameters

Definition at line 738 of file JFitK40.hh.

739 {
740 return ((R .isFree() ? 1 : 0) +
741 (p1.isFree() ? 1 : 0) +
742 (p2.isFree() ? 1 : 0) +
743 (p3.isFree() ? 1 : 0) +
744 (p4.isFree() ? 1 : 0) +
745 (cc.isFree() ? 1 : 0) +
746 (bc.isFree() ? 1 : 0));
747 }
bool isFree() const
Check if parameter is free.
Definition JFitK40.hh:240
JParameter_t bc
constant background
Definition JFitK40.hh:691
JParameter_t R
maximal coincidence rate [Hz]
Definition JFitK40.hh:685
JParameter_t p1
1st order angle dependence coincidence rate
Definition JFitK40.hh:686
JParameter_t p2
2nd order angle dependence coincidence rate
Definition JFitK40.hh:687
JParameter_t p3
3rd order angle dependence coincidence rate
Definition JFitK40.hh:688
JParameter_t p4
4th order angle dependence coincidence rate
Definition JFitK40.hh:689
JParameter_t cc
fraction of signal correlated background
Definition JFitK40.hh:690

◆ getIndex()

int JCALIBRATE::JK40Parameters::getIndex ( JParameter_t JK40Parameters::* p) const
inline

Get index of parameter.

Parameters
ppointer to data member
Returns
index

Definition at line 756 of file JFitK40.hh.

757 {
758 if (!(this->*p).isFree()) {
759 return INVALID_INDEX;
760 }
761
762 int N = 0;
763
764 if (p == &JK40Parameters::R) { return N; } if (R .isFree()) { ++N; }
765 if (p == &JK40Parameters::p1) { return N; } if (p1.isFree()) { ++N; }
766 if (p == &JK40Parameters::p2) { return N; } if (p2.isFree()) { ++N; }
767 if (p == &JK40Parameters::p3) { return N; } if (p3.isFree()) { ++N; }
768 if (p == &JK40Parameters::p4) { return N; } if (p4.isFree()) { ++N; }
769 if (p == &JK40Parameters::cc) { return N; } if (cc.isFree()) { ++N; }
770 if (p == &JK40Parameters::bc) { return N; } if (bc.isFree()) { ++N; }
771
772 return INVALID_INDEX;
773 }
static const int INVALID_INDEX
invalid index
Definition JFitK40.hh:60

◆ getValue()

double JCALIBRATE::JK40Parameters::getValue ( const double ct) const
inline

Get K40 coincidence rate as a function of cosine angle between PMT axes.

Parameters
ctcosine angle between PMT axes
Returns
rate [Hz]

Definition at line 782 of file JFitK40.hh.

783 {
784 return R * exp(ct*(p1+ct*(p2+ct*(p3+ct*p4))) - (p1+p2+p3+p4));
785 }

◆ getGradient()

const JK40Parameters_t & JCALIBRATE::JK40Parameters::getGradient ( const double ct) const
inline

Get gradient.

Parameters
ctcosine angle between PMT axes
Returns
gradient

Definition at line 794 of file JFitK40.hh.

795 {
796 gradient.reset();
797
798 const double rate = getValue(ct);
799 const double ct2 = ct * ct;
800
801 if (R .isFree()) { gradient.R = rate / R; }
802 if (p1.isFree()) { gradient.p1 = rate * ct - rate; }
803 if (p2.isFree()) { gradient.p2 = rate * ct2 - rate; }
804 if (p3.isFree()) { gradient.p3 = rate * ct2 * ct - rate; }
805 if (p4.isFree()) { gradient.p4 = rate * ct2 * ct2 - rate; }
806 if (cc.isFree()) { gradient.cc = rate; }
807 if (bc.isFree()) { gradient.bc = 1.0; }
808
809 return gradient;
810 }
JK40Parameters_t gradient
Definition JFitK40.hh:813
double getValue(const double ct) const
Get K40 coincidence rate as a function of cosine angle between PMT axes.
Definition JFitK40.hh:782

◆ getK40Parameters()

const JK40Parameters_t & JCALIBRATE::JK40Parameters_t::getK40Parameters ( ) const
inlineinherited

Get K40 parameters.

Returns
K40 parameters

Definition at line 631 of file JFitK40.hh.

632 {
633 return static_cast<const JK40Parameters_t&>(*this);
634 }
JK40Parameters_t()
Default constructor.
Definition JFitK40.hh:620

◆ setK40Parameters()

void JCALIBRATE::JK40Parameters_t::setK40Parameters ( const JK40Parameters_t & parameters)
inlineinherited

Set K40 parameters.

Parameters
parametersK40 parameters

Definition at line 642 of file JFitK40.hh.

643 {
644 static_cast<JK40Parameters_t&>(*this) = parameters;
645 }

◆ reset()

void JCALIBRATE::JK40Parameters_t::reset ( )
inlineinherited

Reset.

Definition at line 651 of file JFitK40.hh.

652 {
653 R .set(0.0);
654 p1.set(0.0);
655 p2.set(0.0);
656 p3.set(0.0);
657 p4.set(0.0);
658 cc.set(0.0);
659 bc.set(0.0);
660 }
void set()
Set current value.
Definition JFitK40.hh:271

Member Data Documentation

◆ gradient

JK40Parameters_t JCALIBRATE::JK40Parameters::gradient
mutableprivate

Definition at line 813 of file JFitK40.hh.

◆ R

JParameter_t JCALIBRATE::JK40Parameters_t::R
inherited

maximal coincidence rate [Hz]

Definition at line 685 of file JFitK40.hh.

◆ p1

JParameter_t JCALIBRATE::JK40Parameters_t::p1
inherited

1st order angle dependence coincidence rate

Definition at line 686 of file JFitK40.hh.

◆ p2

JParameter_t JCALIBRATE::JK40Parameters_t::p2
inherited

2nd order angle dependence coincidence rate

Definition at line 687 of file JFitK40.hh.

◆ p3

JParameter_t JCALIBRATE::JK40Parameters_t::p3
inherited

3rd order angle dependence coincidence rate

Definition at line 688 of file JFitK40.hh.

◆ p4

JParameter_t JCALIBRATE::JK40Parameters_t::p4
inherited

4th order angle dependence coincidence rate

Definition at line 689 of file JFitK40.hh.

◆ cc

JParameter_t JCALIBRATE::JK40Parameters_t::cc
inherited

fraction of signal correlated background

Definition at line 690 of file JFitK40.hh.

◆ bc

JParameter_t JCALIBRATE::JK40Parameters_t::bc
inherited

constant background

Definition at line 691 of file JFitK40.hh.


The documentation for this struct was generated from the following file: