o
    ŀgW                     @  s~  d dl mZ d dlmZmZ d dlmZ d dlZd dlm	Z	 d dl
mZmZmZmZmZmZ d dlZd dlmZmZ d dlmZ d d	lmZ d d
lmZ d dlmZm Z m!Z! d dl"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z( d dl)m*Z* d dl+m,Z, d dl-m.  m/Z0 d dl1m2Z2 d dl3m.  m4  m5Z6 d dl3m7Z7m8Z8 d dl9m:Z: erd dl;m<Z<m=Z=m>Z>m?Z?m@Z@ eAd ZBeCejDZEG dd de7ZFdS )    )annotations)HashableIterator)	timedeltaN)	getsizeof)TYPE_CHECKINGAnyCallableLiteralcastoverload)indexlib)unique_deltas)
no_default)function)cache_readonlydeprecate_nonkeyword_argumentsdoc)ensure_platform_intensure_python_intis_float
is_integer	is_scalaris_signed_integer_dtype)ABCTimedeltaIndex)ops)extract_array)Indexmaybe_extract_name)unpack_zerodim_and_defer)AxisDtype
NaPositionSelfnptc                      s  e Zd ZU dZdZedfZded< ded< edd
dZ							ddddZ
eddddZe	ddddZedddZedd!d"Zedd#d$Zdd&d'Zd(d) Zd*d+ Zdd0d1Zedd3d4Zedd5d6Zedd7d8Zedd9d:Zddd<d=Zedd?d@ZeddAdBZeddCdDZeddEdFZddIdJZeddKdLZ e!e"j#ddMdNZ#			dd݇ fdVdWZ$eddXdYZ%dd[d\Z&e!e"j'dd^d_Z'e!e"j(e)fddadbZ(ddcddZ*e!e"j+dddedfZ+ddhdiZ,dddldmZ-dddndoZ.ddpdqZ/		jdddudvZ0d fdydzZ1e2d{d{d{d{d|dddZ3e2d{d{d{ddddZ3e2d{d{d{d{d|dddZ3e4ddgdd		j		dd fddZ3dd fddZ5dddZ6dddZ7dddZ8d fddZ9d· fdd	Z:	dd fddZ;d fddZ<d fddZ=d fddZ>dddZ?edddZ@ fddZAdddZBeCd fddZDdddZEdddZF fddZG fddZH		j	ddddȄZI  ZJS )
RangeIndexaL  
    Immutable Index implementing a monotonic integer range.

    RangeIndex is a memory-saving special case of an Index limited to representing
    monotonic ranges with a 64-bit dtype. Using RangeIndex may in some instances
    improve computing speed.

    This is the default index type used
    by DataFrame and Series when no explicit index is provided by the user.

    Parameters
    ----------
    start : int (default: 0), range, or other RangeIndex instance
        If int and "stop" is not given, interpreted as "stop" instead.
    stop : int (default: 0)
    step : int (default: 1)
    dtype : np.int64
        Unused, accepted for homogeneity with other index types.
    copy : bool, default False
        Unused, accepted for homogeneity with other index types.
    name : object, optional
        Name to be stored in the index.

    Attributes
    ----------
    start
    stop
    step

    Methods
    -------
    from_range

    See Also
    --------
    Index : The base pandas Index type.

    Examples
    --------
    >>> list(pd.RangeIndex(5))
    [0, 1, 2, 3, 4]

    >>> list(pd.RangeIndex(-2, 4))
    [-2, -1, 0, 1, 2, 3]

    >>> list(pd.RangeIndex(0, 10, 2))
    [0, 2, 4, 6, 8]

    >>> list(pd.RangeIndex(2, -10, -3))
    [2, -1, -4, -7]

    >>> list(pd.RangeIndex(0))
    []

    >>> list(pd.RangeIndex(1, 0))
    []
    
rangeindexzsigned integerrange_range
np.ndarray_valuesreturntype[libindex.Int64Engine]c                 C  s   t jS N)libindexInt64Engineself r3   M/var/www/html/myenv/lib/python3.10/site-packages/pandas/core/indexes/range.py_engine_type   s   zRangeIndex._engine_typeNFdtypeDtype | NonecopyboolnameHashable | Noner$   c                 C  s   |  | t||| }t|| r|j|dS t|tr"| j||dS t|||r-td|d ur5t	|nd}|d u rAd|}}nt	|}|d urMt	|nd}|dkrWt
dt|||}| j||dS )Nr:   z,RangeIndex(...) must be called with integersr      zStep must not be zero)_validate_dtyper   
isinstancer8   r(   _simple_newcomall_none	TypeErrorr   
ValueError)clsstartstopstepr6   r8   r:   rngr3   r3   r4   __new__   s"   
	

