Skip to content

Commit

Permalink
Merge pull request #7 from DavidLapous/multiparam_st_schreib_clean
Browse files Browse the repository at this point in the history
Upstream merge
  • Loading branch information
DavidLapous authored Nov 21, 2024
2 parents 9ec506a + b752394 commit 1b24266
Show file tree
Hide file tree
Showing 94 changed files with 8,786 additions and 3,246 deletions.
20 changes: 8 additions & 12 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
version: 2.0
jobs:

### With all third parties
### With all third parties

examples:
docker:
# cf. https://github.com/GUDHI/gudhi-deploy/blob/main/Dockerfile_for_circleci_image
- image: gudhi/ci_for_gudhi:2024.06.02
- image: gudhi/ci_for_gudhi:2024.09.01
steps:
- checkout
- run:
Expand All @@ -25,7 +24,7 @@ jobs:
tests:
docker:
- image: gudhi/ci_for_gudhi:2024.06.02
- image: gudhi/ci_for_gudhi:2024.09.01
steps:
- checkout
- run:
Expand All @@ -44,7 +43,7 @@ jobs:
debug_tests:
docker:
- image: gudhi/ci_for_gudhi:2024.06.02
- image: gudhi/ci_for_gudhi:2024.09.01
steps:
- checkout
- run:
Expand All @@ -63,7 +62,7 @@ jobs:
utils:
docker:
- image: gudhi/ci_for_gudhi:2024.06.02
- image: gudhi/ci_for_gudhi:2024.09.01
steps:
- checkout
- run:
Expand All @@ -82,7 +81,7 @@ jobs:
python:
docker:
- image: gudhi/ci_for_gudhi:2024.06.02
- image: gudhi/ci_for_gudhi:2024.09.01
resource_class: large # Delaunay complex requires about 5 Gb of RAM to compile
steps:
- checkout
Expand All @@ -94,7 +93,6 @@ jobs:
- run:
name: Build and test python module. Generates and tests the python documentation
command: |
pip3 install pydata-sphinx-theme
mkdir build
cd build
cmake -DWITH_GUDHI_THIRD_PARTY=OFF -DUSER_VERSION_DIR=version ..
Expand Down Expand Up @@ -167,8 +165,7 @@ jobs:
latexmk -pdf -interaction=nonstopmode test_biblio.tex
latexmk -pdf -interaction=nonstopmode test_gudhi_citation.tex
### With all third parties, except CGAL and Eigen
### With all third parties, except CGAL and Eigen

examples_without_cgal_eigen:
docker:
Expand Down Expand Up @@ -248,8 +245,7 @@ jobs:
python3 setup.py build_ext --inplace
ctest --output-on-failure
### With all third parties, except CGAL
### With all third parties, except CGAL

