.. _tut_report:

How to generate a report
========================

Suppose that we want to generate a custom report that includes plots and
statistics that are not included as part of the report generated by
:ref:`vp-comparefits <compare-fits>`. We may be lucky enough to find an example
runcard that produces what we need in
`validphys2/examples <https://github.com/NNPDF/nnpdf/tree/master/validphys2/examples>`_.
However, we may need to write our own own `yaml <https://yaml.org/>`_ runcard
from scratch.

Suppose we want to have histograms of the χ2 per replica for some set of
experimental datasets.

The calling of :ref:`validphys <vp-index>` actions are used as normal. The action we
are looking for is
`plot_chi2dist <https://github.com/NNPDF/nnpdf/blob/d79059975e4ef97063c6bdd9f19dfb908586e453/validphys2/src/validphys/dataplots.py#L50>`_.
Here's an example report that does what we're looking for:

.. code:: yaml

  meta:
    title: Distribution plots per replica across experiments
    author: Shayan Iranipour
    keywords: [chi2, replica, distribution, DISonly]

  fit: NNPDF31_nnlo_as_0118_DISonly

  pdf:
    from_: "fit"

  experiments:
    from_: "fit"

  theoryid: 53

  use_cuts: "fromfit"

  template_text: |
    # Histograms of χ2
    ## DIS only distributions
    {@experiments::experiment plot_chi2dist@}

  actions_:
    - report(main=True)

The ``report(main=True)`` command is what generates the report. We can customize
the formatting of the report using
`markdown <https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet>`_
syntax. Note for example that ``# Histograms of χ2`` gives an appropriate title
to the section where we will find our plot.

If the ``template_text`` section of the runcard becomes large and unwieldy, it may
be preferable to put the information from this section in a separate file. In
such cases one can create a ``markdown`` template file, usually called ``template.md``
such as

.. code:: md

  # Histograms of χ2
  ## DIS only distributions
  {@experiments::experiment plot_chi2dist@}

and change the `template_text` section of the runcard to the following

.. code:: yaml

  template: template.md

where this assumes that ``template.md`` is in the same folder as that in which you
execute the ``validphys`` command.

The ``meta`` field is important for retrieving the report once it has been
uploaded to the `validphys server <https://vp.nnpdf.science/>`_. ``title`` and
``author`` are fields that appear when browsing through reports while the
``keywords`` allow quick retrieval of the report by the search functionality of
the server. Setting appropriate keywords is especially important when working on
a big project, within which it is likely that many reports will be produced. In
such cases a ``keyword`` should be chosen for the project and set in each uploaded
report.