zRangeIndex.__new__datac                 C  s<   t |tst| j dt| d| | | j||dS )af  
        Create :class:`pandas.RangeIndex` from a ``range`` object.

        Returns
        -------
        RangeIndex

        Examples
        --------
        >>> pd.RangeIndex.from_range(range(5))
        RangeIndex(start=0, stop=5, step=1)

        >>> pd.RangeIndex.from_range(range(2, -10, -3))
        RangeIndex(start=2, stop=-10, step=-3)
        z7(...) must be called with object coercible to a range, z was passedr<   )r?   r(   rC   __name__reprr>   r@   )rE   rK   r:   r6   r3   r3   r4   
from_range   s   

zRangeIndex.from_rangevaluesc                 C  s<   t | }t|tsJ ||_||_i |_|  d |_|S r.   )	objectrJ   r?   r(   r)   _name_cache_reset_identity_references)rE   rO   r:   resultr3   r3   r4   r@      s   
zRangeIndex._simple_newNonec                 C  s6   |d u rd S | j \}}||std| d| d S )Nz#Incorrect `dtype` passed: expected z, received )_dtype_validation_metadatarD   )rE   r6   validation_funcexpectedr3   r3   r4   r>      s   
zRangeIndex._validate_dtypetype[Index]c                 C     t S )z(return the class to use for construction)r   r1   r3   r3   r4   _constructor      zRangeIndex._constructorc                 C  s   t j| j| j| jt jdS )z
        An int array that for performance reasons is created only when needed.

        The constructed array is saved in ``_cache``.
        r6   )nparangerF   rG   rH   int64r1   r3   r3   r4   _data   s   zRangeIndex._datalist[tuple[str, int]]c                 C  s"   | j }d|jfd|jfd|jfgS )z,return a list of tuples of start, stop, steprF   rG   rH   )r)   rF   rG   rH   )r2   rI   r3   r3   r4   _get_data_as_items   s   zRangeIndex._get_data_as_itemsc                 C  s0   d| j i}|t|   tjt| |fd fS )Nr:   )rQ   updatedictrd   ibase
_new_Indextype)r2   dr3   r3   r4   
__reduce__   s   
zRangeIndex.__reduce__c                 C  s2   t d|  }| jdur|dt| jf |S )zH
        Return a list of tuples of the (attr, formatted_value)
        zlist[tuple[str, str | int]]Nr:   )r   rd   rQ   appendrg   default_pprint)r2   attrsr3   r3   r4   _format_attrs  s   
zRangeIndex._format_attrsheader	list[str]na_repstrc                  sT   t | js|S t| jd }t| jd }tt |t | | fdd| jD  S )Nr   c                   s   g | ]	}|d   qS )<r3   .0x
max_lengthr3   r4   
<listcomp>  s    z2RangeIndex._format_with_header.<locals>.<listcomp>)lenr)   rs   max)r2   rp   rr   first_val_strlast_val_strr3   ry   r4   _format_with_header  s   
zRangeIndex._format_with_headerintc                 C     | j jS )a	  
        The value of the `start` parameter (``0`` if this was not supplied).

        Examples
        --------
        >>> idx = pd.RangeIndex(5)
        >>> idx.start
        0

        >>> idx = pd.RangeIndex(2, -10, -3)
        >>> idx.start
        2
        )r)   rF   r1   r3   r3   r4   rF     s   zRangeIndex.startc                 C  r   )z
        The value of the `stop` parameter.

        Examples
        --------
        >>> idx = pd.RangeIndex(5)
        >>> idx.stop
        5

        >>> idx = pd.RangeIndex(2, -10, -3)
        >>> idx.stop
        -10
        )r)   rG   r1   r3   r3   r4   rG   *  s   zRangeIndex.stopc                 C  r   )a  
        The value of the `step` parameter (``1`` if this was not supplied).

        Examples
        --------
        >>> idx = pd.RangeIndex(5)
        >>> idx.step
        1

        >>> idx = pd.RangeIndex(2, -10, -3)
        >>> idx.step
        -3

        Even if :class:`pandas.RangeIndex` is empty, ``step`` is still ``1`` if
        not supplied.

        >>> idx = pd.RangeIndex(1, 0)
        >>> idx.step
        1
        )r)   rH   r1   r3   r3   r4   rH   ;  s   zRangeIndex.stepc                   s$   | j  t t fdddD  S )zD
        Return the number of bytes in the underlying data.
        c                 3  s    | ]
}t t |V  qd S r.   )r   getattr)rw   	attr_namerI   r3   r4   	<genexpr>Z  s
    
