
    (ph                     d   S SK r S SKJr  S SKJrJr  S SKJr  S SKJ	r	  S SK
r
S SKJr  S SKrS SKrS SKrS SKJrJrJrJrJrJr  S SKrS SKJr  S SKrS S	KJr  S S
KJrJrJ r J!r!  S SK"r#S SK$J%r%J&r&J'r'  S SK(Js  J)s  J*r+  S SK,J-r-J.r.J/r/J0r0  S SK1J2r2J3r3J4r4J5r5  S SK6J7r7J8r8J9r9J:r:J;r;  S SK<Js  J)s  J=r>  S SK?J@r@  \" \" \A5      S5      rB\R                  R                  rES rF\R                  S-  \R                  " S\IS9R                  SS5      -  rKSSS0S\K0S./rL\LR                  SSS0S\" S/5      0S.5        \LR                  SSS0S\R                  " \K5      S\R                  " \K5      -  -   0S.5        \R                  " S 5      rQ\R" \S" SS!5      5      \QS '   \R" \S" SS5      5      \QSS2S 4'   \LR                  S"S#S0S#\Q0S.5        \LR                  S$S%S$0S%\ " \Q5      0S.5        \QR                  \U5      rV\VS&==   S-  ss'   \LR                  S'S(S$0S(\ " \V5      0S.5        \LR                  S)SSS*.\K\QS*.S.5        \LR                  S+S,S0S,\F" S-5      0S.5        \LR                  S.S/S0S/\" S0/5      0S.5        \F" / \F" S/5      \F" SS1//5      \F" / S2Q/5      4\WS9R                  SS-5      rX\" S3/5      \XS&'   S4S5S40S5\X0S./rY\F" \F" S5      \F" S15      \F" / 5      \F" / 5      \F" S65      4\WS9R                  SS-5      rZ\R                  " S7\WS9r\\F" S5      \\S&'   \YR                  S8S9S40S9\\0S.5        \YR                  S:S;S40S;\Z0S.5        \YR                  S<S=S0S=\" / S>Q5      0S.5        \YR                  S?S@S0S@\R                  " \R                  " \R" \S" SSA5      5      SB5      5      0S.5        \" \R                  " S15      \R                  " S5      \R                  /5      R                  SS65      r`SC V s/ s H  o \W4PM     sn ra\R                  " S7\a5      rb\" SD/5      \bSE   S&'   \`\bSF   S&'   \`SG-  \bSH   S&'   \YR                  SISJSI0SJ\b0S.5        \R                  " SK\WS9rc\F" S5      \cS&'   \R                  " SL\WS9\cSM'   \F" S1\R                  S9\cSM   S&'   \F" S6//\R                  S9\cSM   SM'   \R                  " SK\WS9\cSM   SN'   \F" S\R                  S9\cSM   SN   S&'   \F" SO\R                  S9\cSM   SN   SM'   \YR                  SPSQS40SQ\c0S.5        \R                  " S7SR V s/ s H  o \W4PM     sn S9re\F" S5      \eS&   SS'   \R                  " S7ST\W4/S9\eS&   SU'   \" SV/5      \eS&   SU   S&   ST'   \YR                  SWSXSI0SX\e0S.5        \R                  " SKSR V s/ s H  o \W4PM     sn S9rf\F" S5      \fS&   SS'   \F" S15      \fS&   SU'   \" SY/5      \fSM   SS'   \" SZ/5      \fSM   SU'   \YR                  S[S\SI0S\\f0S.5        \R                  " S] V s/ s H  o \W4PM     sn 5      rg\'" \R                  " S7\gS9S^5      rh\hS&   ri\" S_/5      \iS`'   \" Sa/5      \iSb'   \" S_/5      \iSc'   \F" S 5      \iSd'   \F" S5      \iSe'   \F" S5      \iSf'   \YR                  SgShSg0Sh\h0S.5        \j" \" \BSi5      Sj5      rk\kR                  5       R                  Sk5      rn\kR                  5         \YR                  SlSmS0Sm\" \n/5      0S.5        \YR                  S$S%S$0S%\ " \Q5      0S.5        \YR                  S'S(S$0S(\ " \V5      0S.5        \YR                  SnSoSp0So\" Sq/Sr//5      0S.5        \YSS rp\pR                  SsStSg0St\R                  " \hS15      R                  SS15      0S.5        Su rrSv rsSw rtSx ruSy rvSSz jrw\R                  R                  SfS{5      S| 5       ry\R                  R                  SfS{5      S} 5       rz\R                  R                  S~SSS/4SS/4/5      S 5       r{S r|S r}S r~S rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS r\R                  R                  S/ SQ5      S 5       rS rS rS rS rS rS rS rS rgs  sn f s  sn f s  sn f s  sn f )    N)OrderedDict)joindirname)glob)BytesIO)mkdtemp)assert_array_equalassert_array_almost_equalassert_equalassert_assert_warnsassert_allclose)raises)array)issparse	eye_array	coo_array	csc_array)MatlabOpaqueMatlabFunctionMatlabObject)matdimsMatWriteErrorMatReadErrormatfile_version)mat_reader_factoryloadmatsavematwhosmat)MatFile5WriterMatFile5Readervarmats_from_matto_writeableEmptyStructMarker)VisibleDeprecationWarningdatac                  R    [         R                  " U 0 UD6n[        U5      Ul        U$ )z;Convenience function to return matlab-compatible 2-D array.)npr   r   shape)argskwargsarrs      Q/var/www/html/venv/lib/python3.13/site-packages/scipy/io/matlab/tests/test_mio.pymlarrr.   '   s%    
((D
#F
#CCIJ       	   dtype   double
testdouble)nameclassesexpectedstring
teststringcharz+"Do nine men interpret?" "Nine men," I nod.complextestcomplexy              ?)         matrix
testmatrixsparse
testsparser   r   sparsecomplextestsparsecomplexmulti)thetaaminus	testminusonechartestonecharr   )r4   rR   r?   z@This cell contains this string and 3 arrays of increasing lengthcelltestcellr?   r4   r4   
scalarcelltestscalarcell	emptycelltestemptycellstringarrayteststringarray)zone  ztwo  three3dmatrixtest3dmatrix   )r0   r?   rR   )stringfielddoublefieldcomplexfieldzRats live on no evil star.r`   ra   y      ?      ?rb   struct
teststructr4   rR   )r4   r?   r   r4   )r   rR   r@   cellnesttestcellnestonetworj   r\   rk   znumber 3
structnestteststructnestznumber 1znumber 2	structarrteststructarr)expr	inputExprr*   isEmptynumArgsversioninlinexrp   z x = INLINE_INPUTS_{1};rq   r*   rr   rs   rt   object
testobjectzjapanese_utf8.txtrbzutf-8unicodetestunicodebool	testboolslogicalTFobjectarraytestobjectarrayc                 2   [        U 5      n[        U5      nX#L a  gU[        R                  L a+  U R                  S:X  a  [        U R	                  5       5      UL $ U[        R                  L a+  UR                  S:X  a  [        UR	                  5       5      UL $ g)zcCheck if types are same or compatible.

0-D numpy scalars are compatible with bare python scalars.
T F)typer(   ndarrayr)   item)var1var2type1type2s       r-   types_compatibler      s{    
 JEJE~

tzzR/DIIK E))

tzzR/DIIK E))r/   c           	         [        U5      (       a=  [        [        U5      5        [        UR                  5       UR                  5       U SS9  g[        [	        X5      S[        U5       S[        U5       SU  35        [        U[        R                  [        R                  -  [        -  5      (       d  [        X5        g[        UR                  UR                  :H  SUR                   SUR                   SU  3S9  UR                  nUR                  (       a^  [        U[        5      (       a   [        UR                  UR                  5        [!        U5       H  u  pES	X4-  n[#        XeX$   5        M     gUR$                  (       a-  UR$                   H  nU  S
U S3n[#        UX   X'   5        M     gUR
                  [&        [        R(                  [        R*                  4;   a  [        X!U S9  g[        X!U SS9  g)z.Check one level of a potentially nested array r@   )err_msgdecimalNzExpected type z, got z at zExpected shape )msgz
%s, [%d], z, field z, r   )r   r   r
   toarrayr   r   
isinstancer(   voidr   r   r   r)   r3   	hasobject	classname	enumerate_check_levelfieldsstrstr_bool_)labelr9   actualex_dtypeievlevel_labelfns           r-   r   r      s    !!&.."2"*"2"2"4*/*+	- 	X.T(^,F4<.UGLN h"** 4| CDDX&HNNfll*!(..!1~T%QS~~Hh--++V-=-=>x(EA&%3K&)4 ) 	//B"G8B4r2K!vz3 " 	}}# # 	Vu5fqIr/   c                     U HU  n[        USSS9nSU  SU 3nUR                  5        H+  u  pgU SU 3n[        Xd;   SU 35        [        XXF   5        M-     MW     g )NTFstruct_as_recordspmatrixtest ; file z, variable zMissing key at )r   itemsr   r   )	r7   filescase	file_namematdictr   kr9   k_labels	            r-   _load_check_caser   #  sm    	)dUKvWYK0::<KA{1#.GALOG9"=>GJ7 ( r/   c           
         U H~  nSU  SU 3n[        U5      nUR                  5        VVs/ s H  u  pxXxR                  X7   4PM     n	nnUR                  5         U	R                  5         [	        XiU SU< SU	< 35        M     g s  snnf )Nr   r   z: z != )r   r   r)   sortr   )
r7   r   r   r8   r   r   whosr   r9   expected_whoss
             r-   _whos_check_caser   -  s    	vWYK0y! @Dzz|M?KQ
+| 	 M 			Twb],=>	 
Ms   Bc                 h    [        5       n[        X1US9  UR                  S5        [        X/U5        g )Nformatr   )r   r   seekr   )r7   r9   r   
mat_streams       r-   _rt_check_caser   >  s+    JJ0OOAT<2r/   c           	   #   &  #    U S:X  a  [         nOU S:X  a  [        nOU S:X  d   e[        nU H_  nUS   nUS   nUc  S nOA[        [        U[        US9-  5      n[        U5      n[        U5      S:  d   SU S	U 35       eUS
   nXFXX4v   Ma     g 7f)N455_rtr7   r9   )r7   r   zNo files for test  using filter r8   )case_table4case_table5case_table5_rtpjointest_data_pathdictr   len)	rt   filtcasesr   r7   r9   r   use_filtr8   s	            r-   _casesr   F  s     #~	C&   F|
#<E^TDdO-CDHNEu:> @$TF.?@>y/8,, s   BBr   r   c                 >    [        U 5       H  n[        US S 6   M     g )Nr?   )r   r   rt   r   s     r-   	test_loadr   \  s    w$r(#  r/   c                 8    [        U 5       H  n[        U6   M     g N)r   r   r   s     r-   	test_whosr   b  s    w$  r/   zversion, fmtsr   r   r   c                 ^    [        U S S9 H  nU H  n[        US   US   U5        M     M!     g )N)r   r   rR   )r   r   )rt   fmtsr   fmts       r-   test_round_tripr   i  s3    
 wT*C47DGS1  +r/   c                  "   [         R                  " S5      n SU S'   SU S'   [        U 5      nSnSU0nSn[        5       n [	        XR5      n[
        R                  " US	S
9n[        XsUS9  UR                  5         [
        R                  " USS
9n[        USSS9nUR                  5         [        R                  " U5        [        US   R                  5       US   R                  5       [        U5      S9  g ! [        R                  " U5        f = f)N)   r   gffffff@rR   r?   g      @)r0   r@   	gzip_testrv   r   wb)moder   ry   TFr   r   )r(   zerosr   r   r   gzipopenr   closer   shutilrmtreer
   r   repr)	xdenserv   r7   r9   r   tmpdirfnamer   r   s	            r-   test_gzip_simpler   s  s    XXgFF3KF3K&ADAwHFYF
f"YYu40

V4YYu40
dUKffSk113&sm335&*6l4 	fs   A*C6 6Dc                  H   [        5       n  [        [        R                  " S5      S9n[	        U S5      n[        X!5        [        R                  " U5        [        X!5        [        U5        [        R                  " U5        [        US5      n[        X15        UR                  S5        UR                  5         [        US5      n[        U5        UR                  S5        UR                  5         [        R                  " U 5        g ! [        R                  " U 5        f = f)N)rR   rR   rv   za.matr   r   ry   )r   r   r(   r   r   r   osunlinkr   r   r   r   r   r   )r   rv   r   fs       r-   test_multiple_openr     s    YF288F#$fg& 	
		%
		% 	q			
	q			ffs   C&D	 	D!c                      [        [        [        S5      5      n [        [	        U 5      S:  5        U  H3  n[        US5      n[        [        [        USS9  UR                  5         M5     g )Nztesthdf5*.matr   ry   Tr   )
r   r   r   r   r   r   assert_raisesNotImplementedErrorr   r   )	filenamesfilenamefps      r-   
test_mat73r     s\    no.0IC	NQ(D!)'+	- 	
 r/   c                      [        [        S5      n [        R                  " 5          [        R                  " S5        [        U SS9  [        U SS9  S S S 5        g ! , (       d  f       g = f)Nztestdouble_7.1_GLNX86.materrorTr   F)r   r   warningscatch_warningssimplefilterr   )r   s    r-   test_warningsr     sK     ."=>E		 	 	"g&-. 
#	"	"s   +A
A(c                      [        5       n [        U SSS00SS9  [        U 5      S   n[        UR                  S5        [        UR
                  [        R
                  " [        5      5        [        US   S L 5        g )Ndr4   rR   r   r   rU   rF   	r   r   r   r   r)   r3   r(   rw   r   )siobacks     r-   test_regression_653r     sc     )CC#qeS)3<DU#RXXf-.DIr/   c                      Sn SU -  n[         R                  " SU[        4/S9n[        [	        5       SU0SS9  SU S-   -  n[         R                  " SU[        4/S9n[        [        [        [	        5       SU0SS9  g )	N   rK   rU   r2   
longstructr   r   r4   r(   r   rw   r   r   r   
ValueErrorlimfldnamest1s      r-   test_structname_lenr
    sz    
CCiG
((5'6!2 3
4CGIc*37SUmG
((5'6!2 3
4C*gwy%c3r/   c            	      |    [         R                  " SS[        4/S9n [        [        [
        [        5       SU 0SSS9  g )NrU   my_fieldnamer2   	my_structr   Tr   long_field_names)r(   r   rw   r   r  r   r   )r  s    r-   (test_4_and_long_field_names_incompatibler    s7    ~f&=%>?I*gwyy)#Nr/   c            	          Sn SU -  n[         R                  " SU[        4/S9n[        [	        5       SU0SSS9  SU S	-   -  n[         R                  " SU[        4/S9n[        [        [        [	        5       SU0SSS9  g )
N?   rK   rU   r2   r  r   Tr  r4   r  r  s      r-   test_long_field_namesr    s    
CCiG
((5'6!2 3
4CGIc*3MSUmG
((5'6!2 3
4C*gwy%c4Ir/   c            	          Sn SU -  n[         R                  " S[        S9n[         R                  " SU[        4/S9nX2S'   X2S'   [	        [        5       SU0S	S
S9  [        [        [        [        5       SU0S	SS9  g )Nr  rK   re   r2   rU   rF   rf   r  r   Tr  F)r(   r   rw   r   r   r   r   r  )r  r  rS   r	  s       r-   test_long_field_names_in_structr    s|     CCiG::e&)D
((5'6!2 3
4CIIGId+CN *gwy&sULr/   c                      [         R                  " S[        S9n SU S'   SU S'   [        [	        5       SU 0SS	9  [         R                  " S
[        S9n SU S'   [        [	        5       SU 0SS	9  g )Nre   r2   HellorF   Worldrf   rv   r   r   rU   zHello, world)r(   r   rw   r   r   )cellss    r-   test_cell_with_one_thing_in_itr    sc     JJu6*EE#JE#JGIU|C0JJu6*EE#JGIU|C0r/   c                  `   [        [        5       5      n [        U R                  / 5        S/U l        [        U R                  S/5        [        U R                  S5        SU l        [        U R                  S5        [        U R
                  S5        SU l        [        U R
                  S5        g )NavarFT)r    r   r   global_varsunicode_stringsr  )mfws    r-   test_writer_propertiesr     s    

#C"%hCO6(+$$e,C$$d+%%u-C%%t,r/   c                  &   [        5       n [        U 5      n[        R                  " S5      nUR	                  SU05        [        U R                  5       5      nU R                  S5        U R                  S5        UR	                  SU05        [        U[        U R                  5       5      -
  S:  5        U R                  S5        U R                  S5        UR	                  SU05        [        [        U R                  5       5      U-
  S:  5        g )N
   aaaaar   aaaar0   aaaaaa)
r   r    r(   r   put_variablesr   getvaluetruncater   r   )r   wtrr,   w_szs       r-   test_use_small_elementr+    s    
)C

C
((2,Cwn%s||~DLLOHHQKvsm$D3s||~&&*+LLOHHQKxo&C$&*+r/   c                  L   [         R                  " S//S[        4S[        4/S9n [        [        4 Ho  nU" SS/5      n[        5       n[        USU05        UR                  S5        [        U5      S   n[        UR                  R                  S	5        [        X@5        Mq     g )
Nre   rK   br2   )rK   r4   )r-  rR   r   r   rK   r-  )r(   r   rw   r   r   r   r   r   r   r   r3   namesr	   )ab_exp	dict_typer   streamvalss        r-   test_save_dictr4  3  s     XXxj#vf(FGFK(	x*+$Avv&TZZ%%z24( )r/   c                     [         R                  " S5      n S H  n[        5       n[        USU 0US9  [	        U5      n[        US   R                  S5        [        5       n[        USU 0USS9  [	        U5      n[        US   R                  S5        [        5       n[        USU 0US	S9  [	        U5      n[        US   R                  S5        M     g )
Nr@   r   onedr   )r4   r@   column)r   oned_as)r@   r4   row)r(   aranger   r   r   r   r)   )r,   r   r2  r3  s       r-   test_1d_shaper;  B  s    
))A,Cf5vT&\''0 	" vT&\''/	 vT&\''/' r/   c                     [         R                  " S5      R                  S5      n SU S'   [        5       n[	        USU 05        [        UR                  5       5      n[        U5      n[        US   U 5        [        5       n[	        USU 0SS9  [        UR                  5       5      n[        U5      n[        US   U 5        [        X$:  5        U R                  5       nSUS'   [        5       n[	        XUS	.S
S9  [        U5      n[        US   U5        [        5       n[	        XUS	.SS9  [        U5      n[        US   U5        g )Nd   )r@   r   r4   )rR   r"  r,   T)do_compressionrF   )r,   arr2Fr?  )r(   r   reshaper   r   r   r'  r   r	   r   copy)r,   r2  raw_lenr3  compressed_lenr?  s         r-   test_compressionrD  [  s   
((3-


'CCIYFFU3K &//#$G6?DtE{C(YFFU3K5*+N6?DtE{C(G$%88:DDIYFFt,UC6?DtF|T*YFFt,TB6?DtF|T*r/   c            	      b    [        5       n [        U S[        R                  " S[        S905        g )NAr4   r2   )r   r   r(   r   rw   )r2  s    r-   test_single_objectrG  v  s#    YFFS!6234r/   c                      [        [        S5      n [        U SS9n[        SU;   5        [        SU;   5        [	        U SS9u  p#UR                  S5      n[        SU;   5        UR                  R                  5         g )Nztest_skip_variable.matTr   firstsecond)r   r   r   r   r   get_variablesr   r   )r   r   factoryfile_openeds       r-   test_skip_variablerN  {  sx     ^$<=H 	40AGqLHM .hNG 	h'AHMr/   c                  z   [        [        S5      n [        U SS9nUS   n[        UR                  S5        [        UR
                  [        R
                  " [        5      5        [        US   S L 5        [        5       n[        R                  " SSS	9n[        US
U05        [        U5      nUS
   n[        XT5        g )Nztest_empty_struct.matTr   rK   rU   rF   r   Ur2   r,   )r   r   r   r   r)   r3   r(   rw   r   r   r   r   r	   )r   r   rK   r2  r,   a2s         r-   test_empty_structrR    s    ^$;<H 	40A	#A% "((6*+AcFdNYF
((2S
!CFU3K A	
5Brr/   c                      [        5       n [        U S0 05        [        U 5      nUS   n[        UR                  S5        [        UR
                  [        R
                  " [        5      5        [        US   S L 5        g )Nr,   rU   rF   r   )r2  r   rK   s      r-   test_save_empty_dictrT    s^    YFFUBK A	%A% "((6*+AcFdNr/   c                 r    SnU H$  n[         R                  " X:H  5      (       d  M"  Sn  O   [        U5        g)zGAssert `output` is equal to at least one element in `alternatives`
    FTN)r(   allr   )outputalternatives	one_equalr9   s       r-   assert_any_equalrZ    s7     I 66&$%%I ! Ir/   c                     [        [        R                  " S/5      5      n [        U R                  S5        [        U S5        [        R                  " S/SS/S9n[        R                  " S/SS/S9nX4n[        [        SSS	.5      U5        [        [        SSS
S.5      U5        [        [        SSS
S.5      U5        [        [        SSS
S.5      U5         " S S5      nUnSUl        SUl        [        [        U5      U5        [        / 5      n [        U R                  S5        [        U R                  R                  [        R                  5        [        S5      n [        U R                  S5        [        U R                  R                  [        R                  5        [        [        S 5      S L 5        [        [        S5      R                  R                  [        R                  5        [        S5      n [        U R                  S5        [        U R                  R                  [        R                  " S5      R                  R                  5        [        U S5        [        [        0 5      [        L 5        [        [        [        5       5      S L 5         " S S5      n[        [        U" 5       5      [        L 5        [        SS05      S   n [        U R                  S5        [        U R                  R                  [        R                   5        [        [        SS05      [        L 5        [        [        SS05      [        L 5        [        [        SSS.5      [        R                  " S/S/S95        g )Nr4   )r4   re   )rK   |O8)r-  r\  r2   )rR   r4   rR   r.  r?   )rK   r-  _c)rK   r-  r=  )rK   r-  99c                       \ rS rSrSrg) test_to_writeable.<locals>.klassi  r   N__name__
__module____qualname____firstlineno____static_attributes__r   r/   r-   klassr`        r/   rg  r   r   a stringc                       \ rS rSrSrg)test_to_writeable.<locals>.Ci  r   Nra  r   r/   r-   Crl    rh  r/   rm  rK   1_a)rn  r   rR   )r   r\  )r#   r(   r   r   r)   r	   rZ  rK   r-  r3   r   float64r   r   r$   rw   object_)res	expected1	expected2rX  rg  crm  s          r-   test_to_writeablerw    s   
rxx}
%CD!sA&,)EFI&,)EFI)L\qQ-0,?\qQQ"78,G\qQA"67F\qQQ"78,G  	A
AC
AC\!_l3
r
CD!,
r
CD!,L$&'j)//44bgg>
q/CB!!2!2!7!78sAL 112L"d*+  L!223
Qx
 
%CD!,L#a!%667L$q"&77811o.4&79r/   c                  :   SS/n [         R                  " SU S9nSUS   S'   SUS   S	'   S
US   S'   SUS   S	'   [        5       n[        USU05        [	        USS9nUS   S   n[        UR                  S5        [        UR                  S5        [	        USS9nUS   S   n[        US   S5        [        US	   S5        [        UR                  [         R                  " SS/5      5        US   R                  S   n[        US   S
5        [        US	   S5        g )N)f1f8)f2S10rp  r2   g      ?r   ry  pythonr{  c   r4   znot perlr,   Fr   rF   T)ry  O)r{  r  )
r(   r   r   r   r   r   ry  r{  r3   flat)dtr,   r2  r   a20a21s         r-   test_recarrayr    s#   


B
((4r
"CCF4LCF4LCF4LCF4LYFFUCL!/A
E(3-C".A
E(3-CTC TH%BHHk&1&3 4 5
E(--
CTBTJ'r/   c                  N    " S S5      n U " 5       nSUl         SUl        [        5       n[        USU05        [	        USS9nUS   S   n[        UR                   S5        [        UR                  S5        [	        US	S9nUS   S   n[        US
   S5        [        US   S5        g )Nc                       \ rS rSrSrg)test_save_object.<locals>.Ci  r   Nra  r   r/   r-   rm  r    rh  r/   rm  r4   rj  rv  Fr   rF   Tfield1field2)r  r  r   r   r   r   )rm  rv  r2  r   c2s        r-   test_save_objectr    s     	AAHAHYFFS!H/A	
3BAJ'.A	
3BHq!Hz*r/   c                     [         R                  " S5      R                  SS5      n [        5       n[	        USU 05        [        U5      nUR                  5       nUS   n[        X@5        [        USS9n[        UR                  5       S   U R                  S5      5        SUl        [        X@5        [        U[        R                  S9n[        UR                  5       S   U 5        [        U[        R                  S9n[        [        UR                  5        [        R                  Ul        [        UR                  5       S   U 5        [         R                  " S	/5      n UR!                  S
5        UR#                  S
5        [	        USU 05        [        U5      n[        UR                  5       S   U 5        [        USS9n[         R$                  " [         R                  " ['        U R)                  5       5      SS95      n[        UR                  5       S   U5        SUl        [        UR                  5       S   U 5        g )NrA   r4   rK   T
squeeze_me)rA   F)
byte_orderrj  r   )chars_as_stringsU1r2   )r(   r:  r@  r   r   r!   rK  r	   r  bocnative_codeswapped_coder   	Exceptionr  r   r(  r   
atleast_2dlistr   r  )r,   r2  rdr	back_dictrarrcarrs         r-   test_read_optsr  .  s    ))A,

q
#CYFFS#J

 C!!#IS>Dt!
D
1Cs((*3/T1BCCNt!
COO
<Cs((*3/5 C,<,<
=C)S../__CNs((*3/5
((J<
 C
OOA
KKNFS#J

 Cs((*3/5
%
8C==$sxxz"2$?@Ds((*3/6Cs((*3/5r/   c            	         [        [        S5      n [        U S5      n[        U5      nUR	                  5       nUR                  5         [        US   [        R                  " / SS95        [        5       n[        US[        R                  " S/5      05        [        U5      nUR	                  5       n[        US   [        R                  " / SS95        UR                  S5        UR                  S5        [        US[        R                  " / SS905        [        U5      nUR	                  5       n[        US   [        R                  " / SS95        UR                  5         g )Nzsingle_empty_string.matry   rK   r  r2    r   )r   r   r   r!   rK  r   r	   r(   r   r   r   r(  r   )estring_fnamer   r  r   r2  s        r-   test_empty_stringr  Q  s   .*CDM	mT	"B

CAHHJqvrxx$78 YFFS"((B4.)*

 CAqvrxx$78
OOA
KKNFS"((2T234

 CAqvrxx$78
LLNr/   c                      SS K n [        S4U R                  S44 HH  u  p[        [	        [
        U5      S5       n[        U5      n[        XR                  5        S S S 5        MJ     g ! , (       d  f       M\  = f)Nr   corrupted_zlib_data.matzcorrupted_zlib_checksum.matry   )	zlibr  r   r   r   r   r!   r   rK  )r  excr   r   r  s        r-   test_corrupted_datar  l  se    "$=>

$ABD
%.5 $C#001 65D55s   !A((
A7	c                      [        [        [        S5      S5       n [        U SS9nUR	                  5         S S S 5        g ! , (       d  f       g = f)Nr  ry   F) verify_compressed_data_integrity)r   r   r   r!   rK  )r   r  s     r-   )test_corrupted_data_check_can_be_disabledr  u  s;    	eN$=>	ER%H 
F	E	Es	   ?
Ac            	      `   S H  n [        [        [        U 5      S5      n[        U5      nUR	                  5       nUR                  5         [        US   [        R                  " S/S//[        S95        [        US   [        R                  " SS	/S	S
//[        R                  S95        M     g )N)zbig_endian.matzlittle_endian.matry   stringshelloworldr2   floats       @      @      @)r   r   r   r!   rK  r   r	   r(   r   rw   float32)r   r   r  r   s       r-   test_read_both_endianr  {  s    8%.5R 

1Y<88gY&-Y%07=?	@ 	1X;88b"X&("X%/68jjB	C 9r/   c            	         [         R                  " SS/SS//5      n [         R                  " S5      R                  S5      n[         R                  " SS/SS	9n[	        5       n[        UU R                  5       R                  U R                  R                  5       5      UR                  5       R                  UR                  R                  5       5      UR                  5       R                  UR                  R                  5       5      S
.5        [        U5      nUR                  5       n[        US   U 5        [        US   U5        [        US   U5        UR                  5         g )Nr  r  r  rA   r   r  r  rP  r2   )r  intsuni_arrr  r  r  )r(   r   r:  r@  r   r   byteswapviewr3   newbyteorderr!   rK  r	   r   )	float_arrint_arrr  r2  r  r   s         r-   test_write_opposite_endianr    s     2r(r($ %Iiil""6*Ghh)5GYFF$$&++IOO,H,H,JK  "''(B(B(DE##%**7==+E+E+GH 
 
 CAq{I.qy'*q|W-
LLNr/   c                  R   [        [        [        S5      S5       n [        U SS9nUR	                  5       nS S S 5        [
        R                  " S/S//[
        R                  S9n[        WS   U5        [        US   R                  UR                  5        g ! , (       d  f       Nh= f)Nztestbool_8_WIN64.matry   T	mat_dtypeFr2   r}   )r   r   r   r!   rK  r(   r   r   r	   r   r3   )fobjr  r   rv   s       r-   test_logical_arrayr    s     
eN$:;T	BdTT2 
C 	4&5'""((3Aq~q);%%qww/ 
C	Bs   B
B&c                     [        5       n [        R                  " / SQ5      n[        U SU05        U R	                  S5        [        U 5      nUR                  5         UR                  5         UR                  5       u  p4[        UR                  [        R                  5        [        UR                  S5        UR                  US5      n[        UR                  R                   [        R"                  5        g )N)FTFbarrayr   TF)r   r(   r   r   r   r!   initialize_readread_file_headerread_var_headerr   mclassmio5pmxUINT8_CLASS
is_logicalread_var_arrayr3   r   uint8)r2  barrreaderhdr_vars         r-   test_logical_out_typer    s     YF88()DFXt$%
KKNF#F

##%FCU001&


U
+C*r/   c                      [        5       n [        U S[        R                  " S5      05        [	        U 5      nUS   R
                  S:X  d   eg )Nr   )r"  r   )r   r   r(   emptyr   r)   )r2  r   s     r-   test_roundtrip_zero_dimensionsr    s@    YFFS'*+,AS6<<7"""r/   c                      [        5       n [        R                  " S5      R                  S5      n[	        [
        [        U SU0SS5        g )N   )rR   r?   r0   rK   Tr   )r   r(   r:  r@  r   r  r   )r2  r,   s     r-   test_mat4_3dr    s7    YF
))B-


(C*gvSz4Er/   c                  &   [        [        S5      n [        U S5      n[        U5      nUR	                  5       nUR                  5         [        US   [        5      (       d   e[        5       n[        U5      n[        [        UR                  U5        g )Nztestfunc_7.4_GLNX86.matry   testfunc)r   r   r   r!   rK  r   r   r   r   r    r   r   r&  )func_egr   r  r   r2  r)  s         r-   test_func_readr    sv    N$=>G	gt	B

CAHHJa
m^4444YF

 C-!2!2A6r/   c                     [        [        S5      n [        U S5      n[        USS9nUR	                  5       nUR                  5         [        US   R                  R                  S5        [        U S5      n[        USS9nUR	                  5       nUR                  5         [        US   R                  R                  S5        g )	Nztestmatrix_6.1_SOL2.matry   Fr  rC   uTr   )	r   r   r   r!   rK  r   r   r3   kind)	double_egr   r  r   s       r-   test_mat_dtyper    s    n&?@I	i	B
u
-CAHHJ<&&++S1	i	B
t
,CAHHJ<&&++S1r/   c                      S[        S5      0n [        5       n[        USU 05        [        USS9n[	        US   S   S   R                  5       [        R                  " S5      5        g )Nsparsefieldr0   rK   Tr   rF   )r   r   r   r   r	   r   r(   eye)str2  r   s      r-   test_sparse_in_structr    s[     1	&BYFFSH.Aqvd|M2::<bffQiHr/   c                  f    [        5       n SSSS.0n[        X5        [        U SS9  [        U SSS9  g )	Nr  r4   rR   ri   Fr   T)r   r  )r   r   r   )r2  in_ds     r-   test_mat_struct_squeezer    s6    YF#$DFFU+FUt<r/   c                     [        5       n S//SSSS.S.n[        X5        [        U SS9n[        [	        US	   [
        5      5        [        [	        US
   [        5      5        [        [	        US   [        R                  5      5        g )N皙?zmy namer4   rR   ri   )scalarr:   r  Tr  r  r:   r  )	r   r   r   r   r   floatr   r(   r   )r2  r  out_ds      r-   test_scalar_squeezer    so    YFug9KLDFFt,EJuX./JuX,-JuT{BJJ/0r/   c                     [        5       n [        R                  " SS/5      n[        R                  " SS/5      n[        U [	        US95        [        U 5      n[        US   U5        U R                  S5        U R                  S5        UR                  SS9n[        R                  " [        R                  UR                  SUS	9n[        U [	        US95        [        US   U5        U R                  S5        U R                  S5        UR                  S
5      nUR                  S
5      n[        U SU05        [        U 5      n[        US   U5        g )Nr  FoobzFoob )rK   rK   r   F)order)r)   r3   r  bufferrP  )r   r(   r   r   r   r   r	   r(  r   tobytesr   rK   r)   r3   astype)r2  in_arrout_arrrs  in_strin_from_strin_arr_u	out_arr_us           r-   test_str_roundr    s   YFXXw'(Fhh)*GFD6N#
&/Cs3x)
OOA
KKN^^#^&F**177#)<<#&$*,K FD;'(s3x)
OOA
KKN}}S!Hs#IFS(O$
&/Cs3x+r/   c                      [        5       n [        U SSSS.05        [        U 5      nUS   R                  R                  n[        [        U5      SS15        g )NrK   r4   rR   r.  r-  )r   r   r   r3   r/  r   set)r2  rs  field_namess      r-   test_fieldnamesr     sK    YFFSqa.)*
&/Cc(..&&K[!C:.r/   c                  T   / SQn [        [        S5      / 4[        [        S5      U 44 GH{  u  p[        U5      n[        [	        UR                  5       5      [	        SS/U-   5      5        [        USS9n[        [	        UR                  5       5      [	        S/U-   5      5        [        US/S9n[        [	        UR                  5       5      [	        S/U-   5      5        [        US/S9n[        [	        UR                  5       5      [	        S/U-   5      5        [        USS9n[        [	        UR                  5       5      [	        S/U-   5      5        [        U/ S9n[        [	        UR                  5       5      [	        U5      5        S/n[        XS9n[        US/5        GM~     g )N)__globals__
__header____version__ztestmulti_4.2c_SOL2.matztestmulti_7.4_GLNX86.matrK   rJ   )variable_names)rJ   )r   r   r   r   r  keys)mat5_sys_nameseg_filesys_v_namesvarsvnamess        r-   test_loadmat_varnamesr  (  sn   %N 
~8	92>6B89GAI!J wS%sC>K+G'HIws3S%sC5;+>'?@wu5S%sC5;+>'?@wy9S%sG9{+B'CDwz:S%sG9{+B'CDwr2S%s;'78w6VgY'#!Jr/   c                  D   [         R                  " S5      n [        5       nS Hz  nUR                  S5        UR	                  S5        [        USU R                  U5      05        [        U5      n[        [         R                  " U5      US   R                  5        M|     g )Nr"  )rz  f4i8i4i2i1u8u4u2u1c16c8r   r,   )
r(   r:  r   r(  r   r   r  r   r   r3   )r,   r2  dtsr
  s       r-   test_round_typesr  A  su    
))B-CYF0A

301vRXXc]DK$5$560r/   c                    ^	 S[        [        R                  " S5      5      4S[        S5      4S[        S5      44m	 " U	4S jS5      n [        5       n[	        X" 5       5        [        U5      n[        [        U5      S5        [        S5       H4  nX#   u  pET	U   u  pg[        XF5        [        U5      n[        X   U5        M6     g )	Nr,   r"  mystrrj  mynumc                   "   > \ rS rSrU 4S jrSrg) test_varmats_from_mat.<locals>.CiU  c                    > T$ r   r   )self
names_varss    r-   r   &test_varmats_from_mat.<locals>.C.itemsV  s	    r/   r   N)rb  rc  rd  re  r   rf  )r"  s   r-   rm  r  U  s    	 	r/   rm  r?   )r.   r(   r:  r   r   r"   r   r   ranger   r	   )
rm  r2  varmatsr   r7   
var_streamexp_nameexp_resrs  r"  s
            @r-   test_varmats_from_matr)  N  s    %		"./E*-.E"I&(J
  YFFACv&GWq!1X":&qMT$j!39g. r/   c                      [        [        S5      n [        U S5      n[        U5      nUR	                  5       nUR                  5         [        US   R                  S5        g )Nzone_by_zero_char.matry   r  ri  )r   r   r   r!   rK  r   r   r)   )r  r   r  r   s       r-   test_one_by_zeror+  d  sN    N$:;G	gt	B

CAHHJ5&r/   c                  ^    [        [        S5      n [        U 5      n[        US   SS//5        g )Nztest_mat4_le_floats.matrK   r  g333333?)r   r   r   r	   )
mat4_fnamer
  s     r-   test_load_mat4_ler.  n  s/     ~'@AJ:DtCyC:,/r/   c                  n    [        5       n SS0n[        XSS9  [        U 5      n[        US   US   5        g )N
second_catu   Schrödingerr   r   )r   r   r   r   )bior  var_backs      r-   test_unicode_mat4r3  v  s:    
)C
(CCS!s|H,'\):;r/   c            	      F   [        [        S5      n [        U SSS9nUS   n[        [	        U5      =(       a    UR
                  S:H  5        [        UR                  R                  [        R                  5        [        UR                  5       / SQ/ SQ/ SQ/ S	Q/ S	Q/5        g )
Nzlogical_sparse.matTFr   
sp_log_5_4csc)TTTF)FFTF)FFFF)r   r   r   r   r   r   r   r3   r   r(   r   r	   r   )r   r   log_sps      r-   test_logical_sparser8    s     ^$89H 	4%@A|_FHV7%!78""BHH-v~~'13344	67r/   c                     [        5       n SS KnUR                  R                  SS/SS//5      n[	        U [        US95        U R                  S5        [        U SS9nUR                  R                  US   5      (       a   e[        U SS9nUR                  R                  US   5      (       d   e[        U 5      nUR                  R                  US   5      (       d   e[        US   R                  UR                  5        [        US   R                  5       S5        U R                  S5        [        U 5      nUR                  5         UR                  5         UR                  5       u  pV[!        UR"                  S5        g )Nr   r   F)r   rv   Tr4   )r   scipy.sparserD   	csr_arrayr   r   r   r   
isspmatrixr	   r)   r   r!   r  r  r  r   nzmax)r   scipyempty_sparsers  r  r  r  s          r-   test_empty_sparser@    s@   
)C<<))Aa5!A-8LC%&HHQK
#
&C||&&s3x0000
#
%C<<""3s8,,,,
#,C<<""3s8,,,,s3x~~|'9'9:s3x'')1- HHQKC F

##%FCAr/   c                  B    [        5       n [        [        [        U 5        g r   )r   r   r   r   )r   s    r-   test_empty_mat_errorrB    s    
)C,-r/   c                     [        [        S5      n [        U 5      n[        US   [        R
                  " S5      S S S 24   5        [        [        S5      n [        [        5         [        U 5        S S S 5        g ! , (       d  f       g = f)Nzmiuint32_for_miint32.matan_arrayr"  zbad_miuint32.mat)r   r   r   r   r(   r:  r   r  r   rs  s     r-   test_miuint32_compromiserF    sc     ^%?@H
(
CZ"))B-a"89^%78H	z	" 
#	"	"s   %A::
Bc                      [        [        S5      n [        U 5      n[        US   S//5        [        [        S5      n [	        [
        5         [        U 5        S S S 5        g ! , (       d  f       g = f)Nzmiutf8_array_name.mat
array_namer4   zbad_miutf8_array_name.mat)r   r   r   r   r   r  rE  s     r-   !test_miutf8_for_miint8_compromiserI    sU    ^%<=H
(
C\"aSE*^%@AH	z	" 
#	"	"s   A!!
A/c                  x    [        [        S5      n [        U 5      n[        US   SR	                  SS5      5        g )Nzbroken_utf8.mat
bad_strings    am brokenutf8replace)r   r   r   r   decoderE  s     r-   test_bad_utf8rO    s8    ^$56H
(
C\""))&)<>r/   c                 z    [         R                  R                  [        U 5      S5      nSSSS.0n[	        X5        g )Ntest.matrK   r4   test_str)r-  rv  )r   pathr   r   r   )r   r   	test_dicts      r-   test_save_unicode_fieldrU    s1    ww||CK4H!
+,IH r/   c                      " S S5      nU" 5       n[         R                  R                  [        U 5      S5      n[	        USU05        [        U5      n[        US   [        R                  " U5      5        g )Nc                       \ rS rSrSS jrSrg)0test_save_custom_array_type.<locals>.CustomArrayi  Nc                 N    [         R                  " S5      R                  SS5      $ )Ng      @rR   r?   )r(   r:  r@  )r!  r3   rA  s      r-   	__array__:test_save_custom_array_type.<locals>.CustomArray.__array__  s    99S>))!Q//r/   r   )NN)rb  rc  rd  re  rZ  rf  r   r/   r-   CustomArrayrX    s    	0r/   r\  rQ  rK   )	r   rS  r   r   r   r   r	   r(   r   )r   r\  rK   r   outs        r-   test_save_custom_array_typer^    s[    0 0 	Aww||CK4HHsAh
(
Cs3x!-r/   c                  X    [        [        [        S5        [        [        [        S5        g )NzNotExistentFile00.matNotExistentFile00)r   OSErrorr   r   r/   r-   test_filenotfoundrb    s    '7$;<'7$78r/   c                      [        [        S5      n [        U SS9n[        U SS9n[        [	        US   [
        5      5        [        [	        US   [        R                  5      5        [        US   S   [        R                  " / SQ5      5        g )Nztestsimplecell.matTsimplify_cellsFsmycell)rK   r-  rv  )
r   r   r   r   r   r   r(   r   r	   r   )r   res1res2s      r-   test_simplify_cellsrj    sm    ^%9:H8D1D8E2DJtCy$'(JtCy"**-.tCy*BHH_,EFr/   zversion, filt, regex))r   z_4*_*N)r4   z_5*_*N)r4   z_6*_*N)r4   _7*_*z^((?!hdf5).)*$)rR   rk  z.*hdf5.*)r4   z8*_*Nc                    [        [        SU S35      n[        U5      nUb+  U Vs/ s H  n[        R                  " X%5      c  M  UPM      nn[        U5      S:  d   SU  SU 35       eU H  n[        U5      nUS   U :X  a  M   e   g s  snf )Nztest*z.matr   zNo files for version r   )r   r   r   rematchr   r   )rt   r   regexr   r   filegot_versions          r-   test_matfile_versionrr    s     ^uTF$%78HNE"'M%$288E+@%Mu:> >
ytf=>>%d+1~(((  Ns   B
B
c                      [        [        [        S5      5      n [        U S   [        5      (       d   e[        U S   R                  5       S   R                  5       S   [        5      (       d   eg)z,Test that we can read a MatlabOpaque object.parabola.matparabolar?   N)r   r   r   r   r   r   r   r&   s    r-   test_opaquerw  	  s_    589Dd:&7777d:&++-a0557:LIIIIr/   c                  h    [        [        [        S5      SS9n [        U S   [        5      (       d   eg)zETest that we can read a MatlabOpaque object when simplify_cells=True.rt  Trd  ru  N)r   r   r   r   r   rv  s    r-   test_opaque_simplifyry    s-    58NDd:&7777r/   c                     [        [        5         [        R                  R                  R
                  R                    SSS5        [        [        5         SSKJn   SSS5        g! , (       d  f       N-= f! , (       d  f       g= f)z4Test that access to previous attributes still works.Nr   r   )	r   DeprecationWarningr>  iomatlabmio5_paramsr   scipy.io.matlab.miobaser   r{  s    r-   test_deprecationr    sQ     
(	)##00 
* 
(	)8 
*	)	 
*	) 
*	)s   /A&A7&
A47
Bc                    [         R                  R                  S5      nU S-  nUR                  S5      nUR                  S5      nX4/n[         R                  R	                  5        nUR                  [        5        [        USU0SSS9  S S S 5        0 n[        UU5        [        US   S   S   U5        [        US   S   S	   U5        g ! , (       d  f       NG= f)
Ni90  z	lists.mat)r@   r?   )rA   r?   r&   T)r  r>  r   r4   )
r(   randomdefault_rngtestingsuppress_warningsfilterr%   r   r   r   )tmp_pathrngoutfile	array_one	array_twolist_of_arrayssupnew_dicts           r-   test_gh_17992r  !  s    
))


&C$G

5!I

5!I+N		%	%	'3

,-(!%#	% 
( HGHV$Q'*I6HV$Q'*I6 
(	's   ($C
Cc                     [         R                  " [        S5      [        S5      /SS9[         R                  " SS/5      S.nU S-  n[        X!SS9  g )	Nr<   r  r2   r:   )
char_arraystring_arrayztmp.matr   r   )r(   r   r  r   )r  r   r  s      r-   test_gh_19659r  6  sK    hhVd6l;4H(H!56	
A "GGs#r/   c                      [        [        S5      n [        R                  [        R                  :X  a  SOSn[
        R                  " [        US9   [        U 5        S S S 5        g ! , (       d  f       g = f)Nzdebigged_m4.matz$Not enough bytes to read matrix 'a';z9Variable 'a' has byte length longer than largest possiblern  )	r   r   r(   intpint64pytestr   r  r   )truncated_matrn  s     r-   test_large_m4r  @  sR     .*;<M288# 4H 
 
z	/ 
0	/	/s   A%%
A3c                      SSK Jn   g )Nr   r"   )scipy.io.matlabr"   r  s    r-   test_gh_19223r  P  s    0r/   c                  :   S H<  n [         R                  " [        SS9   [        [	        SU -  5      5        S S S 5        M>     [         R                  " [        SS9   [        [	        S5      5        S S S 5        g ! , (       d  f       M  = f! , (       d  f       g = f)N)rR   r0   r"     z Mat file appears to be truncatedr      zMat file appears to be corrupts                       )r  r   r   r   r   ns    r-   test_corrupt_filesr  S  s}    ]]<!CEGGaK()E E  
|=
?%&
? 
?E E
? 
?s   A:B:
B		
B)ztest%(name)s_*.mat)r   collectionsr   os.pathr   r   r   r   r}  r   rm  tempfiler   r   r   r   numpy.testingr	   r
   r   r   r   r   r  r   r   numpyr(   r   r:  r   r   r   r   scipy.ior>  r  r   r   r   scipy.io.matlab._byteordercodesr~  _byteordercodesr  scipy.io.matlab._miobaser   r   r   r   scipy.io.matlab._mior   r   r   r   scipy.io.matlab._mio5r    r!   r"   r#   r$   scipy.io.matlab._mio5_params_mio5_paramsr  scipy._lib._utilr%   __file__r   markthread_unsafe
pytestmarkr.   pir:  r  r@  rJ   r   appendcossinr   rF  r  r$  r  r=   Brw   CAr   CAEr  objarr	transposesqrtexp
st_sub_arrr3   r	  CNr  st2rK   ODTMOm0r   fp_u_strreadrN  u_strr   r   repeatr   r   r   r   r   r   parametrizer   r   r   r   r   r   r   r   r
  r  r  r  r  r   r+  r4  r;  rD  rG  rN  rR  rT  rZ  rw  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r   r  r  r)  r+  r.  r3  r8  r@  rB  rF  rI  rO  rU  r^  rb  rj  rr  rw  ry  r  r  r  r  r  r  r  s   0r-   <module>r     st   	 # *   	    Q Q  *   B B  F F - -; ; N N  - , 6 wx(&1[[&&
 	a		!%(00155x(&
   v&FGHJ   )BFF5M1A!AB
 HHUOE!AJ!	eAaj	!A#   x("
   x(	!-
 HHW #"   $h/%y|4
   "2 q)
   h'uRy)
   'u. 
qc
!ugwi	 "(	) *12	 
 GHJ3 V$b!#$ 	!H	!H	"I	"I	!H
 
 %WQr]  
%f	%Ahs   !6*"F+
    &)!3')*   "F+#U&! "   *BLLDq,=w!GHJ BGGAJrvvay/0881=
LMLVLMhhue!= >?M 3 $M 3 %0N C    x($
 XXe6"
(3
((5
'3Qbhh'3qcU"((+3xxV,3!288,3S !288,3S    ( "%
 	hhu.A.Q[.AB(C((5'6):(;<C %zl 3C W    !8,"C(
 HHU?1v;?@a#ua#uzl##uzl##u    (+!1%
 	hh343 !"F34 5 "((5,h7WC5\6
234;C5\6
a9a9a9   x(#
 n&9:DAw'     'ug/
   x(	!-
   $h/%y|4
   i($%)*, Q   "H-#RYYr1%5%=%=a%BCEF (JV8"3-, J/$ 0$
 J/  0  3*cUO+ 2	248:
/		3N	IL"1-,()02+65
< &<9~(6+$ 6F62C*0+"#F	72I=1,:/(2
7/,'0<7*6.	>!.9G / 2 	)	)J897*$ 1'M& 	N. B @4s   d:d#
3d(
(d-