o
    dBP                     @   s   d dl mZ d dlmZ d dlmZmZ d dlmZ	 d dl
mZ d dlmZ edZedZed	Zd
d Zd+ddZd,ddZdd Zdd Zdd Zdd Zdd Zd-ddZdd  Zd!d" Zd#d$ Z				%			%	&	'	(d.d)d*ZdS )/    )absolute_import)Number)
exceptionsoptional_importsN)
graph_objs)make_subplotspandasnumpyzscipy.statsc                 C   s   t | t}t |}t |}t j|ddd}t j|ddd}t j|ddd}|| }d| }t |||| k }	t |||| k }
||||||	|
d	S )
z6
    Calculate statistics for use in violin plot.
    2   linear)interpolation   lowerK   higher      ?)minmaxq1q2q3d1d2)npasarrayfloatr   r   
percentile)dataxvals_minvals_maxr   r   r   iqrwhisker_distr   r    r#   b/var/www/html/visualizacion-main/env/lib/python3.10/site-packages/plotly/figure_factory/_violin.py
calc_stats   s$   

r%   #1f77b4rgb(0, 0, 0)c                    sH    fddt t D }tj dd|d|tjjd|ddd	dd

S )zG
    Produces a sideways probability distribution fig violin plot.
    c                    s4   g | ]}d d  |  d d |  d qS )z(pdf(y), y)=({:0.2f}z, ))format).0ir   yr#   r$   
<listcomp>/   s    &z$make_half_violin.<locals>.<listcomp>lines tonextxg      ?spline)widthcolorshapetext)
r   r.   modenamer7   fill	fillcolorline	hoverinfoopacity)rangelenr   ScatterscatterLine)r   r.   r;   	linecolorr7   r#   r-   r$   make_half_violin+   s   
rE   c              	   C   s4   t j| | | gt|  t jj|dddddddS )z2
    Returns a rugplot fig for a violin plot.
    zline-ew-open)r5   symbolmarkersr1   Fr.   )r.   r   markerr8   r9   
showlegendr=   )r   rA   r@   rB   Marker)valspdf_maxdistancer5   r#   r#   r$   make_violin_rugplotB   s   rN   c              	   C   s(   t jddg| |gddt jjddddS )z?
    Returns the scatterplot fig of most of a violin plot.
    r   r1   r0   r   
rgb(0,0,0)r4   r5   )r   r.   r9   r8   r<   )r   rA   rB   rC   )r   r   r#   r#   r$   make_non_outlier_intervalQ   s   rQ   c              	   C   sB   t jddg| |gdd|  dd| gdt jjdddd	d
S )z@
    Makes the upper and lower quartiles for a violin plot.
    r   zlower-quartile: r(   zupper-quartile: r0      rO   rP   r7   )r   r.   r7   r8   r<   r=   )r   rA   r*   rB   rC   )r   r   r#   r#   r$   make_quartiles^   s   rS   c              	   C   s.   t jdg| gdd|  gdtddddd	S )
z;
    Formats the 'median' hovertext for a violin plot.
    r   zmedian: r(   rG   squarezrgb(255,255,255))rF   r5   r7   )r   r.   r7   r8   rH   r=   )r   rA   r*   dict)r   r#   r#   r$   make_mediano   s   
rV   c              
   C   s    t jj| |ddddddd}|S )z-
    Makes the x-axis for a violin plot.
    Fr1   )titler?   showgridzerolineshowlinemirrorticksshowticklabels)r   layoutXAxis)xaxis_titlexaxis_rangexaxisr#   r#   r$   
make_XAxis}      
rc   c              
   C   s    t jj| dddddddd}|S )z-
    Makes the y-axis for a violin plot.
    TrR   F)rW   r]   	autorangeticklenrZ   rY   rX   r[   )r   r^   YAxis)yaxis_titleyaxisr#   r#   r$   
make_YAxis   rd   rj   Tc                 C   s
  t | t} t| d }t| d }t| d }t| d }t| d }t| d }t| d }	t| }
t ||d}|
|}t |}|rMd	| d
 nd}| | d |d g}t| ||dt|||dt	||	t
||t|g}|r|t| |||d ||fS )z?
    Refer to FigureFactory.create_violin() for docstring.
    r   r   r   r   r   r   r   d   g       @
   r   g?)r;   )rM   r5   )r   r   r   r%   scipy_statsgaussian_kdelinspacer   rE   rQ   rS   rV   appendrN   )rK   r;   rugplotr   r    r   r   r   r   r   pdfxxyymax_pdfrM   plot_xrange	plot_datar#   r#   r$   
violinplot   s2   

rx   c                 C   s4  g }| | D ]}||vr| | q|r|  | |g}t|}td|dddd}d}t|D ]K\}}t||| t	}|t|krHd}t
||| |d\}}t }|D ]}||d|d  qY|d7 }|d d	|d t|| |i q1|d d
dtdi |d j|
ddd||	d |S )u
    Refer to FigureFactory.create_violin() for docstring.

    Returns fig for violin plot without colorscale.

       T皙?Frowscolsshared_yaxeshorizontal_spacing