z$RangeIndex.nbytes.<locals>.<genexpr>)rF   rG   rH   )r)   r   sumr1   r3   r   r4   nbytesT  s   
zRangeIndex.nbytesdeepc                 C  s   | j S )a  
        Memory usage of my values

        Parameters
        ----------
        deep : bool
            Introspect the data deeply, interrogate
            `object` dtypes for system-level memory consumption

        Returns
        -------
        bytes used

        Notes
        -----
        Memory usage does not include memory consumed by elements that
        are not components of the array if deep=False

        See Also
        --------
        numpy.ndarray.nbytes
        )r   )r2   r   r3   r3   r4   memory_usage_  s   zRangeIndex.memory_usagenp.dtypec                 C  r[   r.   )_dtype_int64r1   r3   r3   r4   r6   x     zRangeIndex.dtypec                 C     dS )z%return if the index has unique valuesTr3   r1   r3   r3   r4   	is_unique|  r]   zRangeIndex.is_uniquec                 C  s   | j jdkpt| dkS Nr   r=   r)   rH   r|   r1   r3   r3   r4   is_monotonic_increasing     z"RangeIndex.is_monotonic_increasingc                 C  s   | j jdk pt| dkS r   r   r1   r3   r3   r4   is_monotonic_decreasing  r   z"RangeIndex.is_monotonic_decreasingkeyr   c                 C  s4   t | zt|}W n
 ty   Y dS w || jv S NF)hashr   rC   r)   )r2   r   r3   r3   r4   __contains__  s   
zRangeIndex.__contains__c                 C  r   )Nintegerr3   r1   r3   r3   r4   inferred_type  r   zRangeIndex.inferred_typec              
   C  sv   t |st|r)|  r)t|}z| j|W S  ty( } zt||d }~ww t|tr2t|| 	| t|r.   )
r   r   r   r)   r   rD   KeyErrorr?   r   _check_indexing_errorr2   r   new_keyerrr3   r3   r4   get_loc  s   


zRangeIndex.get_loctargetr   method
str | Nonelimit
int | Nonenpt.NDArray[np.intp]c                   s   t |||rt j||||dS | jdkr"| j| j| j}}}n| jd d d }|j|j|j}}}t	|}	|	| }
|
| dk|
dk@ |	|k @ }d|
| < |
| | |
|< || jkrjt
| d |
|  |
|< t|
S )N)r   	tolerancer   r   rt   r=   )rA   any_not_nonesuper_get_indexerrH   rF   rG   r)   r_   asarrayr|   r   )r2   r   r   r   r   rF   rG   rH   reversetarget_arraylocsvalid	__class__r3   r4   r     s    



zRangeIndex._get_indexerc                 C  r   )zA
        Should an integer key be treated as positional?
        Fr3   r1   r3   r3   r4   _should_fallback_to_positional  s   z)RangeIndex._should_fallback_to_positional	list[int]c                 C  
   t | jS r.   )listr)   r1   r3   r3   r4   tolist     
