BSMPT 3.0.7
BSMPT - Beyond the Standard Model Phase Transitions : A C++ package for the computation of the EWPT in BSM models
Loading...
Searching...
No Matches
MinimizePlane.cpp File Reference
#include <BSMPT/minimizer/MinimizePlane.h>
#include <BSMPT/utility/Logger.h>
#include <gsl/gsl_errno.h>
#include <gsl/gsl_multimin.h>
#include <BSMPT/models/ClassPotentialOrigin.h>
#include <BSMPT/models/IncludeAllModels.h>
#include <iomanip>
#include <iostream>
#include <limits>
#include <random>
#include <stdexcept>
#include <stdio.h>
#include <string>
#include <time.h>
#include <BSMPT/config.h>

Namespaces

namespace  BSMPT
 This classes calculates the Bounce action of the potential with a set temperature.
 

Functions

std::vector< double > BSMPT::Minimizer::TransformCoordinates (const std::vector< double > &vMinTilde, const struct PointerContainerMinPlane &params)
 
MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane (const std::vector< double > &basepoint, const std::vector< double > &VEVSymmetric, const std::vector< double > &VEVBroken, const ModelID::ModelIDs &Model, const std::vector< double > &par, const std::vector< double > &parCT, const double &Temp, const int &WhichMinimizer=WhichMinimizerDefault)
 
MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane (const std::vector< double > &basepoint, const std::vector< double > &VEVSymmetric, const std::vector< double > &VEVBroken, const ModelID::ModelIDs &Model, const std::vector< double > &par, const std::vector< double > &parCT, const ISMConstants &SMConstant, const double &Temp, const int &WhichMinimizer=WhichMinimizerDefault)
 
MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane (const std::vector< double > &basepoint, const std::vector< double > &VEVSymmetric, const std::vector< double > &VEVBroken, const std::shared_ptr< Class_Potential_Origin > &modelPointer, const double &Temp, const int &WhichMinimizer=WhichMinimizerDefault)
 
double BSMPT::Minimizer::GSL_VEFF_Minimize_Plane (const gsl_vector *v, void *p)
 
int BSMPT::Minimizer::GSL_Minimize_Plane_From_S_gen_all (const struct PointerContainerMinPlane &p, std::vector< double > &sol, const std::vector< double > &start)
 
GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all (const struct PointerContainerMinPlane &params, std::size_t seed, std::size_t MinSol)
 
GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all (const struct PointerContainerMinPlane &params, std::size_t seed)
 
GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all (const struct PointerContainerMinPlane &params, std::size_t seed, std::vector< std::vector< double > > &saveAllMinima, std::size_t MinSol)
 

Function Documentation

◆ GSL_Minimize_Plane_From_S_gen_all()

int BSMPT::Minimizer::GSL_Minimize_Plane_From_S_gen_all ( const struct PointerContainerMinPlane p,
std::vector< double > &  sol,
const std::vector< double > &  start 
)

Uses the GSL minimisation routines to find the next local minimum from a given point

Parameters
pGSL_params struct which containts the information about the model and the potential
solVector to store the solution
startStarting point from where to look for the next local minimum
Returns
The final status of the gsl minimization process.

◆ GSL_Minimize_Plane_gen_all() [1/3]

GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all ( const struct PointerContainerMinPlane params,
std::size_t  seed 
)

Minimise the Potential from different random starting points and look for 20 local minima. Choose the local minimum with the deepest potential value as the candidate for the global minimum

Parameters
paramsPointerContainerMinPlane which containts the model information and potential
seedSeed for generating the random starting points
Returns
A GSLPlaneReturn with a boolean being true if a candidate for the global minimum is found and false otherwise and a vector in which the candidate for the global minimum is stored

◆ GSL_Minimize_Plane_gen_all() [2/3]

GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all ( const struct PointerContainerMinPlane params,
std::size_t  seed,
std::size_t  MinSol 
)

Minimise the Potential from different random starting points and choose the local minimum with the deepest potential value as the candidate for the global minimum

Parameters
paramsPointerContainerMinPlane which containts the model information and potential
seedSeed for generating the random starting points
MinSolNumber of local minima to look out for
Returns
A GSLPlaneReturn with a boolean being true if a candidate for the global minimum is found and false otherwise and a vector in which the candidate for the global minimum is stored

◆ GSL_Minimize_Plane_gen_all() [3/3]

GSLPlaneReturn BSMPT::Minimizer::GSL_Minimize_Plane_gen_all ( const struct PointerContainerMinPlane params,
std::size_t  seed,
std::vector< std::vector< double > > &  saveAllMinima,
std::size_t  MinSol 
)

