topologicpy 0.4.73__py3-none-any.whl → 0.4.74__py3-none-any.whl
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.
- topologicpy/CellComplex.py +66 -0
- topologicpy/__init__.py +1 -1
- {topologicpy-0.4.73.dist-info → topologicpy-0.4.74.dist-info}/METADATA +1 -1
- {topologicpy-0.4.73.dist-info → topologicpy-0.4.74.dist-info}/RECORD +7 -7
- {topologicpy-0.4.73.dist-info → topologicpy-0.4.74.dist-info}/LICENSE +0 -0
- {topologicpy-0.4.73.dist-info → topologicpy-0.4.74.dist-info}/WHEEL +0 -0
- {topologicpy-0.4.73.dist-info → topologicpy-0.4.74.dist-info}/top_level.txt +0 -0
    
        topologicpy/CellComplex.py
    CHANGED
    
    | @@ -967,7 +967,73 @@ class CellComplex(Topology): | |
| 967 967 | 
             
                        if not volume == None:
         | 
| 968 968 | 
             
                            volume += Cell.Volume(cell)
         | 
| 969 969 | 
             
                    return round(volume, mantissa)
         | 
| 970 | 
            +
                
         | 
| 971 | 
            +
                @staticmethod
         | 
| 972 | 
            +
                def Voronoi(vertices: list, cell: topologic.Cell = None, tolerance: float = 0.0001):
         | 
| 973 | 
            +
                    """
         | 
| 974 | 
            +
                    Partitions the input cell based on the Voronoi method. See https://en.wikipedia.org/wiki/Voronoi_diagram.
         | 
| 975 | 
            +
             | 
| 976 | 
            +
                    Parameters
         | 
| 977 | 
            +
                    ----------
         | 
| 978 | 
            +
                    vertices: list
         | 
| 979 | 
            +
                        The input list of vertices to use for voronoi partitioning.
         | 
| 980 | 
            +
                    cell : topologic.Cell , optional
         | 
| 981 | 
            +
                        The input cell. If set to None, an axes-aligned bounding cell is created from the list of vertices. The default is None.
         | 
| 982 | 
            +
                    tolerance : float , optional
         | 
| 983 | 
            +
                        the desired tolerance. The default is 0.0001.
         | 
| 984 | 
            +
                    
         | 
| 970 985 |  | 
| 986 | 
            +
                    Returns
         | 
| 987 | 
            +
                    -------
         | 
| 988 | 
            +
                    float
         | 
| 989 | 
            +
                        The volume of the input cellComplex.
         | 
| 990 | 
            +
             | 
| 991 | 
            +
                    """
         | 
| 992 | 
            +
                    from topologicpy.Vertex import Vertex
         | 
| 993 | 
            +
                    from topologicpy.Face import Face
         | 
| 994 | 
            +
                    from topologicpy.Cell import Cell
         | 
| 995 | 
            +
                    from topologicpy.Cluster import Cluster
         | 
| 996 | 
            +
                    from topologicpy.Topology import Topology
         | 
| 997 | 
            +
                    from scipy.spatial import Voronoi as SCIVoronoi
         | 
| 998 | 
            +
                    import numpy as np
         | 
| 999 | 
            +
             | 
| 1000 | 
            +
                    def fracture_with_voronoi(points):
         | 
| 1001 | 
            +
                        # Compute Voronoi tessellation
         | 
| 1002 | 
            +
                        vor = SCIVoronoi(points)
         | 
| 1003 | 
            +
                        verts = []
         | 
| 1004 | 
            +
                        faces = []
         | 
| 1005 | 
            +
                        for v in vor.vertices:
         | 
| 1006 | 
            +
                            verts.append(Vertex.ByCoordinates(list(v)))
         | 
| 1007 | 
            +
                        for region in vor.ridge_vertices:
         | 
| 1008 | 
            +
                            temp_list = []
         | 
| 1009 | 
            +
                            if -1 not in region and len(region) > 0:
         | 
| 1010 | 
            +
                                for item in region:
         | 
| 1011 | 
            +
                                    temp_list.append(verts[item])
         | 
