2025-05-31 10:11.36: New job: test ahrefs/ocannl https://github.com/ahrefs/ocannl.git#refs/heads/master (d49bc965f5fe7c717cd2c17c3b7f5b0a883d11fb) (linux-x86_64:fedora-41-5.3_opam-2.3)
Base: ocaml/opam:fedora-41-ocaml-5.3@sha256:abc80c782e7acbd09ffd49defcb056c2fc402593e57bcb537add09330e2c3992
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ahrefs/ocannl.git" -b "master" && cd "ocannl" && git reset --hard d49bc965
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:fedora-41-ocaml-5.3@sha256:abc80c782e7acbd09ffd49defcb056c2fc402593e57bcb537add09330e2c3992
# fedora-41-5.3_opam-2.3
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
WORKDIR /src
RUN sudo dnf install -y findutils
RUN sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam
RUN opam init --reinit -ni
RUN uname -rs && opam exec -- ocaml -version && opam --version
WORKDIR /src
RUN sudo chown opam /src
RUN cd ~/opam-repository && (git cat-file -e 5d2fb3923b40a5570824690009441d947b823e8f || git fetch origin master) && git reset -q --hard 5d2fb3923b40a5570824690009441d947b823e8f && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 neural_nets_lib.opam arrayjit.opam ./
RUN opam pin add -yn neural_nets_lib.dev './' && \
opam pin add -yn arrayjit.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="angstrom.0.16.1 astring.0.8.5 backoff.0.1.1 base.v0.17.2 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigarray-compat.1.1.0 bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-libffi.2.0.0 conf-pkg-config.4 cppo.1.8.0 csexp.1.5.2 ctypes.0.23.0 ctypes-foreign.0.23.0 dune.3.19.0 dune-configurator.3.19.0 fieldslib.v0.17.0 fmt.0.10.0 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.8.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.5-1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 parsexp.v0.17.0 pprint.20230830 ppx_assert.v0.17.0 ppx_base.v0.17.0 ppx_cold.v0.17.0 ppx_compare.v0.17.0 ppx_derivers.1.2.1 ppx_deriving.6.0.3 ppx_enumerate.v0.17.0 ppx_expect.v0.17.2 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.0 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.0 ppx_minidebug.2.2.0 ppx_optcomp.v0.17.0 ppx_sexp_conv.v0.17.0 ppx_string.v0.17.0 ppx_variants_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 printbox.0.12 printbox-ext-plot.0.12 printbox-html.0.12 printbox-md.0.12 printbox-text.0.12 ptime.1.2.0 re.1.12.0 result.1.5 saturn_lockfree.0.5.0 seq.base sexplib.v0.17.0 sexplib0.v0.17.0 stdio.v0.17.0 stdlib-shims.0.3.0 thread-local-storage.0.2 time_now.v0.17.0 topkg.1.0.8 tyxml.4.6.0 uucp.16.0.0 uutf.1.0.4 variantslib.v0.17.0"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y neural_nets_lib.dev arrayjit.dev $DEPS
RUN opam install $DEPS
COPY --chown=1000:1000 . /src
RUN opam exec -- dune build @install @check @runtest && rm -rf _build
END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK
2025-05-31 10:11.36: Using cache hint "ahrefs/ocannl-ocaml/opam:fedora-41-ocaml-5.3@sha256:abc80c782e7acbd09ffd49defcb056c2fc402593e57bcb537add09330e2c3992-fedora-41-5.3_opam-2.3-835eddc584e7df6f658cedd74acb2691"
2025-05-31 10:11.36: Using OBuilder spec:
((from ocaml/opam:fedora-41-ocaml-5.3@sha256:abc80c782e7acbd09ffd49defcb056c2fc402593e57bcb537add09330e2c3992)
(comment fedora-41-5.3_opam-2.3)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(workdir /src)
(run (network host)
(shell "sudo dnf install -y findutils"))
(run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
(run (shell "opam init --reinit -ni"))
(run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
(workdir /src)
(run (shell "sudo chown opam /src"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 5d2fb3923b40a5570824690009441d947b823e8f || git fetch origin master) && git reset -q --hard 5d2fb3923b40a5570824690009441d947b823e8f && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src neural_nets_lib.opam arrayjit.opam) (dst ./))
(run (network host)
(shell "opam pin add -yn neural_nets_lib.dev './' && \
\nopam pin add -yn arrayjit.dev './'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "angstrom.0.16.1 astring.0.8.5 backoff.0.1.1 base.v0.17.2 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigarray-compat.1.1.0 bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-libffi.2.0.0 conf-pkg-config.4 cppo.1.8.0 csexp.1.5.2 ctypes.0.23.0 ctypes-foreign.0.23.0 dune.3.19.0 dune-configurator.3.19.0 fieldslib.v0.17.0 fmt.0.10.0 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.8.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.5-1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 parsexp.v0.17.0 pprint.20230830 ppx_assert.v0.17.0 ppx_base.v0.17.0 ppx_cold.v0.17.0 ppx_compare.v0.17.0 ppx_derivers.1.2.1 ppx_deriving.6.0.3 ppx_enumerate.v0.17.0 ppx_expect.v0.17.2 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.0 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.0 ppx_minidebug.2.2.0 ppx_optcomp.v0.17.0 ppx_sexp_conv.v0.17.0 ppx_string.v0.17.0 ppx_variants_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 printbox.0.12 printbox-ext-plot.0.12 printbox-html.0.12 printbox-md.0.12 printbox-text.0.12 ptime.1.2.0 re.1.12.0 result.1.5 saturn_lockfree.0.5.0 seq.base sexplib.v0.17.0 sexplib0.v0.17.0 stdio.v0.17.0 stdlib-shims.0.3.0 thread-local-storage.0.2 time_now.v0.17.0 topkg.1.0.8 tyxml.4.6.0 uucp.16.0.0 uutf.1.0.4 variantslib.v0.17.0")
(env CI true)
(env OCAMLCI true)
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y neural_nets_lib.dev arrayjit.dev $DEPS"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
(copy (src .) (dst /src))
(run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
)
2025-05-31 10:11.36: Waiting for resource in pool OCluster
2025-05-31 10:11.36: Waiting for worker…
2025-05-31 10:11.36: Got resource from pool OCluster
Building on x86-bm-c5.sw.ocaml.org
HEAD is now at 367ff3b7 Claude's third pass at adding BF16, FP8: proper conversions in pure C Claude decided to provide full definitions to inline rather than just headers for jitted C sources, for performance.
HEAD is now at d49bc965 Fixes #204 and #319: fix emulation of FP8, BF16 via single prec floats in Pure_C_config numerics
(from ocaml/opam:fedora-41-ocaml-5.3@sha256:abc80c782e7acbd09ffd49defcb056c2fc402593e57bcb537add09330e2c3992)
2025-05-31 10:11.37 ---> using "da0437edefc3074e740b2380711421a58ad6af000252c27345a9c063faf0cc10" from cache
/: (comment fedora-41-5.3_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (workdir /src)
/src: (run (network host)
(shell "sudo dnf install -y findutils"))
Updating and loading repositories:
Fedora 41 openh264 (From Cisco) - x86_ 100% | 13.6 KiB/s | 989.0 B | 00m00s
Fedora 41 - x86_64 100% | 293.5 KiB/s | 25.8 KiB | 00m00s
Fedora 41 - x86_64 - Updates 100% | 238.4 KiB/s | 23.1 KiB | 00m00s
Fedora 41 - x86_64 - Updates 100% | 10.7 MiB/s | 9.9 MiB | 00m01s
Repositories loaded.
Package "findutils-1:4.10.0-4.fc41.x86_64" is already installed.
Nothing to do.
2025-05-31 10:11.37 ---> using "cda621b93ea4e5bc7b2f3a44f5472568fa9069c819fc4f9ee4dba7021db6599e" from cache
/src: (run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-05-31 10:11.37 ---> using "00fdc0066ab5f68afc204c28620b3ce62c27dda0ac3863d3d421d30b1e5a7121" from cache
/src: (run (shell "opam init --reinit -ni"))
Configuring from /home/opam/.opamrc and then from built-in defaults.
Checking for available remotes: rsync and local, git.
- you won't be able to use mercurial repositories unless you install the hg command on your system.
- you won't be able to use darcs repositories unless you install the darcs command on your system.
Continue? [y/n] y
This development version of opam requires an update to the layout of /home/opam/.opam from version 2.0 to version 2.2, which can't be reverted.
You may want to back it up before going further.
[NOTE] The 'jobs' option was reset, its value was 255 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
opam option jobs=255 --global
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2025-05-31 10:11.37 ---> using "e4c6ec45de15317b19a5e44e28bcb7589e585c58ff662e7c78b23377170afeeb" from cache
/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.15.0-134-generic
The OCaml toplevel, version 5.3.0
2.3.0
2025-05-31 10:11.37 ---> using "21404f6f0f15670f1371a8655b67d83eca7d3eb1d65bed293fe562e27fca1e04" from cache
/src: (workdir /src)
/src: (run (shell "sudo chown opam /src"))
2025-05-31 10:11.37 ---> using "e6db08cef467f22bc6d82a42d4d4c7d0ba62091bad93cb74af70b44a2974850b" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 5d2fb3923b40a5570824690009441d947b823e8f || git fetch origin master) && git reset -q --hard 5d2fb3923b40a5570824690009441d947b823e8f && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
35eb2f107a..5d2fb3923b master -> origin/master
5d2fb3923b Merge pull request #27963 from mseri/base-ppxlib
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from git+file:///home/opam/opam-repository
Everything as up-to-date as possible (run with --verbose to show unavailable upgrades).
However, you may "opam upgrade" these packages explicitly, which will ask permission to downgrade or uninstall the conflicting packages.
Nothing to do.
# To update the current shell environment, run: eval $(opam env)
2025-05-31 10:11.37 ---> using "e4fd8e4a0f2d444f43673e87312c198fcdd61d7b861d2ccebedbe8d8dedfa786" from cache
/src: (copy (src neural_nets_lib.opam arrayjit.opam) (dst ./))
2025-05-31 10:11.37 ---> using "fc05b1093c03a885f9bd20c2ff51632cc6f3c9fdc954a5aae14d623f661c2b45" from cache
/src: (run (network host)
(shell "opam pin add -yn neural_nets_lib.dev './' && \
\nopam pin add -yn arrayjit.dev './'"))
[neural_nets_lib.dev] synchronised (file:///src)
neural_nets_lib is now pinned to file:///src (version dev)
[arrayjit.dev] synchronised (file:///src)
arrayjit is now pinned to file:///src (version dev)
2025-05-31 10:11.37 ---> using "5110ca171b1d4f993212fa0abdef02b32229bad892d24d00364d4a4a4bd62683" from cache
/src: (run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
2025-05-31 10:11.37 ---> using "790c5392935d91ae8dcbed31534648707c169cff25e33653293db6706c80b917" from cache
/src: (env DEPS "angstrom.0.16.1 astring.0.8.5 backoff.0.1.1 base.v0.17.2 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigarray-compat.1.1.0 bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-libffi.2.0.0 conf-pkg-config.4 cppo.1.8.0 csexp.1.5.2 ctypes.0.23.0 ctypes-foreign.0.23.0 dune.3.19.0 dune-configurator.3.19.0 fieldslib.v0.17.0 fmt.0.10.0 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.8.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.5-1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 parsexp.v0.17.0 pprint.20230830 ppx_assert.v0.17.0 ppx_base.v0.17.0 ppx_cold.v0.17.0 ppx_compare.v0.17.0 ppx_derivers.1.2.1 ppx_deriving.6.0.3 ppx_enumerate.v0.17.0 ppx_expect.v0.17.2 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.0 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.0 ppx_minidebug.2.2.0 ppx_optcomp.v0.17.0 ppx_sexp_conv.v0.17.0 ppx_string.v0.17.0 ppx_variants_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 printbox.0.12 printbox-ext-plot.0.12 printbox-html.0.12 printbox-md.0.12 printbox-text.0.12 ptime.1.2.0 re.1.12.0 result.1.5 saturn_lockfree.0.5.0 seq.base sexplib.v0.17.0 sexplib0.v0.17.0 stdio.v0.17.0 stdlib-shims.0.3.0 thread-local-storage.0.2 time_now.v0.17.0 topkg.1.0.8 tyxml.4.6.0 uucp.16.0.0 uutf.1.0.4 variantslib.v0.17.0")
/src: (env CI true)
/src: (env OCAMLCI true)
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y neural_nets_lib.dev arrayjit.dev $DEPS"))
+ /usr/bin/sudo "yum" "makecache"
- Updating and loading repositories:
- Repositories loaded.
- Metadata cache created.
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[arrayjit.dev] synchronised (file:///src)
[neural_nets_lib.dev] synchronised (file:///src)
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
The following system packages will first need to be installed:
libffi-devel
<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>
+ /usr/bin/sudo "yum" "install" "-y" "libffi-devel"
- Updating and loading repositories:
- Repositories loaded.
- Package Arch Version Repository Size
- Installing:
- libffi-devel x86_64 3.4.6-3.fc41 fedora 33.1 KiB
-
- Transaction Summary:
- Installing: 1 package
-
- Total size of inbound packages is 29 KiB. Need to download 29 KiB.
- After this operation, 33 KiB extra will be used (install 33 KiB, remove 0 B).
- [1/1] libffi-devel-0:3.4.6-3.fc41.x86_6 100% | 182.1 KiB/s | 28.8 KiB | 00m00s
- --------------------------------------------------------------------------------
- [1/1] Total 100% | 109.8 KiB/s | 28.8 KiB | 00m00s
- Running transaction
- [1/3] Verify package files 100% | 1.0 KiB/s | 1.0 B | 00m00s
- [2/3] Prepare transaction 100% | 25.0 B/s | 1.0 B | 00m00s
- [3/3] Installing libffi-devel-0:3.4.6-3 100% | 344.5 KiB/s | 34.8 KiB | 00m00s
- Complete!
+ /usr/bin/rpm "-q" "--whatprovides" "libffi-devel"
- libffi-devel-3.4.6-3.fc41.x86_64
2025-05-31 10:11.37 ---> using "a6fe1b5ea87ae9b12d6371060eaf79685b73973a2c5f24a9f5ac3e6a726a57ca" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
The following actions will be performed:
=== install 75 packages
- install angstrom 0.16.1
- install astring 0.8.5
- install backoff 0.1.1
- install base v0.17.2
- install bigarray-compat 1.1.0
- install bigstringaf 0.10.0
- install camlp-streams 5.0.1
- install cmdliner 1.3.0
- install conf-libffi 2.0.0
- install conf-pkg-config 4
- install cppo 1.8.0
- install csexp 1.5.2
- install ctypes 0.23.0
- install ctypes-foreign 0.23.0
- install dune 3.19.0
- install dune-configurator 3.19.0
- install fieldslib v0.17.0
- install fmt 0.10.0
- install integers 0.7.0
- install jane-street-headers v0.17.0
- install jst-config v0.17.0
- install logs 0.8.0
- install mdx 2.5.0
- install mtime 2.1.0
- install multicore-magic 2.3.1
- install num 1.5-1
- install ocaml-compiler-libs v0.17.0
- install ocaml-syntax-shims 1.0.0
- install ocaml-version 4.0.1
- install ocaml_intrinsics_kernel v0.17.1
- install ocamlbuild 0.16.1
- install ocamlfind 1.9.8
- install parsexp v0.17.0
- install pprint 20230830
- install ppx_assert v0.17.0
- install ppx_base v0.17.0
- install ppx_cold v0.17.0
- install ppx_compare v0.17.0
- install ppx_derivers 1.2.1
- install ppx_deriving 6.0.3
- install ppx_enumerate v0.17.0
- install ppx_expect v0.17.2
- install ppx_fields_conv v0.17.0
- install ppx_globalize v0.17.0
- install ppx_hash v0.17.0
- install ppx_here v0.17.0
- install ppx_inline_test v0.17.0
- install ppx_minidebug 2.2.0
- install ppx_optcomp v0.17.0
- install ppx_sexp_conv v0.17.0
- install ppx_string v0.17.0
- install ppx_variants_conv v0.17.0
- install ppxlib 0.35.0
- install ppxlib_jane v0.17.2
- install printbox 0.12
- install printbox-ext-plot 0.12
- install printbox-html 0.12
- install printbox-md 0.12
- install printbox-text 0.12
- install ptime 1.2.0
- install re 1.12.0
- install result 1.5
- install saturn_lockfree 0.5.0
- install seq base
- install sexplib v0.17.0
- install sexplib0 v0.17.0
- install stdio v0.17.0
- install stdlib-shims 0.3.0
- install thread-local-storage 0.2
- install time_now v0.17.0
- install topkg 1.0.8
- install tyxml 4.6.0
- install uucp 16.0.0
- install uutf 1.0.4
- install variantslib v0.17.0
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved backoff.0.1.1 (cached)
-> retrieved angstrom.0.16.1 (cached)
-> retrieved astring.0.8.5 (cached)
-> retrieved base.v0.17.2 (cached)
-> retrieved bigarray-compat.1.1.0 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved camlp-streams.5.0.1 (cached)
-> retrieved cppo.1.8.0 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> installed conf-pkg-config.4
-> retrieved csexp.1.5.2 (cached)
-> retrieved ctypes.0.23.0, ctypes-foreign.0.23.0 (cached)
-> installed conf-libffi.2.0.0
-> retrieved fieldslib.v0.17.0 (cached)
-> retrieved integers.0.7.0 (cached)
-> retrieved fmt.0.10.0 (cached)
-> retrieved jane-street-headers.v0.17.0 (cached)
-> retrieved jst-config.v0.17.0 (cached)
-> retrieved logs.0.8.0 (cached)
-> retrieved mtime.2.1.0 (cached)
-> retrieved mdx.2.5.0 (cached)
-> retrieved multicore-magic.2.3.1 (cached)
-> retrieved num.1.5-1 (cached)
-> retrieved ocaml-compiler-libs.v0.17.0 (cached)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocaml-version.4.0.1 (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.1 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved parsexp.v0.17.0 (cached)
-> retrieved pprint.20230830 (cached)
-> retrieved ppx_assert.v0.17.0 (cached)
-> retrieved dune.3.19.0, dune-configurator.3.19.0 (cached)
-> retrieved ppx_base.v0.17.0 (cached)
-> retrieved ppx_cold.v0.17.0 (cached)
-> retrieved ppx_compare.v0.17.0 (cached)
-> retrieved ppx_derivers.1.2.1 (cached)
-> retrieved ppx_deriving.6.0.3 (cached)
-> retrieved ppx_enumerate.v0.17.0 (cached)
-> retrieved ppx_expect.v0.17.2 (cached)
-> retrieved ppx_fields_conv.v0.17.0 (cached)
-> retrieved ppx_globalize.v0.17.0 (cached)
-> installed cmdliner.1.3.0
-> installed num.1.5-1
-> retrieved ppx_hash.v0.17.0 (cached)
-> retrieved ppx_here.v0.17.0 (cached)
-> retrieved ppx_inline_test.v0.17.0 (cached)
-> retrieved ppx_optcomp.v0.17.0 (cached)
-> retrieved ppx_string.v0.17.0 (cached)
-> retrieved ppx_sexp_conv.v0.17.0 (cached)
-> retrieved ppx_minidebug.2.2.0 (cached)
-> retrieved ppx_variants_conv.v0.17.0 (cached)
-> retrieved ppxlib_jane.v0.17.2 (cached)
-> retrieved ptime.1.2.0 (cached)
-> retrieved re.1.12.0 (cached)
-> retrieved result.1.5 (cached)
-> retrieved saturn_lockfree.0.5.0 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved sexplib.v0.17.0 (cached)
-> retrieved sexplib0.v0.17.0 (cached)
-> retrieved stdio.v0.17.0 (cached)
-> retrieved ppxlib.0.35.0 (cached)
-> retrieved printbox.0.12, printbox-ext-plot.0.12, printbox-html.0.12, printbox-md.0.12, printbox-text.0.12 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved thread-local-storage.0.2 (cached)
-> retrieved time_now.v0.17.0 (cached)
-> retrieved topkg.1.0.8 (cached)
-> retrieved tyxml.4.6.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved variantslib.v0.17.0 (cached)
-> retrieved uucp.16.0.0 (cached)
-> installed ocamlbuild.0.16.1
-> installed ocamlfind.1.9.8
-> installed topkg.1.0.8
-> installed mtime.2.1.0
-> installed uutf.1.0.4
-> installed ptime.1.2.0
-> installed fmt.0.10.0
-> installed astring.0.8.5
-> installed logs.0.8.0
-> installed dune.3.19.0
-> installed jane-street-headers.v0.17.0
-> installed ppx_derivers.1.2.1
-> installed csexp.1.5.2
-> installed backoff.0.1.1
-> installed bigarray-compat.1.1.0
-> installed camlp-streams.5.0.1
-> installed cppo.1.8.0
-> installed multicore-magic.2.3.1
-> installed ocaml-version.4.0.1
-> installed ocaml_intrinsics_kernel.v0.17.1
-> installed pprint.20230830
-> installed printbox.0.12
-> installed result.1.5
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed thread-local-storage.0.2
-> installed ocaml-syntax-shims.1.0.0
-> installed re.1.12.0
-> installed ocaml-compiler-libs.v0.17.0
-> installed integers.0.7.0
-> installed saturn_lockfree.0.5.0
-> installed parsexp.v0.17.0
-> installed dune-configurator.3.19.0
-> installed sexplib.v0.17.0
-> installed bigstringaf.0.10.0
-> installed mdx.2.5.0
-> installed angstrom.0.16.1
-> installed tyxml.4.6.0
-> installed printbox-html.0.12
-> installed uucp.16.0.0
-> installed printbox-text.0.12
-> installed ctypes.0.23.0
-> installed printbox-md.0.12
-> installed printbox-ext-plot.0.12
-> installed base.v0.17.2
-> installed ctypes-foreign.0.23.0
-> installed fieldslib.v0.17.0
-> installed variantslib.v0.17.0
-> installed stdio.v0.17.0
-> installed ppxlib.0.35.0
-> installed ppx_optcomp.v0.17.0
-> installed ppxlib_jane.v0.17.2
-> installed ppx_cold.v0.17.0
-> installed ppx_here.v0.17.0
-> installed ppx_variants_conv.v0.17.0
-> installed ppx_fields_conv.v0.17.0
-> installed ppx_enumerate.v0.17.0
-> installed ppx_deriving.6.0.3
-> installed ppx_globalize.v0.17.0
-> installed ppx_compare.v0.17.0
-> installed ppx_sexp_conv.v0.17.0
-> installed ppx_hash.v0.17.0
-> installed ppx_assert.v0.17.0
-> installed ppx_minidebug.2.2.0
-> installed ppx_base.v0.17.0
-> installed jst-config.v0.17.0
-> installed ppx_string.v0.17.0
-> installed time_now.v0.17.0
-> installed ppx_inline_test.v0.17.0
-> installed ppx_expect.v0.17.2
Done.
# To update the current shell environment, run: eval $(opam env)
2025-05-31 10:11.37 ---> using "c98c96755d84e8d4edba59eb78ee8d011fd46904e65a655883eea2a7d27e1296" from cache
/src: (copy (src .) (dst /src))
2025-05-31 10:11.37 ---> saved as "2721acbfb0b44eecc6078f92575bdf649e99e2c60a6498ded78fff5ca8e5fdf0"
/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
File "arrayjit/test/dune", line 6, characters 7-15:
6 | (pps ppx_jane)))
^^^^^^^^
Error: Library "ppx_jane" not found.
-> required by
_build/default/arrayjit/test/.merlin-conf/exe-test_numerical_types
-> required by alias arrayjit/test/check
(cd _build/default/test/config && ../../arrayjit/bin/read_config.exe --read=backend)
Welcome to OCANNL! Reading configuration defaults from /src/_build/default/test/config/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Wrote value of 'backend' to ocannl_backend.txt
(cd _build/default/test_ppx && ./test_ppx_op_expected.exe)
Welcome to OCANNL! Reading configuration defaults from /src/_build/default/test_ppx/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
File "test/dune", lines 30-40, characters 0-281:
30 | (rule
31 | (alias runtest)
32 | (target
33 | (dir log_files))
34 | (action
35 | (run
36 | %{dep:micrograd_demo_logging.exe}
37 | "--ocannl_debug_backend=text"
38 | "--ocannl_log_file_stem=micrograd_demo_logging"
39 | "--ocannl_log_main_domain_to_stdout=false"
40 | "--ocannl_debug_log_to_stream_files=true")))
(cd _build/default/test && ./micrograd_demo_logging.exe --ocannl_debug_backend=text --ocannl_log_file_stem=micrograd_demo_logging --ocannl_log_main_domain_to_stdout=false --ocannl_debug_log_to_stream_files=true)
Welcome to OCANNL! Reading configuration defaults from /src/_build/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Fatal error: exception Sys_error("log_files/micrograd_demo_logging.log: No such file or directory")
Raised by primitive operation at Stdlib.open_out_gen in file "stdlib.ml", line 331, characters 29-55
Called from Stdlib.open_out in file "stdlib.ml" (inlined), line 336, characters 2-74
Called from Minidebug_runtime.shared_config.Result.find_ch in file "minidebug_runtime.ml", line 98, characters 17-34
Called from Minidebug_runtime.shared_config.Result.current_ch in file "minidebug_runtime.ml", line 125, characters 34-44
Called from CamlinternalLazy.do_force_val_block in file "camlinternalLazy.ml", line 63, characters 15-25
Called from Stdlib__Lazy.force_val in file "lazy.ml" (inlined), line 56, characters 18-61
Called from Minidebug_runtime.shared_config.Result.(!!) in file "minidebug_runtime.ml" (inlined), line 126, characters 21-40
Called from Minidebug_runtime.shared_config.Result.debug_ch in file "minidebug_runtime.ml", line 142, characters 6-18
Called from Minidebug_runtime.PrintBox.close_log_impl.close_tree in file "minidebug_runtime.ml", line 1570, characters 15-26
Called from Minidebug_runtime.PrintBox.log_value_sexp in file "minidebug_runtime.ml", lines 1985-1986, characters 9-73
Called from Utils.set_log_level in file "arrayjit/lib/utils.ml", line 418, characters 2-42
Re-raised at Utils.set_log_level in file "arrayjit/lib/utils.ml", lines 415-418, characters 29-42
Called from Dune__exe__Micrograd_demo_logging in file "test/micrograd_demo_logging.ml", line 16, characters 2-23
(cd _build/default/test_ppx && ./test_ppx_op.exe)
Welcome to OCANNL! Reading configuration defaults from /src/_build/default/test_ppx/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition '' -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition 'Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/0cde9a6f7e74a90a33d1149f5581bfbb/default/test/ocannl_config.' -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition 'Retrieving commandline, environment, or config file variable ocannl_log_level' -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition 'Found 0, in the config file' -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition primitive_ops.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition zero2hero_1of7.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
File "test/dune", line 4, characters 7-30:
4 | (name moons_demo_parallel_run)
^^^^^^^^^^^^^^^^^^^^^^^
(cd _build/default/test && ./moons_demo_parallel_run.exe)
Welcome to OCANNL! Reading configuration defaults from /src/_build/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
("Set log_level to" 1)
└─{orphaned from #2}
Retrieving commandline, environment, or config file variable ocannl_backend
Found multicore_cc, in the config file
Properties of devices:
(multicore_devices
(device ((device_name CPU) (device_ordinal 0) (num_domains 32))))
@!Retrieving commandline, environment, or config file variable ocannl_prefer_backend_uniformity
Found true, in the config file
Retrieving commandline, environment, or config file variable ocannl_debug_log_to_stream_files
Not found, using default false
Retrieving commandline, environment, or config file variable ocannl_ll_ident_style
Not found, using default heuristic
Retrieving commandline, environment, or config file variable ocannl_cc_backend_optimization_level
Not found, using default 3
Retrieving commandline, environment, or config file variable ocannl_cc_backend_compiler_command
Not found, using default gcc
Fatal error: exception Utils.User_error("Constant 24000. is too big for FP16 aka. half precision, risk of overflow; increase precision of tensor node learning_rate")
Raised at Ir__Low_level.simplify_llc.check_constant in file "arrayjit/lib/low_level.ml", lines 739-743, characters 6-46
Called from Ir__Low_level.simplify_llc.check_float in file "arrayjit/lib/low_level.ml" (inlined), line 757, characters 15-29
Called from Ir__Low_level.simplify_llc.check_float in file "arrayjit/lib/low_level.ml", line 766, characters 8-15
Called from Ir__Low_level.simplify_llc.check_proc in file "arrayjit/lib/low_level.ml", line 749, characters 8-15
Called from Ir__Low_level.simplify_llc in file "arrayjit/lib/low_level.ml", line 773, characters 73-90
Called from Ir__Low_level.optimize_proc in file "arrayjit/lib/low_level.ml", lines 812-814, characters 4-67
Re-raised at Ir__Low_level.optimize_proc in file "arrayjit/lib/low_level.ml", lines 802-819, characters 30-35
Called from Ir__Low_level.optimize in file "arrayjit/lib/low_level.ml", line 1064, characters 15-47
Called from Ir__Assignments.lower in file "arrayjit/lib/assignments.ml", line 387, characters 2-75
Re-raised at Ir__Assignments.lower in file "arrayjit/lib/assignments.ml", lines 380-387, characters 22-75
Called from Backends.lower_assignments in file "arrayjit/lib/backends.ml", lines 193-194, characters 4-45
Re-raised at Backends.lower_assignments in file "arrayjit/lib/backends.ml", lines 185-194, characters 34-47
Called from Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", line 356, characters 6-61
Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", lines 355-356, characters 4-61
Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", lines 354-362, characters 26-99
Called from Ocannl__Train.to_routine in file "lib/train.ml" (inlined), line 367, characters 26-61
Called from Ocannl__Train.example_train_loop in file "lib/train.ml", line 427, characters 19-84
Called from Dune__exe__Moons_demo_parallel_run.main in file "test/moons_demo_parallel_run.ml", lines 65-69, characters 4-8
Called from Base__Exn.protectx in file "src/exn.ml", line 79, characters 8-11
Re-raised at Base__Exn.raise_with_original_backtrace in file "src/exn.ml" (inlined), line 59, characters 2-50
Called from Base__Exn.protectx in file "src/exn.ml", line 86, characters 13-49
Called from Base__Exn.protect in file "src/exn.ml" (inlined), line 92, characters 26-49
Called from Dune__exe__Moons_demo_parallel_run in file "test/moons_demo_parallel_run.ml", line 90, characters 2-53
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition hello_world_op.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition moons_demo_parallel.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition einsum_trivia.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test && .tutorials.inline-tests/inline-test-runner.exe inline-test-runner tutorials -partition micrograd_demo.ml -source-tree-root .. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from /src/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
File "test/zero2hero_1of7.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/zero2hero_1of7.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/zero2hero_1of7.ml.corrected
diff --git a/_build/default/test/zero2hero_1of7.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/zero2hero_1of7.ml.corrected
index 13e90be..138e4eb 100644
--- a/_build/default/test/zero2hero_1of7.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/zero2hero_1of7.ml.corrected
@@ -226,10 +226,10 @@ let%expect_test "Graph drawing fetch" =
│( │ # # ## │
│x │ ## # │
│) │ # # │
- │ │ # # ### **│
- │ │ ## # * **** │
+ │ │ # # ## **│
+ │ │ ## # # * **** │
│ │ # # ## * **** │
- │ │ ### ## * *** │
+ │ │ ### ## * **** │
│ │ # # # ##** ** │
│ │ #### # ###* * │
│ │ # #### # # ## # #### │
@@ -328,11 +328,11 @@ let%expect_test "Simple gradients hosted" =
#9 grad_+_d │#11 grad_f
-2.00 │ 4.00
#4 *._e │#6 c │
- -6.00 │ 1.02e+1 │
+ -6.00 │ 1.01e+1 │
#5 grad_*._e │#7 grad_c│
-2.00 │ -2.00 │
#0 a │#2 b │ │
- 1.40 │ -2.60 │ │
+ 1.39 │ -2.59 │ │
#1 grad_a│#3 grad_b│ │
6.00 │ -4.00 │ │
|}];
@@ -344,7 +344,7 @@ let%expect_test "Simple gradients hosted" =
[%expect
{|
#12 *._l
- -1.57e+1
+ -1.58e+1
#13 grad_*._l
1.00
#8 +_d │#10 f
@@ -352,13 +352,13 @@ let%expect_test "Simple gradients hosted" =
#9 grad_+_d │#11 grad_f
-2.40 │ 6.56
#4 *._e │#6 c │
- -3.64 │ 1.02e+1 │
+ -3.62 │ 1.01e+1 │
#5 grad_*._e │#7 grad_c│
-2.40 │ -2.40 │
#0 a │#2 b │ │
- 1.40 │ -2.60 │ │
+ 1.39 │ -2.59 │ │
#1 grad_a│#3 grad_b│ │
- 6.24 │ -3.36 │ │
+ 6.25 │ -3.35 │ │
|}]
let%expect_test "Simple gradients virtual" =
@@ -460,11 +460,11 @@ let%expect_test "Simple gradients virtual" =
#9 grad_+_d Virt/40 │#11 grad_f Dev-stream/41
<void> │<void>
#4 *._e Virt/152 │#6 c │
- <void> │ 1.02e+1 │
+ <void> │ 1.01e+1 │
#5 grad_*._e Virt/40 │#7 grad_c Dev-stream/41│
<void> │<void> │
#0 a │#2 b │ │
- 1.40 │ -2.60 │ │
+ 1.39 │ -2.59 │ │
#1 grad_a Dev-stream/41│#3 grad_b Dev-stream/41│ │
<void> │<void> │ │
|}];
@@ -475,7 +475,7 @@ let%expect_test "Simple gradients virtual" =
[%expect
{|
#12 *._l
- -1.57e+1
+ -1.58e+1
#13 grad_*._l Virt/40
<void>
#8 +_d Local/46 │#10 f
@@ -483,11 +483,11 @@ let%expect_test "Simple gradients virtual" =
#9 grad_+_d Virt/40 │#11 grad_f Dev-stream/41
<void> │<void>
#4 *._e Virt/152 │#6 c │
- <void> │ 1.02e+1 │
+ <void> │ 1.01e+1 │
#5 grad_*._e Virt/40 │#7 grad_c Dev-stream/41│
<void> │<void> │
#0 a │#2 b │ │
- 1.40 │ -2.60 │ │
+ 1.39 │ -2.59 │ │
#1 grad_a Dev-stream/41│#3 grad_b Dev-stream/41│ │
<void> │<void> │ │
|}]
@@ -512,11 +512,11 @@ let%expect_test "2D neuron hosted" =
[%expect
{|
#8 +_v
- 7.00e-1
+ 6.87e-1
#9 grad_+_v
1.00
#6 * │#0 b
- -6.00 │ 6.70
+ -6.00 │ 6.68
#7 grad_* │#1 grad_b
1.00 │ 1.00
#2 w │#4 x │
@@ -539,11 +539,11 @@ let%expect_test "2D neuron virtual" =
[%expect
{|
#8 +_v
- 7.00e-1
+ 6.87e-1
#9 grad_+_v Virt/40
<void>
#6 * Local/46 │#0 b
- <void> │ 6.70
+ <void> │ 6.68
#7 grad_* Virt/40 │#1 grad_b Local/46
<void> │<void>
#2 w │#4 x │
File "test/primitive_ops.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/primitive_ops.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/primitive_ops.ml.corrected
diff --git a/_build/default/test/primitive_ops.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/primitive_ops.ml.corrected
index 71c4c28..395f014 100644
--- a/_build/default/test/primitive_ops.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/primitive_ops.ml.corrected
@@ -177,8 +177,8 @@ let%expect_test "exp(x)" =
│ │ * │
│ │ │
│ │ * │
- │ │ * │
│ │ │
+ │ │ * │
│ │ * │
│f │ * │
│( │ * │
@@ -242,19 +242,19 @@ let%expect_test "log(x)" =
│ │ * │
│ │ * │
│ │ ** │
- │ │ ** #############│
- │ │ *** ################### #### │
+ │ │ ** ############│
+ │ │ *** ################### ##### │
│ │ ****** ######### #### ## │
│ │ ******** *****##### #### │
- │ │ ###### ## ***** ************* **** ********************* ******* │
- │ │- - - - ####### - - - - - - - - - - - - - **********│
+ │ │ ###### ## ***** ************* **** ********************* ***** │
+ │ │- - - - ####### - - - - - - - - - - - - - ************│
│ │ ### # │
│ │ #### │
│ │ ## │
│ │ ## │
│ │ ## │
│ │ # │
- │ -2.30 │# │
+ │ -2.29 │# │
├────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ │1.00e-1 5.00│
│ │ x │
@@ -299,8 +299,8 @@ let%expect_test "log2(x)" =
│ │ *** ################### #### │
│ │ ****** ######### #### ## │
│ │ ******** *****##### #### │
- │ │ ###### ## ***** ************* **** ********************* ******* │
- │ │- - - - ####### - - - - - - - - - - - - - **********│
+ │ │ ###### ## ***** ************* **** ********************* ******** │
+ │ │- - - - ####### - - - - - - - - - - - - - -*********│
│ │ ### # │
│ │ #### │
│ │ ## │
@@ -320,51 +320,51 @@ let%expect_test "sin(x)" =
PrintBox_text.output Stdio.stdout plot_box;
[%expect
{|
- ┌─────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 9.99e-1 │ # │
- │ │#### ## *** ** ### ### │
- │ │ # ** ** # # │
- │ │ # * * # # │
- │ │ # # # │
- │ │ # * * # # │
- │ │ * * # │
- │ │ # * #* │
- │ │ # # # │
- │ │ * * │
- │ │ # * # * # │
- │ │ # # │
- │ │ # * * │
- │ │ # # # │
- │ │* * * *│
- │ │ # # # │
- │ │ * * * * │
- │ │ # # # │
- │f │ * * * * │
- │( │ # # # │
- │x │- * - - - - - - *- - - - - - * - - - - - -* │
- │) │ # # # │
- │ │ * * * * │
- │ │ # # # │
- │ │ * * * * │
- │ │ # # # │
- │ │ * * * * │
- │ │ # # # │
- │ │ * * * # * │
- │ │ # * # * │
- │ │ * # # # * │
- │ │ * * * * │
- │ │ # # # │
- │ │ * * # * #* │
- │ │ * * * * │
- │ │ * # # * # │
- │ │ * * # # * * # │
- │ │ * * # # * * # │
- │ │ ** * # # * ** # │
- │ -9.99e-1│ * ***** ####### **** * ## ####│
- ├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
- │ │-5.00 5.00│
- │ │ x │
- └─────────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
+ ┌──────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
+ │ 1.00 │ # * # │
+ │ │#### ## ** ** ### ### │
+ │ │ # ** ** # # │
+ │ │ # * * # # │
+ │ │ # # # │
+ │ │ # * * # # │
+ │ │ * * # │
+ │ │ # * #* │
+ │ │ # # # │
+ │ │ * * │
+ │ │ # # # │
+ │ │ * # * # │
+ │ │ # * * │
+ │ │ # # # │
+ │ │* * * *│
+ │ │ # # # │
+ │ │ * * * * │
+ │ │ # # # │
+ │f │ * * * * │
+ │( │ # # # │
+ │x │- * - - - - - - *- - - - - - * - - - - - -* │
+ │) │ # # # │
+ │ │ * * * * │
+ │ │ # # # │
+ │ │ * * * * │
+ │ │ # # # │
+ │ │ * * * * │
+ │ │ # # # │
+ │ │ * * * # * │
+ │ │ # * # * │
+ │ │ * # # # * │
+ │ │ * * * * │
+ │ │ # * # * # │
+ │ │ * # #* │
+ │ │ * * * * │
+ │ │ * # # * # │
+ │ │ * * # # * * # │
+ │ │ * * # # * * # │
+ │ │ ** * # # * ** # │
+ │ -1.00│ * ***** ####### **** * ## ####│
+ ├──────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
+ │ │-5.00 5.00│
+ │ │ x │
+ └──────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}]
let%expect_test "cos(x)" =
@@ -373,51 +373,51 @@ let%expect_test "cos(x)" =
PrintBox_text.output Stdio.stdout plot_box;
[%expect
{|
- ┌─────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 9.99e-1 │ * │
- │ │ *** *** ### ## ** ****│
- │ │ * * ## ## * │
- │ │ * * # # * │
- │ │ * * * │
- │ │ * * # # * │
- │ │ * # # │
- │ │ # * # * │
- │ │ * * * │
- │ │ # # │
- │ │ * # * # * │
- │ │ * * │
- │ │ # # * │
- │ │ * * * │
- │ │# # # #│
- │ │ * * * │
- │ │ # # # # │
- │ │ * * * │
- │f │ # # # # │
- │( │ * * * │
- │x │- # - - - - - - #- - - - - - # - - - - - -# │
- │) │ * * * │
- │ │ # # # # │
- │ │ * * * │
- │ │ # # # # │
- │ │ * * * │
- │ │ # # # # │
- │ │ * * * │
- │ │ # * # # # │
- │ │ # * # * │
- │ │ # * * * # │
- │ │ # # # # │
- │ │ * * * │
- │ │ #* # * # # │
- │ │ # # * # │
- │ │ * # * * # │
- │ │ * # # * * # # │
- │ │ * # # * * # # │
- │ │ * ## # * * # ## │
- │ -9.99e-1│**** ** # ##### ******* #### # │
- ├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
- │ │-5.00 5.00│
- │ │ x │
- └─────────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
+ ┌──────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
+ │ 1.00 │ * # * │
+ │ │ *** *** ## ## ** ***│
+ │ │ * * ## ## * │
+ │ │ * * # # * │
+ │ │ * * * │
+ │ │ * * # # * │
+ │ │ * # # │
+ │ │ # * # * │
+ │ │ * * * │
+ │ │ # # │
+ │ │ * * * │
+ │ │ * # * # │
+ │ │ # # * │
+ │ │ * * * │
+ │ │# # # #│
+ │ │ * * * │
+ │ │ # # # # │
+ │ │ * * * │
+ │f │ # # # # │
+ │( │ * * * │
+ │x │- # - - - - - - #- - - - - - # - - - - - -# │
+ │) │ * * * │
+ │ │ # # # # │
+ │ │ * * * │
+ │ │ # # # # │
+ │ │ * * * │
+ │ │ # # # # │
+ │ │ * * * │
+ │ │ # * # # # │
+ │ │ # * # * │
+ │ │ # * * * # │
+ │ │ # # # # │
+ │ │ * # * # * │
+ │ │ #* * # │
+ │ │ # # * # │
+ │ │ * # * * # │
+ │ │ * # # * * # # │
+ │ │ * # # * * # # │
+ │ │ * ## # * * # ## │
+ │ -1.00│**** ** # ##### ******* #### # │
+ ├──────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
+ │ │-5.00 5.00│
+ │ │ x │
+ └──────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}]
let%expect_test "neg(x)" =
@@ -534,27 +534,27 @@ let%expect_test "sqrt(x)" =
{|
┌─────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
│ 2.23│ #│
- │ │ ##### │
- │ │ ##### │
- │ │ #### │
- │ │ ## ## │
+ │ │ #### │
+ │ │ ###### │
+ │ │ ##### │
+ │ │ ## # │
│ │ ##### │
- │ │ #### │
- │ │ ##### │
+ │ │ ##### │
+ │ │ #### │
│ │ #### │
│ │ ## # │
│ │ # ## │
- │ │ ### │
- │ │* #### │
+ │ │ #### │
+ │ │* ### │
│ │ #### │
│ │ # # │
- │ │ ### │
- │ │ ### │
- │ │ * ### │
+ │ │ #### │
+ │ │ ### │
+ │ │ * ## │
│f │ ## │
│( │ ### │
- │x │ * ### │
- │) │ ## │
+ │x │ * ## │
+ │) │ ### │
│ │ * ## │
│ │ # ## │
│ │ * ## │
@@ -563,9 +563,9 @@ let%expect_test "sqrt(x)" =
│ │ *# │
│ │ # ** │
│ │ ## *** │
- │ │ # * * │
- │ │ # ***** │
- │ │ # ******** │
+ │ │ # * ** │
+ │ │ # ***** │
+ │ │ # ******* │
│ │ # * ********** │
│ │# * ************* **** │
│ │ * ********************* ************ │
@@ -639,23 +639,23 @@ let%expect_test "recip_sqrt(x)" =
[%expect
{|
┌─────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 3.16 │# │
+ │ 3.15 │# │
│ │ │
│ │ ## │
│ │ ## │
│ │ ####### │
- │ │ ### ############## ##### │
- │ │ ##### ############# #### ##################### #################│
- │ │- - - - - - -********** *************-****-********************* *****************│
- │ │ * ************** │
- │ │ **** │
+ │ │ ### ############## #### │
+ │ │ ###### ############# #### ##################### #################│
+ │ │- - - - - - - ******** *************-****-********************* *****************│
+ │ │ * ************** ** │
+ │ │ ***** │
│ │ *** │
│ │ * │
│ │ * │
│ │ * │
│ │ │
- │ │ * │
│ │ │
+ │ │ * │
│ │ │
│f │ │
│( │ * │
@@ -678,7 +678,7 @@ let%expect_test "recip_sqrt(x)" =
│ │ │
│ │ │
│ │ │
- │ -1.58e+1│* │
+ │ -1.56e+1│* │
├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ │1.00e-1 5.00│
│ │ x │
@@ -691,51 +691,51 @@ let%expect_test "tanh(x)" =
PrintBox_text.output Stdio.stdout plot_box;
[%expect
{|
- ┌─────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 9.99e-1 │ #│
- │ │ ** * ############## #### ####### ### │
- │ │ * * #### │
- │ │ * * ## │
- │ │ * * # │
- │ │ * * ## │
- │ │ # │
- │ │ * * │
- │ │ * * │
- │ │ # │
- │ │ * # * │
- │ │ * * │
- │ │ # │
- │ │ * # * │
- │ │ * * │
- │ │ * # * │
- │ │ ** ** │
- │ │ ** # ** │
- │f │ ** ** │
- │( │ * ***** # ****** │
- │x │**** *** *** *** ********- - - - - - - - - - ******* **** *******-****│
- │) │ # │
- │ │ │
- │ │ # │
- │ │ │
- │ │ # │
- │ │ │
- │ │ # │
- │ │ # │
- │ │ │
- │ │ # │
- │ │ # │
- │ │ # │
- │ │ │
- │ │ # │
- │ │ ## │
- │ │ # │
- │ │ ## │
- │ │ #### │
- │ -9.99e-1│#### ### ### ### ######## ###### │
- ├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
- │ │-5.00 5.00│
- │ │x │
- └─────────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
+ ┌──────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
+ │ 1.00 │ ### ####### ####│
+ │ │ ** * ############## # │
+ │ │ * * #### │
+ │ │ * * ## │
+ │ │ * * # │
+ │ │ * * ## │
+ │ │ # │
+ │ │ * * │
+ │ │ * * │
+ │ │ # │
+ │ │ * # * │
+ │ │ * * │
+ │ │ # │
+ │ │ * # * │
+ │ │ * * │
+ │ │ * # * │
+ │ │ ** ** │
+ │ │ ** # ** │
+ │f │ *** *** │
+ │( │ * **** # ***** │
+ │x │**** *** *** *** ********- - - - - - - - - - ******* **** *******-****│
+ │) │ # │
+ │ │ │
+ │ │ # │
+ │ │ │
+ │ │ # │
+ │ │ │
+ │ │ # │
+ │ │ # │
+ │ │ │
+ │ │ # │
+ │ │ # │
+ │ │ # │
+ │ │ │
+ │ │ # │
+ │ │ ## │
+ │ │ # │
+ │ │ ## │
+ │ │ #### │
+ │ -1.00│#### ### ### ### ######## ###### │
+ ├──────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
+ │ │-5.00 5.00│
+ │ │ x │
+ └──────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}]
let%expect_test "where(x < 0, sin(x), cos(x))" =
@@ -744,49 +744,49 @@ let%expect_test "where(x < 0, sin(x), cos(x))" =
PrintBox_text.output Stdio.stdout plot_box;
[%expect
{|
- ┌─────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 9.99e-1 │ # * │
- │ │#### ## *** ## ** ***│
- │ │ # ** ## * │
- │ │ # * # * │
- │ │ # * │
- │ │ # * # * │
- │ │ * # │
- │ │ # * # * │
- │ │ # * │
- │ │ * # │
- │ │ # * # * │
- │ │ │
- │ │ # * # * │
- │ │ # * │
- │ │* * # #│
- │ │ # * │
- │ │ * * # # │
- │ │ # * │
- │f │ * * # # │
- │( │ # * │
- │x │- * - - - - - - *- - - - - - # - - - - - -# │
- │) │ # * * │
- │ │ * * # # │
- │ │ # # * * │
- │ │ * * # # │
- │ │ # # * * │
- │ │ * * # # │
- │ │ # # * * │
- │ │ * * # # │
- │ │ # * # * # * │
- │ │ * # # * * # │
- │ │ * * # # │
- │ │ # # * * │
- │ │ * * # * # # │
- │ │ * * * # │
- │ │ * # # * * # │
- │ │ * * # # * * # # │
- │ │ * * # # * * # # │
- │ │ ** * # # * * # ## │
- │ -9.99e-1│ * ***** ####### ******* #### # │
- ├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
- │ │-5.00 5.00│
- │ │ x │
- └─────────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
+ ┌──────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
+ │ 1.00 │ # * * │
+ │ │#### ## ** ## ** ***│
+ │ │ # ** ## * │
+ │ │ # * # * │
+ │ │ # * │
+ │ │ # * # * │
+ │ │ * # │
+ │ │ # * # * │
+ │ │ # * │
+ │ │ * # │
+ │ │ # * │
+ │ │ * # │
+ │ │ # * # * │
+ │ │ # * │
+ │ │* * # #│
+ │ │ # * │
+ │ │ * * # # │
+ │ │ # * │
+ │f │ * * # # │
+ │( │ # * │
+ │x │- * - - - - - - *- - - - - - # - - - - - -# │
+ │) │ # * * │
+ │ │ * * # # │
+ │ │ # # * * │
+ │ │ * * # # │
+ │ │ # # * * │
+ │ │ * * # # │
+ │ │ # # * * │
+ │ │ * * # # │
+ │ │ # * # * # * │
+ │ │ * # # * * # │
+ │ │ * * # # │
+ │ │ # * # * # * │
+ │ │ * # * # │
+ │ │ * * * # │
+ │ │ * # # * * # │
+ │ │ * * # # * * # # │
+ │ │ * * # # * * # # │
+ │ │ ** * # # * * # ## │
+ │ -1.00│ * ***** ####### ******* #### # │
+ ├──────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
+ │ │-5.00 5.00│
+ │ │ x │
+ └──────┴────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}]
File "test/moons_demo_parallel.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/moons_demo_parallel.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/moons_demo_parallel.ml.corrected
diff --git a/_build/default/test/moons_demo_parallel.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/moons_demo_parallel.ml.corrected
index ce09725..a66ab7f 100644
--- a/_build/default/test/moons_demo_parallel.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/moons_demo_parallel.ml.corrected
@@ -105,4 +105,29 @@ let%expect_test "Half-moons data parallel" =
]
in
PrintBox_text.output Stdio.stdout plot_loss);
- [%expect "Success"]
+ [%expect.unreachable]
+[@@expect.uncaught_exn {|
+ (* CR expect_test_collector: This test expectation appears to contain a backtrace.
+ This is strongly discouraged as backtraces are fragile.
+ Please change this test to not include a backtrace. *)
+ ("Utils.User_error(\"Constant 24000. is too big for FP16 aka. half precision, risk of overflow; increase precision of tensor node learning_rate\")")
+ Raised at Ir__Low_level.simplify_llc.check_constant in file "arrayjit/lib/low_level.ml", lines 739-743, characters 6-46
+ Called from Ir__Low_level.simplify_llc.check_float in file "arrayjit/lib/low_level.ml" (inlined), line 757, characters 15-29
+ Called from Ir__Low_level.simplify_llc.check_float in file "arrayjit/lib/low_level.ml", line 766, characters 8-15
+ Called from Ir__Low_level.simplify_llc.check_proc in file "arrayjit/lib/low_level.ml", line 749, characters 8-15
+ Called from Ir__Low_level.simplify_llc in file "arrayjit/lib/low_level.ml", line 773, characters 73-90
+ Called from Ir__Low_level.optimize_proc in file "arrayjit/lib/low_level.ml", lines 812-814, characters 4-67
+ Re-raised at Ir__Low_level.optimize_proc in file "arrayjit/lib/low_level.ml", lines 802-819, characters 30-35
+ Called from Ir__Low_level.optimize in file "arrayjit/lib/low_level.ml", line 1064, characters 15-47
+ Called from Ir__Assignments.lower in file "arrayjit/lib/assignments.ml", line 387, characters 2-75
+ Re-raised at Ir__Assignments.lower in file "arrayjit/lib/assignments.ml", lines 380-387, characters 22-75
+ Called from Backends.lower_assignments in file "arrayjit/lib/backends.ml", lines 193-194, characters 4-45
+ Re-raised at Backends.lower_assignments in file "arrayjit/lib/backends.ml", lines 185-194, characters 34-47
+ Called from Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", line 356, characters 6-61
+ Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", lines 355-356, characters 4-61
+ Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", lines 354-362, characters 26-99
+ Called from Ocannl__Train.to_routine in file "lib/train.ml" (inlined), line 367, characters 26-61
+ Called from Ocannl__Train.example_train_loop in file "lib/train.ml", line 427, characters 19-84
+ Called from Tutorials__Moons_demo_parallel.(fun) in file "test/moons_demo_parallel.ml", lines 58-62, characters 4-8
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
File "test/micrograd_demo.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/micrograd_demo.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/micrograd_demo.ml.corrected
diff --git a/_build/default/test/micrograd_demo.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/micrograd_demo.ml.corrected
index 62a1f34..5040ca9 100644
--- a/_build/default/test/micrograd_demo.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/micrograd_demo.ml.corrected
@@ -78,7 +78,7 @@ let%expect_test "Micrograd README basic example" =
│┌┬─────────┐ │
│││axis 0 │ │
│├┼─────────┤ │
- │││ 6.45e+2 │ │
+ │││ 6.44e+2 │ │
│└┴─────────┘ │
└────────────────────────┘
|}]
@@ -191,44 +191,44 @@ let%expect_test "Micrograd half-moons example" =
┌────────────────────────────────────────────────────────────────────────────────────────────────────┐
│****************************#***********************************************************************│
│****************************###***###***#***********************************************************│
- │***************************#********#***#***********************************************************│
- │********************#*********************##*#*#****************************************************│
- │******************#***#*****##*#*#*#****#*#*#*##****************************************************│
- │**************#*#**###**#*##**##********#**#****###**#**********************************************│
- │***********#***##***#**##*****************#*#*##*###**********************************************..│
- │***************#**###******************************##*#******************************************...│
- │*************#*****#******************************#*#***#*#*************************************....│
- │*********#***#******************......************##*###**#************************************.....│
- │******#***#*#*#****************........******************#*#*********************************.......│
- │*****###****#****************...........****************#***********************************........│
- │*******#*###****************.............******************#*#*****************************.........│
- │**********##***************.......%%......***************#**##****************************..........│
- │*****#***#****************......%..%%......*********************************************..........%.│
- │**####*******************......%..%..........****************##*#**********************........%...%│
- │****#*******************.......%%..%..........***************#*#**********************.........%....│
- │*#****##***************.........%....%.........************##***#********************.......%...%%..│
- │****#*#***************.........%..%.%...........*************#**#*******************..........%.%...│
- │##*##****************............%...............**************#*##****************.........%.%.%%%.│
- │**#####************............%...%%.............*******************************...........%..%.%..│
- │******************...............%.%.%%............*********#*#*#*#*************................%%..│
- │***##************................%..%..%............************#*#************.............%...%...│
- │##**#***********...................%...%.............********#**###***********...........%.%%.......│
- │###************..................%.%.%................***********##**********..................%....│
- │**##**********.........................................**********#*********.............%%.%..%.....│
- │**#**********......................%%...................********##********..............%%.%........│
- │************..........................%..................****#**#********...................%.......│
- │***********.........................%%.%..................*****##******...............%..%..........│
- │**********.............................%%..................***********.................%%.%%........│
- │*********..............................%...%................*******.....................%%%.........│
- │********...................................%..%....................................%.....%..........│
- │*******.................................%%..%.%................................%.%.%.%%.............│
- │******.....................................%%.%...%%.%.......................%%%....%.%.%...........│
- │*****....................................%.....%.%..%....................%.....%%.%.%...............│
- │****........................................%%...%.%%%%..%.......%.........%%.%%....................│
- │***...............................................%..%.......%..%%%%...%.%..%.%.....................│
- │**.................................................%.%.%............%..%...%........................│
- │*.................................................%....%.%......%%...%.%............................│
- │..........................................................%..%......%%%.............................│
+ │***************************#********#***#*#*********************************************************│
+ │********************#**********************#*#*#****************************************************│
+ │******************##**#*****##*#*#*#****#*#*#*#*#***************************************************│
+ │**************#*#***#***#*##*#*#********#**#****###**#**********************************************│
+ │***********#***##*#*#**##*****************#*#*##*###***********************************************.│
+ │***************#***##******************************##*#*******************************************..│
+ │*************#*****#******************************#*#**#**#**************************************...│
+ │*********#***#*****************......*************##*###*#*#************************************....│
+ │******#***#*#*#***************........*******************#*************************************.....│
+ │*****###****#****************...........****************#*************************************......│
+ │******####*#****************.............******************#*#*******************************.......│
+ │**********##***************.......%%......***************#**##*****************************.........│
+ │*****#***#****************......%..%%......***********************************************.........%│
+ │**####*******************......%.%%.........****************###*#************************......%...%│
+ │****#*******************.......%%..%.........****************#*#************************.......%....│
+ │##****##***************.........%....%........*************##***#**********************.....%...%%..│
+ │***##*#***************.........%..%.%..........**************#**#*********************........%.%...│
+ │##*##****************...........%...............***************#*##******************.......%.%.%%%.│
+ │**####**************...........%..%.%............**********************************.........%...%%..│
+ │*******************..............%.%.%%...........**********#*#*#*#***************..............%%..│
+ │***##*************...............%..%..%...........*************#*#***************..........%...%...│
+ │##**#*************.................%...%............********#***###*************.........%.%%.......│
+ │##***************................%.%.%...............************##************................%....│
+ │**##************......................................***********#************..........%%.%..%.....│
+ │*#*************....................%%..................*********##***********...........%..%........│
+ │**************........................%.................*****#**#***********.............%.%........│
+ │**************......................%%.%.................******##*********.............%.%..........│
+ │************...........................%%.................***************..............%%.%%........│
+ │************...........................%...%...............*************................%%%.........│
+ │***********................................%..%.............***********............%.....%..........│
+ │**********..............................%%..%.%..............*******...........%%%.%.%%.............│
+ │*********..................................%%.%...%%.%........****...........%%%....%.%.%...........│
+ │********.................................%....%%.%..%..........................%%.%.%...............│
+ │********....................................%%..%..%%%%..%.......%.......%.%%.%%....................│
+ │******............................................%..%.......%..%%%....%.%..%%......................│
+ │******.............................................%.%.%............%..%...%........................│
+ │*****.............................................%....%.%.......%...%.%............................│
+ │****......................................................%..%..%...%%..............................│
└────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}];
Stdio.printf "Loss:\n%!";
@@ -241,7 +241,7 @@ let%expect_test "Micrograd half-moons example" =
{|
Loss:
┌────────┬────────────────────────────────────────────────────────────────────────────────────────────────────┐
- │ 3.79e+1│- │
+ │ 3.80e+1│- │
│ │ │
│ │ │
│ │ │
@@ -279,7 +279,7 @@ let%expect_test "Micrograd half-moons example" =
│ │ │
│ │ │
│ │ │
- │ │- - - │
+ │ │- - - │
│ 0.00 │----------------------------------------------------------------------------------------------------│
├────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ │0.00 3.99e+2│
@@ -306,36 +306,36 @@ let%expect_test "Micrograd half-moons example" =
│ │ │
│ │ │
│ │- │
- │ │ - - │
- │ │ - - - │
- │ │------ - │
- │ │ ---- - - --- - - - - - │
- │ │ -- - - - --- -- - -- - │
- │ │ - -- - - --- - - --- ----- - -- │
- │l │ -- - - - - --- - - - │
- │o │ - - - -- - -- - - - - - │
- │g │ - - - - -- - - - - - - - │
- │ │ - - - -- - - - -- - - - │
- │l │ - - -- -- - - - - -│
- │o │ - - - - - - - - - - - │
- │s │ - - - - -- - │
- │s │ - - │
- │ │ - - - - - - - - - │
- │ │ - - - - - │
- │ │ - - │
- │ │ - - - │
- │ │ - - │
+ │ │ - │
+ │ │ - - - │
+ │ │----- - - │
+ │ │ - ---- - --- - - -- - │
+ │ │ -- -- - - ---- - --- - - │
+ │ │ --- - - - --- ----- - - - │
+ │l │ --- - - - - --- -- - │
+ │o │ -- - -- - - - │
+ │g │ - - - - - - -- - - - - │
+ │ │ - - - - - - - - - - - │
+ │l │ - - - --- - - - - - - │
+ │o │ - - -- - - - - - │
+ │s │ - -- - - - - - -- - │
+ │s │ - - - -- - - - - -- - - │
+ │ │ - - - - │
+ │ │ - - - - - - - - │
+ │ │ - - │
+ │ │ - - - - │
+ │ │ - - - │
+ │ │ -- - │
│ │ │
- │ │ - │
- │ │ - │
│ │ │
│ │ │
│ │ │
│ │ │
- │ │ - │
│ │ │
│ │ │
- │ -1.00e+1│ - - - - ----- -- --------------- ---------------------------------------------------------│
+ │ │ │
+ │ │ │
+ │ -1.00e+1│ -- - - ----- -- ------- -----------------------------------------------------------------│
├─────────┼────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ │0.00 3.99e+2│
│ │ step │
@@ -356,38 +356,38 @@ let%expect_test "Micrograd half-moons example" =
│ │ ---- │
│ │ --- │
│ │ ---- │
- │ │ --- │
+ │ │ ---- │
│ │ --- │
│ │ --- │
- │ │ --- │
+ │ │ ---- │
│ │ ---- │
│ │ --- │
│ │ ---- │
- │ │ --- │
- │l │ ---- │
- │e │ --- │
+ │ │ ---- │
+ │l │ --- │
+ │e │ ---- │
│a │ --- │
- │r │ --- │
- │n │ --- │
- │i │ ---- │
- │n │ --- │
- │g │ ---- │
+ │r │ ---- │
+ │n │ ---- │
+ │i │ --- │
+ │n │ ---- │
+ │g │ --- │
│ │ --- │
│r │ ---- │
│a │ --- │
- │t │ --- │
- │e │ --- │
+ │t │ ---- │
+ │e │ ---- │
│ │ --- │
│ │ ---- │
- │ │ --- │
- │ │ ---- │
- │ │ --- │
- │ │ ---- │
- │ │ --- │
- │ │ --- │
- │ │ --- │
- │ │ --- │
- │ │ ---- │
+ │ │ ---- │
+ │ │ --- │
+ │ │ ---- │
+ │ │ --- │
+ │ │ ---- │
+ │ │ ---- │
+ │ │ --- │
+ │ │ ---- │
+ │ │ --- │
│ │ --- │
│ │ ---- │
│ -2.00e-1│--- │
File "test/hello_world_op.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/hello_world_op.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/hello_world_op.ml.corrected
diff --git a/_build/default/test/hello_world_op.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/hello_world_op.ml.corrected
index 0cea005..72e1505 100644
--- a/_build/default/test/hello_world_op.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/hello_world_op.ml.corrected
@@ -604,45 +604,45 @@ let%expect_test "Very big tensor" =
││ │axis 5 │axis 5 │axis 5│axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││0 @ 1 │ 0.00 1.00 ... 7.00 8.00 │ 9.00 1.00e+1 ... 1.60e+1 1.70e+1 │ ... │ 5.40e+1 5.50e+1 ... 6.10e+1 6.20e+1 │ 6.30e+1 6.40e+1 ... 7.00e+1 7.10e+1 ││
- ││axis 2│ 5.04e+2 5.05e+2 ... 5.11e+2 5.12e+2 │ 5.13e+2 5.14e+2 ... 5.20e+2 5.21e+2 │ │ 5.58e+2 5.59e+2 ... 5.65e+2 5.66e+2 │ 5.67e+2 5.68e+2 ... 5.74e+2 5.75e+2 ││
+ ││axis 2│ 5.04e+2 5.04e+2 ... 5.12e+2 5.12e+2 │ 5.12e+2 5.12e+2 ... 5.20e+2 5.20e+2 │ │ 5.60e+2 5.60e+2 ... 5.64e+2 5.68e+2 │ 5.68e+2 5.68e+2 ... 5.76e+2 5.76e+2 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 4.53e+3 4.53e+3 ... 4.54e+3 4.54e+3 │ 4.54e+3 4.54e+3 ... 4.55e+3 4.55e+3 │ │ 4.59e+3 4.59e+3 ... 4.59e+3 4.59e+3 │ 4.59e+3 4.60e+3 ... 4.60e+3 4.60e+3 ││
- ││ │ 5.04e+3 5.04e+3 ... 5.04e+3 5.04e+3 │ 5.04e+3 5.05e+3 ... 5.05e+3 5.05e+3 │ │ 5.09e+3 5.09e+3 ... 5.10e+3 5.10e+3 │ 5.10e+3 5.10e+3 ... 5.11e+3 5.11e+3 ││
+ ││ │ 4.54e+3 4.54e+3 ... 4.54e+3 4.54e+3 │ 4.54e+3 4.54e+3 ... 4.54e+3 4.54e+3 │ │ 4.57e+3 4.57e+3 ... 4.60e+3 4.60e+3 │ 4.60e+3 4.60e+3 ... 4.60e+3 4.60e+3 ││
+ ││ │ 5.05e+3 5.05e+3 ... 5.05e+3 5.05e+3 │ 5.05e+3 5.05e+3 ... 5.05e+3 5.05e+3 │ │ 5.08e+3 5.08e+3 ... 5.08e+3 5.08e+3 │ 5.08e+3 5.12e+3 ... 5.12e+3 5.12e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 1 │ 5.54e+3 5.54e+3 ... 5.55e+3 5.55e+3 │ 5.55e+3 5.55e+3 ... 5.56e+3 5.56e+3 │ ... │ 5.59e+3 5.59e+3 ... 5.60e+3 5.60e+3 │ 5.60e+3 5.60e+3 ... 5.61e+3 5.61e+3 ││
- ││axis 2│ 6.04e+3 6.04e+3 ... 6.05e+3 6.05e+3 │ 6.05e+3 6.05e+3 ... 6.06e+3 6.06e+3 │ │ 6.10e+3 6.10e+3 ... 6.10e+3 6.11e+3 │ 6.11e+3 6.11e+3 ... 6.11e+3 6.11e+3 ││
+ ││1 @ 1 │ 5.53e+3 5.53e+3 ... 5.53e+3 5.56e+3 │ 5.56e+3 5.56e+3 ... 5.56e+3 5.56e+3 │ ... │ 5.60e+3 5.60e+3 ... 5.60e+3 5.60e+3 │ 5.60e+3 5.60e+3 ... 5.60e+3 5.60e+3 ││
+ ││axis 2│ 6.04e+3 6.04e+3 ... 6.04e+3 6.04e+3 │ 6.04e+3 6.04e+3 ... 6.08e+3 6.08e+3 │ │ 6.11e+3 6.11e+3 ... 6.11e+3 6.11e+3 │ 6.11e+3 6.11e+3 ... 6.11e+3 6.11e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.00e+4 1.00e+4 ... 1.00e+4 1.00e+4 │ 1.00e+4 1.00e+4 ... 1.00e+4 1.00e+4 │ │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 ││
- ││ │ 1.05e+4 1.05e+4 ... 1.05e+4 1.05e+4 │ 1.05e+4 1.05e+4 ... 1.06e+4 1.06e+4 │ │ 1.06e+4 1.06e+4 ... 1.06e+4 1.06e+4 │ 1.06e+4 1.06e+4 ... 1.06e+4 1.06e+4 ││
+ ││ │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 │ │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 │ 1.01e+4 1.01e+4 ... 1.01e+4 1.01e+4 ││
+ ││ │ 1.05e+4 1.05e+4 ... 1.05e+4 1.06e+4 │ 1.06e+4 1.06e+4 ... 1.06e+4 1.06e+4 │ │ 1.06e+4 1.06e+4 ... 1.06e+4 1.06e+4 │ 1.06e+4 1.06e+4 ... 1.06e+4 1.06e+4 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... │ ... ││
││axis 2│ │ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││8 @ 1 │ 4.43e+4 4.43e+4 ... 4.43e+4 4.43e+4 │ 4.43e+4 4.43e+4 ... 4.43e+4 4.43e+4 │ ... │ 4.44e+4 4.44e+4 ... 4.44e+4 4.44e+4 │ 4.44e+4 4.44e+4 ... 4.44e+4 4.44e+4 ││
- ││axis 2│ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 │ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 │ │ 4.49e+4 4.49e+4 ... 4.49e+4 4.49e+4 │ 4.49e+4 4.49e+4 ... 4.49e+4 4.49e+4 ││
+ ││8 @ 1 │ 4.42e+4 4.42e+4 ... 4.42e+4 4.42e+4 │ 4.42e+4 4.42e+4 ... 4.42e+4 4.42e+4 │ ... │ 4.42e+4 4.42e+4 ... 4.42e+4 4.42e+4 │ 4.42e+4 4.45e+4 ... 4.45e+4 4.45e+4 ││
+ ││axis 2│ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 │ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 │ │ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 │ 4.48e+4 4.48e+4 ... 4.48e+4 4.48e+4 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 4.88e+4 4.88e+4 ... 4.88e+4 4.88e+4 │ 4.88e+4 4.88e+4 ... 4.89e+4 4.89e+4 │ │ 4.89e+4 4.89e+4 ... 4.89e+4 4.89e+4 │ 4.89e+4 4.89e+4 ... 4.89e+4 4.89e+4 ││
- ││ │ 4.93e+4 4.93e+4 ... 4.93e+4 4.94e+4 │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 │ │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 ││
+ ││ │ 4.88e+4 4.88e+4 ... 4.88e+4 4.88e+4 │ 4.88e+4 4.88e+4 ... 4.88e+4 4.88e+4 │ │ 4.88e+4 4.88e+4 ... 4.88e+4 4.88e+4 │ 4.88e+4 4.88e+4 ... 4.88e+4 4.88e+4 ││
+ ││ │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 │ │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 │ 4.94e+4 4.94e+4 ... 4.94e+4 4.94e+4 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││9 @ 1 │ 4.98e+4 4.98e+4 ... 4.99e+4 4.99e+4 │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 │ ... │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 ││
+ ││9 @ 1 │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 │ ... │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 │ 4.99e+4 4.99e+4 ... 4.99e+4 4.99e+4 ││
││axis 2│ 5.04e+4 5.04e+4 ... 5.04e+4 5.04e+4 │ 5.04e+4 5.04e+4 ... 5.04e+4 5.04e+4 │ │ 5.04e+4 5.04e+4 ... 5.04e+4 5.04e+4 │ 5.04e+4 5.04e+4 ... 5.04e+4 5.04e+4 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 5.44e+4 5.44e+4 ... 5.44e+4 5.44e+4 │ 5.44e+4 5.44e+4 ... 5.44e+4 5.44e+4 │ │ 5.44e+4 5.44e+4 ... 5.44e+4 5.44e+4 │ 5.44e+4 5.44e+4 ... 5.45e+4 5.45e+4 ││
- ││ │ 5.49e+4 5.49e+4 ... 5.49e+4 5.49e+4 │ 5.49e+4 5.49e+4 ... 5.49e+4 5.49e+4 │ │ 5.49e+4 5.49e+4 ... 5.49e+4 5.49e+4 │ 5.49e+4 5.50e+4 ... 5.50e+4 5.50e+4 ││
+ ││ │ 5.45e+4 5.45e+4 ... 5.45e+4 5.45e+4 │ 5.45e+4 5.45e+4 ... 5.45e+4 5.45e+4 │ │ 5.45e+4 5.45e+4 ... 5.45e+4 5.45e+4 │ 5.45e+4 5.45e+4 ... 5.45e+4 5.45e+4 ││
+ ││ │ 5.50e+4 5.50e+4 ... 5.50e+4 5.50e+4 │ 5.50e+4 5.50e+4 ... 5.50e+4 5.50e+4 │ │ 5.50e+4 5.50e+4 ... 5.50e+4 5.50e+4 │ 5.50e+4 5.50e+4 ... 5.50e+4 5.50e+4 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┬──────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
││1 @ 0 │0 @ 4 │1 @ 4 │~~~~~ │6 @ 4 │7 @ 4 ││
││ │axis 5 │axis 5 │axis 5│axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 1 │ 5.54e+4 5.54e+4 ... 5.54e+4 5.54e+4 │ 5.54e+4 5.54e+4 ... 5.54e+4 5.54e+4 │ ... │ 5.54e+4 5.54e+4 ... 5.55e+4 5.55e+4 │ 5.55e+4 5.55e+4 ... 5.55e+4 5.55e+4 ││
- ││axis 2│ 5.59e+4 5.59e+4 ... 5.59e+4 5.59e+4 │ 5.59e+4 5.59e+4 ... 5.59e+4 5.59e+4 │ │ 5.59e+4 5.59e+4 ... 5.60e+4 5.60e+4 │ 5.60e+4 5.60e+4 ... 5.60e+4 5.60e+4 ││
+ ││0 @ 1 │ 5.55e+4 5.55e+4 ... 5.55e+4 5.55e+4 │ 5.55e+4 5.55e+4 ... 5.55e+4 5.55e+4 │ ... │ 5.55e+4 5.55e+4 ... 5.55e+4 5.55e+4 │ 5.55e+4 5.55e+4 ... 5.55e+4 5.55e+4 ││
+ ││axis 2│ 5.60e+4 5.60e+4 ... 5.60e+4 5.60e+4 │ 5.60e+4 5.60e+4 ... 5.60e+4 5.60e+4 │ │ 5.60e+4 5.60e+4 ... 5.60e+4 5.60e+4 │ 5.60e+4 5.60e+4 ... 5.60e+4 5.60e+4 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 5.99e+4 5.99e+4 ... 5.99e+4 5.99e+4 │ 5.99e+4 5.99e+4 ... 5.99e+4 5.99e+4 │ │ 6.00e+4 6.00e+4 ... 6.00e+4 6.00e+4 │ 6.00e+4 6.00e+4 ... 6.00e+4 6.00e+4 ││
- ││ │ 6.04e+4 6.04e+4 ... 6.04e+4 6.04e+4 │ 6.04e+4 6.04e+4 ... 6.04e+4 6.04e+4 │ │ 6.05e+4 6.05e+4 ... 6.05e+4 6.05e+4 │ 6.05e+4 6.05e+4 ... 6.05e+4 6.05e+4 ││
+ ││ │ 5.99e+4 5.99e+4 ... 5.99e+4 5.99e+4 │ 5.99e+4 5.99e+4 ... 5.99e+4 5.99e+4 │ │ 5.99e+4 5.99e+4 ... 6.01e+4 6.01e+4 │ 6.01e+4 6.01e+4 ... 6.01e+4 6.01e+4 ││
+ ││ │ 6.04e+4 6.04e+4 ... 6.04e+4 6.04e+4 │ 6.04e+4 6.04e+4 ... 6.04e+4 6.04e+4 │ │ 6.04e+4 6.04e+4 ... 6.04e+4 6.04e+4 │ 6.04e+4 6.04e+4 ... 6.06e+4 6.06e+4 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 1 │ 6.09e+4 6.09e+4 ... 6.09e+4 6.09e+4 │ 6.09e+4 6.09e+4 ... 6.10e+4 6.10e+4 │ ... │ 6.10e+4 6.10e+4 ... 6.10e+4 6.10e+4 │ 6.10e+4 6.10e+4 ... 6.10e+4 6.10e+4 ││
- ││axis 2│ 6.14e+4 6.14e+4 ... 6.14e+4 6.14e+4 │ 6.14e+4 6.14e+4 ... 6.15e+4 6.15e+4 │ │ 6.15e+4 6.15e+4 ... 6.15e+4 6.15e+4 │ 6.15e+4 6.15e+4 ... 6.15e+4 6.15e+4 ││
+ ││1 @ 1 │ 6.09e+4 6.09e+4 ... 6.09e+4 6.09e+4 │ 6.09e+4 6.09e+4 ... 6.09e+4 6.09e+4 │ ... │ 6.09e+4 6.09e+4 ... 6.09e+4 6.09e+4 │ 6.09e+4 6.09e+4 ... 6.09e+4 6.09e+4 ││
+ ││axis 2│ 6.14e+4 6.14e+4 ... 6.14e+4 6.14e+4 │ 6.14e+4 6.14e+4 ... 6.14e+4 6.14e+4 │ │ 6.14e+4 6.14e+4 ... 6.14e+4 6.14e+4 │ 6.14e+4 6.14e+4 ... 6.14e+4 6.14e+4 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 6.55e+4 6.55e+4 ... 6.55e+4 6.55e+4 │ 6.55e+4 6.55e+4 ... 6.55e+4 6.55e+4 │ │ 6.55e+4 6.55e+4 ... 6.55e+4 6.55e+4 │ 6.55e+4 6.55e+4 ... 6.55e+4 6.55e+4 ││
││ │ 6.60e+4 6.60e+4 ... 6.60e+4 6.60e+4 │ 6.60e+4 6.60e+4 ... 6.60e+4 6.60e+4 │ │ 6.60e+4 6.60e+4 ... 6.60e+4 6.60e+4 │ 6.60e+4 6.60e+4 ... 6.60e+4 6.60e+4 ││
@@ -650,7 +650,7 @@ let%expect_test "Very big tensor" =
││~~~~~ │ ... │ ... │ ... │ ... │ ... ││
││axis 2│ │ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││8 @ 1 │ 9.97e+4 9.97e+4 ... 9.97e+4 9.98e+4 │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 │ ... │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 ││
+ ││8 @ 1 │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 │ ... │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 │ 9.98e+4 9.98e+4 ... 9.98e+4 9.98e+4 ││
││axis 2│ 1.00e+5 1.00e+5 ... 1.00e+5 1.00e+5 │ 1.00e+5 1.00e+5 ... 1.00e+5 1.00e+5 │ │ 1.00e+5 1.00e+5 ... 1.00e+5 1.00e+5 │ 1.00e+5 1.00e+5 ... 1.00e+5 1.00e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 1.04e+5 1.04e+5 ... 1.04e+5 1.04e+5 │ 1.04e+5 1.04e+5 ... 1.04e+5 1.04e+5 │ │ 1.04e+5 1.04e+5 ... 1.04e+5 1.04e+5 │ 1.04e+5 1.04e+5 ... 1.04e+5 1.04e+5 ││
@@ -659,7 +659,7 @@ let%expect_test "Very big tensor" =
││9 @ 1 │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ ... │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 ││
││axis 2│ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 │ 1.05e+5 1.05e+5 ... 1.05e+5 1.05e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.09e+5 1.09e+5 ... 1.09e+5 1.09e+5 │ 1.09e+5 1.09e+5 ... 1.09e+5 1.09e+5 │ │ 1.09e+5 1.09e+5 ... 1.09e+5 1.09e+5 │ 1.09e+5 1.09e+5 ... 1.09e+5 1.09e+5 ││
+ ││ │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 ││
││ │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 │ 1.10e+5 1.10e+5 ... 1.10e+5 1.10e+5 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
@@ -669,14 +669,14 @@ let%expect_test "Very big tensor" =
││4 @ 0 │0 @ 4 │1 @ 4 │~~~~~ │6 @ 4 │7 @ 4 ││
││ │axis 5 │axis 5 │axis 5│axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 1 │ 2.21e+5 2.21e+5 ... 2.21e+5 2.21e+5 │ 2.21e+5 2.21e+5 ... 2.21e+5 2.21e+5 │ ... │ 2.21e+5 2.21e+5 ... 2.21e+5 2.21e+5 │ 2.21e+5 2.21e+5 ... 2.21e+5 2.21e+5 ││
+ ││0 @ 1 │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ ... │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 ││
││axis 2│ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 │ 2.22e+5 2.22e+5 ... 2.22e+5 2.22e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 ││
- ││ │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 ││
+ ││ │ 2.26e+5 2.26e+5 ... 2.26e+5 2.26e+5 │ 2.26e+5 2.26e+5 ... 2.27e+5 2.27e+5 │ │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││1 @ 1 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ ... │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 ││
- ││axis 2│ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 ││
+ ││axis 2│ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ 2.27e+5 2.27e+5 ... 2.27e+5 2.27e+5 │ │ 2.28e+5 2.28e+5 ... 2.28e+5 2.28e+5 │ 2.28e+5 2.28e+5 ... 2.28e+5 2.28e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 2.31e+5 2.31e+5 ... 2.31e+5 2.31e+5 │ 2.31e+5 2.31e+5 ... 2.31e+5 2.31e+5 │ │ 2.31e+5 2.31e+5 ... 2.31e+5 2.31e+5 │ 2.31e+5 2.31e+5 ... 2.31e+5 2.31e+5 ││
││ │ 2.32e+5 2.32e+5 ... 2.32e+5 2.32e+5 │ 2.32e+5 2.32e+5 ... 2.32e+5 2.32e+5 │ │ 2.32e+5 2.32e+5 ... 2.32e+5 2.32e+5 │ 2.32e+5 2.32e+5 ... 2.32e+5 2.32e+5 ││
@@ -688,9 +688,9 @@ let%expect_test "Very big tensor" =
││axis 2│ 2.66e+5 2.66e+5 ... 2.66e+5 2.66e+5 │ 2.66e+5 2.66e+5 ... 2.66e+5 2.66e+5 │ │ 2.66e+5 2.66e+5 ... 2.66e+5 2.66e+5 │ 2.66e+5 2.66e+5 ... 2.66e+5 2.66e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 ││
- ││ │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 ││
+ ││ │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 │ 2.70e+5 2.70e+5 ... 2.70e+5 2.70e+5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││9 @ 1 │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ ... │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 │ 2.71e+5 2.71e+5 ... 2.71e+5 2.71e+5 ││
+ ││9 @ 1 │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ ... │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 ││
││axis 2│ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 │ 2.72e+5 2.72e+5 ... 2.72e+5 2.72e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 ││
@@ -701,32 +701,32 @@ let%expect_test "Very big tensor" =
││5 @ 0 │0 @ 4 │1 @ 4 │~~~~~ │6 @ 4 │7 @ 4 ││
││ │axis 5 │axis 5 │axis 5│axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 1 │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ ... │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 ││
- ││axis 2│ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 │ 2.77e+5 2.77e+5 ... 2.77e+5 2.77e+5 ││
+ ││0 @ 1 │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ ... │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 │ 2.76e+5 2.76e+5 ... 2.76e+5 2.76e+5 ││
+ ││axis 2│ 2.78e+5 2.78e+5 ... 2.78e+5 2.78e+5 │ 2.78e+5 2.78e+5 ... 2.78e+5 2.78e+5 │ │ 2.78e+5 2.78e+5 ... 2.78e+5 2.78e+5 │ 2.78e+5 2.78e+5 ... 2.78e+5 2.78e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 2.81e+5 2.81e+5 ... 2.81e+5 2.81e+5 │ 2.81e+5 2.81e+5 ... 2.81e+5 2.81e+5 │ │ 2.81e+5 2.81e+5 ... 2.81e+5 2.81e+5 │ 2.81e+5 2.81e+5 ... 2.81e+5 2.81e+5 ││
+ ││ │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 ││
││ │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││1 @ 1 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ ... │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 ││
- ││axis 2│ 2.83e+5 2.83e+5 ... 2.83e+5 2.83e+5 │ 2.83e+5 2.83e+5 ... 2.83e+5 2.83e+5 │ │ 2.83e+5 2.83e+5 ... 2.83e+5 2.83e+5 │ 2.83e+5 2.83e+5 ... 2.83e+5 2.83e+5 ││
+ ││axis 2│ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 │ 2.82e+5 2.82e+5 ... 2.82e+5 2.82e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 ││
- ││ │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 │ 2.87e+5 2.87e+5 ... 2.87e+5 2.87e+5 ││
+ ││ │ 2.86e+5 2.86e+5 ... 2.86e+5 2.86e+5 │ 2.86e+5 2.86e+5 ... 2.86e+5 2.86e+5 │ │ 2.86e+5 2.86e+5 ... 2.86e+5 2.86e+5 │ 2.86e+5 2.86e+5 ... 2.86e+5 2.86e+5 ││
+ ││ │ 2.88e+5 2.88e+5 ... 2.88e+5 2.88e+5 │ 2.88e+5 2.88e+5 ... 2.88e+5 2.88e+5 │ │ 2.88e+5 2.88e+5 ... 2.88e+5 2.88e+5 │ 2.88e+5 2.88e+5 ... 2.88e+5 2.88e+5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... │ ... ││
││axis 2│ │ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││8 @ 1 │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ ... │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 ││
- ││axis 2│ 3.22e+5 3.22e+5 ... 3.22e+5 3.22e+5 │ 3.22e+5 3.22e+5 ... 3.22e+5 3.22e+5 │ │ 3.22e+5 3.22e+5 ... 3.22e+5 3.22e+5 │ 3.22e+5 3.22e+5 ... 3.22e+5 3.22e+5 ││
+ ││axis 2│ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 │ 3.21e+5 3.21e+5 ... 3.21e+5 3.21e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 ││
- ││ │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 │ 3.26e+5 3.26e+5 ... 3.26e+5 3.26e+5 ││
+ ││ │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 ││
+ ││ │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ │ 3.25e+5 3.25e+5 ... 3.25e+5 3.25e+5 │ 3.25e+5 3.27e+5 ... 3.27e+5 3.27e+5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││9 @ 1 │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ ... │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 ││
││axis 2│ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 │ 3.27e+5 3.27e+5 ... 3.27e+5 3.27e+5 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
││ │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 ││
- ││ │ 3.32e+5 3.32e+5 ... 3.32e+5 3.32e+5 │ 3.32e+5 3.32e+5 ... 3.32e+5 3.32e+5 │ │ 3.32e+5 3.32e+5 ... 3.32e+5 3.32e+5 │ 3.32e+5 3.32e+5 ... 3.32e+5 3.32e+5 ││
+ ││ │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 │ 3.31e+5 3.31e+5 ... 3.31e+5 3.31e+5 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
└───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}];
@@ -740,11 +740,11 @@ let%expect_test "Very big tensor" =
││ │0 @ 0 │1 @ 0 │~~~~~ │4 @ 0 │5 @ 0 ││
││ │axis 2 │axis 2 │axis 2│axis 2 │axis 2 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││axis 1│ 2.53e+5 7.61e+5 ... 4.82e+6 5.33e+6 │ 5.61e+7 5.66e+7 ... 6.07e+7 6.12e+7 │ ... │ 2.23e+8 2.24e+8 ... 2.28e+8 2.28e+8 │ 2.79e+8 2.80e+8 ... 2.84e+8 2.84e+8 ││
- ││ │ 5.84e+6 6.34e+6 ... 1.04e+7 1.09e+7 │ 6.17e+7 6.22e+7 ... 6.62e+7 6.68e+7 │ │ 2.29e+8 2.29e+8 ... 2.33e+8 2.34e+8 │ 2.85e+8 2.85e+8 ... 2.89e+8 2.90e+8 ││
+ ││axis 1│ 2.59e+5 5.24e+5 ... 4.19e+6 4.19e+6 │ 3.35e+7 3.35e+7 ... 3.35e+7 3.35e+7 │ ... │ 1.34e+8 1.34e+8 ... 1.34e+8 1.34e+8 │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 ││
+ ││ │ 4.19e+6 4.19e+6 ... 8.38e+6 8.38e+6 │ 3.35e+7 3.35e+7 ... 6.71e+7 6.71e+7 │ │ 1.34e+8 1.34e+8 ... 1.34e+8 1.34e+8 │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 4.49e+7 4.54e+7 ... 4.95e+7 5.00e+7 │ 1.00e+8 1.01e+8 ... 1.05e+8 1.05e+8 │ │ 2.68e+8 2.69e+8 ... 2.73e+8 2.73e+8 │ 3.24e+8 3.24e+8 ... 3.28e+8 3.29e+8 ││
- ││ │ 5.05e+7 5.10e+7 ... 5.51e+7 5.56e+7 │ 1.06e+8 1.06e+8 ... 1.11e+8 1.11e+8 │ │ 2.74e+8 2.74e+8 ... 2.78e+8 2.79e+8 │ 3.29e+8 3.30e+8 ... 3.34e+8 3.35e+8 ││
+ ││ │ 3.35e+7 3.35e+7 ... 3.35e+7 3.35e+7 │ 6.71e+7 6.71e+7 ... 6.71e+7 6.71e+7 │ │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 ││
+ ││ │ 3.35e+7 3.35e+7 ... 3.35e+7 3.35e+7 │ 6.71e+7 6.71e+7 ... 6.71e+7 6.71e+7 │ │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 │ 2.68e+8 2.68e+8 ... 2.68e+8 2.68e+8 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
└───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}]
File "test/einsum_trivia.ml", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/default/test/einsum_trivia.ml _build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/einsum_trivia.ml.corrected
diff --git a/_build/default/test/einsum_trivia.ml b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/einsum_trivia.ml.corrected
index 162aa57..ed9a15a 100644
--- a/_build/default/test/einsum_trivia.ml
+++ b/_build/.sandbox/e1d7023915fc680c552db725b49b26bc/default/test/einsum_trivia.ml.corrected
@@ -79,87 +79,87 @@ let%expect_test "einsum1 permute axes" =
││1 @ 2 │ 1.40e+2 1.41e+2 1.42e+2 1.43e+2 1.44e+2 │ 1.45e+2 1.46e+2 1.47e+2 1.48e+2 1.49e+2 │ 1.50e+2 1.51e+2 1.52e+2 1.53e+2 1.54e+2 │ 1.55e+2 1.56e+2 1.57e+2 1.58e+2 1.59e+2 ││
││axis 3│ 1.60e+2 1.61e+2 1.62e+2 1.63e+2 1.64e+2 │ 1.65e+2 1.66e+2 1.67e+2 1.68e+2 1.69e+2 │ 1.70e+2 1.71e+2 1.72e+2 1.73e+2 1.74e+2 │ 1.75e+2 1.76e+2 1.77e+2 1.78e+2 1.79e+2 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 2.40e+2 2.41e+2 2.42e+2 2.43e+2 2.44e+2 │ 2.45e+2 2.46e+2 2.47e+2 2.48e+2 2.49e+2 │ 2.50e+2 2.51e+2 2.52e+2 2.53e+2 2.54e+2 │ 2.55e+2 2.56e+2 2.57e+2 2.58e+2 2.59e+2 ││
- ││ │ 2.60e+2 2.61e+2 2.62e+2 2.63e+2 2.64e+2 │ 2.65e+2 2.66e+2 2.67e+2 2.68e+22.69e+2 │ 2.70e+2 2.71e+2 2.72e+2 2.73e+2 2.74e+2 │ 2.75e+2 2.76e+2 2.77e+2 2.78e+2 2.79e+2 ││
+ ││ │ 2.40e+2 2.41e+2 2.42e+2 2.43e+2 2.44e+2 │ 2.45e+2 2.46e+2 2.47e+2 2.48e+2 2.49e+2 │ 2.50e+2 2.51e+2 2.52e+2 2.53e+2 2.54e+2 │ 2.55e+2 2.56e+2 2.56e+2 2.58e+2 2.60e+2 ││
+ ││ │ 2.60e+2 2.60e+2 2.62e+2 2.64e+2 2.64e+2 │ 2.64e+2 2.66e+2 2.68e+2 2.68e+2 2.68e+2 │ 2.70e+2 2.72e+2 2.72e+2 2.72e+2 2.74e+2 │ 2.76e+2 2.76e+2 2.76e+2 2.78e+2 2.80e+2 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││4 @ 2 │ 5.60e+2 5.61e+2 5.62e+2 5.63e+2 5.64e+2 │ 5.65e+2 5.66e+2 5.67e+2 5.68e+2 5.69e+2 │ 5.70e+2 5.71e+2 5.72e+2 5.73e+2 5.74e+2 │ 5.75e+2 5.76e+2 5.77e+2 5.78e+2 5.79e+2 ││
- ││axis 3│ 5.80e+2 5.81e+2 5.82e+2 5.83e+2 5.84e+2 │ 5.85e+2 5.86e+2 5.87e+2 5.88e+2 5.89e+2 │ 5.90e+2 5.91e+2 5.92e+2 5.93e+2 5.94e+2 │ 5.95e+2 5.96e+2 5.97e+2 5.98e+2 5.99e+2 ││
+ ││4 @ 2 │ 5.60e+2 5.60e+2 5.60e+2 5.64e+2 5.64e+2 │ 5.64e+2 5.68e+2 5.68e+2 5.68e+2 5.68e+2 │ 5.68e+2 5.72e+2 5.72e+2 5.72e+2 5.76e+2 │ 5.76e+2 5.76e+2 5.76e+2 5.76e+2 5.80e+2 ││
+ ││axis 3│ 5.80e+2 5.80e+2 5.84e+2 5.84e+2 5.84e+2 │ 5.84e+2 5.84e+2 5.88e+2 5.88e+2 5.88e+2 │ 5.92e+2 5.92e+2 5.92e+2 5.92e+2 5.92e+2 │ 5.96e+2 5.96e+2 5.96e+2 6.00e+2 6.00e+2 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 6.60e+2 6.61e+2 6.62e+2 6.63e+2 6.64e+2 │ 6.65e+2 6.66e+2 6.67e+2 6.68e+2 6.69e+2 │ 6.70e+2 6.71e+2 6.72e+2 6.73e+2 6.74e+2 │ 6.75e+2 6.76e+2 6.77e+2 6.78e+2 6.79e+2 ││
- ││ │ 6.80e+2 6.81e+2 6.82e+2 6.83e+2 6.84e+2 │ 6.85e+2 6.86e+2 6.87e+2 6.88e+2 6.89e+2 │ 6.90e+2 6.91e+2 6.92e+2 6.93e+2 6.94e+2 │ 6.95e+2 6.96e+2 6.97e+2 6.98e+2 6.99e+2 ││
+ ││ │ 6.60e+2 6.60e+2 6.64e+2 6.64e+2 6.64e+2 │ 6.64e+2 6.64e+2 6.68e+2 6.68e+2 6.68e+2 │ 6.72e+2 6.72e+2 6.72e+2 6.72e+2 6.72e+2 │ 6.76e+2 6.76e+2 6.76e+2 6.80e+2 6.80e+2 ││
+ ││ │ 6.80e+2 6.80e+2 6.80e+2 6.84e+2 6.84e+2 │ 6.84e+2 6.88e+2 6.88e+2 6.88e+2 6.88e+2 │ 6.88e+2 6.92e+2 6.92e+2 6.92e+2 6.96e+2 │ 6.96e+2 6.96e+2 6.96e+2 6.96e+2 7.00e+2 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││5 @ 2 │ 7.00e+2 7.01e+2 7.02e+2 7.03e+2 7.04e+2 │ 7.05e+2 7.06e+2 7.07e+2 7.08e+2 7.09e+2 │ 7.10e+2 7.11e+2 7.12e+2 7.13e+2 7.14e+2 │ 7.15e+2 7.16e+2 7.17e+2 7.18e+2 7.19e+2 ││
- ││axis 3│ 7.20e+2 7.21e+2 7.22e+2 7.23e+2 7.24e+2 │ 7.25e+2 7.26e+2 7.27e+2 7.28e+2 7.29e+2 │ 7.30e+2 7.31e+2 7.32e+2 7.33e+2 7.34e+2 │ 7.35e+2 7.36e+2 7.37e+2 7.38e+2 7.39e+2 ││
+ ││5 @ 2 │ 7.00e+2 7.00e+2 7.04e+2 7.04e+2 7.04e+2 │ 7.04e+2 7.04e+2 7.08e+2 7.08e+2 7.08e+2 │ 7.12e+2 7.12e+2 7.12e+2 7.12e+2 7.12e+2 │ 7.16e+2 7.16e+2 7.16e+2 7.20e+2 7.20e+2 ││
+ ││axis 3│ 7.20e+2 7.20e+2 7.20e+2 7.24e+2 7.24e+2 │ 7.24e+2 7.28e+2 7.28e+2 7.28e+2 7.28e+2 │ 7.28e+2 7.32e+2 7.32e+2 7.32e+2 7.36e+2 │ 7.36e+2 7.36e+2 7.36e+2 7.36e+2 7.40e+2 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 8.00e+2 8.01e+2 8.02e+2 8.03e+2 8.04e+2 │ 8.05e+2 8.06e+2 8.07e+2 8.08e+2 8.09e+2 │ 8.10e+2 8.11e+2 8.12e+2 8.13e+2 8.14e+2 │ 8.15e+2 8.16e+2 8.17e+2 8.18e+2 8.19e+2 ││
- ││ │ 8.20e+2 8.21e+2 8.22e+2 8.23e+2 8.24e+2 │ 8.25e+2 8.26e+2 8.27e+2 8.28e+2 8.29e+2 │ 8.30e+2 8.31e+2 8.32e+2 8.33e+2 8.34e+2 │ 8.35e+2 8.36e+2 8.37e+2 8.38e+2 8.39e+2 ││
+ ││ │ 8.00e+2 8.00e+2 8.00e+2 8.04e+2 8.04e+2 │ 8.04e+2 8.08e+2 8.08e+2 8.08e+2 8.08e+2 │ 8.08e+2 8.12e+2 8.12e+2 8.12e+2 8.16e+2 │ 8.16e+2 8.16e+2 8.16e+2 8.16e+2 8.20e+2 ││
+ ││ │ 8.20e+2 8.20e+2 8.24e+2 8.24e+2 8.24e+2 │ 8.24e+2 8.24e+2 8.28e+2 8.28e+2 8.28e+2 │ 8.32e+2 8.32e+2 8.32e+2 8.32e+2 8.32e+2 │ 8.36e+2 8.36e+2 8.36e+2 8.40e+2 8.40e+2 ││
│└──────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┐│
││1 @ 1 │0 @ 4 │1 @ 4 │2 @ 4 │3 @ 4 ││
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││0 @ 2 │ 8.40e+2 8.41e+2 8.42e+2 8.43e+2 8.44e+2 │ 8.45e+2 8.46e+2 8.47e+2 8.48e+2 8.49e+2 │ 8.50e+2 8.51e+2 8.52e+2 8.53e+2 8.54e+2 │ 8.55e+2 8.56e+2 8.57e+2 8.58e+2 8.59e+2 ││
- ││axis 3│ 8.60e+2 8.61e+2 8.62e+2 8.63e+2 8.64e+2 │ 8.65e+2 8.66e+2 8.67e+2 8.68e+2 8.69e+2 │ 8.70e+2 8.71e+2 8.72e+2 8.73e+2 8.74e+2 │ 8.75e+2 8.76e+2 8.77e+2 8.78e+2 8.79e+2 ││
+ ││0 @ 2 │ 8.40e+2 8.40e+2 8.40e+2 8.44e+2 8.44e+2 │ 8.44e+2 8.48e+2 8.48e+2 8.48e+2 8.48e+2 │ 8.48e+2 8.52e+2 8.52e+2 8.52e+2 8.56e+2 │ 8.56e+2 8.56e+2 8.56e+2 8.56e+2 8.60e+2 ││
+ ││axis 3│ 8.60e+2 8.60e+2 8.64e+2 8.64e+2 8.64e+2 │ 8.64e+2 8.64e+2 8.68e+2 8.68e+2 8.68e+2 │ 8.72e+2 8.72e+2 8.72e+2 8.72e+2 8.72e+2 │ 8.76e+2 8.76e+2 8.76e+2 8.80e+2 8.80e+2 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 9.40e+2 9.41e+2 9.42e+2 9.43e+2 9.44e+2 │ 9.45e+2 9.46e+2 9.47e+2 9.48e+2 9.49e+2 │ 9.50e+2 9.51e+2 9.52e+2 9.53e+2 9.54e+2 │ 9.55e+2 9.56e+2 9.57e+2 9.58e+2 9.59e+2 ││
- ││ │ 9.60e+2 9.61e+2 9.62e+2 9.63e+2 9.64e+2 │ 9.65e+2 9.66e+2 9.67e+2 9.68e+2 9.69e+2 │ 9.70e+2 9.71e+2 9.72e+2 9.73e+2 9.74e+2 │ 9.75e+2 9.76e+2 9.77e+2 9.78e+2 9.79e+2 ││
+ ││ │ 9.40e+2 9.40e+2 9.44e+2 9.44e+2 9.44e+2 │ 9.44e+2 9.44e+2 9.48e+2 9.48e+2 9.48e+2 │ 9.52e+2 9.52e+2 9.52e+2 9.52e+2 9.52e+2 │ 9.56e+2 9.56e+2 9.56e+2 9.60e+2 9.60e+2 ││
+ ││ │ 9.60e+2 9.60e+2 9.60e+2 9.64e+2 9.64e+2 │ 9.64e+2 9.68e+2 9.68e+2 9.68e+2 9.68e+2 │ 9.68e+2 9.72e+2 9.72e+2 9.72e+2 9.76e+2 │ 9.76e+2 9.76e+2 9.76e+2 9.76e+2 9.80e+2 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││1 @ 2 │ 9.80e+2 9.81e+2 9.82e+2 9.83e+2 9.84e+2 │ 9.85e+2 9.86e+2 9.87e+2 9.88e+2 9.89e+2 │ 9.90e+2 9.91e+2 9.92e+2 9.93e+2 9.94e+2 │ 9.95e+2 9.96e+2 9.97e+2 9.98e+2 9.99e+2 ││
- ││axis 3│ 1.00e+3 1.00e+3 1.00e+3 1.00e+3 1.00e+3 │ 1.00e+3 1.00e+3 1.00e+3 1.00e+3 1.00e+3 │ 1.01e+3 1.01e+3 1.01e+3 1.01e+3 1.01e+3 │ 1.01e+3 1.01e+3 1.01e+3 1.01e+3 1.01e+3 ││
+ ││1 @ 2 │ 9.80e+2 9.80e+2 9.84e+2 9.84e+2 9.84e+2 │ 9.84e+2 9.84e+2 9.88e+2 9.88e+2 9.88e+2 │ 9.92e+2 9.92e+2 9.92e+2 9.92e+2 9.92e+2 │ 9.96e+2 9.96e+2 9.96e+2 1.00e+3 1.00e+3 ││
+ ││axis 3│ 1.00e+3 1.00e+3 1.00e+3 1.00e+3 1.00e+3 │ 1.00e+3 1.00e+3 1.00e+3 1.00e+3 1.00e+3 │ 1.00e+3 1.01e+3 1.01e+3 1.01e+3 1.01e+3 │ 1.01e+3 1.01e+3 1.01e+3 1.01e+3 1.02e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.08e+3 1.08e+3 1.08e+3 1.08e+3 1.08e+3 │ 1.08e+3 1.08e+3 1.08e+3 1.08e+3 1.08e+3 │ 1.09e+3 1.09e+3 1.09e+3 1.09e+3 1.09e+3 │ 1.09e+3 1.09e+3 1.09e+3 1.09e+3 1.09e+3 ││
- ││ │ 1.10e+3 1.10e+3 1.10e+3 1.10e+3 1.10e+3 │ 1.10e+3 1.10e+3 1.10e+3 1.10e+3 1.10e+3 │ 1.11e+3 1.11e+3 1.11e+3 1.11e+3 1.11e+3 │ 1.11e+3 1.11e+3 1.11e+3 1.11e+3 1.11e+3 ││
+ ││ │ 1.08e+3 1.08e+3 1.08e+3 1.08e+3 1.08e+3 │ 1.08e+3 1.08e+3 1.08e+3 1.08e+3 1.08e+3 │ 1.08e+3 1.08e+3 1.08e+3 1.09e+3 1.09e+3 │ 1.09e+3 1.09e+3 1.09e+3 1.09e+3 1.09e+3 ││
+ ││ │ 1.10e+3 1.10e+3 1.10e+3 1.10e+3 1.10e+3 │ 1.10e+3 1.10e+3 1.10e+3 1.10e+3 1.11e+3 │ 1.11e+3 1.11e+3 1.11e+3 1.11e+3 1.11e+3 │ 1.11e+3 1.12e+3 1.12e+3 1.12e+3 1.12e+3 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││4 @ 2 │ 1.40e+3 1.40e+3 1.40e+3 1.40e+3 1.40e+3 │ 1.40e+3 1.40e+3 1.40e+3 1.40e+3 1.40e+3 │ 1.41e+3 1.41e+3 1.41e+3 1.41e+3 1.41e+3 │ 1.41e+3 1.41e+3 1.41e+3 1.41e+3 1.41e+3 ││
- ││axis 3│ 1.42e+3 1.42e+3 1.42e+3 1.42e+3 1.42e+3 │ 1.42e+3 1.42e+3 1.42e+3 1.42e+3 1.42e+3 │ 1.43e+3 1.43e+3 1.43e+3 1.43e+3 1.43e+3 │ 1.43e+3 1.43e+3 1.43e+3 1.43e+3 1.43e+3 ││
+ ││4 @ 2 │ 1.40e+3 1.40e+3 1.40e+3 1.40e+3 1.40e+3 │ 1.40e+3 1.40e+3 1.40e+3 1.40e+3 1.40e+3 │ 1.40e+3 1.40e+3 1.40e+3 1.41e+3 1.41e+3 │ 1.41e+3 1.41e+3 1.41e+3 1.41e+3 1.41e+3 ││
+ ││axis 3│ 1.42e+3 1.42e+3 1.42e+3 1.42e+3 1.42e+3 │ 1.42e+3 1.42e+3 1.42e+3 1.42e+3 1.43e+3 │ 1.43e+3 1.43e+3 1.43e+3 1.43e+3 1.43e+3 │ 1.43e+3 1.44e+3 1.44e+3 1.44e+3 1.44e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.50e+3 1.50e+3 1.50e+3 1.50e+3 1.50e+3 │ 1.50e+3 1.50e+3 1.50e+3 1.50e+3 1.50e+3 │ 1.51e+3 1.51e+3 1.51e+3 1.51e+3 1.51e+3 │ 1.51e+3 1.51e+3 1.51e+3 1.51e+3 1.51e+3 ││
- ││ │ 1.52e+3 1.52e+3 1.52e+3 1.52e+3 1.52e+3 │ 1.52e+3 1.52e+3 1.52e+3 1.52e+3 1.52e+3 │ 1.53e+3 1.53e+3 1.53e+3 1.53e+3 1.53e+3 │ 1.53e+3 1.53e+3 1.53e+3 1.53e+3 1.53e+3 ││
+ ││ │ 1.50e+3 1.50e+3 1.50e+3 1.50e+3 1.50e+3 │ 1.50e+3 1.50e+3 1.50e+3 1.50e+3 1.51e+3 │ 1.51e+3 1.51e+3 1.51e+3 1.51e+3 1.51e+3 │ 1.51e+3 1.52e+3 1.52e+3 1.52e+3 1.52e+3 ││
+ ││ │ 1.52e+3 1.52e+3 1.52e+3 1.52e+3 1.52e+3 │ 1.52e+3 1.52e+3 1.52e+3 1.52e+3 1.52e+3 │ 1.52e+3 1.52e+3 1.53e+3 1.53e+3 1.53e+3 │ 1.53e+3 1.53e+3 1.53e+3 1.53e+3 1.53e+3 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││5 @ 2 │ 1.54e+3 1.54e+3 1.54e+3 1.54e+3 1.54e+3 │ 1.54e+3 1.54e+3 1.54e+3 1.54e+3 1.54e+3 │ 1.55e+3 1.55e+3 1.55e+3 1.55e+3 1.55e+3 │ 1.55e+3 1.55e+3 1.55e+3 1.55e+3 1.55e+3 ││
- ││axis 3│ 1.56e+3 1.56e+3 1.56e+3 1.56e+3 1.56e+3 │ 1.56e+3 1.56e+3 1.56e+3 1.56e+3 1.56e+3 │ 1.57e+3 1.57e+3 1.57e+3 1.57e+3 1.57e+3 │ 1.57e+3 1.57e+3 1.57e+3 1.57e+3 1.57e+3 ││
+ ││5 @ 2 │ 1.53e+3 1.54e+3 1.54e+3 1.54e+3 1.54e+3 │ 1.54e+3 1.54e+3 1.54e+3 1.55e+3 1.55e+3 │ 1.55e+3 1.55e+3 1.55e+3 1.55e+3 1.55e+3 │ 1.55e+3 1.55e+3 1.56e+3 1.56e+3 1.56e+3 ││
+ ││axis 3│ 1.56e+3 1.56e+3 1.56e+3 1.56e+3 1.56e+3 │ 1.56e+3 1.56e+3 1.56e+3 1.56e+3 1.56e+3 │ 1.56e+3 1.56e+3 1.56e+3 1.57e+3 1.57e+3 │ 1.57e+3 1.57e+3 1.57e+3 1.57e+3 1.57e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.64e+3 1.64e+3 1.64e+3 1.64e+3 1.64e+3 │ 1.64e+3 1.64e+3 1.64e+3 1.64e+3 1.64e+3 │ 1.65e+3 1.65e+3 1.65e+3 1.65e+3 1.65e+3 │ 1.65e+3 1.65e+3 1.65e+3 1.65e+3 1.65e+3 ││
- ││ │ 1.66e+3 1.66e+3 1.66e+3 1.66e+3 1.66e+3 │ 1.66e+3 1.66e+3 1.66e+3 1.66e+3 1.66e+3 │ 1.67e+3 1.67e+3 1.67e+3 1.67e+3 1.67e+3 │ 1.67e+3 1.67e+3 1.67e+3 1.67e+3 1.67e+3 ││
+ ││ │ 1.64e+3 1.64e+3 1.64e+3 1.64e+3 1.64e+3 │ 1.64e+3 1.64e+3 1.64e+3 1.64e+3 1.64e+3 │ 1.64e+3 1.64e+3 1.64e+3 1.65e+3 1.65e+3 │ 1.65e+3 1.65e+3 1.65e+3 1.65e+3 1.65e+3 ││
+ ││ │ 1.66e+3 1.66e+3 1.66e+3 1.66e+3 1.66e+3 │ 1.66e+3 1.66e+3 1.66e+3 1.66e+3 1.67e+3 │ 1.67e+3 1.67e+3 1.67e+3 1.67e+3 1.67e+3 │ 1.67e+3 1.68e+3 1.68e+3 1.68e+3 1.68e+3 ││
│└──────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┬─────────────────────────────────────────────┐│
││2 @ 1 │0 @ 4 │1 @ 4 │2 @ 4 │3 @ 4 ││
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││0 @ 2 │ 1.68e+3 1.68e+3 1.68e+3 1.68e+3 1.68e+3 │ 1.68e+3 1.68e+3 1.68e+3 1.68e+3 1.68e+3 │ 1.69e+3 1.69e+3 1.69e+3 1.69e+3 1.69e+3 │ 1.69e+3 1.69e+3 1.69e+3 1.69e+3 1.69e+3 ││
- ││axis 3│ 1.70e+3 1.70e+3 1.70e+3 1.70e+3 1.70e+3 │ 1.70e+3 1.70e+3 1.70e+3 1.70e+3 1.70e+3 │ 1.71e+3 1.71e+3 1.71e+3 1.71e+3 1.71e+3 │ 1.71e+3 1.71e+3 1.71e+3 1.71e+3 1.71e+3 ││
+ ││0 @ 2 │ 1.68e+3 1.68e+3 1.68e+3 1.68e+3 1.68e+3 │ 1.68e+3 1.68e+3 1.68e+3 1.68e+3 1.68e+3 │ 1.68e+3 1.68e+3 1.69e+3 1.69e+3 1.69e+3 │ 1.69e+3 1.69e+3 1.69e+3 1.69e+3 1.69e+3 ││
+ ││axis 3│ 1.69e+3 1.70e+3 1.70e+3 1.70e+3 1.70e+3 │ 1.70e+3 1.70e+3 1.70e+3 1.71e+3 1.71e+3 │ 1.71e+3 1.71e+3 1.71e+3 1.71e+3 1.71e+3 │ 1.71e+3 1.71e+3 1.72e+3 1.72e+3 1.72e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.78e+3 1.78e+3 1.78e+3 1.78e+3 1.78e+3 │ 1.78e+3 1.78e+3 1.78e+3 1.78e+3 1.78e+3 │ 1.79e+3 1.79e+3 1.79e+3 1.79e+3 1.79e+3 │ 1.79e+3 1.79e+3 1.79e+3 1.79e+3 1.79e+3 ││
- ││ │ 1.80e+3 1.80e+3 1.80e+3 1.80e+3 1.80e+3 │ 1.80e+3 1.80e+3 1.80e+3 1.80e+3 1.80e+3 │ 1.81e+3 1.81e+3 1.81e+3 1.81e+3 1.81e+3 │ 1.81e+3 1.81e+3 1.81e+3 1.81e+3 1.81e+3 ││
+ ││ │ 1.77e+3 1.78e+3 1.78e+3 1.78e+3 1.78e+3 │ 1.78e+3 1.78e+3 1.78e+3 1.79e+3 1.79e+3 │ 1.79e+3 1.79e+3 1.79e+3 1.79e+3 1.79e+3 │ 1.79e+3 1.79e+3 1.80e+3 1.80e+3 1.80e+3 ││
+ ││ │ 1.80e+3 1.80e+3 1.80e+3 1.80e+3 1.80e+3 │ 1.80e+3 1.80e+3 1.80e+3 1.80e+3 1.80e+3 │ 1.80e+3 1.80e+3 1.80e+3 1.81e+3 1.81e+3 │ 1.81e+3 1.81e+3 1.81e+3 1.81e+3 1.81e+3 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││1 @ 2 │ 1.82e+3 1.82e+3 1.82e+3 1.82e+3 1.82e+3 │ 1.82e+3 1.82e+3 1.82e+3 1.82e+3 1.82e+3 │ 1.83e+3 1.83e+3 1.83e+3 1.83e+3 1.83e+3 │ 1.83e+3 1.83e+3 1.83e+3 1.83e+3 1.83e+3 ││
- ││axis 3│ 1.84e+3 1.84e+3 1.84e+3 1.84e+3 1.84e+3 │ 1.84e+3 1.84e+3 1.84e+3 1.84e+3 1.84e+3 │ 1.85e+3 1.85e+3 1.85e+3 1.85e+3 1.85e+3 │ 1.85e+3 1.85e+3 1.85e+3 1.85e+3 1.85e+3 ││
+ ││1 @ 2 │ 1.82e+3 1.82e+3 1.82e+3 1.82e+3 1.82e+3 │ 1.82e+3 1.82e+3 1.82e+3 1.82e+3 1.83e+3 │ 1.83e+3 1.83e+3 1.83e+3 1.83e+3 1.83e+3 │ 1.83e+3 1.84e+3 1.84e+3 1.84e+3 1.84e+3 ││
+ ││axis 3│ 1.84e+3 1.84e+3 1.84e+3 1.84e+3 1.84e+3 │ 1.84e+3 1.84e+3 1.84e+3 1.84e+3 1.84e+3 │ 1.84e+3 1.84e+3 1.85e+3 1.85e+3 1.85e+3 │ 1.85e+3 1.85e+3 1.85e+3 1.85e+3 1.85e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 1.92e+3 1.92e+3 1.92e+3 1.92e+3 1.92e+3 │ 1.92e+3 1.92e+3 1.92e+3 1.92e+3 1.92e+3 │ 1.93e+3 1.93e+3 1.93e+3 1.93e+3 1.93e+3 │ 1.93e+3 1.93e+3 1.93e+3 1.93e+3 1.93e+3 ││
- ││ │ 1.94e+3 1.94e+3 1.94e+3 1.94e+3 1.94e+3 │ 1.94e+3 1.94e+3 1.94e+3 1.94e+3 1.94e+3 │ 1.95e+3 1.95e+3 1.95e+3 1.95e+3 1.95e+3 │ 1.95e+3 1.95e+3 1.95e+3 1.95e+3 1.95e+3 ││
+ ││ │ 1.92e+3 1.92e+3 1.92e+3 1.92e+3 1.92e+3 │ 1.92e+3 1.92e+3 1.92e+3 1.92e+3 1.92e+3 │ 1.92e+3 1.92e+3 1.93e+3 1.93e+3 1.93e+3 │ 1.93e+3 1.93e+3 1.93e+3 1.93e+3 1.93e+3 ││
+ ││ │ 1.93e+3 1.94e+3 1.94e+3 1.94e+3 1.94e+3 │ 1.94e+3 1.94e+3 1.94e+3 1.95e+3 1.95e+3 │ 1.95e+3 1.95e+3 1.95e+3 1.95e+3 1.95e+3 │ 1.95e+3 1.95e+3 1.96e+3 1.96e+3 1.96e+3 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││4 @ 2 │ 2.24e+3 2.24e+3 2.24e+3 2.24e+3 2.24e+3 │ 2.24e+3 2.24e+3 2.24e+3 2.24e+3 2.24e+3 │ 2.25e+3 2.25e+3 2.25e+3 2.25e+3 2.25e+3 │ 2.25e+3 2.25e+3 2.25e+3 2.25e+3 2.25e+3 ││
- ││axis 3│ 2.26e+3 2.26e+3 2.26e+3 2.26e+3 2.26e+3 │ 2.26e+3 2.26e+3 2.26e+3 2.26e+3 2.26e+3 │ 2.27e+3 2.27e+3 2.27e+3 2.27e+3 2.27e+3 │ 2.27e+3 2.27e+3 2.27e+3 2.27e+3 2.27e+3 ││
+ ││4 @ 2 │ 2.24e+3 2.24e+3 2.24e+3 2.24e+3 2.24e+3 │ 2.24e+3 2.24e+3 2.24e+3 2.24e+3 2.25e+3 │ 2.25e+3 2.25e+3 2.25e+3 2.25e+3 2.25e+3 │ 2.25e+3 2.25e+3 2.25e+3 2.25e+3 2.25e+3 ││
+ ││axis 3│ 2.25e+3 2.25e+3 2.25e+3 2.25e+3 2.27e+3 │ 2.27e+3 2.27e+3 2.27e+3 2.27e+3 2.27e+3 │ 2.27e+3 2.27e+3 2.27e+3 2.27e+3 2.27e+3 │ 2.27e+3 2.27e+3 2.27e+3 2.27e+3 2.27e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 2.34e+3 2.34e+3 2.34e+3 2.34e+3 2.34e+3 │ 2.34e+3 2.34e+3 2.34e+3 2.34e+3 2.34e+3 │ 2.35e+3 2.35e+3 2.35e+3 2.35e+3 2.35e+3 │ 2.35e+3 2.35e+3 2.35e+3 2.35e+3 2.35e+3 ││
- ││ │ 2.36e+3 2.36e+3 2.36e+3 2.36e+3 2.36e+3 │ 2.36e+3 2.36e+3 2.36e+3 2.36e+3 2.36e+3 │ 2.37e+3 2.37e+3 2.37e+3 2.37e+3 2.37e+3 │ 2.37e+3 2.37e+3 2.37e+3 2.37e+3 2.37e+3 ││
+ ││ │ 2.33e+3 2.33e+3 2.33e+3 2.33e+3 2.33e+3 │ 2.35e+3 2.35e+3 2.35e+3 2.35e+3 2.35e+3 │ 2.35e+3 2.35e+3 2.35e+3 2.35e+3 2.35e+3 │ 2.35e+3 2.35e+3 2.35e+3 2.35e+3 2.35e+3 ││
+ ││ │ 2.36e+3 2.36e+3 2.36e+3 2.36e+3 2.36e+3 │ 2.36e+3 2.36e+3 2.36e+3 2.36e+3 2.36e+3 │ 2.36e+3 2.36e+3 2.36e+3 2.36e+3 2.36e+3 │ 2.36e+3 2.36e+3 2.38e+3 2.38e+3 2.38e+3 ││
│├──────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┼─────────────────────────────────────────────┤│
- ││5 @ 2 │ 2.38e+3 2.38e+3 2.38e+3 2.38e+3 2.38e+3 │ 2.38e+3 2.38e+3 2.38e+3 2.38e+3 2.38e+3 │ 2.39e+3 2.39e+3 2.39e+3 2.39e+3 2.39e+3 │ 2.39e+3 2.39e+3 2.39e+3 2.39e+3 2.39e+3 ││
- ││axis 3│ 2.40e+3 2.40e+3 2.40e+3 2.40e+3 2.40e+3 │ 2.40e+3 2.40e+3 2.40e+3 2.40e+3 2.40e+3 │ 2.41e+3 2.41e+3 2.41e+3 2.41e+3 2.41e+3 │ 2.41e+3 2.41e+3 2.41e+3 2.41e+3 2.41e+3 ││
+ ││5 @ 2 │ 2.38e+3 2.38e+3 2.38e+3 2.38e+3 2.38e+3 │ 2.38e+3 2.38e+3 2.38e+3 2.38e+3 2.38e+3 │ 2.38e+3 2.38e+3 2.40e+3 2.40e+3 2.40e+3 │ 2.40e+3 2.40e+3 2.40e+3 2.40e+3 2.40e+3 ││
+ ││axis 3│ 2.40e+3 2.40e+3 2.40e+3 2.40e+3 2.40e+3 │ 2.40e+3 2.40e+3 2.40e+3 2.40e+3 2.41e+3 │ 2.41e+3 2.41e+3 2.41e+3 2.41e+3 2.41e+3 │ 2.41e+3 2.41e+3 2.41e+3 2.41e+3 2.41e+3 ││
││ │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... │ ... ... ... ... ... ││
- ││ │ 2.48e+3 2.48e+3 2.48e+3 2.48e+3 2.48e+3 │ 2.48e+3 2.48e+3 2.48e+3 2.48e+3 2.48e+3 │ 2.49e+3 2.49e+3 2.49e+3 2.49e+3 2.49e+3 │ 2.49e+3 2.49e+3 2.49e+3 2.49e+3 2.49e+3 ││
- ││ │ 2.50e+3 2.50e+3 2.50e+3 2.50e+3 2.50e+3 │ 2.50e+3 2.50e+3 2.50e+3 2.50e+3 2.50e+3 │ 2.51e+3 2.51e+3 2.51e+3 2.51e+3 2.51e+3 │ 2.51e+3 2.51e+3 2.51e+3 2.51e+3 2.51e+3 ││
+ ││ │ 2.48e+3 2.48e+3 2.48e+3 2.48e+3 2.48e+3 │ 2.48e+3 2.48e+3 2.48e+3 2.49e+3 2.49e+3 │ 2.49e+3 2.49e+3 2.49e+3 2.49e+3 2.49e+3 │ 2.49e+3 2.49e+3 2.49e+3 2.49e+3 2.49e+3 ││
+ ││ │ 2.49e+3 2.49e+3 2.49e+3 2.49e+3 2.49e+3 │ 2.51e+3 2.51e+3 2.51e+3 2.51e+3 2.51e+3 │ 2.51e+3 2.51e+3 2.51e+3 2.51e+3 2.51e+3 │ 2.51e+3 2.51e+3 2.51e+3 2.51e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┴─────────────────────────────────────────────┘│
└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}];
@@ -172,50 +172,50 @@ let%expect_test "einsum1 permute axes" =
││0 @ 1 │0 @ 4 │1 @ 4 ││
││ │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 2 │ 0.00 1.40e+2 ... 5.60e+2 7.00e+2 │ 2.52e+3 2.66e+3 ... 3.08e+3 3.22e+3 ││
- ││axis 3│ 8.40e+2 9.80e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
- ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.20e+3 4.34e+3 ... 4.76e+3 4.90e+3 ││
+ ││0 @ 2 │ 0.00 1.40e+2 ... 5.60e+2 7.00e+2 │ 2.52e+3 2.65e+3 ... 3.07e+3 3.21e+3 ││
+ ││axis 3│ 8.40e+2 9.80e+2 ... 1.40e+3 1.53e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
+ ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.19e+3 4.35e+3 ... 4.76e+3 4.89e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 1.00 1.41e+2 ... 5.61e+2 7.01e+2 │ 2.52e+3 2.66e+3 ... 3.08e+3 3.22e+3 ││
- ││axis 3│ 8.41e+2 9.81e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
- ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.20e+3 4.34e+3 ... 4.76e+3 4.90e+3 ││
+ ││1 @ 2 │ 1.00 1.41e+2 ... 5.60e+2 7.00e+2 │ 2.52e+3 2.65e+3 ... 3.08e+3 3.21e+3 ││
+ ││axis 3│ 8.40e+2 9.80e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
+ ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.19e+3 4.35e+3 ... 4.76e+3 4.89e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││2 @ 2 │ 2.00 1.42e+2 ... 5.62e+2 7.02e+2 │ 2.52e+3 2.66e+3 ... 3.08e+3 3.22e+3 ││
- ││axis 3│ 8.42e+2 9.82e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
- ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.20e+3 4.34e+3 ... 4.76e+3 4.90e+3 ││
+ ││2 @ 2 │ 2.00 1.42e+2 ... 5.60e+2 7.04e+2 │ 2.52e+3 2.65e+3 ... 3.08e+3 3.21e+3 ││
+ ││axis 3│ 8.40e+2 9.84e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
+ ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.19e+3 4.35e+3 ... 4.76e+3 4.89e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││3 @ 2 │ 3.00 1.43e+2 ... 5.63e+2 7.03e+2 │ 2.52e+3 2.66e+3 ... 3.08e+3 3.22e+3 ││
- ││axis 3│ 8.43e+2 9.83e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
- ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.20e+3 4.34e+3 ... 4.76e+3 4.90e+3 ││
+ ││3 @ 2 │ 3.00 1.43e+2 ... 5.64e+2 7.04e+2 │ 2.52e+3 2.65e+3 ... 3.08e+3 3.21e+3 ││
+ ││axis 3│ 8.44e+2 9.84e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
+ ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.19e+3 4.35e+3 ... 4.76e+3 4.89e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 4.00 1.44e+2 ... 5.64e+2 7.04e+2 │ 2.52e+3 2.66e+3 ... 3.08e+3 3.22e+3 ││
+ ││4 @ 2 │ 4.00 1.44e+2 ... 5.64e+2 7.04e+2 │ 2.52e+3 2.65e+3 ... 3.08e+3 3.23e+3 ││
││axis 3│ 8.44e+2 9.84e+2 ... 1.40e+3 1.54e+3 │ 3.36e+3 3.50e+3 ... 3.92e+3 4.06e+3 ││
- ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.20e+3 4.34e+3 ... 4.76e+3 4.90e+3 ││
+ ││ │ 1.68e+3 1.82e+3 ... 2.24e+3 2.38e+3 │ 4.19e+3 4.35e+3 ... 4.76e+3 4.89e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
││1 @ 1 │0 @ 4 │1 @ 4 ││
││ │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 2 │ 2.00e+1 1.60e+2 ... 5.80e+2 7.20e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
- ││axis 3│ 8.60e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.38e+3 3.52e+3 ... 3.94e+3 4.08e+3 ││
- ││ │ 1.70e+3 1.84e+3 ... 2.26e+3 2.40e+3 │ 4.22e+3 4.36e+3 ... 4.78e+3 4.92e+3 ││
+ ││0 @ 2 │ 2.00e+1 1.60e+2 ... 5.80e+2 7.20e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.23e+3 ││
+ ││axis 3│ 8.60e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.37e+3 3.52e+3 ... 3.93e+3 4.08e+3 ││
+ ││ │ 1.69e+3 1.84e+3 ... 2.25e+3 2.40e+3 │ 4.22e+3 4.35e+3 ... 4.76e+3 4.92e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 2.10e+1 1.61e+2 ... 5.81e+2 7.21e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
- ││axis 3│ 8.61e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.38e+3 3.52e+3 ... 3.94e+3 4.08e+3 ││
- ││ │ 1.70e+3 1.84e+3 ... 2.26e+3 2.40e+3 │ 4.22e+3 4.36e+3 ... 4.78e+3 4.92e+3 ││
+ ││1 @ 2 │ 2.10e+1 1.61e+2 ... 5.80e+2 7.20e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
+ ││axis 3│ 8.60e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.37e+3 3.52e+3 ... 3.93e+3 4.08e+3 ││
+ ││ │ 1.70e+3 1.84e+3 ... 2.25e+3 2.40e+3 │ 4.22e+3 4.35e+3 ... 4.76e+3 4.92e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││2 @ 2 │ 2.20e+1 1.62e+2 ... 5.82e+2 7.22e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
- ││axis 3│ 8.62e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.38e+3 3.52e+3 ... 3.94e+3 4.08e+3 ││
- ││ │ 1.70e+3 1.84e+3 ... 2.26e+3 2.40e+3 │ 4.22e+3 4.36e+3 ... 4.78e+3 4.92e+3 ││
+ ││2 @ 2 │ 2.20e+1 1.62e+2 ... 5.84e+2 7.20e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
+ ││axis 3│ 8.64e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.37e+3 3.52e+3 ... 3.93e+3 4.08e+3 ││
+ ││ │ 1.70e+3 1.84e+3 ... 2.25e+3 2.40e+3 │ 4.22e+3 4.35e+3 ... 4.76e+3 4.92e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││3 @ 2 │ 2.30e+1 1.63e+2 ... 5.83e+2 7.23e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
- ││axis 3│ 8.63e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.38e+3 3.52e+3 ... 3.94e+3 4.08e+3 ││
- ││ │ 1.70e+3 1.84e+3 ... 2.26e+3 2.40e+3 │ 4.22e+3 4.36e+3 ... 4.78e+3 4.92e+3 ││
+ ││3 @ 2 │ 2.30e+1 1.63e+2 ... 5.84e+2 7.24e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
+ ││axis 3│ 8.64e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.37e+3 3.52e+3 ... 3.93e+3 4.08e+3 ││
+ ││ │ 1.70e+3 1.84e+3 ... 2.25e+3 2.40e+3 │ 4.22e+3 4.35e+3 ... 4.76e+3 4.92e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││4 @ 2 │ 2.40e+1 1.64e+2 ... 5.84e+2 7.24e+2 │ 2.54e+3 2.68e+3 ... 3.10e+3 3.24e+3 ││
- ││axis 3│ 8.64e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.38e+3 3.52e+3 ... 3.94e+3 4.08e+3 ││
- ││ │ 1.70e+3 1.84e+3 ... 2.26e+3 2.40e+3 │ 4.22e+3 4.36e+3 ... 4.78e+3 4.92e+3 ││
+ ││axis 3│ 8.64e+2 1.00e+3 ... 1.42e+3 1.56e+3 │ 3.39e+3 3.52e+3 ... 3.93e+3 4.08e+3 ││
+ ││ │ 1.70e+3 1.84e+3 ... 2.27e+3 2.40e+3 │ 4.22e+3 4.35e+3 ... 4.80e+3 4.92e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────┤
│ ... │
@@ -224,25 +224,25 @@ let%expect_test "einsum1 permute axes" =
││5 @ 1 │0 @ 4 │1 @ 4 ││
││ │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││0 @ 2 │ 1.00e+2 2.40e+2 ... 6.60e+2 8.00e+2 │ 2.62e+3 2.76e+3 ... 3.18e+3 3.32e+3 ││
- ││axis 3│ 9.40e+2 1.08e+3 ... 1.50e+3 1.64e+3 │ 3.46e+3 3.60e+3 ... 4.02e+3 4.16e+3 ││
...TRUNCATED BY DUNE...
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 5.60e+2 5.80e+2 ... 6.60e+2 6.80e+2 │ 5.65e+2 5.85e+2 ... 6.65e+2 6.85e+2 │ 5.70e+2 5.90e+2 ... 6.70e+2 6.90e+2 │ 5.75e+2 5.95e+2 ... 6.75e+2 6.95e+2 ││
- ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
- ││ │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 ││
+ ││4 @ 2 │ 5.60e+2 5.80e+2 ... 6.60e+2 6.80e+2 │ 5.64e+2 5.84e+2 ... 6.64e+2 6.84e+2 │ 5.68e+2 5.92e+2 ... 6.72e+2 6.88e+2 │ 5.76e+2 5.96e+2 ... 6.76e+2 6.96e+2 ││
+ ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.43e+3 ... 1.51e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
+ ││ │ 2.24e+3 2.25e+3 ... 2.33e+3 2.36e+3 │ 2.24e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││5 @ 2 │ 7.00e+2 7.20e+2 ... 8.00e+2 8.20e+2 │ 7.05e+2 7.25e+2 ... 8.05e+2 8.25e+2 │ 7.10e+2 7.30e+2 ... 8.10e+2 8.30e+2 │ 7.15e+2 7.35e+2 ... 8.15e+2 8.35e+2 ││
- ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
- ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
+ ││5 @ 2 │ 7.00e+2 7.20e+2 ... 8.00e+2 8.20e+2 │ 7.04e+2 7.24e+2 ... 8.04e+2 8.24e+2 │ 7.12e+2 7.28e+2 ... 8.08e+2 8.32e+2 │ 7.16e+2 7.36e+2 ... 8.16e+2 8.36e+2 ││
+ ││axis 3│ 1.53e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.56e+3 ... 1.64e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
+ ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.49e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.51e+3 │ 2.38e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
@@ -905,23 +905,23 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││0 @ 2 │ 1.00 2.10e+1 ... 1.01e+2 1.21e+2 │ 6.00 2.60e+1 ... 1.06e+2 1.26e+2 │ 1.10e+1 3.10e+1 ... 1.11e+2 1.31e+2 │ 1.60e+1 3.60e+1 ... 1.16e+2 1.36e+2 ││
- ││axis 3│ 8.41e+2 8.61e+2 ... 9.41e+2 9.61e+2 │ 8.46e+2 8.66e+2 ... 9.46e+2 9.66e+2 │ 8.51e+2 8.71e+2 ... 9.51e+2 9.71e+2 │ 8.56e+2 8.76e+2 ... 9.56e+2 9.76e+2 ││
- ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 ││
+ ││axis 3│ 8.40e+2 8.60e+2 ... 9.40e+2 9.60e+2 │ 8.48e+2 8.64e+2 ... 9.44e+2 9.68e+2 │ 8.52e+2 8.72e+2 ... 9.52e+2 9.72e+2 │ 8.56e+2 8.76e+2 ... 9.56e+2 9.76e+2 ││
+ ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.71e+3 ... 1.79e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 1.41e+2 1.61e+2 ... 2.41e+2 2.61e+2 │ 1.46e+2 1.66e+2 ... 2.46e+2 2.66e+2 │ 1.51e+2 1.71e+2 ... 2.51e+2 2.71e+2 │ 1.56e+2 1.76e+2 ... 2.56e+2 2.76e+2 ││
- ││axis 3│ 9.81e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.86e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.91e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 9.96e+2 1.01e+3 ... 1.09e+3 1.11e+3 ││
- ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 ││
+ ││1 @ 2 │ 1.41e+2 1.61e+2 ... 2.41e+2 2.60e+2 │ 1.46e+2 1.66e+2 ... 2.46e+2 2.66e+2 │ 1.51e+2 1.71e+2 ... 2.51e+2 2.72e+2 │ 1.56e+2 1.76e+2 ... 2.56e+2 2.76e+2 ││
+ ││axis 3│ 9.80e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.84e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.92e+2 1.01e+3 ... 1.08e+3 1.11e+3 │ 9.96e+2 1.01e+3 ... 1.09e+3 1.12e+3 ││
+ ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.84e+3 ... 1.92e+3 1.95e+3 │ 1.84e+3 1.85e+3 ... 1.93e+3 1.95e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 5.61e+2 5.81e+2 ... 6.61e+2 6.81e+2 │ 5.66e+2 5.86e+2 ... 6.66e+2 6.86e+2 │ 5.71e+2 5.91e+2 ... 6.71e+2 6.91e+2 │ 5.76e+2 5.96e+2 ... 6.76e+2 6.96e+2 ││
- ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
- ││ │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 ││
+ ││4 @ 2 │ 5.60e+2 5.80e+2 ... 6.60e+2 6.80e+2 │ 5.68e+2 5.84e+2 ... 6.64e+2 6.88e+2 │ 5.72e+2 5.92e+2 ... 6.72e+2 6.92e+2 │ 5.76e+2 5.96e+2 ... 6.76e+2 6.96e+2 ││
+ ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.43e+3 ... 1.51e+3 1.52e+3 │ 1.41e+3 1.44e+3 ... 1.52e+3 1.53e+3 ││
+ ││ │ 2.24e+3 2.25e+3 ... 2.33e+3 2.36e+3 │ 2.24e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││5 @ 2 │ 7.01e+2 7.21e+2 ... 8.01e+2 8.21e+2 │ 7.06e+2 7.26e+2 ... 8.06e+2 8.26e+2 │ 7.11e+2 7.31e+2 ... 8.11e+2 8.31e+2 │ 7.16e+2 7.36e+2 ... 8.16e+2 8.36e+2 ││
- ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
- ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
+ ││5 @ 2 │ 7.00e+2 7.20e+2 ... 8.00e+2 8.20e+2 │ 7.04e+2 7.28e+2 ... 8.08e+2 8.24e+2 │ 7.12e+2 7.32e+2 ... 8.12e+2 8.32e+2 │ 7.16e+2 7.36e+2 ... 8.16e+2 8.36e+2 ││
+ ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.56e+3 ... 1.64e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.68e+3 ││
+ ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.49e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.51e+3 │ 2.38e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
@@ -929,23 +929,23 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││0 @ 2 │ 2.00 2.20e+1 ... 1.02e+2 1.22e+2 │ 7.00 2.70e+1 ... 1.07e+2 1.27e+2 │ 1.20e+1 3.20e+1 ... 1.12e+2 1.32e+2 │ 1.70e+1 3.70e+1 ... 1.17e+2 1.37e+2 ││
- ││axis 3│ 8.42e+2 8.62e+2 ... 9.42e+2 9.62e+2 │ 8.47e+2 8.67e+2 ... 9.47e+2 9.67e+2 │ 8.52e+2 8.72e+2 ... 9.52e+2 9.72e+2 │ 8.57e+2 8.77e+2 ... 9.57e+2 9.77e+2 ││
- ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 ││
+ ││axis 3│ 8.40e+2 8.64e+2 ... 9.44e+2 9.60e+2 │ 8.48e+2 8.68e+2 ... 9.48e+2 9.68e+2 │ 8.52e+2 8.72e+2 ... 9.52e+2 9.72e+2 │ 8.56e+2 8.76e+2 ... 9.56e+2 9.76e+2 ││
+ ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.80e+3 │ 1.69e+3 1.72e+3 ... 1.80e+3 1.81e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 1.42e+2 1.62e+2 ... 2.42e+2 2.62e+2 │ 1.47e+2 1.67e+2 ... 2.47e+2 2.67e+2 │ 1.52e+2 1.72e+2 ... 2.52e+2 2.72e+2 │ 1.57e+2 1.77e+2 ... 2.57e+2 2.77e+2 ││
- ││axis 3│ 9.82e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.87e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.92e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 9.97e+2 1.01e+3 ... 1.09e+3 1.11e+3 ││
- ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 ││
+ ││1 @ 2 │ 1.42e+2 1.62e+2 ... 2.42e+2 2.62e+2 │ 1.47e+2 1.67e+2 ... 2.47e+2 2.68e+2 │ 1.52e+2 1.72e+2 ... 2.52e+2 2.72e+2 │ 1.57e+2 1.77e+2 ... 2.56e+2 2.76e+2 ││
+ ││axis 3│ 9.84e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.88e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.92e+2 1.01e+3 ... 1.08e+3 1.11e+3 │ 9.96e+2 1.01e+3 ... 1.09e+3 1.12e+3 ││
+ ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.84e+3 1.85e+3 ... 1.93e+3 1.96e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 5.62e+2 5.82e+2 ... 6.62e+2 6.82e+2 │ 5.67e+2 5.87e+2 ... 6.67e+2 6.87e+2 │ 5.72e+2 5.92e+2 ... 6.72e+2 6.92e+2 │ 5.77e+2 5.97e+2 ... 6.77e+2 6.97e+2 ││
- ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
- ││ │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 ││
+ ││4 @ 2 │ 5.60e+2 5.84e+2 ... 6.64e+2 6.80e+2 │ 5.68e+2 5.88e+2 ... 6.68e+2 6.88e+2 │ 5.72e+2 5.92e+2 ... 6.72e+2 6.92e+2 │ 5.76e+2 5.96e+2 ... 6.76e+2 6.96e+2 ││
+ ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.44e+3 ... 1.52e+3 1.53e+3 ││
+ ││ │ 2.24e+3 2.25e+3 ... 2.33e+3 2.36e+3 │ 2.24e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.38e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││5 @ 2 │ 7.02e+2 7.22e+2 ... 8.02e+2 8.22e+2 │ 7.07e+2 7.27e+2 ... 8.07e+2 8.27e+2 │ 7.12e+2 7.32e+2 ... 8.12e+2 8.32e+2 │ 7.17e+2 7.37e+2 ... 8.17e+2 8.37e+2 ││
- ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
- ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
+ ││5 @ 2 │ 7.04e+2 7.20e+2 ... 8.00e+2 8.24e+2 │ 7.08e+2 7.28e+2 ... 8.08e+2 8.28e+2 │ 7.12e+2 7.32e+2 ... 8.12e+2 8.32e+2 │ 7.16e+2 7.36e+2 ... 8.16e+2 8.36e+2 ││
+ ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.56e+3 ... 1.64e+3 1.67e+3 │ 1.56e+3 1.57e+3 ... 1.65e+3 1.68e+3 ││
+ ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.49e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
@@ -953,23 +953,23 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││0 @ 2 │ 3.00 2.30e+1 ... 1.03e+2 1.23e+2 │ 8.00 2.80e+1 ... 1.08e+2 1.28e+2 │ 1.30e+1 3.30e+1 ... 1.13e+2 1.33e+2 │ 1.80e+1 3.80e+1 ... 1.18e+2 1.38e+2 ││
- ││axis 3│ 8.43e+2 8.63e+2 ... 9.43e+2 9.63e+2 │ 8.48e+2 8.68e+2 ... 9.48e+2 9.68e+2 │ 8.53e+2 8.73e+2 ... 9.53e+2 9.73e+2 │ 8.58e+2 8.78e+2 ... 9.58e+2 9.78e+2 ││
- ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 ││
+ ││axis 3│ 8.44e+2 8.64e+2 ... 9.44e+2 9.64e+2 │ 8.48e+2 8.68e+2 ... 9.48e+2 9.68e+2 │ 8.52e+2 8.72e+2 ... 9.52e+2 9.72e+2 │ 8.56e+2 8.80e+2 ... 9.60e+2 9.76e+2 ││
+ ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.71e+3 ... 1.79e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.72e+3 ... 1.80e+3 1.81e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 1.43e+2 1.63e+2 ... 2.43e+2 2.63e+2 │ 1.48e+2 1.68e+2 ... 2.48e+2 2.68e+2 │ 1.53e+2 1.73e+2 ... 2.53e+2 2.73e+2 │ 1.58e+2 1.78e+2 ... 2.58e+2 2.78e+2 ││
- ││axis 3│ 9.83e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.88e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.93e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 9.98e+2 1.01e+3 ... 1.09e+3 1.11e+3 ││
- ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 ││
+ ││1 @ 2 │ 1.43e+2 1.63e+2 ... 2.43e+2 2.64e+2 │ 1.48e+2 1.68e+2 ... 2.48e+2 2.68e+2 │ 1.53e+2 1.73e+2 ... 2.53e+2 2.72e+2 │ 1.58e+2 1.78e+2 ... 2.58e+2 2.78e+2 ││
+ ││axis 3│ 9.84e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.88e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.92e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 1.00e+3 1.01e+3 ... 1.09e+3 1.12e+3 ││
+ ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.84e+3 1.85e+3 ... 1.93e+3 1.96e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 5.63e+2 5.83e+2 ... 6.63e+2 6.83e+2 │ 5.68e+2 5.88e+2 ... 6.68e+2 6.88e+2 │ 5.73e+2 5.93e+2 ... 6.73e+2 6.93e+2 │ 5.78e+2 5.98e+2 ... 6.78e+2 6.98e+2 ││
- ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
- ││ │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 ││
+ ││4 @ 2 │ 5.64e+2 5.84e+2 ... 6.64e+2 6.84e+2 │ 5.68e+2 5.88e+2 ... 6.68e+2 6.88e+2 │ 5.72e+2 5.92e+2 ... 6.72e+2 6.92e+2 │ 5.76e+2 6.00e+2 ... 6.80e+2 6.96e+2 ││
+ ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.44e+3 ... 1.52e+3 1.53e+3 ││
+ ││ │ 2.24e+3 2.25e+3 ... 2.33e+3 2.36e+3 │ 2.24e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.38e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││5 @ 2 │ 7.03e+2 7.23e+2 ... 8.03e+2 8.23e+2 │ 7.08e+2 7.28e+2 ... 8.08e+2 8.28e+2 │ 7.13e+2 7.33e+2 ... 8.13e+2 8.33e+2 │ 7.18e+2 7.38e+2 ... 8.18e+2 8.38e+2 ││
- ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
- ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
+ ││5 @ 2 │ 7.04e+2 7.24e+2 ... 8.04e+2 8.24e+2 │ 7.08e+2 7.28e+2 ... 8.08e+2 8.28e+2 │ 7.12e+2 7.32e+2 ... 8.12e+2 8.32e+2 │ 7.20e+2 7.36e+2 ... 8.16e+2 8.40e+2 ││
+ ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.56e+3 1.57e+3 ... 1.65e+3 1.68e+3 ││
+ ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.49e+3 │ 2.38e+3 2.40e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
├────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│┌──────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┬─────────────────────────────────────────┐│
@@ -977,23 +977,23 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
││ │axis 5 │axis 5 │axis 5 │axis 5 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││0 @ 2 │ 4.00 2.40e+1 ... 1.04e+2 1.24e+2 │ 9.00 2.90e+1 ... 1.09e+2 1.29e+2 │ 1.40e+1 3.40e+1 ... 1.14e+2 1.34e+2 │ 1.90e+1 3.90e+1 ... 1.19e+2 1.39e+2 ││
- ││axis 3│ 8.44e+2 8.64e+2 ... 9.44e+2 9.64e+2 │ 8.49e+2 8.69e+2 ... 9.49e+2 9.69e+2 │ 8.54e+2 8.74e+2 ... 9.54e+2 9.74e+2 │ 8.59e+2 8.79e+2 ... 9.59e+2 9.79e+2 ││
- ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 ││
+ ││axis 3│ 8.44e+2 8.64e+2 ... 9.44e+2 9.64e+2 │ 8.48e+2 8.68e+2 ... 9.48e+2 9.68e+2 │ 8.56e+2 8.72e+2 ... 9.52e+2 9.76e+2 │ 8.60e+2 8.80e+2 ... 9.60e+2 9.80e+2 ││
+ ││ │ 1.68e+3 1.70e+3 ... 1.78e+3 1.80e+3 │ 1.68e+3 1.71e+3 ... 1.79e+3 1.80e+3 │ 1.69e+3 1.71e+3 ... 1.79e+3 1.81e+3 │ 1.69e+3 1.72e+3 ... 1.80e+3 1.81e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││1 @ 2 │ 1.44e+2 1.64e+2 ... 2.44e+2 2.64e+2 │ 1.49e+2 1.69e+2 ... 2.49e+2 2.69e+2 │ 1.54e+2 1.74e+2 ... 2.54e+2 2.74e+2 │ 1.59e+2 1.79e+2 ... 2.59e+2 2.79e+2 ││
- ││axis 3│ 9.84e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.89e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.94e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 9.99e+2 1.01e+3 ... 1.09e+3 1.11e+3 ││
- ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 ││
+ ││1 @ 2 │ 1.44e+2 1.64e+2 ... 2.44e+2 2.64e+2 │ 1.49e+2 1.69e+2 ... 2.49e+2 2.68e+2 │ 1.54e+2 1.74e+2 ... 2.54e+2 2.74e+2 │ 1.59e+2 1.79e+2 ... 2.60e+2 2.80e+2 ││
+ ││axis 3│ 9.84e+2 1.00e+3 ... 1.08e+3 1.10e+3 │ 9.88e+2 1.00e+3 ... 1.08e+3 1.11e+3 │ 9.92e+2 1.01e+3 ... 1.09e+3 1.11e+3 │ 1.00e+3 1.02e+3 ... 1.09e+3 1.12e+3 ││
+ ││ │ 1.82e+3 1.84e+3 ... 1.92e+3 1.94e+3 │ 1.83e+3 1.84e+3 ... 1.92e+3 1.95e+3 │ 1.83e+3 1.85e+3 ... 1.93e+3 1.95e+3 │ 1.84e+3 1.85e+3 ... 1.93e+3 1.96e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
││~~~~~ │ ... │ ... │ ... │ ... ││
││axis 3│ │ │ │ ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││4 @ 2 │ 5.64e+2 5.84e+2 ... 6.64e+2 6.84e+2 │ 5.69e+2 5.89e+2 ... 6.69e+2 6.89e+2 │ 5.74e+2 5.94e+2 ... 6.74e+2 6.94e+2 │ 5.79e+2 5.99e+2 ... 6.79e+2 6.99e+2 ││
- ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 ││
- ││ │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.24e+3 2.26e+3 ... 2.34e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.37e+3 ││
+ ││4 @ 2 │ 5.64e+2 5.84e+2 ... 6.64e+2 6.84e+2 │ 5.68e+2 5.88e+2 ... 6.68e+2 6.88e+2 │ 5.76e+2 5.92e+2 ... 6.72e+2 6.96e+2 │ 5.80e+2 6.00e+2 ... 6.80e+2 7.00e+2 ││
+ ││axis 3│ 1.40e+3 1.42e+3 ... 1.50e+3 1.52e+3 │ 1.40e+3 1.43e+3 ... 1.51e+3 1.52e+3 │ 1.41e+3 1.43e+3 ... 1.51e+3 1.53e+3 │ 1.41e+3 1.44e+3 ... 1.52e+3 1.53e+3 ││
+ ││ │ 2.24e+3 2.27e+3 ... 2.33e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.36e+3 │ 2.25e+3 2.27e+3 ... 2.35e+3 2.38e+3 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││5 @ 2 │ 7.04e+2 7.24e+2 ... 8.04e+2 8.24e+2 │ 7.09e+2 7.29e+2 ... 8.09e+2 8.29e+2 │ 7.14e+2 7.34e+2 ... 8.14e+2 8.34e+2 │ 7.19e+2 7.39e+2 ... 8.19e+2 8.39e+2 ││
- ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 ││
- ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.38e+3 2.40e+3 ... 2.48e+3 2.50e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.39e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
+ ││5 @ 2 │ 7.04e+2 7.24e+2 ... 8.04e+2 8.24e+2 │ 7.08e+2 7.28e+2 ... 8.08e+2 8.28e+2 │ 7.12e+2 7.36e+2 ... 8.16e+2 8.32e+2 │ 7.20e+2 7.40e+2 ... 8.20e+2 8.40e+2 ││
+ ││axis 3│ 1.54e+3 1.56e+3 ... 1.64e+3 1.66e+3 │ 1.55e+3 1.56e+3 ... 1.64e+3 1.67e+3 │ 1.55e+3 1.57e+3 ... 1.65e+3 1.67e+3 │ 1.56e+3 1.57e+3 ... 1.65e+3 1.68e+3 ││
+ ││ │ 2.38e+3 2.40e+3 ... 2.48e+3 2.49e+3 │ 2.38e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 │ 2.40e+3 2.41e+3 ... 2.49e+3 2.51e+3 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}];
@@ -1009,9 +1009,9 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
││ │0 @ 0 │1 @ 0 │2 @ 0 │3 @ 0 │4 @ 0 ││
││ │axis 2 │axis 2 │axis 2 │axis 2 │axis 2 ││
│├──────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┼─────────────────────────────────────────┤│
- ││axis 1│ 7.76e+4 7.86e+4 ... 8.24e+4 8.34e+4 │ 7.76e+4 7.86e+4 ... 8.24e+4 8.34e+4 │ 7.77e+4 7.86e+4 ... 8.25e+4 8.34e+4 │ 7.77e+4 7.87e+4 ... 8.25e+4 8.35e+4 │ 7.78e+4 7.87e+4 ... 8.26e+4 8.35e+4 ││
- ││ │ 1.17e+5 1.18e+5 ... 1.22e+5 1.23e+5 │ 1.18e+5 1.18e+5 ... 1.22e+5 1.23e+5 │ 1.18e+5 1.19e+5 ... 1.22e+5 1.23e+5 │ 1.18e+5 1.19e+5 ... 1.22e+5 1.23e+5 │ 1.18e+5 1.19e+5 ... 1.22e+5 1.23e+5 ││
- ││ │ 1.58e+5 1.59e+5 ... 1.63e+5 1.64e+5 │ 1.58e+5 1.59e+5 ... 1.63e+5 1.64e+5 │ 1.58e+5 1.59e+5 ... 1.63e+5 1.64e+5 │ 1.58e+5 1.59e+5 ... 1.63e+5 1.64e+5 │ 1.58e+5 1.59e+5 ... 1.63e+5 1.64e+5 ││
+ ││axis 1│ 7.73e+4 7.83e+4 ... 8.08e+4 8.34e+4 │ 7.73e+4 7.83e+4 ... 8.08e+4 8.34e+4 │ 7.73e+4 7.83e+4 ... 8.14e+4 8.34e+4 │ 7.78e+4 7.83e+4 ... 8.24e+4 8.34e+4 │ 7.78e+4 7.83e+4 ... 8.24e+4 8.39e+4 ││
+ ││ │ 1.18e+5 1.18e+5 ... 1.23e+5 1.24e+5 │ 1.18e+5 1.18e+5 ... 1.23e+5 1.24e+5 │ 1.18e+5 1.18e+5 ... 1.23e+5 1.24e+5 │ 1.18e+5 1.18e+5 ... 1.23e+5 1.24e+5 │ 1.18e+5 1.18e+5 ... 1.23e+5 1.24e+5 ││
+ ││ │ 1.58e+5 1.59e+5 ... 1.64e+5 1.64e+5 │ 1.58e+5 1.60e+5 ... 1.64e+5 1.64e+5 │ 1.58e+5 1.60e+5 ... 1.64e+5 1.64e+5 │ 1.58e+5 1.60e+5 ... 1.64e+5 1.64e+5 │ 1.58e+5 1.60e+5 ... 1.64e+5 1.64e+5 ││
│└──────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┴─────────────────────────────────────────┘│
└──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
|}];
@@ -1692,9 +1692,9 @@ let%expect_test "einsum with a leftmost input axis preserved as output axis" =
││ │axis 2 │axis 2 │axis 2 ││
│├──────┼──────────────────┼──────────────────┼──────────────────┤│
││axis 1│ 1.20e+1 4.80e+1 │ 9.00e+2 1.00e+3 │ 2.94e+3 3.12e+3 ││
- ││ │ 1.05e+2 1.50e+2 │ 1.20e+3 1.32e+3 │ 3.46e+3 3.65e+3 ││
- ││ │ 2.34e+2 2.88e+2 │ 1.55e+3 1.68e+3 │ 4.02e+3 4.22e+3 ││
- ││ │ 3.99e+2 4.62e+2 │ 1.93e+3 2.07e+3 │ 4.62e+3 4.83e+3 ││
+ ││ │ 1.05e+2 1.50e+2 │ 1.20e+3 1.32e+3 │ 3.45e+3 3.64e+3 ││
+ ││ │ 2.34e+2 2.88e+2 │ 1.55e+3 1.68e+3 │ 4.01e+3 4.22e+3 ││
+ ││ │ 4.00e+2 4.60e+2 │ 1.93e+3 2.08e+3 │ 4.60e+3 4.83e+3 ││
│└──────┴──────────────────┴──────────────────┴──────────────────┘│
└─────────────────────────────────────────────────────────────────┘
|}]
"/usr/bin/env" "bash" "-c" "opam exec -- dune build @install @check @runtest && rm -rf _build" failed with exit status 1
2025-05-31 10:11.53: Job failed: Failed: Build failed