
    h                     F   S SK JrJrJrJrJr  SSKJr  SSKJ	r	  SSK
Jr  SSKJr  SSKJrJrJrJrJr  \R(                  " S5      S	S	\	S
4S\\   S\\   S\\	   S\S\	\\4   4
S jj5       rS\	S\S\S\\\4   4S jrS\	S\S\S\\\\/\4   4   4S jrS\	S\S\4S jrg	)    )AnyCallableOptionalTupleType   )registry)Model)	MXNetShim)
ArgsKwargs)convert_recursiveis_mxnet_arrayis_xp_arraymxnet2xpxp2mxnetzMXNetWrapper.v1Nmxnetconvert_inputsconvert_outputsmodel_class
model_namereturnc                 X    Uc  [         nUc  [        nU" U[        XS.[        U 5      /S9$ )a  Wrap a MXNet model, so that it has the same API as Thinc models.
To optimize the model, you'll need to create a MXNet optimizer and call
optimizer.step() after each batch.

Your MXNet model's forward method can take arbitrary args and kwargs,
but must return either a single tensor as output or a tuple. You may find the
MXNet register_forward_hook helpful if you need to adapt the output.

The convert functions are used to map inputs and outputs to and from your
MXNet model. Each function should return the converted output, and a callback
to use during the backward pass. So:

    Xmxnet, get_dX = convert_inputs(X)
    Ymxnet, mxnet_backprop = model.shims[0](Xmxnet, is_train)
    Y, get_dYmxnet = convert_outputs(Ymxnet)

To allow maximum flexibility, the MXNetShim expects ArgsKwargs objects
on the way into the forward and backward passes. The ArgsKwargs objects
will be passed straight into the model in the forward pass, and straight
into `mxnet.autograd.backward` during the backward pass.
)r   r   )attrsshims)convert_mxnet_default_inputsconvert_mxnet_default_outputsforwardr   )mxnet_modelr   r   r   r   s        S/home/james-whalen/.local/lib/python3.13/site-packages/thinc/layers/mxnetwrapper.pyMXNetWrapperr    
   s>    : 57!/T%&	     modelXis_trainc                    ^	^
^ U R                   S   nU R                   S   nU" XU5      u  nm	U R                  S   " XR5      u  nmU" XU4U5      u  nm
S[        S[        4U	U
U4S jjnXx4$ )zuReturn the output of the wrapped MXNet model for the given input,
along with a callback to handle the backward pass.
r   r   r   dYr   c                 8   > T" U 5      nT" U5      nT" U5      nU$ N )r&   dYmxnetdXmxnetdXget_dXget_dYmxnetmxnet_backprops       r   backpropforward.<locals>.backprop>   s$    b/ )G_	r!   )r   r   r   )r"   r#   r$   r   r   XmxnetYmxnetYr0   r-   r.   r/   s            @@@r   r   r   3   s     [[!12Nkk"34O#Eh7NFF"[[^F=FN$UKBNA{S S   ;r!   c                 D  ^ U4S jn[        [        X15      n[        U[        5      (       a  S nXE4$ [        U[        5      (       a  S n[        [        5       US9U4$ [        U[
        [        45      (       a  S n[        [        U5      0 S9U4$ S n[        U40 S9U4$ )Nc                    > [        U TS9$ )N)requires_grad)r   )xr$   s    r   <lambda>.convert_mxnet_default_inputs.<locals>.<lambda>M   s    (1H=r!   c                 ,    [        [        [        U 5      $ r(   )r   r   r   )r+   s    r   reverse_conversion8convert_mxnet_default_inputs.<locals>.reverse_conversionQ   s    $^XwGGr!   c                 D    [        [        [        U 5      nUR                  $ r(   )r   r   r   kwargsr+   r,   s     r   r<   r=   W   s    ">8WEB99r!   argsr?   c                 D    [        [        [        U 5      nUR                  $ r(   r   r   r   rB   r@   s     r   r<   r=   ^   s    ">8WEB77Nr!   c                 J    [        [        [        U 5      nUR                  S   $ )Nr   rD   r@   s     r   r<   r=   e   s    ">8WEB771:r!   )r   r   
isinstancer   dicttuplelist)r"   r#   r$   	xp2mxnet_	convertedr<   s     `   r   r   r   J   s     >I!+y<I)Z((	H ,,	It	$	$	 uwy9;MMM	It}	-	-	 uY/;=OOO	 	|B79KKKr!   X_Ymxnetc                 f   ^ Uu  nm[        [        [        T5      nS[        S[        4U4S jjnXE4$ )Nr&   r   c                 J   > [        [        [        U 5      n[        T44SU0S9$ )N
head_gradsrA   )r   r   r   r   )r&   r*   r3   s     r   r<   9convert_mxnet_default_outputs.<locals>.reverse_conversionp   s'    #K2>	|\74KLLr!   )r   r   r   r   r   )r"   rL   r$   r#   r4   r<   r3   s         @r   r   r   l   s;    IAv.(F;AMs Mz M   r!   )typingr   r   r   r   r   configr	   r"   r
   r   r   typesr   utilr   r   r   r   r   layersstrr    boolr   r   r   r)   r!   r   <module>rX      s   7 7     U U 
"# *.*.$%X&% h'% e	%
 % 38_% $%P5 S D U3=5I .LLL$(L
:xc 1223LD! !# ! !r!   