# hgeometry: Geometric Algorithms, Data structures, and Data types.

**This is a package candidate release!** Here you can preview how this package release will appear once published to the main package index (which can be accomplished via the 'maintain' link below). Please note that once a package has been published to the main package index it cannot be undone! Please consult the package uploading documentation for more information.

**Warnings:**

- 'ghc-options: -O2' is rarely needed. Check that it is giving a real benefit and not just imposing longer compile times on your users.

HGeometry provides some basic geometry types, and geometric algorithms and data structures for them. The main two focusses are: (1) Strong type safety, and (2) implementations of geometric algorithms and data structures with good asymptotic running time guarantees. Note that HGeometry is still highly experimental, don't be surprised to find bugs.

[Skip to ReadMe]

## Properties

Versions | 0.1.0.0, 0.1.1.0, 0.1.1.1, 0.4.0.0, 0.5.0.0, 0.6.0.0, 0.7.0.0, 0.7.0.0, 0.8.0.0, 0.9.0.0, 0.10.0.0 |
---|---|

Change log | changelog.md |

Dependencies | aeson (>=1.0), base (>=4.9 && <5), bifunctors (>=4.1), bytestring (>=0.10), colour (>=2.3.3), containers (>=0.5.5), contravariant (>=1.4), data-clist (>=0.0.7.2), deepseq (>=1.1), dlist (>=0.7), fingertree (>=0.1), fixed-vector (>=1.0), hexpat (>=0.20.9), lens (>=4.2), linear (>=1.10), mtl, parsec (>=3), QuickCheck (>=2.5), quickcheck-instances (>=0.3), random, reflection (>=2.1), semigroupoids (>=5), semigroups (>=0.18), singletons (>=2.0), template-haskell, text (>=1.1.1.0), vector (>=0.11), vinyl (>=0.6), yaml (>=0.8) [details] |

License | BSD-3-Clause |

Author | Frank Staals |

Maintainer | frank@fstaals.net |

Category | Geometry |

Home page | https://fstaals.net/software/hgeometry |

Source repository | head: git clone https://github.com/noinia/hgeometry |

Executables | hgeometry-examples, hgeometry-viewer |

Uploaded | Fri Jul 20 15:58:50 UTC 2018 by FrankStaals |

## Modules

[Index]

*Algorithms**Geometry**ConvexHull**DelaunayTriangulation*- Algorithms.Geometry.Diameter
*EuclideanMST*- Algorithms.Geometry.LineSegmentIntersection
*LowerEnvelope**PolyLineSimplification**PolygonTriangulation**SmallestEnclosingBall*- Algorithms.Geometry.Sweep
*WellSeparatedPairDecomposition*

*Graph*- Algorithms.Util

*Control**Monad*

*Data*- Data.BalBST
- Data.BinaryTree
*CircularList*- Data.CircularSeq
- Data.Ext
- Data.Geometry
- Data.Geometry.Ball
- Data.Geometry.Boundary
- Data.Geometry.Box
- Data.Geometry.Duality
- Data.Geometry.HalfLine
- Data.Geometry.Interval
- Data.Geometry.IntervalTree
- Data.Geometry.Ipe
- Data.Geometry.KDTree
- Data.Geometry.Line
- Data.Geometry.LineSegment
- Data.Geometry.PlanarSubdivision
- Data.Geometry.Point
- Data.Geometry.PolyLine
- Data.Geometry.Polygon
- Data.Geometry.Properties
- Data.Geometry.SegmentTree
- Data.Geometry.Slab
- Data.Geometry.SubLine
- Data.Geometry.Transformation
- Data.Geometry.Triangle
- Data.Geometry.Vector

- Data.OrdSeq
- Data.Permutation
- Data.PlanarGraph
- Data.PlaneGraph
- Data.Range
- Data.Seq
- Data.Seq2
*Sequence*- Data.SlowSeq
- Data.UnBounded
- Data.Util
*Yaml*

*System**Random*

*Test**QuickCheck*

## Flags

Name | Description | Default | Type |
---|---|---|---|

examples | Build demonstration programs | Disabled | Manual |

with-quickcheck | Include QuickCheck instances | Enabled | Automatic |

interactive | Build interactive parts | Disabled | Manual |

Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info

## Downloads

- hgeometry-0.7.0.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)

#### Maintainers' corner

For package maintainers and hackage trustees