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

Use tempdir during execution #172

Merged
merged 198 commits into from
Jan 9, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
198 commits
Select commit Hold shift + click to select a range
b38776d
Fix struct.detached
andreab1997 Nov 8, 2022
93d86f7
Remove useless loops and start fixing the tests
andreab1997 Nov 10, 2022
b3b216e
Fix tests
andreab1997 Nov 10, 2022
e0cd03b
First implementation of metadata file
andreab1997 Nov 10, 2022
3d13809
Fix write_text
andreab1997 Nov 14, 2022
8b567cc
Add method to access metadata
andreab1997 Nov 14, 2022
1cc6b59
Add metadata to detached
andreab1997 Nov 14, 2022
9121212
Add metadata argument
andreab1997 Nov 14, 2022
a12b4df
Fix names of objects inside metadata dict
andreab1997 Nov 14, 2022
ec1ffa4
Drop if in detached
andreab1997 Nov 14, 2022
0d1ee0d
Add rotations key to metadata and implement function to update metadata
andreab1997 Nov 14, 2022
20fc9e5
Update metadata after manipulation
andreab1997 Nov 14, 2022
5af40cb
Fix stream.len
andreab1997 Nov 14, 2022
68bcd48
Fix stream.tell()
andreab1997 Nov 14, 2022
77ed2a2
Add docs
andreab1997 Nov 15, 2022
c605672
Cast to numpy array
andreab1997 Nov 15, 2022
4c5acfb
Move casting to np array in detached
andreab1997 Nov 15, 2022
8275476
First draft of solution for metadata file
andreab1997 Nov 15, 2022
0a2b5a7
Use __post_init__ even when rotations is called
andreab1997 Nov 15, 2022
0c65799
Fix test_output and remove dump of update_metadata
andreab1997 Nov 16, 2022
d3a0cea
Update pids after to_evol
andreab1997 Nov 16, 2022
693e00a
Fix test_output_struct
andreab1997 Nov 16, 2022
83bb5bb
Move update_metadata after
andreab1997 Nov 16, 2022
0022bec
Store matrices for pids and fix test
andreab1997 Nov 16, 2022
6d15a17
Fix test_runner
andreab1997 Nov 16, 2022
b251b8c
Fix ekobox and tests
andreab1997 Nov 16, 2022
33a9653
Explicitly cast pids to list in op card generation
andreab1997 Nov 16, 2022
e163006
Fix test_apply
andreab1997 Nov 16, 2022
702cc7a
Create operator_card class
andreab1997 Nov 29, 2022
984d982
Fix benchmark of ekobox
andreab1997 Nov 29, 2022
354ffb5
Update metadata file after reshape
andreab1997 Nov 29, 2022
6a0ff30
Update src/eko/output/struct.py
andreab1997 Dec 1, 2022
bff4170
Add rich dependency to box
alecandido Dec 3, 2022
985f0cc
Reorganize eko CLI
alecandido Dec 3, 2022
808fae0
Simplify runcards functions
alecandido Dec 3, 2022
dba6d74
Complete runcards generating subcommand
alecandido Dec 3, 2022
7ef3608
Fix runcards related tests
alecandido Dec 3, 2022
027e4da
Fix type compatibility with py3.8
alecandido Dec 3, 2022
c82dcfc
Implement eko run command
alecandido Dec 3, 2022
f5f3d7d
Transition Q2 to mu2 in new struct
alecandido Dec 3, 2022
47933c6
Add inspect subcommand
alecandido Dec 3, 2022
f629312
Restore Q2grid in operator card, scope field/s
alecandido Dec 3, 2022
6722081
Fix mu2grid in tests
alecandido Dec 4, 2022
b6398ff
Fix mu2grid in legacy dump
alecandido Dec 4, 2022
7c6ba3c
Update CLI minimal test
alecandido Dec 4, 2022
720e3ca
Init CLI docs
alecandido Dec 5, 2022
a298a19
Add converter to CLI
alecandido Dec 5, 2022
3e9c675
Add convert subcommand to docs
alecandido Dec 5, 2022
a01a52d
Rearrange exported content
alecandido Dec 5, 2022
28808b8
Tiny improvements to legacy loader
alecandido Dec 5, 2022
2ebfd84
Import dedidcated errors
alecandido Dec 5, 2022
dfbbe43
Adjust docstrings layout
alecandido Dec 5, 2022
3f0dbda
Migrate get/set items accessors
alecandido Dec 5, 2022
e756df0
Adapt existing file accessors to plain dir, drop extract
alecandido Dec 5, 2022
e99e6f9
Rename output to io
alecandido Dec 5, 2022
625c7c0
Distribute content of struct
alecandido Dec 5, 2022
d12ca64
Sketch new metadata and update
alecandido Dec 5, 2022
9973831
Rework massively the EKO structure
alecandido Dec 7, 2022
32d7b4b
Drop interpolator calculation from EKO structure
alecandido Dec 7, 2022
5a865d1
Rearrange runner and compatibility in new subpackages
alecandido Dec 8, 2022
ab620b5
Add theory card, start moving compatibility
alecandido Dec 8, 2022
2004c2c
Remove old style compatibility
alecandido Dec 8, 2022
9c89181
Fix compatibility in runner and conftest
alecandido Dec 8, 2022
61541f9
Make the tests run again
alecandido Dec 8, 2022
4b17c1e
Reorganize eko test folder
alecandido Dec 8, 2022
7820dbd
Make tests a package, to rely on the package scope
alecandido Dec 8, 2022
8d52774
Fix runcards update
alecandido Dec 9, 2022
a83a55a
Introduce devtools in dev deps
alecandido Dec 9, 2022
48c7f3f
Introduce DictLike autoloading
alecandido Dec 9, 2022
49cfdb8
Replace Couplings.from_dict
alecandido Dec 9, 2022
1d14899
Scope types in io
alecandido Dec 9, 2022
9612bbd
Fix nf interpretation
alecandido Dec 9, 2022
d734483
Drop ThresholdAtlas.from_dict
alecandido Dec 9, 2022
1a6a407
Improve docstrings
alecandido Dec 9, 2022
96907d5
Kill OperatorGrid.from_dict
alecandido Dec 9, 2022
f3d6b7b
Improve DictLike loading, allow Q2grid compatibility, fix eko product…
alecandido Dec 10, 2022
c5b5511
Provide type-safe aliases for open
alecandido Dec 10, 2022
73a58aa
Provide context manager also from builder
alecandido Dec 10, 2022
3900eac
Drop tests on thresholds from_dict
alecandido Dec 10, 2022
21a5f03
Provide example runcards
alecandido Dec 10, 2022
44c55b0
Replace old output factory
alecandido Dec 10, 2022
18b6a55
Adapt default cards
alecandido Dec 10, 2022
301eecc
Fix OperatorGrid tests
alecandido Dec 10, 2022
671bd56
Fix legacy runner tests
alecandido Dec 11, 2022
c88efa5
Fix evolution operator tests
alecandido Dec 11, 2022
6501787
Improve file errors for output creatrion
alecandido Dec 11, 2022
4816ed2
Check file name validity on creation, not its existence
alecandido Dec 11, 2022
1c7d3af
Produce a proper in conftest
alecandido Dec 11, 2022
5e08780
Fix nan check, make cards accessor coherent
alecandido Dec 11, 2022
b39dd09
Fix EKO properties test
alecandido Dec 11, 2022
05ee72c
Fix regression in masses definition
alecandido Dec 11, 2022
26cd461
Fix deepcopy and loading
alecandido Dec 11, 2022
8061a01
Fix all existing struct tests
alecandido Dec 11, 2022
3741cea
Fix ome tests
alecandido Dec 12, 2022
0dcd6cb
Turn all errors in failures
alecandido Dec 12, 2022
71a073d
Purge old card generators, fix cards generation tests
alecandido Dec 13, 2022
95199e9
Fix ekobox product test
alecandido Dec 13, 2022
0bc72f5
Fix apply pdf and its tests
alecandido Dec 13, 2022
715ec14
Never return open EKOs
alecandido Dec 13, 2022
8e912f7
Fix apply pdf and its tests, again
alecandido Dec 13, 2022
70a5c64
Fix evolve pdfs tests
alecandido Dec 13, 2022
7267a8e
Fix solve test
alecandido Dec 13, 2022
aaa49e9
Fix manipulate tests
alecandido Dec 13, 2022
969fcdf
Fix deepcopy regression
alecandido Dec 13, 2022
30a4385
Rename append constructor to edit
alecandido Dec 13, 2022
9314c6d
Update CLI
alecandido Dec 14, 2022
052b4e6
Add existence requirement to suitable CLI path arguments
alecandido Dec 14, 2022
c962701
Make CLI runner compatible with new runcards
alecandido Dec 14, 2022
aacbb4b
Replace fac_to_ren with xif
alecandido Dec 14, 2022
3cf801d
Address review first batch of comments, mostly runner docs
alecandido Dec 14, 2022
4430ef5
Address some comments from second batch of the review
alecandido Dec 14, 2022
4ac3dee
Fix xif2 in evolution operator
alecandido Dec 14, 2022
0b1446e
Fix xif2 in msbar masses
alecandido Dec 14, 2022
d820925
Propagate xif change to tests
alecandido Dec 14, 2022
61b3dde
Use RawCard in ekobox as well
alecandido Dec 14, 2022
bebbda8
Propagate xif change to msbar masses tests
alecandido Dec 14, 2022
a4c2d96
Upgrade legacy tar loader
alecandido Dec 15, 2022
6e81a7c
Add example legacy tar operator
alecandido Dec 15, 2022
80500e3
Provide minimal legacy loader test
alecandido Dec 15, 2022
cdb1045
Fix CLI compatibility with old and converted output
alecandido Dec 15, 2022
63112b5
Fix a few pylint errors
alecandido Dec 15, 2022
66bcbe4
Solve Pylint errors
alecandido Dec 16, 2022
41b3441
Change operator name encoding
alecandido Dec 16, 2022
d052f36
Nest with statements
alecandido Dec 16, 2022
b79aad5
Move cards initialization in function call
alecandido Dec 16, 2022
3370f0d
Remove fail-fast
alecandido Dec 16, 2022
42b57b7
Fix some isolated benchmarks
alecandido Dec 16, 2022
f8ba286
Second batch of isolated benchmarks fixes
alecandido Dec 16, 2022
0a86912
Expose contraction strings as constants in manipulate module
alecandido Dec 16, 2022
2211c3f
Convert the last incorrect xif to xif2
alecandido Dec 16, 2022
21196d4
Save open status for EKO
alecandido Dec 16, 2022
fbf9fe3
Export neeeded conftest to benchmark package
alecandido Dec 16, 2022
07319de
Prevent operations according to operator permissions
alecandido Dec 17, 2022
fbfd4fd
Rename Lambert grid generator
alecandido Dec 17, 2022
415cda3
Solve readability issues
alecandido Dec 17, 2022
65536a3
Poetry update
alecandido Dec 17, 2022
7ea702a
Add einsum optimization again
alecandido Dec 17, 2022
45231a6
Fix subclass check in weird NumPy hierarchy on py3.8
alecandido Dec 17, 2022
9c7fe1a
Update msbar masses call
alecandido Dec 19, 2022
0dfb4c2
Drop couplings from_dict constructor
alecandido Dec 19, 2022
c657cf7
Start fixing msbar masses unit tests
alecandido Dec 19, 2022
beffaef
Fix compute msbar function call in legacy runner
alecandido Dec 19, 2022
714a156
Fix update from old th card with new locations
felixhekhorn Dec 19, 2022
be5b9f9
Fix scale to be squared
alecandido Dec 19, 2022
a46c0a2
Fix MSbar masses tests
alecandido Dec 20, 2022
6cf5db3
Fix accordingly also couplings tests
alecandido Dec 20, 2022
d980b0d
Update strong couplings benchmark
alecandido Dec 21, 2022
fd46030
Update msbar masses benchmark
alecandido Dec 21, 2022
34874b8
Add some docstrings
felixhekhorn Dec 21, 2022
b27e2a8
Fix msbar evolution benchmark
alecandido Dec 21, 2022
6de1f6b
Convert APFEL evol mode to upper-case, to match APFEL recognized values
alecandido Dec 21, 2022
86ef24f
Replace ref coupling value query
alecandido Dec 21, 2022
0612926
Replace assumed squared scales with correct linear ones
alecandido Dec 21, 2022
177c7df
Fix QCD perturbative order in APFEL call
alecandido Dec 22, 2022
69137bc
Convert new io data type to plain list
alecandido Dec 22, 2022
e9f1a87
Add temporary path to store operators generated to benchmark evolution
alecandido Dec 22, 2022
8cd8a30
Apply suggestions from code review
alecandido Dec 22, 2022
678ac33
Fix Sphinx warnings
felixhekhorn Dec 22, 2022
7c4c33e
Update src/eko/couplings.py
alecandido Dec 22, 2022
b5aeb33
Update tests/eko/test_msbar_masses.py
alecandido Dec 22, 2022
c24e484
Update src/eko/msbar_masses.py
alecandido Dec 22, 2022
14fb44a
Fix ekomark runner
felixhekhorn Dec 22, 2022
d199660
Fix wrong docstring about eko version
alecandido Dec 22, 2022
763598e
Update benchmarks/ekobox/benchmark_evol_pdf.py
alecandido Dec 22, 2022
6321b6e
Rename assertions in couplings constructor
alecandido Dec 22, 2022
5b58f1b
Update src/eko/interpolation.py
alecandido Dec 22, 2022
4bcbef5
Update src/eko/interpolation.py
alecandido Dec 22, 2022
677268b
Fix apfel+pegasus
felixhekhorn Dec 22, 2022
ecf5d3c
Update benchmarks/ekobox/benchmark_evol_pdf.py
alecandido Dec 22, 2022
d637469
Update src/eko/interpolation.py
alecandido Dec 22, 2022
c3e832e
Update src/eko/interpolation.py
alecandido Dec 22, 2022
60f029d
Start fixing tutorials
felixhekhorn Dec 22, 2022
7583496
Check metadata after reshaping operator, see #162
alecandido Dec 22, 2022
9f0c6cf
Import the content of #154
alecandido Dec 22, 2022
8c77c67
Update src/eko/io/struct.py
alecandido Dec 22, 2022
51e29ed
Catch legacy warning
felixhekhorn Dec 23, 2022
8b4bf00
Update output tutorial
felixhekhorn Dec 23, 2022
7a4d172
Update pdf tutorial
felixhekhorn Dec 23, 2022
d2df011
Make as tutorial running
felixhekhorn Dec 23, 2022
1d0c59a
Refactor couplings tests
niclaurenti Dec 27, 2022
2af1531
Fix msbar compute docs
felixhekhorn Jan 5, 2023
e888119
Rename max number of flavors in strong coupling running
alecandido Jan 5, 2023
6d81d9b
Rename num_flavs_max_as to max_num_flavs
felixhekhorn Jan 5, 2023
d92ce25
Merge branch 'tempdir' of github.com:N3PDF/eko into tempdir
felixhekhorn Jan 5, 2023
2aa8d78
Update couplings constructor
felixhekhorn Jan 5, 2023
3659de7
Make precision depend on the order
niclaurenti Jan 5, 2023
8902a3a
Increase precision for order=(1,2)
niclaurenti Jan 5, 2023
5c3c792
Remove default for max_num_flavs
felixhekhorn Jan 5, 2023
97a8526
Merge branch 'tempdir' into refactor-coupling-tests
niclaurenti Jan 5, 2023
4a4c565
Revert alphaem ref scale
felixhekhorn Jan 5, 2023
a5187d8
Merge pull request #187 from NNPDF/refactor-coupling-tests
felixhekhorn Jan 5, 2023
13fb787
Attempt fix benchmarks
felixhekhorn Jan 5, 2023
7e78733
Add test_couplings_mod_ev
felixhekhorn Jan 5, 2023
3c7eef7
Fix dglap tutorial
felixhekhorn Jan 5, 2023
e41296f
Fix alphas tutorial
felixhekhorn Jan 5, 2023
c002aea
Remove shadowing in Couplings init
alecandido Jan 5, 2023
8f90751
Remove default for reference number of flavors
alecandido Jan 5, 2023
d05ca84
Fix struct exceptions
felixhekhorn Jan 6, 2023
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
1 change: 1 addition & 0 deletions .github/workflows/unittests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ jobs:
strategy:
matrix:
python-version: ["3.8", "3.9", "3.10"]
fail-fast: false

