
    |h
                     l    d dl ZddgZddZd Zd Zej                  e_        ej                  e_        y)    N	load_sift	load_surfc           	         t        | t              rt        |       }d}n| }d}|dk(  rjt        t        |j                         j                               \  }}t        j                  dt        fdt        fdt        fdt        fdt        |ffg      }nsd	}t	        |j                               d
z
  }t	        |j                               }t        j                  dt        fdt        fdt        dffdt        fdt        |ffg      }t        j                  |d      }|j                  ||j                  z  t        j                  t              j                  z  k7  rt        d| d      |r|j                          |j                  |      S )a   Read SIFT or SURF features from externally generated file.

    This routine reads SIFT or SURF files generated by binary utilities from
    http://people.cs.ubc.ca/~lowe/keypoints/ and
    http://www.vision.ee.ethz.ch/~surf/.

    This routine *does not* generate SIFT/SURF features from an image. These
    algorithms are patent encumbered. Please use :obj:`skimage.feature.CENSURE`
    instead.

    Parameters
    ----------
    filelike : string or open file
        Input file generated by the feature detectors from
        http://people.cs.ubc.ca/~lowe/keypoints/ or
        http://www.vision.ee.ethz.ch/~surf/ .
    mode : {'SIFT', 'SURF'}, optional
        Kind of descriptor used to generate `filelike`.

    Returns
    -------
    data : record array with fields
        - row: int
            row position of feature
        - column: int
            column position of feature
        - scale: float
            feature scale
        - orientation: float
            feature orientation
        - data: array
            feature values

    TFSIFTrowcolumnscaleorientationdataSURF   second_moment   sign )sepzInvalid z feature file.)
isinstancestropenmapintreadlinesplitnpdtypefloatfromfilesizeitemsizeOSErrorcloseview)filelikemodeffilelike_is_strnr_featuresfeature_lendatatyper   s           N/var/www/html/test/engine/venv/lib/python3.12/site-packages/skimage/io/sift.py
_sift_readr+      sh   F (C Nv~#&sAJJL,>,>,@#A [885!% &%-.
 !**,'!+!**,'885! 5!*-%-.
 ;;qc"DyyK("3"33bhhuo6N6NNNn566 		99X    c                     t        | d      S )Nr   r$   r+   r%   s    r*   r   r   T       af%%r,   c                     t        | d      S )Nr   r.   r/   r0   s    r*   r   r   X   r1   r,   )r   )numpyr   __all__r+   r   r   __doc__ r,   r*   <module>r7      sA    
$K\&& &&	 &&	 r,   