o
    5c                     @  s  d dl 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mZ d dl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mZ d d
lmZ d dl m!Z!m"Z" d dl#m$Z$ d dl%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+m,Z, d dl-m.Z. d dl/m0Z0 d dl1m2Z2 d dl3m4  m5Z6 d dl7m8Z8 d dl9m4  m:  m;Z< d dl9m=Z= d dl>m?Z?m@Z@mAZA d dlBmCZC erd dlDmEZE eFd ZGG dd deAZHdS )    )annotations)	timedeltaN)	getsizeof)TYPE_CHECKINGAnyCallableHashableIteratorListcast)indexlib)unique_deltas)
no_default)Dtypenpt)function)cache_readonlydoc)find_stack_level)ensure_platform_intensure_python_intis_float
is_integer	is_scalaris_signed_integer_dtypeis_timedelta64_dtype)ABCTimedeltaIndex)ops)resolve_na_sentinel)extract_array)maybe_extract_name)Float64Index
Int64IndexNumericIndex)unpack_zerodim_and_defer)Indexc                      sn  e Zd ZU dZdZedfZded< dZ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d!d" Zd#d$ Zd%d& Zdd'd(Zdd-d.Zd/Ze	dd1d2Ze	dd3d4Ze	dd5d6Ze	dd7d8Ze	dd9d:Ze	dd;d<Zedd=d>Zddd@dAZe	ddCdDZ e	ddEdFZ!eddGdHZ"eddIdJZ#ddMdNZ$e	ddOdPZ%e&e'j(d fdQdR	Z(			ddʇ fdZd[Z)dd]d^Z*e&e'j+dd`daZ+e&e'j,e-fddbdcZ,ddedfZ.e&e'j/				dddgdhZ/ddjdkZ0dddndoZ1dddpdqZ2ddrdsZ3de4j-e4j-fddzd{Z5dև fd~dZ6		l		dd؇ fddZ7ddه fddZ8dddZ9dddZ:dddZ;dه fddZ<d fdd	Z=dd݇ fddZ>dއ fddZ?d߇ fddZ@d fddZAdddZBe	dddZC fddZDdddZEeFd fddZGdddZHdddZI fddZJ fddZK  ZLS )
RangeIndexa  
    Immutable Index implementing a monotonic integer range.

    RangeIndex is a memory-saving special case of Int64Index limited to
    representing monotonic ranges. 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.
    Int64Index : Index of int64 data.
    
rangeindexzsigned integerrange_rangeFbool(_is_backward_compat_public_numeric_indexreturntype[libindex.Int64Engine]c                 C  s   t jS N)libindexInt64Engineself r4   O/var/www/html/gps/gps/lib/python3.10/site-packages/pandas/core/indexes/range.py_engine_typeo   s   zRangeIndex._engine_typeNdtypeDtype | Nonecopynamer   c                 C  s   |  | t||| }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!   
isinstancer'   r9   r)   _simple_newcomall_none	TypeErrorr   
ValueError)clsstartstopstepr7   r9   r:   rngr4   r4   r5   __new__v   s"   
	

zRangeIndex.__new__datac                 C  s<   t |tst| j dt| d| | | j||dS )zl
        Create RangeIndex from a range object.

        Returns
        -------
        RangeIndex
        z7(...) must be called with object coercible to a range, z was passedr;   )r>   r)   rB   __name__reprr=   r?   )rD   rJ   r:   r7   r4   r4   r5   
from_range   s   

zRangeIndex.from_rangevaluesc                 C  s6   t | }t|tsJ ||_||_i |_|  |S r/   )objectrI   r>   r)   r*   _name_cache_reset_identity)rD   rN   r:   resultr4   r4   r5   r?      s   
zRangeIndex._simple_newtype[Int64Index]c                 C  s   t S )z(return the class to use for construction)r#   r2   r4   r4   r5   _constructor      zRangeIndex._constructor
np.ndarrayc                 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``.
        r7   )nparangerE   rF   rG   int64r2   r4   r4   r5   _data   s   zRangeIndex._datac                 C  s"   | j }d|jfd|jfd|jfgS )z,return a list of tuples of start, stop, steprE   rF   rG   )r*   rE   rF   rG   )r3   rH   r4   r4   r5   _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:   )r:   updatedictr]   ibase