zRangeIndex.tolistIterator[int]c                 c  s    | j E d H  d S r.   r)   r1   r3   r3   r4   __iter__  s   zRangeIndex.__iter__r   c                 C  s   |t u r| jn|}|jjdkrt||tjdS t|}t|dkr@|d dkr@|d }t	|d |d | |}t
| j||dS | jj||dS )Nf)r:   r6   r=   r   rt   r<   )r   rQ   r6   kindr   r_   float64r   r|   r(   ri   r@   r\   )r2   rO   r:   unique_diffsdiff	new_ranger3   r3   r4   _shallow_copy  s   zRangeIndex._shallow_copyc                 C  s"   t | j| j| jd}| j|_|S )Nr<   )ri   r@   r)   rQ   rR   )r2   rU   r3   r3   r4   _view  s   zRangeIndex._viewc                 C  s"   | j ||dd }| j|d}|S )N)r:   r   r   r<   )_validate_names_rename)r2   r:   r   	new_indexr3   r3   r4   r8     s   zRangeIndex.copymethc                 C  sT   t | d }|dkrtjS |dkr| jdks|dkr"| jdk r"| jS | j| j|  S )Nr=   rt   minr   r}   )r|   r_   nanrH   rF   )r2   r   no_stepsr3   r3   r4   _minmax  s   $zRangeIndex._minmaxTskipnac                 O      t | t || | dS )z#The minimum value of the RangeIndexr   )nvvalidate_minmax_axisvalidate_minr   r2   axisr   argskwargsr3   r3   r4   r        

zRangeIndex.minc                 O  r   )z#The maximum value of the RangeIndexr}   )r   r   validate_maxr   r   r3   r3   r4   r}     r   zRangeIndex.maxc                 O  sx   | dd}| dd t|| | jjdkr#tjt| tjd}ntjt| d ddtjd}|s:|ddd }|S )	z
        Returns the indices that would sort the index and its
        underlying data.

        Returns
        -------
        np.ndarray[np.intp]

        See Also
        --------
        numpy.ndarray.argsort
        	ascendingTr   Nr   r^   r=   rt   )	popr   validate_argsortr)   rH   r_   r`   r|   intp)r2   r   r   r   rU   r3   r3   r4   argsort  s   zRangeIndex.argsortsortuse_na_sentinel'tuple[npt.NDArray[np.intp], RangeIndex]c                 C  sJ   t jt| t jd}| }|r!| jdk r!|d d d }|d d d }||fS )Nr^   r   rt   )r_   r`   r|   r   rH   )r2   r   r   codesuniquesr3   r3   r4   	factorize  s   zRangeIndex.factorizeotherrP   c                   s"   t |tr| j|jkS t |S )zL
        Determines if two Index objects contain the same elements.
        )r?   r&   r)   r   equalsr2   r   r   r3   r4   r   )  s   
zRangeIndex.equals.return_indexerr   na_positionr   r   Literal[False]r   r   r#   Callable | Nonec                C     d S r.   r3   r2   r   r   r   r   r3   r3   r4   sort_values2     	zRangeIndex.sort_values)r   r   r   Literal[True]$tuple[Self, np.ndarray | RangeIndex]c                C  r   r.   r3   r   r3   r3   r4   r   =  r   +Self | tuple[Self, np.ndarray | RangeIndex]c                C  r   r.   r3   r   r3   r3   r4   r   H  r   z3.0r2   r   )versionallowed_argsr:   lastc                   s   |d urt  j||||dS | }d}|r#| jdk r"| d d d }d}n| jdkr1| d d d }d}|rL|r@tt| d dd}ntt| }|t|fS |S )Nr   Fr   rt   Tr=   )r   r   rH   r(   r|   r&   )r2   r   r   r   r   sorted_indexinverse_indexerrI   r   r3   r4   r   S  s.   


c                   sb  t |tst j||dS | jdk r| jd d d n| j}|jdk r*|jd d d n|j}t|j|j}t|j	|j	}||krD| 
tS | |j|j\}}}	|j|j | r\| 
tS |j|j|j |j | |  }
|j|j | }t|
||}| 
|}||}t||j	|j}| 
|}| jdk o|jdk |jdk ur|d d d }|d u r| }|S )Nr   r   rt   )r?   r&   r   _intersectionrH   r)   r}   rF   r   rG   r@   _empty_range_extended_gcdr(   _min_fitting_elementr   )r2   r   r   firstsecondint_lowint_highgcds_	tmp_startnew_stepr   r   	new_startr   r3   r4   r   |  s.   
  

 


zRangeIndex._intersectionlower_limitc                 C  s,   || j   t| j  }| j t| j|  S )z?Returns the smallest element greater than or equal to the limit)rF   absrH   )r2   r  r   r3   r3   r4   r     s   zRangeIndex._min_fitting_elementabtuple[int, int, int]c           
      C  sj   d\}}d\}}||}}|r0|| }	|||	|  }}|||	|  }}|||	|  }}|s|||fS )z
        Extended Euclidean algorithms to solve Bezout's identity:
           a*x + b*y = gcd(x, y)
        Finds one particular solution for x, y: s, t
        Returns: gcd, s, t
        )r   r=   )r=   r   r3   )