Minimise the Potential from different random starting points and choose the local minimum with the deepest potential value as the candidate for the global minimum

Parameters
paramsPointerContainerMinPlane which containts the model information and potential
seedSeed for generating the random starting points
saveAllMinimaMatrix in which all found local minima are saved
MinSolNumber of local minima to look out for
Returns
A GSLPlaneReturn with a boolean being true if a candidate for the global minimum is found and false otherwise and a vector in which the candidate for the global minimum is stored

◆ GSL_VEFF_Minimize_Plane()

double BSMPT::Minimizer::GSL_VEFF_Minimize_Plane ( const gsl_vector *  v,
void *  p 
)

Calculates the value of the effective potential at the vev v and temperature p->Temp for the gsl interface

Parameters
vVEV configuration at which potential should be evaluated
pPointer to a PointerContainerMinPlane struct which contains the model information

◆ MinimizePlane() [1/3]

MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane ( const std::vector< double > &  basepoint,
const std::vector< double > &  VEVSymmetric,
const std::vector< double > &  VEVBroken,
const ModelID::ModelIDs Model,
const std::vector< double > &  par,
const std::vector< double > &  parCT,
const double &  Temp,
const int &  WhichMinimizer = WhichMinimizerDefault 
)

Calculates the minimum of a potential on a plane. For this the normal vector of the plane is calculated as the connection vector between the symmetric and the broken phase. At a given point the plane normal to the connection vector is then calculated and the potential is minimised along this plane.

Parameters
basepointParameter point at which the plane and the connection between the symmetric and the broken minimum should be calculated
VEVSymmetricSymmetric minimum
VEVBrokenBroken minimum
ModelDecides which model should be used through FChoose
parInputparameters for the parameterpoint
parCTCounterterm parameters for the parameterpoint
TempTemperature at which the minimum should be calculated
Returns
MinimizePlaneReturn struct which has the minimum and the value of the potential

◆ MinimizePlane() [2/3]

MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane ( const std::vector< double > &  basepoint,
const std::vector< double > &  VEVSymmetric,
const std::vector< double > &  VEVBroken,
const ModelID::ModelIDs Model,
const std::vector< double > &  par,
const std::vector< double > &  parCT,
const ISMConstants SMConstant,
const double &  Temp,
const int &  WhichMinimizer = WhichMinimizerDefault 
)

Calculates the minimum of a potential on a plane. For this the normal vector of the plane is calculated as the connection vector between the symmetric and the broken phase. At a given point the plane normal to the connection vector is then calculated and the potential is minimised along this plane.

Parameters
basepointParameter point at which the plane and the connection between the symmetric and the broken minimum should be calculated
VEVSymmetricSymmetric minimum
VEVBrokenBroken minimum
ModelDecides which model should be used through FChoose
parInputparameters for the parameterpoint
parCTCounterterm parameters for the parameterpoint
SMConstantThe SM constants used by the parameter point
TempTemperature at which the minimum should be calculated
Returns
MinimizePlaneReturn struct which has the minimum and the value of the potential

◆ MinimizePlane() [3/3]

MinimizePlaneReturn BSMPT::Minimizer::MinimizePlane ( const std::vector< double > &  basepoint,
const std::vector< double > &  VEVSymmetric,
const std::vector< double > &  VEVBroken,
const std::shared_ptr< Class_Potential_Origin > &  modelPointer,
const double &  Temp,
const int &  WhichMinimizer = WhichMinimizerDefault 
)

Calculates the minimum of a potential on a plane. For this the normal vector of the plane is calculated as the connection vector between the symmetric and the broken phase. At a given point the plane normal to the connection vector is then calculated and the potential is minimised along this plane.

Parameters
basepointParameter point at which the plane and the connection between the symmetric and the broken minimum should be calculated
VEVSymmetricSymmetric minimum
VEVBrokenBroken minimum
modelPointerPointer to the corresponding model and parameter point through Class_Potential_Origin
TempTemperature at which the minimum should be calculated
Returns
MinimizePlaneReturn struct which has the minimum and the value of the potential

◆ TransformCoordinates()

std::vector< double > BSMPT::Minimizer::TransformCoordinates ( const std::vector< double > &  vMinTilde,
const struct PointerContainerMinPlane params 
)

Transform from nVEV -1 coordinates used in the plane minimisation to the nVEV coordinates used to evaluate the potential.

Parameters
vMinTildeA point in the nVEV -1 dimensions which were used to minimise the potential in the plane
paramsthe PointerContainerMinPlane struct which containts the potential and the index at which the vector has to be extended.
Returns
The point vMinTilde will be extended by the missing component to be in the nVEV dimensional space which can be used to calculate the potential