
    j2                    r    d dl mZ d dlmZ d dlmZ d dlZd dlZd dl	m
Z
mZ d dlmZ  G d de
          ZdS )	    )annotations)cycle)AnyN)BaseSolutionSolutionResults)plt_settingsc                  X     e Zd ZdZ e            d fd            ZddZ	 dddZ xZS )	Analyticsa  A class for creating and updating various types of charts for visual analytics.

    This class extends BaseSolution to provide functionality for generating line, bar, pie, and area charts based on
    object detection and tracking data.

    Attributes:
        type (str): The type of analytics chart to generate ('line', 'bar', 'pie', or 'area').
        x_label (str): Label for the x-axis.
        y_label (str): Label for the y-axis.
        bg_color (str): Background color of the chart frame.
        fg_color (str): Foreground color of the chart frame.
        title (str): Title of the chart window.
        max_points (int): Maximum number of data points to display on the chart.
        fontsize (int): Font size for text display.
        color_cycle (cycle): Cyclic iterator for chart colors.
        total_counts (int): Total count of detected objects (used for line charts).
        clswise_count (dict[str, int]): Dictionary for class-wise object counts.
        fig (Figure): Matplotlib figure object for the chart.
        ax (Axes): Matplotlib axes object for the chart.
        canvas (FigureCanvasAgg): Canvas for rendering the chart.
        lines (dict): Dictionary to store line objects for area charts.
        color_mapping (dict[str, str]): Dictionary mapping class labels to colors for consistent visualization.

    Methods:
        process: Process image data and update the chart.
        update_graph: Update the chart with new data points.

    Examples:
        >>> analytics = Analytics(analytics_type="line")
        >>> frame = cv2.imread("image.jpg")
        >>> results = analytics.process(frame, frame_number=1)
        >>> cv2.imshow("Analytics", results.plot_im)
    kwargsr   returnNonec                    t                      j        di | ddlm} ddlm} ddlm} | j        d         | _	        | j	        dv rdnd| _
        d	| _        d
