trouver


Nametrouver JSON
Version 1.0.1 PyPI version JSON
download
home_pagehttps://github.com/hyunjongkimmath/trouver
SummaryCreate and maintain mathematical Obsidian.md notes, and gather data from them to train ML models
upload_time2024-12-26 23:03:29
maintainerNone
docs_urlNone
authorHyun Jong Kim
requires_python>=3.10
licenseApache Software License 2.0
keywords nbdev jupyter notebook python
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            trouver
================

<!-- WARNING: THIS FILE WAS AUTOGENERATED! DO NOT EDIT! -->

- [Author’s academic
  website](https://sites.google.com/view/hyunjongkimmath/)
- [GitHub repository](https://github.com/hyunjongkimmath/trouver#readme)
- [Documentation website](https://hyunjongkimmath.github.io/trouver/)
- [pypi page](https://pypi.org/project/trouver/)
- [Survey](https://docs.google.com/forms/d/e/1FAIpQLScA7XJthYUgt1lK9RbNXvwWKe7Xo1G23Tgivq2o0K3YRFagxw/viewform)

Mathematicians constantly need to learn and read about concepts with
which they are unfamiliar. Keeping mathematical notes in an
[`Obsidian.md`](https://obsidian.md/) vault can help with this learning
process as `Obsidian.md` makes it easy to edit notes, link notes to one
another, organize notes, read notes, and access notes.

This library currently includes functionalities (see also the
[below](#descriptions-of-functionalities)) to

1.  Parse LaTeX documents (e.g. those available on
    [`arxiv.org`](https://arxiv.org/)) and divide them into reasonably
    lengthed parts/notes/excerpts as `.md` files, especially for viewing
    and editing on `Obsidian.md`.
2.  Use a machine learning model to categorize the type of text each
    excerpt is (e.g. introducing definitions/notations, presenting a
    concept, presenting a proof).
3.  Use a machine learning model to identify definitions and notations
    introduced in each excerpt.
4.  Use machine learning models to “name” definitions and notations
    introducd in each excerpt.
5.  Create accompanying notes for each notation as more `.md` files.
6.  Use a machine learning model to summarize what these notations
    denote in the created accompanying notes.

As some of these functionalities use machine learning models, they
ultimately cannot run perfectly. Nevertheless, some of these models,
particularly those described in 2 and 3, perform well enough that these
functionalities are quite useful as tools to help reading mathematical
papers (when used in conjunction with `Obsidian.md`).

Moreover, the results of the machine learning models are recorded in the
notes/`.md` files. One can very well correct these recorded results by
manually editing the affected `.md` files with any file editor.

As of [Version 1.0.1](release_notes.html##ver-101), `trouver` has a
[graphical user interface](#gui) wrapping some (but not all) of its
functionalities.

<p style="text-align:center;">
<img src="/images/index_gui_image.png" alt="The trouver GUI" width="400" class="center"/>
</p>

## Disclaimer

At the time of this writing (12/23/2024), there is only one
author/contributor of this library. Nevertheless, the author often
refers to himself as *the author*, *the authors*, or *the
author/authors* in writing this library. Moreover, the author often uses
the [*editorial we*](https://en.wikipedia.org/wiki/We#Editorial_we) in
writing this library.

Use this library at your own risk as using this library can write or
modify files in your computer and as the documentation of components of
this library may be inaccurate, outdated, or not-well-maintained.
Moreover, future components of this library may use external API’s
(including but possibly not limited to OpenAI’s API) that may not be
free to use. By using this library, you agree that the author/authors of
this library is/are not responsible for any damages or losses, including
but not limited to data or monetary losses, from this library and
related components.

This library is still somewhere in-between prototype and alpha.
Moreover, the library itself may be unstable and subject to abrupt
changes.

The author/authors of this library is/are also not affiliated with
`Obsidian.md`, `fast.ai`, `Hugging Face`, and `arXiv`.

## Install

See also [how_to.install_trouver](how_to.install_trouver.html)

We recommend having at least 5GB of free disk space to install `trouver`
and related components (mostly the ML models).

``` sh
pip install trouver
```

You may also have to manually install other libraries which are required
by the `fast.ai` and/or `Hugging Face` libraries.

We recommend installing [Obsidian.md](https://obsidian.md/) to view,
edit, and modify mathematical notes created by or which interact with
`trouver`.

See `how_to.install_trouver` for more details on installation.

> **Warning** At the time of this writing, `trouver` has not been tested
> on MacOS extensively. We have also found that running the latest
> Python versions in Jupyter notebooks on modern MacOS machines
> (e.g. those using the M1 processor and in particular the arm64
> architecture) lead to some issues. cf. stackexchange discussions such
> as
>
> - <https://apple.stackexchange.com/questions/436801/m1-mac-mach-o-file-but-is-an-incompatible-architecture-have-x86-64-need-a>
> - <https://stackoverflow.com/questions/71502583/jupiter-wont-launch-from-terminal-on-m1-macbook>.
>
> <!--- > One can also try running `trouver` on an older version of Python (e.g. version 3.7) to avoid these Jupyter problems. In this case, one may need to install some additional Python packages, such as [`graphlib-backport`](https://pypi.org/project/graphlib-backport/). -->

## Descriptions of functionalities

We describe some of `trouver`’s ML functionalities. Sample code is
available in [`tutorial.walkthrough`](tutorial.walkthrough.html). See
[below](#rationale-for-the-functionalities-and-intended-use) for some
rationale for these functionalities.

The predictions in the examples below are just for illustration; actual
predictions by the ML models may differ — what constitutes as “ideal
predictions” is ultimately subjective and users’ opinions on how the ML
models should actually predict will vary. All of the ML models are
hosted on the page for the user
[`hyunjongkimmath`](https://huggingface.co/hyunjongkimmath) on
[`huggingface`](https://huggingface.co/).

TODO: mention the functions for each of the functionalities

#### 1. Predict types of excerpts of mathematical text.

The model
[`hyunjongkimmath/information_note_type`](https://huggingface.co/hyunjongkimmath/information_note_type)
predicts what type a given excerpt of text is (using `Markdown` tags).
See
[`markdown.obsidian.personal.machine_learning.information_note_types`](markdown.obsidian.personal.machine_learning.information_note_types.html)
for more details.

For example, the model should predict that the following excerpt is a
`#_meta/definition` and a `#_meta/notation`.

> Let $(X, d)$ be a metric space and $x \in X$.
>
> **Definition 1.3.1:** The open ball centered at $x$ with radius
> $r > 0$ is defined as:
>
> $$B(x, r) = \{y \in X : d(x, y) < r\}$$
>
> **Definition 1.3.2:** The closed ball centered at $x$ with radius
> $r \geq 0$ is defined as:
>
> $$\overline{B}(x, r) = \{y \in X : d(x, y) \leq r\}$$

For another example, the model should predict that the following excerpt
is a `#_meta/concept` and a `#_meta/proof`.

> **Theorem 3.2.1:** Let $A$ be an $n \times n$ matrix. If $A$ is
> invertible, then its columns are linearly independent.
>
> **Proof:** Let $c_1, c_2, ..., c_n$ be the columns of $A$. Suppose
>
> $$a_1c_1 + a_2c_2 + ... + a_nc_n = 0$$
>
> for some scalars $a_1, a_2, ..., a_n$. This is equivalent to
>
> $$A\mathbf{x} = \mathbf{0}$$
>
> where $\mathbf{x} = (a_1, a_2, ..., a_n)^T$. Since $A$ is invertible,
>
> $$\mathbf{x} = A^{-1}\mathbf{0} = \mathbf{0}$$
>
> Thus, $a_1 = a_2 = ... = a_n = 0$, proving that the columns are
> linearly independent.

For yet another example, the model should predict that the following
excerpt is a `#_meta/narrative`.

> In this section, we explore the fundamental concepts of eigenvalues
> and eigenvectors. These powerful tools allow us to:
>
> 1.  Understand the action of a linear transformation on specific
>     vectors
> 2.  Diagonalize matrices, simplifying many computations
> 3.  Analyze dynamical systems and their long-term behavior
>
> We begin by defining eigenvalues and eigenvectors, then proceed to
> develop methods for finding them. The characteristic equation will
> play a crucial role in our analysis. Finally, we’ll examine some
> applications, including the diagonalization of matrices and solving
> systems of differential equations.

The following are some tags that the model is adept at predicting:

- `#_meta/definition` labels a note that introduces a definition.
- `#_meta/notation` labels a note that introduces a notation.
- `#_meta/concept` labels a note that contains a general concept,
  e.g. by virtue of stating a theorem/proposiiton/lemma/corollary.
- `#_meta/proof` labels a note that contains a proof.
- `#_meta/narrative` labels a note that contains narrative -
  explainations of the material that is presented. Narratives most
  usually occur at the start/end of a chapter/section of a
  book/text/paper and in-between definitions/theorems/etc.
- `#_meta/exercise` labels a note that contains an exercise problem.
- `#_meta/remark` labels a note that contains a remark.
- `#_meta/example` labels a note that contains an example.
- `#_meta/context` labels a note that contains “contextual information”,
  i.e. information that other notes might depend on (e.g. “in this
  section, $k$ is an algebraically closed field”, “For the rest of this
  section, we assume that $X$ is a pointed topological space”).

#### 2. Mark definitions and notations introduced in an excerpt of mathematical text.

The model
[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)
attempts to find where exactly definitions and notations are introduced
in a given excerpt of text. See
[`markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification`](markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification.html)

For example, take the following excerpt.

> Let $(X, d)$ be a metric space and $x \in X$.
>
> **Definition 1.3.1:** The open ball centered at $x$ with radius
> $r > 0$ is defined as:
>
> $$B(x, r) = \{y \in X : d(x, y) < r\}$$
>
> We denote this open ball as $B(x, r)$.
>
> **Definition 1.3.2:** The closed ball centered at $x$ with radius
> $r \geq 0$ is defined as:
>
> $$\overline{B}(x, r) = \{y \in X : d(x, y) \leq r\}$$
>
> We use the notation $\overline{B}(x, r)$ for closed balls.

The model should predict (and functions in the module
[`markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification`](markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification.html)
should mark) the following definitions and notations as introduced in
the text:

> Let $(X, d)$ be a metric space and $x \in X$.
>
> **Definition 1.3.1:** The
> <b style="border-width:1px;border-style:solid;padding:3px" definition="">open
> ball centered at $x$ with radius $r > 0$</b> is defined as:
>
> <span style="border-width:1px;border-style:solid;padding:3px" notation="">
>
> $$B(x, r) = \{y \in X : d(x, y) < r\}.$$
>
> </span>
>
> **Definition 1.3.2:** The
> <b style="border-width:1px;border-style:solid;padding:3px" definition="">closed
> ball centered at $x$ with radius $r \geq 0$</b> is defined as:
>
> <span style="border-width:1px;border-style:solid;padding:3px" notation="">
>
> $$\overline{B}(x, r) = \{y \in X : d(x, y) \leq r\}.$$
>
> </span>

#### 3. Name definitions and notations introduced in an excerpt of mathematical text.

The models
[hyunjongkimmath/definition_naming_model](https://huggingface.co/hyunjongkimmath/definition_naming_model)
and
[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)
attempt to “name” definitions and notations (marked either manually or
with the
[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)
discussed
[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)).

In the example
[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text),
the
[hyunjongkimmath/definition_naming_model](https://huggingface.co/hyunjongkimmath/definition_naming_model)
model ideally would name the definition encapsulated by the marked
phrases

- **open ball centered at $x$ with radius $r > 0$** and
- **closed ball centered at $x$ with radius $r \geq 0$**

as (something along the lines of)

- “Open ball centered at a point of a metric space with radius $r$” and
- “Closed ball centered at a point of a metric space with radius $r$”

respectively.

Moreover, the
[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)
ideally would name the notation encapsulated by the marked LaTeX math
mode texts

- $$B(x, r) = \{y \in X : d(x, y) < r\}$$
- $$\overline{B}(x, r) = \{y \in X : d(x, y) \leq r\}$$

as

- $B(x, r)$ and
- $\overline{B}(x, r)$

respectively — the aim of the notation-naming process is to only extract
the actual notation itself, not other parts of the LaTeX math mode texts
that are not part of the notation.

There may sometimes be more than one “good” way to name a
definition/notation and a given marked phrase may actually encapsulate
more than one definition/notation. In the above example, one might argue
that the marked phrases

- **open ball centered at $x$ with radius $r > 0$** and
- **closed ball centered at $x$ with radius $r \geq 0$**

encapsulate not only the notions of “open ball” and “closed ball”
(centered at a point and with radius $r$), but also the notions of “the
center of an open/closed ball” or “the radius of an open/closed ball”.

#### 4. Summarize what a notation denotes as introduced in an excerpt of mathematical text.

The model
[hyunjongkimmath/notation_summarizations_model](https://huggingface.co/hyunjongkimmath/notation_summarizations_model)
attempts to summarize what a notation introduced in a excerpt (marked
either manually or with the
[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)
discussed
[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)
and named with the
[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)
discussed
[above](#3-name-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text))
is supposed to denote.

In the
[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)
[examples](#3-name-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text),
the marked (and named) notations of $B(x,r)$ and $\overline{B}(x,r)$ may
be ideally summarized as follows:

> $B(x,r)$ denotes the open ball centered at $x$ with radius $r$ where
> $x$ is a point of a metric space $X$ and $r > 0$. It is defined as
> $$B(x, r) = \{y \in X : d(x, y) < r\}$$

> $\overline{B}(x,r)$ denotes the closed ball centered at $x$ with
> radius $r$ where $x$ is a point of a metric space $X$ and $r > 0$. It
> is defined as $$\overline{B}(x, r) = \{y \in X : d(x, y) \leq r\}$$

Ideally, such a generated notation should contain the following
information (as available):

1.  The name/intuitive description of the notion denoted by the notation
    (in the above examples, “open ball” and “closed ball”).
2.  The way the notion is defined/constructed (in the above examples,
    $B(x, r) = \{y \in X : d(x, y) < r\}$, etc.)
3.  Other helpful information about the notation as introduced in the
    text.

## Rationale for the functionalities and intended use

The sheer amount and interconnectedness of definitions and notations
that one has to understand (or at least be aware of) make it difficult
to learn mathemamatics, especially at the graduate or research levels
(and beyond). The [above
functionalities](#descriptions-of-functionalities) aim to make learning
mathematics more tractable by making it easier to locate (and remind
oneself of) definitions and notations introduced in mathematical text.

#### Difficulties in reading mathematical papers

For example, take the following (very much fake) mathematical theorem
[from Hyun Jong Kim’s
talk](https://drive.google.com/file/d/1OXQzMAoMiVWUz_cCWRJJ00NYwt_Yq2TK/view)
at the [AMS Student Chapter
Seminar](https://wiki.math.wisc.edu/index.php/AMS_Student_Chapter_Seminar)[^1]
at the University of Wisconsin-Madison during the Spring 2024 semester:

> Theorem.
>
> Given a smooth, flavorful, gastroidal toroid $\mathscr{T}_\mathscr{G}$
> of rank $n$, we have a natural isomorphism
> $$H_{\text{suc}}^i(\mathscr{T}_\mathscr{G}) \cong H_{\text{Betti}} ( |\mathscr{T}_\mathscr{G}|(\mathbb{C}), \mathbb{Q}(\mathscr{T}_\mathscr{G}))^{3n-i}.$$

Even in this short (fake) theorem, a first time reader may not
understand a multitude of defintions/notations:

- Gastroidal toroid
- Smooth gastroidal toroid
- flavorful gastroidal toroid
- rank of a gastroidal toroid
- $H_{\text{suc}}^i$
- $|\mathscr{T}_\mathscr{G}|$
- $|\mathscr{T}_\mathscr{G}|(\mathbb{C})$
- $\mathbb{Q}(\mathscr{T}_\mathscr{G})$.

Hypothetically, say that the reader finds some definitions/notations
(which may very well take several minutes):

> A gastroidal toroid is a toroid constructed as a fried dough and
> equipped with a sucrose structure. The space
> $|\mathscr{T}_\mathscr{G}|$ of a gastroidal toroid
> $\mathscr{T}_\mathscr{G}$ is the underlying topological space
> structure of the friend dough. We say that a gastroidal toroid is
> flavorful is
> $\lim_{n \to \infty} \operatorname{swt}_n(\mathscr{T}_\mathscr{G}) \geq 1$

However, this excerpt requires the reader to understand more definitions
and notations:

- a fried dough
- a sucrose structure
- $\operatorname{swt}_n$

In practice, as one sets out to learn about numerous definitions and
notations, say in a given mathematical paper, one can often forget
details and thus need to spend much time to re-find such definitions and
notations.

#### A workaround using `Obsidian.md`

The functionalities of `trouver`, used in conjunction with
`Obsidian.md`, can help work around these difficulties to reduce the
amount of time and effort needed to re-find and re-learn these
definitions and notations. `trouver` can divide a LaTeX document into
not-too-long notes (see the
[`divide_latex_text`](https://hyunjongkimmath.github.io/trouver/latex.divide.html#divide_latex_text)
function in [latex.divide](latex.divide.html#divide_latex_text) and the
[`setup_reference_from_latex_parts`](https://hyunjongkimmath.github.io/trouver/latex.convert.html#setup_reference_from_latex_parts)
function in [latex.convert](latex.convert.html)) for an `Obsidian.md`
vault.

Some of `Obsidian.md` strengths include the ease with which
links/embeddings between notes can be made and the ease with which notes
can be searched and opened. In essence, one can use the [aforementioned
functionalities](#descriptions-of-functionalities) to automatically
identify definitions and notations introduced throughout the
mathematical text, create new notes dedicated to each notation (see the
[`make_notation_notes_from_HTML_tags`](https://hyunjongkimmath.github.io/trouver/markdown.obsidian.personal.notation.html#make_notation_notes_from_html_tags)
function in
[markdown.obsidian.personal.notation](markdown.obsidian.personal.notation.html)),
and write summaries of what the notations denote.

These notation notes can then be linked/embedded into other notes as
needed, thereby making it much easier to view what a notation denotes.

TODO: include example image

## GUI

`trouver` now has a prototype GUI for some of the [aforementioned
funcionalities](#descriptions-of-functionalities).

TODO: include link to GUI download

# How to use

See [tutorial.walkthrough](tutorial.walkthrough.html) and
[tutorial.concise_code](tutorial.concise_code.html)

# How the examples/tests are structured

Many of the functions and methods in this library are accompanied by
examples demonstrating how one might use them.

These examples are usually also tests of the functions/methods; the
developer of this library can use `nbdev`’s
[`nbdev_test`](https://nbdev.fast.ai/api/test.html#nbdev_test)
command-line command to automatically run these tests[^2][^3]. Moreover,
there is a GitHub workflow in the repository for this library (see the
`.github/workflows/test.yaml`) which automatically runs these
examples/tests on GitHub Actions when changes to are [committed to the
GitHub repository](https://github.com/git-guides/git-commit)[^4].

These examples may use a combination of the following:

- Mock patching via Python’s
  [`unittest.mock`](https://docs.python.org/3/library/unittest.mock.html)
  library.
- The [`fastcore.test`](https://fastcore.fast.ai/test.html) module as
  assertion statements.
- example/test files in the `nbs/_tests` folder in the repository[^5].
  - The `_test_directory()` function in the `helper` module obtains this
    folder.
  - Many of these examples also use the
    [`tempfile.TemporaryDirectory`](https://docs.python.org/3/library/tempfile.html#tempfile.TemporaryDirectory)
    class along with the
    [`shutil.copytree`](https://docs.python.org/3/library/shutil.html#shutil.copytree)
    to create a Python context manager of a temporary directory with
    contents copied from the `nbs/_tests` folder. The temporary
    directory is automatically deleted once the context manager ends. We
    do this to run tests/examples which modify files/folders without
    modifying the files/folders in the `nbs/_tests` directory
    themselves.
    - For example, the code

    ``` python
    with tempfile.TemporaryDirectory(prefix='temp_dir', dir=os.getcwd()) as temp_dir:
        temp_vault = Path(temp_dir) / 'test_vault_1'
        shutil.copytree(_test_directory() / 'test_vault_1', temp_vault)

        # run the rest of the example here

        # Uncomment the below lines of code to view the end-results of the example; 
        # os.startfile(os.getcwd())
        # os.input()  # this line pauses the process until the user makes an input so the deletion of the temporary directory is delayed.
    ```

    first creates a temporary directory starting `temp_dir` in the
    current working directory and copies into this temporary directory
    the contents of `test_vault_1` in the `nbs/_tests` folder. One the
    example/test has finished running, the temporary directory is
    removed whether or not the test succeeds.

## Miscellaneous

This repository is still in its preliminary stages and much of the code
and documentation may be faulty or not well formatted. The author
greatly appreciates reports of these issues, notifications of typos, and
suggestions on edits; please feel free to report them on the `Issues`
section of the GitHub repository for this library. The
[author](https://sites.google.com/wisc.edu/hyunjongkim) of this
repository, who is primarily a mathematician (a postdoctoral associate
at the time of this writing), does not guarantee quick responses or
resolutions to such issues, but will do his best to address them.

# For developers

This repository is based on the [`nbdev`](https://nbdev.fast.ai/)
template. As such, code for the packages as well as the documentation
for the repository are written in jupyter notebooks (the `.ipynb` files
in the `nbs` folder) and the Python modules are auto-generated via the
command-line command
[`nbdev_export`](https://nbdev.fast.ai/api/doclinks.html#nbdev_export)
(or
[`nbdev_prepare`](https://nbdev.fast.ai/tutorials/tutorial.html#prepare-your-changes),
which among other things runs `nbdev_export`.).

## Troubleshooting

- In the `nbs/_tests` folder, make sure that the folders that you want
  to test are not empty; since git does not track empty folders, empty
  folders will not be pushed in GitHub and the tests in GitHub Actions
  may yield different results than in a local computer.

# Copyright

Copyright © 2023 onward Hyun Jong Kim. Licensed under the Apache
License, Version 2.0 (the “License”); you may not use this project’s
files except in compliance with the License. A copy of the License is
provided in the LICENSE file in this repository.

# Special Thanks

The author of `trouver` thanks [Sun Woo
Park](https://sites.google.com/wisc.edu/spark483) for agreeing to allow
their coauthored paper, [*Global $\mathbb{A}^1$-degrees covering maps
between modular curves*](https://arxiv.org/abs/2106.10586), along with
some of Park’s expository writings, to be used in examples in this
library. The author of `trouver` further thanks Sun Woo Park for his
help in testing `trouver` on a MacOS computer and for reviewing the
`tutorial.walkthrough` page.

Components of `trouver` use [arXiv.org’s
API](https://info.arxiv.org/help/api/index.html). As such, we include
the following thanks:

> Thank you to arXiv for use of its open access interoperability.

`trouver` was built using [`nbdev`](https://nbdev.fast.ai/) as a
template.

# Release notes

See [`release_notes`](release_notes.html).

[^1]: Colloquially referred to as the “Donut seminar”, as the organizers
    purchase donuts with the funds provided by the AMS for the speakers
    and the audience to eat. The fake theorem/definition below are jokes
    about donuts.

[^2]: cf. [nbdev’s End-To-End
    Walkthrough](https://nbdev.fast.ai/tutorials/tutorial.html#add-your-own-examples-tests-and-docs)
    to see how to use `nbdev_test`

[^3]: There are also tests which are hidden from the documentation
    website; one can find these tests in the jupyter notebook files in
    the `nbs` folder in the repository for this library as notebook
    cells marked with the `#| hide` flag, cf. [nbdev’s End-to-End
    Walkthrough](https://nbdev.fast.ai/tutorials/tutorial.html#add-your-own-frontmatter)
    to see what the `#| hide` flag does.

[^4]: The `.github/workflows/test.yaml` GitHub workflow file is set up
    in such a way that that allows GitHub Actions to access/use the
    contents of the `nbs/_tests` directory upon running the
    tests/examples.

[^5]: The `.github/workflows/test.yaml` GitHub workflow file is set up
    in such a way that that allows GitHub Actions to access/use the
    contents of the `nbs/_tests` directory upon running the
    tests/examples.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/hyunjongkimmath/trouver",
    "name": "trouver",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": null,
    "keywords": "nbdev jupyter notebook python",
    "author": "Hyun Jong Kim",
    "author_email": "hyunjongkim96@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/3c/ec/637666279429d0040926a3f84b9c1477968793b519f30fc5eb6b52d5a064/trouver-1.0.1.tar.gz",
    "platform": null,
    "description": "trouver\n================\n\n<!-- WARNING: THIS FILE WAS AUTOGENERATED! DO NOT EDIT! -->\n\n- [Author\u2019s academic\n  website](https://sites.google.com/view/hyunjongkimmath/)\n- [GitHub repository](https://github.com/hyunjongkimmath/trouver#readme)\n- [Documentation website](https://hyunjongkimmath.github.io/trouver/)\n- [pypi page](https://pypi.org/project/trouver/)\n- [Survey](https://docs.google.com/forms/d/e/1FAIpQLScA7XJthYUgt1lK9RbNXvwWKe7Xo1G23Tgivq2o0K3YRFagxw/viewform)\n\nMathematicians constantly need to learn and read about concepts with\nwhich they are unfamiliar. Keeping mathematical notes in an\n[`Obsidian.md`](https://obsidian.md/) vault can help with this learning\nprocess as `Obsidian.md` makes it easy to edit notes, link notes to one\nanother, organize notes, read notes, and access notes.\n\nThis library currently includes functionalities (see also the\n[below](#descriptions-of-functionalities)) to\n\n1.  Parse LaTeX documents (e.g.\u00a0those available on\n    [`arxiv.org`](https://arxiv.org/)) and divide them into reasonably\n    lengthed parts/notes/excerpts as `.md` files, especially for viewing\n    and editing on `Obsidian.md`.\n2.  Use a machine learning model to categorize the type of text each\n    excerpt is (e.g.\u00a0introducing definitions/notations, presenting a\n    concept, presenting a proof).\n3.  Use a machine learning model to identify definitions and notations\n    introduced in each excerpt.\n4.  Use machine learning models to \u201cname\u201d definitions and notations\n    introducd in each excerpt.\n5.  Create accompanying notes for each notation as more `.md` files.\n6.  Use a machine learning model to summarize what these notations\n    denote in the created accompanying notes.\n\nAs some of these functionalities use machine learning models, they\nultimately cannot run perfectly. Nevertheless, some of these models,\nparticularly those described in 2 and 3, perform well enough that these\nfunctionalities are quite useful as tools to help reading mathematical\npapers (when used in conjunction with `Obsidian.md`).\n\nMoreover, the results of the machine learning models are recorded in the\nnotes/`.md` files. One can very well correct these recorded results by\nmanually editing the affected `.md` files with any file editor.\n\nAs of [Version 1.0.1](release_notes.html##ver-101), `trouver` has a\n[graphical user interface](#gui) wrapping some (but not all) of its\nfunctionalities.\n\n<p style=\"text-align:center;\">\n<img src=\"/images/index_gui_image.png\" alt=\"The trouver GUI\" width=\"400\" class=\"center\"/>\n</p>\n\n## Disclaimer\n\nAt the time of this writing (12/23/2024), there is only one\nauthor/contributor of this library. Nevertheless, the author often\nrefers to himself as *the author*, *the authors*, or *the\nauthor/authors* in writing this library. Moreover, the author often uses\nthe [*editorial we*](https://en.wikipedia.org/wiki/We#Editorial_we) in\nwriting this library.\n\nUse this library at your own risk as using this library can write or\nmodify files in your computer and as the documentation of components of\nthis library may be inaccurate, outdated, or not-well-maintained.\nMoreover, future components of this library may use external API\u2019s\n(including but possibly not limited to OpenAI\u2019s API) that may not be\nfree to use. By using this library, you agree that the author/authors of\nthis library is/are not responsible for any damages or losses, including\nbut not limited to data or monetary losses, from this library and\nrelated components.\n\nThis library is still somewhere in-between prototype and alpha.\nMoreover, the library itself may be unstable and subject to abrupt\nchanges.\n\nThe author/authors of this library is/are also not affiliated with\n`Obsidian.md`, `fast.ai`, `Hugging Face`, and `arXiv`.\n\n## Install\n\nSee also [how_to.install_trouver](how_to.install_trouver.html)\n\nWe recommend having at least 5GB of free disk space to install `trouver`\nand related components (mostly the ML models).\n\n``` sh\npip install trouver\n```\n\nYou may also have to manually install other libraries which are required\nby the `fast.ai` and/or `Hugging Face` libraries.\n\nWe recommend installing [Obsidian.md](https://obsidian.md/) to view,\nedit, and modify mathematical notes created by or which interact with\n`trouver`.\n\nSee `how_to.install_trouver` for more details on installation.\n\n> **Warning** At the time of this writing, `trouver` has not been tested\n> on MacOS extensively. We have also found that running the latest\n> Python versions in Jupyter notebooks on modern MacOS machines\n> (e.g.\u00a0those using the M1 processor and in particular the arm64\n> architecture) lead to some issues. cf.\u00a0stackexchange discussions such\n> as\n>\n> - <https://apple.stackexchange.com/questions/436801/m1-mac-mach-o-file-but-is-an-incompatible-architecture-have-x86-64-need-a>\n> - <https://stackoverflow.com/questions/71502583/jupiter-wont-launch-from-terminal-on-m1-macbook>.\n>\n> <!--- > One can also try running `trouver` on an older version of Python (e.g. version 3.7) to avoid these Jupyter problems. In this case, one may need to install some additional Python packages, such as [`graphlib-backport`](https://pypi.org/project/graphlib-backport/). -->\n\n## Descriptions of functionalities\n\nWe describe some of `trouver`\u2019s ML functionalities. Sample code is\navailable in [`tutorial.walkthrough`](tutorial.walkthrough.html). See\n[below](#rationale-for-the-functionalities-and-intended-use) for some\nrationale for these functionalities.\n\nThe predictions in the examples below are just for illustration; actual\npredictions by the ML models may differ \u2014 what constitutes as \u201cideal\npredictions\u201d is ultimately subjective and users\u2019 opinions on how the ML\nmodels should actually predict will vary. All of the ML models are\nhosted on the page for the user\n[`hyunjongkimmath`](https://huggingface.co/hyunjongkimmath) on\n[`huggingface`](https://huggingface.co/).\n\nTODO: mention the functions for each of the functionalities\n\n#### 1. Predict types of excerpts of mathematical text.\n\nThe model\n[`hyunjongkimmath/information_note_type`](https://huggingface.co/hyunjongkimmath/information_note_type)\npredicts what type a given excerpt of text is (using `Markdown` tags).\nSee\n[`markdown.obsidian.personal.machine_learning.information_note_types`](markdown.obsidian.personal.machine_learning.information_note_types.html)\nfor more details.\n\nFor example, the model should predict that the following excerpt is a\n`#_meta/definition` and a `#_meta/notation`.\n\n> Let $(X, d)$ be a metric space and $x \\in X$.\n>\n> **Definition 1.3.1:** The open ball centered at $x$ with radius\n> $r > 0$ is defined as:\n>\n> $$B(x, r) = \\{y \\in X : d(x, y) < r\\}$$\n>\n> **Definition 1.3.2:** The closed ball centered at $x$ with radius\n> $r \\geq 0$ is defined as:\n>\n> $$\\overline{B}(x, r) = \\{y \\in X : d(x, y) \\leq r\\}$$\n\nFor another example, the model should predict that the following excerpt\nis a `#_meta/concept` and a `#_meta/proof`.\n\n> **Theorem 3.2.1:** Let $A$ be an $n \\times n$ matrix. If $A$ is\n> invertible, then its columns are linearly independent.\n>\n> **Proof:** Let $c_1, c_2, ..., c_n$ be the columns of $A$. Suppose\n>\n> $$a_1c_1 + a_2c_2 + ... + a_nc_n = 0$$\n>\n> for some scalars $a_1, a_2, ..., a_n$. This is equivalent to\n>\n> $$A\\mathbf{x} = \\mathbf{0}$$\n>\n> where $\\mathbf{x} = (a_1, a_2, ..., a_n)^T$. Since $A$ is invertible,\n>\n> $$\\mathbf{x} = A^{-1}\\mathbf{0} = \\mathbf{0}$$\n>\n> Thus, $a_1 = a_2 = ... = a_n = 0$, proving that the columns are\n> linearly independent.\n\nFor yet another example, the model should predict that the following\nexcerpt is a `#_meta/narrative`.\n\n> In this section, we explore the fundamental concepts of eigenvalues\n> and eigenvectors. These powerful tools allow us to:\n>\n> 1.  Understand the action of a linear transformation on specific\n>     vectors\n> 2.  Diagonalize matrices, simplifying many computations\n> 3.  Analyze dynamical systems and their long-term behavior\n>\n> We begin by defining eigenvalues and eigenvectors, then proceed to\n> develop methods for finding them. The characteristic equation will\n> play a crucial role in our analysis. Finally, we\u2019ll examine some\n> applications, including the diagonalization of matrices and solving\n> systems of differential equations.\n\nThe following are some tags that the model is adept at predicting:\n\n- `#_meta/definition` labels a note that introduces a definition.\n- `#_meta/notation` labels a note that introduces a notation.\n- `#_meta/concept` labels a note that contains a general concept,\n  e.g.\u00a0by virtue of stating a theorem/proposiiton/lemma/corollary.\n- `#_meta/proof` labels a note that contains a proof.\n- `#_meta/narrative` labels a note that contains narrative -\n  explainations of the material that is presented. Narratives most\n  usually occur at the start/end of a chapter/section of a\n  book/text/paper and in-between definitions/theorems/etc.\n- `#_meta/exercise` labels a note that contains an exercise problem.\n- `#_meta/remark` labels a note that contains a remark.\n- `#_meta/example` labels a note that contains an example.\n- `#_meta/context` labels a note that contains \u201ccontextual information\u201d,\n  i.e.\u00a0information that other notes might depend on (e.g.\u00a0\u201cin this\n  section, $k$ is an algebraically closed field\u201d, \u201cFor the rest of this\n  section, we assume that $X$ is a pointed topological space\u201d).\n\n#### 2. Mark definitions and notations introduced in an excerpt of mathematical text.\n\nThe model\n[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)\nattempts to find where exactly definitions and notations are introduced\nin a given excerpt of text. See\n[`markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification`](markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification.html)\n\nFor example, take the following excerpt.\n\n> Let $(X, d)$ be a metric space and $x \\in X$.\n>\n> **Definition 1.3.1:** The open ball centered at $x$ with radius\n> $r > 0$ is defined as:\n>\n> $$B(x, r) = \\{y \\in X : d(x, y) < r\\}$$\n>\n> We denote this open ball as $B(x, r)$.\n>\n> **Definition 1.3.2:** The closed ball centered at $x$ with radius\n> $r \\geq 0$ is defined as:\n>\n> $$\\overline{B}(x, r) = \\{y \\in X : d(x, y) \\leq r\\}$$\n>\n> We use the notation $\\overline{B}(x, r)$ for closed balls.\n\nThe model should predict (and functions in the module\n[`markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification`](markdown.obsidian.personal.machine_learning.tokenize.def_and_notat_token_classification.html)\nshould mark) the following definitions and notations as introduced in\nthe text:\n\n> Let $(X, d)$ be a metric space and $x \\in X$.\n>\n> **Definition 1.3.1:** The\n> <b style=\"border-width:1px;border-style:solid;padding:3px\" definition=\"\">open\n> ball centered at $x$ with radius $r > 0$</b> is defined as:\n>\n> <span style=\"border-width:1px;border-style:solid;padding:3px\" notation=\"\">\n>\n> $$B(x, r) = \\{y \\in X : d(x, y) < r\\}.$$\n>\n> </span>\n>\n> **Definition 1.3.2:** The\n> <b style=\"border-width:1px;border-style:solid;padding:3px\" definition=\"\">closed\n> ball centered at $x$ with radius $r \\geq 0$</b> is defined as:\n>\n> <span style=\"border-width:1px;border-style:solid;padding:3px\" notation=\"\">\n>\n> $$\\overline{B}(x, r) = \\{y \\in X : d(x, y) \\leq r\\}.$$\n>\n> </span>\n\n#### 3. Name definitions and notations introduced in an excerpt of mathematical text.\n\nThe models\n[hyunjongkimmath/definition_naming_model](https://huggingface.co/hyunjongkimmath/definition_naming_model)\nand\n[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)\nattempt to \u201cname\u201d definitions and notations (marked either manually or\nwith the\n[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)\ndiscussed\n[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)).\n\nIn the example\n[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text),\nthe\n[hyunjongkimmath/definition_naming_model](https://huggingface.co/hyunjongkimmath/definition_naming_model)\nmodel ideally would name the definition encapsulated by the marked\nphrases\n\n- **open ball centered at $x$ with radius $r > 0$** and\n- **closed ball centered at $x$ with radius $r \\geq 0$**\n\nas (something along the lines of)\n\n- \u201cOpen ball centered at a point of a metric space with radius $r$\u201d and\n- \u201cClosed ball centered at a point of a metric space with radius $r$\u201d\n\nrespectively.\n\nMoreover, the\n[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)\nideally would name the notation encapsulated by the marked LaTeX math\nmode texts\n\n- $$B(x, r) = \\{y \\in X : d(x, y) < r\\}$$\n- $$\\overline{B}(x, r) = \\{y \\in X : d(x, y) \\leq r\\}$$\n\nas\n\n- $B(x, r)$ and\n- $\\overline{B}(x, r)$\n\nrespectively \u2014 the aim of the notation-naming process is to only extract\nthe actual notation itself, not other parts of the LaTeX math mode texts\nthat are not part of the notation.\n\nThere may sometimes be more than one \u201cgood\u201d way to name a\ndefinition/notation and a given marked phrase may actually encapsulate\nmore than one definition/notation. In the above example, one might argue\nthat the marked phrases\n\n- **open ball centered at $x$ with radius $r > 0$** and\n- **closed ball centered at $x$ with radius $r \\geq 0$**\n\nencapsulate not only the notions of \u201copen ball\u201d and \u201cclosed ball\u201d\n(centered at a point and with radius $r$), but also the notions of \u201cthe\ncenter of an open/closed ball\u201d or \u201cthe radius of an open/closed ball\u201d.\n\n#### 4. Summarize what a notation denotes as introduced in an excerpt of mathematical text.\n\nThe model\n[hyunjongkimmath/notation_summarizations_model](https://huggingface.co/hyunjongkimmath/notation_summarizations_model)\nattempts to summarize what a notation introduced in a excerpt (marked\neither manually or with the\n[`hyunjongkimmath/def_and_notat_token_classification_model`](https://huggingface.co/hyunjongkimmath/def_and_notat_token_classification_model)\ndiscussed\n[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)\nand named with the\n[hyunjongkimmath/notation_naming_model](https://huggingface.co/hyunjongkimmath/notation_naming_model)\ndiscussed\n[above](#3-name-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text))\nis supposed to denote.\n\nIn the\n[above](#2-mark-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text)\n[examples](#3-name-definitions-and-notations-introduced-in-an-excerpt-of-mathematical-text),\nthe marked (and named) notations of $B(x,r)$ and $\\overline{B}(x,r)$ may\nbe ideally summarized as follows:\n\n> $B(x,r)$ denotes the open ball centered at $x$ with radius $r$ where\n> $x$ is a point of a metric space $X$ and $r > 0$. It is defined as\n> $$B(x, r) = \\{y \\in X : d(x, y) < r\\}$$\n\n> $\\overline{B}(x,r)$ denotes the closed ball centered at $x$ with\n> radius $r$ where $x$ is a point of a metric space $X$ and $r > 0$. It\n> is defined as $$\\overline{B}(x, r) = \\{y \\in X : d(x, y) \\leq r\\}$$\n\nIdeally, such a generated notation should contain the following\ninformation (as available):\n\n1.  The name/intuitive description of the notion denoted by the notation\n    (in the above examples, \u201copen ball\u201d and \u201cclosed ball\u201d).\n2.  The way the notion is defined/constructed (in the above examples,\n    $B(x, r) = \\{y \\in X : d(x, y) < r\\}$, etc.)\n3.  Other helpful information about the notation as introduced in the\n    text.\n\n## Rationale for the functionalities and intended use\n\nThe sheer amount and interconnectedness of definitions and notations\nthat one has to understand (or at least be aware of) make it difficult\nto learn mathemamatics, especially at the graduate or research levels\n(and beyond). The [above\nfunctionalities](#descriptions-of-functionalities) aim to make learning\nmathematics more tractable by making it easier to locate (and remind\noneself of) definitions and notations introduced in mathematical text.\n\n#### Difficulties in reading mathematical papers\n\nFor example, take the following (very much fake) mathematical theorem\n[from Hyun Jong Kim\u2019s\ntalk](https://drive.google.com/file/d/1OXQzMAoMiVWUz_cCWRJJ00NYwt_Yq2TK/view)\nat the [AMS Student Chapter\nSeminar](https://wiki.math.wisc.edu/index.php/AMS_Student_Chapter_Seminar)[^1]\nat the University of Wisconsin-Madison during the Spring 2024 semester:\n\n> Theorem.\n>\n> Given a smooth, flavorful, gastroidal toroid $\\mathscr{T}_\\mathscr{G}$\n> of rank $n$, we have a natural isomorphism\n> $$H_{\\text{suc}}^i(\\mathscr{T}_\\mathscr{G}) \\cong H_{\\text{Betti}} ( |\\mathscr{T}_\\mathscr{G}|(\\mathbb{C}), \\mathbb{Q}(\\mathscr{T}_\\mathscr{G}))^{3n-i}.$$\n\nEven in this short (fake) theorem, a first time reader may not\nunderstand a multitude of defintions/notations:\n\n- Gastroidal toroid\n- Smooth gastroidal toroid\n- flavorful gastroidal toroid\n- rank of a gastroidal toroid\n- $H_{\\text{suc}}^i$\n- $|\\mathscr{T}_\\mathscr{G}|$\n- $|\\mathscr{T}_\\mathscr{G}|(\\mathbb{C})$\n- $\\mathbb{Q}(\\mathscr{T}_\\mathscr{G})$.\n\nHypothetically, say that the reader finds some definitions/notations\n(which may very well take several minutes):\n\n> A gastroidal toroid is a toroid constructed as a fried dough and\n> equipped with a sucrose structure. The space\n> $|\\mathscr{T}_\\mathscr{G}|$ of a gastroidal toroid\n> $\\mathscr{T}_\\mathscr{G}$ is the underlying topological space\n> structure of the friend dough. We say that a gastroidal toroid is\n> flavorful is\n> $\\lim_{n \\to \\infty} \\operatorname{swt}_n(\\mathscr{T}_\\mathscr{G}) \\geq 1$\n\nHowever, this excerpt requires the reader to understand more definitions\nand notations:\n\n- a fried dough\n- a sucrose structure\n- $\\operatorname{swt}_n$\n\nIn practice, as one sets out to learn about numerous definitions and\nnotations, say in a given mathematical paper, one can often forget\ndetails and thus need to spend much time to re-find such definitions and\nnotations.\n\n#### A workaround using `Obsidian.md`\n\nThe functionalities of `trouver`, used in conjunction with\n`Obsidian.md`, can help work around these difficulties to reduce the\namount of time and effort needed to re-find and re-learn these\ndefinitions and notations. `trouver` can divide a LaTeX document into\nnot-too-long notes (see the\n[`divide_latex_text`](https://hyunjongkimmath.github.io/trouver/latex.divide.html#divide_latex_text)\nfunction in [latex.divide](latex.divide.html#divide_latex_text) and the\n[`setup_reference_from_latex_parts`](https://hyunjongkimmath.github.io/trouver/latex.convert.html#setup_reference_from_latex_parts)\nfunction in [latex.convert](latex.convert.html)) for an `Obsidian.md`\nvault.\n\nSome of `Obsidian.md` strengths include the ease with which\nlinks/embeddings between notes can be made and the ease with which notes\ncan be searched and opened. In essence, one can use the [aforementioned\nfunctionalities](#descriptions-of-functionalities) to automatically\nidentify definitions and notations introduced throughout the\nmathematical text, create new notes dedicated to each notation (see the\n[`make_notation_notes_from_HTML_tags`](https://hyunjongkimmath.github.io/trouver/markdown.obsidian.personal.notation.html#make_notation_notes_from_html_tags)\nfunction in\n[markdown.obsidian.personal.notation](markdown.obsidian.personal.notation.html)),\nand write summaries of what the notations denote.\n\nThese notation notes can then be linked/embedded into other notes as\nneeded, thereby making it much easier to view what a notation denotes.\n\nTODO: include example image\n\n## GUI\n\n`trouver` now has a prototype GUI for some of the [aforementioned\nfuncionalities](#descriptions-of-functionalities).\n\nTODO: include link to GUI download\n\n# How to use\n\nSee [tutorial.walkthrough](tutorial.walkthrough.html) and\n[tutorial.concise_code](tutorial.concise_code.html)\n\n# How the examples/tests are structured\n\nMany of the functions and methods in this library are accompanied by\nexamples demonstrating how one might use them.\n\nThese examples are usually also tests of the functions/methods; the\ndeveloper of this library can use `nbdev`\u2019s\n[`nbdev_test`](https://nbdev.fast.ai/api/test.html#nbdev_test)\ncommand-line command to automatically run these tests[^2][^3]. Moreover,\nthere is a GitHub workflow in the repository for this library (see the\n`.github/workflows/test.yaml`) which automatically runs these\nexamples/tests on GitHub Actions when changes to are [committed to the\nGitHub repository](https://github.com/git-guides/git-commit)[^4].\n\nThese examples may use a combination of the following:\n\n- Mock patching via Python\u2019s\n  [`unittest.mock`](https://docs.python.org/3/library/unittest.mock.html)\n  library.\n- The [`fastcore.test`](https://fastcore.fast.ai/test.html) module as\n  assertion statements.\n- example/test files in the `nbs/_tests` folder in the repository[^5].\n  - The `_test_directory()` function in the `helper` module obtains this\n    folder.\n  - Many of these examples also use the\n    [`tempfile.TemporaryDirectory`](https://docs.python.org/3/library/tempfile.html#tempfile.TemporaryDirectory)\n    class along with the\n    [`shutil.copytree`](https://docs.python.org/3/library/shutil.html#shutil.copytree)\n    to create a Python context manager of a temporary directory with\n    contents copied from the `nbs/_tests` folder. The temporary\n    directory is automatically deleted once the context manager ends. We\n    do this to run tests/examples which modify files/folders without\n    modifying the files/folders in the `nbs/_tests` directory\n    themselves.\n    - For example, the code\n\n    ``` python\n    with tempfile.TemporaryDirectory(prefix='temp_dir', dir=os.getcwd()) as temp_dir:\n        temp_vault = Path(temp_dir) / 'test_vault_1'\n        shutil.copytree(_test_directory() / 'test_vault_1', temp_vault)\n\n        # run the rest of the example here\n\n        # Uncomment the below lines of code to view the end-results of the example; \n        # os.startfile(os.getcwd())\n        # os.input()  # this line pauses the process until the user makes an input so the deletion of the temporary directory is delayed.\n    ```\n\n    first creates a temporary directory starting `temp_dir` in the\n    current working directory and copies into this temporary directory\n    the contents of `test_vault_1` in the `nbs/_tests` folder. One the\n    example/test has finished running, the temporary directory is\n    removed whether or not the test succeeds.\n\n## Miscellaneous\n\nThis repository is still in its preliminary stages and much of the code\nand documentation may be faulty or not well formatted. The author\ngreatly appreciates reports of these issues, notifications of typos, and\nsuggestions on edits; please feel free to report them on the `Issues`\nsection of the GitHub repository for this library. The\n[author](https://sites.google.com/wisc.edu/hyunjongkim) of this\nrepository, who is primarily a mathematician (a postdoctoral associate\nat the time of this writing), does not guarantee quick responses or\nresolutions to such issues, but will do his best to address them.\n\n# For developers\n\nThis repository is based on the [`nbdev`](https://nbdev.fast.ai/)\ntemplate. As such, code for the packages as well as the documentation\nfor the repository are written in jupyter notebooks (the `.ipynb` files\nin the `nbs` folder) and the Python modules are auto-generated via the\ncommand-line command\n[`nbdev_export`](https://nbdev.fast.ai/api/doclinks.html#nbdev_export)\n(or\n[`nbdev_prepare`](https://nbdev.fast.ai/tutorials/tutorial.html#prepare-your-changes),\nwhich among other things runs `nbdev_export`.).\n\n## Troubleshooting\n\n- In the `nbs/_tests` folder, make sure that the folders that you want\n  to test are not empty; since git does not track empty folders, empty\n  folders will not be pushed in GitHub and the tests in GitHub Actions\n  may yield different results than in a local computer.\n\n# Copyright\n\nCopyright \u00a9 2023 onward Hyun Jong Kim. Licensed under the Apache\nLicense, Version 2.0 (the \u201cLicense\u201d); you may not use this project\u2019s\nfiles except in compliance with the License. A copy of the License is\nprovided in the LICENSE file in this repository.\n\n# Special Thanks\n\nThe author of `trouver` thanks [Sun Woo\nPark](https://sites.google.com/wisc.edu/spark483) for agreeing to allow\ntheir coauthored paper, [*Global $\\mathbb{A}^1$-degrees covering maps\nbetween modular curves*](https://arxiv.org/abs/2106.10586), along with\nsome of Park\u2019s expository writings, to be used in examples in this\nlibrary. The author of `trouver` further thanks Sun Woo Park for his\nhelp in testing `trouver` on a MacOS computer and for reviewing the\n`tutorial.walkthrough` page.\n\nComponents of `trouver` use [arXiv.org\u2019s\nAPI](https://info.arxiv.org/help/api/index.html). As such, we include\nthe following thanks:\n\n> Thank you to arXiv for use of its open access interoperability.\n\n`trouver` was built using [`nbdev`](https://nbdev.fast.ai/) as a\ntemplate.\n\n# Release notes\n\nSee [`release_notes`](release_notes.html).\n\n[^1]: Colloquially referred to as the \u201cDonut seminar\u201d, as the organizers\n    purchase donuts with the funds provided by the AMS for the speakers\n    and the audience to eat. The fake theorem/definition below are jokes\n    about donuts.\n\n[^2]: cf.\u00a0[nbdev\u2019s End-To-End\n    Walkthrough](https://nbdev.fast.ai/tutorials/tutorial.html#add-your-own-examples-tests-and-docs)\n    to see how to use `nbdev_test`\n\n[^3]: There are also tests which are hidden from the documentation\n    website; one can find these tests in the jupyter notebook files in\n    the `nbs` folder in the repository for this library as notebook\n    cells marked with the `#| hide` flag, cf.\u00a0[nbdev\u2019s End-to-End\n    Walkthrough](https://nbdev.fast.ai/tutorials/tutorial.html#add-your-own-frontmatter)\n    to see what the `#| hide` flag does.\n\n[^4]: The `.github/workflows/test.yaml` GitHub workflow file is set up\n    in such a way that that allows GitHub Actions to access/use the\n    contents of the `nbs/_tests` directory upon running the\n    tests/examples.\n\n[^5]: The `.github/workflows/test.yaml` GitHub workflow file is set up\n    in such a way that that allows GitHub Actions to access/use the\n    contents of the `nbs/_tests` directory upon running the\n    tests/examples.\n",
    "bugtrack_url": null,
    "license": "Apache Software License 2.0",
    "summary": "Create and maintain mathematical Obsidian.md notes, and gather data from them to train ML models",
    "version": "1.0.1",
    "project_urls": {
        "Homepage": "https://github.com/hyunjongkimmath/trouver"
    },
    "split_keywords": [
        "nbdev",
        "jupyter",
        "notebook",
        "python"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "04ec8ce4918691ef2d058f8011cecf16444866fa1a30a8c7e30a94b7a181ae41",
                "md5": "2006ca49386f225c73b6d94feaaa7085",
                "sha256": "a6376f89e4375e10435f185024614ffa1e1e5235958af4fa1cda32abf99afd0b"
            },
            "downloads": -1,
            "filename": "trouver-1.0.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "2006ca49386f225c73b6d94feaaa7085",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 251098,
            "upload_time": "2024-12-26T23:03:23",
            "upload_time_iso_8601": "2024-12-26T23:03:23.621370Z",
            "url": "https://files.pythonhosted.org/packages/04/ec/8ce4918691ef2d058f8011cecf16444866fa1a30a8c7e30a94b7a181ae41/trouver-1.0.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "3cec637666279429d0040926a3f84b9c1477968793b519f30fc5eb6b52d5a064",
                "md5": "322231fe2bf7e19dd32fe2097fe9bd58",
                "sha256": "c7c21a59cdaba75ca91252c0e1875dea8e79c3a9a823ec2308311df41b9ea927"
            },
            "downloads": -1,
            "filename": "trouver-1.0.1.tar.gz",
            "has_sig": false,
            "md5_digest": "322231fe2bf7e19dd32fe2097fe9bd58",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 218743,
            "upload_time": "2024-12-26T23:03:29",
            "upload_time_iso_8601": "2024-12-26T23:03:29.561694Z",
            "url": "https://files.pythonhosted.org/packages/3c/ec/637666279429d0040926a3f84b9c1477968793b519f30fc5eb6b52d5a064/trouver-1.0.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-26 23:03:29",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "hyunjongkimmath",
    "github_project": "trouver",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "trouver"
}
        
Elapsed time: 0.42208s