r2   r  r  r   old_stold_trold_rquotientr3   r3   r4   r     s   

zRangeIndex._extended_gcdc                 C  sJ   |sdS | j s	dS t|dkr|j| j j rdS |j| j v o$|d | j v S )z)Check if other range is contained in selfTFr=   rt   )r)   r|   rH   rF   r   r3   r3   r4   _range_in_self  s   zRangeIndex._range_in_selfbool | Nonec                   sh  t |tr,|dv s|du r,| jdkr,| |jr,| j| j}}| j| jt| d   }|j|j}}|j|jt|d   }| jdk rP|| |}}}|jdk r^|| |}}}t| dkrut|dkrut| j|j  }}nt| dkr~|}nt|dkr|}t||}	t	||}
||kr|| | dkr|| |kr|| |krt
| |	|
| |S |d dkrt|| |d krt|| |d krt
| |	|
|d  |d S nQ|| dkr|| | dkr|| |kr|| |krt
| |	|
| |S n(|| dkr,|| | dkr,|| |kr,|| |kr,t
| |	|
| |S t j||dS )a  
        Form the union of two Index objects and sorts if possible

        Parameters
        ----------
        other : Index or array-like

        sort : bool or None, default None
            Whether to sort (monotonically increasing) the resulting index.
            ``sort=None|True`` returns a ``RangeIndex`` if possible or a sorted
            ``Index`` with a int64 dtype if not.
            ``sort=False`` can return a ``RangeIndex`` if self is monotonically
            increasing and other is fully contained in self. Otherwise, returns
            an unsorted ``Index`` with an int64 dtype.

        Returns
        -------
        union : Index
        NTFr   r=      r   )r?   r&   rH   r  r)   rF   r|   r  r   r}   ri   r   _union)r2   r   r   start_sstep_send_sstart_ostep_oend_ostart_rend_rr   r3   r4   r    sR   $



zRangeIndex._unionc           
        s*  |  | | | | |\}}t|tst j||dS |dur1| jdk r1| d d d |S t	| |}| jdk rD| j
d d d n| j
}| |}|jdk rX|d d d }t|dkrd| j|dS t|t| kru| d d |S t|dkr|d | d kr| dd  S |d | d kr| d d S t| dkr|d | d kr| d d d S t j||dS t|dkr|d |d kr|d |d kr| dd S |j|jkr|d |jkrt|d |j |j|j}n|d |d krt|j|d |j}n~|j
|dd krt|d }|d d | }nft j||dS t| dks(J |j|jd kru|d |d krO|d |d |d	 fv rO|dd d }n.|d |d krm|d |d |d	 fv rm|d d d }nt j||dS t j||dS t| j||d}	|| j
ur|	d d d }	|	S )
Nr   Fr   rt   r<   r=      r  )_validate_sort_keyword_assert_can_do_setop_convert_can_do_setopr?   r&   r   _differencerH   r   get_op_result_namer)   intersectionr|   renamerF   r(   rG   ri   r@   )
r2   r   r   result_nameres_namer   overlapnew_rngrH   r   r   r3   r4   r!    s^   


 

,,,zRangeIndex._differencer%  c                   sV   t |tr	|d urt |||S | |}|| }||}|d ur)||}|S r.   )r?   r&   r   symmetric_difference
differenceunionr$  )r2   r   r%  r   leftrightrU   r   r3   r4   r)  m  s   



zRangeIndex.symmetric_differencec                   s   t |r5|dt|  fv r| dd  S |dt| d fv r#| d d S t| dkr4|dv r4| d d d S n#t|rXttj|tjdt| }t|t	rX| | }| j
|dd	S t |S )
Nr   r=   rt   r  )r=   r  r  r^   Fr   )r   r|   r   is_list_likemaybe_indices_to_slicer_   r   r   r?   slicer*  r   delete)r2   locslcr   r   r3   r4   r1    s   

