This example uses a custom phi^3 model created with FeynRules. Please evaluate the file FeynCalc/Examples/FeynRules/Phi3/GenerateModelPhi3.m before running it for the first time.
= "Renormalization, phi^3, MS and MSbar, 1-loop";
description If[ $FrontEnd === Null,
= False;
$FeynCalcStartupMessages Print[description];
];
If[ $Notebooks === False,
= False
$FeynCalcStartupMessages ];
= {"FeynArts"};
$LoadAddOns
<< FeynCalc`= 0;
$FAVerbose
[9, 3, 1]; FCCheckVersion
We keep scaleless B0 functions, since otherwise the UV part would not come out right.
= True; $KeepLogDivergentScalelessIntegrals
[PatchModelsOnly -> True];
FAPatch
(*Successfully patched FeynArts.*)
= {InsertionLevel -> {Particles}, Model -> FileNameJoin[{"Phi3", "Phi3"}],
params -> FileNameJoin[{"Phi3", "Phi3"}]};
GenericModel top[i_, j_] := CreateTopologies[1, i -> j, ExcludeTopologies -> Tadpoles];
[i_, j_] := CreateCTTopologies[1, i -> j];
topCT[i_, j_] := CreateTopologies[1, i -> j,
topVertex-> {WFCorrections}];
ExcludeTopologies [i_, j_] := CreateCTTopologies[1, i -> j,
topVertexCT-> {WFCorrectionCTs}];
ExcludeTopologies
{diagPhi3SE, diagPhi3SECT} = InsertFields[#, {S[1]} -> {S[1]},
Sequence @@ params] & /@ {top[1, 1], topCT[1, 1]};
{diagVertex, diagVertexCT} = InsertFields[#, {S[1]} -> {S[1], S[1]},
Sequence @@ params] & /@ {topVertex[1, 2], topVertexCT[1, 2]};
[0] = diagPhi3SE[[0]][Sequence @@ diagPhi3SE,
diag1Sequence @@ diagPhi3SECT];
[0] = diagVertex[[0]][Sequence @@ diagVertex,
diag2Sequence @@ diagVertexCT];
[diag1[0], ColumnsXRows -> {2, 1}, SheetHeader -> None,
Paint-> Simple, ImageSize -> {512, 256}]; Numbering
[diag2[0], ColumnsXRows -> {2, 1}, SheetHeader -> None,
Paint-> Simple, ImageSize -> {512, 256}]; Numbering
The 1/(2Pi)^D prefactor is implicit.
Self-energy including the counter-term
[0] = FCFAConvert[CreateFeynAmp[diag1[0], Truncated -> True,
amp1-> {}, PreFactor -> 1],
GaugeRules -> {p}, OutgoingMomenta -> {p},
IncomingMomenta -> {mu},
LorentzIndexNames -> {l}, UndoChiralSplittings -> True,
LoopMomenta -> D, List -> False, SMP -> True,
ChangeDimension -> {Zm -> SMP["Z_m"], Zphi -> SMP["Z_phi"],
FinalSubstitutions [S[1]] -> 1, Mphi -> m}] GaugeXi
Quartic vertex including the counter-term
[0] = FCFAConvert[CreateFeynAmp[diag2[0], Truncated -> True,
amp2-> {}, PreFactor -> 1],
GaugeRules -> {p1}, OutgoingMomenta -> {p2, p3},
IncomingMomenta -> {mu}, LoopMomenta -> {l},
LorentzIndexNames -> True, ChangeDimension -> D,
UndoChiralSplittings List -> False, SMP -> True, FinalSubstitutions -> {Zg -> SMP["Z_g"],
-> SMP["Z_phi"], GaugeXi[S[1]] -> 1, Mphi -> m}] Zphi
[1] = amp1[0] // ReplaceAll[#, {SMP["Z_phi"] -> 1 + alpha SMP["d_phi"],
amp1["Z_m"] -> 1 + alpha SMP["d_m"]}] & // Series[#, {alpha, 0, 1}] & //
SMPNormal // ReplaceAll[#, alpha -> 1] &
Express the self-energy in tems of the Passarino-Veltman coefficient functions.
[2] = ToPaVe[amp1[1], l] amp1
Discard all the finite pieces of the 1-loop amplitude
[0] = PaVeUVPart[amp1[2], Prefactor -> 1/(2 Pi)^D] //
amp1Div[#, D -> 4 - 2 Epsilon] & // Series[#, {Epsilon, 0, 0}] & // Normal //
FCReplaceD// SelectNotFree2[#, {SMP["Delta"], SMP["d_m"],
FCHideEpsilon ["d_phi"]}] & // Simplify SMP
Equating the result to zero and solving for d_phi and d_m we obtain the renormalization constants in the minimal subtraction schemes.
[1] = Solve[SelectNotFree2[amp1Div[0], p] == 0,
sol["d_phi"]] // Flatten // Simplify;
SMP[2] = Solve[(SelectFree2[amp1Div[0], p] == 0) /. sol[1],
sol["d_m"]] // Flatten // Simplify;
SMP= Join[sol[1], sol[2]] /. {
solMS1 ["d_phi"] -> SMP["d_phi^MS"],
SMP["d_m"] -> SMP["d_m^MS"], SMP["Delta"] -> 1/Epsilon
SMP}
= Join[sol[1], sol[2]] /. {
solMSbar1 ["d_phi"] -> SMP["d_phi^MSbar"],
SMP["d_m"] -> SMP["d_m^MSbar"]
SMP}
[1] = amp2[0] // ReplaceRepeated[#, {SMP["Z_g"] -> 1 + alpha SMP["d_g"],
amp2["Z_phi"] -> 1 + alpha SMP["d_phi"]}] & //
SMPSeries[#, {alpha, 0, 1}] & // Normal // ReplaceAll[#, alpha -> 1] &
Express the cubic vertex in tems of the Passarino-Veltman coefficient functions.
[2] = ToPaVe[amp2[1], l] amp2
Discard all the finite pieces of the 1-loop amplitude
[0] = PaVeUVPart[amp2[2], Prefactor -> 1/(2 Pi)^D] //
amp2Div[#, D -> 4 - 2 Epsilon] & // Series[#, {Epsilon, 0, 0}] & // Normal //
FCReplaceD// SelectNotFree2[#, {SMP["Delta"], SMP["d_g"], SMP["d_phi"]}] & // Simplify FCHideEpsilon
[3] = Solve[(amp2Div[0] == 0) /. sol[1],
sol["d_g"]] // Flatten // Simplify;
SMP= sol[3] /. {
solMS2 ["d_g"] -> SMP["d_g^MS"],
SMP["Delta"] -> 1/Epsilon
SMP}
= sol[3] /. {
solMSbar2 ["d_g"] -> SMP["d_g^MSbar"]
SMP}
= {
knownResult ["d_phi^MS"] -> 0,
SMP["d_m^MS"] -> (g^2*1/Epsilon)/(32*Pi^2 m^2),
SMP["d_g^MS"] -> 0,
SMP
["d_phi^MSbar"] -> 0,
SMP["d_m^MSbar"] -> (g^2*SMP["Delta"])/(32*Pi^2 m^2),
SMP["d_g^MSbar"] -> 0
SMP};
[Join[solMS1, solMS2, solMSbar1, solMSbar2], knownResult,
FCCompareResultsText -> {"\tCompare to Cheng and Li, Gauge theory of elementary particle physics, Problems and Solutions, Eq. 2.120:",
"CORRECT.", "WRONG!"}, Interrupt -> {Hold[Quit[1]], Automatic}];
Print["\tCPU Time used: ", Round[N[TimeUsed[], 4], 0.001], " s."];