examples_without_cgal:
docker:
Expand Down
4 changes: 2 additions & 2 deletions .github/for_maintainers/new_gudhi_version_creation.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ nor [unlabelled closed PRs](https://github.com/GUDHI/gudhi-devel/pulls?q=is%3Apr
**Edit the file CMakeGUDHIVersion.txt**, and increment major, minor, or patch version number, in function of the version new delivery.
```bash
# cf. .gitignore - ignore this if it is a fresh clone version
rm -rf data/points/COIL_database/lucky_cat.off_dist data/points/COIL_database/lucky_cat.off_sc.dot data/points/KleinBottle5D.off_dist data/points/KleinBottle5D.off_sc.dot data/points/human.off_dist data/points/human.off_sc.off data/points/human.off_sc.txt src/python/test/__pycache__ src/python/gudhi/*.cpp
rm -rf data/points/COIL_database/lucky_cat.off_dist data/points/COIL_database/lucky_cat.off_sc.dot data/points/KleinBottle5D.off_dist data/points/KleinBottle5D.off_sc.dot data/points/human.off_dist data/points/human.off_sc.off data/points/human.off_sc.txt src/python/test/__pycache__
```

Checkin the modifications, build and test the version:
Expand Down Expand Up @@ -154,4 +154,4 @@ Send version mail to the following lists :

**Edit the file CMakeGUDHIVersion.txt**, and increment major, minor, or patch version number, in function of the future version (something like `3.X+1.0a0`).

Reset [.github/next_release.md](.github/next_release.md) with [.github/for_maintainers/next_release_template.md](.github/for_maintainers/next_release_template.md).
Reset [.github/next_release.md](.github/next_release.md) with [.github/for_maintainers/next_release_template.md](.github/for_maintainers/next_release_template.md).
3 changes: 2 additions & 1 deletion .github/next_release.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ Below is a list of changes:

- Installation
- CMake ≥ 3.15 is now required (was ≥ 3.8).
- Python ≥ 3.8 is now required (was ≥ 3.5), because of `importlib.metadata`.

- Miscellaneous
- The [list of bugs that were solved](https://github.com/GUDHI/gudhi-devel/issues?q=label%3A3.11.0+is%3Aclosed) is available on GitHub.
Expand All @@ -29,7 +30,7 @@ However, there are still GPL dependencies for many modules. We invite you to che

We kindly ask users to cite the GUDHI library as appropriately as possible in their papers, and to mention the use of the GUDHI library on the web pages of their projects using GUDHI and provide us with links to these web pages.

We provide [bibtex entries](https://gudhi.inria.fr/doc/latest/_citation.html) for the modules of the User and Reference Manual, as well as for publications directly related to the GUDHI library.
We provide [bibtex entries](https://gudhi.inria.fr/doc/latest/_citation.html) for the modules of the User and Reference Manual, as well as for publications directly related to the GUDHI library.

Feel free to [contact us](https://gudhi.inria.fr/contact/) in case you have any questions or remarks.

Expand Down
5 changes: 0 additions & 5 deletions .github/workflows/pip-packaging-linux.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ jobs:
# numpy~=1.21.4 means any numpy=1.21.*, but also numpy>=1.21.4 (numpy~=1.21 do not work as it means any numpy==1.*)
- name: Build wheel for Python 3.8
run: |
rm -rf src/python/gudhi/*.cpp
mkdir build_38
cd build_38
cmake -DCMAKE_BUILD_TYPE=Release -DPython_EXECUTABLE=$PYTHON38/bin/python ..
Expand All @@ -38,7 +37,6 @@ jobs:
$PYTHON38/bin/python -m pytest -v src/python/test/test_rips_complex.py
- name: Build wheel for Python 3.9
run: |
rm -rf src/python/gudhi/*.cpp
mkdir build_39
cd build_39
cmake -DCMAKE_BUILD_TYPE=Release -DPython_EXECUTABLE=$PYTHON39/bin/python ..
Expand All @@ -61,7 +59,6 @@ jobs:
$PYTHON39/bin/python -m pytest -v src/python/test/test_rips_complex.py
- name: Build wheel for Python 3.10
run: |
rm -rf src/python/gudhi/*.cpp
mkdir build_310
cd build_310
cmake -DCMAKE_BUILD_TYPE=Release -DPython_EXECUTABLE=$PYTHON310/bin/python ..
Expand All @@ -80,7 +77,6 @@ jobs:
$PYTHON310/bin/python -m pytest -v src/python/test/test_rips_complex.py
- name: Build wheel for Python 3.11
run: |
rm -rf src/python/gudhi/*.cpp
mkdir build_311
cd build_311
cmake -DCMAKE_BUILD_TYPE=Release -DPython_EXECUTABLE=$PYTHON311/bin/python ..
Expand All @@ -99,7 +95,6 @@ jobs:
$PYTHON311/bin/python -m pytest -v src/python/test/test_rips_complex.py
- name: Build wheel for Python 3.12
run: |
rm -rf src/python/gudhi/*.cpp
mkdir build_312
cd build_312
cmake -DCMAKE_BUILD_TYPE=Release -DPython_EXECUTABLE=$PYTHON312/bin/python ..
Expand Down
3 changes: 0 additions & 3 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,9 +1,6 @@
# Classical CMake build directory
/*build*

# Generated by Cython
src/python/gudhi/*.cpp

# Generated by tests
data/points/COIL_database/lucky_cat.off_dist
data/points/COIL_database/lucky_cat.off_sc.dot
Expand Down
2 changes: 2 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ add_gudhi_module(Hasse_complex)
add_gudhi_module(Persistence_representations)
add_gudhi_module(Persistent_cohomology)
add_gudhi_module(Rips_complex)
add_gudhi_module(Ripser)
add_gudhi_module(Simplex_tree)
add_gudhi_module(Skeleton_blocker)
add_gudhi_module(Spatial_searching)
Expand All @@ -46,6 +47,7 @@ add_gudhi_module(Toplex_map)
add_gudhi_module(Witness_complex)
add_gudhi_module(Nerve_GIC)
add_gudhi_module(Persistence_matrix)
add_gudhi_module(Zigzag_persistence)
add_gudhi_module(Multi_persistence)
add_gudhi_module(Multi_filtration)

Expand Down
4 changes: 2 additions & 2 deletions data/distance_matrix/tore3D_1307_distance_matrix.csv

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions src/Alpha_complex/test/Incremental_delaunay_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
#define BOOST_TEST_MODULE "incremental_delaunay"
#include <boost/test/unit_test.hpp>
#include <boost/range/adaptor/sliced.hpp>
#include <boost/mpl/list.hpp>

#include <CGAL/Epick_d.h>
#include <CGAL/Epeck_d.h>
Expand Down
2 changes: 2 additions & 0 deletions src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ add_gudhi_module(Hasse_complex)
add_gudhi_module(Persistence_representations)
add_gudhi_module(Persistent_cohomology)
add_gudhi_module(Rips_complex)
add_gudhi_module(Ripser)
add_gudhi_module(Simplex_tree)
add_gudhi_module(Skeleton_blocker)
add_gudhi_module(Spatial_searching)
Expand All @@ -45,6 +46,7 @@ add_gudhi_module(Toplex_map)
add_gudhi_module(Witness_complex)
add_gudhi_module(Nerve_GIC)
add_gudhi_module(Persistence_matrix)
add_gudhi_module(Zigzag_persistence)
add_gudhi_module(Multi_persistence)
add_gudhi_module(Multi_filtration)

Expand Down
55 changes: 48 additions & 7 deletions src/Multi_filtration/include/gudhi/Multi_critical_filtration.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
#include <cstdint>
#include <iostream>
#include <limits>
#include <stdexcept>
#include <string>
#include <utility>
#include <vector>
Expand Down Expand Up @@ -240,6 +241,18 @@ class Multi_critical_filtration {
* and if there is no generator, the method will segfault.
*/
operator Generator() {
if (num_generators() != 1)
throw std::logic_error("Casting a " + std::to_string(num_generators()) +
"-critical filtration value into an 1-critical filtration value.");
return multi_filtration_[0];
}

/**
* @brief Casts the object into the type of a generator.
* @pre The filtration value is 1-critical. If there are more than one generator, only the first will be preserved
* and if there is no generator, the method will segfault.
*/
operator const Generator() const {
GUDHI_CHECK(num_generators() == 1, "Casting a " + std::to_string(num_generators()) +
"-critical filtration value into an 1-critical filtration value.");
return multi_filtration_[0];
Expand Down Expand Up @@ -845,14 +858,42 @@ class Multi_critical_filtration {
// no nan values and if there is an inf/-inf, then 'end - curr == 1'
// modifies multi_filtration_ only if true is returned.
bool _generator_can_be_added(const Generator &x, std::size_t curr, std::size_t &end) {
if (x.empty() || x.is_nan() || (x.is_plus_inf() && end - curr != 0)) return false;
if (x.empty() || x.is_nan()) return false;

if (x.is_minus_inf()) {
if (end - curr == 1 && multi_filtration_[curr].is_minus_inf()) return false;
// assumes that everything between curr and end is already simplified
// so, if end - curr != 1, there can be no minus_inf anymore.
end = curr;
return true;
// assumes that everything between curr and end is simplified
// so, only multi_filtration_[curr] can be at inf or -inf.
if constexpr (co) {
if (multi_filtration_[curr].is_plus_inf() || (x.is_minus_inf() && end - curr != 0)) {
return false;
}
if (multi_filtration_[curr].is_minus_inf()) {
if (x.is_minus_inf()) {
return false;
}
end = curr;
return true;
}
if (x.is_plus_inf()) {
if (multi_filtration_[curr].is_plus_inf()) return false;
end = curr;
return true;
}
} else {
if (multi_filtration_[curr].is_minus_inf() || (x.is_plus_inf() && end - curr != 0)) {
return false;
}
if (multi_filtration_[curr].is_plus_inf()) {
if (x.is_plus_inf()) {
return false;
}
end = curr;
return true;
}
if (x.is_minus_inf()) {
if (multi_filtration_[curr].is_minus_inf()) return false;
end = curr;
return true;
}
}

while (curr != end) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -421,6 +421,11 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(multi_critical_filtration_add, T, list_of_tested_v
BOOST_CHECK_EQUAL(f5[0][0], 0);
BOOST_CHECK_EQUAL(f5[0][1], 1);
BOOST_CHECK_EQUAL(f5[0][2], 2);

Multi_critical_filtration<T, true> f6 = Multi_critical_filtration<T, true>::minus_inf();
bool change = f6.add_generator(Multi_critical_filtration<T, true>::inf());
BOOST_CHECK(change);
BOOST_CHECK(f6.is_plus_inf());
}

BOOST_AUTO_TEST_CASE_TEMPLATE(multi_critical_filtration_friends, T, list_of_tested_variants)
Expand Down
22 changes: 16 additions & 6 deletions src/Multi_persistence/include/gudhi/Multi_persistence/Line.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
#ifndef LINE_FILTRATION_TRANSLATION_H_INCLUDED
#define LINE_FILTRATION_TRANSLATION_H_INCLUDED

#include <cmath>
#include <cstddef>
#include <stdexcept>
#include <limits>
Expand Down Expand Up @@ -82,6 +83,15 @@ class Line {
* the number of coordinates.
*/
Point operator[](T t) const {
GUDHI_CHECK(direction_.empty() || direction_.size() == basePoint_.size(),
"Direction and base point do not have the same dimension.");

if constexpr (std::numeric_limits<T>::has_quiet_NaN){ //to avoid windows error
if (std::isnan(t)) return Point::nan();
}
if (t == Point::T_inf) return Point::inf();
if (t == -Point::T_inf) return Point::minus_inf();

Point x(basePoint_.size());

if (direction_.size() > 0) {
Expand Down Expand Up @@ -222,21 +232,21 @@ class Line {
}

/**
* @brief Given a box, returns the intersection of this box and the line.
* @brief Given a box, returns "time" parameter of the intersection of this box and the line.
*
* @param box Box to intersect.
* @return A pair representing the two bounding points of the intersection, such that the first element is the
* smallest of the two. If the box and the line do not intersect, returns the pair {inf, inf}.
* smallest of the two. If the box and the line do not intersect or the box is trivial, returns the pair {inf, -inf}.
*/
std::pair<Point, Point> get_bounds(const Box<T> &box) const {
if (box.is_trivial()) return {Point::inf(), Point::inf()};
std::pair<T, T> get_bounds(const Box<T> &box) const {
if (box.is_trivial()) return {Point::T_inf, -Point::T_inf};

T bottom = compute_forward_intersection(box.get_lower_corner());
T top = compute_backward_intersection(box.get_upper_corner());

if (bottom > top) return {Point::inf(), Point::inf()}; // no intersection
if (bottom > top) return {Point::T_inf, -Point::T_inf}; // no intersection

return {(*this)[bottom], (*this)[top]};
return {bottom, top};
}

private:
Expand Down
12 changes: 7 additions & 5 deletions src/Multi_persistence/test/multipersistence_line_unit_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -87,9 +87,9 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(line_intersections, T, list_of_tested_variants)
t = l.template compute_backward_intersection<double>(KP({P{2,1,3}, P{2,3,3}}));
BOOST_CHECK_EQUAL(t, 0);

std::pair<P, P> bounds = l.get_bounds({{-10, 0, 10}, {10, 4, 10}});
auto& bottom = bounds.first;
auto& top = bounds.second;
std::pair<T, T> bounds = l.get_bounds({{-10, 0, 10}, {10, 4, 10}});
auto bottom = l[bounds.first];
auto top = l[bounds.second];
BOOST_CHECK_EQUAL(bottom.size(), 3);
BOOST_CHECK_EQUAL(bottom[0], T(5. + 2. / 3.));
BOOST_CHECK_EQUAL(bottom[1], 2);
Expand All @@ -100,8 +100,10 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(line_intersections, T, list_of_tested_variants)
BOOST_CHECK_EQUAL(top[2], T(3. + T(7. / 6.) * 6.));

bounds = l.get_bounds({{-10, 0, 10}, {10, 1, 10}});
BOOST_CHECK(bounds.first.is_plus_inf());
BOOST_CHECK(bounds.second.is_plus_inf());
BOOST_CHECK_EQUAL(bounds.first, P::T_inf);
BOOST_CHECK_EQUAL(bounds.second, -P::T_inf);
BOOST_CHECK(l[bounds.first].is_plus_inf());
BOOST_CHECK(l[bounds.second].is_minus_inf());
}

BOOST_AUTO_TEST_CASE_TEMPLATE(line_other, T, list_of_tested_variants)
Expand Down
Loading

0 comments on commit 1b24266

Please sign in to comment.