zRangeIndex.deleter2  c                   s  t | rt|st|r| j}|dkr2|| d | j kr2t|j|j |j|j}t| j	|| j
dS |t | krW|| d | j krWt|j|j|j |j}t| j	|| j
dS t | dkr|| d | jd  krt| jd }t| j| j|}t| j	|| j
dS t ||S )Nr   r<   rt   r  )r|   r   r   r)   rH   r(   rF   rG   ri   r@   rQ   r   r   insert)r2   r2  itemrI   r(  rH   r   r3   r4   r4    s   "zRangeIndex.insertindexeslist[Index]c                   s  t dd |D st ||S t|dkr|d S ttt |}d } }}dd |D }|D ]r}|j}	|du rJ|	j}|du rIt|	dkrI|	j	}n$|du rn|	j|krit
dd |D }
| |
}||  S |	j| }||	j	kryt|	dkp|duo|	j|k}|r| t
d	d |D }||  S |dur|	d
 | }q0|r|du r|d
 jn|}t||||S tdd|S )a  
        Overriding parent method for the case of all RangeIndex instances.

        When all members of "indexes" are of type RangeIndex: result will be
        RangeIndex if possible, Index with a int64 dtype otherwise. E.g.:
        indexes = [RangeIndex(3), RangeIndex(3, 6)] -> RangeIndex(6)
        indexes = [RangeIndex(3), RangeIndex(4, 6)] -> Index([0,1,2,4,5], dtype='int64')
        c                 s  s    | ]}t |tV  qd S r.   )r?   r&   rv   r3   r3   r4   r     s    z%RangeIndex._concat.<locals>.<genexpr>r=   r   Nc                 S  s   g | ]}t |r|qS r3   r|   )rw   objr3   r3   r4   r{     s    z&RangeIndex._concat.<locals>.<listcomp>c                 S     g | ]}|j qS r3   r+   rv   r3   r3   r4   r{         c                 S  r:  r3   r;  rv   r3   r3   r4   r{     r<  rt   )allr   _concatr|   r   r   r&   r)   rF   rH   r_   concatenater\   r$  rG   )r2   r6  r:   rng_indexesrF   rH   next_non_empty_indexesr9  rI   rO   rU   non_consecutiverG   r   r3   r4   r>    sF   	


zRangeIndex._concatc                 C  r   )z5
        return the length of the RangeIndex
        )r|   r)   r1   r3   r3   r4   __len__  s   
zRangeIndex.__len__c                 C  s   t | S r.   r8  r1   r3   r3   r4   size  s   zRangeIndex.sizec              
     s   t |tr
| |S t|r2t|}z| j| W S  ty1 } ztd| dt|  |d}~ww t|r:tdt	 
|S )zE
        Conserve RangeIndex type for scalar and slice keys.
        index ' is out of bounds for axis 0 with size Nzuonly integers, slices (`:`), ellipsis (`...`), numpy.newaxis (`None`) and integer or boolean arrays are valid indices)r?   r0  _getitem_slicer   r   r)   
IndexErrorr|   r   r   __getitem__r   r   r3   r4   rJ    s&   

zRangeIndex.__getitem__slobjr0  c                 C  s   | j | }t| j|| jdS )zH
        Fastpath for __getitem__ when we know we have a slice.
        r<   )r)   ri   r@   rQ   )r2   rK  resr3   r3   r4   rH    s   
zRangeIndex._getitem_slice__floordiv__c                   s   t |rY|dkrYt| dks| j| dkr>| j| dkr>| j| }| j| }|t| |  }t|||p4d}| j|| jdS t| dkrY| j| }t||d d}| j|| jdS t |S )Nr   r=   r<   )	r   r|   rF   rH   r(   r@   rQ   r   rM  )r2   r   rF   rH   rG   r   r   r3   r4   rM    s   (


zRangeIndex.__floordiv__c                 O  s
   d| j vS )Nr   r   r2   r   r   r3   r3   r4   r=  "  r   zRangeIndex.allc                 O  r   r.   )anyr)   rN  r3   r3   r4   rO  %  r   zRangeIndex.anyc                   s2   t |tr| j|jkrt | |S t ||S r.   )r?   r&   r)   r   _cmp_method)r2   r   opr   r3   r4   rP  *  s   zRangeIndex._cmp_methodc              
     s  t |trtS t |ttjfrt ||S t	t
|dddr't ||S |tjtjtjtjtjtjttjfv rAt ||S d}|tjtjtjtjfv rQ|}t|ddd}| }zy|rtjdd ||j|}W d   n1 stw   Y  t|r|stn|tjkr|j n|j}tjdd ||j|}||j |}W d   n1 sw   Y  t!| |}	t"| ||||	d}
t#d	d
 |||fD s|
