U
    9vf                     @   s,   d Z ddlmZ ddlZdgZdddZdS )z
Vitality measures.
    )partialNcloseness_vitalityc                    sf   |dkrt j| |d}|dk	rDt j| t| |h |d}|| S tt| ||d  fdd| D S )a  Returns the closeness vitality for nodes in the graph.

    The *closeness vitality* of a node, defined in Section 3.6.2 of [1],
    is the change in the sum of distances between all node pairs when
    excluding that node.

    Parameters
    ----------
    G : NetworkX graph
        A strongly-connected graph.

    weight : string
        The name of the edge attribute used as weight. This is passed
        directly to the :func:`~networkx.wiener_index` function.

    node : object
        If specified, only the closeness vitality for this node will be
        returned. Otherwise, a dictionary mapping each node to its
        closeness vitality will be returned.

    Other parameters
    ----------------
    wiener_index : number
        If you have already computed the Wiener index of the graph
        `G`, you can provide that value here. Otherwise, it will be
        computed for you.

    Returns
    -------
    dictionary or float
        If `node` is None, this function returns a dictionary
        with nodes as keys and closeness vitality as the
        value. Otherwise, it returns only the closeness vitality for the
        specified `node`.

        The closeness vitality of a node may be negative infinity if
        removing that node would disconnect the graph.

    Examples
    --------
    >>> G = nx.cycle_graph(3)
    >>> nx.closeness_vitality(G)
    {0: 2.0, 1: 2.0, 2: 2.0}

    See Also
    --------
    closeness_centrality

    References
    ----------
    .. [1] Ulrik Brandes, Thomas Erlebach (eds.).
           *Network Analysis: Methodological Foundations*.
           Springer, 2005.
           <http://books.google.com/books?id=TTNhSm7HYrIC>

    N)weight)r   wiener_indexc                    s   i | ]}| |d qS ))node ).0vZvitalityr   @/tmp/pip-unpacked-wheel-_lngutwb/networkx/algorithms/vitality.py
<dictcomp>K   s      z&closeness_vitality.<locals>.<dictcomp>)nxr   Zsubgraphsetr   r   )Gr   r   r   afterr   r
   r   r      s    9)NNN)__doc__	functoolsr   Znetworkxr   __all__r   r   r   r   r   <module>   s   