2025-07-12 16:30.02: New job: test ahrefs/ocannl https://github.com/ahrefs/ocannl.git#refs/heads/master (6f9d38d66047dc14cf71db6958bbbba8b4c44a53) (windows-amd64:windows-server-2022-amd64-5.3_opam-2.3)
Base: windows-server-2022-amd64-ocaml-5.3
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ahrefs/ocannl.git" -b "master" && cd "ocannl" && git reset --hard 6f9d38d6
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM windows-server-2022-amd64-ocaml-5.3
# windows-server-2022-amd64-5.3_opam-2.3
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
RUN ln -f /usr/bin/opam-2.3 /usr/bin/opam
RUN opam init --reinit -ni
RUN uname -rs && opam exec -- ocaml -version && opam --version
RUN cd ~/opam-repository && (git cat-file -e 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 || git fetch origin master) && git reset -q --hard 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 neural_nets_lib.opam arrayjit.opam /Users/opam/src/./
RUN opam pin add -yn neural_nets_lib.dev '/Users/opam/src/./' && \
opam pin add -yn arrayjit.dev '/Users/opam/src/./'
RUN echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'
ENV DEPS="angstrom.0.16.1 arch-x86_64.1 astring.0.8.5 backoff.0.1.1 base.v0.17.3 base-bigarray.base base-bytes.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 camlzip.1.13 cmdliner.1.3.0 conf-libcurl.2 conf-libffi.2.0.0 conf-mingw-w64-curl-x86_64.1 conf-mingw-w64-gcc-x86_64.1 conf-mingw-w64-libffi-x86_64.1 conf-mingw-w64-zlib-x86_64.1 conf-pkg-config.4 conf-zlib.1 cppo.1.8.0 csexp.1.5.2 csv.2.4 ctypes.0.23.0 ctypes-foreign.0.23.0 curl.0.10.0 dune.3.19.1 dune-configurator.3.19.1 fieldslib.v0.17.0 flexdll.0.44 fmt.0.10.0 host-arch-x86_64.1 host-system-mingw.1 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.9.0 mdx.2.5.0 mingw-w64-shims.0.2.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.6 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-env-mingw64.1 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.1.0 ppx_enumerate.v0.17.0 ppx_expect.v0.17.3 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.2 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.1 ppx_minidebug.2.3.0 ppx_optcomp.v0.17.1 ppx_sexp_conv.v0.17.1 ppx_string.v0.17.0 ppx_variants_conv.v0.17.1 ppxlib.0.36.0 ppxlib_jane.v0.17.4 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.13.2 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 system-mingw.1 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 . /Users/opam/src
RUN cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build
END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK
2025-07-12 16:30.02: Using cache hint "ahrefs/ocannl-windows-server-2022-amd64-ocaml-5.3-windows-server-2022-amd64-5.3_opam-2.3-950247227a354322f2fe64c9bc5c5fea"
2025-07-12 16:30.02: Using OBuilder spec:
((from windows-server-2022-amd64-ocaml-5.3)
(comment windows-server-2022-amd64-5.3_opam-2.3)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(run (shell "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"))
(run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 || git fetch origin master) && git reset -q --hard 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src neural_nets_lib.opam arrayjit.opam) (dst /Users/opam/src/./))
(run (network host)
(shell "opam pin add -yn neural_nets_lib.dev '/Users/opam/src/./' && \
\nopam pin add -yn arrayjit.dev '/Users/opam/src/./'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'"))
(env DEPS "angstrom.0.16.1 arch-x86_64.1 astring.0.8.5 backoff.0.1.1 base.v0.17.3 base-bigarray.base base-bytes.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 camlzip.1.13 cmdliner.1.3.0 conf-libcurl.2 conf-libffi.2.0.0 conf-mingw-w64-curl-x86_64.1 conf-mingw-w64-gcc-x86_64.1 conf-mingw-w64-libffi-x86_64.1 conf-mingw-w64-zlib-x86_64.1 conf-pkg-config.4 conf-zlib.1 cppo.1.8.0 csexp.1.5.2 csv.2.4 ctypes.0.23.0 ctypes-foreign.0.23.0 curl.0.10.0 dune.3.19.1 dune-configurator.3.19.1 fieldslib.v0.17.0 flexdll.0.44 fmt.0.10.0 host-arch-x86_64.1 host-system-mingw.1 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.9.0 mdx.2.5.0 mingw-w64-shims.0.2.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.6 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-env-mingw64.1 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.1.0 ppx_enumerate.v0.17.0 ppx_expect.v0.17.3 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.2 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.1 ppx_minidebug.2.3.0 ppx_optcomp.v0.17.1 ppx_sexp_conv.v0.17.1 ppx_string.v0.17.0 ppx_variants_conv.v0.17.1 ppxlib.0.36.0 ppxlib_jane.v0.17.4 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.13.2 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 system-mingw.1 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 "c:\\Users\\opam\\AppData\\local\\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 "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam install $DEPS"))
(copy (src .) (dst /Users/opam/src))
(run (shell "cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build"))
)
2025-07-12 16:30.02: Waiting for resource in pool OCluster
2025-07-12 16:30.02: Waiting for workerβ¦
2025-07-12 16:32.48: Got resource from pool OCluster
Building on thyme
Updating files: 64% (87/134)
Updating files: 65% (88/134)
Updating files: 66% (89/134)
Updating files: 67% (90/134)
Updating files: 68% (92/134)
Updating files: 69% (93/134)
Updating files: 70% (94/134)
Updating files: 71% (96/134)
Updating files: 72% (97/134)
Updating files: 73% (98/134)
Updating files: 74% (100/134)
Updating files: 75% (101/134)
Updating files: 76% (102/134)
Updating files: 77% (104/134)
Updating files: 78% (105/134)
Updating files: 79% (106/134)
Updating files: 80% (108/134)
Updating files: 81% (109/134)
Updating files: 82% (110/134)
Updating files: 83% (112/134)
Updating files: 84% (113/134)
Updating files: 85% (114/134)
Updating files: 86% (116/134)
Updating files: 87% (117/134)
Updating files: 88% (118/134)
Updating files: 89% (120/134)
Updating files: 90% (121/134)
Updating files: 91% (122/134)
Updating files: 92% (124/134)
Updating files: 93% (125/134)
Updating files: 94% (126/134)
Updating files: 95% (128/134)
Updating files: 96% (129/134)
Updating files: 97% (130/134)
Updating files: 98% (132/134)
Updating files: 99% (133/134)
Updating files: 100% (134/134)
Updating files: 100% (134/134), done.
HEAD is now at 90bf5fc6 Also rename Ops.map_prec -> apply_prec (see recent commit on renaming Ndarray.map)
HEAD is now at 6f9d38d6 Refactoring and a small cleanup of test organization
(from windows-server-2022-amd64-ocaml-5.3)
2025-07-12 16:32.53 ---> using "1d6ffeb5a52124df73b2e951323e99615c52ca4f9bdf0f65039be6146fabdaab" from cache
/: (comment windows-server-2022-amd64-5.3_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (run (shell "ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-07-12 16:32.53 ---> using "95d5d85ee56c2575e196f53fe7f940cc0731fb5c4485beb38b72a714de9d05bf" from cache
/: (run (shell "opam init --reinit -ni"))
No configuration file found, using built-in defaults.
<><> Unix support infrastructure ><><><><><><><><><><><><><><><><><><><><><><><>
opam and the OCaml ecosystem in general require various Unix tools in order to operate correctly. At present, this requires the installation of Cygwin to provide these tools.
How should opam obtain Unix tools?
> 1. Use tools found in PATH (Cygwin installation at C:\cygwin64)
2. Automatically create an internal Cygwin installation that will be managed by opam (recommended)
3. Use Cygwin installation found in C:\cygwin64
4. Use another existing Cygwin/MSYS2 installation
5. Abort initialisation
[1/2/3/4/5] 1
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.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] no changes from file://C:/Users/opam/opam-repository
2025-07-12 16:32.53 ---> using "53bae75d46d214e65b51daece9ef873c6c6a891e203ec3d98bbd26c30834d1e2" from cache
/: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
CYGWIN_NT-10.0-20348 3.5.5-1.x86_64
The OCaml toplevel, version 5.3.0
2.3.0
2025-07-12 16:32.53 ---> using "2b54922bf0d8d5ddbb1aea4afec4a959968c963bd87de7fe3038a742f957825c" from cache
/: (run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 || git fetch origin master) && git reset -q --hard 64169c3d1d6774ef4ce0fcc471269bb09cd215f5 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
f93eb7cb02..0094db1438 master -> origin/master
64169c3d1d Merge pull request #28149 from dbuenzli/b0-publish-logs.0.9.0
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from file://C:/Users/opam/opam-repository
The following actions will be performed:
=== recompile 7 packages
- recompile base-domains base [uses ocaml]
- recompile base-effects base [uses ocaml]
- recompile base-nnp base [uses base-domains]
- recompile ocaml 5.3.0 [uses ocaml-base-compiler]
- recompile ocaml-base-compiler 5.3.0 (pinned) [uses ocaml-compiler]
- recompile ocaml-compiler 5.3.0 [uses flexdll]
- recompile ocaml-config 3 [uses ocaml-base-compiler]
=== upgrade 1 package
- upgrade flexdll 0.43 to 0.44
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ocaml-config.3 (cached)
-> retrieved flexdll.0.44 (cached)
-> removed base-effects.base
-> removed base-nnp.base
-> removed base-domains.base
-> removed ocaml.5.3.0
-> removed ocaml-config.3
-> removed ocaml-base-compiler.5.3.0
-> retrieved ocaml-compiler.5.3.0 (cached)
-> removed ocaml-compiler.5.3.0
-> removed flexdll.0.43
-> installed flexdll.0.44
-> installed ocaml-compiler.5.3.0
-> installed ocaml-base-compiler.5.3.0
-> installed ocaml-config.3
-> installed ocaml.5.3.0
-> installed base-domains.base
-> installed base-effects.base
-> installed base-nnp.base
Done.
# To update the current shell environment, run: eval $(opam env)
2025-07-12 16:32.53 ---> using "f22f645267bc3a50629a9176279a2533136fa8917121aa3888a7ebf13dca502c" from cache
/: (copy (src neural_nets_lib.opam arrayjit.opam) (dst /Users/opam/src/./))
2025-07-12 16:32.53 ---> using "72aa72a0bb831a08d05ceef5c078a63a9d03d533c08e500ef95227f27979ccdc" from cache
/: (run (network host)
(shell "opam pin add -yn neural_nets_lib.dev '/Users/opam/src/./' && \
\nopam pin add -yn arrayjit.dev '/Users/opam/src/./'"))
[neural_nets_lib.dev] synchronised (file://C:/Users/opam/src/.)
neural_nets_lib is now pinned to file://C:/Users/opam/src/. (version dev)
[arrayjit.dev] synchronised (file://C:/Users/opam/src/.)
arrayjit is now pinned to file://C:/Users/opam/src/. (version dev)
2025-07-12 16:32.53 ---> using "60a7711a872333184cfdf62a755bc6be6db0f7a3aa38692510024532a668e23c" from cache
/: (run (network host)
(shell "echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'"))
2025-07-12 16:32.53 ---> using "e0cf21b7456889e3ac293a1112c3c9ebcc26482f69783e8aae80e1d200b384c1" from cache
/: (env DEPS "angstrom.0.16.1 arch-x86_64.1 astring.0.8.5 backoff.0.1.1 base.v0.17.3 base-bigarray.base base-bytes.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 camlzip.1.13 cmdliner.1.3.0 conf-libcurl.2 conf-libffi.2.0.0 conf-mingw-w64-curl-x86_64.1 conf-mingw-w64-gcc-x86_64.1 conf-mingw-w64-libffi-x86_64.1 conf-mingw-w64-zlib-x86_64.1 conf-pkg-config.4 conf-zlib.1 cppo.1.8.0 csexp.1.5.2 csv.2.4 ctypes.0.23.0 ctypes-foreign.0.23.0 curl.0.10.0 dune.3.19.1 dune-configurator.3.19.1 fieldslib.v0.17.0 flexdll.0.44 fmt.0.10.0 host-arch-x86_64.1 host-system-mingw.1 integers.0.7.0 jane-street-headers.v0.17.0 jst-config.v0.17.0 logs.0.9.0 mdx.2.5.0 mingw-w64-shims.0.2.0 mtime.2.1.0 multicore-magic.2.3.1 num.1.6 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-env-mingw64.1 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.1.0 ppx_enumerate.v0.17.0 ppx_expect.v0.17.3 ppx_fields_conv.v0.17.0 ppx_globalize.v0.17.2 ppx_hash.v0.17.0 ppx_here.v0.17.0 ppx_inline_test.v0.17.1 ppx_minidebug.2.3.0 ppx_optcomp.v0.17.1 ppx_sexp_conv.v0.17.1 ppx_string.v0.17.0 ppx_variants_conv.v0.17.1 ppxlib.0.36.0 ppxlib_jane.v0.17.4 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.13.2 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 system-mingw.1 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 "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y neural_nets_lib.dev arrayjit.dev $DEPS"))
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[neural_nets_lib.dev] synchronised (file://C:/Users/opam/src/.)
[arrayjit.dev] synchronised (file://C:/Users/opam/src/.)
[NOTE] Package system-mingw is already installed (current version is 1).
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-env-mingw64 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 mingw-w64-shims is already installed (current version is 0.2.0).
[NOTE] Package host-system-mingw is already installed (current version is 1).
[NOTE] Package host-arch-x86_64 is already installed (current version is 1).
[NOTE] Package flexdll is already installed (current version is 0.44).
[NOTE] Package conf-mingw-w64-gcc-x86_64 is already installed (current version is 1).
[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).
[NOTE] Package arch-x86_64 is already installed (current version is 1).
The following system packages will first need to be installed:
mingw64-x86_64-curl mingw64-x86_64-libffi mingw64-x86_64-zlib
<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>
+ C:\Users\opam\AppData\Local\opam\.cygwin\setup-x86_64.exe "--root" "C:\\cygwin64" "--quiet-mode" "unattended" "--no-shortcuts" "--no-startmenu" "--no-desktop" "--no-admin" "--no-version-check" "--no-write-registry" "--packages" "mingw64-x86_64-curl,mingw64-x86_64-libffi,mingw64-x86_64-zlib"
- Starting cygwin install, version 2.934
- User has backup/restore rights
- User has symlink creation right
- Current Directory: C:\Windows\system32
- root: C:\cygwin64 system
- Changing gid to Administrators
- Selected local directory: C:\Windows\system32
- net: Preconfig
- site: https://cygwin.mirror.constant.com/
- solving: 3 tasks, update: no, use test packages: no
- solving: 11 tasks, update: no, use test packages: no
- Augmented Transaction List:
- 0 install mingw64-x86_64-gcc-g++ 12.4.0-1
- 1 install mingw64-x86_64-libffi 3.2.1-2
- 2 install mingw64-x86_64-nghttp2 1.61.0-1
- 3 install mingw64-x86_64-win-iconv 0.0.8-1
- 4 install mingw64-x86_64-zlib 1.3.1-1
- 5 install mingw64-x86_64-zstd 1.5.7-1
- 6 install mingw64-x86_64-gettext 0.22.5-1
- 7 install mingw64-x86_64-openssl 3.0.17-1
- 8 install mingw64-x86_64-libssh2 1.11.0-1
- 9 install mingw64-x86_64-libidn2 2.3.8-1
- 10 install mingw64-x86_64-curl 8.14.1-1
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/x86_64/release/mingw64-x86_64-gcc/mingw64-x86_64-gcc-g++/mingw64-x86_64-gcc-g++-12.4.0-1.tar.zst
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libffi/mingw64-x86_64-libffi-3.2.1-2.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-nghttp2/mingw64-x86_64-nghttp2-1.61.0-1.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-win-iconv/mingw64-x86_64-win-iconv-0.0.8-1.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-zlib/mingw64-x86_64-zlib-1.3.1-1.tar.zst
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-zstd/mingw64-x86_64-zstd-1.5.7-1.tar.zst
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-gettext/mingw64-x86_64-gettext-0.22.5-1.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-openssl/mingw64-x86_64-openssl-3.0.17-1-noarch.tar.zst
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libssh2/mingw64-x86_64-libssh2-1.11.0-1.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libidn2/mingw64-x86_64-libidn2-2.3.8-1.tar.xz
- Downloaded C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-curl/mingw64-x86_64-curl-8.14.1-1-noarch.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/x86_64/release/mingw64-x86_64-gcc/mingw64-x86_64-gcc-g++/mingw64-x86_64-gcc-g++-12.4.0-1.tar.zst
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libffi/mingw64-x86_64-libffi-3.2.1-2.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-nghttp2/mingw64-x86_64-nghttp2-1.61.0-1.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-win-iconv/mingw64-x86_64-win-iconv-0.0.8-1.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-zlib/mingw64-x86_64-zlib-1.3.1-1.tar.zst
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-zstd/mingw64-x86_64-zstd-1.5.7-1.tar.zst
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-gettext/mingw64-x86_64-gettext-0.22.5-1.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-openssl/mingw64-x86_64-openssl-3.0.17-1-noarch.tar.zst
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libssh2/mingw64-x86_64-libssh2-1.11.0-1.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-libidn2/mingw64-x86_64-libidn2-2.3.8-1.tar.xz
- Extracting from file://C:\Windows\system32/https%3a%2f%2fcygwin.mirror.constant.com%2f/noarch/release/mingw64-x86_64-curl/mingw64-x86_64-curl-8.14.1-1-noarch.tar.xz
- running: C:\cygwin64\bin\dash.exe "/etc/postinstall/0p_000_autorebase.dash"
- running: C:\cygwin64\bin\dash.exe "/etc/postinstall/0p_update-info-dir.dash"
- running: C:\cygwin64\bin\dash.exe "/etc/postinstall/zp_man-db-update-index.dash"
- Ending cygwin install
- NOTE: you should run 'diskperf -y' to enable the disk statistics
- NOTE: you should run 'diskperf -y' to enable the disk statistics
2025-07-12 16:32.53 ---> using "92a1cac14f505602ecc5a78c2ba7c0d400fa24af5e764b7a632514af76b8b290" from cache
/: (run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam install $DEPS"))
[NOTE] Package system-mingw is already installed (current version is 1).
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-env-mingw64 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 mingw-w64-shims is already installed (current version is 0.2.0).
[NOTE] Package host-system-mingw is already installed (current version is 1).
[NOTE] Package host-arch-x86_64 is already installed (current version is 1).
[NOTE] Package flexdll is already installed (current version is 0.44).
[NOTE] Package conf-mingw-w64-gcc-x86_64 is already installed (current version is 1).
[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).
[NOTE] Package arch-x86_64 is already installed (current version is 1).
The following actions will be performed:
=== recompile 1 package
- recompile mingw-w64-shims 0.2.0
=== install 84 packages
- install angstrom 0.16.1
- install astring 0.8.5
- install backoff 0.1.1
- install base v0.17.3
- install base-bytes base
- install bigarray-compat 1.1.0
- install bigstringaf 0.10.0
- install camlp-streams 5.0.1
- install camlzip 1.13
- install cmdliner 1.3.0
- install conf-libcurl 2
- install conf-libffi 2.0.0
- install conf-mingw-w64-curl-x86_64 1
- install conf-mingw-w64-libffi-x86_64 1
- install conf-mingw-w64-zlib-x86_64 1
- install conf-pkg-config 4
- install conf-zlib 1
- install cppo 1.8.0
- install csexp 1.5.2
- install csv 2.4
- install ctypes 0.23.0
- install ctypes-foreign 0.23.0
- install curl 0.10.0
- install dune 3.19.1
- install dune-configurator 3.19.1
- 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.9.0
- install mdx 2.5.0
- install mtime 2.1.0
- install multicore-magic 2.3.1
- install num 1.6
- 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.1.0
- install ppx_enumerate v0.17.0
- install ppx_expect v0.17.3
- install ppx_fields_conv v0.17.0
- install ppx_globalize v0.17.2
- install ppx_hash v0.17.0
- install ppx_here v0.17.0
- install ppx_inline_test v0.17.1
- install ppx_minidebug 2.3.0
- install ppx_optcomp v0.17.1
- install ppx_sexp_conv v0.17.1
- install ppx_string v0.17.0
- install ppx_variants_conv v0.17.1
- install ppxlib 0.36.0
- install ppxlib_jane v0.17.4
- 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.13.2
- 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 angstrom.0.16.1 (cached)
-> retrieved astring.0.8.5 (cached)
-> retrieved backoff.0.1.1 (cached)
-> retrieved bigarray-compat.1.1.0 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved camlp-streams.5.0.1 (cached)
-> retrieved camlzip.1.13 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> retrieved base.v0.17.3 (https://github.com/janestreet/base/archive/refs/tags/v0.17.3.tar.gz)
-> retrieved cppo.1.8.0 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved csv.2.4 (cached)
-> retrieved curl.0.10.0 (cached)
-> installed conf-pkg-config.4
-> retrieved ctypes.0.23.0, ctypes-foreign.0.23.0 (cached)
-> retrieved fieldslib.v0.17.0 (cached)
-> retrieved fmt.0.10.0 (cached)
-> retrieved integers.0.7.0 (cached)
-> retrieved jane-street-headers.v0.17.0 (cached)
-> installed conf-mingw-w64-curl-x86_64.1
-> retrieved jst-config.v0.17.0 (cached)
-> installed conf-mingw-w64-libffi-x86_64.1
-> installed conf-libffi.2.0.0
-> installed conf-mingw-w64-zlib-x86_64.1
-> retrieved logs.0.9.0 (https://erratique.ch/software/logs/releases/logs-0.9.0.tbz)
-> installed conf-zlib.1
-> retrieved mingw-w64-shims.0.2.0 (cached)
-> retrieved mdx.2.5.0 (cached)
-> retrieved mtime.2.1.0 (cached)
-> installed mingw-w64-shims.0.2.0
-> retrieved multicore-magic.2.3.1 (cached)
-> retrieved ocaml-compiler-libs.v0.17.0 (cached)
-> installed conf-libcurl.2
-> retrieved num.1.6 (https://github.com/ocaml/num/archive/refs/tags/v1.6.tar.gz)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.1 (cached)
-> retrieved ocaml-version.4.0.1 (https://github.com/ocurrent/ocaml-version/releases/download/v4.0.1/ocaml-version-4.0.1.tbz)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved parsexp.v0.17.0 (cached)
-> retrieved pprint.20230830 (cached)
-> retrieved ppx_assert.v0.17.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 dune.3.19.1, dune-configurator.3.19.1 (https://github.com/ocaml/dune/releases/download/3.19.1/dune-3.19.1.tbz)
-> retrieved ppx_deriving.6.1.0 (cached)
-> retrieved ppx_enumerate.v0.17.0 (cached)
-> retrieved ppx_fields_conv.v0.17.0 (cached)
-> retrieved ppx_expect.v0.17.3 (https://github.com/janestreet/ppx_expect/archive/refs/tags/v0.17.3.tar.gz)
-> retrieved ppx_globalize.v0.17.2 (https://github.com/janestreet/ppx_globalize/archive/refs/tags/v0.17.2.tar.gz)
-> retrieved ppx_hash.v0.17.0 (cached)
-> retrieved ppx_here.v0.17.0 (cached)
-> retrieved ppx_inline_test.v0.17.1 (https://github.com/janestreet/ppx_inline_test/archive/refs/tags/v0.17.1.tar.gz)
-> retrieved ppx_minidebug.2.3.0 (https://github.com/lukstafi/ppx_minidebug/archive/refs/tags/2.3.0.tar.gz)
-> retrieved ppx_optcomp.v0.17.1 (https://github.com/janestreet/ppx_optcomp/archive/refs/tags/v0.17.1.tar.gz)
-> retrieved ppx_string.v0.17.0 (cached)
-> installed cmdliner.1.3.0
-> installed num.1.6
-> retrieved ppx_sexp_conv.v0.17.1 (https://github.com/janestreet/ppx_sexp_conv/archive/refs/tags/v0.17.1.tar.gz)
-> retrieved ppx_variants_conv.v0.17.1 (https://github.com/janestreet/ppx_variants_conv/archive/refs/tags/v0.17.1.tar.gz)
-> retrieved ppxlib_jane.v0.17.4 (https://github.com/janestreet/ppxlib_jane/archive/refs/tags/v0.17.4.tar.gz)
-> retrieved printbox.0.12, printbox-ext-plot.0.12, printbox-html.0.12, printbox-md.0.12, printbox-text.0.12 (cached)
-> retrieved ppxlib.0.36.0 (cached)
-> retrieved ptime.1.2.0 (cached)
-> retrieved result.1.5 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved re.1.13.2 (https://github.com/ocaml/ocaml-re/archive/refs/tags/1.13.2.tar.gz)
-> retrieved saturn_lockfree.0.5.0 (cached)
-> retrieved sexplib.v0.17.0 (cached)
-> retrieved sexplib0.v0.17.0 (cached)
-> retrieved stdio.v0.17.0 (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 uucp.16.0.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved variantslib.v0.17.0 (cached)
[WARNING] .install file is missing .exe extension for src/findlib/ocamlfind
[WARNING] .install file is missing .exe extension for src/findlib/ocamlfind_opt
[WARNING] Automatically adding .exe to C:\Users\opam\AppData\Local\opam\5.3.0\.opam-switch\build\ocamlfind.1.9.8\src\findlib\ocamlfind.exe
[WARNING] Automatically adding .exe to C:\Users\opam\AppData\Local\opam\5.3.0\.opam-switch\build\ocamlfind.1.9.8\src\findlib\ocamlfind_opt.exe
[WARNING] C:\Users\opam\AppData\Local\opam\5.3.0\bin\safe_camlp4 is a script; the command won't be available
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed camlzip.1.13
-> installed ocamlbuild.0.16.1
-> installed topkg.1.0.8
-> installed uutf.1.0.4
-> installed astring.0.8.5
-> installed fmt.0.10.0
-> installed mtime.2.1.0
-> installed ptime.1.2.0
-> installed logs.0.9.0
-> installed dune.3.19.1
-> installed bigarray-compat.1.1.0
-> installed backoff.0.1.1
-> installed camlp-streams.5.0.1
-> installed csexp.1.5.2
-> installed jane-street-headers.v0.17.0
-> installed cppo.1.8.0
-> installed csv.2.4
-> installed multicore-magic.2.3.1
-> installed ocaml-compiler-libs.v0.17.0
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml-version.4.0.1
-> installed uucp.16.0.0
-> installed ppx_derivers.1.2.1
-> installed ocaml_intrinsics_kernel.v0.17.1
-> installed pprint.20230830
-> installed printbox.0.12
-> installed result.1.5
-> installed stdlib-shims.0.3.0
-> installed printbox-text.0.12
-> installed saturn_lockfree.0.5.0
-> installed dune-configurator.3.19.1
-> installed sexplib0.v0.17.0
-> installed re.1.13.2
-> installed integers.0.7.0
-> installed printbox-md.0.12
-> installed bigstringaf.0.10.0
-> installed thread-local-storage.0.2
-> installed parsexp.v0.17.0
-> installed curl.0.10.0
-> installed angstrom.0.16.1
-> installed tyxml.4.6.0
-> installed mdx.2.5.0
-> installed sexplib.v0.17.0
-> installed printbox-html.0.12
-> installed printbox-ext-plot.0.12
-> installed base.v0.17.3
-> installed fieldslib.v0.17.0
-> installed variantslib.v0.17.0
-> installed stdio.v0.17.0
-> installed ctypes.0.23.0
-> installed ppxlib.0.36.0
-> installed ctypes-foreign.0.23.0
-> installed ppx_optcomp.v0.17.1
-> installed ppx_cold.v0.17.0
-> installed ppx_here.v0.17.0
-> installed ppxlib_jane.v0.17.4
-> installed ppx_variants_conv.v0.17.1
-> installed ppx_fields_conv.v0.17.0
-> installed ppx_deriving.6.1.0
-> installed ppx_enumerate.v0.17.0
-> installed ppx_globalize.v0.17.2
-> installed ppx_compare.v0.17.0
-> installed ppx_sexp_conv.v0.17.1
-> installed ppx_hash.v0.17.0
-> installed ppx_assert.v0.17.0
-> installed ppx_minidebug.2.3.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.1
-> installed ppx_expect.v0.17.3
Done.
# To update the current shell environment, run: eval $(opam env)
2025-07-12 16:32.53 ---> using "1609d00ad32f4c91c4f3506bfc6643d87f2913587a69d939279cb6411d09e5c6" from cache
/: (copy (src .) (dst /Users/opam/src))
2025-07-12 16:33.49 ---> saved as "86719d0e520ee0690173d8198df0a20f9b72246add7a238d63bc72e32d2ef328"
/: (run (shell "cd /cygdrive/c/Users/opam/src && 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/operations/config && ..\..\..\arrayjit\bin\read_config.exe --read=backend)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\operations\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
File "test/ppx/test_ppx_op_expected.ml", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/ppx/test_ppx_op_expected.ml _build/default/test/ppx/test_ppx_op_actual.ml
diff --git a/_build/default/test/ppx/test_ppx_op_expected.ml b/_build/default/test/ppx/test_ppx_op_actual.ml
index a6aa4ae..307a71f 100644
--- a/_build/default/test/ppx/test_ppx_op_expected.ml
+++ b/_build/default/test/ppx/test_ppx_op_actual.ml
@@ -2,20 +2,20 @@ open Base
open Ocannl
module TDSL = Operation.TDSL
let y0 =
- let hey1 = TDSL.param ?values:None "hey1" in
+ let hey1 = TDSL.param ?value:None "hey1" in
let open! TDSL.O in
((+) ?label:(Some ["y0"]))
((( *. ) ?label:None) (TDSL.number (Float.of_int 2)) hey1)
(TDSL.number (Float.of_int 3))
let y1 =
- let hey2 = TDSL.param ?values:None "hey2" in
+ let hey2 = TDSL.param ?value:None "hey2" in
let open! TDSL.O in
fun x ->
((+) ?label:(Some
(List.concat [["y1"]; (x.Tensor.value).Ir.Tnode.label])))
((( * ) ?label:None) hey2 (TDSL.number (Float.of_int 2))) x
let y2 =
- let hey3 = TDSL.param ?values:None "hey3" in
+ let hey3 = TDSL.param ?value:None "hey3" in
let open! TDSL.O in
fun x1 x2 ->
((+) ?label:(Some
@@ -36,14 +36,14 @@ let b =
~output_dims:[2]
[|(Float.of_int 7);(Float.of_int 8);(Float.of_int 9);(Float.of_int 10)|]
let y =
- let hey4 = TDSL.param ?values:None "hey4" in
+ let hey4 = TDSL.param ?value:None "hey4" in
let open! TDSL.O in
((+) ?label:(Some ["y"]))
((( * ) ?label:None) hey4 (TDSL.number ?label:None ~axis_label:"q" 2.0))
(TDSL.number ?label:None ~axis_label:"p" 1.0)
let z =
- let hey5 = TDSL.param ?values:None "hey5"
- and hey6 = TDSL.param ?values:None "hey6" in
+ let hey5 = TDSL.param ?value:None "hey5"
+ and hey6 = TDSL.param ?value:None "hey6" in
let open! TDSL.O in
((+) ?label:(Some ["z"]))
((( * ) ?label:None) (TDSL.number ?label:None ~axis_label:"q" 2.0) hey5)
@@ -51,8 +51,8 @@ let z =
let stride = 2
and dilation = 3
let z2 =
- let hey7 = TDSL.param ?values:None "hey7"
- and hey8 = TDSL.param ?values:None "hey8" in
+ let hey7 = TDSL.param ?value:None "hey7"
+ and hey8 = TDSL.param ?value:None "hey8" in
let open! TDSL.O in
TDSL.einsum ?label:(Some ["z2"])
(String.concat ~sep:""
@@ -61,8 +61,8 @@ let z2 =
let z3 =
let s = 2
and d = 3 in
- let hey10 = TDSL.param ?values:None "hey10"
- and hey9 = TDSL.param ?values:None "hey9" in
+ let hey10 = TDSL.param ?value:None "hey10"
+ and hey9 = TDSL.param ?value:None "hey9" in
let open! TDSL.O in
TDSL.einsum ?label:(Some [])
(String.concat ~sep:""
@@ -78,7 +78,7 @@ let mlp_layer =
let b =
(TDSL.param ~more_label:(config.label)) ~output_dims:[config.hid_dim]
"b"
- and w = (TDSL.param ~more_label:(config.label)) ?values:None "w" in
+ and w = (TDSL.param ~more_label:(config.label)) ?value:None "w" in
fun x ->
(relu
?label:(Some
(cd _build/default/test/ppx && .\test_ppx_op.exe)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\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/einsum/test_print_style.expected", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/einsum/test_print_style.expected _build/default/test/einsum/test_print_style.exe.output
diff --git a/_build/default/test/einsum/test_print_style.expected b/_build/default/test/einsum/test_print_style.exe.output
index e51ab37..ec0dfbd 100644
--- a/_build/default/test/einsum/test_print_style.expected
+++ b/_build/default/test/einsum/test_print_style.exe.output
@@ -1,5 +1,5 @@
-Welcome to OCANNL! Reading configuration defaults from /Users/lukstafi/ocannl/_build/default/test/ocannl_config.
+Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Testing print_style functionality:
(cd _build/default/test/ppx && .\test_ppx_op_expected.exe)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\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/einsum/test_conv_syntax.expected", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/einsum/test_conv_syntax.expected _build/default/test/einsum/test_conv_syntax.exe.output
diff --git a/_build/default/test/einsum/test_conv_syntax.expected b/_build/default/test/einsum/test_conv_syntax.exe.output
index 7098c49..c4fb351 100644
--- a/_build/default/test/einsum/test_conv_syntax.expected
+++ b/_build/default/test/einsum/test_conv_syntax.exe.output
@@ -1,5 +1,5 @@
-Welcome to OCANNL! Reading configuration defaults from /Users/lukstafi/ocannl/_build/default/test/einsum/ocannl_config.
+Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Testing conv syntax parsing...
File "test/training/dune", line 5, characters 7-17:
5 | (name moons_demo)
^^^^^^^^^^
(cd _build/default/test/training && .\moons_demo.exe) > _build/default/test/training/moons_demo.exe.output
Fatal error: exception Utils.User_error("The linked context lacks node b1")
Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 861, characters 8-11
Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 860, characters 8-14
Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
Called from Dune__exe__Moons_demo.main in file "test/training/moons_demo.ml", line 50, characters 4-83
Called from Dune__exe__Moons_demo in file "test/training/moons_demo.ml", line 131, characters 9-16
File "test/operations/dune", lines 19-29, characters 0-281:
19 | (rule
20 | (alias runtest)
21 | (target
22 | (dir log_files))
23 | (action
24 | (run
25 | %{dep:micrograd_demo_logging.exe}
26 | "--ocannl_debug_backend=text"
27 | "--ocannl_log_file_stem=micrograd_demo_logging"
28 | "--ocannl_log_main_domain_to_stdout=false"
29 | "--ocannl_debug_log_to_stream_files=true")))
(cd _build/default/test/operations && .\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 C:\Users\opam\src\_build\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Retrieving commandline, environment, or config file variable ocannl_backend
Found multicore_cc, in the config file
Retrieving commandline, environment, or config file variable ocannl_limit_constant_fill_size
Not found, using default 256
Retrieving commandline, environment, or config file variable ocannl_cd_ident_style
Not found, using default heuristic
Retrieving commandline, environment, or config file variable ocannl_ll_ident_style
Not found, using default heuristic
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
Found true, commandline --ocannl_debug_log_to_stream_files=true
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 x86_64-w64-mingw32-gcc
Retrieving commandline, environment, or config file variable ocannl_cc_backend_verify_codesign
Not found, using default false
Fatal error: exception File "src/printbox-text/PrintBox_text.ml", line 212, characters 6-12: Assertion failed
Raised at PrintBox_text.Output.Make_out.to_buf_aux_ in file "src/printbox-text/PrintBox_text.ml", line 212, characters 6-50
Called from Stdlib__Map.Make.fold in file "map.ml", line 329, characters 19-42
Called from Stdlib__Map.Make.fold in file "map.ml", line 329, characters 26-41
Called from Stdlib__Map.Make.fold in file "map.ml", line 329, characters 26-41
Called from Stdlib__Map.Make.fold in file "map.ml", line 329, characters 26-41
Called from PrintBox_text.Output.Make_out.render in file "src/printbox-text/PrintBox_text.ml", line 242, characters 14-64
Called from PrintBox_text.output in file "src/printbox-text/PrintBox_text.ml", line 851, characters 2-31
Called from Minidebug_runtime.PrintBox.output_box in file "minidebug_runtime.ml", line 1527, characters 19-59
Called from Minidebug_runtime.PrintBox.close_log_impl.close_tree in file "minidebug_runtime.ml", line 1572, characters 6-38
Called from Backends.Add_buffer_retrieval_and_syncing.sync_routine in file "arrayjit/lib/backends.ml", lines 207-235, characters 31-82
Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 539-540, characters 4-92
Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
Called from Dune__exe__Micrograd_demo_logging in file "test/operations/micrograd_demo_logging.ml", line 36, characters 13-76
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition "Retrieving commandline, environment, or config file variable ocannl_log_level" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition "Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\75660aa7a7ba25ebc5e9e14262b8d780\default\test\operations\ocannl_config." -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition "Found 0, in the config file" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition "" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum && .einsum_tutorials.inline-tests\inline-test-runner.exe inline-test-runner einsum_tutorials -partition "" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\0fb69c092a35771e142363b4696e5614\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum && .einsum_tutorials.inline-tests\inline-test-runner.exe inline-test-runner einsum_tutorials -partition "Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\c8a5c98a4134e81896eff03cd1267d0a\default\test\einsum\ocannl_config." -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\0fb69c092a35771e142363b4696e5614\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum && .einsum_tutorials.inline-tests\inline-test-runner.exe inline-test-runner einsum_tutorials -partition "Retrieving commandline, environment, or config file variable ocannl_log_level" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\0fb69c092a35771e142363b4696e5614\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum && .einsum_tutorials.inline-tests\inline-test-runner.exe inline-test-runner einsum_tutorials -partition "Found 0, in the config file" -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\0fb69c092a35771e142363b4696e5614\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition zero2hero_1of7.ml -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition primitive_ops.ml -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
(cd _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations && .operations_tutorials.inline-tests\inline-test-runner.exe inline-test-runner operations_tutorials -partition hello_world_op.ml -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\60ecf5e825c2aa39c8bae307b0f8dda8\default\test\operations\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
File "test/operations/zero2hero_1of7.ml", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml.corrected
diff --git a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml.corrected
index 3b7cc00..2e741fa 100644
--- a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml
+++ b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/zero2hero_1of7.ml.corrected
@@ -30,24 +30,24 @@ let%expect_test "Graph drawing recompile" =
Tensor.print_tree ~with_grad:true ~depth:9 f_nd;
[%expect
{|
- #15 +_f_nd
- 6.00e+1
- #16 grad_+_f_nd Virt/30
- <void>
- #13 - Virt/152 β#2 5. Virt/40
- <void> β<void>
- #14 grad_- Virt/30 β
- <void> β
- #11 *. Virt/152 β #4 *. Virt/152 β
- <void> β <void> β
- #12 grad_*. Virt/30 β #5 grad_*. Virt/30 β
- <void> β <void> β
- #10 3. Virt/40β#7 **. Virt/152 β#3 4. Virt/40β#0 x β
- <void> β<void> β<void> β 5.00 β
- β#8 grad_**. Virt/30β β#1 grad_x Local/30β
- β<void> β β<void> β
- β[0]β #6 2. Virt/40 β β β
- β β <void> β β β
+ #15 +_f_nd
+ 5.00
+ #16 grad_+_f_nd Virt/30
+ <void>
+ #13 - Virt/152 β#2 5. Virt/40
+ <void> β<void>
+ #14 grad_- Virt/30 β
+ <void> β
+ #11 *. Virt/152 β#4 *. Virt/152 β
+ <void> β<void> β
+ #12 grad_*. Virt/30 β#5 grad_*. Virt/30β
+ <void> β<void> β
+ #10 3. Virt/40β#7 **. Virt/152 β#3 4. Virt/40β[0] β
+ <void> β<void> β<void> β β
+ β#8 grad_**. Virt/30β β β
+ β<void> β β β
+ β[0]β #6 2. Virt/40 β β β
+ β β <void> β β β
|}];
let%op f = (3 *. ("x" [ 5 ] **. 2)) - (4 *. x) + 5 in
Train.every_non_literal_on_host f;
@@ -55,27 +55,7 @@ let%expect_test "Graph drawing recompile" =
let f_bprop = Train.to_routine (module Backend) ctx IDX.empty f_upd in
Train.run f_bprop;
Tensor.print_tree ~with_grad:true ~depth:9 f;
- [%expect
- {|
- #32 +_f
- 6.00e+1
- #33 grad_+_f
- 1.00
- #30 - β#19 5. Virt/40
- 5.50e+1 β<void>
- #31 grad_- β
- 1.00 β
- #28 *. β #21 *. β
- 7.50e+1 β 2.00e+1 β
- #29 grad_*. β #22 grad_*. β
- 1.00 β -1.00 β
- #27 3. Virt/40β #24 **. β#20 4. Virt/40β#17 x β
- <void> β 2.50e+1 β<void> β 5.00 β
- β #25 grad_**. β β#18 grad_xβ
- β 3.00 β β 2.60e+1 β
- β[17]β#23 2. Virt/40β β β
- β β<void> β β β
- |}];
+ [%expect.unreachable];
let xs = Array.init 10 ~f:Float.(fun i -> of_int i - 5.) in
let ys =
Array.map xs ~f:(fun v ->
@@ -94,54 +74,21 @@ let%expect_test "Graph drawing recompile" =
[ Scatterplot { points = Array.zip_exn xs ys; content = PrintBox.line "#" } ]
in
PrintBox_text.output Stdio.stdout plot_box;
- [%expect
- {|
- ββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β 1.00e+2β# β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β β
- β β # β
- β β β
- β β β
- β β β
- β β β
- βf β β
- β( β β
- βx β β
- β) β β
- β β β
- β β # β
- β β β
- β β β
- β β #β
- β β β
- β β β
- β β β
- β β β
- β β # β
- β β β
- β β # β
- β β β
- β β β
- β β # β
- β β # β
- β β β
- β 4.00 β # # β
- ββββββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- β β-5.00 4.00β
- β β x β
- ββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}]
+ [%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(\"The linked context lacks node x\")")
+ Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
+ Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
+ Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
+ Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
+ Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
+ Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
+ Called from Operations_tutorials__Zero2hero_1of7.(fun) in file "test/operations/zero2hero_1of7.ml", line 55, characters 16-69
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
let%expect_test "Graph drawing fetch" =
Tensor.unsafe_reinitialize ();
@@ -271,96 +218,39 @@ let%expect_test "Simple gradients hosted" =
let sgd_routine = Train.to_routine (module Backend) grad_routine.context IDX.empty sgd in
(* Check out the initial state without running a forward pass. *)
Tensor.print_tree ~spy:true ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l Host&stream/41
- <not-in-yet>
- #13 grad_*._l Host&stream/41
- <not-in-yet>
- #8 +_d Host&stream/41 β#10 f Host&shared/39
- <not-in-yet> β<not-in-yet>
- #9 grad_+_d Host&stream/41 β#11 grad_f Host&stream/41
- <not-in-yet> β<not-in-yet>
- #4 *._e Host&stream/41 β#6 c Host&shared/39 β
- <not-in-yet> β<not-in-yet> β
- #5 grad_*._e Host&stream/41 β#7 grad_c Host&stream/41β
- <not-in-yet> β<not-in-yet> β
- #0 a Host&shared/39 β#2 b Host&shared/39 β β
- <not-in-yet> β<not-in-yet> β β
- #1 grad_a Host&stream/41β#3 grad_b Host&stream/41β β
- <not-in-yet> β<not-in-yet> β β
- |}];
+ [%expect.unreachable];
(* Do not update the params: all values and gradients will be at initial points, which are
specified in the tensor in the brackets. *)
Train.run grad_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -8.00
- #13 grad_*._l
- 1.00
- #8 +_d β#10 f
- 4.00 β -2.00
- #9 grad_+_d β#11 grad_f
- -2.00 β 4.00
- #4 *._e β#6 c β
- -6.00 β 1.00e+1 β
- #5 grad_*._e β#7 grad_cβ
- -2.00 β -2.00 β
- #0 a β#2 b β β
- 2.00 β -3.00 β β
- #1 grad_aβ#3 grad_bβ β
- 6.00 β -4.00 β β
- |}];
+ [%expect.unreachable];
(* Now we update the params, but we are not doing the forward and backward passes: only params
values will change, compared to the above. The update is in the opposite direction of the
gradient. *)
Train.run sgd_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -8.00
- #13 grad_*._l
- 1.00
- #8 +_d β#10 f
- 4.00 β -2.40
- #9 grad_+_d β#11 grad_f
- -2.00 β 4.00
- #4 *._e β#6 c β
- -6.00 β 1.02e+1 β
- #5 grad_*._e β#7 grad_cβ
- -2.00 β -2.00 β
- #0 a β#2 b β β
- 1.40 β -2.60 β β
- #1 grad_aβ#3 grad_bβ β
- 6.00 β -4.00 β β
- |}];
+ [%expect.unreachable];
(* Now the params will remain as above, but both param gradients and the values and gradients of
other nodes will change thanks to the forward and backward passes. *)
Train.run grad_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -1.57e+1
- #13 grad_*._l
- 1.00
- #8 +_d β#10 f
- 6.56 β -2.40
- #9 grad_+_d β#11 grad_f
- -2.40 β 6.56
- #4 *._e β#6 c β
- -3.64 β 1.02e+1 β
- #5 grad_*._e β#7 grad_cβ
- -2.40 β -2.40 β
- #0 a β#2 b β β
- 1.40 β -2.60 β β
- #1 grad_aβ#3 grad_bβ β
- 6.24 β -3.36 β β
- |}]
+ [%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(\"The linked context lacks node a\")")
+ Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
+ Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 860, characters 8-14
+ Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
+ Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
+ Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
+ Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
+ Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
+ Called from Operations_tutorials__Zero2hero_1of7.(fun) in file "test/operations/zero2hero_1of7.ml", line 270, characters 21-73
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
let%expect_test "Simple gradients virtual" =
Tensor.unsafe_reinitialize ();
@@ -381,68 +271,29 @@ let%expect_test "Simple gradients virtual" =
Tensor.print_tree ~spy:true ~with_grad:true ~depth:9 l;
[%expect
{|
- #12 *._l Host&dev/41
- <not-in-yet>
- #13 grad_*._l unknown
- <not-in-yet>
- #8 +_d unknown β#10 f Host-non-const/24
- <not-in-yet> β<not-in-yet>
- #9 grad_+_d unknown β#11 grad_f Material/28
- <not-in-yet> β<not-in-yet>
- #4 *._e unknown β#6 c Host-non-const/24β
- <not-in-yet> β<not-in-yet> β
- #5 grad_*._e unknown β#7 grad_c Material/28 β
- <not-in-yet> β<not-in-yet> β
- #0 a Host-non-const/24β#2 b Host-non-const/24β β
- <not-in-yet> β<not-in-yet> β β
- #1 grad_a Material/28 β#3 grad_b Material/28 β β
- <not-in-yet> β<not-in-yet> β β
+ #12 *._l Host&dev/412
+ <not-in-yet>
+ #13 grad_*._l unknown
+ <not-in-yet>
+ #8 +_d unknown β[10]
+ <not-in-yet> β
+ #9 grad_+_d unknown β
+ <not-in-yet> β
+ #4 *._e unknown β[6]β
+ <not-in-yet> β β
+ #5 grad_*._e unknownβ β
+ <not-in-yet> β β
+ [0]β[2] β β
|}];
let grad_routine = Train.to_routine (module Backend) ctx IDX.empty grad in
(* Check out the state without running a forward pass or compiling the SGD update. *)
Tensor.print_tree ~spy:true ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l Host&stream/41
- <not-in-yet>
- #13 grad_*._l Virt/40
- <not-in-yet>
- #8 +_d Local/46 β#10 f Host&shared/39
- <not-in-yet> β<not-in-yet>
- #9 grad_+_d Virt/40 β#11 grad_f Dev-stream/41
- <not-in-yet> β<not-in-yet>
- #4 *._e Virt/152 β#6 c Host&shared/39 β
- <not-in-yet> β<not-in-yet> β
- #5 grad_*._e Virt/40 β#7 grad_c Dev-stream/41β
- <not-in-yet> β<not-in-yet> β
- #0 a Host&shared/39 β#2 b Host&shared/39 β β
- <not-in-yet> β<not-in-yet> β β
- #1 grad_a Dev-stream/41β#3 grad_b Dev-stream/41β β
- <not-in-yet> β<not-in-yet> β β
- |}];
+ [%expect.unreachable];
(* Do not update the params: all values and gradients will be at initial points, which are
specified in the tensor in the brackets. *)
Train.run grad_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -8.00
- #13 grad_*._l Virt/40
- <void>
- #8 +_d Local/46 β#10 f
- <void> β -2.00
- #9 grad_+_d Virt/40 β#11 grad_f Dev-stream/41
- <void> β<void>
- #4 *._e Virt/152 β#6 c β
- <void> β 1.00e+1 β
- #5 grad_*._e Virt/40 β#7 grad_c Dev-stream/41β
- <void> β<void> β
- #0 a β#2 b β β
- 2.00 β -3.00 β β
- #1 grad_a Dev-stream/41β#3 grad_b Dev-stream/41β β
- <void> β<void> β β
- |}];
+ [%expect.unreachable];
(* Only now compile the SGD update. *)
let sgd_routine = Train.to_routine (module Backend) grad_routine.context IDX.empty sgd in
(* Now we update the params, but are not doing the forward and backward passes: only params values
@@ -450,48 +301,28 @@ let%expect_test "Simple gradients virtual" =
always be recomputed using the latest parameter state. *)
Train.run sgd_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -8.00
- #13 grad_*._l Virt/40
- <void>
- #8 +_d Local/46 β#10 f
- <void> β -2.40
- #9 grad_+_d Virt/40 β#11 grad_f Dev-stream/41
- <void> β<void>
- #4 *._e Virt/152 β#6 c β
- <void> β 1.02e+1 β
- #5 grad_*._e Virt/40 β#7 grad_c Dev-stream/41β
- <void> β<void> β
- #0 a β#2 b β β
- 1.40 β -2.60 β β
- #1 grad_a Dev-stream/41β#3 grad_b Dev-stream/41β β
- <void> β<void> β β
- |}];
+ [%expect.unreachable];
(* Now the params will remain as above, but both param gradients and the values and gradients of
other nodes will change thanks to the forward and backward passes. *)
Train.run grad_routine;
Tensor.print_tree ~with_grad:true ~depth:9 l;
- [%expect
- {|
- #12 *._l
- -1.57e+1
- #13 grad_*._l Virt/40
- <void>
- #8 +_d Local/46 β#10 f
- <void> β -2.40
- #9 grad_+_d Virt/40 β#11 grad_f Dev-stream/41
- <void> β<void>
- #4 *._e Virt/152 β#6 c β
- <void> β 1.02e+1 β
- #5 grad_*._e Virt/40 β#7 grad_c Dev-stream/41β
- <void> β<void> β
- #0 a β#2 b β β
- 1.40 β -2.60 β β
- #1 grad_a Dev-stream/41β#3 grad_b Dev-stream/41β β
- <void> β<void> β β
- |}]
+ [%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(\"The linked context lacks node a\")")
+ Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
+ Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 860, characters 8-14
+ Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 860, characters 8-14
+ Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
+ Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
+ Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
+ Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
+ Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
+ Called from Operations_tutorials__Zero2hero_1of7.(fun) in file "test/operations/zero2hero_1of7.ml", line 401, characters 21-73
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
let%expect_test "tanh plot" =
Tensor.unsafe_reinitialize ();
@@ -510,21 +341,22 @@ let%expect_test "2D neuron hosted" =
let routine = Train.to_routine (module Backend) ctx IDX.empty update in
Train.run routine;
Tensor.print_tree ~with_grad:true ~depth:9 v;
- [%expect
- {|
- #8 +_v
- 7.00e-1
- #9 grad_+_v
- 1.00
- #6 * β#0 b
- -6.00 β 6.70
- #7 grad_* β#1 grad_b
- 1.00 β 1.00
- #2 w β#4 x β
- -3.00 1.00 β 2.00 0.00 β
- #3 grad_w β#5 grad_x β
- 2.00 0.00 β -3.00 1.00 β
- |}]
+ [%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(\"The linked context lacks node b\")")
+ Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
+ Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 861, characters 8-11
+ Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
+ Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
+ Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
+ Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
+ Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
+ Called from Operations_tutorials__Zero2hero_1of7.(fun) in file "test/operations/zero2hero_1of7.ml", line 510, characters 16-70
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
let%expect_test "2D neuron virtual" =
Tensor.unsafe_reinitialize ();
@@ -537,18 +369,19 @@ let%expect_test "2D neuron virtual" =
let routine = Train.to_routine (module Backend) ctx IDX.empty update in
Train.run routine;
Tensor.print_tree ~with_grad:true ~depth:9 v;
- [%expect
- {|
- #8 +_v
- 7.00e-1
- #9 grad_+_v Virt/40
- <void>
- #6 * Local/46 β#0 b
- <void> β 6.70
- #7 grad_* Virt/40 β#1 grad_b Local/46
- <void> β<void>
- #2 w β#4 x β
- -3.00 1.00 β 2.00 0.00 β
- #3 grad_w Local/46β#5 grad_x Local/46β
- <void> β<void> β
- |}]
+ [%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(\"The linked context lacks node b\")")
+ Raised at Backends.verify_prior_context.(fun) in file "arrayjit/lib/backends.ml", line 285, characters 11-93
+ Called from Base__Set.Tree0.iter.iter in file "src/set.ml", line 860, characters 8-14
+ Called from Base__Set.Accessors.iter in file "src/set.ml" (inlined), line 1193, characters 18-38
+ Called from Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 281-285, characters 2-94
+ Re-raised at Backends.verify_prior_context in file "arrayjit/lib/backends.ml", lines 280-285, characters 37-94
+ Called from Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 527-528, characters 4-49
+ Re-raised at Backends.Raise_backend.link in file "arrayjit/lib/backends.ml", lines 526-540, characters 23-92
+ Called from Operations_tutorials__Zero2hero_1of7.(fun) in file "test/operations/zero2hero_1of7.ml", line 537, characters 16-70
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
File "test/operations/hello_world_op.ml", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml.corrected
diff --git a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml.corrected
index 6407bb4..1e22e2c 100644
--- a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml
+++ b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/hello_world_op.ml.corrected
@@ -36,11 +36,11 @@ let%expect_test "Pointwise multiplication dims 1" =
{|
ββββββββββββββββββββββ
β[3]: *._y shape 0:1 β
- βββ¬ββββββββββ β
- βββaxis 0 β β
- βββΌββββββββββ€ β
- βββ 1.40e+1 β β
- βββ΄ββββββββββ β
+ βββ¬ββββββββββββ β
+ βββaxis 0 β β
+ βββΌββββββββββββ€ β
+ βββ -1.53e+26 β β
+ βββ΄ββββββββββββ β
ββββββββββββββββββββββ
|}]
@@ -67,11 +67,11 @@ let%expect_test "Matrix multiplication dims 1x1" =
{|
ββββββββββββββββββββββββββ
β[0]: hey shape 1:1->0:1 β
- βββββββββ¬βββββββ β
- ββ βaxis 1β β
- βββββββββΌβββββββ€ β
- ββaxis 0β 7.00 β β
- βββββββββ΄βββββββ β
+ βββββββββ¬ββββββββββββ β
+ ββ βaxis 1 β β
+ βββββββββΌββββββββββββ€ β
+ ββaxis 0β -7.77e+15 β β
+ βββββββββ΄ββββββββββββ β
ββββββββββββββββββββββββββ
|}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ y;
@@ -79,11 +79,11 @@ let%expect_test "Matrix multiplication dims 1x1" =
{|
βββββββββββββββββββββ
β[6]: +_y shape 0:1 β
- βββ¬ββββββββββ β
- βββaxis 0 β β
- βββΌββββββββββ€ β
- βββ 1.50e+1 β β
- βββ΄ββββββββββ β
+ βββ¬ββββββββββββ β
+ βββaxis 0 β β
+ βββΌββββββββββββ€ β
+ βββ -1.55e+16 β β
+ βββ΄ββββββββββββ β
βββββββββββββββββββββ
|}]
@@ -108,7 +108,7 @@ let%expect_test "Print constant tensor" =
Tensor.print ~with_code:false ~with_grad:false `Inline @@ hey;
[%expect
{|
- [0]: [ 1.00 , 2.00 , 3.00 ; 4.00 , 5.00 , 6.00 ]_hey shape 1:3->0:2 [
+ [0]: [ 0.00 , 0.00 , 0.00 ; 0.00 , 0.00 , 0.00 ]_hey shape 1:3->0:2 [
1.00 , 2.00 , 3.00
; 4.00 , 5.00 , 6.00
]
@@ -117,7 +117,7 @@ let%expect_test "Print constant tensor" =
[%expect
{|
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: [ 1.00 , 2.00 , 3.00 ; 4.00 , 5.00 , 6.00 ]_hey shape 1:3->0:2 β
+ β[0]: [ 0.00 , 0.00 , 0.00 ; 0.00 , 0.00 , 0.00 ]_hey shape 1:3->0:2 β
βββββββββ¬βββββββββββββββββββ β
ββ βaxis 1 β β
βββββββββΌβββββββββββββββββββ€ β
@@ -131,7 +131,7 @@ let%expect_test "Print constant tensor" =
Tensor.print ~with_code:false ~with_grad:false `Inline @@ hoo;
[%expect
{|
- [1]: [| [ 1.00 ; 2.00 ; 3.00 ] ; [ 4.00 ; 5.00 ; 6.00 ] |]_hoo shape 0:2|1:3 [|
+ [1]: [| [ 0.00 ; 0.00 ; 0.00 ] ; [ 0.00 ; 0.00 ; 0.00 ] |]_hoo shape 0:2|1:3 [|
[ 1.00 ; 2.00 ; 3.00 ]
; [ 4.00 ; 5.00 ; 6.00 ]
|]
@@ -140,7 +140,7 @@ let%expect_test "Print constant tensor" =
[%expect
{|
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[1]: [| [ 1.00 ; 2.00 ; 3.00 ] ; [ 4.00 ; 5.00 ; 6.00 ] |]_hoo shape 0:2|1:3 β
+ β[1]: [| [ 0.00 ; 0.00 ; 0.00 ] ; [ 0.00 ; 0.00 ; 0.00 ] |]_hoo shape 0:2|1:3 β
βββββββββ¬βββββββββββββββββββ β
ββ βaxis 1 β β
βββββββββΌβββββββββββββββββββ€ β
@@ -471,28 +471,28 @@ let%expect_test "Matrix multiplication dims 2x3" =
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
{|
- ββββββββββββββββββββββββββ
- β[0]: hey shape 1:2->0:3 β
- βββββββββ¬βββββββββββββ β
- ββ βaxis 1 β β
- βββββββββΌβββββββββββββ€ β
- ββaxis 0β 7.00 7.00 β β
- ββ β 7.00 7.00 β β
- ββ β 7.00 7.00 β β
- βββββββββ΄βββββββββββββ β
- ββββββββββββββββββββββββββ
+ βββββββββββββββββββββββββββββββ
+ β[0]: hey shape 1:2->0:3 β
+ βββββββββ¬ββββββββββββββββββββββ
+ ββ βaxis 1 ββ
+ βββββββββΌβββββββββββββββββββββ€β
+ ββaxis 0β 1.01e-38 8.72e-39 ββ
+ ββ β 9.64e-39 9.27e-39 ββ
+ ββ β 1.61e-43 0.00 ββ
+ βββββββββ΄ββββββββββββββββββββββ
+ βββββββββββββββββββββββββββββββ
|}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ y;
[%expect
{|
- ββββββββββββββββββββββββββββββββ
- β[6]: +_y shape 0:3 β
- βββ¬βββββββββββββββββββββββββββββ
- βββaxis 0 ββ
- βββΌββββββββββββββββββββββββββββ€β
- βββ 3.90e+1 4.00e+1 4.10e+1 ββ
- βββ΄βββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββ
+ βββββββββββββββββββββββ
+ β[6]: +_y shape 0:3 β
+ βββ¬ββββββββββββββββββββ
+ βββaxis 0 ββ
+ βββΌβββββββββββββββββββ€β
+ βββ 4.00 5.00 6.00 ββ
+ βββ΄ββββββββββββββββββββ
+ βββββββββββββββββββββββ
|}]
let%expect_test "Big matrix" =
@@ -516,70 +516,37 @@ let%expect_test "Big matrix" =
Train.forward_and_forget backend ctx y;
Tensor.print ~with_code:false ~with_grad:false `Inline zero_to_twenty;
[%expect
- {|
- [2]: 0...20 shape 0:21 [
- 0.00
- ; 1.00
- ; 2.00
- ; 3.00
- ; 4.00
- ; 5.00
- ; 6.00
- ; 7.00
- ; 8.00
- ; 9.00
- ; 10.00
- ; 11.00
- ; 12.00
- ; 13.00
- ; 14.00
- ; 15.00
- ; 16.00
- ; 17.00
- ; 18.00
- ; 19.00
- ; 20.00
- ]
- |}];
+ {| [2]: 0...20 shape 0:21 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default zero_to_twenty;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββββββββ
- β[2]: 0...20 shape 0:21 β
- βββ¬βββββββββββββββββββββββββββββββββββββ
- βββaxis 0 ββ
- βββΌββββββββββββββββββββββββββββββββββββ€β
- βββ 0.00 1.00 ... 1.90e+1 2.00e+1 ββ
- βββ΄βββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [2]: 0...20 shape 0:21 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default hey;
[%expect
{|
- ββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: hey shape 1:21->0:21 β
- βββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ βaxis 1 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββaxis 0β 5.00e-1 5.00e-1 ... 5.00e-1 5.00e-1 ββ
- ββ β 5.00e-1 5.00e-1 ... 5.00e-1 5.00e-1 ββ
- ββ β ... ... ... ... ... ββ
- ββ β 5.00e-1 5.00e-1 ... 5.00e-1 5.00e-1 ββ
- ββ β 5.00e-1 5.00e-1 ... 5.00e-1 5.00e-1 ββ
- βββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββ
+ ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+ β[0]: hey shape 1:21->0:21 β
+ βββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββ
+ ββ βaxis 1 ββ
+ βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββββββ€β
+ ββaxis 0β -1.30e+16 7.62e-43 ... -2.28e-26 -1.36e-38 ββ
+ ββ β -1.18e+21 -2.28e-26 ... -2.28e-26 -1.36e-38 ββ
+ ββ β ... ... ... ... ... ββ
+ ββ β 0.00 0.00 ... 0.00 0.00 ββ
+ ββ β 0.00 0.00 ... 0.00 0.00 ββ
+ βββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββ
+ ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
|}];
Tensor.print ~with_code:false ~with_grad:false `Default y;
[%expect
{|
- ββββββββββββββββββββββββββββββββββββββββββββββ
- β[5]: + shape 0:21 β
- βββ¬βββββββββββββββββββββββββββββββββββββββββββ
- βββaxis 0 ββ
- βββΌββββββββββββββββββββββββββββββββββββββββββ€β
- βββ 1.05e+2 1.06e+2 ... 1.24e+2 1.25e+2 ββ
- βββ΄βββββββββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββ
+ ββββββββββββββββββββββββββββββββββββββββββββββββββ
+ β[5]: + shape 0:21 β
+ βββ¬βββββββββββββββββββββββββββββββββββββββββββββββ
+ βββaxis 0 ββ
+ βββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
+ βββ -1.45e+26 -7.47e+22 ... 1.90e+1 2.00e+1 ββ
+ βββ΄βββββββββββββββββββββββββββββββββββββββββββββββ
+ ββββββββββββββββββββββββββββββββββββββββββββββββββ
|}]
let%expect_test "Very big tensor" =
@@ -603,140 +570,7 @@ let%expect_test "Very big tensor" =
Train.forward_and_forget backend ctx hoo;
Tensor.print ~with_code:false ~with_grad:false `Default hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r6x10x11x7x8x9 shape 0:6|3:7,4:8,5:9->1:10,2:11 β
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ0 @ 0 β0 @ 4 β1 @ 4 β~~~~~ β6 @ 4 β7 @ 4 ββ
- ββ β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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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.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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ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 ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- β ... β
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ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 ββ
- ββ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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... β ... ββ
- ββaxis 2β β β β β ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ8 @ 1 β 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 ββ
- ββ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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ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 ββ
- ββ β 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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌβββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r6x10x11x7x8x9 shape 0:6|3:7,4:8,5:9->1:10,2:11 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default hoo;
(* Disable line wrapping for viewing the output. In VSCode: `View: Toggle Word Wrap`. *)
[%expect
File "test/operations/primitive_ops.ml", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml _build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml.corrected
diff --git a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml.corrected
index c0aa497..0f54388 100644
--- a/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml
+++ b/_build/.sandbox/60ecf5e825c2aa39c8bae307b0f8dda8/default/test/operations/primitive_ops.ml.corrected
@@ -318,54 +318,129 @@ let%expect_test "sin(x)" =
let%op f x = sin x in
let plot_box = plot_unop ~f () in
PrintBox_text.output Stdio.stdout plot_box;
- [%expect
- {|
- βββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β 9.99e-1 β # β
- β β#### ## *** ** ### ### β
- β β # ** ** # # β
- β β # * * # # β
- β β # # # β
- β β # * * # # β
- β β * * # β
- β β # * #* β
- β β # # # β
- β β * * β
- β β # * # * # β
- β β # # β
- β β # * * β
- β β # # # β
- β β* * * *β
- β β # # # β
- β β * * * * β
- β β # # # β
- βf β * * * * β
- β( β # # # β
- βx β- * - - - - - - *- - - - - - * - - - - - -* β
- β) β # # # β
- β β * * * * β
- β β # # # β
- β β * * * * β
- β β # # # β
- β β * * * * β
- β β # # # β
- β β * * * # * β
- β β # * # * β
- β β * # # # * β
- β β * * * * β
- β β # # # β
- β β * * # * #* β
- β β * * * * β
- β β * # # * # β
- β β * * # # * * # β
- β β * * # # * * # β
- β β ** * # # * ** # β
- β -9.99e-1β * ***** ####### **** * ## ####β
- βββββββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- β β-5.00 5.00β
- β β x β
- βββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}]
+ [%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. *)
+ "Assert_failure arrayjit/lib/c_syntax.ml:453:4"
+ Raised at Ir__C_syntax.C_syntax.pp_array_offset in file "arrayjit/lib/c_syntax.ml", line 453, characters 4-39
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 509, characters 25-53
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 479, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.pp_ll in file "arrayjit/lib/c_syntax.ml", line 480, characters 17-25
+ Called from Ir__C_syntax.C_syntax.compile_main in file "arrayjit/lib/c_syntax.ml" (inlined), line 732, characters 43-52
+ Called from Ir__C_syntax.C_syntax.compile_proc in file "arrayjit/lib/c_syntax.ml", line 855, characters 63-79
+ Called from Backends__Cc_backend.compile in file "arrayjit/lib/cc_backend.ml", line 137, characters 25-69
+ Called from Backends.Add_device.compile in file "arrayjit/lib/backends.ml", line 326, characters 15-45
+ Called from Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", line 443, characters 29-59
+ Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", line 443, characters 4-59
+ Re-raised at Backends.Raise_backend.compile in file "arrayjit/lib/backends.ml", lines 439-447, characters 26-99
+ Called from Ocannl__Train.to_routine in file "lib/train.ml", line 354, characters 26-82
+ Called from Operations_tutorials__Primitive_ops.plot_unop in file "test/operations/primitive_ops.ml", line 35, characters 19-72
+ Called from Operations_tutorials__Primitive_ops.(fun) in file "test/operations/primitive_ops.ml", line 319, characters 17-32
+ Called from Ppx_expect_runtime__Test_block.Configured.dump_backtrace in file "runtime/test_block.ml", line 142, characters 10-28
+ |}]
let%expect_test "cos(x)" =
let%op f x = cos x in
File "test/einsum/einsum_trivia_exec.expected", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/einsum/einsum_trivia_exec.expected _build/default/test/einsum/einsum_trivia_exec.exe.output
diff --git a/_build/default/test/einsum/einsum_trivia_exec.expected b/_build/default/test/einsum/einsum_trivia_exec.exe.output
index ab456b5..71061a0 100644
--- a/_build/default/test/einsum/einsum_trivia_exec.expected
+++ b/_build/default/test/einsum/einsum_trivia_exec.exe.output
@@ -1,5 +1,5 @@
-Welcome to OCANNL! Reading configuration defaults from /Users/lukstafi/ocannl/_build/default/test/einsum/ocannl_config.
+Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
HERE: test/einsum/einsum_trivia_exec.ml:31:21
@@ -735,173 +735,173 @@ HERE: test/einsum/einsum_trivia_exec.ml:269:21
HERE: test/einsum/einsum_trivia_exec.ml:298:21
-ββββββββββββββββββββββββββββββββββ
-β[9]: ;=>+ shape 0:4,1:5,2:6,3:3 β
-βββββββββ¬βββββββββββββββββββ β
-ββ0 @ 0 βaxis 3 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ0 @ 1 β 0.00 0.00 0.00 β β
-ββaxis 2β 0.00 0.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 0.00 0.00 4.00 β β
-ββ β 0.00 0.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ1 @ 1 β 0.00 1.00 0.00 β β
-ββaxis 2β 0.00 1.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 0.00 1.00 4.00 β β
-ββ β 0.00 1.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ2 @ 1 β 0.00 2.00 0.00 β β
-ββaxis 2β 0.00 2.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 0.00 2.00 4.00 β β
-ββ β 0.00 2.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ3 @ 1 β 0.00 3.00 0.00 β β
-ββaxis 2β 0.00 3.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 0.00 3.00 4.00 β β
-ββ β 0.00 3.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ4 @ 1 β 0.00 4.00 0.00 β β
-ββaxis 2β 0.00 4.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 0.00 4.00 4.00 β β
-ββ β 0.00 4.00 5.00 β β
-βββββββββ΄βββββββββββββββββββ β
-ββββββββββββββββββββββββββββββββββ€
-βββββββββ¬βββββββββββββββββββ β
-ββ1 @ 0 βaxis 3 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ0 @ 1 β 1.00 0.00 0.00 β β
-ββaxis 2β 1.00 0.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 1.00 0.00 4.00 β β
-ββ β 1.00 0.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ1 @ 1 β 1.00 1.00 0.00 β β
-ββaxis 2β 1.00 1.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 1.00 1.00 4.00 β β
-ββ β 1.00 1.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ2 @ 1 β 1.00 2.00 0.00 β β
-ββaxis 2β 1.00 2.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 1.00 2.00 4.00 β β
-ββ β 1.00 2.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ3 @ 1 β 1.00 3.00 0.00 β β
-ββaxis 2β 1.00 3.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 1.00 3.00 4.00 β β
-ββ β 1.00 3.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ4 @ 1 β 1.00 4.00 0.00 β β
-ββaxis 2β 1.00 4.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 1.00 4.00 4.00 β β
-ββ β 1.00 4.00 5.00 β β
-βββββββββ΄βββββββββββββββββββ β
-ββββββββββββββββββββββββββββββββββ€
-βββββββββ¬βββββββββββββββββββ β
-ββ2 @ 0 βaxis 3 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ0 @ 1 β 2.00 0.00 0.00 β β
-ββaxis 2β 2.00 0.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 2.00 0.00 4.00 β β
-ββ β 2.00 0.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ1 @ 1 β 2.00 1.00 0.00 β β
-ββaxis 2β 2.00 1.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 2.00 1.00 4.00 β β
-ββ β 2.00 1.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ2 @ 1 β 2.00 2.00 0.00 β β
-ββaxis 2β 2.00 2.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 2.00 2.00 4.00 β β
-ββ β 2.00 2.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ3 @ 1 β 2.00 3.00 0.00 β β
-ββaxis 2β 2.00 3.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 2.00 3.00 4.00 β β
-ββ β 2.00 3.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ4 @ 1 β 2.00 4.00 0.00 β β
-ββaxis 2β 2.00 4.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 2.00 4.00 4.00 β β
-ββ β 2.00 4.00 5.00 β β
-βββββββββ΄βββββββββββββββββββ β
-ββββββββββββββββββββββββββββββββββ€
-βββββββββ¬βββββββββββββββββββ β
-ββ3 @ 0 βaxis 3 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ0 @ 1 β 3.00 0.00 0.00 β β
-ββaxis 2β 3.00 0.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 3.00 0.00 4.00 β β
-ββ β 3.00 0.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ1 @ 1 β 3.00 1.00 0.00 β β
-ββaxis 2β 3.00 1.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 3.00 1.00 4.00 β β
-ββ β 3.00 1.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ2 @ 1 β 3.00 2.00 0.00 β β
-ββaxis 2β 3.00 2.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 3.00 2.00 4.00 β β
-ββ β 3.00 2.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ3 @ 1 β 3.00 3.00 0.00 β β
-ββaxis 2β 3.00 3.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 3.00 3.00 4.00 β β
-ββ β 3.00 3.00 5.00 β β
-βββββββββΌβββββββββββββββββββ€ β
-ββ4 @ 1 β 3.00 4.00 0.00 β β
-ββaxis 2β 3.00 4.00 1.00 β β
-ββ β ... ... ... β β
-ββ β 3.00 4.00 4.00 β β
-ββ β 3.00 4.00 5.00 β β
-βββββββββ΄βββββββββββββββββββ β
-ββββββββββββββββββββββββββββββββββ
+ββββββββββββββββββββββββββββββββββββββββββ
+β[9]: ;=>+ shape 0:4,1:5,2:6,3:3 β
+βββββββββ¬βββββββββββββββββββββββββββββββββ
+ββ0 @ 0 βaxis 3 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ0 @ 1 β -3.33e+17 7.16e-39 -6.13e+7 ββ
+ββaxis 2β -3.33e+17 7.16e-39 -6.13e+7 ββ
+ββ β ... ... ... ββ
+ββ β -3.33e+17 7.16e-39 -6.13e+7 ββ
+ββ β -3.33e+17 7.16e-39 -6.13e+7 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ1 @ 1 β -6.13e+7 1.00 1.40e+1 ββ
+ββaxis 2β 1.90e-42 1.00 1.50e+1 ββ
+ββ β ... ... ... ββ
+ββ β 9.51e-43 1.00 1.80e+1 ββ
+ββ β 9.51e-43 1.00 1.90e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ2 @ 1 β -6.13e+7 2.00 5.00 ββ
+ββaxis 2β 3.00 2.00 6.00 ββ
+ββ β ... ... ... ββ
+ββ β 3.00 2.00 9.00 ββ
+ββ β 3.00 2.00 1.00e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ3 @ 1 β -6.13e+7 3.00 1.70e+1 ββ
+ββaxis 2β 1.50e+1 3.00 1.80e+1 ββ
+ββ β ... ... ... ββ
+ββ β 1.50e+1 3.00 2.10e+1 ββ
+ββ β 1.50e+1 3.00 2.20e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ4 @ 1 β -6.13e+7 4.00 8.00 ββ
+ββaxis 2β 6.00 4.00 9.00 ββ
+ββ β ... ... ... ββ
+ββ β 6.00 4.00 1.20e+1 ββ
+ββ β 6.00 4.00 1.30e+1 ββ
+βββββββββ΄βββββββββββββββββββββββββββββββββ
+ββββββββββββββββββββββββββββββββββββββββββ€
+βββββββββ¬βββββββββββββββββββββββββββββββββ
+ββ1 @ 0 βaxis 3 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ0 @ 1 β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββaxis 2β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββ β ... ... ... ββ
+ββ β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββ β -3.33e+17 8.72e-39 -6.13e+7 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ1 @ 1 β -6.13e+7 1.00 1.40e+1 ββ
+ββaxis 2β 1.00 1.00 1.50e+1 ββ
+ββ β ... ... ... ββ
+ββ β 1.00 1.00 1.80e+1 ββ
+ββ β 1.00 1.00 1.90e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ2 @ 1 β -6.13e+7 2.00 5.00 ββ
+ββaxis 2β 4.00 2.00 6.00 ββ
+ββ β ... ... ... ββ
+ββ β 4.00 2.00 9.00 ββ
+ββ β 4.00 2.00 1.00e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ3 @ 1 β -6.13e+7 3.00 1.70e+1 ββ
+ββaxis 2β 1.60e+1 3.00 1.80e+1 ββ
+ββ β ... ... ... ββ
+ββ β 1.60e+1 3.00 2.10e+1 ββ
+ββ β 1.60e+1 3.00 2.20e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ4 @ 1 β -6.13e+7 4.00 8.00 ββ
+ββaxis 2β 7.00 4.00 9.00 ββ
+ββ β ... ... ... ββ
+ββ β 7.00 4.00 1.20e+1 ββ
+ββ β 7.00 4.00 1.30e+1 ββ
+βββββββββ΄βββββββββββββββββββββββββββββββββ
+ββββββββββββββββββββββββββββββββββββββββββ€
+βββββββββ¬βββββββββββββββββββββββββββββββββ
+ββ2 @ 0 βaxis 3 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ0 @ 1 β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββaxis 2β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββ β ... ... ... ββ
+ββ β -3.33e+17 8.72e-39 -6.13e+7 ββ
+ββ β -3.33e+17 8.72e-39 -6.13e+7 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ1 @ 1 β -6.13e+7 1.00 1.40e+1 ββ
+ββaxis 2β 2.00 1.00 1.50e+1 ββ
+ββ β ... ... ... ββ
+ββ β 2.00 1.00 1.80e+1 ββ
+ββ β 2.00 1.00 1.90e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ2 @ 1 β -6.13e+7 2.00 5.00 ββ
+ββaxis 2β 5.00 2.00 6.00 ββ
+ββ β ... ... ... ββ
+ββ β 5.00 2.00 9.00 ββ
+ββ β 5.00 2.00 1.00e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ3 @ 1 β -6.13e+7 3.00 1.70e+1 ββ
+ββaxis 2β 1.70e+1 3.00 1.80e+1 ββ
+ββ β ... ... ... ββ
+ββ β 1.70e+1 3.00 2.10e+1 ββ
+ββ β 1.70e+1 3.00 2.20e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ4 @ 1 β -6.13e+7 4.00 8.00 ββ
+ββaxis 2β 8.00 4.00 9.00 ββ
+ββ β ... ... ... ββ
+ββ β 8.00 4.00 1.20e+1 ββ
+ββ β 8.00 4.00 1.30e+1 ββ
+βββββββββ΄βββββββββββββββββββββββββββββββββ
+ββββββββββββββββββββββββββββββββββββββββββ€
+βββββββββ¬βββββββββββββββββββββββββββββββββ
+ββ3 @ 0 βaxis 3 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ0 @ 1 β -3.33e+17 1.04e-42 -6.13e+7 ββ
+ββaxis 2β -3.33e+17 9.66e-44 -6.13e+7 ββ
+ββ β ... ... ... ββ
+ββ β -3.33e+17 9.66e-44 -6.13e+7 ββ
+ββ β -3.33e+17 9.66e-44 -6.13e+7 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ1 @ 1 β -6.13e+7 1.00 1.40e+1 ββ
+ββaxis 2β 3.00 1.00 1.50e+1 ββ
+ββ β ... ... ... ββ
+ββ β 3.00 1.00 1.80e+1 ββ
+ββ β 3.00 1.00 1.90e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ2 @ 1 β -6.13e+7 2.00 5.00 ββ
+ββaxis 2β 6.00 2.00 6.00 ββ
+ββ β ... ... ... ββ
+ββ β 6.00 2.00 9.00 ββ
+ββ β 6.00 2.00 1.00e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ3 @ 1 β -6.13e+7 3.00 1.70e+1 ββ
+ββaxis 2β 1.80e+1 3.00 1.80e+1 ββ
+ββ β ... ... ... ββ
+ββ β 1.80e+1 3.00 2.10e+1 ββ
+ββ β 1.80e+1 3.00 2.20e+1 ββ
+βββββββββΌββββββββββββββββββββββββββββββββ€β
+ββ4 @ 1 β -6.13e+7 4.00 8.00 ββ
+ββaxis 2β 9.00 4.00 9.00 ββ
+ββ β ... ... ... ββ
+ββ β 9.00 4.00 1.20e+1 ββ
+ββ β 9.00 4.00 1.30e+1 ββ
+βββββββββ΄βββββββββββββββββββββββββββββββββ
+ββββββββββββββββββββββββββββββββββββββββββ
HERE: test/einsum/einsum_trivia_exec.ml:299:21
-βββββββββββββββββββββββββββββ
-β[1]: =>_ti shape 0:4,1:3 β
-βββββββββ¬ββββββββββββββββββββ
-ββ βaxis 1 ββ
-βββββββββΌβββββββββββββββββββ€β
-ββaxis 0β 0.00 0.00 0.00 ββ
-ββ β 1.00 0.00 0.00 ββ
-ββ β 2.00 0.00 0.00 ββ
-ββ β 3.00 0.00 0.00 ββ
-βββββββββ΄ββββββββββββββββββββ
-βββββββββββββββββββββββββββββ
+βββββββββββββββββββββββββββββββββββββ
+β[1]:>_ti shape 0:4,1:3 β
+βββββββββ¬ββββββββββββββββββββββββββββ
+ββ βaxis 1 ββ
+βββββββββΌβββββββββββββββββββββββββββ€β
+ββaxis 0β 0.00 7.16e-39 6.97e-39 ββ
+ββ β 1.00 8.72e-39 6.24e-39 ββ
+ββ β 2.00 8.72e-39 7.71e-39 ββ
+ββ β 3.00 9.66e-44 4.22e-39 ββ
+βββββββββ΄ββββββββββββββββββββββββββββ
+βββββββββββββββββββββββββββββββββββββ
HERE: test/einsum/einsum_trivia_exec.ml:300:21
-βββββββββββββββββββββββββββββ
-β[7]: =>_tk shape 0:6,1:3 β
-βββββββββ¬ββββββββββββββββββββ
-ββ βaxis 1 ββ
-βββββββββΌβββββββββββββββββββ€β
-ββaxis 0β 0.00 0.00 0.00 ββ
-ββ β 0.00 0.00 1.00 ββ
-ββ β ... ... ... ββ
-ββ β 0.00 0.00 4.00 ββ
-ββ β 0.00 0.00 5.00 ββ
-βββββββββ΄ββββββββββββββββββββ
-βββββββββββββββββββββββββββββ
+βββββββββββββββββββββββββββββββββββββ
+β[7]: =>_tk shape 0:6,1:3 β
+βββββββββ¬ββββββββββββββββββββββββββββ
+ββ βaxis 1 ββ
+βββββββββΌβββββββββββββββββββββββββββ€β
+ββaxis 0β -6.13e+7 9.51e-43 0.00 ββ
+ββ β 9.51e-43 0.00 1.00 ββ
+ββ β ... ... ... ββ
+ββ β 0.00 0.00 4.00 ββ
+ββ β 0.00 0.00 5.00 ββ
+βββββββββ΄ββββββββββββββββββββββββββββ
+βββββββββββββββββββββββββββββββββββββ
HERE: test/einsum/einsum_trivia_exec.ml:323:21
File "test/einsum/moons_demo_variant.expected", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/einsum/moons_demo_variant.expected _build/default/test/einsum/moons_demo_variant.exe.output
diff --git a/_build/default/test/einsum/moons_demo_variant.expected b/_build/default/test/einsum/moons_demo_variant.exe.output
index 68171df..9f32c29 100644
--- a/_build/default/test/einsum/moons_demo_variant.expected
+++ b/_build/default/test/einsum/moons_demo_variant.exe.output
@@ -1,121 +1,124 @@
-Welcome to OCANNL! Reading configuration defaults from /Users/lukstafi/ocannl/_build/default/test/einsum/ocannl_config.
+Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
Half-moons scatterplot and decision boundary:
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
-β****************************#***********************************************************************β
-β****************************###***###***#***********************************************************β
-β***************************#********#***#**********************************************************.β
-β********************#*********************##*#*#************************************************....β
-β******************#***#*****##*#*#*#****#*#*#*##**********************************************......β
-β**************#*#**###**#*##**##********#**#****###**#*************************************.........β
-β***********#***##***#**##*****************#*#*##*###*************************************...........β
-β***************#**###******************************##*#********************************.............β
-β*************#*****#******************************#*#***#*#*************************................β
-β*********#***#************************************##*###**#***********************..................β
-β******#***#*#*#******************************************#*#*******************.....................β
-β*****###****#*******************************************#********************.......................β
-β*******#*###***********************************************#*#************..........................β
-β**********##**********************%%*********************#**##**********............................β
-β*****#***#**********************%**%%********************************.............................%.β
-β**####*************************%**%**************************##*#**............................%...%β
-β****#**************************%%**%*************************#*#*..............................%....β
-β*#****##************************%*...%*********************##*..#...........................%...%%..β
-β****#*#***********************.%..%.%........................#..#.............................%.%...β
-β##*##*********************.......%.............................#.##.........................%.%.%%%.β
-β**#####*****************.......%...%%.......................................................%..%.%..β
-β**********************...........%.%.%%.....................#.#.#.#.............................%%..β
-β***##****************............%..%..%........................#.#.........................%...%...β
-β##**#**************................%...%.....................#..###......................%.%%.......β
-β###***************...............%.%.%...........................##............................%....β
-β**##************.................................................#......................%%.%..%.....β
-β**#************....................%%...........................##......................%%.%........β
-β**************........................%......................#..#...........................%.......β
-β************........................%%.%.......................##.....................%..%..........β
-β***********............................%%..............................................%%.%%........β
-β**********.............................%...%............................................%%%.........β
-β********...................................%..%....................................%.....%..........β
-β*******.................................%%..%.%................................%.%.%.%%.............β
-β******.....................................%%.%...%%.%.......................%%%....%.%.%...........β
-β*****....................................%.....%.%..%....................%.....%%.%.%...............β
-β***.........................................%%...%.%%%%..%.......%.........%%.%%....................β
-β**................................................%..%.......%..%%%%...%.%..%.%.....................β
-β*..................................................%.%.%............%..%...%........................β
-β..................................................%....%.%......%%...%.%............................β
-β..........................................................%..%......%%%.............................β
+β...................................#................................................................β
+β..........................##..#..###....##..........................................................β
+β.........................#....#.....#...............................................................β
+β.......................#.##.#.......#####...#.#.....................................................β
+β..................#.#.#...#..#.##....#.#.##..#....#.................................................β
+β.............#.#......##.#..#..........###..#....#..................................................β
+β.............##..##.....#....................#.##.###...#...........................................β
+β.............#.##.#.#.#.......................#...##..#.............................................β
+β.........#.#....##..................................##..#...........................................β
+β...........#.#....................................#..##...#.#.......................................β
+β..........##..........................................#...#.#.......................................β
+β.......#...###............................................#.........................................β
+β....#....##..........................%..................#....##.....................................β
+β.........##................................................#..#..............................%......β
+β.....#..#........................%..%......................##.#...................................%.β
+β...##.#..................................................#....................................%...%.β
+β..###...........................%..%%......................###................................%.%...β
+β..#...#.#.......................%%.%%.......................#.##.#............................%.....β
+β..#...#.............................%.........................##..............................%...%.β
+β..##..#............................%%.........................#..##.........................%%..%.%%β
+β#...#..#.........................%.%%%.......................##...#............................%.%..β
+β##...#.............................%%.........................#.#..#................................β
+β...................................%%%%.......................##.#.#........................%%..%.%.β
+β###................................%%..............................#.......................%....%...β
+β..##................................%%%.%....................................................%%..%..β
+β.#.....................................%.......................#.###......................%.%%.%....β
+β.....#................................%...%................................................%...%....β
+β...................................%.....%%......................#..................................β
+β.....................................%%%..%...........................................%..%%..%......β
+β.......................................%%.....%......................................%..%.%.%.......β
+β.........................................%%............................................%..%%.%......β
+β..........................................%.%.....%...............................%.%.%%..%.........β
+β.........................................%%%..%%......................................%.............β
+β...........................................%.%..%..............................%%.%.%.%%.%..........β
+β..............................................%%%%..%.%.......................%%..%.%.%.............β
+β..............................................%..%%%.%%...................%..%%...%.................β
+β...............................................%...%.%.%..%...%.%%..%%.%%...%.......................β
+β......................................................%%.%%%..%.%..%%.%.%.%%........................β
+β.....................................................%...........%%%%......%%.......................β
+β.......................................................%.%%%%.%.......%...%.........................β
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββLoss:
-ββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
-β 3.79e+1β- β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-βl β β
-βo β β
-βs β β
-βs β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β - β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β β
-β β - - - - β
-β 0.00 β - ---- --- --- ---- ---- ---- ---- -- - ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- β
-ββββββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
-β β0.00 7.90e+1β
-β β step β
-ββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββLog-loss, for better visibility:
+βββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+β 2.18β - β
+β β - β
+β β - β
+β β β
+β β - - - β
+β β β
+β β - - β
+β β - β
+β β β
+β β - - β
+β β - β
+β β - β
+β β - β
+β β - - β
+β β - β
+β β - β
+β β - β
+β β - - β
+βl β β
+βo β - - - β
+βs β β
+βs β - β
+β β- - - β
+β β - β
+β β - β
+β β - - - β
+β β β
+β β - - β
+β β - β
+β β - - - β
+β β β
+β β - - β
+β β - - β
+β β - β
+β β - - β
+β β - β
+β β - - β
+β β - - β
+β β β
+β 0.00β --- ---- ---- ---- --- ---- - ---- -- β
+βββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
+β β0.00 7.90e+1β
+β β step β
+βββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββLog-loss, for better visibility:
βββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
-β 3.63 β- β
+β 7.79e-1 β - β
+β β --- ---- ---- β
+β β -- --- --- β
+β β- -- - - - -- β
+β β - - - -- β
+β β - - -- -- β
+β β - - - β
+β β - - - β
+β β - - β
+β β - β
+β β - - - β
β β β
β β β
β β β
-β β - β
β β β
+β β - - β
+βl β β
+βo β β
+βg β β
+β β - β
+βl β β
+βo β β
+βs β β
+βs β β
+β β - β
β β β
β β β
β β β
-β β - β
-β β - β
-β β - - - β
-β β - - - - β
-β β -- - - - - - - - -- - - - - - -- β
-β β - - - - - - - -- - - -- - - - - β
-β β - - - β
-βl β - - - -- - β
-βo β - - β
-βg β - - - - β
-β β - - - β
-βl β - -- β
-βo β - - - β
-βs β - β
-βs β - β
-β β - β
β β β
β β β
β β β
@@ -127,10 +130,7 @@ Half-moons scatterplot and decision boundary:
β β β
β β β
β β β
-β β β
-β β β
-β β β
-β -1.00e+1β - - - - - - - β
+β -1.00e+1β -- ---- ---- ---- -- ---- ---- - β
βββββββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
β β0.00 7.90e+1β
β β step β
(cd _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum && .einsum_tutorials.inline-tests\inline-test-runner.exe inline-test-runner einsum_tutorials -partition einsum_trivia.ml -source-tree-root ../.. -diff-cmd -)
Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\.sandbox\0fb69c092a35771e142363b4696e5614\default\test\einsum\ocannl_config.
Retrieving commandline, environment, or config file variable ocannl_log_level
Found 0, in the config file
File "test/einsum/einsum_trivia.ml", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml _build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml.corrected
diff --git a/_build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml b/_build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml.corrected
index 8724033..b8fc7c9 100644
--- a/_build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml
+++ b/_build/.sandbox/0fb69c092a35771e142363b4696e5614/default/test/einsum/einsum_trivia.ml.corrected
@@ -31,20 +31,7 @@ let%expect_test "einsum1 permute axes" =
Train.forward_and_forget backend ctx ho;
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho;
[%expect
{|
@@ -67,106 +54,7 @@ let%expect_test "einsum1 permute axes" =
Train.forward_and_forget backend ctx ho2;
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey2;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[2]: r2x3x6x7x4x5 shape 0:2,1:3|4:4,5:5->2:6,3:7 β
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββ
- ββ0 @ 1 β0 @ 4 β1 @ 4 β2 @ 4 β3 @ 4 ββ
- ββ βaxis 5 βaxis 5 βaxis 5 βaxis 5 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ0 @ 2 β 0.00 1.00 2.00 3.00 4.00 β 5.00 6.00 7.00 8.00 9.00 β 1.00e+1 1.10e+1 1.20e+1 1.30e+1 1.40e+1 β 1.50e+1 1.60e+1 1.70e+1 1.80e+1 1.90e+1 ββ
- ββaxis 3β 2.00e+1 2.10e+1 2.20e+1 2.30e+1 2.40e+1 β 2.50e+1 2.60e+1 2.70e+1 2.80e+1 2.90e+1 β 3.00e+1 3.10e+1 3.20e+1 3.30e+1 3.40e+1 β 3.50e+1 3.60e+1 3.70e+1 3.80e+1 3.90e+1 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 1.00e+2 1.01e+2 1.02e+2 1.03e+2 1.04e+2 β 1.05e+2 1.06e+2 1.07e+2 1.08e+2 1.09e+2 β 1.10e+2 1.11e+2 1.12e+2 1.13e+2 1.14e+2 β 1.15e+2 1.16e+2 1.17e+2 1.18e+2 1.19e+2 ββ
- ββ β 1.20e+2 1.21e+2 1.22e+2 1.23e+2 1.24e+2 β 1.25e+2 1.26e+2 1.27e+2 1.28e+2 1.29e+2 β 1.30e+2 1.31e+2 1.32e+2 1.33e+2 1.34e+2 β 1.35e+2 1.36e+2 1.37e+2 1.38e+2 1.39e+2 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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+2 2.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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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.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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 @ 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.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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ~~~~~ β ... β ... β ... β ... ββ
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
- ββ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 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 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]: r2x3x6x7x4x5 shape 0:2,1:3|4:4,5:5->2:6,3:7 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho2;
[%expect
{|
@@ -295,20 +183,7 @@ let%expect_test "einsum1 sum out axes" =
Train.forward_and_forget backend ctx ho;
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho;
[%expect
{|
@@ -367,28 +242,10 @@ let%expect_test "einsum outer product" =
Train.forward_and_forget backend ctx c;
Tensor.print ~with_code:false ~with_grad:false `Default @@ a;
[%expect
- {|
- ββββββββββββββββββββ
- β[0]: r2 shape 0:2 β
- βββ¬βββββββββββββ β
- βββaxis 0 β β
- βββΌβββββββββββββ€ β
- βββ 0.00 1.00 β β
- βββ΄βββββββββββββ β
- ββββββββββββββββββββ
- |}];
+ {| [0]: r2 shape 0:2 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ b;
[%expect
- {|
- βββββββββββββββββββββββ
- β[1]: r3 shape 0:3 β
- βββ¬ββββββββββββββββββββ
- βββaxis 0 ββ
- βββΌβββββββββββββββββββ€β
- βββ 0.00 1.00 2.00 ββ
- βββ΄ββββββββββββββββββββ
- βββββββββββββββββββββββ
- |}];
+ {| [1]: r3 shape 0:3 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ c;
[%expect
{|
@@ -409,37 +266,10 @@ let%expect_test "einsum outer product" =
Train.forward_and_forget backend ctx c;
Tensor.print ~with_code:false ~with_grad:false `Default @@ a;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[5]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [5]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ b;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[6]: r5x7x6 shape 0:5|2:6->1:7 β
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 β2 @ 0 β3 @ 0 β4 @ 0 ββ
- ββ βaxis 2 βaxis 2 βaxis 2 βaxis 2 βaxis 2 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 ... 4.00 5.00 β 4.20e+1 4.30e+1 ... 4.60e+1 4.70e+1 β 8.40e+1 8.50e+1 ... 8.80e+1 8.90e+1 β 1.26e+2 1.27e+2 ... 1.30e+2 1.31e+2 β 1.68e+2 1.69e+2 ... 1.72e+2 1.73e+2 ββ
- ββ β 6.00 7.00 ... 1.00e+1 1.10e+1 β 4.80e+1 4.90e+1 ... 5.20e+1 5.30e+1 β 9.00e+1 9.10e+1 ... 9.40e+1 9.50e+1 β 1.32e+2 1.33e+2 ... 1.36e+2 1.37e+2 β 1.74e+2 1.75e+2 ... 1.78e+2 1.79e+2 ββ
- ββ β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... β ... ... ... ... ... ββ
- ββ β 3.00e+1 3.10e+1 ... 3.40e+1 3.50e+1 β 7.20e+1 7.30e+1 ... 7.60e+1 7.70e+1 β 1.14e+2 1.15e+2 ... 1.18e+2 1.19e+2 β 1.56e+2 1.57e+2 ... 1.60e+2 1.61e+2 β 1.98e+2 1.99e+2 ... 2.02e+2 2.03e+2 ββ
- ββ β 3.60e+1 3.70e+1 ... 4.00e+1 4.10e+1 β 7.80e+1 7.90e+1 ... 8.20e+1 8.30e+1 β 1.20e+2 1.21e+2 ... 1.24e+2 1.25e+2 β 1.62e+2 1.63e+2 ... 1.66e+2 1.67e+2 β 2.04e+2 2.05e+2 ... 2.08e+2 2.09e+2 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [6]: r5x7x6 shape 0:5|2:6->1:7 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ c;
[%expect
{|
@@ -726,20 +556,7 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
let ctx = Train.forward_and_ctx backend ctx ho in
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho;
[%expect
{|
@@ -779,106 +596,7 @@ let%expect_test "einsum1 broadcast or sum out prefix axes" =
let ctx = Train.forward_and_ctx backend ctx ho3 in
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey2;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[3]: r2x3x6x7x4x5 shape 0:2,1:3|4:4,5:5->2:6,3:7 β
- βββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββ
- ββ0 @ 1 β0 @ 4 β1 @ 4 β2 @ 4 β3 @ 4 ββ
- ββ βaxis 5 βaxis 5 βaxis 5 βaxis 5 ββ
- βββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββββββββββββββββββββ€β
...TRUNCATED BY DUNE...
Tensor.print ~with_code:false ~with_grad:false `Default @@ e;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββ
- β[4]: r3x4 shape 1:4->0:3 β
- βββββββββ¬ββββββββββββββββββββββββββββββββ
- ββ βaxis 1 ββ
- βββββββββΌβββββββββββββββββββββββββββββββ€β
- ββaxis 0β 0.00 1.00 2.00 3.00 ββ
- ββ β 4.00 5.00 6.00 7.00 ββ
- ββ β 8.00 9.00 1.00e+1 1.10e+1 ββ
- βββββββββ΄ββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [4]: r3x4 shape 1:4->0:3 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ f;
[%expect
{|
@@ -1256,20 +891,7 @@ let%expect_test "einsum1 fixed dim axis" =
let ctx = Train.forward_and_ctx backend ctx ho in
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho;
[%expect
{|
@@ -1287,20 +909,7 @@ let%expect_test "einsum1 fixed dim axis" =
let ctx = Train.forward_and_ctx backend ctx ho2 in
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r2x4x3 shape 0:2|2:3->1:4 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 ββ
- ββ βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 1.20e+1 1.30e+1 1.40e+1 ββ
- ββ β 3.00 4.00 5.00 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 6.00 7.00 8.00 β 1.80e+1 1.90e+1 2.00e+1 ββ
- ββ β 9.00 1.00e+1 1.10e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x4x3 shape 0:2|2:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho2;
[%expect
{|
@@ -1319,18 +928,7 @@ let%expect_test "einsum1 fixed dim axis" =
let ctx = Train.forward_and_ctx backend ctx ho3 in
Tensor.print ~with_code:false ~with_grad:false `Default @@ hey2;
[%expect
- {|
- βββββββββββββββββββββββββββ
- β[3]: r3x2 shape 1:2->0:3 β
- βββββββββ¬βββββββββββββ β
- ββ βaxis 1 β β
- βββββββββΌβββββββββββββ€ β
- ββaxis 0β 0.00 1.00 β β
- ββ β 2.00 3.00 β β
- ββ β 4.00 5.00 β β
- βββββββββ΄βββββββββββββ β
- βββββββββββββββββββββββββββ
- |}];
+ {| [3]: r3x2 shape 1:2->0:3 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ho3;
[%expect
{|
@@ -1382,34 +980,10 @@ let%expect_test "einsum with fixed dim axes" =
Train.forward_and_forget backend ctx c;
Tensor.print ~with_code:false ~with_grad:false `Default @@ a;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r3x2x4 shape 0:3|2:4->1:2 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 β2 @ 0 ββ
- ββ βaxis 2 βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 3.00 β 8.00 9.00 1.00e+1 1.10e+1 β 1.60e+1 1.70e+1 1.80e+1 1.90e+1 ββ
- ββ β 4.00 5.00 6.00 7.00 β 1.20e+1 1.30e+1 1.40e+1 1.50e+1 β 2.00e+1 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r3x2x4 shape 0:3|2:4->1:2 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ b;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββ
- β[1]: r3x4x1 shape 0:3|2:1->1:4 β
- βββββββββ¬βββββββ¬βββββββ¬βββββββββββ
- ββ β0 @ 0 β1 @ 0 β2 @ 0 ββ
- ββ βaxis 2βaxis 2βaxis 2 ββ
- βββββββββΌβββββββΌβββββββΌββββββββββ€β
- ββaxis 1β 0.00 β 4.00 β 8.00 ββ
- ββ β 1.00 β 5.00 β 9.00 ββ
- ββ β 2.00 β 6.00 β 1.00e+1 ββ
- ββ β 3.00 β 7.00 β 1.10e+1 ββ
- βββββββββ΄βββββββ΄βββββββ΄βββββββββββ
- ββββββββββββββββββββββββββββββββββ
- |}];
+ {| [1]: r3x4x1 shape 0:3|2:1->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ c;
[%expect
{|
@@ -1453,175 +1027,175 @@ let%expect_test "outer_sum simulating axis concatenation" =
Tensor.print ~with_code:false ~with_grad:false `Default @@ positions;
[%expect
{|
- ββββββββββββββββββββββββββββββββββ
- β[9]: ;=>+ shape 0:4,1:5,2:6,3:3 β
- βββββββββ¬βββββββββββββββββββ β
- ββ0 @ 0 βaxis 3 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ0 @ 1 β 0.00 0.00 0.00 β β
- ββaxis 2β 0.00 0.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 0.00 0.00 4.00 β β
- ββ β 0.00 0.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ1 @ 1 β 0.00 1.00 0.00 β β
- ββaxis 2β 0.00 1.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 0.00 1.00 4.00 β β
- ββ β 0.00 1.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ2 @ 1 β 0.00 2.00 0.00 β β
- ββaxis 2β 0.00 2.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 0.00 2.00 4.00 β β
- ββ β 0.00 2.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ3 @ 1 β 0.00 3.00 0.00 β β
- ββaxis 2β 0.00 3.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 0.00 3.00 4.00 β β
- ββ β 0.00 3.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ4 @ 1 β 0.00 4.00 0.00 β β
- ββaxis 2β 0.00 4.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 0.00 4.00 4.00 β β
- ββ β 0.00 4.00 5.00 β β
- βββββββββ΄βββββββββββββββββββ β
- ββββββββββββββββββββββββββββββββββ€
- βββββββββ¬βββββββββββββββββββ β
- ββ1 @ 0 βaxis 3 β β
- ββββββββΌβββββββββββββββββββ€ β
- ββ0 @ 1 β 1.00 0.00 0.00 β β
- ββaxis 2β 1.00 0.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 1.00 0.00 4.00 β β
- ββ β 1.00 0.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ1 @ 1 β 1.00 1.00 0.00 β β
- ββaxis 2β 1.00 1.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 1.00 1.00 4.00 β β
- ββ β 1.00 1.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ2 @ 1 β 1.00 2.00 0.00 β β
- ββaxis 2β 1.00 2.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 1.00 2.00 4.00 β β
- ββ β 1.00 2.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ3 @ 1 β 1.00 3.00 0.00 β β
- ββaxis 2β 1.00 3.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 1.00 3.00 4.00 β β
- ββ β 1.00 3.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ4 @ 1 β 1.00 4.00 0.00 β β
- ββaxis 2β 1.00 4.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 1.00 4.00 4.00 β β
- ββ β 1.00 4.00 5.00 β β
- βββββββββ΄βββββββββββββββββββ β
- ββββββββββββββββββββββββββββββββββ€
- βββββββββ¬βββββββββββββββββββ β
- ββ2 @ 0 βaxis 3 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ0 @ 1 β 2.00 0.00 0.00 β β
- ββaxis 2β 2.00 0.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 2.00 0.00 4.00 β β
- ββ β 2.00 0.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ1 @ 1 β 2.00 1.00 0.00 β β
- ββaxis 2β 2.00 1.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 2.00 1.00 4.00 β β
- ββ β 2.00 1.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ2 @ 1 β 2.00 2.00 0.00 β β
- ββaxis 2β 2.00 2.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 2.00 2.00 4.00 β β
- ββ β 2.00 2.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ3 @ 1 β 2.00 3.00 0.00 β β
- ββaxis 2β 2.00 3.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 2.00 3.00 4.00 β β
- ββ β 2.00 3.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ4 @ 1 β 2.00 4.00 0.00 β β
- ββaxis 2β 2.00 4.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 2.00 4.00 4.00 β β
- ββ β 2.00 4.00 5.00 β β
- βββββββββ΄βββββββββββββββββββ β
- ββββββββββββββββββββββββββββββββββ€
- βββββββββ¬βββββββββββββββββββ β
- ββ3 @ 0 βaxis 3 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ0 @ 1 β 3.00 0.00 0.00 β β
- ββaxis 2β 3.00 0.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 3.00 0.00 4.00 β β
- ββ β 3.00 0.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ1 @ 1 β 3.00 1.00 0.00 β β
- ββaxis 2β 3.00 1.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 3.00 1.00 4.00 β β
- ββ β 3.00 1.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ2 @ 1 β 3.00 2.00 0.00 β β
- ββaxis 2β 3.00 2.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 3.00 2.00 4.00 β β
- ββ β 3.00 2.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ3 @ 1 β 3.00 3.00 0.00 β β
- ββaxis 2β 3.00 3.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 3.00 3.00 4.00 β β
- ββ β 3.00 3.00 5.00 β β
- βββββββββΌβββββββββββββββββββ€ β
- ββ4 @ 1 β 3.00 4.00 0.00 β β
- ββaxis 2β 3.00 4.00 1.00 β β
- ββ β ... ... ... β β
- ββ β 3.00 4.00 4.00 β β
- ββ β 3.00 4.00 5.00 β β
- βββββββββ΄βββββββββββββββββββ β
- ββββββββββββββββββββββββββββββββββ
+ βββββββββββββββββββββββββββββββββββββββββββββββ
+ β[9]: ;=>+ shape 0:4,1:5,2:6,3:3 includes NaNβ
+ βββββββββ¬βββββββββββββββββββββββββββββββ β
+ ββ0 @ 0 βaxis 3 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ0 @ 1 β 9.09e-39 8.08e-39 2.00e-38 β β
+ ββaxis 2β 9.09e-39 3.85e-34 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 7.98e-39 4.00 β β
+ ββ β 9.09e-39 7.98e-39 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ1 @ 1 β 9.09e-39 1.00 1.90e-38 β β
+ ββaxis 2β 9.09e-39 1.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.00 4.00 β β
+ ββ β 9.09e-39 1.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ2 @ 1 β 9.82e-39 2.00 1.88e-38 β β
+ ββaxis 2β 9.82e-39 2.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 2.00 4.00 β β
+ ββ β 9.82e-39 2.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ3 @ 1 β 9.27e-39 3.00 2.12e-38 β β
+ ββaxis 2β 9.27e-39 3.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 3.00 4.00 β β
+ ββ β 9.27e-39 3.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ4 @ 1 β 9.09e-39 4.00 2.06e-38 β β
+ ββaxis 2β 9.09e-39 4.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 4.00 4.00 β β
+ ββ β 9.09e-39 4.00 5.00 β β
+ βββββββββ΄βββββββββββββββββββββββββββββββ β
+ βββββββββββββββββββββββββββββββββββββββββββββββ€
+ βββββββββ¬βββββββββββββββββββββββββββββββ β
+ ββ1 @ 0 βaxis 3 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ0 @ 1 β 1.00 1.06e-38 2.04e-38 β β
+ ββaxis 2β 1.00 3.85e-34 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.05e-38 4.00 β β
+ ββ β 1.00 1.05e-38 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ1 @ 1 β 1.00 1.00 1.94e-38 β β
+ ββaxis 2β 1.00 1.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.00 4.00 β β
+ ββ β 1.00 1.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ2 @ 1 β 1.00 2.00 1.92e-38 β β
+ ββaxis 2β 1.00 2.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 2.00 4.00 β β
+ ββ β 1.00 2.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ3 @ 1 β 1.00 3.00 2.16e-38 β β
+ ββaxis 2β 1.00 3.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 3.00 4.00 β β
+ ββ β 1.00 3.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ4 @ 1 β 1.00 4.00 2.11e-38 β β
+ ββaxis 2β 1.00 4.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 4.00 4.00 β β
+ ββ β 1.00 4.00 5.00 β β
+ βββββββββ΄βββββββββββββββββββββββββββββββ β
+ βββββββββββββββββββββββββββββββββββββββββββββββ€
+ βββββββββ¬βββββββββββββββββββββββββββββββ β
+ ββ2 @ 0 βaxis 3 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ0 @ 1 β 2.00 9.36e-39 1.46e-38 β β
+ ββaxis 2β 2.00 3.85e-34 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 9.27e-39 4.00 β β
+ ββ β 2.00 9.27e-39 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ1 @ 1 β 2.00 1.00 1.35e-38 β β
+ ββaxis 2β 2.00 1.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.00 4.00 β β
+ ββ β 2.00 1.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ2 @ 1 β 2.00 2.00 1.34e-38 β β
+ ββaxis 2β 2.00 2.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 2.00 4.00 β β
+ ββ β 2.00 2.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ3 @ 1 β 2.00 3.00 1.57e-38 β β
+ ββaxis 2β 2.00 3.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 3.00 4.00 β β
+ ββ β 2.00 3.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ4 @ 1 β 2.00 4.00 1.52e-38 β β
+ ββaxis 2β 2.00 4.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 4.00 4.00 β β
+ ββ β 2.00 4.00 5.00 β β
+ βββββββββ΄βββββββββββββββββββββββββββββββ β
+ βββββββββββββββββββββββββββββββββββββββββββββββ€
+ βββββββββ¬βββββββββββββββββββββββββββββββ β
+ ββ3 @ 0 βaxis 3 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ0 @ 1 β 3.00 1.01e-38 1.41e-38 β β
+ ββaxis 2β 3.00 3.85e-34 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.00e-38 4.00 β β
+ ββ β 3.00 1.00e-38 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ1 @ 1 β 3.00 1.00 1.31e-38 β β
+ ββaxis 2β 3.00 1.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.00 4.00 β β
+ ββ β 3.00 1.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ2 @ 1 β 3.00 2.00 1.29e-38 β β
+ ββaxis 2β 3.00 2.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 2.00 4.00 β β
+ ββ β 3.00 2.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ3 @ 1 β 3.00 3.00 1.53e-38 β β
+ ββaxis 2β 3.00 3.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 3.00 4.00 β β
+ ββ β 3.00 3.00 5.00 β β
+ βββββββββΌβββββββββββββββββββββββββββββββ€ β
+ ββ4 @ 1 β 3.00 4.00 1.47e-38 β β
+ ββaxis 2β 3.00 4.00 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 4.00 4.00 β β
+ ββ β 3.00 4.00 5.00 β β
+ βββββββββ΄βββββββββββββββββββββββββββββββ β
+ βββββββββββββββββββββββββββββββββββββββββββββββ
|}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ ti;
[%expect
{|
- βββββββββββββββββββββββββββββ
- β[1]: =>_ti shape 0:4,1:3 β
- βββββββββ¬ββββββββββββββββββββ
- ββ βaxis 1 ββ
- βββββββββΌβββββββββββββββββββ€β
- ββaxis 0β 0.00 0.00 0.00 ββ
- ββ β 1.00 0.00 0.00 ββ
- ββ β 2.00 0.00 0.00 ββ
- ββ β 3.00 0.00 0.00 ββ
- βββββββββ΄ββββββββββββββββββββ
- βββββββββββββββββββββββββββββ
+ βββββββββββββββββββββββββββββββββββββ
+ β[1]: =>_ti shape 0:4,1:3 β
+ βββββββββ¬ββββββββββββββββββββββββββββ
+ ββ βaxis 1 ββ
+ βββββββββΌβββββββββββββββββββββββββββ€β
+ ββaxis 0β 0.00 7.98e-39 1.01e-38 ββ
+ ββ β 1.00 1.05e-38 1.05e-38 ββ
+ ββ β 2.00 9.27e-39 4.68e-39 ββ
+ ββ β 3.00 1.00e-38 4.22e-39 ββ
+ βββββββββ΄ββββββββββββββββββββββββββββ
+ βββββββββββββββββββββββββββββββββββββ
|}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ tk;
[%expect
{|
- βββββββββββββββββββββββββββββ
- β[7]: =>_tk shape 0:6,1:3 β
- βββββββββ¬ββββββββββββββββββββ
- ββ βaxis 1 ββ
- βββββββββΌβββββββββββββββββββ€β
- ββaxis 0β 0.00 0.00 0.00 ββ
- ββ β 0.00 0.00 1.00 ββ
- ββ β ... ... ... ββ
- ββ β 0.00 0.00 4.00 ββ
- ββ β 0.00 0.00 5.00 ββ
- βββββββββ΄ββββββββββββββββββββ
- βββββββββββββββββββββββββββββ
+ ββββββββββββββββββββββββββββββββββββββββ
+ β[7]: =>_tk shape 0:6,1:3 includes NaNβ
+ βββββββββ¬βββββββββββββββββββββββββββ β
+ ββ βaxis 1 β β
+ βββββββββΌβββββββββββββββββββββββββββ€ β
+ ββaxis 0β 9.80e-45 9.24e-41 0.00 β β
+ ββ β 1.82e-44 3.85e-34 1.00 β β
+ ββ β ... ... ... β β
+ ββ β 2.25e+15 1.40e-44 4.00 β β
+ ββ β 1.40e-44 0.00 5.00 β β
+ βββββββββ΄βββββββββββββββββββββββββββ β
+ ββββββββββββββββββββββββββββββββββββββββ
|}]
let%expect_test "einsum with a leftmost input axis preserved as output axis" =
@@ -1647,54 +1221,10 @@ let%expect_test "einsum with a leftmost input axis preserved as output axis" =
Train.forward_and_forget backend ctx c;
Tensor.print ~with_code:false ~with_grad:false `Default @@ a;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[0]: r3x2x4_a shape 0:3|2:4->1:2 β
- βββββββββ¬βββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββ
- ββ β0 @ 0 β1 @ 0 β2 @ 0 ββ
- ββ βaxis 2 βaxis 2 βaxis 2 ββ
- βββββββββΌβββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 3.00 β 8.00 9.00 1.00e+1 1.10e+1 β 1.60e+1 1.70e+1 1.80e+1 1.90e+1 ββ
- ββ β 4.00 5.00 6.00 7.00 β 1.20e+1 1.30e+1 1.40e+1 1.50e+1 β 2.00e+1 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r3x2x4_a shape 0:3|2:4->1:2 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ b;
[%expect
- {|
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[1]: r3x4x2x3_b shape 0:3|2:2,3:3->1:4 β
- βββββββββ¬ββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ0 @ 0 β0 @ 2 β1 @ 2 ββ
- ββ βaxis 3 βaxis 3 ββ
- βββββββββΌββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 0.00 1.00 2.00 β 3.00 4.00 5.00 ββ
- ββ β 6.00 7.00 8.00 β 9.00 1.00e+1 1.10e+1 ββ
- ββ β 1.20e+1 1.30e+1 1.40e+1 β 1.50e+1 1.60e+1 1.70e+1 ββ
- ββ β 1.80e+1 1.90e+1 2.00e+1 β 2.10e+1 2.20e+1 2.30e+1 ββ
- βββββββββ΄ββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ1 @ 0 β0 @ 2 β1 @ 2 ββ
- ββ βaxis 3 βaxis 3 ββ
- βββββββββΌββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 2.40e+1 2.50e+1 2.60e+1 β 2.70e+1 2.80e+1 2.90e+1 ββ
- ββ β 3.00e+1 3.10e+1 3.20e+1 β 3.30e+1 3.40e+1 3.50e+1 ββ
- ββ β 3.60e+1 3.70e+1 3.80e+1 β 3.90e+1 4.00e+1 4.10e+1 ββ
- ββ β 4.20e+1 4.30e+1 4.40e+1 β 4.50e+1 4.60e+1 4.70e+1 ββ
- βββββββββ΄ββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
- βββββββββ¬ββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββ
- ββ2 @ 0 β0 @ 2 β1 @ 2 ββ
- ββ βaxis 3 βaxis 3 ββ
- βββββββββΌββββββββββββββββββββββββββββΌββββββββββββββββββββββββββββ€β
- ββaxis 1β 4.80e+1 4.90e+1 5.00e+1 β 5.10e+1 5.20e+1 5.30e+1 ββ
- ββ β 5.40e+1 5.50e+1 5.60e+1 β 5.70e+1 5.80e+1 5.90e+1 ββ
- ββ β 6.00e+1 6.10e+1 6.20e+1 β 6.30e+1 6.40e+1 6.50e+1 ββ
- ββ β 6.60e+1 6.70e+1 6.80e+1 β 6.90e+1 7.00e+1 7.10e+1 ββ
- βββββββββ΄ββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββ
- ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [1]: r3x4x2x3_b shape 0:3|2:2,3:3->1:4 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ c;
[%expect
{|
@@ -1731,34 +1261,10 @@ let%expect_test "einsum permuting two leftmost input axes as output axes" =
Train.forward_and_forget backend ctx c;
Tensor.print ~with_code:false ~with_grad:false `Default @@ a;
[%expect
- {|
- βββββββββββββββββββββββββββββ
- β[0]: r2x2_a shape 1:2->0:2 β
- βββββββββ¬βββββββββββββ β
- ββ βaxis 1 β β
- βββββββββΌβββββββββββββ€ β
- ββaxis 0β 0.00 1.00 β β
- ββ β 2.00 3.00 β β
- βββββββββ΄βββββββββββββ β
- βββββββββββββββββββββββββββββ
- |}];
+ {| [0]: r2x2_a shape 1:2->0:2 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ b;
[%expect
- {|
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- β[1]: r2x2x3x4_b shape 1:2,2:3,3:4->0:2 β
- βββββββββ¬βββββββββββββββββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββ¬ββββββββββββββββββββββββββββββββββββββ
- ββ β0 @ 2 β1 @ 2 β2 @ 2 ββ
- ββ βaxis 3 βaxis 3 βaxis 3 ββ
- βββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββ€β
- ββ0 @ 1 β 0.00 1.00 2.00 3.00 β 4.00 5.00 6.00 7.00 β 8.00 9.00 1.00e+1 1.10e+1 ββ
- ββaxis 0β 2.40e+1 2.50e+1 2.60e+1 2.70e+1 β 2.80e+1 2.90e+1 3.00e+1 3.10e+1 β 3.20e+1 3.30e+1 3.40e+1 3.50e+1 ββ
- βββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββΌβββββββββββββββββββββββββββββββββββββ€β
- ββ1 @ 1 β 1.20e+1 1.30e+1 1.40e+1 1.50e+1 β 1.60e+1 1.70e+1 1.80e+1 1.90e+1 β 2.00e+1 2.10e+1 2.20e+1 2.30e+1 ββ
- ββaxis 0β 3.60e+1 3.70e+1 3.80e+1 3.90e+1 β 4.00e+1 4.10e+1 4.20e+1 4.30e+1 β 4.40e+1 4.50e+1 4.60e+1 4.70e+1 ββ
- βββββββββ΄βββββββββββββββββββββββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββ΄ββββββββββββββββββββββββββββββββββββββ
- βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- |}];
+ {| [1]: r2x2x3x4_b shape 1:2,2:3,3:4->0:2 <virtual> |}];
Tensor.print ~with_code:false ~with_grad:false `Default @@ c;
[%expect
{|
File "test/training/moons_demo_parallel.expected", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/default/test/training/moons_demo_parallel.expected _build/default/test/training/moons_demo_parallel.exe.output
diff --git a/_build/default/test/training/moons_demo_parallel.expected b/_build/default/test/training/moons_demo_parallel.exe.output
index 3582111..0f86c83 100644
--- a/_build/default/test/training/moons_demo_parallel.expected
+++ b/_build/default/test/training/moons_demo_parallel.exe.output
@@ -1 +1,140 @@
-Success
+
+Welcome to OCANNL! Reading configuration defaults from C:\Users\opam\src\_build\default\test\training\ocannl_config.
+Retrieving commandline, environment, or config file variable ocannl_log_level
+Found 0, in the config file
+
+Half-moons scatterplot and decision boundary:
+ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+β...................................#................................................................β
+β.......................#.#################.#........................................................β
+β......................##########################....................................................β
+β.................#################################..................................................β
+β..............######################################................................................β
+β.............#########################################..............................................β
+β...........################.............#################...........................................β
+β..........##############...................###############..........................................β
+β........##############..........................###########.........................................β
+β.......#############............................##.##########.......................................β
+β......###########..................................############.....................................β
+β.....###########....................................###########.....................................β
+β....##########.....................%.................###########....................................β
+β...#########.#...................%%%%.................#########..............................%%%.%%.β
+β...##########..................%%%.%%...................########.#...........................%%.%%%.β
+β..#######......................%%%%%%%..................##########...........................%%%%%%%β
+β.#########....................%%%%%%%%....................########...........................%%%%%%.β
+β.########......................%%%%%%%.....................########..........................%%%%%%.β
+β#########.....................%%.%%%%%......................########........................%%%%%%%.β
+β.#######.......................%%%%%%%%....................#########........................%%%%%%%.β
+β########.......................%%%%%%%%.....................########.......................%%%%%%%%.β
+β#######.........................%%%%%%%......................#######.......................%%%%%%%%.β
+β#######.........................%%%%%%%%......................#######.....................%%%%%%%%..β
+β#######.........................%%%%%%%%.....................#######.....................%%%%%%%%%..β
+β######............................%%%%%%%%...................#######....................%%%%%%%%%...β
+β######...........................%%%%%%%%....................########..................%%%%%%%%%%...β
+β######............................%%%%%%%%%..................#######..................%.%%%%%%%%....β
+β###.#.............................%.%%%%%%%%%.................#.#.##..................%%.%%%%%%%....β
+β....................................%%%%%%%%%.......................................%%%%%%%%%%%.....β
+β......................................%%%%%%%.%.....................................%%%%%%%%%%%.....β
+β.....................................%%%%%%%%%%%.................................%%%%%%%%%%%%.......β
+β......................................%%.%%%%%%%%...............................%%%%%%%%%%%.........β
+β........................................%%%%%%%%%%%%........................%..%%%%%%%%%%%%.........β
+β........................................%%%%%%%%%%%%%%.%....................%%%%%%%%%%%%%...........β
+β..........................................%%%%%%%%%%%%%%%%%..............%%%%%%%%%%%%%%%............β
+β............................................%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%...............β
+β................................................%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%.%..%..............β
+β................................................%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%.%..................β
+β..................................................%%%%%%%%%%%%%%%%%%%%%%%%%%%%.%....................β
+β.....................................................%%.%..%%%%%%%%%%%%%%%..........................β
+ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+Batch Log-loss:
+βββββββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+β 3.16 β - β
+β β - - - - - - -- - -- - -- - -- - -- - -- - -- - -- - -- - - - - - - - - - - - - - - - - β
+β β - - - - - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - ---- β
+β β - - - - - - - - - - - - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - -- - --β
+β β- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -- - -- -β
+β β- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -β
+β β - - - - - - - - - - - - - - - - - - - - β
+β β- - - - - - - - - - - - - β
+β β - - - - β
+β β - - - - β
+β β - - β
+β β - β
+β β - β
+βb β β
+βa β - - β
+βt β β
+βc β β
+βh β β
+β β β
+βl β β
+βo β β
+βg β β
+β β β
+βl β β
+βo β β
+βs β β
+βs β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β -1.04e+1β--- - - - - - β
+βββββββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
+β β0.00 3.99e+2β
+β β step β
+βββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+Epoch Log-loss:
+βββββββ¬βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+β 5.48β - β
+β β - - - - - - β
+β β - - - - - - β
+β β - - - - β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β - - β
+βe β β
+βp β β
+βo β β
+βc β β
+βh β β
+β β β
+βl β β
+βo β β
+βg β β
+β β β
+βl β β
+βo β β
+βs β β
+βs β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β β β
+β 4.72β- β
+βββββββΌβββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ€
+β β0.00 1.90e+1β
+β β step β
+βββββββ΄βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
\ No newline at end of file
"cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build" failed with exit status 1
2025-07-12 16:42.02: Job failed: Failed: Build failed