
    (ph5                         S r SSKJr  SSKJrJr  SSKJrJr  SSK	J
r
Jr  / SQr\SS j5       rSS	 jr\SS j5       r\SS
S.S jj5       r\     SS j5       r\SS j5       rg)z7
Module for reading and writing matlab (TM) .mat files
    )contextmanager   )_get_matfile_version	docfiller)MatFile4ReaderMatFile4Writer)MatFile5ReaderMatFile5Writer)loadmatsavematwhosmatc              #      #    [        XU5      u  p4 Uv   U(       a  UR                  5         g g ! U(       a  UR                  5         f f = f7f)N)
_open_fileclose)	file_like	appendmatmodefopeneds        G/var/www/html/venv/lib/python3.13/site-packages/scipy/io/matlab/_mio.py_open_file_contextr      s?     96IAGGI 6GGI s   A/ AA		Ac                    [        U5      [        S5      -  (       a  S1O	[        5       n[        U5      [        S5      -  (       a  UR                  S5        UR                  [        U 5      5      (       a  U S4$  [	        X5      S4$ ! [
         aZ  n[        U [        5      (       a4  U(       a  U R                  S5      (       d  U S-  n [	        X5      S4s SnA$ [        S	5      UeSnAff = f)
z
Open `file_like` and return as file-like object. First, check if object is
already file-like; if so, return it as-is. Otherwise, try to pass it
to open(). If that fails, and `file_like` is a string, and `appendmat` is true,
append '.mat' and try again.
zr+readzwax+writeFTz.matNz/Reader needs file name or open file-like object)	setaddissubsetdiropenOSError
isinstancestrendswith)r   r   r   reqses        r   r   r      s     4y3t9,F8#%D
4y3v;}}S^$$%I$d** 	i%%!3!3F!;!;V#		($..A	s%   ;B 
C,AC'C,C''C,Tc                     [        X5      u  p4[        U5      u  pVUS:X  a  [        U40 UD6U4$ US:X  a  [        U40 UD6U4$ US:X  a  [	        S5      e[        SU 35      e)aX  
Create reader for matlab .mat format files.

Parameters
----------
%(file_arg)s
%(append_arg)s
%(load_args)s
%(struct_arg)s

Returns
-------
matreader : MatFileReader object
   Initialized instance of MatFileReader class matching the mat file
   type detected in `filename`.
file_opened : bool
   Whether the file was opened by this routine.

r   r      z6Please use HDF reader for matlab v7.3 files, e.g. h5pyzDid not recognize version )r   r   r   r	   NotImplementedError	TypeError)	file_namer   kwargsbyte_streamfile_openedmjvmnvs          r   mat_reader_factoryr0   4   s    *  *)?K#K0HC
axk4V4kAA	k4V4kAA	! #5 6 	6 4SE:;;    N)spmatrixc                v   UR                  SS5      n[        X5       n[        U40 UD6u  pxUR                  U5      n	SSS5        U(       aC  SSKJn
Jn  [        W	R                  5       5       H  u  pU
" U5      (       d  M  U" U5      X'   M      Ub  UR                  W	5        U$ W	nU$ ! , (       d  f       Nr= f)a\  
Load MATLAB file.

Parameters
----------
file_name : str
   Name of the mat file (do not need .mat extension if
   appendmat==True). Can also pass open file-like object.
mdict : dict, optional
    Dictionary in which to insert matfile variables.
appendmat : bool, optional
   True to append the .mat extension to the end of the given
   filename, if not already present. Default is True.
spmatrix : bool, optional (default: True)
    If ``True``, return sparse ``coo_matrix``. Otherwise return ``coo_array``.
    Only relevant for sparse variables.
byte_order : str or None, optional
   None by default, implying byte order guessed from mat
   file. Otherwise can be one of ('native', '=', 'little', '<',
   'BIG', '>').
mat_dtype : bool, optional
   If True, return arrays in same dtype as would be loaded into
   MATLAB (instead of the dtype with which they are saved).
squeeze_me : bool, optional
   Whether to squeeze unit matrix dimensions or not.
chars_as_strings : bool, optional
   Whether to convert char arrays to string arrays.
matlab_compatible : bool, optional
   Returns matrices as would be loaded by MATLAB (implies
   squeeze_me=False, chars_as_strings=False, mat_dtype=True,
   struct_as_record=True).
struct_as_record : bool, optional
   Whether to load MATLAB structs as NumPy record arrays, or as
   old-style NumPy arrays with dtype=object. Setting this flag to
   False replicates the behavior of scipy version 0.7.x (returning
   NumPy object arrays). The default setting is True, because it
   allows easier round-trip load and save of MATLAB files.
verify_compressed_data_integrity : bool, optional
    Whether the length of compressed sequences in the MATLAB file
    should be checked, to ensure that they are not longer than we expect.
    It is advisable to enable this (the default) because overlong
    compressed sequences in MATLAB files generally indicate that the
    files have experienced some sort of corruption.
variable_names : None or sequence
    If None (the default) - read all variables in file. Otherwise,
    `variable_names` should be a sequence of strings, giving names of the
    MATLAB variables to read from the file. The reader will skip any
    variable with a name not in this sequence, possibly saving some read
    processing.
simplify_cells : False, optional
    If True, return a simplified dict structure (which is useful if the mat
    file contains cell arrays). Note that this only affects the structure
    of the result and not its contents (which is identical for both output
    structures). If True, this automatically sets `struct_as_record` to
    False and `squeeze_me` to True, which is required to simplify cells.
uint16_codec : str, optional
    The codec to use for decoding characters, which are stored as uint16
    values. The default uses the system encoding, but this can be manually
    set to other values such as 'ascii', 'latin1', and 'utf-8'. This
    parameter is relevant only for files stored as v6 and above, and not
    for files stored as v4.

Returns
-------
mat_dict : dict
   dictionary with variable names as keys, and loaded matrices as values.

Notes
-----
v4 (Level 1.0), v6 and v7 to 7.2 matfiles are supported.

You will need an HDF5 Python library to read MATLAB 7.3 format mat
files. Because SciPy does not supply one, we do not implement the
HDF5 / 7.3 interface here.

Examples
--------
>>> from os.path import dirname, join as pjoin
>>> import scipy.io as sio

Get the filename for an example .mat file from the tests/data directory.

>>> data_dir = pjoin(dirname(sio.__file__), 'matlab', 'tests', 'data')
>>> mat_fname = pjoin(data_dir, 'testdouble_7.4_GLNX86.mat')

Load the .mat file contents.

>>> mat_contents = sio.loadmat(mat_fname, spmatrix=False)

The result is a dictionary, one key/value pair for each variable:

>>> sorted(mat_contents.keys())
['__globals__', '__header__', '__version__', 'testdouble']
>>> mat_contents['testdouble']
array([[0.        , 0.78539816, 1.57079633, 2.35619449, 3.14159265,
        3.92699082, 4.71238898, 5.49778714, 6.28318531]])

By default SciPy reads MATLAB structs as structured NumPy arrays where the
dtype fields are of type `object` and the names correspond to the MATLAB
struct field names. This can be disabled by setting the optional argument
`struct_as_record=False`.

Get the filename for an example .mat file that contains a MATLAB struct
called `teststruct` and load the contents.

>>> matstruct_fname = pjoin(data_dir, 'teststruct_7.4_GLNX86.mat')
>>> matstruct_contents = sio.loadmat(matstruct_fname)
>>> teststruct = matstruct_contents['teststruct']
>>> teststruct.dtype
dtype([('stringfield', 'O'), ('doublefield', 'O'), ('complexfield', 'O')])

The size of the structured array is the size of the MATLAB struct, not the
number of elements in any particular field. The shape defaults to 2-D
unless the optional argument `squeeze_me=True`, in which case all length 1
dimensions are removed.

>>> teststruct.size
1
>>> teststruct.shape
(1, 1)

Get the 'stringfield' of the first element in the MATLAB struct.

>>> teststruct[0, 0]['stringfield']
array(['Rats live on no evil star.'],
  dtype='<U26')

Get the first element of the 'doublefield'.

>>> teststruct['doublefield'][0, 0]
array([[ 1.41421356,  2.71828183,  3.14159265]])

Load the MATLAB struct, squeezing out length 1 dimensions, and get the item
from the 'complexfield'.

>>> matstruct_squeezed = sio.loadmat(matstruct_fname, squeeze_me=True)
>>> matstruct_squeezed['teststruct'].shape
()
>>> matstruct_squeezed['teststruct']['complexfield'].shape
()
>>> matstruct_squeezed['teststruct']['complexfield'].item()
array([ 1.41421356+1.41421356j,  2.71828183+2.71828183j,
    3.14159265+3.14159265j])
variable_namesNr   )issparse
coo_matrix)
popr   r0   get_variablesscipy.sparser5   r6   listitemsupdate)r*   mdictr   r2   r+   r4   r   MR_matfile_dictr5   r6   namevars                 r   r   r   V   s    d ZZ 0$7N	I	1Q"1//''7 
2 5l0023ID}}%/_" 4 \" L L 
2	1s    B**
B8c           	          [        XS5       nUS:X  a   U(       a  Sn[        U5      e[        Xv5      n	OUS:X  a  [        UUSUUS9n	O[        S5      eU	R	                  U5        SSS5        g! , (       d  f       g= f)	a  
Save a dictionary of names and arrays into a MATLAB-style .mat file.

This saves the array objects in the given dictionary to a MATLAB-
style .mat file.

Parameters
----------
file_name : str or file-like object
    Name of the .mat file (.mat extension not needed if ``appendmat ==
    True``).
    Can also pass open file_like object.
mdict : dict
    Dictionary from which to save matfile variables.
appendmat : bool, optional
    True (the default) to append the .mat extension to the end of the
    given filename, if not already present.
format : {'5', '4'}, string, optional
    '5' (the default) for MATLAB 5 and up (to 7.2),
    '4' for MATLAB 4 .mat files.
long_field_names : bool, optional
    False (the default) - maximum field name length in a structure is
    31 characters which is the documented maximum length.
    True - maximum field name length in a structure is 63 characters
    which works for MATLAB 7.6+.
do_compression : bool, optional
    Whether or not to compress matrices on write. Default is False.
oned_as : {'row', 'column'}, optional
    If 'column', write 1-D NumPy arrays as column vectors.
    If 'row', write 1-D NumPy arrays as row vectors.

Examples
--------
>>> from scipy.io import savemat
>>> import numpy as np
>>> a = np.arange(20)
>>> mdic = {"a": a, "label": "experiment"}
>>> mdic
{'a': array([ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,
    17, 18, 19]),
'label': 'experiment'}
>>> savemat("matlab_matrix.mat", mdic)
wb4z6Long field names are not available for version 4 files5T)do_compressionunicode_stringslong_field_namesoned_aszFormat should be '4' or '5'N)r   
ValueErrorr   r
   put_variables)
r*   r=   r   formatrI   rG   rJ   file_streammessageMWs
             r   r   r      s|    d 
I$	7;S=R ))5Bs]/=041A(/	1B :;;
 
8	7	7s   AA--
A;c                     [        X5       n[        U40 UD6u  pEUR                  5       nSSS5        U$ ! , (       d  f       W$ = f)a  
List variables inside a MATLAB file.

Parameters
----------
%(file_arg)s
%(append_arg)s
%(load_args)s
%(struct_arg)s

Returns
-------
variables : list of tuples
    A list of tuples, where each tuple holds the matrix name (a string),
    its shape (tuple of ints), and its data class (a string).
    Possible data classes are: int8, uint8, int16, uint16, int32, uint32,
    int64, uint64, single, double, cell, struct, object, char, sparse,
    function, opaque, logical, unknown.

Notes
-----
v4 (Level 1.0), v6 and v7 to 7.2 matfiles are supported.

You will need an HDF5 python library to read matlab 7.3 format mat
files (e.g. h5py). Because SciPy does not supply one, we do not implement the
HDF5 / 7.3 interface here.

.. versionadded:: 0.12.0

Examples
--------
>>> from io import BytesIO
>>> import numpy as np
>>> from scipy.io import savemat, whosmat

Create some arrays, and use `savemat` to write them to a ``BytesIO``
instance.

>>> a = np.array([[10, 20, 30], [11, 21, 31]], dtype=np.int32)
>>> b = np.geomspace(1, 10, 5)
>>> f = BytesIO()
>>> savemat(f, {'a': a, 'b': b})

Use `whosmat` to inspect ``f``.  Each tuple in the output list gives
the name, shape and data type of the array in ``f``.

>>> whosmat(f)
[('a', (2, 3), 'int32'), ('b', (1, 5), 'double')]

N)r   r0   list_variables)r*   r   r+   r   MLr-   	variabless          r   r   r   =  sL    h 
I	1Q,Q9&9%%'	 
2  
2	1 s	   5
A)rb)T)NT)TrF   FFrow)__doc__
contextlibr   _miobaser   r   _mio4r   r   _mio5r	   r
   __all__r   r   r0   r   r   r    r1   r   <module>r^      s   
 & 5 1 1
+  6 < <B `t ` `F " ?  ? D 6 6r1   