| 1012 | 
            +
                                f = Face.ByVertices(temp_list)
         | 
| 1013 | 
            +
                                if isinstance(f, topologic.Face):
         | 
| 1014 | 
            +
                                    faces.append(f)
         | 
| 1015 | 
            +
                        return Cluster.ByTopologies(faces)
         | 
| 1016 | 
            +
                    
         | 
| 1017 | 
            +
             | 
| 1018 | 
            +
                    if cell == None:
         | 
| 1019 | 
            +
                        cell = Topology.BoundingBox(Cluster.ByTopologies(vertices))
         | 
| 1020 | 
            +
                    if not isinstance(cell, topologic.Cell):
         | 
| 1021 | 
            +
                        print("CellComplex.Voronoi - Error: The input cell parameter is not a valid cell. Returning None.")
         | 
| 1022 | 
            +
                        return None
         | 
| 1023 | 
            +
                    vertices = [v for v in vertices if Cell.IsInternal(cell, v)]
         | 
| 1024 | 
            +
                    if len(vertices) < 1:
         | 
| 1025 | 
            +
                        print("CellComplex.Voronoi - Error: The input vertices paramter does not contain any vertices that are inside the input cell parameter. Returning None.")
         | 
| 1026 | 
            +
                        return None
         | 
| 1027 | 
            +
                    cell_vertices = Topology.Vertices(cell)
         | 
| 1028 | 
            +
                    all_vertices = cell_vertices + vertices
         | 
| 1029 | 
            +
                    voronoi_points = np.array([Vertex.Coordinates(v) for v in all_vertices])
         | 
| 1030 | 
            +
                    cluster = fracture_with_voronoi(voronoi_points)
         | 
| 1031 | 
            +
                    cellComplex = Topology.Slice(cell, cluster)
         | 
| 1032 | 
            +
                    if not isinstance(cellComplex, topologic.CellComplex):
         | 
| 1033 | 
            +
                        print("CellComplex.Voronoi - Error: the operation failed. Returning None.")
         | 
| 1034 | 
            +
                        return None
         | 
| 1035 | 
            +
                    return cellComplex
         | 
| 1036 | 
            +
                
         | 
| 971 1037 | 
             
                @staticmethod
         | 
| 972 1038 | 
             
                def Wires(cellComplex: topologic.CellComplex) -> list:
         | 
