rgeometry 0.12.0

High-Level Computational Geometry
mod two_opt {
  use num_rational::BigRational;
  use rgeometry::algorithms::polygonization::*;
  use rgeometry::data::*;
  use rgeometry::*;

  use rand::SeedableRng;

  #[test]
  fn clockwise() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(1);
    let pts = vec![Point::new([0, 0]), Point::new([0, 1]), Point::new([1, 0])];
    two_opt_moves(pts, &mut rng)?;
    Ok(())
  }

  #[test]
  fn linear() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(1);
    let pts = vec![
      Point::new([0, 0]),
      Point::new([1, 0]),
      Point::new([2, 0]),
      Point::new([3, 0]),
      Point::new([4, 0]),
    ];
    assert!(two_opt_moves(pts, &mut rng).is_err());
    Ok(())
  }

  #[test]
  fn near_linear() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(1);
    let pts = vec![
      Point::new([0, 0]),
      Point::new([4, 0]),
      Point::new([3, 0]),
      Point::new([1, 0]),
      Point::new([2, 0]),
      Point::new([5, 1]),
    ];
    two_opt_moves(pts, &mut rng)?;
    Ok(())
  }

  #[test]
  fn with_dups() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(0);
    let pts = vec![
      Point::new([0, 0]),
      Point::new([0, 0]),
      Point::new([1, 1]),
      Point::new([1, 1]),
      Point::new([0, 1]),
      Point::new([0, 1]),
    ];
    assert_eq!(
      two_opt_moves(pts, &mut rng).err(),
      Some(Error::DuplicatePoints)
    );
    Ok(())
  }

  #[test]
  fn basic() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(1);
    let pts = vec![
      Point::new([0, 0]),
      Point::new([1, 0]),
      Point::new([1, 1]),
      Point::new([0, 1]),
      Point::new([2, 3]),
    ];
    two_opt_moves(pts, &mut rng)?;
    Ok(())
  }

  #[test]
  fn basic_2() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(0);
    let pts = vec![
      Point::new([0, 0]),
      Point::new([1, 2]),
      Point::new([2, 0]),
      Point::new([0, 1]),
      Point::new([2, 1]),
    ];
    two_opt_moves(pts, &mut rng)?;
    Ok(())
  }

  #[test]
  fn basic_3() -> Result<(), Error> {
    let mut rng = rand::rngs::SmallRng::seed_from_u64(0);
    let pts: Vec<Point<BigRational, 2>> = vec![
      Point::new([0.0, 0.0]).into(),
      Point::new([1.0, 2.0]).into(),
      Point::new([2.0, 0.0]).into(),
      Point::new([0.0, 1.0]).into(),
      Point::new([2.0, 1.0]).into(),
    ];
    two_opt_moves(pts, &mut rng)?;
    Ok(())
  }
}