| _        d| _        d| _        d| _        d| _        | j        d         }t#          g d          | _        d| _        i | _        |                    dd          | _        d| _        | j	        dv ri | _         || j        |          | _         || j                  | _        | j                            d| j                  | _        | j	        dk    r,| j                            g g d| j                  \  | _        dS dS | j	        dv r|                     || j                  \  | _        | _         || j                  | _        | j        !                    | j                   i | _"        | j	        dk    r| j        #                    d           dS dS dS )zSInitialize Analytics class with various chart types for visual data representation.r   N)FigureCanvasAgg)Figureanalytics_type>   barpieClasseszFrame#zTotal Countsz#F3F3F3z#111E68zUltralytics Solutions-      figsizez#DD00BAz#042AFFz#FF4447z#7D24FFz#BD00FFupdate_every   >   arealine)	facecolorr   o   )r   r   cyan)color	linewidth)r   r   r   equal )$super__init__matplotlib.pyplotpyplotmatplotlib.backends.backend_aggr   matplotlib.figurer   CFGtypex_labely_labelbg_colorfg_colortitle
max_pointsfontsizer   color_cycletotal_countsclswise_countgetr   last_plot_imlinesfigcanvasadd_subplotaxplot
line_widthr   subplotsset_facecolorcolor_mappingaxis)selfr   pltr   r   r   	__class__s         d/home/longshao/multi-rider-rag/.venv/lib/python3.11/site-packages/ultralytics/solutions/analytics.pyr%   zAnalytics.__init__2   s,    	""6"""''''''CCCCCC,,,,,,H-.	$(I$?$?yyX% "!,
(9% !X!X!XYY"JJ~r::  9(((DJvwGGGDH)/$(33DKh**3$-*HHDGyF""#w||B&DO|\\ #"Y.(( #W V VDHdg)/$(33DKG!!$-000!#DyE!!W%%%%% )( "!    im0
np.ndarrayframe_numberintr   c                p                          |            j        dk    r] j        D ]} xj        dz  c_        | j        z  dk    p j        du }|r                     |           _         j        }d _        n j        dv roddlm}  | fd j	        D                        _
        | j        z  dk    p j        du }|r'                     | j
         j        	           _         j        }nt          d
 j         d          t          |t           j                   j
                  S )a  Process image data and run object tracking to update analytics charts.

        Args:
            im0 (np.ndarray): Input image for processing.
            frame_number (int): Video frame number for plotting the data.

        Returns:
            (SolutionResults): Contains processed image `plot_im`, 'total_tracks' (int, total number of tracked objects)
                and 'classwise_count' (dict, per-class object count).

        Raises:
            ValueError: If an unsupported chart type is specified.

        Examples:
            >>> analytics = Analytics(analytics_type="line")
            >>> frame = np.zeros((480, 640, 3), dtype=np.uint8)
            >>> results = analytics.process(frame, frame_number=1)
        r      r   N)rJ   >   r   r   r   )Counterc              3  L   K   | ]}j         t          |                   V  d S )N)namesrK   ).0clsrC   s     rF   	<genexpr>z$Analytics.process.<locals>.<genexpr>~   s0      (S(S#CHH)=(S(S(S(S(S(SrG   )rJ   
count_dictr=   zUnsupported analytics_type='z)'. Supported types: line, bar, pie, area.)plot_imtotal_tracksclasswise_count)extract_tracksr+   boxesr4   r   r7   update_graphcollectionsrN   clssr5   
ValueErrorr   len	track_ids)rC   rH   rJ   _update_requiredrU   rN   s   `      rF   processzAnalytics.process_   s   & 	C   9Z ' '!!Q&!!!*T->>!C`tGX\`G`O Q$($5$5<$5$P$P!'G !DY000++++++!((S(S(S(S(S(S(S!S!SD*T->>!C`tGX\`G`O $($5$5!-$:LSWS\ %6 % %! 'GGpDIpppqqq wS=P=PbfbtuuuurG   Nr   rT   dict[str, int] | Noner=   strc                    |<t          j         j                                        t	          |                    }t          j         j                                        t	           j                            }t          |           j        k    r | j         d         | j         d         }} j        	                    ||            j        
                    d            j                            d            j                            d            j                             j        dz             nt          |                                          }t          |                                          }|dk    rot%          g d          } j        j        r$ j        j        d                                         nt          j        g           }d	 |                                D             }	 j        j        rIt-           j        j        |                                          D ]\  }
}|
                                |	|<   t          j        |t	          |                    }t          |          }|                                D ]}t          j        |	|         t	          ||                             |	|<   t          |	|                   |k     r6t          j        |	|         d|t          |	|                   z
  f          |	|<   t          |           j        k    r4|d
d         }|                                D ]}|	|         d
d         |	|<    j                                         |	                                D ]c\  }}t5          |          } j                            |||d            j                            ||| j        d j        dz  | d           dn	|dk    rF j                                         |D ]'}| j        vrt5           j                   j        |<   ( fd|D             } j                            |||          }t-          ||          D ]s\  }} j                             |!                                |"                                dz  z   |#                                tI          |          dd j%                   tt-          ||          D ]\  }}|
                    |            j        &                    dd j%         j%                   n|dk    rtO          |          fd|D             } j                                         d} j        (                    |||d j%        id          \  }}d t-          ||          D             } j        &                    ||d d!d"#            j)        *                    d$d%&            j        +                    d'            j        ,                    d(d)d*d*+            j        -                     j.         j%         j/        ,            j        0                     j1         j%         j/        d-z
  ,            j        2                     j3         j%         j/        d-z
  ,            j        &                    dd j4         j4                  }|5                                D ]}|                     j%                    j        6                                  j        7                                  j8        9                                 t          j         j8        j:        ;                                          }ty          j=        |dddddd-f         tx          j>                  } ?                    |           |S ).a  Update the graph with new data for single or multiple classes.

        Args:
            frame_number (int): The current frame number.
            count_dict (dict[str, int], optional): Dictionary with class names as keys and counts as values for multiple
                classes. If None, updates a single line graph.
            plot (str): Type of the plot. Options are 'line', 'bar', 'pie', or 'area'.

        Returns:
            (np.ndarray): Updated image containing the graph.

        Examples:
            >>> analytics = Analytics(analytics_type="bar")
            >>> frame_num = 10
            >>> results_dict = {"person": 5, "car": 3}
            >>> updated_image = analytics.update_graph(frame_num, results_dict, plot="bar")
        NCountsz#7b0068*   r   r   r   c                8    i | ]}|t          j        g           S r#   )nparray)rQ   keys     rF   
<dictcomp>z*Analytics.update_graph.<locals>.<dictcomp>   s"    NNNSsBHRLLNNNrG   rM   g?)r    alphaoz Data Points)r    r!   marker
markersizelabelr   c                *    g | ]}j         |         S r#   )rA   )rQ   rr   rC   s     rF   
<listcomp>z*Analytics.update_graph.<locals>.<listcomp>   s!    HHH$,U3HHHrG   )r       centerbottom)havar    z
upper left   )locr2   r   	edgecolorr   c                     g | ]
}|z  d z  S )d   r#   )rQ   sizetotals     rF   rt   z*Analytics.update_graph.<locals>.<listcomp>   s"    EEEdte|c1EEErG   Z   r    )labels
startangle	textpropsautopctc                &    g | ]\  }}| d |ddS )z (z.1fz%)r#   )rQ   rr   
percentages      rF   rt   z*Analytics.update_graph.<locals>.<listcomp>   s1     r r rDUE:E!?!?Z!?!?!?!? r r rrG   r   zcenter left)rM   r         ?rM   )r0   r{   bbox_to_anchorg?g      ?)leftrightz#f0f0f0Tz--r   )	linestyler!   rn   )r    r2      )@rj   appendr   	get_xdatafloat	get_ydatar4   r^   r1   set_data	set_label	set_color
set_markerset_markersizer>   listkeysvaluesr   r<   r8   rk   zippadclearitemsnextfill_betweenr=   rA   r3   r   textget_x	get_width
get_heightrd   r/   legendsumr   r9   subplots_adjustr@   grid	set_titler0   r2   
set_xlabelr,   
set_ylabelr-   r.   	get_textsrelimautoscale_viewr:   drawrendererbuffer_rgbacv2cvtColorCOLOR_RGBA2BGRdisplay_output)rC   rJ   rT   r=   x_datay_datar   countsr3   y_data_dictr   rl   
max_lengthr    rr   colorsbarsr   countpercentagesstart_anglewedgesr`   legend_labelsr   r   rH   r   s   `                          @rF   rZ   zAnalytics.update_graph   sv   ( Yty2244eL6I6IJJFYty2244eD<M6N6NOOF6{{T_,,!'(8(:(:!;VT_DTDVDV=WIvv...I)))I	***I  %%%I$$T_q%89999*//++,,F*++--..Fv~~#$[$[$[\\9=Xq)33555BHUWLLNNJOO<M<MNNN7= <%(
8I8I%J%J < <	c+/>>+;+;C((65+>+>?? [[
%??,, m mC')yS1A5TWCYCY'Z'ZK$;s+,,z99+-6+c2BQ
UXYdehYiUjUjHjDk+l+lC(v;;00#ABBZF)00 @ @+6s+;ABB+?C((#.#4#4#6#6  KC --EG((uD(QQQGLL#"&/"#'?Q#6!$222 !     # K KED$666489I4J4J*51HHHHHHHw{{66{@@"%dF"3"3  JCGLL		cmmoo&99((E

##"m !     #&dF"3"3 ) )JCMM%((((<"aeanooooFEEEEfEEE  GKK6kgW[WdMeos (  	 !s rY\]cepYqYq r r r v}I=iwxxx((c(>>> 	i(((TTSDDD$*DMDMRRR4<t}t}WXGXYYY4<t}t}WXGXYYY L2bfbopp$$&& 	* 	*DNN4=)))) 	   ht{+7799::l3qqq!!!RaRx=#*<==C   
rG   )r   r   r   r   )rH   rI   rJ   rK   r   r   )Nr   )rJ   rK   rT   rc   r=   rd   r   rI   )	__name__
__module____qualname____doc__r   r%   rb   rZ   __classcell__)rE   s   @rF   r
   r
      s           D \^^*& *& *& *& *& ^*&X*v *v *v *vZ X^} } } } } } } } }rG   r
   )
__future__r   	itertoolsr   typingr   r   numpyrj   ultralytics.solutions.solutionsr   r   ultralytics.utilsr   r
   r#   rG   rF   <module>r      s    # " " " " "             



     I I I I I I I I * * * * * *y y y y y y y y y yrG   