_new_Indextype)r3   dr4   r4   r5   
__reduce__   s   
zRangeIndex.__reduce__c                 C  s,   |   }| jdur|dt| jf |S )zH
        Return a list of tuples of the (attr, formatted_value)
        Nr:   )r]   r:   appendr`   default_pprint)r3   attrsr4   r4   r5   _format_attrs   s   
zRangeIndex._format_attrsc                 C  s   d S r/   r4   )r3   r:   r4   r4   r5   _format_data      zRangeIndex._format_data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 )<r4   .0x
max_lengthr4   r5   
<listcomp>   s    z2RangeIndex._format_with_header.<locals>.<listcomp>)lenr*   rn   max)r3   rk   rm   first_val_strlast_val_strr4   rt   r5   _format_with_header   s   
zRangeIndex._format_with_headerz^RangeIndex.{} is deprecated and will be removed in a future version. Use RangeIndex.{} insteadintc                 C     | j jS )zV
        The value of the `start` parameter (``0`` if this was not supplied).
        )r*   rE   r2   r4   r4   r5   rE         zRangeIndex.startc                 C  "   t j| jddtt d | jS )z
        The value of the `start` parameter (``0`` if this was not supplied).

         .. deprecated:: 0.25.0
            Use ``start`` instead.
        _startrE   
stacklevel)warningswarn_deprecation_messageformatFutureWarningr   rE   r2   r4   r4   r5   r      s   zRangeIndex._startc                 C  r}   )z4
        The value of the `stop` parameter.
        )r*   rF   r2   r4   r4   r5   rF     s   zRangeIndex.stopc                 C  r   )zw
        The value of the `stop` parameter.

         .. deprecated:: 0.25.0
            Use ``stop`` instead.
        _stoprF   r   )r   r   r   r   r   r   rF   r2   r4   r4   r5   r        	zRangeIndex._stopc                 C  r}   )zU
        The value of the `step` parameter (``1`` if this was not supplied).
        )r*   rG   r2   r4   r4   r5   rG   %  r~   zRangeIndex.stepc                 C  r   )z
        The value of the `step` parameter (``1`` if this was not supplied).

         .. deprecated:: 0.25.0
            Use ``step`` instead.
        _steprG   r   )r   r   r   r   r   r   rG   r2   r4   r4   r5   r   -  r   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)rr   	attr_namerH   r4   r5   	<genexpr>C  s
    
z$RangeIndex.nbytes.<locals>.<genexpr>)rE   rF   rG   )r*   r   sumr2   r4   r   r5   nbytes=  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   )r3   r   r4   r4   r5   memory_usageH  s   zRangeIndex.memory_usagenp.dtypec                 C  s   t t jS r/   )rY   r7   r[   r2   r4   r4   r5   r7   a  s   zRangeIndex.dtypec                 C     dS )z%return if the index has unique valuesTr4   r2   r4   r4   r5   	is_uniquee  rV   zRangeIndex.is_uniquec                 C  s   | j jdkpt| dkS Nr   r<   r*   rG   rw   r2   r4   r4   r5   is_monotonic_increasingj     z"RangeIndex.is_monotonic_increasingc                 C  s   | j jdk pt| dkS r   r   r2   r4   r4   r5   is_monotonic_decreasingn  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   rB   r*   )r3   r   r4   r4   r5   __contains__r  s   
zRangeIndex.__contains__c                 C  r   )Nintegerr4   r2   r4   r4   r5   inferred_typez  rj   zRangeIndex.inferred_typec              
     s   |d u r:|d u r:t |st|r1|  r1t|}z| j|W S  ty0 } zt||d }~ww | | t|t j	|||dS )N)method	tolerance)
r   r   r|   r*   r   rC   KeyError_check_indexing_errorsuperget_loc)r3   r   r   r   new_keyerr	__class__r4   r5   r     s   

zRangeIndex.get_loctargetr&   r   
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   r   r   r   ro   r<   )r@   any_not_noner   _get_indexerrG   rE   rF   r*   rY   asarrayrw   r   )r3   r   r   r   r   rE   rF   rG   reversetarget_arraylocsvalidr   r4   r5   r     s    



zRangeIndex._get_indexer	list[int]c                 C  
   t | jS r/   )listr*   r2   r4   r4   r5   tolist     
zRangeIndex.tolistIterator[int]c                 c  s    | j E d H  d S r/   r*   r2   r4   r4   r5   __iter__  s   zRangeIndex.__iter__c                 C  s   |t u r| jn|}|jjdkrt||dS t|}t|dkr>|d dkr>|d }t|d |d | |}t| j	||dS t
j	||dS )Nfr;   r<   r   ro   )r   r:   r7   kindr"   r   rw   r)   rb   r?   r#   )r3   rN   r:   unique_diffsdiff	new_ranger4   r4   r5   _shallow_copy  s   zRangeIndex._shallow_copyr3   c                 C  s"   t | j| j| jd}| j|_|S )Nr;   )rb   r?   r*   rP   rQ   )r3   rS   r4   r4   r5   _view  s   zRangeIndex._viewc                 C  sD   | j |||dd }| j|d}|r tjdtt d ||}|S )N)r:   namesr   r   r;   zeparameter dtype is deprecated and will be removed in a future version. Use the astype method instead.r   )_validate_names_renamer   r   r   r   astype)r3   r:   r   r7   r   	new_indexr4   r4   r5   r9     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<   ro   minr   rx   )rw   rY   nanrG   rE   )r3   r   no_stepsr4   r4   r5   _minmax  s   $zRangeIndex._minmaxTskipnac                 O      t | t || | dS )z#The minimum value of the RangeIndexr   )nvvalidate_minmax_axisvalidate_minr   r3   axisr   argskwargsr4   r4   r5   r        

zRangeIndex.minc                 O  r   )z#The maximum value of the RangeIndexrx   )r   r   validate_maxr   r   r4   r4   r5   rx     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   rX   r<   ro   )	popr   validate_argsortr*   rG   rY   rZ   rw   intp)r3   r   r   r   rS   r4   r4   r5   argsort  s   zRangeIndex.argsortsortna_sentinelint | lib.NoDefaultuse_na_sentinelbool | lib.NoDefault'tuple[npt.NDArray[np.intp], RangeIndex]c                 C  sT   t || tjt| tjd}| }|r&| jdk r&|d d d }|d d d }||fS )NrX   r   ro   )r   rY   rZ   rw   r   rG   )r3   r   r   r   codesuniquesr4   r4   r5   	factorize  s   
zRangeIndex.factorizeotherrO   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r3   r   r   r4   r5   r     s   
zRangeIndex.equalslastreturn_indexerr   na_positionCallable | Nonec                   s   | }t tt| }|d urt j||||dS | }|r0| jdk r/| d d d }|d d d }n| jdkrE| d d d }|d d d  }}|rK||fS |S )N)r   r   r   r   r   ro   )r'   r)   rw   r   sort_valuesrG   )r3   r   r   r   r   sorted_indexindexerr   r4   r5   r   %  s*   

zRangeIndex.sort_valuesc                   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   ro   )r>   r'   r   _intersectionrG   r*   rx   rE   r   rF   r?   _empty_range_extended_gcdr)   _min_fitting_elementr   )r3   r   r   firstsecondint_lowint_highgcds_	tmp_startnew_stepr   r   	new_startr   r4   r5   r   H  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)rE   absrG   )r3   r  r   r4   r4   r5   r   w  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   r4   )
r3   r  r  r   old_stold_trold_rquotientr4   r4   r5   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<   ro   )r*   rw   rG   rE   r   r4   r4   r5   _range_in_self  s   zRangeIndex._range_in_selfc                   sh  t |tr,|du 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 : False or None, default None
            Whether to sort (monotonically increasing) the resulting index.
            ``sort=None`` returns a ``RangeIndex`` if possible or a sorted
            ``Int64Index`` if not.
            ``sort=False`` can return a ``RangeIndex`` if self is monotonically
            increasing and other is fully contained in self. Otherwise, returns
            an unsorted ``Int64Index``

            .. versionadded:: 0.25.0

        Returns
        -------
        union : Index
        NFr   r<      r   )r>   r'   rG   r  r*   rE   rw   r  r   rx   rb   r   _union)r3   r   r   start_sstep_send_sstart_ostep_oend_ostart_rend_rr   r4   r5   r    st   











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   r   ro   r;   r<      r  )_validate_sort_keyword_assert_can_do_setop_convert_can_do_setopr>   r'   r   _differencerG   r   get_op_result_namer*   intersectionrw   renamerE   r)   rF   rb   r?   )
r3   r   r   result_nameres_namer   overlapnew_rngrG   r   r   r4   r5   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  )r3   r   r   r   leftrightrS   r   r4   r5   r$  <  s   



zRangeIndex.symmetric_differencec                   s   t |r=|dks|t|  kr| dd  S |dks!|t| d kr'| d d S t| dkr<|dks5|dkr<| d d d S n#t|r`ttj|tjdt| }t|t	r`| | }| j
|dd	S t |S )
Nr   r<   ro   r  r  r  rX   Fr   )r   rw   r   is_list_likemaybe_indices_to_slicerY   r   r   r>   slicer%  r   delete)r3   locslcr   r   r4   r5   r,  L  s   

zRangeIndex.deleter-  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;   ro   r  )rw   r   r   r*   rG   r)   rE   rF   rb   r?   r:   r|   r   insert)r3   r-  itemrH   r#  rG   r   r4   r5   r/  b  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 ]p}|j}	|du rJ|	j}|du rIt|	dkrI|	j	}n#|du rm|	j|krht
dd |D }
t|
}||  S |	j| }||	j	krxt|	dkp|duo|	j|k}|rtt
d	d |D }||  S |dur|	d
 | }q0|r|du r|d
 jn|}t||||S tdd|S )ar  
        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, Int64Index otherwise. E.g.:
        indexes = [RangeIndex(3), RangeIndex(3, 6)] -> RangeIndex(6)
        indexes = [RangeIndex(3), RangeIndex(4, 6)] -> Int64Index([0,1,2,4,5])
        c                 s  s    | ]}t |tV  qd S r/   )r>   r'   rq   r4   r4   r5   r     s    z%RangeIndex._concat.<locals>.<genexpr>r<   r   Nc                 S  s   g | ]}t |r|qS r4   rw   )rr   objr4   r4   r5   rv     s    z&RangeIndex._concat.<locals>.<listcomp>c                 S     g | ]}|j qS r4   _valuesrq   r4   r4   r5   rv         c                 S  r5  r4   r6  rq   r4   r4   r5   rv     r8  ro   )allr   _concatrw   r   r
   r'   r*   rE   rG   rY   concatenater#   r  rF   )r3   r1  r:   rng_indexesrE   rG   next_non_empty_indexesr4  rH   rN   rS   non_consecutiverF   r   r4   r5   r:  w  sB   	

zRangeIndex._concatc                 C  r   )z5
        return the length of the RangeIndex
        )rw   r*   r2   r4   r4   r5   __len__  s   
zRangeIndex.__len__c                 C  s   t | S r/   r3  r2   r4   r4   r5   size  s   zRangeIndex.sizec              
     s   t |tr| j| }| j|| jdS t|r:t|}z| j| W S  ty9 } ztd| dt|  |d}~ww t	|rBtdt
 |S )zE
        Conserve RangeIndex type for scalar and slice keys.
        r;   zindex z' 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>   r+  r*   r?   rP   r   r|   
IndexErrorrw   r   r   __getitem__)r3   r   r   r   r   r   r4   r5   rC    s(   

zRangeIndex.__getitem__slobjr+  c                 C  s   | j | }t| j|| jdS )zH
        Fastpath for __getitem__ when we know we have a slice.
        r;   )r*   rb   r?   rP   )r3   rD  resr4   r4   r5   _getitem_slice  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   rw   rE   rG   r)   r?   r:   r   rG  )r3   r   rE   rG   rF   r   r   r4   r5   rG    s   (


zRangeIndex.__floordiv__c                 O  s
   d| j vS )Nr   r   r3   r   r   r4   r4   r5   r9    r   zRangeIndex.allc                 O  r   r/   )anyr*   rH  r4   r4   r5   rI    r   zRangeIndex.anyc                   s2   t |tr| j|jkrt | |S t ||S r/   )r>   r'   r*   r   _cmp_method)r3   r   opr   r4   r5   rJ    s   zRangeIndex._cmp_methodc              
     s  t |trtS t |ttjfrt ||S t|r!t ||S |t	j
tjt	jtjt	jtjttjfv r;t ||S d}|t	jtjt	jtjfv rK|}t|ddd}| }zp|r|tjdd ||j|}W d   n1 snw   Y  t|ry|s{t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
        NT)extract_numpyextract_rangeignore)r9  r;   c                 s  s    | ]}t |V  qd S r/   )r   rq   r4   r4   r5   r   >  s    z+RangeIndex._arith_method.<locals>.<genexpr>float64)$r>   r   NotImplementedr   rY   timedelta64r   _arith_methodr   operatorpowr   rpowmodrmodfloordiv	rfloordivdivmodrdivmodmulrmultruedivrtruedivr    errstaterG   r   rC   rE   rF   r  rb   r9  r   rB   ZeroDivisionError)r3   r   rK  rG   r(  r'  rsteprstartrstopr!  rS   r   r4   r5   rR    sV   
	

zRangeIndex._arith_method)r-   r.   )NNNNFN)r7   r8   r9   r+   r:   r   r-   r'   )NN)rJ   r)   r7   r8   r-   r'   r/   )rN   r)   r:   r   r-   r'   )r-   rT   )r-   rW   )rk   rl   rm   rn   r-   rl   )r-   r|   )F)r   r+   r-   r|   )r-   r   )r-   r+   )r   r   r-   r+   )r-   rn   )NNN)r   r&   r   r   r   r   r-   r   )r-   r   )r-   r   )r:   r   )r3   r'   r-   r'   )NFNN)r:   r   r   r+   r7   r8   )r   rn   )NT)r   r+   r-   r|   )r-   r   )r   r+   r   r   r   r   r-   r   )r   rO   r-   r+   )FTr   N)r   r+   r   r+   r   rn   r   r   )r   r&   )r  r|   r-   r|   )r  r|   r  r|   r-   r  )r   r)   r-   r+   )r   r   )r-   r&   )r-  r|   r-   r&   )r1  r2  r:   r   r-   r&   )r3   r'   rD  r+  r-   r'   )MrK   
__module____qualname____doc___typr   _dtype_validation_metadata__annotations__r,   propertyr6   rI   classmethodrM   r?   r   rU   r\   r]   rd   rh   ri   r{   r   rE   r   rF   r   rG   r   r   r   r7   r   r   r   r   r   r   r#   r   r   r   r   r   r   r   r9   r   r   rx   r   r   r   r   r   r   r   r   r  r  r  r$  r,  r/  r:  r@  rA  rC  rF  r%   rG  r9  rI  rJ  rR  __classcell__r4   r4   r   r5   r'   B   s   
 '$
	



 

	

#
/

MW
;


r'   )I
__future__r   datetimer   rS  sysr   typingr   r   r   r   r	   r
   r   r   numpyrY   pandas._libsr   r0   r   pandas._libs.algosr   pandas._libs.libr   pandas._typingr   r   pandas.compat.numpyr   r   pandas.util._decoratorsr   r   pandas.util._exceptionsr   pandas.core.dtypes.commonr   r   r   r   r   r   r   pandas.core.dtypes.genericr   pandas.corer   pandas.core.algorithmsr   pandas.core.commoncorecommonr@   pandas.core.constructionr    pandas.core.indexes.baser1  baser`   r!   pandas.core.indexes.numericr"   r#   r$   pandas.core.ops.commonr%   pandasr&   r)   r   r'   r4   r4   r4   r5   <module>   s8    $	$	