
    hh8$                     x    d Z ddlZddlmZ ddlmZ ej                  Zej                  ZddZ	 	 	 	 d	dZ	d
dZ
y)a  Histogram summaries and TensorFlow operations to create them.

A histogram summary stores a list of buckets. Each bucket is encoded as
a triple `[left_edge, right_edge, count]`. Thus, a full histogram is
encoded as a tensor of dimension `[k, 3]`.

In general, the value of `k` (the number of buckets) will be a constant,
like 30. There are two edge cases: if there is no data, then there are
no buckets (the shape is `[0, 3]`); and if there is data but all points
have the same value, then there is one bucket whose left and right
endpoints are the same (the shape is `[1, 3]`).

NOTE: This module is in beta, and its API is subject to change, but the
data that it stores to disk will be supported forever.
    N)metadata)
summary_v2c                 ,    ddl mc m t        j                  j                  d g      5  j                  j                        j                  j                        g      5  j                   dg       j                   j                         j                  j                         d      }fd} fd	}j                  |||      cddd       cddd       S # 1 sw Y   nxY wddd       y# 1 sw Y   yxY w)
a  Create a TensorFlow op to group data into histogram buckets.

    Arguments:
      data: A `Tensor` of any shape. Must be castable to `float64`.
      bucket_count: Optional positive `int` or scalar `int32` `Tensor`.
    Returns:
      A `Tensor` of shape `[k, 3]` and type `float64`. The `i`th row is
      a triple `[left_edge, right_edge, count]` for a single bucket.
      The value of `k` is either `bucket_count` or `1` or `0`.
    r   Nbuckets)values)shapeinputc                  @     j                  g d j                        S )Nr      )r	   dtype)constantfloat64)tfs   c/var/www/html/dev/engine/venv/lib/python3.12/site-packages/tensorboard/plugins/histogram/summary.py
when_emptyz_buckets.<locals>.when_emptyD   s    ;;rrzz;BB    c                      j                        j                        z
  j                  d      } fd}fd}j                  | ||      S )N)input_tensorr   c                     j                  	j                        z  } 
z
  }j                  j                  || z        j                        }j	                  |	dz
        }j                  |	j                        }j                  j                  |d      j                        }j                  	dz         }|d d }|dd  }j                  j                  |||g            S )Nr      )depthr   r   )r   axisr   a)
castr   floorint32minimumone_hot
reduce_sumlinspace	transposestack)bucket_widthoffsetsbucket_indicesclamped_indicesone_hotsbucket_countsedges
left_edgesright_edgesbucket_countdatamax_min_range_r   s            r   when_nonsingularz9_buckets.<locals>.when_nonempty.<locals>.when_nonsingularM   s
   %bjj(II+!#HHW|34BHH ") " #%**^\A=M"N ::#<rzz &  !#MMxaM@** !( ! D$q0@A"3BZ
#ABi||hh
KGH $  r   c                     } j                  | dz
  g      }j                  | dz   g      }j                  j                  j                        j                        g      }j	                  j                  |||g            S )N      ?r
   r   )r'   r   sizer   r&   )centerbucket_startsbucket_endsr-   r2   r4   r   s       r   when_singularz6_buckets.<locals>.when_nonempty.<locals>.when_singulare   s     "&3, 8 hh~6 "WWRWW4W0"**=>! ||hh{MJK $  r   )
reduce_min
reduce_maxequalcond)	is_singularr6   r=   r3   r4   r5   r1   r2   r   s	      @@@r   when_nonemptyz_buckets.<locals>.when_nonemptyG   sa    ==d=3D==d=3DD[F((61-K 0	 77;7GHHr   )tensorflow.compat.v1compatv1r   DEFAULT_BUCKET_COUNT
name_scopecontrol_dependenciesassert_scalarassert_typer!   reshaper   r   r@   r9   rA   )r2   r1   is_emptyr   rC   r   s   ``   @r   _bucketsrN   +   s     &%!66	4. 
 
 7<				,	'bhh)OP7<
 zz$rdz+wwtRZZ(88BGG$G/3	C)	IV wwx];o7< 7< 7< 7< 7< 7< 7<s$   =D
