anuga 1.3.5__zip
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__config__.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__config__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__init__.py +363 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__metadata__.py +6 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/__metadata__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/__init__.py +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/ermapper_grids.py +251 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/ermapper_grids.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/file_function.py +483 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/file_function.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/gauge.py +1080 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/gauge.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/general_mesh.py +865 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/general_mesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/generic_boundary_conditions.py +862 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/generic_boundary_conditions.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/generic_domain.py +2274 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/generic_domain.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/mesh_factory.py +1011 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/mesh_factory.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/mesh_factory_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/neighbour_mesh.py +1488 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/neighbour_mesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/neighbour_mesh_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/neighbour_table_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/pmesh2domain.py +299 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/pmesh2domain.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/pmesh2domain_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/quantity.py +2162 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/quantity.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/quantity_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/region.py +321 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/region.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/setup.py +48 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tag_region.py +167 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tag_region.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/show_balanced_limiters.py +87 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_ermapper.py +189 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_gauge.py +539 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_general_mesh.py +517 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_generic_boundary_conditions.py +439 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_generic_domain.py +907 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_ghost.py +52 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_neighbour_mesh.py +1854 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_pmesh2domain.py +219 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_quantity.py +2859 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_region.py +99 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_tag_region.py +258 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/tests/test_util.py +1632 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/util.py +928 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/abstract_2d_finite_volumes/util.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/__init__.py +12 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/advection.py +298 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/advection.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/advection_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/setup.py +27 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/advection/tests/test_advection.py +183 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/__init__.py +4 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/alpha_shape.py +654 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/alpha_shape.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/alpha_shape/tests/test_alpha_shape.py +402 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/anuga_exceptions.py +46 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/anuga_exceptions.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/__init__.py +18 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/caching.py +2531 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/caching.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/dummy_classes_for_testing.py +20 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/dummy_classes_for_testing.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/caching/tests/test_caching.py +895 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/compile_all.py +82 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/compile_all.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/config.py +273 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/config.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/__init__.py +6 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/geo_reference.py +478 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/geo_reference.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/lat_long_UTM_conversion.py +250 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/lat_long_UTM_conversion.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/point.py +128 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/point.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/redfearn.py +233 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/redfearn.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points.csv +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points_z53.csv +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points_z53.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points_z54.csv +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/projection_test_points_z54.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/redfearn.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/data/redfearn.xls +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/test_geo_reference.py +716 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/test_lat_long_UTM_conversion.py +126 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/test_point.py +125 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/coordinate_transforms/tests/test_redfearn.py +508 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/__init__.py +9 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_class.py +1627 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_class.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_polygons.py +114 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_polygons.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_routines.py +362 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/culvert_routines.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/new_culvert_class.py +1630 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/new_culvert_class.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/culvert_polygons_example.py +38 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/example_rating_curve.csv +20 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/example_rating_curve.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/example_rating_curve2.csv +20 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/example_rating_curve2.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/unittests.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/data/unittests.xls +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/run_culvert_flat_water_lev.py +173 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_class.py +812 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_polygons.py +84 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_routines.py +586 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_routines_box_10pct.py +342 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_routines_box_1pct.py +342 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_routines_pipe_10pct.py +338 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_culvert_routines_pipe_1pct.py +338 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/culvert_flows/tests/test_new_culvert_class.py +810 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/__init__.py +9 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/exposure.py +223 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/exposure.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/inundation_damage.py +467 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/inundation_damage.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/tests/test_exposure.py +325 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/damage_modelling/tests/test_inundation_damage.py +610 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/error_api.py +130 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/error_api.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/extras.py +193 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/extras.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/__init__.py +54 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/csv_file.py +399 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/csv_file.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/mux.py +120 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/mux.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/netcdf.py +266 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/netcdf.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/pts.py +29 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/pts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/setup.py +27 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/sts.py +293 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/sts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/sww.py +1552 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/sww.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_csv.py +413 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_mux.py +1539 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_read_sww.py +350 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_sww.py +560 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_ungenerate.py +283 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/tests/test_urs.py +217 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/ungenerate.py +92 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/ungenerate.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/urs.py +323 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/urs.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file/urs_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/__init__.py +20 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/asc2dem.py +213 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/asc2dem.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/calc_grid_values_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/csv2sts.py +165 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/csv2sts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2array.py +90 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2array.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2dem.py +145 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2dem.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2pts.py +357 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/dem2pts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/esri2sww.py +327 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/esri2sww.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/ferret2sww.py +436 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/ferret2sww.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/file_conversion.py +367 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/file_conversion.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/grd2array.py +122 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/grd2array.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sdf2pts.py +181 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sdf2pts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/setup.py +29 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sts2sww_mesh.py +141 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sts2sww_mesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2array.py +321 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2array.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2dem.py +550 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2dem.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2dem_new.py +547 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2dem_new.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2pts.py +175 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/sww2pts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_2pts.py +249 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_csv2sts.py +118 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_dem2array.py +121 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_dem2dem.py +220 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_dem2pts.py +411 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_file_conversion.py +953 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_grd2array.py +270 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_sww2dem.py +1882 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_urs2sts.py +2127 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/tests/test_urs2sww.py +628 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2nc.py +202 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2nc.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2sts.py +316 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2sts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2sww.py +306 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2sww.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2txt.py +71 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/urs2txt.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/xya2pts.py +39 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/file_conversion/xya2pts.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/__init__.py +12 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/benchmark_least_squares.py +367 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/benchmark_least_squares.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/fit.py +611 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/fit.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/fitsmooth.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/general_fit_interpolate.py +127 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/general_fit_interpolate.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/interpolate.py +1144 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/interpolate.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/interpolate2d.py +305 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/interpolate2d.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/profile_long_benchmark.py +79 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/profile_long_benchmark.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/run_long_benchmark.py +131 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/run_long_benchmark.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/setup.py +37 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/tests/test_fit.py +1150 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/tests/test_interpolate.py +1952 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/tests/test_interpolate2d.py +469 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/tests/test_search_functions.py +236 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/ticket178_benchmark.py +66 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/fit_interpolate/ticket178_benchmark.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/__init__.py +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/aabb.py +133 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/aabb.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/polygon.py +1138 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/polygon.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/polygon_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/polygon_function.py +133 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/polygon_function.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/quad.py +190 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/quad.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/setup.py +27 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/tests/test_geometry.py +110 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geometry/tests/test_polygon.py +1994 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/__init__.py +9 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/geospatial_data.py +1698 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/geospatial_data.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/geospatial_data/tests/test_geospatial_data.py +1853 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/__init__.py +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/add_csv_header.py +136 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/add_csv_header.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/file_length.py +14 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/file_length.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/maxasc.py +96 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/maxasc.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/order_boundary.py +109 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/order_boundary.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/setup.py +22 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/perthAll_stage_250m.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/perthAll_stage_250m_all.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/perthAll_stage_original.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_bad_num_lines.asc +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_bad_num_lines.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_header_differs.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_header_differs.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_wrong_num_columns.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test1_wrong_num_columns.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test2.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test2.expected.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test2.expected.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test2.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test3.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test3.expected.asc +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test3.expected.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test3.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test_maxasc.py +150 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/lib/tests/test_order_boundary.py +397 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/__init__.py +4 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/loadASCII.py +1073 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/loadASCII.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/setup.py +21 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/load_mesh/tests/test_loadASCII.py +544 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/__init__.py +4 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/compile.py +9 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/compile.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/mesh_engine.py +221 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/mesh_engine.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/mesh_engine_c_layer.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/setup.py +29 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/mesh_engine/tests/test_generate_mesh.py +470 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/__init__.py +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/base_operator.py +125 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/base_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/boundary_flux_integral_operator.py +79 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/boundary_flux_integral_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/change_friction_operator.py +240 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/change_friction_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/collect_max_quantities_operator.py +142 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/collect_max_quantities_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/collect_max_stage_operator.py +85 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/collect_max_stage_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/compile_all.py +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/compile_all.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/elliptic_operator.py +495 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/elliptic_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/erosion_operators.py +859 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/erosion_operators.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/kinematic_viscosity_operator.py +563 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/kinematic_viscosity_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/kinematic_viscosity_operator_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/mannings_operator.py +87 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/mannings_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/mannings_operator_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/rate_operators.py +431 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/rate_operators.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_elevation.py +290 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_elevation.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_elevation_operator.py +148 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_elevation_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_friction_operators.py +159 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_friction_operators.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_quantity.py +172 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_quantity.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_quantity_operator.py +158 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_quantity_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_stage.py +131 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_stage.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_stage_operator.py +135 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_stage_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_w_uh_vh_operator.py +170 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/set_w_uh_vh_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/setup.py +33 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_base_operator.py +51 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_boundary_flux_integral_operator.py +98 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_erosion_operators.py +344 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_kinematic_viscosity_operator.py +1366 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_rate_operators.py +888 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_set_elevation_operator.py +1034 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_set_quantity.py +511 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_set_stage_operator.py +491 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/operators/tests/test_set_w_uh_vh_operators.py +211 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/__init__.py +31 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/config.py +14 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/config.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/distribute_mesh.py +1682 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/distribute_mesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_advection.py +205 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_advection.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_api.py +467 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_api.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_boyd_box_operator.py +332 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_boyd_box_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_boyd_pipe_operator.py +283 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_boyd_pipe_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_generic_communications.py +207 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_generic_communications.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet.py +605 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet_enquiry.py +228 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet_enquiry.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet_operator.py +281 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_inlet_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_internal_boundary_operator.py +230 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_internal_boundary_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_meshes.py +445 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_meshes.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_operator_factory.py +959 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_operator_factory.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_shallow_water.py +282 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_shallow_water.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_structure_operator.py +1241 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_structure_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_weir_orifice_trapezoid_operator.py +281 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/parallel_weir_orifice_trapezoid_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/print_stats.py +205 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/print_stats.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/pypar_ext.py +528 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/pypar_ext.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/sequential_distribute.py +309 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/sequential_distribute.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/setup.py +100 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/parallel/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/AppShell.py +345 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/AppShell.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/Pmw.py +9253 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/Pmw.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/PmwBlt.py +671 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/PmwBlt.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/PmwColor.py +389 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/PmwColor.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/ProgressBar.py +80 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/ProgressBar.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/__init__.py +4 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/compile.py +24 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/compile.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/cursornames.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/cursornames.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/exesetup.py +24 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/exesetup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/graphical_mesh_generator.py +1519 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/graphical_mesh_generator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/addVertex.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/addVertex.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/autoSegGiveAlpha.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/autoSegGiveAlpha.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/default.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/default.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/edit.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/edit.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/hole.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/hole.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/joinVer.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/joinVer.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/meshGen.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/meshGen.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/no_see.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/no_see.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/pointer.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/pointer.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/region.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/region.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/see.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/see.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/segment.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/segment.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/sep.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/sep.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/vertex.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/vertex.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoom0.5.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoom0.5.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoom2.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoom2.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoomToMesh.gif +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/icons/zoomToMesh.lic +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh.py +2416 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh_interface.py +373 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh_interface.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh_quadtree.py +130 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/mesh_quadtree.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/run_setup.py +43 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/run_setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/setup.py +22 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/tests/test_mesh.py +2129 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/tests/test_mesh_interface.py +988 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/tests/test_meshquad.py +189 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/timing.py +150 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/timing.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/toolbarbutton.py +80 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/toolbarbutton.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/ungen_example.py +69 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/ungen_example.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/view_tsh.py +47 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/view_tsh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/visualmesh.py +302 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pmesh/visualmesh.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/__init__.py +6 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/metis_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/setup.py +54 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/pymetis/tests/test_metis.py +141 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/setup.py +49 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/__init__.py +12 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/boundaries.py +1028 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/boundaries.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/checkpoint.py +118 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/checkpoint.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/forcing.py +1339 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/forcing.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/most2nc.py +101 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/most2nc.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/setup.py +37 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/shallow_water_domain.py +3114 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/shallow_water_domain.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/shallow_water_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/swDE1_domain_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/swb2_domain.py +576 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/swb2_domain.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/swb2_domain_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/sww_interrogate.py +652 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/sww_interrogate.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/__init__.py +8 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/polygon_values_example.csv +46 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/polygon_values_example.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/test_points_large.csv +7855 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/test_points_large.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/test_points_small.csv +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/data/test_points_small.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_DE1_domain.py +111 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_data_manager.py +879 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_forcing.py +2271 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_loadsave.py +212 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_local_extrapolation_and_flux_updating.py +114 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_most2nc.py +52 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_shallow_water_domain.py +8670 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_swb2_domain.py +106 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_sww_interrogate.py +888 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/test_system.py +193 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/1-z.grd-e-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/1-z.grd-n-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/1-z.grd-z-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/1-z.lic +55 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/2-z.grd-e-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/2-z.grd-n-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/2-z.grd-z-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/2-z.lic +55 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/3-z.grd-e-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/3-z.grd-n-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/3-z.grd-z-mux2 +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/3-z.lic +55 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_1_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_2_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_3_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/e_combined_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_1_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_2_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_3_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/n_combined_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/thinned_bound_order_test.lic +18 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/thinned_bound_order_test.txt +6 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_1_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_2_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_3_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_0.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_0.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_1.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_1.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_2.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_2.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_3.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_3.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_4.csv +252 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tests/urs_test_data/z_combined_4.lic +25 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tsh2sww.py +65 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/shallow_water/tsh2sww.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/__init__.py +5 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_box_operator.py +380 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_box_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_box_operator_Amended3.py +245 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_box_operator_Amended3.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_pipe_operator.py +305 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/boyd_pipe_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet.py +289 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet_enquiry.py +146 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet_enquiry.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet_operator.py +229 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/inlet_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/internal_boundary_functions.py +431 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/internal_boundary_functions.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/internal_boundary_operator.py +169 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/internal_boundary_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/riverwall.py +738 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/riverwall.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/setup.py +24 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/structure_operator.py +757 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/structure_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/hecras_bridge_table.csv +105 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/inlet_operator_test1.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/inlet_operator_test1.tms +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/inlet_operator_test2.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/inlet_operator_test2.tms +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/data/test_hydrograph.tms +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_boyd_box_operator.py +2623 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_boyd_pipe_operator.py +482 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_inlet_operator.py +311 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_internal_boundary_functions.py +96 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_riverwall_structure.py +619 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/tests/test_weir_orifice_trapezoid_operator.py +650 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/weir_orifice_trapezoid_operator.py +387 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/structures/weir_orifice_trapezoid_operator.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/test_all.py +282 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/test_all.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/__init__.py +13 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/eqf.py +147 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/eqf.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/eqf_v2.py +559 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/eqf_v2.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/okada_tsunami.py +347 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/okada_tsunami.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/setup.py +27 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/smf.py +467 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/smf.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_MS.lic +23 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_MS.txt +36 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_SP.lic +23 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_SP.txt +36 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_SS.lic +23 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/data/fullokada_SS.txt +36 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/okada_tsunami_octave_95.txt +101 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/test_eq.py +67 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/test_okada_tsunami.py +439 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/test_smf.py +143 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tests/test_tsunami_okada.py +303 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tsunami_okada.py +1885 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/tsunami_source/tsunami_okada.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/__init__.py +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/argparsing.py +76 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/argparsing.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/cg_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/cg_solve.py +327 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/cg_solve.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/compile.py +497 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/compile.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/csv_tools.py +121 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/csv_tools.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/data_audit.py +404 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/data_audit.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/data_audit_wrapper.py +52 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/data_audit_wrapper.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/file_utils.py +308 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/file_utils.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/function_utils.py +117 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/function_utils.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/interp.py +318 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/interp.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/log.py +414 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/log.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/log_analyser.py +77 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/log_analyser.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/mem_time_equation.py +106 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/mem_time_equation.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/model_tools.py +457 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/model_tools.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/norms.py +16 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/norms.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/numerical_tools.py +397 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/numerical_tools.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/parallel_abstraction.py +67 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/parallel_abstraction.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/parse.py +26 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/parse.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/plot_utils.py +1237 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/plot_utils.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/quad_tree_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/quantity_setting_functions.py +612 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/quantity_setting_functions.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/quickPlots.py +164 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/quickPlots.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/run_anuga_script.py +70 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/run_anuga_script.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/setup.py +39 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sparse.py +398 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sparse.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sparse_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sparse_matrix_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/spatialInputUtil.py +1394 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/spatialInputUtil.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sww_merge.py +820 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/sww_merge.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/system_tools.py +646 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/system_tools.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/terminal_width.py +60 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/terminal_width.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/complex_polygon.csv +4 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/complex_polygon.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/crc_test_file.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/crc_test_file.png +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/mainland_only.csv +669 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/mainland_only.lic +33 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/non_complex_polygon.csv +5 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/data/non_complex_polygon.lic +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_cg_solve.py +569 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_csv_tools.py +435 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_data_audit.py +393 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_file_utils.py +157 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_function_utils.py +65 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_log_analyser.py +89 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_mem_time_equation.py +47 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_numerical_tools.py +616 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_plot_utils.py +455 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_quantity_setting_functions.py +369 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_sparse.py +215 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_spatialInputUtil.py +418 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_system_tools.py +483 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/tests/test_xml_tools.py +316 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/util_ext.pyd +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/where_close.py +219 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/where_close.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/xml_tools.py +326 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/utilities/xml_tools.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/__init__.py +15 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/__init__.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/fabricate.py +1429 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/fabricate.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/parameters.py +24 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/parameters.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/produce_report.py +38 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/produce_report.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/run_validation.py +51 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/run_validation.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/save_parameters_tex.py +17 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/save_parameters_tex.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/setup.py +22 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/setup.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/typeset_report.py +55 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/validation_utilities/typeset_report.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/version.py +11 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga/version.pyc +0 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga-1.3.5-py2.7.egg-info/PKG-INFO +117 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga-1.3.5-py2.7.egg-info/SOURCES.txt +1329 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga-1.3.5-py2.7.egg-info/dependency_links.txt +1 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga-1.3.5-py2.7.egg-info/not-zip-safe +1 -0
- Users/steve/Miniconda/envs/anuga/Lib/site-packages/anuga-1.3.5-py2.7.egg-info/top_level.txt +1 -0
|
@@ -0,0 +1,1138 @@
|
|
|
1
|
+
#!/usr/bin/env python
|
|
2
|
+
|
|
3
|
+
"""Polygon manipulations"""
|
|
4
|
+
|
|
5
|
+
import numpy as num
|
|
6
|
+
import math
|
|
7
|
+
|
|
8
|
+
from anuga.utilities.numerical_tools import ensure_numeric
|
|
9
|
+
from anuga.geospatial_data.geospatial_data import ensure_absolute, \
|
|
10
|
+
Geospatial_data
|
|
11
|
+
import anuga.utilities.log as log
|
|
12
|
+
|
|
13
|
+
from aabb import AABB
|
|
14
|
+
|
|
15
|
+
def point_on_line(point, line, rtol=1.0e-5, atol=1.0e-8):
|
|
16
|
+
"""Determine whether a point is on a line segment
|
|
17
|
+
|
|
18
|
+
Input:
|
|
19
|
+
point is given by [x, y]
|
|
20
|
+
line is given by [x0, y0], [x1, y1]] or
|
|
21
|
+
the equivalent 2x2 numeric array with each row corresponding to a point.
|
|
22
|
+
|
|
23
|
+
Output:
|
|
24
|
+
|
|
25
|
+
Note: Line can be degenerate and function still works to discern coinciding
|
|
26
|
+
points from non-coinciding.
|
|
27
|
+
"""
|
|
28
|
+
|
|
29
|
+
point = ensure_numeric(point)
|
|
30
|
+
line = ensure_numeric(line)
|
|
31
|
+
|
|
32
|
+
res = _point_on_line(point[0], point[1],
|
|
33
|
+
line[0, 0], line[0, 1],
|
|
34
|
+
line[1, 0], line[1, 1],
|
|
35
|
+
rtol, atol)
|
|
36
|
+
|
|
37
|
+
return bool(res)
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
######
|
|
41
|
+
# Result functions used in intersection() below for collinear lines.
|
|
42
|
+
# (p0,p1) defines line 0, (p2,p3) defines line 1.
|
|
43
|
+
######
|
|
44
|
+
|
|
45
|
+
# result functions for possible states
|
|
46
|
+
def lines_dont_coincide(p0, p1, p2, p3):
|
|
47
|
+
return (3, None)
|
|
48
|
+
|
|
49
|
+
def lines_0_fully_included_in_1(p0, p1, p2, p3):
|
|
50
|
+
return (2, num.array([p0, p1]))
|
|
51
|
+
|
|
52
|
+
def lines_1_fully_included_in_0(p0, p1, p2, p3):
|
|
53
|
+
return (2, num.array([p2, p3]))
|
|
54
|
+
|
|
55
|
+
def lines_overlap_same_direction(p0, p1, p2, p3):
|
|
56
|
+
return (2, num.array([p0, p3]))
|
|
57
|
+
|
|
58
|
+
def lines_overlap_same_direction2(p0, p1, p2, p3):
|
|
59
|
+
return (2, num.array([p2, p1]))
|
|
60
|
+
|
|
61
|
+
def lines_overlap_opposite_direction(p0, p1, p2, p3):
|
|
62
|
+
return (2, num.array([p0, p2]))
|
|
63
|
+
|
|
64
|
+
def lines_overlap_opposite_direction2(p0, p1, p2, p3):
|
|
65
|
+
return (2, num.array([p3, p1]))
|
|
66
|
+
|
|
67
|
+
# this function called when an impossible state is found
|
|
68
|
+
def lines_error(p1, p2, p3, p4):
|
|
69
|
+
raise RuntimeError, ('INTERNAL ERROR: p1=%s, p2=%s, p3=%s, p4=%s'
|
|
70
|
+
% (str(p1), str(p2), str(p3), str(p4)))
|
|
71
|
+
|
|
72
|
+
collinear_result = {
|
|
73
|
+
# line 0 starts on 1, 0 ends 1, 1 starts 0, 1 ends 0
|
|
74
|
+
# 0s1 0e1 1s0 1e0
|
|
75
|
+
(False, False, False, False): lines_dont_coincide,
|
|
76
|
+
(False, False, False, True ): lines_error,
|
|
77
|
+
(False, False, True, False): lines_error,
|
|
78
|
+
(False, False, True, True ): lines_1_fully_included_in_0,
|
|
79
|
+
(False, True, False, False): lines_error,
|
|
80
|
+
(False, True, False, True ): lines_overlap_opposite_direction2,
|
|
81
|
+
(False, True, True, False): lines_overlap_same_direction2,
|
|
82
|
+
(False, True, True, True ): lines_1_fully_included_in_0,
|
|
83
|
+
(True, False, False, False): lines_error,
|
|
84
|
+
(True, False, False, True ): lines_overlap_same_direction,
|
|
85
|
+
(True, False, True, False): lines_overlap_opposite_direction,
|
|
86
|
+
(True, False, True, True ): lines_1_fully_included_in_0,
|
|
87
|
+
(True, True, False, False): lines_0_fully_included_in_1,
|
|
88
|
+
(True, True, False, True ): lines_0_fully_included_in_1,
|
|
89
|
+
(True, True, True, False): lines_0_fully_included_in_1,
|
|
90
|
+
(True, True, True, True ): lines_0_fully_included_in_1
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
def intersection(line0, line1, rtol=1.0e-5, atol=1.0e-8):
|
|
94
|
+
"""Returns intersecting point between two line segments.
|
|
95
|
+
|
|
96
|
+
However, if parallel lines coincide partly (i.e. share a common segment),
|
|
97
|
+
the line segment where lines coincide is returned
|
|
98
|
+
|
|
99
|
+
Inputs:
|
|
100
|
+
line0, line1: Each defined by two end points as in: [[x0, y0], [x1, y1]]
|
|
101
|
+
A line can also be a 2x2 numpy array with each row
|
|
102
|
+
corresponding to a point.
|
|
103
|
+
|
|
104
|
+
Output:
|
|
105
|
+
status, value - where status and value is interpreted as follows:
|
|
106
|
+
status == 0: no intersection, value set to None.
|
|
107
|
+
status == 1: intersection point found and returned in value as [x,y].
|
|
108
|
+
status == 2: Collinear overlapping lines found.
|
|
109
|
+
Value takes the form [[x0,y0], [x1,y1]].
|
|
110
|
+
status == 3: Collinear non-overlapping lines. Value set to None.
|
|
111
|
+
status == 4: Lines are parallel. Value set to None.
|
|
112
|
+
"""
|
|
113
|
+
|
|
114
|
+
# FIXME (Ole): Write this in C
|
|
115
|
+
|
|
116
|
+
line0 = ensure_numeric(line0, num.float)
|
|
117
|
+
line1 = ensure_numeric(line1, num.float)
|
|
118
|
+
|
|
119
|
+
x0 = line0[0, 0]; y0 = line0[0, 1]
|
|
120
|
+
x1 = line0[1, 0]; y1 = line0[1, 1]
|
|
121
|
+
|
|
122
|
+
x2 = line1[0, 0]; y2 = line1[0, 1]
|
|
123
|
+
x3 = line1[1, 0]; y3 = line1[1, 1]
|
|
124
|
+
|
|
125
|
+
denom = (y3-y2)*(x1-x0) - (x3-x2)*(y1-y0)
|
|
126
|
+
u0 = (x3-x2)*(y0-y2) - (y3-y2)*(x0-x2)
|
|
127
|
+
u1 = (x2-x0)*(y1-y0) - (y2-y0)*(x1-x0)
|
|
128
|
+
|
|
129
|
+
if num.allclose(denom, 0.0, rtol=rtol, atol=atol):
|
|
130
|
+
# Lines are parallel - check if they are collinear
|
|
131
|
+
if num.allclose([u0, u1], 0.0, rtol=rtol, atol=atol):
|
|
132
|
+
# We now know that the lines are collinear
|
|
133
|
+
state_tuple = (point_on_line([x0, y0], line1, rtol=rtol, atol=atol),
|
|
134
|
+
point_on_line([x1, y1], line1, rtol=rtol, atol=atol),
|
|
135
|
+
point_on_line([x2, y2], line0, rtol=rtol, atol=atol),
|
|
136
|
+
point_on_line([x3, y3], line0, rtol=rtol, atol=atol))
|
|
137
|
+
|
|
138
|
+
return collinear_result[state_tuple]([x0, y0], [x1, y1],
|
|
139
|
+
[x2, y2], [x3, y3])
|
|
140
|
+
else:
|
|
141
|
+
# Lines are parallel but aren't collinear
|
|
142
|
+
return 4, None #FIXME (Ole): Add distance here instead of None
|
|
143
|
+
else:
|
|
144
|
+
# Lines are not parallel, check if they intersect
|
|
145
|
+
u0 = u0/denom
|
|
146
|
+
u1 = u1/denom
|
|
147
|
+
|
|
148
|
+
x = x0 + u0*(x1-x0)
|
|
149
|
+
y = y0 + u0*(y1-y0)
|
|
150
|
+
|
|
151
|
+
# Sanity check - can be removed to speed up if needed
|
|
152
|
+
assert num.allclose(x, x2 + u1*(x3-x2), rtol=rtol, atol=atol)
|
|
153
|
+
assert num.allclose(y, y2 + u1*(y3-y2), rtol=rtol, atol=atol)
|
|
154
|
+
|
|
155
|
+
# Check if point found lies within given line segments
|
|
156
|
+
if 0.0 <= u0 <= 1.0 and 0.0 <= u1 <= 1.0:
|
|
157
|
+
# We have intersection
|
|
158
|
+
return 1, num.array([x, y])
|
|
159
|
+
else:
|
|
160
|
+
# No intersection
|
|
161
|
+
return 0, None
|
|
162
|
+
|
|
163
|
+
def NEW_C_intersection(line0, line1):
|
|
164
|
+
"""Returns intersecting point between two line segments.
|
|
165
|
+
|
|
166
|
+
However, if parallel lines coincide partly (i.e. share a common segment),
|
|
167
|
+
the line segment where lines coincide is returned
|
|
168
|
+
|
|
169
|
+
Inputs:
|
|
170
|
+
line0, line1: Each defined by two end points as in: [[x0, y0], [x1, y1]]
|
|
171
|
+
A line can also be a 2x2 numpy array with each row
|
|
172
|
+
corresponding to a point.
|
|
173
|
+
|
|
174
|
+
Output:
|
|
175
|
+
status, value - where status and value is interpreted as follows:
|
|
176
|
+
status == 0: no intersection, value set to None.
|
|
177
|
+
status == 1: intersection point found and returned in value as [x,y].
|
|
178
|
+
status == 2: Collinear overlapping lines found.
|
|
179
|
+
Value takes the form [[x0,y0], [x1,y1]].
|
|
180
|
+
status == 3: Collinear non-overlapping lines. Value set to None.
|
|
181
|
+
status == 4: Lines are parallel. Value set to None.
|
|
182
|
+
"""
|
|
183
|
+
|
|
184
|
+
line0 = ensure_numeric(line0, num.float)
|
|
185
|
+
line1 = ensure_numeric(line1, num.float)
|
|
186
|
+
|
|
187
|
+
status, value = _intersection(line0[0, 0], line0[0, 1],
|
|
188
|
+
line0[1, 0], line0[1, 1],
|
|
189
|
+
line1[0, 0], line1[0, 1],
|
|
190
|
+
line1[1, 0], line1[1, 1])
|
|
191
|
+
|
|
192
|
+
return status, value
|
|
193
|
+
|
|
194
|
+
def polygon_overlap(triangles, polygon, verbose=False):
|
|
195
|
+
"""Determine if a polygon and triangle overlap
|
|
196
|
+
|
|
197
|
+
"""
|
|
198
|
+
polygon = ensure_numeric(polygon)
|
|
199
|
+
triangles = ensure_numeric(triangles)
|
|
200
|
+
|
|
201
|
+
M = triangles.shape[0]/3 # Number of triangles
|
|
202
|
+
|
|
203
|
+
indices = num.zeros(M, num.int)
|
|
204
|
+
|
|
205
|
+
count = _polygon_overlap(polygon, triangles, indices)
|
|
206
|
+
|
|
207
|
+
if verbose:
|
|
208
|
+
log.critical('Found %d triangles (out of %d) that polygon' % (count, M))
|
|
209
|
+
|
|
210
|
+
return indices[:count]
|
|
211
|
+
|
|
212
|
+
def not_polygon_overlap(triangles, polygon, verbose=False):
|
|
213
|
+
"""Determine if a polygon and triangle overlap
|
|
214
|
+
|
|
215
|
+
"""
|
|
216
|
+
polygon = ensure_numeric(polygon)
|
|
217
|
+
triangles = ensure_numeric(triangles)
|
|
218
|
+
|
|
219
|
+
M = triangles.shape[0]/3 # Number of triangles
|
|
220
|
+
|
|
221
|
+
indices = num.zeros(M, num.int)
|
|
222
|
+
|
|
223
|
+
count = _polygon_overlap(polygon, triangles, indices)
|
|
224
|
+
|
|
225
|
+
if verbose:
|
|
226
|
+
log.critical('Found %d triangles (out of %d) that polygon' % (count, M))
|
|
227
|
+
|
|
228
|
+
return indices[count:]
|
|
229
|
+
|
|
230
|
+
def line_intersect(triangles, line, verbose=False):
|
|
231
|
+
"""Determine which of a list of trianglee intersect a line
|
|
232
|
+
|
|
233
|
+
"""
|
|
234
|
+
line = ensure_numeric(line)
|
|
235
|
+
triangles = ensure_numeric(triangles)
|
|
236
|
+
|
|
237
|
+
M = triangles.shape[0]/3 # Number of triangles
|
|
238
|
+
|
|
239
|
+
indices = num.zeros(M, num.int)
|
|
240
|
+
|
|
241
|
+
count = _line_intersect(line, triangles, indices)
|
|
242
|
+
|
|
243
|
+
if verbose:
|
|
244
|
+
log.critical('Found %d triangles (out of %d) that intersect line' % (count, M))
|
|
245
|
+
|
|
246
|
+
return indices[:count]
|
|
247
|
+
|
|
248
|
+
|
|
249
|
+
def line_length(line):
|
|
250
|
+
"""Determine the length of the line
|
|
251
|
+
"""
|
|
252
|
+
|
|
253
|
+
l12 = line[1]-line[0]
|
|
254
|
+
|
|
255
|
+
return math.sqrt(num.dot(l12,l12))
|
|
256
|
+
|
|
257
|
+
def not_line_intersect(triangles, line, verbose=False):
|
|
258
|
+
"""Determine if a polyline and triangle overlap
|
|
259
|
+
|
|
260
|
+
"""
|
|
261
|
+
line = ensure_numeric(line)
|
|
262
|
+
triangles = ensure_numeric(triangles)
|
|
263
|
+
|
|
264
|
+
M = triangles.shape[0]/3 # Number of triangles
|
|
265
|
+
|
|
266
|
+
indices = num.zeros(M, num.int)
|
|
267
|
+
|
|
268
|
+
count = _line_intersect(line, triangles, indices)
|
|
269
|
+
|
|
270
|
+
if verbose:
|
|
271
|
+
log.critical('Found %d triangles (out of %d) that intersect the line' % (count, M))
|
|
272
|
+
|
|
273
|
+
return indices[count:]
|
|
274
|
+
|
|
275
|
+
|
|
276
|
+
def is_inside_triangle(point, triangle,
|
|
277
|
+
closed=True,
|
|
278
|
+
rtol=1.0e-12,
|
|
279
|
+
atol=1.0e-12,
|
|
280
|
+
check_inputs=True):
|
|
281
|
+
"""Determine if one point is inside a triangle
|
|
282
|
+
|
|
283
|
+
This uses the barycentric method:
|
|
284
|
+
|
|
285
|
+
Triangle is A, B, C
|
|
286
|
+
Point P can then be written as
|
|
287
|
+
|
|
288
|
+
P = A + alpha * (C-A) + beta * (B-A)
|
|
289
|
+
or if we let
|
|
290
|
+
v=P-A, v0=C-A, v1=B-A
|
|
291
|
+
|
|
292
|
+
v = alpha*v0 + beta*v1
|
|
293
|
+
|
|
294
|
+
Dot this equation by v0 and v1 to get two:
|
|
295
|
+
|
|
296
|
+
dot(v0, v) = alpha*dot(v0, v0) + beta*dot(v0, v1)
|
|
297
|
+
dot(v1, v) = alpha*dot(v1, v0) + beta*dot(v1, v1)
|
|
298
|
+
|
|
299
|
+
or if a_ij = dot(v_i, v_j) and b_i = dot(v_i, v)
|
|
300
|
+
the matrix equation:
|
|
301
|
+
|
|
302
|
+
a_00 a_01 alpha b_0
|
|
303
|
+
=
|
|
304
|
+
a_10 a_11 beta b_1
|
|
305
|
+
|
|
306
|
+
Solving for alpha and beta yields:
|
|
307
|
+
|
|
308
|
+
alpha = (b_0*a_11 - b_1*a_01)/denom
|
|
309
|
+
beta = (b_1*a_00 - b_0*a_10)/denom
|
|
310
|
+
|
|
311
|
+
with denom = a_11*a_00 - a_10*a_01
|
|
312
|
+
|
|
313
|
+
The point is in the triangle whenever
|
|
314
|
+
alpha and beta and their sums are in the unit interval.
|
|
315
|
+
|
|
316
|
+
rtol and atol will determine how close the point has to be to the edge
|
|
317
|
+
before it is deemed to be on the edge.
|
|
318
|
+
|
|
319
|
+
"""
|
|
320
|
+
|
|
321
|
+
triangle = ensure_numeric(triangle)
|
|
322
|
+
point = ensure_numeric(point, num.float)
|
|
323
|
+
|
|
324
|
+
if check_inputs is True:
|
|
325
|
+
msg = 'is_inside_triangle must be invoked with one point only'
|
|
326
|
+
assert num.allclose(point.shape, [2]), msg
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
# Use C-implementation
|
|
330
|
+
return bool(_is_inside_triangle(point, triangle, int(closed), rtol, atol))
|
|
331
|
+
|
|
332
|
+
def is_complex(polygon, closed=True, verbose=False):
|
|
333
|
+
"""Check if a polygon is complex (self-intersecting).
|
|
334
|
+
Uses a sweep algorithm that is O(n^2) in the worst case, but
|
|
335
|
+
for most normal looking polygons it'll be O(n log n).
|
|
336
|
+
|
|
337
|
+
polygon is a list of points that define a closed polygon.
|
|
338
|
+
verbose will print a list of the intersection points if true
|
|
339
|
+
|
|
340
|
+
Return True if polygon is complex.
|
|
341
|
+
"""
|
|
342
|
+
|
|
343
|
+
def key_xpos(item):
|
|
344
|
+
""" Return the x coord out of the passed point for sorting key. """
|
|
345
|
+
return (item[0][0])
|
|
346
|
+
|
|
347
|
+
def segments_joined(seg0, seg1):
|
|
348
|
+
""" See if there are identical segments in the 2 lists. """
|
|
349
|
+
for i in seg0:
|
|
350
|
+
for j in seg1:
|
|
351
|
+
if i == j: return True
|
|
352
|
+
return False
|
|
353
|
+
|
|
354
|
+
polygon = ensure_numeric(polygon, num.float)
|
|
355
|
+
|
|
356
|
+
# build a list of discrete segments from the polygon
|
|
357
|
+
unsorted_segs = []
|
|
358
|
+
for i in range(0, len(polygon)-1):
|
|
359
|
+
unsorted_segs.append([list(polygon[i]), list(polygon[i+1])])
|
|
360
|
+
|
|
361
|
+
if closed:
|
|
362
|
+
unsorted_segs.append([list(polygon[0]), list(polygon[-1])])
|
|
363
|
+
|
|
364
|
+
# all segments must point in same direction
|
|
365
|
+
for val in unsorted_segs:
|
|
366
|
+
if val[0][0] > val[1][0]:
|
|
367
|
+
val[0], val[1] = val[1], val[0]
|
|
368
|
+
|
|
369
|
+
l_x = sorted(unsorted_segs, key=key_xpos)
|
|
370
|
+
|
|
371
|
+
comparisons = 0
|
|
372
|
+
|
|
373
|
+
# loop through, only comparing lines that partially overlap in x
|
|
374
|
+
for index, leftmost in enumerate(l_x):
|
|
375
|
+
cmp = index+1
|
|
376
|
+
while cmp < len(l_x) and leftmost[1][0] > l_x[cmp][0][0]:
|
|
377
|
+
if not segments_joined(leftmost, l_x[cmp]):
|
|
378
|
+
(type, point) = intersection(leftmost, l_x[cmp])
|
|
379
|
+
comparisons += 1
|
|
380
|
+
if type != 0 and type != 4 and type != 3 or (type == 2 and list(point[0]) !=\
|
|
381
|
+
list(point[1])):
|
|
382
|
+
if verbose:
|
|
383
|
+
print 'Self-intersecting polygon found, type ', type
|
|
384
|
+
print 'point', point,
|
|
385
|
+
print 'vertices: ', leftmost, ' - ', l_x[cmp]
|
|
386
|
+
return True
|
|
387
|
+
cmp += 1
|
|
388
|
+
|
|
389
|
+
return False
|
|
390
|
+
|
|
391
|
+
|
|
392
|
+
def is_inside_polygon(point, polygon, closed=True, verbose=False):
|
|
393
|
+
"""Determine if one point is inside a polygon
|
|
394
|
+
|
|
395
|
+
See inside_polygon for more details
|
|
396
|
+
"""
|
|
397
|
+
|
|
398
|
+
indices = inside_polygon(point, polygon, closed, verbose)
|
|
399
|
+
|
|
400
|
+
if indices.shape[0] == 1:
|
|
401
|
+
return True
|
|
402
|
+
elif indices.shape[0] == 0:
|
|
403
|
+
return False
|
|
404
|
+
else:
|
|
405
|
+
msg = 'is_inside_polygon must be invoked with one point only'
|
|
406
|
+
raise Exception(msg)
|
|
407
|
+
|
|
408
|
+
def inside_polygon(points, polygon, closed=True, verbose=False):
|
|
409
|
+
"""Determine points inside a polygon
|
|
410
|
+
|
|
411
|
+
Functions inside_polygon and outside_polygon have been defined in
|
|
412
|
+
terms of separate_by_polygon which will put all inside indices in
|
|
413
|
+
the first part of the indices array and outside indices in the last
|
|
414
|
+
|
|
415
|
+
See separate_points_by_polygon for documentation
|
|
416
|
+
|
|
417
|
+
points and polygon can be a geospatial instance,
|
|
418
|
+
a list or a numeric array
|
|
419
|
+
"""
|
|
420
|
+
|
|
421
|
+
try:
|
|
422
|
+
points = ensure_absolute(points)
|
|
423
|
+
except NameError, err:
|
|
424
|
+
raise NameError, err
|
|
425
|
+
except:
|
|
426
|
+
# If this fails it is going to be because the points can't be
|
|
427
|
+
# converted to a numeric array.
|
|
428
|
+
msg = 'Points could not be converted to numeric array'
|
|
429
|
+
raise Exception, msg
|
|
430
|
+
|
|
431
|
+
|
|
432
|
+
try:
|
|
433
|
+
polygon = ensure_absolute(polygon)
|
|
434
|
+
except NameError, e:
|
|
435
|
+
raise NameError, e
|
|
436
|
+
except:
|
|
437
|
+
# If this fails it is going to be because the points can't be
|
|
438
|
+
# converted to a numeric array.
|
|
439
|
+
msg = ('Polygon %s could not be converted to numeric array'
|
|
440
|
+
% (str(polygon)))
|
|
441
|
+
raise Exception, msg
|
|
442
|
+
|
|
443
|
+
if len(points.shape) == 1:
|
|
444
|
+
# Only one point was passed in. Convert to array of points
|
|
445
|
+
points = num.reshape(points, (1,2))
|
|
446
|
+
|
|
447
|
+
indices, count = separate_points_by_polygon(points, polygon,
|
|
448
|
+
closed=closed,
|
|
449
|
+
verbose=verbose)
|
|
450
|
+
|
|
451
|
+
# Return indices of points inside polygon
|
|
452
|
+
return indices[:count]
|
|
453
|
+
|
|
454
|
+
def is_outside_polygon(point, polygon, closed=True, verbose=False,
|
|
455
|
+
points_geo_ref=None, polygon_geo_ref=None):
|
|
456
|
+
"""Determine if one point is outside a polygon
|
|
457
|
+
|
|
458
|
+
See outside_polygon for more details
|
|
459
|
+
"""
|
|
460
|
+
|
|
461
|
+
indices = outside_polygon(point, polygon, closed, verbose)
|
|
462
|
+
|
|
463
|
+
if indices.shape[0] == 1:
|
|
464
|
+
return True
|
|
465
|
+
elif indices.shape[0] == 0:
|
|
466
|
+
return False
|
|
467
|
+
else:
|
|
468
|
+
msg = 'is_outside_polygon must be invoked with one point only'
|
|
469
|
+
raise Exception, msg
|
|
470
|
+
|
|
471
|
+
def outside_polygon(points, polygon, closed = True, verbose = False):
|
|
472
|
+
"""Determine points outside a polygon
|
|
473
|
+
|
|
474
|
+
Functions inside_polygon and outside_polygon have been defined in
|
|
475
|
+
terms of separate_by_polygon which will put all inside indices in
|
|
476
|
+
the first part of the indices array and outside indices in the last
|
|
477
|
+
|
|
478
|
+
See separate_points_by_polygon for documentation
|
|
479
|
+
"""
|
|
480
|
+
|
|
481
|
+
try:
|
|
482
|
+
points = ensure_numeric(points, num.float)
|
|
483
|
+
except NameError, e:
|
|
484
|
+
raise NameError, e
|
|
485
|
+
except:
|
|
486
|
+
msg = 'Points could not be converted to numeric array'
|
|
487
|
+
raise Exception, msg
|
|
488
|
+
|
|
489
|
+
try:
|
|
490
|
+
polygon = ensure_numeric(polygon, num.float)
|
|
491
|
+
except NameError, e:
|
|
492
|
+
raise NameError, e
|
|
493
|
+
except:
|
|
494
|
+
msg = 'Polygon could not be converted to numeric array'
|
|
495
|
+
raise Exception, msg
|
|
496
|
+
|
|
497
|
+
if len(points.shape) == 1:
|
|
498
|
+
# Only one point was passed in. Convert to array of points
|
|
499
|
+
points = num.reshape(points, (1, 2))
|
|
500
|
+
|
|
501
|
+
indices, count = separate_points_by_polygon(points, polygon,
|
|
502
|
+
closed=closed,
|
|
503
|
+
verbose=verbose)
|
|
504
|
+
|
|
505
|
+
# Return indices of points outside polygon
|
|
506
|
+
if count == len(indices):
|
|
507
|
+
# No points are outside
|
|
508
|
+
return num.array([])
|
|
509
|
+
else:
|
|
510
|
+
return indices[count:][::-1] #return reversed
|
|
511
|
+
|
|
512
|
+
def in_and_outside_polygon(points, polygon, closed=True, verbose=False):
|
|
513
|
+
"""Determine points inside and outside a polygon
|
|
514
|
+
|
|
515
|
+
See separate_points_by_polygon for documentation
|
|
516
|
+
|
|
517
|
+
Returns an array of points inside and array of points outside the polygon
|
|
518
|
+
"""
|
|
519
|
+
|
|
520
|
+
try:
|
|
521
|
+
points = ensure_numeric(points, num.float)
|
|
522
|
+
except NameError, e:
|
|
523
|
+
raise NameError, e
|
|
524
|
+
except:
|
|
525
|
+
msg = 'Points could not be converted to numeric array'
|
|
526
|
+
raise Exception, msg
|
|
527
|
+
|
|
528
|
+
try:
|
|
529
|
+
polygon = ensure_numeric(polygon, num.float)
|
|
530
|
+
except NameError, e:
|
|
531
|
+
raise NameError, e
|
|
532
|
+
except:
|
|
533
|
+
msg = 'Polygon could not be converted to numeric array'
|
|
534
|
+
raise Exception, msg
|
|
535
|
+
|
|
536
|
+
if len(points.shape) == 1:
|
|
537
|
+
# Only one point was passed in. Convert to array of points
|
|
538
|
+
points = num.reshape(points, (1, 2))
|
|
539
|
+
|
|
540
|
+
indices, count = separate_points_by_polygon(points, polygon,
|
|
541
|
+
closed=closed,
|
|
542
|
+
verbose=verbose)
|
|
543
|
+
|
|
544
|
+
# Returns indices of points inside and indices of points outside
|
|
545
|
+
# the polygon
|
|
546
|
+
if count == len(indices):
|
|
547
|
+
# No points are outside
|
|
548
|
+
return indices[:count], []
|
|
549
|
+
else:
|
|
550
|
+
return indices[:count], indices[count:][::-1] #return reversed
|
|
551
|
+
|
|
552
|
+
|
|
553
|
+
|
|
554
|
+
def separate_points_by_polygon(points, polygon,
|
|
555
|
+
closed=True,
|
|
556
|
+
check_input=True,
|
|
557
|
+
verbose=False):
|
|
558
|
+
"""Determine whether points are inside or outside a polygon
|
|
559
|
+
|
|
560
|
+
Input:
|
|
561
|
+
points - Tuple of (x, y) coordinates, or list of tuples
|
|
562
|
+
polygon - list of vertices of polygon
|
|
563
|
+
closed - (optional) determine whether points on boundary should be
|
|
564
|
+
regarded as belonging to the polygon (closed = True)
|
|
565
|
+
or not (closed = False)
|
|
566
|
+
check_input: Allows faster execution if set to False
|
|
567
|
+
|
|
568
|
+
Outputs:
|
|
569
|
+
indices: array of same length as points with indices of points falling
|
|
570
|
+
inside the polygon listed from the beginning and indices of points
|
|
571
|
+
falling outside listed from the end.
|
|
572
|
+
|
|
573
|
+
count: count of points falling inside the polygon
|
|
574
|
+
|
|
575
|
+
The indices of points inside are obtained as indices[:count]
|
|
576
|
+
The indices of points outside are obtained as indices[count:]
|
|
577
|
+
|
|
578
|
+
Examples:
|
|
579
|
+
U = [[0,0], [1,0], [1,1], [0,1]] #Unit square
|
|
580
|
+
|
|
581
|
+
separate_points_by_polygon( [[0.5, 0.5], [1, -0.5], [0.3, 0.2]], U)
|
|
582
|
+
will return the indices [0, 2, 1] and count == 2 as only the first
|
|
583
|
+
and the last point are inside the unit square
|
|
584
|
+
|
|
585
|
+
Remarks:
|
|
586
|
+
The vertices may be listed clockwise or counterclockwise and
|
|
587
|
+
the first point may optionally be repeated.
|
|
588
|
+
Polygons do not need to be convex.
|
|
589
|
+
Polygons can have holes in them and points inside a hole is
|
|
590
|
+
regarded as being outside the polygon.
|
|
591
|
+
|
|
592
|
+
Algorithm is based on work by Darel Finley,
|
|
593
|
+
http://www.alienryderflex.com/polygon/
|
|
594
|
+
|
|
595
|
+
Uses underlying C-implementation in polygon_ext.c
|
|
596
|
+
"""
|
|
597
|
+
|
|
598
|
+
if check_input:
|
|
599
|
+
#Input checks
|
|
600
|
+
assert isinstance(closed, bool), \
|
|
601
|
+
'Keyword argument "closed" must be boolean'
|
|
602
|
+
assert isinstance(verbose, bool), \
|
|
603
|
+
'Keyword argument "verbose" must be boolean'
|
|
604
|
+
|
|
605
|
+
try:
|
|
606
|
+
points = ensure_numeric(points, num.float)
|
|
607
|
+
except NameError, e:
|
|
608
|
+
raise NameError, e
|
|
609
|
+
except:
|
|
610
|
+
msg = 'Points could not be converted to numeric array'
|
|
611
|
+
raise Exception(msg)
|
|
612
|
+
|
|
613
|
+
try:
|
|
614
|
+
polygon = ensure_numeric(polygon, num.float)
|
|
615
|
+
except NameError, e:
|
|
616
|
+
raise NameError(e)
|
|
617
|
+
except:
|
|
618
|
+
msg = 'Polygon could not be converted to numeric array'
|
|
619
|
+
raise Exception(msg)
|
|
620
|
+
|
|
621
|
+
msg = 'Polygon array must be a 2d array of vertices'
|
|
622
|
+
assert len(polygon.shape) == 2, msg
|
|
623
|
+
|
|
624
|
+
msg = 'Polygon array must have two columns'
|
|
625
|
+
assert polygon.shape[1] == 2, msg
|
|
626
|
+
|
|
627
|
+
|
|
628
|
+
msg = ('Points array must be 1 or 2 dimensional. '
|
|
629
|
+
'I got %d dimensions' % len(points.shape))
|
|
630
|
+
assert 0 < len(points.shape) < 3, msg
|
|
631
|
+
|
|
632
|
+
if len(points.shape) == 1:
|
|
633
|
+
# Only one point was passed in. Convert to array of points.
|
|
634
|
+
points = num.reshape(points, (1, 2))
|
|
635
|
+
|
|
636
|
+
msg = ('Point array must have two columns (x,y), '
|
|
637
|
+
'I got points.shape[1]=%d' % points.shape[0])
|
|
638
|
+
assert points.shape[1]==2, msg
|
|
639
|
+
|
|
640
|
+
|
|
641
|
+
msg = ('Points array must be a 2d array. I got %s.'
|
|
642
|
+
% str(points[:30]))
|
|
643
|
+
assert len(points.shape) == 2, msg
|
|
644
|
+
|
|
645
|
+
msg = 'Points array must have two columns'
|
|
646
|
+
assert points.shape[1] == 2, msg
|
|
647
|
+
|
|
648
|
+
N = polygon.shape[0] # Number of vertices in polygon
|
|
649
|
+
M = points.shape[0] # Number of points
|
|
650
|
+
|
|
651
|
+
indices = num.zeros(M, num.int)
|
|
652
|
+
|
|
653
|
+
count = _separate_points_by_polygon(points, polygon, indices,
|
|
654
|
+
int(closed), int(verbose))
|
|
655
|
+
|
|
656
|
+
if verbose:
|
|
657
|
+
log.critical('Found %d points (out of %d) inside polygon' % (count, M))
|
|
658
|
+
|
|
659
|
+
return indices, count
|
|
660
|
+
|
|
661
|
+
|
|
662
|
+
def polygon_area(input_polygon):
|
|
663
|
+
""" Determine area of arbitrary polygon.
|
|
664
|
+
|
|
665
|
+
input_polygon The polygon to get area of.
|
|
666
|
+
|
|
667
|
+
return A scalar value for the polygon area.
|
|
668
|
+
|
|
669
|
+
Reference: http://mathworld.wolfram.com/PolygonArea.html
|
|
670
|
+
"""
|
|
671
|
+
# Move polygon to origin (0,0) to avoid rounding errors
|
|
672
|
+
# This makes a copy of the polygon to avoid destroying it
|
|
673
|
+
input_polygon = ensure_numeric(input_polygon)
|
|
674
|
+
min_x = min(input_polygon[:, 0])
|
|
675
|
+
min_y = min(input_polygon[:, 1])
|
|
676
|
+
polygon = input_polygon - [min_x, min_y]
|
|
677
|
+
|
|
678
|
+
# Compute area
|
|
679
|
+
n = len(polygon)
|
|
680
|
+
poly_area = 0.0
|
|
681
|
+
|
|
682
|
+
for i in range(n):
|
|
683
|
+
pti = polygon[i]
|
|
684
|
+
if i == n-1:
|
|
685
|
+
pt1 = polygon[0]
|
|
686
|
+
else:
|
|
687
|
+
pt1 = polygon[i+1]
|
|
688
|
+
xi = pti[0]
|
|
689
|
+
yi1 = pt1[1]
|
|
690
|
+
xi1 = pt1[0]
|
|
691
|
+
yi = pti[1]
|
|
692
|
+
poly_area += xi*yi1 - xi1*yi
|
|
693
|
+
|
|
694
|
+
return abs(poly_area/2)
|
|
695
|
+
|
|
696
|
+
|
|
697
|
+
def plot_polygons(polygons_points,
|
|
698
|
+
style=None,
|
|
699
|
+
figname=None,
|
|
700
|
+
label=None,
|
|
701
|
+
alpha=None):
|
|
702
|
+
""" Take list of polygons and plot.
|
|
703
|
+
|
|
704
|
+
Inputs:
|
|
705
|
+
|
|
706
|
+
polygons - list of polygons
|
|
707
|
+
|
|
708
|
+
style - style list corresponding to each polygon
|
|
709
|
+
- for a polygon, use 'line'
|
|
710
|
+
- for points falling outside a polygon, use 'outside'
|
|
711
|
+
- style can also be user defined as in normal pylab plot.
|
|
712
|
+
|
|
713
|
+
figname - name to save figure to
|
|
714
|
+
|
|
715
|
+
label - title for plotA
|
|
716
|
+
|
|
717
|
+
alpha - transparency of polygon fill, 0.0=none, 1.0=solid
|
|
718
|
+
if not supplied, no fill.
|
|
719
|
+
|
|
720
|
+
Outputs:
|
|
721
|
+
|
|
722
|
+
- plot of polygons
|
|
723
|
+
"""
|
|
724
|
+
|
|
725
|
+
|
|
726
|
+
|
|
727
|
+
try:
|
|
728
|
+
import matplotlib
|
|
729
|
+
matplotlib.use('Agg')
|
|
730
|
+
from matplotlib.pyplot import hold, plot, savefig, xlabel, \
|
|
731
|
+
ylabel, title, close, title, fill
|
|
732
|
+
except:
|
|
733
|
+
return
|
|
734
|
+
|
|
735
|
+
assert type(polygons_points) == list, \
|
|
736
|
+
'input must be a list of polygons and/or points'
|
|
737
|
+
|
|
738
|
+
#ion()
|
|
739
|
+
hold(True)
|
|
740
|
+
|
|
741
|
+
if label is None:
|
|
742
|
+
label = ''
|
|
743
|
+
|
|
744
|
+
# clamp alpha to sensible range
|
|
745
|
+
if alpha:
|
|
746
|
+
try:
|
|
747
|
+
alpha = float(alpha)
|
|
748
|
+
except ValueError:
|
|
749
|
+
alpha = None
|
|
750
|
+
else:
|
|
751
|
+
alpha = max(0.0, min(1.0, alpha))
|
|
752
|
+
|
|
753
|
+
num_points = len(polygons_points)
|
|
754
|
+
colour = []
|
|
755
|
+
if style is None:
|
|
756
|
+
style_type = 'line'
|
|
757
|
+
style = []
|
|
758
|
+
for i in range(num_points):
|
|
759
|
+
style.append(style_type)
|
|
760
|
+
colour.append('b-')
|
|
761
|
+
else:
|
|
762
|
+
for style_name in style:
|
|
763
|
+
if style_name == 'line':
|
|
764
|
+
colour.append('b-')
|
|
765
|
+
if style_name == 'outside':
|
|
766
|
+
colour.append('r.')
|
|
767
|
+
if style_name == 'point':
|
|
768
|
+
colour.append('g.')
|
|
769
|
+
if style_name not in ['line', 'outside', 'point']:
|
|
770
|
+
colour.append(style_name)
|
|
771
|
+
|
|
772
|
+
for i, item in enumerate(polygons_points):
|
|
773
|
+
pt_x, pt_y = _poly_xy(item)
|
|
774
|
+
plot(pt_x, pt_y, colour[i])
|
|
775
|
+
if alpha:
|
|
776
|
+
fill(pt_x, pt_y, colour[i], alpha=alpha)
|
|
777
|
+
xlabel('x')
|
|
778
|
+
ylabel('y')
|
|
779
|
+
title(label)
|
|
780
|
+
|
|
781
|
+
if figname is not None:
|
|
782
|
+
savefig(figname)
|
|
783
|
+
else:
|
|
784
|
+
savefig('test_image')
|
|
785
|
+
|
|
786
|
+
#ioff()
|
|
787
|
+
hold(False)
|
|
788
|
+
|
|
789
|
+
close('all')
|
|
790
|
+
|
|
791
|
+
|
|
792
|
+
def _poly_xy(polygon):
|
|
793
|
+
""" this is used within plot_polygons so need to duplicate
|
|
794
|
+
the first point so can have closed polygon in plot
|
|
795
|
+
|
|
796
|
+
polygon A set of points defining a polygon.
|
|
797
|
+
verbose True if this function is to be verbose.
|
|
798
|
+
|
|
799
|
+
Returns a tuple (x, y) of X and Y coordinates of the polygon.
|
|
800
|
+
We duplicate the first point so can have closed polygon in plot.
|
|
801
|
+
"""
|
|
802
|
+
|
|
803
|
+
try:
|
|
804
|
+
polygon = ensure_numeric(polygon, num.float)
|
|
805
|
+
except NameError, err:
|
|
806
|
+
raise NameError, err
|
|
807
|
+
except:
|
|
808
|
+
msg = ('Polygon %s could not be converted to numeric array'
|
|
809
|
+
% (str(polygon)))
|
|
810
|
+
raise Exception, msg
|
|
811
|
+
|
|
812
|
+
pts_x = num.concatenate((polygon[:, 0], [polygon[0, 0]]), axis = 0)
|
|
813
|
+
pts_y = num.concatenate((polygon[:, 1], [polygon[0, 1]]), axis = 0)
|
|
814
|
+
|
|
815
|
+
return pts_x, pts_y
|
|
816
|
+
|
|
817
|
+
|
|
818
|
+
################################################################################
|
|
819
|
+
# Functions to read and write polygon information
|
|
820
|
+
################################################################################
|
|
821
|
+
|
|
822
|
+
def read_polygon(filename, delimiter=',', closed=True, verbose=False):
|
|
823
|
+
""" Read points assumed to form a (closed) polygon.
|
|
824
|
+
Can also be used to read in a polyline (closed=False)
|
|
825
|
+
|
|
826
|
+
Also checks to make sure polygon (polyline)
|
|
827
|
+
is not complex (self-intersecting).
|
|
828
|
+
|
|
829
|
+
filename Path to file containing polygon data.
|
|
830
|
+
delimiter Delimiter to split polygon data with.
|
|
831
|
+
A list of point data from the polygon file.
|
|
832
|
+
|
|
833
|
+
There must be exactly two numbers in each line
|
|
834
|
+
separated by the delimiter.
|
|
835
|
+
No header.
|
|
836
|
+
"""
|
|
837
|
+
|
|
838
|
+
fid = open(filename)
|
|
839
|
+
lines = fid.readlines()
|
|
840
|
+
fid.close()
|
|
841
|
+
polygon = []
|
|
842
|
+
for line in lines:
|
|
843
|
+
fields = line.split(delimiter)
|
|
844
|
+
polygon.append([float(fields[0]), float(fields[1])])
|
|
845
|
+
|
|
846
|
+
# check this is a valid polygon (polyline).
|
|
847
|
+
if is_complex(polygon, closed, verbose=verbose):
|
|
848
|
+
msg = 'ERROR: Self-intersecting polygon detected in file '
|
|
849
|
+
msg += filename +'. A complex polygon will not '
|
|
850
|
+
msg += 'necessarily break the algorithms within ANUGA, but it'
|
|
851
|
+
msg += 'usually signifies pathological data. Please fix this file.'
|
|
852
|
+
raise Exception, msg
|
|
853
|
+
|
|
854
|
+
return polygon
|
|
855
|
+
|
|
856
|
+
|
|
857
|
+
def write_polygon(polygon, filename=None):
|
|
858
|
+
"""Write polygon to csv file.
|
|
859
|
+
|
|
860
|
+
There will be exactly two numbers, easting and northing, in each line
|
|
861
|
+
separated by a comma.
|
|
862
|
+
|
|
863
|
+
No header.
|
|
864
|
+
"""
|
|
865
|
+
|
|
866
|
+
fid = open(filename, 'w')
|
|
867
|
+
for point in polygon:
|
|
868
|
+
fid.write('%f, %f\n' % point)
|
|
869
|
+
fid.close()
|
|
870
|
+
|
|
871
|
+
|
|
872
|
+
def populate_polygon(polygon, number_of_points, seed=None, exclude=None):
|
|
873
|
+
"""Populate given polygon with uniformly distributed points.
|
|
874
|
+
|
|
875
|
+
Input:
|
|
876
|
+
polygon - list of vertices of polygon
|
|
877
|
+
number_of_points - (optional) number of points
|
|
878
|
+
seed - seed for random number generator (default=None)
|
|
879
|
+
exclude - list of polygons (inside main polygon) from where points
|
|
880
|
+
should be excluded
|
|
881
|
+
|
|
882
|
+
Output:
|
|
883
|
+
points - list of points inside polygon
|
|
884
|
+
|
|
885
|
+
Examples:
|
|
886
|
+
populate_polygon( [[0,0], [1,0], [1,1], [0,1]], 5 )
|
|
887
|
+
will return five randomly selected points inside the unit square
|
|
888
|
+
"""
|
|
889
|
+
|
|
890
|
+
from random import uniform, seed as seed_function
|
|
891
|
+
|
|
892
|
+
seed_function(seed)
|
|
893
|
+
|
|
894
|
+
points = []
|
|
895
|
+
|
|
896
|
+
# Find outer extent of polygon
|
|
897
|
+
extents = AABB(polygon)
|
|
898
|
+
|
|
899
|
+
while len(points) < number_of_points:
|
|
900
|
+
rand_x = uniform(extents.xmin, extents.xmax)
|
|
901
|
+
rand_y = uniform(extents.ymin, extents.ymax)
|
|
902
|
+
|
|
903
|
+
append = False
|
|
904
|
+
if is_inside_polygon([rand_x, rand_y], polygon):
|
|
905
|
+
append = True
|
|
906
|
+
|
|
907
|
+
#Check exclusions
|
|
908
|
+
if exclude is not None:
|
|
909
|
+
for ex_poly in exclude:
|
|
910
|
+
if is_inside_polygon([rand_x, rand_y], ex_poly):
|
|
911
|
+
append = False
|
|
912
|
+
|
|
913
|
+
if append is True:
|
|
914
|
+
points.append([rand_x, rand_y])
|
|
915
|
+
|
|
916
|
+
return points
|
|
917
|
+
|
|
918
|
+
|
|
919
|
+
def point_in_polygon(polygon, delta=1e-8):
|
|
920
|
+
"""Return a point inside a given polygon which will be close to the
|
|
921
|
+
polygon edge.
|
|
922
|
+
|
|
923
|
+
Input:
|
|
924
|
+
polygon - list of vertices of polygon
|
|
925
|
+
delta - the square root of 2 * delta is the maximum distance from the
|
|
926
|
+
polygon points and the returned point.
|
|
927
|
+
Output:
|
|
928
|
+
points - a point inside polygon
|
|
929
|
+
|
|
930
|
+
searches in all diagonals and up and down (not left and right).
|
|
931
|
+
"""
|
|
932
|
+
|
|
933
|
+
polygon = ensure_numeric(polygon)
|
|
934
|
+
|
|
935
|
+
while True:
|
|
936
|
+
for poly_point in polygon:
|
|
937
|
+
for x_mult in range(-1, 2):
|
|
938
|
+
for y_mult in range(-1, 2):
|
|
939
|
+
pt_x, pt_y = poly_point
|
|
940
|
+
|
|
941
|
+
if pt_x == 0:
|
|
942
|
+
x_delta = x_mult * delta
|
|
943
|
+
else:
|
|
944
|
+
x_delta = pt_x + x_mult*pt_x*delta
|
|
945
|
+
|
|
946
|
+
if pt_y == 0:
|
|
947
|
+
y_delta = y_mult * delta
|
|
948
|
+
else:
|
|
949
|
+
y_delta = pt_y + y_mult*pt_y*delta
|
|
950
|
+
|
|
951
|
+
point = [x_delta, y_delta]
|
|
952
|
+
|
|
953
|
+
if is_inside_polygon(point, polygon, closed=False):
|
|
954
|
+
return point
|
|
955
|
+
delta = delta * 0.1
|
|
956
|
+
|
|
957
|
+
|
|
958
|
+
def number_mesh_triangles(interior_regions, bounding_poly, remainder_res):
|
|
959
|
+
"""Calculate the approximate number of triangles inside the
|
|
960
|
+
bounding polygon and the other interior regions
|
|
961
|
+
|
|
962
|
+
Polygon areas are converted to square Kms
|
|
963
|
+
|
|
964
|
+
FIXME: Add tests for this function
|
|
965
|
+
"""
|
|
966
|
+
|
|
967
|
+
# TO DO check if any of the regions fall inside one another
|
|
968
|
+
|
|
969
|
+
log.info('-' * 80)
|
|
970
|
+
log.info('Polygon Max triangle area (m^2) Total area (km^2) '
|
|
971
|
+
'Estimated #triangles')
|
|
972
|
+
log.info('-' * 80)
|
|
973
|
+
|
|
974
|
+
no_triangles = 0.0
|
|
975
|
+
area = polygon_area(bounding_poly)
|
|
976
|
+
|
|
977
|
+
for poly, resolution in interior_regions:
|
|
978
|
+
this_area = polygon_area(poly)
|
|
979
|
+
this_triangles = this_area/resolution
|
|
980
|
+
no_triangles += this_triangles
|
|
981
|
+
area -= this_area
|
|
982
|
+
|
|
983
|
+
log.info('Interior %s%s%d'
|
|
984
|
+
% (('%.0f' % resolution).ljust(25),
|
|
985
|
+
('%.2f' % (this_area/1000000)).ljust(19),
|
|
986
|
+
this_triangles))
|
|
987
|
+
|
|
988
|
+
bound_triangles = area/remainder_res
|
|
989
|
+
no_triangles += bound_triangles
|
|
990
|
+
|
|
991
|
+
log.info('Bounding %s%s%d'
|
|
992
|
+
% (('%.0f' % remainder_res).ljust(25),
|
|
993
|
+
('%.2f' % (area/1000000)).ljust(19),
|
|
994
|
+
bound_triangles))
|
|
995
|
+
|
|
996
|
+
total_number_of_triangles = no_triangles/0.7
|
|
997
|
+
|
|
998
|
+
log.info('Estimated total number of triangles: %d'
|
|
999
|
+
% total_number_of_triangles)
|
|
1000
|
+
log.info('Note: This is generally about 20% less than the final amount')
|
|
1001
|
+
|
|
1002
|
+
return int(total_number_of_triangles)
|
|
1003
|
+
|
|
1004
|
+
|
|
1005
|
+
def decimate_polygon(polygon, factor=10):
|
|
1006
|
+
"""Reduce number of points in polygon by the specified
|
|
1007
|
+
factor (default=10, hence the name of the function) such that
|
|
1008
|
+
the extrema in both axes are preserved.
|
|
1009
|
+
|
|
1010
|
+
Reduce number of points in polygon by the specified factor.
|
|
1011
|
+
polygon The polygon to reduce.
|
|
1012
|
+
factor The factor to reduce polygon points by (default 10).
|
|
1013
|
+
|
|
1014
|
+
The extrema of both axes are preserved.
|
|
1015
|
+
|
|
1016
|
+
Return reduced polygon
|
|
1017
|
+
"""
|
|
1018
|
+
|
|
1019
|
+
# FIXME(Ole): This doesn't work at present,
|
|
1020
|
+
# but it isn't critical either
|
|
1021
|
+
|
|
1022
|
+
# Find outer extent of polygon
|
|
1023
|
+
num_polygon = ensure_numeric(polygon)
|
|
1024
|
+
max_x = max(num_polygon[:, 0])
|
|
1025
|
+
max_y = max(num_polygon[:, 1])
|
|
1026
|
+
min_x = min(num_polygon[:, 0])
|
|
1027
|
+
min_y = min(num_polygon[:, 1])
|
|
1028
|
+
|
|
1029
|
+
# Keep only some points making sure extrema are kept
|
|
1030
|
+
reduced_polygon = []
|
|
1031
|
+
for i, point in enumerate(polygon):
|
|
1032
|
+
if point[0] in [min_x, max_x] and point[1] in [min_y, max_y]:
|
|
1033
|
+
# Keep
|
|
1034
|
+
reduced_polygon.append(point)
|
|
1035
|
+
else:
|
|
1036
|
+
if len(reduced_polygon)*factor < i:
|
|
1037
|
+
reduced_polygon.append(point)
|
|
1038
|
+
|
|
1039
|
+
return reduced_polygon
|
|
1040
|
+
|
|
1041
|
+
|
|
1042
|
+
def interpolate_polyline(data,
|
|
1043
|
+
polyline_nodes,
|
|
1044
|
+
gauge_neighbour_id,
|
|
1045
|
+
interpolation_points=None,
|
|
1046
|
+
rtol=1.0e-6,
|
|
1047
|
+
atol=1.0e-8):
|
|
1048
|
+
"""Interpolate linearly between values data on polyline nodes
|
|
1049
|
+
of a polyline to list of interpolation points.
|
|
1050
|
+
|
|
1051
|
+
data is the data on the polyline nodes.
|
|
1052
|
+
|
|
1053
|
+
Inputs:
|
|
1054
|
+
data: Vector or array of data at the polyline nodes.
|
|
1055
|
+
polyline_nodes: Location of nodes where data is available.
|
|
1056
|
+
gauge_neighbour_id: ?
|
|
1057
|
+
interpolation_points: Interpolate polyline data to these positions.
|
|
1058
|
+
List of coordinate pairs [x, y] of
|
|
1059
|
+
data points or an nx2 numeric array or a Geospatial_data object
|
|
1060
|
+
rtol, atol: Used to determine whether a point is on the polyline or not.
|
|
1061
|
+
See point_on_line.
|
|
1062
|
+
|
|
1063
|
+
Output:
|
|
1064
|
+
Interpolated values at interpolation points
|
|
1065
|
+
"""
|
|
1066
|
+
|
|
1067
|
+
if isinstance(interpolation_points, Geospatial_data):
|
|
1068
|
+
interpolation_points = interpolation_points.\
|
|
1069
|
+
get_data_points(absolute=True)
|
|
1070
|
+
|
|
1071
|
+
interpolated_values = num.zeros(len(interpolation_points), num.float)
|
|
1072
|
+
|
|
1073
|
+
data = ensure_numeric(data, num.float)
|
|
1074
|
+
polyline_nodes = ensure_numeric(polyline_nodes, num.float)
|
|
1075
|
+
interpolation_points = ensure_numeric(interpolation_points, num.float)
|
|
1076
|
+
gauge_neighbour_id = ensure_numeric(gauge_neighbour_id, num.int)
|
|
1077
|
+
|
|
1078
|
+
num_nodes = polyline_nodes.shape[0] # Number of nodes in polyline
|
|
1079
|
+
|
|
1080
|
+
# Input sanity check
|
|
1081
|
+
assert_msg = 'interpolation_points are not given (interpolate.py)'
|
|
1082
|
+
assert interpolation_points is not None, assert_msg
|
|
1083
|
+
|
|
1084
|
+
assert_msg = 'function value must be specified at every interpolation node'
|
|
1085
|
+
assert data.shape[0] == polyline_nodes.shape[0], assert_msg
|
|
1086
|
+
|
|
1087
|
+
assert_msg = 'Must define function value at one or more nodes'
|
|
1088
|
+
assert data.shape[0] > 0, assert_msg
|
|
1089
|
+
|
|
1090
|
+
if num_nodes == 1:
|
|
1091
|
+
assert_msg = 'Polyline contained only one point. I need more. '
|
|
1092
|
+
assert_msg += str(data)
|
|
1093
|
+
raise Exception, assert_msg
|
|
1094
|
+
elif num_nodes > 1:
|
|
1095
|
+
_interpolate_polyline(data,
|
|
1096
|
+
polyline_nodes,
|
|
1097
|
+
gauge_neighbour_id,
|
|
1098
|
+
interpolation_points,
|
|
1099
|
+
interpolated_values,
|
|
1100
|
+
rtol,
|
|
1101
|
+
atol)
|
|
1102
|
+
|
|
1103
|
+
|
|
1104
|
+
return interpolated_values
|
|
1105
|
+
|
|
1106
|
+
|
|
1107
|
+
def polylist2points_verts(polylist):
|
|
1108
|
+
""" Convert a list of polygons to discrete points and vertices.
|
|
1109
|
+
"""
|
|
1110
|
+
|
|
1111
|
+
offset = 0
|
|
1112
|
+
points = []
|
|
1113
|
+
vertices = []
|
|
1114
|
+
for poly in polylist:
|
|
1115
|
+
points.extend(poly)
|
|
1116
|
+
vertices.extend([[i, i+1] for i in range(offset, offset+len(poly)-1)])
|
|
1117
|
+
offset += len(poly)
|
|
1118
|
+
|
|
1119
|
+
return points, vertices
|
|
1120
|
+
|
|
1121
|
+
|
|
1122
|
+
################################################################################
|
|
1123
|
+
# Initialise module
|
|
1124
|
+
################################################################################
|
|
1125
|
+
|
|
1126
|
+
from polygon_ext import _point_on_line
|
|
1127
|
+
from polygon_ext import _separate_points_by_polygon
|
|
1128
|
+
from polygon_ext import _interpolate_polyline
|
|
1129
|
+
from polygon_ext import _polygon_overlap
|
|
1130
|
+
from polygon_ext import _line_intersect
|
|
1131
|
+
from polygon_ext import _is_inside_triangle
|
|
1132
|
+
#from polygon_ext import _intersection
|
|
1133
|
+
|
|
1134
|
+
|
|
1135
|
+
|
|
1136
|
+
|
|
1137
|
+
if __name__ == "__main__":
|
|
1138
|
+
pass
|