o
    h                     @   s   d Z g dZG dd deZG dd deZG dd deZG dd	 d	eZG d
d deZG dd deZG dd deZ	G dd deZ
G dd deZG dd deZG dd deZG dd deZG dd deZG dd deZdS )zL
**********
Exceptions
**********

Base exceptions and errors for NetworkX.
)	HasACycleNodeNotFoundPowerIterationFailedConvergenceExceededMaxIterationsAmbiguousSolutionNetworkXAlgorithmErrorNetworkXExceptionNetworkXErrorNetworkXNoCycleNetworkXNoPathNetworkXNotImplementedNetworkXPointlessConceptNetworkXUnboundedNetworkXUnfeasiblec                   @      e Zd ZdZdS )r   z&Base class for exceptions in NetworkX.N__name__
__module____qualname____doc__ r   r   f/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/networkx/exception.pyr          r   c                   @   r   )r   z)Exception for a serious error in NetworkXNr   r   r   r   r   r      r   r   c                   @   r   )r   a  Raised when a null graph is provided as input to an algorithm
    that cannot use it.

    The null graph is sometimes considered a pointless concept [1]_,
    thus the name of the exception.

    Notes
    -----
    Null graphs and empty graphs are often used interchangeably but they
    are well defined in NetworkX. An ``empty_graph`` is a graph with ``n`` nodes
    and 0 edges, and a ``null_graph`` is a graph with 0 nodes and 0 edges.

    References
    ----------
    .. [1] Harary, F. and Read, R. "Is the Null Graph a Pointless
       Concept?"  In Graphs and Combinatorics Conference, George
       Washington University.  New York: Springer-Verlag, 1973.

    Nr   r   r   r   r   r   #   r   r   c                   @   r   )r   z3Exception for unexpected termination of algorithms.Nr   r   r   r   r   r   9   r   r   c                   @   r   )r   zdException raised by algorithms trying to solve a problem
    instance that has no feasible solution.Nr   r   r   r   r   r   =   r   r   c                   @   r   )r
   zoException for algorithms that should return a path when running
    on graphs where such a path does not exist.Nr   r   r   r   r   r
   B   r   r
   c                   @   r   )r	   zqException for algorithms that should return a cycle when running
    on graphs where such a cycle does not exist.Nr   r   r   r   r   r	   G   r   r	   c                   @   r   )r   z^Raised if a graph has a cycle when an algorithm expects that it
    will have no cycles.

    Nr   r   r   r   r   r   L   r   r   c                   @   r   )r   zwException raised by algorithms trying to solve a maximization
    or a minimization problem instance that is unbounded.Nr   r   r   r   r   r   S   r   r   c                   @   r   )r   zCException raised by algorithms not implemented for a type of graph.Nr   r   r   r   r   r   X   r   r   c                   @   r   )r   z>Exception raised if requested node is not present in the graphNr   r   r   r   r   r   \   r   r   c                   @   r   )r   a@  Raised if more than one valid solution exists for an intermediary step
    of an algorithm.

    In the face of ambiguity, refuse the temptation to guess.
    This may occur, for example, when trying to determine the
    bipartite node sets in a disconnected bipartite graph when
    computing bipartite matchings.

    Nr   r   r   r   r   r   `   r   r   c                   @   r   )r   zRaised if a loop iterates too many times without breaking.

    This may occur, for example, in an algorithm that computes
    progressively better approximations to a value but exceeds an
    iteration bound specified by the user.

    Nr   r   r   r   r   r   l   r   r   c                       s    e Zd ZdZ fddZ  ZS )r   zRaised when the power iteration method fails to converge within a
    specified iteration limit.

    `num_iterations` is the number of iterations that have been
    completed when this exception was raised.

    c                    s4   d| d}|}t  j}|| |g|R i | d S )Nz*power iteration failed to converge within z iterations)super__init__)selfnum_iterationsargskwmsgexception_message	superinit	__class__r   r   r      s   z(PowerIterationFailedConvergence.__init__)r   r   r   r   r   __classcell__r   r   r!   r   r   v   s    r   N)r   __all__	Exceptionr   r   r   r   r   r
   r	   r   r   r   r   r   r   r   r   r   r   r   <module>   s     
