
    M/Ph                     Z    d Z ddlZddlmZ ddlmc mZ 	 	 ddZd Z	d Z
d	 Zd
 Zd ZdS )zR
Holds files for l1 regularization of LikelihoodModel, using
scipy.optimize.slsqp
    N)
fmin_slsqpF  c                    '( t          j        |                              d          }t          |          (t          j        |t          j        |                    }t          j        |d                                       d          ''t          j        (          z  ''                                dk    sJ t          ||          }|	                    dd          }' (fd}(fd}'(fd}(fd	}t          ||||||||	|
	  	        }t          j        |d         d(                   }|d         }|d         }t          j        |'||          }|d         }|d         }|d         }t          j        |('||||          \  }}|	rj|\  }}}}} |t          j        |                    } |dk    }!t          |          dz   |z   }"|}#t!          d          }$t!          d          }%| |!|#|$|%||"d}&|	r||&fS |S )a  
    Solve the l1 regularized problem using scipy.optimize.fmin_slsqp().

    Specifically:  We convert the convex but non-smooth problem

    .. math:: \min_\beta f(\beta) + \sum_k\alpha_k |\beta_k|

    via the transformation to the smooth, convex, constrained problem in twice
    as many variables (adding the "added variables" :math:`u_k`)

    .. math:: \min_{\beta,u} f(\beta) + \sum_k\alpha_k u_k,

    subject to

    .. math:: -u_k \leq \beta_k \leq u_k.

    Parameters
    ----------
    All the usual parameters from LikelhoodModel.fit
    alpha : non-negative scalar or numpy array (same size as parameters)
        The weight multiplying the l1 penalty term
    trim_mode : 'auto, 'size', or 'off'
        If not 'off', trim (set to zero) parameters that would have been zero
            if the solver reached the theoretical minimum.
        If 'auto', trim params using the Theory above.
        If 'size', trim params if they have very small absolute value
    size_trim_tol : float or 'auto' (default = 'auto')
        For use when trim_mode === 'size'
    auto_trim_tol : float
        For sue when trim_mode == 'auto'.  Use
    qc_tol : float
        Print warning and do not allow auto trim when (ii) in "Theory" (above)
        is violated by this much.
    qc_verbose : bool
        If true, print out a full QC report upon failure
    acc : float (default 1e-6)
        Requested accuracy as used by slsqp
    Falpha_rescaledr   accg|=c                 $    t          | gR  S N)_objective_func)x_fullalphaargsfk_paramss    Y/var/www/html/test/jupyter/venv/lib/python3.11/site-packages/statsmodels/base/l1_slsqp.py<lambda>zfit_l1_slsqp.<locals>.<lambda>F   s    /!VXuLtLLL     c                 $    t          |           S r
   )
_f_ieqconsr   r   s    r   r   zfit_l1_slsqp.<locals>.<lambda>G   s    Jvx$@$@ r   c                 (    t          |           S r
   )_fprime)r   r   r   scores    r   r   zfit_l1_slsqp.<locals>.<lambda>H   s    %!H!H r   c                 $    t          |           S r
   )_fprime_ieqconsr   s    r   r   zfit_l1_slsqp.<locals>.<lambda>I   s    )J)J r   )	f_ieqconsfprimer   iterdispfull_outputfprime_ieqconsNqc_tol
qc_verbose	trim_modesize_trim_tolauto_trim_tol nan)fopt	converged
iterationsgopthopttrimmedwarnflag)nparrayravellenappendfabsonesmin_get_disp_slsqp
setdefaultr   asarrayl1_solvers_common
qc_resultsdo_trim_paramsstrfloat))r   r   start_paramsr   kwargsr   maxitercallbackretallr    hessx0
disp_slsqpr   funcf_ieqcons_wrapfprime_wrapfprime_ieqcons_wrapresultsparamsr"   r#   passedr$   r%   r&   r.   r   fxitsimodesmoder)   r*   r/   r+   r,   r-   retvalsr   r   s)   `` `                                   @@r   fit_l1_slsqprT   
   sv   R 8L))//44L
 <  H	<!6!6	7	7BHV,-..44S99EBGH%%%E99;;! v..J


E5
)
)C MLLLLLLD@@@@NHHHHHHKJJJJ bN;C:;*, , ,G Z
9H9-..F HF%J)ufj2 2F {#I?+M?+M'6%	= OFG  "(/%CtBJv&&''aZ	u::#e+
U||U||y
$7 " "  wr   c                 $    | s|r	| rd}|rd}nd}|S )N      r    )r   rD   rG   s      r   r8   r8   w   s7     v  	J 	J
r   c                 l    |d|         }||d         } | |g|R  ||z                                   z   S )z,
    The regularized objective function
    N)sum)r   r   r   r   r   x_paramsx_addeds          r   r   r      sM     ixi HXYYG1X 5 5 7 777r   c                 R    |d|         }t          j         | |          |          S )z$
    The regularized derivative
    Nr0   r4   )r   r   r   r   r[   s        r   r   r      s,     ixi H9UU8__e,,,r   c                 `    | d|         }| |d         }t          j        ||z   ||z
            S )z%
    The inequality constraints.
    Nr^   )r   r   r[   r\   s       r   r   r      s<     ixi HXYYG9X'8);<<<r   c                     t          j        |          }t          j        ||fd          }t          j        | |fd          }t          j        ||fd          }|S )z2
    Derivative of the inequality constraints
    rV   )axisr   )r0   eyeconcatenate)r   r   IABCs         r   r   r      sb     	xA
1vA&&&A
AwQ'''A
1vA&&&AHr   )Fr   NFFN)__doc__numpyr0   scipy.optimizer   "statsmodels.base.l1_solvers_commonbaser;   rT   r8   r   r   r   r   rX   r   r   <module>rm      s         % % % % % % > > > > > > > > > CG=Aj j j jZ  8 8 8- - -= = =	 	 	 	 	r   