Load
FeynCalc and the necessary add-ons or other packages
description = "B -> EtaC, QCD, topology minimization, 2-loops";
If[ $FrontEnd === Null,
$FeynCalcStartupMessages = False;
Print[description];
];
If[ $Notebooks === False,
$FeynCalcStartupMessages = False
];
<< FeynCalc`
FCCheckVersion[10, 0, 0];
FeynCalc 10.0.0 (dev version, 2024-08-07 16:59:34 +02:00, 2f62a22c). For help, use the onlinedocumentation, visit the forum and have a look at the supplied examples. The PDF-version of the manual can be downloaded here.
If you use FeynCalc in your research, please evaluate FeynCalcHowToCite[] to learn how to cite this software.
Please keep in mind that the proper academic attribution of our work is crucial to ensure the future development of this package!
Load the topologies
SetDirectory[FCGetNotebookDirectory[]];
rawTopologies0 = Get["RawTopologies-B-Etac.m"];
Run the naive topology
identification
fcVariables={gkin,meta,u0b};
(DataType[#, FCVariable] = True) & /@ fcVariables;
rawTopologies = loopHead /@ (rawTopologies0);
kinematics={Hold[SPD][n]->0,Hold[SPD][nb]->0,Hold[SPD][n,nb]->2};
aux1 = FCLoopFindTopologies[rawTopologies, {k1, k2}, FCLoopIsolate -> loopHead,
FCLoopBasisOverdeterminedQ -> True, FinalSubstitutions -> kinematics,
Names -> "preTopoDia", Head -> Identity, FCLoopGetKinematicInvariants -> False, FCLoopScalelessQ -> False];
FCLoopFindTopologies: Number of the initial candidate topologies: 248
FCLoopFindTopologies: Number of the identified unique topologies: 184
FCLoopFindTopologies: Number of the preferred topologies among the unique topologies: 0
FCLoopFindTopologies: Number of the identified subtopologies: 64
FCLoopFindTopologies: Follwing identified topologies are scaleless and will be set to zero: {preTopoDia31,preTopoDia32,preTopoDia33,preTopoDia34,preTopoDia60,preTopoDia61,preTopoDia77,preTopoDia86,preTopoDia88,preTopoDia98,preTopoDia110,preTopoDia111,preTopoDia118,preTopoDia119,preTopoDia120,preTopoDia123,preTopoDia139,preTopoDia144,preTopoDia152,preTopoDia155,preTopoDia156,preTopoDia157,preTopoDia158,preTopoDia159,preTopoDia160,preTopoDia161,preTopoDia162,preTopoDia163,preTopoDia164,preTopoDia165,preTopoDia166,preTopoDia170,preTopoDia174,preTopoDia175,preTopoDia176,preTopoDia177,preTopoDia178,preTopoDia179,preTopoDia180,preTopoDia181,preTopoDia182,preTopoDia183,preTopoDia184}
This particular set of topologies contains mixed quadratic-eikonal
that will cause issues with the topology minimization if we leave them
as is.
To handle this situation we employ the routine
FCLoopReplaceQuadraticEikonalPropagators
, telling it the
loop momenta, kinematic constraints and the rules for completing the
square for the pure loop parts of the propagators
topoPre = FCLoopReplaceQuadraticEikonalPropagators[aux1[[2]], LoopMomenta -> {k1, k2},
InitialSubstitutions -> {ExpandScalarProduct[SPD[k1 - k2]] -> SPD[k1 - k2],
ExpandScalarProduct[SPD[k1 + k2]] -> SPD[k1 + k2]}, IntermediateSubstitutions -> kinematics];
Handle overdetermined
propagator bases
Single out topologies that have an overdetermined sets of
propagators
overdeterminedToposPre = Select[topoPre, FCLoopBasisOverdeterminedQ];
overdeterminedToposPre // Length
105
Generate partial fractioning rules to be applied to the original sets
of denominators
AbsoluteTiming[pfrRules = FCLoopCreatePartialFractioningRules[aux1[[1]], topoPre];]
{76.2728,Null}
Some examples of such rules are
{GpreTopoDia49(1,1,0,1,1,1,1)→metau0bGpreTopoDia49PFR23(1,2,1,1,1)−meta(u0b−1)GpreTopoDia49PFR35(1,1,2,1,1)+meta(u0b−1)u0bGpreTopoDia49PFR36(1,1,2,1,1),GpreTopoDia126(1,1,1,1,1,1)→metau0bGpreTopoDia126PFR2(1,1,2,1,1)−meta(u0b−1)GpreTopoDia126PFR5(1,1,1,2,1)+meta(u0b−1)u0bGpreTopoDia126PFR6(1,1,1,2,1)}
These rules can be converted to FORM and used for simplifying the
amplitude.
New topologies after partial fractioning
pfrToposPre = Union[First /@ pfrRules[[2]]];
aux2 = {aux1[[1]] /. Dispatch[pfrRules[[1]]], topoPre};
Some denominators from original topologies that do not require
partial fractioning . Notice that the corresponding topologies
themselves still might contain overdetermined sets of propagators
remainderDens = SelectNotFree[aux2[[1]], First /@ overdeterminedToposPre] // Union
{GpreTopoDia100(1,1,0,0,1,1,1),GpreTopoDia100(1,1,0,0,1,2,1),GpreTopoDia105(1,1,1,0,0,2,1),GpreTopoDia116(1,1,1,1,1,1,0),GpreTopoDia126(1,1,1,0,0,1),GpreTopoDia126(1,2,1,1,1,0),GpreTopoDia130(1,1,0,0,2,1),GpreTopoDia142(1,1,0,0,2,1),GpreTopoDia143(1,1,1,2,0,1),GpreTopoDia147(1,1,0,1,1,1),GpreTopoDia147(1,1,0,2,1,1),GpreTopoDia149(1,0,1,0,2,1),GpreTopoDia2(1,1,1,0,1,1,0,1),GpreTopoDia22(1,1,0,0,0,0,0,1),GpreTopoDia23(1,1,1,1,1,0,1,0),GpreTopoDia25(1,1,0,1,1,1,0,1),GpreTopoDia28(1,1,0,1,1,1,0,1),GpreTopoDia39(1,0,1,0,1,1,1,1),GpreTopoDia39(1,1,1,0,1,1,0,1),GpreTopoDia4(1,1,0,2,0,1,1,0),GpreTopoDia49(1,1,0,0,1,0,1),GpreTopoDia76(1,1,0,0,1,2,1),GpreTopoDia79(1,1,1,1,1,0,1),GpreTopoDia93(1,1,1,0,2,0,1),GpreTopoDia95(1,1,0,1,1,1,0),GpreTopoDia95(1,1,1,0,1,1,0),GpreTopoDia96(1,1,1,0,0,1,1)}
Determine which topologies related to these denominators are
overdetermined
overdeterminedTopos = FCLoopSelectTopology[remainderDens, overdeterminedToposPre];
Group the remaining denominators together with the corresponding
topologies. Remove the now irrelevant propagators from the leftover
topologies
toRemoveList = {#, First@SelectNotFree[overdeterminedTopos, #[[1]]], First /@ Position[#[[2]], 0]} & /@ remainderDens;
newNoPfrGLIs = (FCLoopRemovePropagator[#[[1]], #[[3]]] & /@ toRemoveList);
newNoPfrTopos = (FCLoopRemovePropagator[#[[2]], #[[3]]] & /@ toRemoveList);
List of all resulting topologies upon doing partial fractioning
pfrTopos = Union[pfrToposPre, First /@ newNoPfrTopos];
Replacement rule for renaming preTopo - topologies (with PFR -
suffixes from partial fractioning) to pfrTopo topologies
pfrToposNew = Table["pfrTopo" <> ToString[i], {i, 1, Length[pfrTopos]}];
pfrRenRu = Thread[Rule[pfrTopos, pfrToposNew]];
An extra rule for mapping the remaining denominators to the
corresponding topologies with removed propagators
gliRulePfr = Thread[Rule[remainderDens, newNoPfrGLIs]] /. pfrRenRu;
Final list of topologies upon doing partial fractioning
relevantPFrTopos = Union[Cases[aux2[[1]] /. Dispatch[gliRulePfr], GLI[id_, ___] :> id, Infinity]];
finalPreToposPfrRaw = SelectNotFree[Join[topoPre, pfrRules[[2]], newNoPfrTopos /. Dispatch[pfrRenRu]],relevantPFrTopos] // Union;
Identify scaleless topologies among them
scalelessPfrTopos = Select[finalPreToposPfrRaw, FCLoopScalelessQ] /. Dispatch[pfrRenRu];
Remove scaleless topologies. This gives us the final list of
topologies after partial fractioning
finalPreTopos = SelectFree[finalPreToposPfrRaw /. pfrRenRu, scalelessPfrTopos] // Union;
Check that there are no overdetermined topologies left
If[Union[FCLoopBasisOverdeterminedQ /@ finalPreTopos] =!= {False},
Print["ERROR! Not all overdetermined topologies were eliminated."];
]
Finally use FCLoopFindTopologyMappings
to find mappings
between topologies
AbsoluteTiming[mappedTopos = FCLoopFindTopologyMappings[finalPreTopos];]
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo378 and pfrTopo114. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo413 and pfrTopo114. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo76 and pfrTopo114. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo82 and pfrTopo114. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo97 and pfrTopo114. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo207 and pfrTopo154. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo320 and pfrTopo154. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo327 and pfrTopo154. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo6 and pfrTopo154. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo450 and pfrTopo19. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo80 and pfrTopo19. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo278 and pfrTopo203. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo349 and pfrTopo203. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies pfrTopo63 and pfrTopo23. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindMomentumShifts: Failed to derive the momentum shifts between topologies preTopoDia171 and pfrTopo23. This can be due to the presence of nonquadratic propagators or because shifts in external momenta are also necessary.
FCLoopFindTopologyMappings: Found 190 mapping relations
FCLoopFindTopologyMappings: Final number of independent topologies: 241
{22.4032,Null}
Allowing for shifts of external momenta would give us even more
mapping relations but this is not safe unless we explicitly know that
the amplitude is symmetric under such shifts
AbsoluteTiming[mappedToposTest = FCLoopFindTopologyMappings[finalPreTopos, Momentum -> All];]
FCLoopFindTopologyMappings: Found 205 mapping relations
FCLoopFindTopologyMappings: Final number of independent topologies: 226
{23.6277,Null}
Introducing new names for the final topologies
finTopoNames = First /@ mappedTopos[[2]];
finTopoNamesNew = Table["finTopo" <> ToString[i], {i, 1, Length[finTopoNames]}];
finRenRu = Thread[Rule[finTopoNames, finTopoNamesNew]];
Some of the final topologies might be incomplete, so we need to
account for that as well
finToposRenamed = mappedTopos[[2]] /. finRenRu;
incompleteTopos = Select[finToposRenamed, FCLoopBasisIncompleteQ];
For the basis completion we can use all available propagators
allProps = Union[Flatten[#[[2]] & /@ finToposRenamed]];
completedTopos = FCLoopBasisFindCompletion[incompleteTopos, Method -> allProps];
Generate basis completion rules
basisCompletionRules = FCLoopCreateRuleGLIToGLI[completedTopos, List /@ incompleteTopos] //Flatten;
Generating the ultimate list of topologies where all propagator sets
now form a basis
ultimateTopos = finToposRenamed /. Thread[Rule[incompleteTopos, completedTopos]];
ultimateToposNewNames = Table["topology" <> ToString[i], {i, 1, Length[finToposRenamed]}];
ultimateToposRenamingRule = Thread[Rule[First /@ ultimateTopos, ultimateToposNewNames]];
ultimateToposRenamed = ultimateTopos /. ultimateToposRenamingRule;
fcTopologies = ultimateToposRenamed;
Finally, we also need rules to eliminate scalar products
ruGLI = Map[{#[[1]], FCLoopCreateRulesToGLI[#]} &, fcTopologies // FCLoopTopologyNameToSymbol];
Names of the final topologies
sortedTopologyNames = First /@ fcTopologies;