+
    0iz>              
       $   R t ^ RIt^ RIt^ RIHt ^RIHt ^ RIH	t	H
t
HtHtHtHt RR.t]! 4       ]! R R ^R	 R
RR7      RR R ll4       4       tR R lt]! 4       ]! R ^R ]R7      RRRRR^ RR/R R ll4       4       tR tR tR tR tR tR# )!z5
Created on Fri Apr  2 09:06:05 2021

@author: matth
N)special)_axis_nan_policy_factory)array_namespace
xp_promote	xp_device	is_marray_share_masksxp_capabilitiesentropydifferential_entropyc                     V # N xs   &R/var/www/html/photoedit/myenv/lib/python3.14/site-packages/scipy/stats/_entropy.py<lambda>r          a    c                 .    R V 9   d   V R ,          e   ^# ^# )qkr   )kwgss   &r   r   r      s!    dltDz5 		r   c                     V 3# r   r   r   _s   &&r   r   r      s    qdr   T)	n_samples	n_outputsresult_to_tuplepaired	too_smallc                    V ^8  d   QhR\         P                  P                  R\         P                  P                  R,          R\        R,          R\        R\         P
                  \         P                  ,          /# )   pkr   Nbaseaxisreturn)nptyping	ArrayLikefloatintnumberndarray)formats   "r   __annotate__r.      sh     J J		## J		##d*J$,J J RZZ'	Jr   c           	        Ve   V^ 8:  d   \        R4      h\        W4      p\        WRVR7      w  r\        P                  ! RR7      ;_uu_ 4        Ve)   \        WVR7      w  rWP                  WRR7      ,          pWP                  WRR7      ,          p RRR4       Vf   \        P                  ! V 4      pMo\        V4      '       dI   \        P                  ! V P                  VP                  4      pVP                  WPP                  R	7      pM\        P                  ! W4      pVP                  WSR
7      pVe   V\        P                  ! V4      ,          pV#   + '       g   i     L; i)a  
Calculate the Shannon entropy/relative entropy of given distribution(s).

If only probabilities `pk` are given, the Shannon entropy is calculated as
``H = -sum(pk * log(pk))``.

If `qk` is not None, then compute the relative entropy
``D = sum(pk * log(pk / qk))``. This quantity is also known
as the Kullback-Leibler divergence.

This routine will normalize `pk` and `qk` if they don't sum to 1.

Parameters
----------
pk : array_like
    Defines the (discrete) distribution. Along each axis-slice of ``pk``,
    element ``i`` is the  (possibly unnormalized) probability of event
    ``i``.
qk : array_like, optional
    Sequence against which the relative entropy is computed. Should be in
    the same format as `pk`.
base : float, optional
    The logarithmic base to use, defaults to ``e`` (natural logarithm).
axis : int, optional
    The axis along which the entropy is calculated. Default is 0.

Returns
-------
S : {float, array_like}
    The calculated entropy.

Notes
-----
Informally, the Shannon entropy quantifies the expected uncertainty
inherent in the possible outcomes of a discrete random variable.
For example,
if messages consisting of sequences of symbols from a set are to be
encoded and transmitted over a noiseless channel, then the Shannon entropy
``H(pk)`` gives a tight lower bound for the average number of units of
information needed per symbol if the symbols occur with frequencies
governed by the discrete distribution `pk` [1]_. The choice of base
determines the choice of units; e.g., ``e`` for nats, ``2`` for bits, etc.

The relative entropy, ``D(pk|qk)``, quantifies the increase in the average
number of units of information needed per symbol if the encoding is
optimized for the probability distribution `qk` instead of the true
distribution `pk`. Informally, the relative entropy quantifies the expected
excess in surprise experienced if one believes the true distribution is
`qk` when it is actually `pk`.

A related quantity, the cross entropy ``CE(pk, qk)``, satisfies the
equation ``CE(pk, qk) = H(pk) + D(pk|qk)`` and can also be calculated with
the formula ``CE = -sum(pk * log(qk))``. It gives the average
number of units of information needed per symbol if an encoding is
optimized for the probability distribution `qk` when the true distribution
is `pk`. It is not computed directly by `entropy`, but it can be computed
using two calls to the function (see Examples).

See [2]_ for more information.

References
----------
.. [1] Shannon, C.E. (1948), A Mathematical Theory of Communication.
       Bell System Technical Journal, 27: 379-423.
       https://doi.org/10.1002/j.1538-7305.1948.tb01338.x
