Pushing the boundaries of higher-loop amplitude calculations in quantum field theory is no easy task, and no recipe works for all. This means that one needs try different approaches, investigate, and iterate. To this end, one can’t use a prepackaged monolithic solution—one needs a library: alibrary.
Alibrary is a Mathematica library that provides functions to generate Feynman diagrams, insert Feynman rules, sum over tensor traces, construct IBP families, convert amplitudes to IBP notation, etc, etc. It acts as a central hub to call into QGRAF, GraphViz, FORM (with color.h), Feynson, LiteRed and FIRE, Kira, pySecDec, etc, all while allowing you to develop interactively (in a read-eval-print loop or an interactive notebook), inspect and modify intermediate results, and generally progress towards building a solution to your problem one step at a time.
Alibrary tries to be light on abstraction. As much as possible it works with data in the standard Mathematica notation, so that each of its functions could be useful separately from the rest, and its data could be operated on using normal Mathematica commands. In other words: alibrary is a library, not a framework.
Alibrary is meant to be extended, modified, or simply learned from. Ultimately you are doing the calculation, alibrary is just one of the pieces of code you might be using. Its goal is not to be a big deal.
Finally, alibrary aspires to be a learning resource, and have all of its internals obvious and documented, so that one could read and understand it without too much effort—this goal is a work in progress; sorry.
The documentation currently lives at magv.github.io/alibrary and consists of the following main annotated source files:
And also the following auxiliary source files:
Finally, the following files remain undocumented:
The documentation is not really complete, but the plan is to gradually improve it.
Additionally, the author gave a talk at CAPP 2021 about Calculating loop amplitudes on a computer: it describes how to build a library like alibrary. The code accompanying the talk is in essence a simplified version of this library, so the presentation is an accurate description of the main ideas and intended usage.
As an example of the common usage, please take a look at:
Download the source code, put it into a directory somewhere, and import it into your Mathematica session like this:
Get["/path/to/alibrary.m"];
Alternatively, to only import generic Mathematica functions (those that are not related to loop amplitudes), use this:
Get["/path/to/utils.m"];