39 if (config !=
nullptr) {
53 s.set_alpha_em_mz(sm->alpha_em_mz);
54 s.set_alpha_s_mz(sm->alpha_s_mz);
58 for (
int i = 0;
i < 3;
i++) {
59 s.set_mu(
i, sm->mu[
i]);
61 for (
int i = 0;
i < 3;
i++) {
62 s.set_md(
i, sm->md[
i]);
64 for (
int i = 0;
i < 3;
i++) {
65 s.set_mv(
i, sm->mv[
i]);
67 for (
int i = 0;
i < 3;
i++) {
68 s.set_ml(
i, sm->ml[
i]);
70 Eigen::Matrix<std::complex<double>,3,3> ckm;
71 for (
int i = 0;
i < 3;
i++) {
72 for (
int k = 0;
k < 3;
k++) {
73 ckm(
i,
k) = std::complex<double>(sm->ckm_real[
i][
k], sm->ckm_imag[
i][
k]);
86 if (
basis !=
nullptr) {
88 for (
int i = 0;
i < 7;
i++) {
91 b.tan_beta =
basis->tan_beta;
96 for (
int i = 0;
i < 3;
i++) {
97 for (
int k = 0;
k < 3;
k++) {
115 if (
basis !=
nullptr) {
121 b.sin_beta_minus_alpha =
basis->sin_beta_minus_alpha;
122 b.lambda_6 =
basis->lambda_6;
123 b.lambda_7 =
basis->lambda_7;
124 b.tan_beta =
basis->tan_beta;
129 for (
int i = 0;
i < 3;
i++) {
130 for (
int k = 0;
k < 3;
k++) {
168 ERROR(
"unknown exception thrown");
180 if (config !=
nullptr) {
203 if (model ==
nullptr) {
245 if (model ==
nullptr) {
contains declarations of C interface functions for the SM
contains declarations of C interface functions for the model
gm2calc_THDM_yukawa_type
Yukawa schemes.
gm2calc_error gm2calc_thdm_new_with_mass_basis(gm2calc_THDM **model, const gm2calc_THDM_mass_basis *basis, const ::gm2calc_SM *sm, const gm2calc_THDM_config *config)
Allocate a new general THDM model with physical basis input.
void gm2calc_thdm_config_set_to_default(gm2calc_THDM_config *config)
Sets configuration options to default values.
gm2calc_THDM_yukawa_type int_to_c_yukawa_type(int i)
convert int to gm2calc_THDM_yukawa_type
gm2calc_error gm2calc_thdm_new_with_gauge_basis(gm2calc_THDM **model, const gm2calc_THDM_gauge_basis *basis, const ::gm2calc_SM *sm, const gm2calc_THDM_config *config)
Allocate a new general THDM model with general basis input.
void gm2calc_thdm_free(gm2calc_THDM *model)
Deletes a general THDM model.
void set_alpha_em_0(double a) noexcept
Contains routines to determine the THDM parameters.
@ gm2calc_PhysicalProblem
struct gm2calc_THDM gm2calc_THDM
Yukawa_type int_to_cpp_yukawa_type(int yukawa_type)
convert int to thdm::Yukawa_type
void svd_eigen(const Eigen::Matrix< Scalar, M, N > &m, Eigen::Array< Real,(((M)<(N)) ?(M) :(N)), 1 > &s, Eigen::Matrix< Scalar, M, M > *u, Eigen::Matrix< Scalar, N, N > *vh)
Configuration options for the THDM.
bool running_couplings
use running couplings
bool force_output
force output
THDM configuration options.
general THDM general basis input
general THDM physical basis input