uses: N3PDF/workflows/.github/workflows/python-poetry-tests.yml@v2
with:
Expand Down
2 changes: 1 addition & 1 deletion benchmarks/HERA20_bench.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
}

# LHAPDF x-range is smaller
base_op = {"interpolation_xgrid": interpolation.make_lambert_grid(50, 1.0e-6)}
base_op = {"interpolation_xgrid": interpolation.lambertgrid(50, 1.0e-6)}


class BenchmarkHERA20(Runner):
Expand Down
31 changes: 31 additions & 0 deletions benchmarks/conftest.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import numpy as np
import pytest

from eko import interpolation
from eko.io.runcards import TheoryCard
from ekobox import cards


@pytest.fixture
def theory_card():
return cards.example.theory()


@pytest.fixture()
def theory_ffns(theory_card):
def set_(flavors: int) -> TheoryCard:
i = flavors - 3
for q in "cbt"[i:]:
setattr(theory_card.matching, q, np.inf)
return theory_card

return set_


@pytest.fixture
def operator_card():
card = cards.example.operator()
card.rotations.xgrid = interpolation.XGrid([0.1, 0.3, 0.5, 1.0])
card.configs.interpolation_polynomial_degree = 2

return card
117 changes: 40 additions & 77 deletions benchmarks/eko/benchmark_evol_to_unity.py
Original file line number Diff line number Diff line change
@@ -1,94 +1,57 @@
import pathlib
from math import nan