.. [2] Thomas M. Cover and Joy A. Thomas. 2006. Elements of Information
       Theory (Wiley Series in Telecommunications and Signal Processing).
       Wiley-Interscience, USA.


Examples
--------
The outcome of a fair coin is the most uncertain:

>>> import numpy as np
>>> from scipy.stats import entropy
>>> base = 2  # work in units of bits
>>> pk = np.array([1/2, 1/2])  # fair coin
>>> H = entropy(pk, base=base)
>>> H
1.0
>>> H == -np.sum(pk * np.log(pk)) / np.log(base)
True

The outcome of a biased coin is less uncertain:

>>> qk = np.array([9/10, 1/10])  # biased coin
>>> entropy(qk, base=base)
0.46899559358928117

The relative entropy between the fair coin and biased coin is calculated
as:

>>> D = entropy(pk, qk, base=base)
>>> D
0.7369655941662062
>>> np.isclose(D, np.sum(pk * np.log(pk/qk)) / np.log(base), rtol=4e-16, atol=0)
True

The cross entropy can be calculated as the sum of the entropy and
relative entropy`:

>>> CE = entropy(pk, base=base) + entropy(pk, qk, base=base)
>>> CE
1.736965594166206
>>> CE == -np.sum(pk * np.log(qk)) / np.log(base)
True

N+`base` must be a positive number or `None`.T)	broadcastxpignore)invalidr2   r$   keepdims)maskr$   )
ValueErrorr   r   r&   errstater   sumr   entrr   rel_entrdataasarrayr8   mathlog)r"   r   r#   r$   r2   vecSs   &&&&   r   r
   r
      s   x DAIFGG		 B$26FB	X	&	&>!"R0FBffRTf::B&&&66	 
' 
zll2R==""277BGG4C**Sww*/C""2*C
sA	TXXd^H% 
'	&s   AEE.	c                    V ^ ,          pVP                   V,          pVP                  R4      pVf2   \        P                  ! \        P                  ! V4      R,           4      p^^V,          u;8:  d
   V8  g    R#  R# R# )    window_length      ?TF)shapegetrA   floorsqrt)sampleskwargsr$   valuesnrG   s   &&&   r   "_differential_entropy_is_too_smallrQ      sh    QZFTAJJ/M

499Q<##56M!%A% &r   c                     V # r   r   r   s   &r   r   r      r   r   c                     V 3# r   r   r   s   &&r   r   r      s    A4r   )r   r   r   rG   r#   r$   methodautoc                    V ^8  d   QhR\         P                  P                  R\        R,          R\        R,          R\        R\
        R\         P                  \         P                  ,          /# )r!   rO   rG   Nr#   r$   rT   r%   )r&   r'   r(   r*   r)   strr+   r,   )r-   s   "r   r.   r.      sm     |( |(II|( :|( $,	|(
 |( |( YY|(r   c          
        \        V 4      p\        V RVR7      p VP                  WR4      p V P                  R,          pVf2   \        P
                  ! \        P                  ! V4      R,           4      p^^V,          u;8:  d   V8  g   M \        RV RV R24      hVe   V^ 8:  d   \        R4      hVP                  V RR7      pR	\        R
\        R\        R\        R\        /pVP                  4       pWH9  d   R\        V4       2p	\        V	4      hVR8X  d   V^
8:  d   R
pMVR8:  d   RpMR	pW,          ! WqVR7      p
Ve   V
\        P                  ! V4      ,          p
VP!                  WP"                  4      # )a  Given a sample of a distribution, estimate the differential entropy.

Several estimation methods are available using the `method` parameter. By
default, a method is selected based the size of the sample.

Parameters
----------
values : sequence
    Sample from a continuous distribution.
window_length : int, optional
    Window length for computing Vasicek estimate. Must be an integer
    between 1 and half of the sample size. If ``None`` (the default), it
    uses the heuristic value

    .. math::
        \left \lfloor \sqrt{n} + 0.5 \right \rfloor

    where :math:`n` is the sample size. This heuristic was originally
    proposed in [2]_ and has become common in the literature.
base : float, optional
    The logarithmic base to use, defaults to ``e`` (natural logarithm).
axis : int, optional
    The axis along which the differential entropy is calculated.
    Default is 0.
method : {'vasicek', 'van es', 'ebrahimi', 'correa', 'auto'}, optional
    The method used to estimate the differential entropy from the sample.
    Default is ``'auto'``.  See Notes for more information.

Returns
-------
entropy : float
    The calculated differential entropy.

Notes
-----
This function will converge to the true differential entropy in the limit

.. math::
    n \to \infty, \quad m \to \infty, \quad \frac{m}{n} \to 0

The optimal choice of ``window_length`` for a given sample size depends on
the (unknown) distribution. Typically, the smoother the density of the
distribution, the larger the optimal value of ``window_length`` [1]_.

The following options are available for the `method` parameter.

* ``'vasicek'`` uses the estimator presented in [1]_. This is
  one of the first and most influential estimators of differential entropy.
* ``'van es'`` uses the bias-corrected estimator presented in [3]_, which
  is not only consistent but, under some conditions, asymptotically normal.
* ``'ebrahimi'`` uses an estimator presented in [4]_, which was shown
  in simulation to have smaller bias and mean squared error than
  the Vasicek estimator.
* ``'correa'`` uses the estimator presented in [5]_ based on local linear
  regression. In a simulation study, it had consistently smaller mean
  square error than the Vasiceck estimator, but it is more expensive to
  compute.
* ``'auto'`` selects the method automatically (default). Currently,
  this selects ``'van es'`` for very small samples (<10), ``'ebrahimi'``
  for moderate sample sizes (11-1000), and ``'vasicek'`` for larger
  samples, but this behavior is subject to change in future versions.

All estimators are implemented as described in [6]_.

References
----------
.. [1] Vasicek, O. (1976). A test for normality based on sample entropy.
       Journal of the Royal Statistical Society:
       Series B (Methodological), 38(1), 54-59.
.. [2] Crzcgorzewski, P., & Wirczorkowski, R. (1999). Entropy-based
       goodness-of-fit test for exponentiality. Communications in
       Statistics-Theory and Methods, 28(5), 1183-1202.
.. [3] Van Es, B. (1992). Estimating functionals related to a density by a
       class of statistics based on spacings. Scandinavian Journal of
       Statistics, 61-72.
.. [4] Ebrahimi, N., Pflughoeft, K., & Soofi, E. S. (1994). Two measures
       of sample entropy. Statistics & Probability Letters, 20(3), 225-234.
.. [5] Correa, J. C. (1995). A new estimator of entropy. Communications
       in Statistics-Theory and Methods, 24(10), 2439-2449.
.. [6] Noughabi, H. A. (2015). Entropy Estimation Using Numerical Methods.
       Annals of Data Science, 2(2), 231-241.
       https://link.springer.com/article/10.1007/s40745-015-0045-9

Examples
--------
>>> import numpy as np
>>> from scipy.stats import differential_entropy, norm

Entropy of a standard normal distribution:

>>> rng = np.random.default_rng()
>>> values = rng.standard_normal(100)
>>> differential_entropy(values)
1.3407817436640392

Compare with the true entropy:

>>> float(norm.entropy())
1.4189385332046727

For several sample sizes between 5 and 1000, compare the accuracy of
the ``'vasicek'``, ``'van es'``, and ``'ebrahimi'`` methods. Specifically,
compare the root mean squared error (over 1000 trials) between the estimate
and the true differential entropy of the distribution.

>>> from scipy import stats
>>> import matplotlib.pyplot as plt
>>>
>>>
>>> def rmse(res, expected):
...     '''Root mean squared error'''
...     return np.sqrt(np.mean((res - expected)**2))
>>>
>>>
>>> a, b = np.log10(5), np.log10(1000)
>>> ns = np.round(np.logspace(a, b, 10)).astype(int)
>>> reps = 1000  # number of repetitions for each sample size
>>> expected = stats.expon.entropy()
>>>
>>> method_errors = {'vasicek': [], 'van es': [], 'ebrahimi': []}
>>> for method in method_errors:
...     for n in ns:
...        rvs = stats.expon.rvs(size=(reps, n), random_state=rng)
...        res = stats.differential_entropy(rvs, method=method, axis=-1)
...        error = rmse(res, expected)
...        method_errors[method].append(error)
>>>
>>> for method, errors in method_errors.items():
...     plt.loglog(ns, errors, label=method)
>>>
>>> plt.legend()
>>> plt.xlabel('sample size')
>>> plt.ylabel('RMSE (1000 trials)')
>>> plt.title('Entropy Estimator Error (Exponential Distribution)')

T)force_floatingr2   rH   zWindow length (z7) must be positive and less than half the sample size (z).r0   r9   vasicekzvan escorreaebrahimirU   z`method` must be one of i  r5   )r   r   moveaxisrI   rA   rK   rL   r:   sort_vasicek_entropy_van_es_entropy_correa_entropy_ebrahimi_entropylowersetrB   astypedtype)rO   rG   r#   r$   rT   r2   rP   sorted_datamethodsmessageress   &$$$$      r   r   r      sp   j 
	 Bt;F[[r*FRA

499Q<##56M!%A%m_ -**+B0
 	

 DAIFGG''&r'*K*,'	)G
 \\^F,S\N;!!7F$YFF
/+
<Ctxx~ 99S,,''r   c                   V P                   RR V3,           pVP                  V R,          V4      pVP                  V RRR13,          V4      pVP                  W@V3RR7      # )z9Pad the data for computing the rolling window difference.N.r9   r]   ).:N   N)rI   broadcast_toconcat)Xmr2   rI   XlXrs   &&$   r   _pad_along_last_axisrt   w  s_     GGCRLA4E	7U	+B	38e	,B99bR[r9**r   c                  V P                   R,          p\        WVR7      p V R^V,          R13,          V RRRV,          13,          ,
          pVP                  V^V,          ,          V,          4      pVP                  VRR7      # )z:Compute the Vasicek estimator as described in [6] Eq. 1.3.r5   .Nr9   r]   )rI   rt   rB   mean)rp   rq   r2   rP   differenceslogss   &&$   r   r`   r`     sr    	AQb)ACQK.1S)BF)^#44K66!QqS'K'(D774b7!!r   c                  V P                   R,          pV RVR13,          V RRV) 13,          ,
          p^W1,
          ,          VP                  VP                  V^,           V,          V,          4      RR7      ,          pVP                  W^,           VP                  \        V 4      R7      pWRP                  ^V,          4      ,           \        P                  ! V4      ,           \        P                  ! V^,           4      ,
          # )z1Compute the van Es estimator as described in [6]..Nr9   rg   devicer]   )rI   r<   rB   arangerg   r   rA   )rp   rq   r2   rP   
differenceterm1ks   &&$    r   ra   ra     s     	
A37aSqbSk)JqsGbffRVVQqS!Gj$89fCCE
		!qSIaL	AA66!A#;!,txx!}<<r   c               *   V P                   R,          p\        WVR7      p V R^V,          R13,          V RRRV,          13,          ,
          pVP                  ^V^,           V P                  \	        V 4      R7      pVP                  WQ8*  ^V^,
          V,          ,           R4      pVP                  WSV,
          ^,           8  ^W5,
          V,          ,           V4      pVP                  W4,          Wa,          ,          4      pVP                  VRR7      # )	z3Compute the Ebrahimi estimator as described in [6].r5   .Nr{   g       @r9   r]   rv   )rI   rt   r}   rg   r   whererB   rw   )rp   rq   r2   rP   rx   iciry   s   &&$     r   rc   rc     s     	
AQb)ACQK.1S)BF)^#44K
		!QqS	!	=A	!&!q1uai-	,B	!1uqy.!quai-	4B66!/RV,-D774b7!!r   c               2   V P                   R,          p\        WVR7      p VP                  ^V^,           \        V 4      R7      pVP                  V) V^,           \        V 4      R7      R,          pWE,           pWa,           ^,
          pVP	                  V RV3,          R	RR7      pV RV3,          V,
          p	VP                  W,          R	R7      p
W2P                  V	^,          R	R7      ,          pVP	                  VP                  W,          4      RR7      ) # )
z1Compute the Correa estimator as described in [6].r5   )r|   .Tr6   r9   r]   ):NNNNrv   )rI   rt   r}   r   rw   r<   rB   )rp   rq   r2   rP   r   djjj0Xibarr~   numdens   &&$         r   rb   rb     s     	
AQb)A
		!QqS1	.A	A2qs9Q<	0	9B	A	
BGGAc2gJR$G7E37e#J
&&R&
(C
FF:q=rF*
*CGGBFF37O"G---r   r]   )NNrF   )r]   )__doc__rA   numpyr&   scipyr   _axis_nan_policyr   scipy._lib._array_apir   r   r   r   r   r	   __all__r
   rQ   r   rt   r`   ra   rc   rb   r   r   r   <module>r      s       6M M ,
-  !24J JZ 1.?0|( !%|( 	|(
 |( |(	 
|(~+"=" .r   