Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fixing calculation of BR(KL,KS->emu,mue) #141

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 63 additions & 23 deletions flavio/physics/kdecays/kll.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,22 +9,21 @@
from math import pi, sqrt


def amplitudes(par, wc, l1, l2):
r"""Amplitudes P and S entering the $K\to\ell_1^+\ell_2^-$ observables.
def amplitudes_weak_eigst(par, wc, l1, l2):
r"""Amplitudes P and S for the decay $\bar K^0\to\ell_1^+\ell_2^-$.

Parameters
----------

- `par`: parameter dictionary
- `wc`: Wilson coefficient dictionary
- `K`: should be `'KL'` or `'KS'`
- `l1` and `l2`: should be `'e'` or `'mu'`
"""
# masses
ml1 = par['m_'+l1]
ml2 = par['m_'+l2]
mK = par['m_K0']
# Wilson coefficients
# Wilson coefficient postfix
qqll = 'sd' + l1 + l2
# For LFV expressions see arXiv:1602.00881 eq. (5)
C9m = wc['C9_'+qqll] - wc['C9p_'+qqll] # only relevant for l1 != l2
Expand All @@ -33,52 +32,92 @@ def amplitudes(par, wc, l1, l2):
CSm = wc['CS_'+qqll] - wc['CSp_'+qqll]
P = (ml2 + ml1)/mK * C10m + mK * CPm # neglecting mu, md
S = (ml2 - ml1)/mK * C9m + mK * CSm # neglecting mu, md
# Include complex part of the eff. operator prefactor. Phases matter.
xi_t = ckm.xi('t', 'sd')(par)
return xi_t * P, xi_t * S


def amplitudes(par, wc, K, l1, l2):
r"""Amplitudes P and S entering the $K_{L,S}\to\ell_1^+\ell_2^-$ observables.

Parameters
----------

- `par`: parameter dictionary
- `wc`: Wilson coefficient dictionary
- `K`: should be `'KL'` or `'KS'`
- `l1` and `l2`: should be `'e'` or `'mu'`
"""
# KL, KS are linear combinations of K0, K0bar. So are the amplitudes.
# Normalization differs by sqrt(2) from `amplitudes_weak_eigst`.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a particular reason not to use the same normalization?

P_K0bar, S_K0bar = amplitudes_weak_eigst(par, wc, l1, l2)
if l1 != l2:
P_aux, S_aux = amplitudes_weak_eigst(par, wc, l2, l1)
S_K0 = -S_aux.conjugate()
P_K0 = P_aux.conjugate()
if K == 'KL':
sig = +1
elif K == 'KS':
sig = -1
S = (S_K0 + sig * S_K0bar) / 2
P = (P_K0 + sig * P_K0bar) / 2
# Simplified expressions for special cases. See also arXiv:1711.11030.
elif l1 == l2:
if K == 'KL':
S = -1j * S_K0bar.imag
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

comparing this to your notes, Eq. (22a), shouldn't this be +1j * S_K0bar.imag?

P = P_K0bar.real
elif K == 'KS':
S = -S_K0bar.real
P = -1j * P_K0bar.imag
return P, S


def amplitudes_LD(par, K, l):
r"""Long-distance amplitudes entering the $K\to\ell^+\ell^-$ observables."""
ml = par['m_' + l]
mK = par['m_' + K]
mK = par['m_K0']
s2w = par['s2w']
pre = 2 * ml / mK / s2w
# numbers extracted from arXiv:1711.11030
ASgaga = 2.49e-4 * (-2.821 + 1.216j)
ALgaga = 2.02e-4 * (par['chi_disp(KL->gammagamma)'] - 5.21j)
S = pre * ASgaga
P = -pre * ALgaga
return S, P
if K == 'KS':
ASgaga = 2.49e-4 * (-2.821 + 1.216j)
SLD = pre * ASgaga
PLD = 0
elif K == 'KL':
ALgaga = 2.02e-4 * (par['chi_disp(KL->gammagamma)'] - 5.21j)
SLD = 0
PLD = pre * ALgaga
return SLD, PLD


def amplitudes_eff(par, wc, K, l1, l2, ld=True):
r"""Effective amplitudes entering the $K\to\ell_1^+\ell_2^-$ observables."""
P, S = amplitudes(par, wc, l1, l2)
P, S = amplitudes(par, wc, K, l1, l2)
if l1 != l2 or not ld:
SLD = 0
PLD = 0
else:
SLD, PLD = amplitudes_LD(par, K, l1)
if K == 'KS' and l1 == l2:
Peff = P.imag
Seff = S.real + SLD
if K == 'KL':
Peff = P.real + PLD
Seff = S.imag
# The relative sign due to different conventions. Cf. my notes.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe instead of Cf. my notes., you could put the link to the notes there. Otherwise it will be impossible find them just by looking at this comment in the code.

Peff = P - PLD
Seff = S - SLD
return Peff, Seff


def get_wc(wc_obj, par, l1, l2):
scale = config['renormalization scale']['kdecays']
label = 'sd' + l1 + l2
wcnp = wc_obj.get_wc(label, scale, par)
if l1 == l2:
if l1 == l2: # (l1,l2) == ('e','e') or ('mu','mu')
label = 'sd' + l1 + l2
wcnp = wc_obj.get_wc(label, scale, par)
# include SM contributions for LF conserving decay
_c = wilsoncoefficients_sm_sl(par, scale)
xi_t = ckm.xi('t', 'sd')(par)
xi_c = ckm.xi('c', 'sd')(par)
wcsm = {'C10_sd' + l1 + l2: _c['C10_t'] + xi_c / xi_t * _c['C10_c']}
else:
elif {l1,l2} == {'e','mu'}:
# Both flavor combinations relevant due to K0-K0bar mixing
wcnp = {**wc_obj.get_wc('sdemu', scale, par),
**wc_obj.get_wc('sdmue', scale, par)}
wcsm = {}

return add_dict((wcsm, wcnp))
Expand All @@ -95,7 +134,7 @@ def br_kll(par, wc_obj, K, l1, l2, ld=True):
mK = par['m_K0']
tauK = par['tau_'+K]
fK = par['f_K0']
# appropriate CKM elements
# CKM part of the eff. operator prefactor N is included in Peff and Seff
N = 4 * GF / sqrt(2) * alphaem / (4 * pi)
beta = sqrt(lambda_K(mK**2, ml1**2, ml2**2)) / mK**2
beta_p = sqrt(1 - (ml1 + ml2)**2 / mK**2)
Expand All @@ -113,7 +152,8 @@ def f(wc_obj, par):

def br_kll_fct_lsum(K, l1, l2):
def f(wc_obj, par):
return br_kll(par, wc_obj, K, l1, l2) + br_kll(par, wc_obj, K, l2, l1)
# Neglecting indirect CPV in kaons, BR(KL,KS->e+mu-) = BR(KL,KS->mu+e-)
return 2 * br_kll(par, wc_obj, K, l1, l2)
return f


Expand Down