import numpy as np
import pytest

from eko import basis_rotation as br
from eko import compatibility
from eko.couplings import Couplings
from eko.evolution_operator import Operator
from eko.evolution_operator.grid import OperatorGrid
from eko.interpolation import InterpolatorDispatcher, XGrid
from eko.thresholds import ThresholdsAtlas
from eko.interpolation import XGrid
from eko.io import types
from eko.io.runcards import OperatorCard, TheoryCard
from eko.runner.legacy import Runner

# from eko.matching_conditions.operator_matrix_element import OperatorMatrixElement


@pytest.mark.isolated
class BenchmarkBackwardForward:
# setup objs
theory_card = {
"alphas": 0.35,
"alphaqed": 0.007496,
"PTO": 0,
"QED": 0,
"ModEv": "EXA",
"fact_to_ren_scale_ratio": 1.0,
"Qref": np.sqrt(2),
"nfref": None,
"Q0": np.sqrt(2),
"nf0": 4,
"IC": 1,
"IB": 1,
"mc": 1.0,
"mb": 4.75,
"mt": 173.0,
"kcThr": 1.0,
"kbThr": 1.0,
"ktThr": 1.0,
"MaxNfPdf": 6,
"MaxNfAs": 6,
"HQ": "POLE",
"ModSV": None,
}
operators_card = {
"Q2grid": [10],
# here you need a very dense grid
"xgrid": np.linspace(1e-1, 1, 30),
# "xgrid": make_grid(30,30, x_min=1e-3),
"configs": {
"interpolation_polynomial_degree": 1,
"interpolation_is_log": True,
"ev_op_max_order": (2, 0),
"ev_op_iterations": 1,
"backward_inversion": "exact",
"n_integration_cores": 1,
},
"debug": {
"skip_singlet": False,
"skip_non_singlet": False,
},
}
new_theory, new_operators = compatibility.update(theory_card, operators_card)
g = OperatorGrid.from_dict(
new_theory,
new_operators,
ThresholdsAtlas.from_dict(new_theory),
Couplings.from_dict(new_theory),
InterpolatorDispatcher(
XGrid(
new_operators["xgrid"],
log=new_operators["configs"]["interpolation_is_log"],
),
new_operators["configs"]["interpolation_polynomial_degree"],
),
def update_cards(theory: TheoryCard, operator: OperatorCard):
theory.couplings = types.CouplingsRef(
alphas=types.FloatRef(value=0.35, scale=float(np.sqrt(2))),
alphaem=types.FloatRef(value=0.007496, scale=nan),
max_num_flavs=6,
num_flavs_ref=None,
)
theory.num_flavs_init = 4
theory.intrinsic_flavors = [4, 5]
theory.quark_masses.c.value = 1.0
theory.quark_masses.b.value = 4.75
theory.quark_masses.t.value = 173.0
operator.mu0 = float(np.sqrt(2))
operator.mu2grid = [10]
operator.rotations.xgrid = XGrid(np.linspace(1e-1, 1, 30))
operator.configs.interpolation_polynomial_degree = 1
operator.configs.ev_op_max_order = (2, 0)
operator.configs.ev_op_iterations = 1
operator.configs.inversion_method = types.InversionMethod.EXACT
operator.configs.n_integration_cores = 1


@pytest.mark.isolated
class BenchmarkBackwardForward:
def test_operator_grid(
# test that eko_forward @ eko_backward gives ID matrix or zeros
self,
theory_card: TheoryCard,
operator_card: OperatorCard,
tmp_path: pathlib.Path,
):
g = OperatorGrid.from_dict(
self.new_theory,
self.new_operators,
ThresholdsAtlas.from_dict(self.new_theory),
Couplings.from_dict(self.new_theory),
InterpolatorDispatcher(
XGrid(
self.new_operators["xgrid"],
log=self.new_operators["configs"]["interpolation_is_log"],
),
self.new_operators["configs"]["interpolation_polynomial_degree"],
),
)
"""Test that eko_forward @ eko_backward gives ID matrix or zeros."""
update_cards(theory_card, operator_card)
g = Runner(
theory_card=theory_card,
operators_card=operator_card,
path=tmp_path / "eko.tar",
).op_grid

q20 = 30
q21 = 50
nf = 4
Expand Down
Loading