$d}
|
W S  tt%t&fy   t || Y S w )z
        Parameters
        ----------
        other : Any
        op : callable that accepts 2 params
            perform the binary op
        r6   NmT)extract_numpyextract_rangeignore)r=  r<   c                 s  s    | ]}t |V  qd S r.   )r   rv   r3   r3   r4   r   q  s    z+RangeIndex._arith_method.<locals>.<genexpr>r   )'r?   r   NotImplementedr   r_   timedelta64r   _arith_methodr   is_np_dtyper   operatorpowr   rpowmodrmodfloordiv	rfloordivdivmodrdivmodmulrmultruedivrtruedivr   errstaterH   r   rD   rsubrF   rG   r"  ri   r=  astyperC   ZeroDivisionError)r2   r   rQ  rH   r-  r,  rsteprstartrstopr&  rU   r   r3   r4   rX  0  sV   
	

zRangeIndex._arith_methodr   r   r!   
allow_fillc           	      K  s  |rt d| t|rtdt|}| ||| t|dkr*tjg | j	d}nS|
 }|t| kr@td| dt|  | }|t|  k rWtd| dt|  |j| j	dd}|dk ri|t| ; }| jd	krs|| j9 }| jdkr}|| j7 }| jj|| jd
S )Nr3   z!Expected indices to be array-liker   r^   rF  rG  safe)castingr=   r<   )r   validate_taker   rC   r   _maybe_disallow_fillr|   r_   arrayr6   r}   rI  r   ri  rH   rF   r\   r@   r:   )	r2   indicesr   rn  
fill_valuer   takenind_maxind_minr3   r3   r4   take|  s4   



zRangeIndex.take)r,   r-   )NNNNFN)r6   r7   r8   r9   r:   r;   r,   r$   )NN)rK   r(   r6   r7   r,   r$   r.   )rO   r(   r:   r;   r,   r$   )r6   r7   r,   rV   )r,   rZ   )r,   r*   )r,   rc   )rp   rq   rr   rs   r,   rq   )r,   r   )F)r   r9   r,   r   )r,   r   )r,   r9   )r   r   r,   r9   )r,   rs   )NNN)r   r   r   r   r   r   r,   r   )r,   r   )r,   r   )r:   r   )r,   r$   r   )r:   r;   r   r9   r,   r$   )r   rs   r  )r   r9   r,   r   )r,   r   )FT)r   r9   r   r9   r,   r   )r   rP   r,   r9   )
r   r   r   r9   r   r#   r   r   r,   r$   )
r   r   r   r9   r   r#   r   r   r,   r   )
r   r9   r   r9   r   r#   r   r   r,   r   )FTr   N)r   r   r   r9   )r  r   r,   r   )r  r   r  r   r,   r  )r   r(   r,   r9   )r   r   r   r  )r%  r;   )r,   r   )r2  r   r,   r   )r6  r7  r:   r   r,   r   )rK  r0  r,   r$   )r   TN)r   r!   rn  r9   r,   r   )KrL   
__module____qualname____doc___typr   rW   __annotations__propertyr5   rJ   classmethodrN   r@   r>   r   r\   rb   rd   rk   ro   r   rF   rG   rH   r   r   r6   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r   r   r}   r   r   r   r   r   r   r   r   r   r  r  r!  r)  r1  r4  r>  rD  rE  rJ  rH  r    rM  r=  rO  rP  rX  ry  __classcell__r3   r3   r   r4   r&   B   s   
 :$

	




	
	


&
.

KX
=


Or&   )G
__future__r   collections.abcr   r   datetimer   rZ  sysr   typingr   r   r	   r
   r   r   numpyr_   pandas._libsr   r/   r   pandas._libs.algosr   pandas._libs.libr   pandas.compat.numpyr   r   pandas.util._decoratorsr   r   r   pandas.core.dtypes.commonr   r   r   r   r   r   pandas.core.dtypes.genericr   pandas.corer   pandas.core.commoncorecommonrA   pandas.core.constructionr   pandas.core.indexes.baser6  baserg   r   r   pandas.core.ops.commonr    pandas._typingr!   r"   r#   r$   r%   r(   r   r6   ra   r   r&   r3   r3   r3   r4   <module>   s2     	 