1A1C5"	D
5C>	:D

Dc                     ddl mc m} || }t        j                  ||      }|j                  |       5  t        ||      }|j                  j                  d|||      cddd       S # 1 sw Y   yxY w)a  Create a legacy histogram summary op.

    Arguments:
      name: A unique name for the generated summary node.
      data: A `Tensor` of any shape. Must be castable to `float64`.
      bucket_count: Optional positive `int`. The output will have this
        many buckets, except in two edge cases. If there is no data, then
        there are no buckets. If there is data but all points have the
        same value, then there is one bucket whose left and right
        endpoints are the same.
      display_name: Optional name for this summary in TensorBoard, as a
        constant `str`. Defaults to `name`.
      description: Optional long-form description for this summary, as a
        constant `str`. Markdown is supported. Defaults to empty.
      collections: Optional list of graph collections keys. The new
        summary op is added to these collections. Defaults to
        `[Graph Keys.SUMMARIES]`.

    Returns:
      A TensorFlow summary op.
    r   Ndisplay_namedescription)r1   histogram_summary)nametensorcollectionssummary_metadata)	rD   rE   rF   r   create_summary_metadatarH   rN   summarytensor_summary)	rT   r2   r1   rQ   rR   rV   r   rW   rU   s	            r   opr[   u   s}    < &%77!{ 
t	 
$\:zz(($#-	 ) 

 
 
s   ,A,,A5c                 R   ddl mc m} |t        j                  }t        j                  |      j                         j                  t              }|j                  dk(  r&t        j                  g       j                  d      }nt        j                  |      }t        j                  |      }||z
  }	|	dk(  r6|}
t        j                  |
dz
  |
dz   t        |j                        gg      }n$|	|z  }||z
  }t        j                  ||z        j                  t              }t        j                   ||dz
        }t        j                  |g      j#                         t        j$                  d|      k(  }|j&                  |j                  |fk(  sJ |j&                  |j                  |ff       t        j(                  |d      }t        j*                  |||dz         }|dd }|dd }t        j                  |||g      j#                         }|j-                  ||j.                        }|| }t1        j2                  ||	      }|j4                  j7                  |j9                               }|j;                         }|j<                  j?                  d
| z  ||       |S )aa  Create a legacy histogram summary protobuf.

    Arguments:
      name: A unique name for the generated summary, including any desired
        name scopes.
      data: A `np.array` or array-like form of any shape. Must have type
        castable to `float`.
      bucket_count: Optional positive `int`. The output will have this
        many buckets, except in two edge cases. If there is no data, then
        there are no buckets. If there is data but all points have the
        same value, then there is one bucket whose left and right
        endpoints are the same.
      display_name: Optional name for this summary in TensorBoard, as a
        `str`. Defaults to `name`.
      description: Optional long-form description for this summary, as a
        `str`. Markdown is supported. Defaults to empty.

    Returns:
      A `tf.Summary` protobuf object.
    r   Nr   r8   r   )r   r   r   rP   z%s/histogram_summary)tagr   rU   ) rD   rE   rF   r   rG   nparrayflattenastypefloatr9   rL   minmaxr    intr"   r&   aranger	   sumr%   make_tensor_protor   r   rX   SummaryMetadata
FromStringSerializeToStringSummaryvalueadd)rT   r2   r1   rQ   rR   r   r   r4   r3   r5   r:   r(   r)   r*   r+   r,   r-   r.   r/   r0   rU   rW   tf_summary_metadatarY   s                           r   pbrp      se   , &%!6688D>!!#**51DyyA~((2,&&v.vvd|vvd|Q;Fhh#v|U499=M NOPG!L0LTkGXXg&<=DDSIN jj9IJOxx 12<<>"))<C H >>dii%>> L)A > FF8!4MKKdL1,<=EsJ)Khh[-8ik  !!'!<F77!{ ,,77**, jjlGMM"T)$  
 Nr   )N)NNNN)NNN)__doc__numpyr^   tensorboard.plugins.histogramr   r   	histogramhistogram_pbrN   r[   rp    r   r   <module>rw      sN   "  2 4   	&&G<Z ,
^Hr   