| 973 1039 | 
             
                    """
         | 
    
        topologicpy/__init__.py
    CHANGED
    
    
| @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            Metadata-Version: 2.1
         | 
| 2 2 | 
             
            Name: topologicpy
         | 
| 3 | 
            -
            Version: 0.4. | 
| 3 | 
            +
            Version: 0.4.74
         | 
| 4 4 | 
             
            Summary: An Advanced Spatial Modelling and Analysis Software Library for Architecture, Engineering, and Construction.
         | 
| 5 5 | 
             
            Author-email: Wassim Jabi <wassim.jabi@gmail.com>
         | 
| 6 6 | 
             
            Project-URL: Homepage, https://github.com/wassimj/TopologicPy
         | 
| @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            topologicpy/Aperture.py,sha256=vENYlFaM6Pu-xCJB1YsW1I1_u5yDj-A70aU3bo3lpFA,2819
         | 
| 2 2 | 
             
            topologicpy/Cell.py,sha256=91vG1L65RjBFSZZ9GA9ZCXUyCY60No9SLQvEeX17mhY,93138
         | 
| 3 | 
            -
            topologicpy/CellComplex.py,sha256= | 
| 3 | 
            +
            topologicpy/CellComplex.py,sha256=63k_5FBlMJDZUD5xtYiAGl2-azqcZ_vNVNL7-RUoMK0,43855
         | 
| 4 4 | 
             
            topologicpy/Cluster.py,sha256=AVKUayG0wCAEWTI_aLE7i0CvllpaVDEsU7Z_PgAQ1M8,52831
         | 
| 5 5 | 
             
            topologicpy/Color.py,sha256=8G7dI0CKNMPwhL0658LfmUJt-Ud-6o7xfem_laoi9vQ,10473
         | 
| 6 6 | 
             
            topologicpy/Context.py,sha256=bgwslZSu8Ijuz3fusdhP6XcDnCdwGhtbI0-uhVjB36U,2977
         | 
| @@ -23,7 +23,7 @@ topologicpy/Topology.py,sha256=zjGBxnVvlx8-7EARFgnIpD49nVfdDAyYKoHuABWHLgU,28614 | |
| 23 23 | 
             
            topologicpy/Vector.py,sha256=g28SO3yggTfYfpGqjE-dXpk1loQb9ZaZvP12B7Fzdcw,19564
         | 
| 24 24 | 
             
            topologicpy/Vertex.py,sha256=A7hCI-WpHaemow4eDiaqVhZ0ekgifXcWFpa-82txwYM,55187
         | 
| 25 25 | 
             
            topologicpy/Wire.py,sha256=gMqOqNOmph2Elup6j8bNrorBZfCScVChjTvq03rB6NA,133812
         | 
| 26 | 
            -
            topologicpy/__init__.py,sha256= | 
| 26 | 
            +
            topologicpy/__init__.py,sha256=xPdxZJULDEpfOS3-Tcde50M9q_83JNmpE9PDAL5jskI,1445
         | 
| 27 27 | 
             
            topologicpy/bin/linux/topologic/__init__.py,sha256=XlFReDf3FWlYdM9uXtanYPIafgPb6GVTQczS_xJAXD0,60
         | 
| 28 28 | 
             
            topologicpy/bin/linux/topologic/libTKBO-6bdf205d.so.7.7.0,sha256=ANok9DQKcnWcLd9T_LAt-i-X4nsYYy16q9kQlcTre1E,2996488
         | 
| 29 29 | 
             
            topologicpy/bin/linux/topologic/libTKBRep-2960a069.so.7.7.0,sha256=OJ3XesL79du8LeBHrsleGPXub6OpJdOilxha0mwjqQo,1378768
         | 
| @@ -84,8 +84,8 @@ topologicpy/bin/windows/topologic/topologic.cp310-win_amd64.pyd,sha256=F0sPLuMpD | |
| 84 84 | 
             
            topologicpy/bin/windows/topologic/topologic.cp311-win_amd64.pyd,sha256=aBAJQj3OmJ58MOAF1ZIFybL_5fFK7FNR9hrIps6b6pc,1551872
         | 
| 85 85 | 
             
            topologicpy/bin/windows/topologic/topologic.cp38-win_amd64.pyd,sha256=aLgNf54nbJmGc7Tdmkuy-V0m6B9zLxabIbpRwAy7cBA,1551360
         | 
| 86 86 | 
             
            topologicpy/bin/windows/topologic/topologic.cp39-win_amd64.pyd,sha256=_8cp205hiRxkFHtzQQOweA4DhCPk8caH4kTVLWGQeVw,1411584
         | 
| 87 | 
            -
            topologicpy-0.4. | 
| 88 | 
            -
            topologicpy-0.4. | 
| 89 | 
            -
            topologicpy-0.4. | 
| 90 | 
            -
            topologicpy-0.4. | 
| 91 | 
            -
            topologicpy-0.4. | 
| 87 | 
            +
            topologicpy-0.4.74.dist-info/LICENSE,sha256=RUmXeeqj63bBySLJjEfhwb9OE7M8h9K6HuOBF3ASVyI,35697
         | 
| 88 | 
            +
            topologicpy-0.4.74.dist-info/METADATA,sha256=YZCjMT3etplLdrUJSbpexAWKR8Ns7_JIt_s-6PgJct0,7252
         | 
| 89 | 
            +
            topologicpy-0.4.74.dist-info/WHEEL,sha256=oiQVh_5PnQM0E3gPdiz09WCNmwiHDMaGer_elqB3coM,92
         | 
| 90 | 
            +
            topologicpy-0.4.74.dist-info/top_level.txt,sha256=J30bDzW92Ob7hw3zA8V34Jlp-vvsfIkGzkr8sqvb4Uw,12
         | 
| 91 | 
            +
            topologicpy-0.4.74.dist-info/RECORD,,
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |