diff --git a/.buildinfo b/.buildinfo index 09a9f92..a45b577 100644 --- a/.buildinfo +++ b/.buildinfo @@ -1,4 +1,4 @@ # Sphinx build info version 1 # This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. -config: 78bfbccb42ead2c17534c3edc9d79023 +config: c21e735eab84c3aa0e238b171d1ab8ac tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/.doctrees/api.doctree b/.doctrees/api.doctree index 423faaa..288d0b7 100644 Binary files a/.doctrees/api.doctree and b/.doctrees/api.doctree differ diff --git a/.doctrees/environment.pickle b/.doctrees/environment.pickle index fbbd50e..1517963 100644 Binary files a/.doctrees/environment.pickle and b/.doctrees/environment.pickle differ diff --git a/.doctrees/examples/sg_execution_times.doctree b/.doctrees/examples/sg_execution_times.doctree index ac675dc..74ccf00 100644 Binary files a/.doctrees/examples/sg_execution_times.doctree and b/.doctrees/examples/sg_execution_times.doctree differ diff --git a/.doctrees/examples/spatial_indexing.doctree b/.doctrees/examples/spatial_indexing.doctree index a093e92..88a37ef 100644 Binary files a/.doctrees/examples/spatial_indexing.doctree and b/.doctrees/examples/spatial_indexing.doctree differ diff --git a/.doctrees/sg_execution_times.doctree b/.doctrees/sg_execution_times.doctree index f57224d..0693a80 100644 Binary files a/.doctrees/sg_execution_times.doctree and b/.doctrees/sg_execution_times.doctree differ diff --git a/_downloads/bc82bea3a5dd7bdba60b65220891d9e5/examples_python.zip b/_downloads/bc82bea3a5dd7bdba60b65220891d9e5/examples_python.zip index 0a702e9..b4cb24b 100644 Binary files a/_downloads/bc82bea3a5dd7bdba60b65220891d9e5/examples_python.zip and b/_downloads/bc82bea3a5dd7bdba60b65220891d9e5/examples_python.zip differ diff --git a/_downloads/f989545cc7034bd6c0c40e2091705820/spatial_indexing.py b/_downloads/f989545cc7034bd6c0c40e2091705820/spatial_indexing.py index cc7eab2..37cf2d4 100644 --- a/_downloads/f989545cc7034bd6c0c40e2091705820/spatial_indexing.py +++ b/_downloads/f989545cc7034bd6c0c40e2091705820/spatial_indexing.py @@ -24,6 +24,7 @@ We'll start by importing the required packages with matplotlib for plotting. """ + import os import matplotlib.pyplot as plt diff --git a/_downloads/fb625db3c50d423b1b7881136ffdeec8/examples_jupyter.zip b/_downloads/fb625db3c50d423b1b7881136ffdeec8/examples_jupyter.zip index d5d40a8..d3a5716 100644 Binary files a/_downloads/fb625db3c50d423b1b7881136ffdeec8/examples_jupyter.zip and b/_downloads/fb625db3c50d423b1b7881136ffdeec8/examples_jupyter.zip differ diff --git a/_modules/index.html b/_modules/index.html index a3e3996..ad7cf27 100644 --- a/_modules/index.html +++ b/_modules/index.html @@ -427,7 +427,7 @@
import numpy as np
-from .algorithms import (
+from numba_celltree.algorithms import (
area_of_intersection,
barycentric_triangle_weights,
barycentric_wachspress_weights,
box_area_of_intersection,
polygons_intersect,
)
-from .constants import (
+from numba_celltree.constants import (
FILL_VALUE,
MAX_N_FACE,
MAX_N_VERTEX,
@@ -401,9 +401,9 @@ Source code for numba_celltree.celltree
IntArray,
IntDType,
)
-from .creation import initialize
-from .geometry_utils import build_bboxes, counter_clockwise
-from .query import (
+from numba_celltree.creation import initialize
+from numba_celltree.geometry_utils import build_bboxes, counter_clockwise
+from numba_celltree.query import (
collect_node_bounds,
locate_boxes,
locate_edges,
@@ -874,7 +874,7 @@ Source code for numba_celltree.celltree
Examples
Computation times#
-00:00.773 total execution time for 1 file from examples:
+00:00.746 total execution time for 1 file from examples:
diff --git a/examples/sg_execution_times.html b/examples/sg_execution_times.html
index fb1fec4..92b4439 100644
--- a/examples/sg_execution_times.html
+++ b/examples/sg_execution_times.html
@@ -382,7 +382,7 @@
diff --git a/_sources/examples/sg_execution_times.rst.txt b/_sources/examples/sg_execution_times.rst.txt
index d2e185e..40de308 100644
--- a/_sources/examples/sg_execution_times.rst.txt
+++ b/_sources/examples/sg_execution_times.rst.txt
@@ -6,7 +6,7 @@
Computation times
=================
-**00:00.773** total execution time for 1 file **from examples**:
+**00:00.746** total execution time for 1 file **from examples**:
.. container::
@@ -33,5 +33,5 @@ Computation times
- Time
- Mem (MB)
* - :ref:`sphx_glr_examples_spatial_indexing.py` (``spatial_indexing.py``)
- - 00:00.773
+ - 00:00.746
- 0.0
diff --git a/_sources/examples/spatial_indexing.rst.txt b/_sources/examples/spatial_indexing.rst.txt
index b31f1d3..622d040 100644
--- a/_sources/examples/spatial_indexing.rst.txt
+++ b/_sources/examples/spatial_indexing.rst.txt
@@ -43,10 +43,11 @@ these.
We'll start by importing the required packages with matplotlib for plotting.
-.. GENERATED FROM PYTHON SOURCE LINES 27-36
+.. GENERATED FROM PYTHON SOURCE LINES 27-37
.. code-block:: Python
+
import os
import matplotlib.pyplot as plt
@@ -63,11 +64,11 @@ We'll start by importing the required packages with matplotlib for plotting.
-.. GENERATED FROM PYTHON SOURCE LINES 37-38
+.. GENERATED FROM PYTHON SOURCE LINES 38-39
Let's start with a rectangular mesh:
-.. GENERATED FROM PYTHON SOURCE LINES 38-44
+.. GENERATED FROM PYTHON SOURCE LINES 39-45
.. code-block:: Python
@@ -84,11 +85,11 @@ Let's start with a rectangular mesh:
-.. GENERATED FROM PYTHON SOURCE LINES 45-46
+.. GENERATED FROM PYTHON SOURCE LINES 46-47
Determine the edges of the cells, and plot them.
-.. GENERATED FROM PYTHON SOURCE LINES 46-52
+.. GENERATED FROM PYTHON SOURCE LINES 47-53
.. code-block:: Python
@@ -110,14 +111,14 @@ Determine the edges of the cells, and plot them.
-.. GENERATED FROM PYTHON SOURCE LINES 53-57
+.. GENERATED FROM PYTHON SOURCE LINES 54-58
Locating points
---------------
We'll build a cell tree first, then look for some points.
-.. GENERATED FROM PYTHON SOURCE LINES 57-68
+.. GENERATED FROM PYTHON SOURCE LINES 58-69
.. code-block:: Python
@@ -145,7 +146,7 @@ We'll build a cell tree first, then look for some points.
-.. GENERATED FROM PYTHON SOURCE LINES 69-75
+.. GENERATED FROM PYTHON SOURCE LINES 70-76
These numbers are the cell numbers in which we can find the points.
@@ -154,7 +155,7 @@ A value of -1 means that a point is not located in any cell.
Let's get rid of the -1 values, and take a look which cells have been found.
We'll color the found cells blue, and we'll draw the nodes to compare.
-.. GENERATED FROM PYTHON SOURCE LINES 75-82
+.. GENERATED FROM PYTHON SOURCE LINES 76-83
.. code-block:: Python
@@ -177,11 +178,11 @@ We'll color the found cells blue, and we'll draw the nodes to compare.
-.. GENERATED FROM PYTHON SOURCE LINES 83-84
+.. GENERATED FROM PYTHON SOURCE LINES 84-85
Now let's try a more exotic example.
-.. GENERATED FROM PYTHON SOURCE LINES 84-93
+.. GENERATED FROM PYTHON SOURCE LINES 85-94
.. code-block:: Python
@@ -206,13 +207,13 @@ Now let's try a more exotic example.
-.. GENERATED FROM PYTHON SOURCE LINES 94-97
+.. GENERATED FROM PYTHON SOURCE LINES 95-98
There are certainly no rows or columns to speak of!
Let's build a new tree, and look for the same points as before.
-.. GENERATED FROM PYTHON SOURCE LINES 97-106
+.. GENERATED FROM PYTHON SOURCE LINES 98-107
.. code-block:: Python
@@ -237,7 +238,7 @@ Let's build a new tree, and look for the same points as before.
-.. GENERATED FROM PYTHON SOURCE LINES 107-122
+.. GENERATED FROM PYTHON SOURCE LINES 108-123
It should be clear by now that a point may only fall into a single cell. A
point may also be out of bounds. If a cell falls exactly on an edge, one of the
@@ -255,7 +256,7 @@ A search of N points will yield N answers (cell numbers). A search of N boxes
may yield M answers. To illustrate, let's look for all the cells inside of
a box.
-.. GENERATED FROM PYTHON SOURCE LINES 122-136
+.. GENERATED FROM PYTHON SOURCE LINES 123-137
.. code-block:: Python
@@ -285,11 +286,11 @@ a box.
-.. GENERATED FROM PYTHON SOURCE LINES 137-138
+.. GENERATED FROM PYTHON SOURCE LINES 138-139
We can also search for multiple boxes:
-.. GENERATED FROM PYTHON SOURCE LINES 138-148
+.. GENERATED FROM PYTHON SOURCE LINES 139-149
.. code-block:: Python
@@ -322,7 +323,7 @@ We can also search for multiple boxes:
-.. GENERATED FROM PYTHON SOURCE LINES 149-154
+.. GENERATED FROM PYTHON SOURCE LINES 150-155
Note that this method returns two arrays of equal length. The second array
contains the cell numbers, as usual. The first array contains the index of
@@ -330,7 +331,7 @@ the bounding box in which the respective cells fall. Note that there are only
two numbers in ``box_i``: there are no cells located in the third box, as we
can confirm visually:
-.. GENERATED FROM PYTHON SOURCE LINES 154-167
+.. GENERATED FROM PYTHON SOURCE LINES 155-168
.. code-block:: Python
@@ -359,7 +360,7 @@ can confirm visually:
-.. GENERATED FROM PYTHON SOURCE LINES 168-179
+.. GENERATED FROM PYTHON SOURCE LINES 169-180
Locating cells
--------------
@@ -373,7 +374,7 @@ This returns three arrays of equal length:
* the index of the face in the celtree
* the area of the intersection
-.. GENERATED FROM PYTHON SOURCE LINES 179-211
+.. GENERATED FROM PYTHON SOURCE LINES 180-212
.. code-block:: Python
@@ -421,14 +422,14 @@ This returns three arrays of equal length:
-.. GENERATED FROM PYTHON SOURCE LINES 212-216
+.. GENERATED FROM PYTHON SOURCE LINES 213-217
Let's color the faces of the mesh by their ratio of overlap. Because our
mesh is triangular, we can represent the triangles as two collections of
vectors (V, U). Then the area is half of the absolute value of the cross
product of U and V.
-.. GENERATED FROM PYTHON SOURCE LINES 216-234
+.. GENERATED FROM PYTHON SOURCE LINES 217-235
.. code-block:: Python
@@ -463,19 +464,19 @@ product of U and V.
.. code-block:: none
- /home/runner/work/numba_celltree/numba_celltree/examples/spatial_indexing.py:220: DeprecationWarning: Arrays of 2-dimensional vectors are deprecated. Use arrays of 3-dimensional vectors instead. (deprecated in NumPy 2.0)
+ /home/runner/work/numba_celltree/numba_celltree/examples/spatial_indexing.py:221: DeprecationWarning: Arrays of 2-dimensional vectors are deprecated. Use arrays of 3-dimensional vectors instead. (deprecated in NumPy 2.0)
full_area = 0.5 * np.abs(np.cross(V, U))
-.. GENERATED FROM PYTHON SOURCE LINES 235-238
+.. GENERATED FROM PYTHON SOURCE LINES 236-239
``CellTree2d`` also provides a method to compute overlaps between boxes and a
mesh. This may come in handy to compute overlap with a raster, for example to
rasterize a mesh.
-.. GENERATED FROM PYTHON SOURCE LINES 238-258
+.. GENERATED FROM PYTHON SOURCE LINES 239-259
.. code-block:: Python
@@ -506,12 +507,12 @@ rasterize a mesh.
-.. GENERATED FROM PYTHON SOURCE LINES 259-261
+.. GENERATED FROM PYTHON SOURCE LINES 260-262
We can construct a weight matrix with these arrays. This weight matrix stores
for every raster cell (row) the area of overlap with a triangle (column).
-.. GENERATED FROM PYTHON SOURCE LINES 261-268
+.. GENERATED FROM PYTHON SOURCE LINES 262-269
.. code-block:: Python
@@ -534,13 +535,13 @@ for every raster cell (row) the area of overlap with a triangle (column).
-.. GENERATED FROM PYTHON SOURCE LINES 269-272
+.. GENERATED FROM PYTHON SOURCE LINES 270-273
This weight matrix can be used for translating data from one mesh to another.
Let's generate some mock elevation data for a valley. Then, we'll compute the
area weighted mean for every raster cell.
-.. GENERATED FROM PYTHON SOURCE LINES 272-298
+.. GENERATED FROM PYTHON SOURCE LINES 273-299
.. code-block:: Python
@@ -582,7 +583,7 @@ area weighted mean for every raster cell.
-.. GENERATED FROM PYTHON SOURCE LINES 299-323
+.. GENERATED FROM PYTHON SOURCE LINES 300-324
Such a weight matrix doesn't apply to just boxes and triangles, but to every
case of mapping one mesh to another by intersecting cell areas. Note however
@@ -609,7 +610,7 @@ This once again returns three arrays of equal length:
* the index of the cell
* the location of the intersection
-.. GENERATED FROM PYTHON SOURCE LINES 323-332
+.. GENERATED FROM PYTHON SOURCE LINES 324-333
.. code-block:: Python
@@ -638,13 +639,13 @@ This once again returns three arrays of equal length:
-.. GENERATED FROM PYTHON SOURCE LINES 333-336
+.. GENERATED FROM PYTHON SOURCE LINES 334-337
To wrap up, we'll color the intersect faces with the length of the
intersected line segments. We can easily compute the length of each segment
with the Euclidian norm (Pythagorean distance):
-.. GENERATED FROM PYTHON SOURCE LINES 336-348
+.. GENERATED FROM PYTHON SOURCE LINES 337-349
.. code-block:: Python
@@ -675,7 +676,7 @@ with the Euclidian norm (Pythagorean distance):
.. rst-class:: sphx-glr-timing
- **Total running time of the script:** (0 minutes 0.773 seconds)
+ **Total running time of the script:** (0 minutes 0.746 seconds)
.. _sphx_glr_download_examples_spatial_indexing.py:
diff --git a/_sources/sg_execution_times.rst.txt b/_sources/sg_execution_times.rst.txt
index 80d2a91..698e271 100644
--- a/_sources/sg_execution_times.rst.txt
+++ b/_sources/sg_execution_times.rst.txt
@@ -6,7 +6,7 @@
Computation times
=================
-**00:00.773** total execution time for 1 file **from all galleries**:
+**00:00.746** total execution time for 1 file **from all galleries**:
.. container::
@@ -33,5 +33,5 @@ Computation times
- Time
- Mem (MB)
* - :ref:`sphx_glr_examples_spatial_indexing.py` (``../examples/spatial_indexing.py``)
- - 00:00.773
+ - 00:00.746
- 0.0
diff --git a/_static/searchtools.js b/_static/searchtools.js
index 92da3f8..b08d58c 100644
--- a/_static/searchtools.js
+++ b/_static/searchtools.js
@@ -178,7 +178,7 @@ const Search = {
htmlToText: (htmlString, anchor) => {
const htmlElement = new DOMParser().parseFromString(htmlString, 'text/html');
- for (const removalQuery of [".headerlinks", "script", "style"]) {
+ for (const removalQuery of [".headerlink", "script", "style"]) {
htmlElement.querySelectorAll(removalQuery).forEach((el) => { el.remove() });
}
if (anchor) {
@@ -328,13 +328,14 @@ const Search = {
for (const [title, foundTitles] of Object.entries(allTitles)) {
if (title.toLowerCase().trim().includes(queryLower) && (queryLower.length >= title.length/2)) {
for (const [file, id] of foundTitles) {
- let score = Math.round(100 * queryLower.length / title.length)
+ const score = Math.round(Scorer.title * queryLower.length / title.length);
+ const boost = titles[file] === title ? 1 : 0; // add a boost for document titles
normalResults.push([
docNames[file],
titles[file] !== title ? `${titles[file]} > ${title}` : title,
id !== null ? "#" + id : "",
null,
- score,
+ score + boost,
filenames[file],
]);
}
diff --git a/api.html b/api.html
index 05793f4..70b7300 100644
--- a/api.html
+++ b/api.html
@@ -698,7 +698,7 @@
diff --git a/examples/index.html b/examples/index.html
index bf96011..48198a8 100644
--- a/examples/index.html
+++ b/examples/index.html
@@ -510,7 +510,7 @@