print_gridr   r;   rq   r^   xaxis{}yaxis{}r1   closestrW   rI   	hovermodeautosizeheightr4   )rp   sortgroupbyr@   r   	enumerater   r   	get_groupr   rx   r   Layoutappend_traceupdater*   rc   rj   )r   data_headergroup_headercolorsuse_colorscalegroup_statsrq   r   r   r4   rW   
group_namer9   gbLfigcolor_indexkgrrK   rw   rv   r^   itemr#   r#   r$   violin_no_colorscale   sJ   



	r   c           !      C   s  g }| | D ]}||vr| | q|r|  |D ]}||vr%tdq| |g}t|}td|dddd}t|d tj	}t|d tj	}g }|D ]	}| ||  qOt
|}t|}t|D ]Q\}}t||| t}|| | ||  }t|||}t|d||d	\}}t }|D ]}||d|d  q|d
 d|d t|| |i qetjdgdgdtd||d|d gd|d ggdddd} || d| |d
 ddtdi |d
 j|
ddd||	d |S )zr
    Refer to FigureFactory.create_violin() for docstring.

    Returns fig for violin plot with colorscale.

    zRAll values/groups in the index column must be represented as a key in group_stats.rz   Tr{   Fr|   r   zrgb{}r   r^   r   rG      )sizecmincmax
colorscale	showscale)r   r.   r8   rH   rI   r   r1   r   r   )rp   r   r   PlotlyErrorr   r@   r   clrscolor_parserunlabel_rgbr   r   r   r   r   r   r   find_intermediate_colorrx   r*   r   r   r   r   rc   rA   rU   rj   )!r   r   r   r   r   r   rq   r   r   r4   rW   r   r9   groupr   r   r   lowcolor	highcolorgroup_stats_valueskey	max_value	min_valuer   r   rK   intermedintermed_colorrw   rv   r^   r   trace_dummyr#   r#   r$   violin_colorscale	  s|   


	r   c                 C   s4  g }| | D ]}||vr| | q|r|  |D ]}||vr%tdq| |g}t|}td|dddd}t|D ]?\}}t	|
|| t}t||| |d\}}t }|D ]}||d|d  q]|d d	|d t|| |i q=|d d
dtdi |d j|
ddd||	d |S )ry   zMIf colors is a dictionary, all the group names must appear as keys in colors.rz   Tr{   Fr|   r   r^   r   r   r1   r   r   )rp   r   r   r   r   r@   r   r   r   r   r   r   rx   r   r   r   r   r*   rc   rj   )r   r   r   r   r   r   rq   r   r   r4   rW   r   r9   r   r   r   r   r   r   rK   rw   rv   r^   r   r#   r#   r$   violin_dictp  sJ   

	r   F  X  Violin and Rug Plotc                 C   s  t |trt|d}nt|d}|du rt | tr4t| dkr&tdt	dd | D s4tdt
rNt | t
jjjrN|du rGtd| | j } t| |d |d	\}}tj|
d
tjjdd|d
|	td|tddd	}|d td
d
dd tj||d}|S t | t
jjjstd|du rtd|d
u rt |trt| |||||||||	|
}|S t| |||||||||	|
}|S t |trtdt|dk rtdt |tstdt| |||||||||	|
}|S )a}  
    **deprecated**, use instead the plotly.graph_objects trace
    :class:`plotly.graph_objects.Violin`.

    :param (list|array) data: accepts either a list of numerical values,
        a list of dictionaries all with identical keys and at least one
        column of numeric values, or a pandas dataframe with at least one
        column of numbers.
    :param (str) data_header: the header of the data column to be used
        from an inputted pandas dataframe. Not applicable if 'data' is
        a list of numeric values.
    :param (str) group_header: applicable if grouping data by a variable.
        'group_header' must be set to the name of the grouping variable.
    :param (str|tuple|list|dict) colors: either a plotly scale name,
        an rgb or hex color, a color tuple, a list of colors or a
        dictionary. An rgb color is of the form 'rgb(x, y, z)' where
        x, y and z belong to the interval [0, 255] and a color tuple is a
        tuple of the form (a, b, c) where a, b and c belong to [0, 1].
        If colors is a list, it must contain valid color types as its
        members.
    :param (bool) use_colorscale: only applicable if grouping by another
        variable. Will implement a colorscale based on the first 2 colors
        of param colors. This means colors must be a list with at least 2
        colors in it (Plotly colorscales are accepted since they map to a
        list of two rgb colors). Default = False
    :param (dict) group_stats: a dictionary where each key is a unique
        value from the group_header column in data. Each value must be a
        number and will be used to color the violin plots if a colorscale
        is being used.
    :param (bool) rugplot: determines if a rugplot is draw on violin plot.
        Default = True
    :param (bool) sort: determines if violins are sorted
        alphabetically (True) or by input order (False). Default = False
    :param (float) height: the height of the violin plot.
    :param (float) width: the width of the violin plot.
    :param (str) title: the title of the violin plot.

    Example 1: Single Violin Plot

    >>> from plotly.figure_factory import create_violin
    >>> import plotly.graph_objs as graph_objects

    >>> import numpy as np
    >>> from scipy import stats

    >>> # create list of random values
    >>> data_list = np.random.randn(100)

    >>> # create violin fig
    >>> fig = create_violin(data_list, colors='#604d9e')

    >>> # plot
    >>> fig.show()

    Example 2: Multiple Violin Plots with Qualitative Coloring

    >>> from plotly.figure_factory import create_violin
    >>> import plotly.graph_objs as graph_objects

    >>> import numpy as np
    >>> import pandas as pd
    >>> from scipy import stats

    >>> # create dataframe
    >>> np.random.seed(619517)
    >>> Nr=250
    >>> y = np.random.randn(Nr)
    >>> gr = np.random.choice(list("ABCDE"), Nr)
    >>> norm_params=[(0, 1.2), (0.7, 1), (-0.5, 1.4), (0.3, 1), (0.8, 0.9)]

    >>> for i, letter in enumerate("ABCDE"):
    ...     y[gr == letter] *=norm_params[i][1]+ norm_params[i][0]
    >>> df = pd.DataFrame(dict(Score=y, Group=gr))

    >>> # create violin fig
    >>> fig = create_violin(df, data_header='Score', group_header='Group',
    ...                    sort=True, height=600, width=1000)

    >>> # plot
    >>> fig.show()

    Example 3: Violin Plots with Colorscale

    >>> from plotly.figure_factory import create_violin
    >>> import plotly.graph_objs as graph_objects

    >>> import numpy as np
    >>> import pandas as pd
    >>> from scipy import stats

    >>> # create dataframe
    >>> np.random.seed(619517)
    >>> Nr=250
    >>> y = np.random.randn(Nr)
    >>> gr = np.random.choice(list("ABCDE"), Nr)
    >>> norm_params=[(0, 1.2), (0.7, 1), (-0.5, 1.4), (0.3, 1), (0.8, 0.9)]

    >>> for i, letter in enumerate("ABCDE"):
    ...     y[gr == letter] *=norm_params[i][1]+ norm_params[i][0]
    >>> df = pd.DataFrame(dict(Score=y, Group=gr))

    >>> # define header params
    >>> data_header = 'Score'
    >>> group_header = 'Group'

    >>> # make groupby object with pandas
    >>> group_stats = {}
    >>> groupby_data = df.groupby([group_header])

    >>> for group in "ABCDE":
    ...     data_from_group = groupby_data.get_group(group)[data_header]
    ...     # take a stat of the grouped data
    ...     stat = np.median(data_from_group)
    ...     # add to dictionary
    ...     group_stats[group] = stat

    >>> # create violin fig
    >>> fig = create_violin(df, data_header='Score', group_header='Group',
    ...                     height=600, width=1000, use_colorscale=True,
    ...                     group_stats=group_stats)

    >>> # plot
    >>> fig.show()
    rgbNr   zRIf data is a list, it must be nonempty and contain either numbers or dictionaries.c                 s   s    | ]}t |tV  qd S )N)
isinstancer   )r+   elementr#   r#   r$   	<genexpr>R  s    z create_violin.<locals>.<genexpr>z0If data is a list, it must contain only numbers.zVdata_header must be the column name with the desired numeric data for the violin plot.r   F   )r   r1   r   )	rW   r   fontr   rI   r4   rb   ri   r   ri   )rZ   r]   r\   )r   r^   zGError. You must use a pandas DataFrame if you are using a group header.zFThe colors param cannot be a dictionary if you are using a colorscale.r   zHcolors must be a list with at least 2 colors. A Plotly scale is allowed.z,Your group_stats param must be a dictionary.)r   rU   r   validate_colors_dictvalidate_colorslistr@   r   r   allpdcoreframe	DataFramevaluestolistrx   r   r   r^   Fontrc   rj   r   Figurer   r   r   )r   r   r   r   r   r   rq   r   r   r4   rW   valid_colorsrw   rv   r^   r   r#   r#   r$   create_violin  s    






r   )r&   r'   )r&   )r&   T)
NNNFNTFr   r   r   )
__future__r   numbersr   plotlyr   r   plotly.colorsr   r   plotly.graph_objsr   plotly.subplotsr   
get_moduler   r   rm   r%   rE   rN   rQ   rS   rV   rc   rj   rx   r   r   r   r   r#   r#   r#   r$   <module>   s@    





'CgJ