a
    Sicl                     @   s  d dl Z d dlmZ d dlZd dlZddlmZ ddl	m
Z
mZ ddlmZmZ ddlmZ g dZeg d	g d
g dg dg dg dg dg dg dg dg dg ddZdddddddddddddZe Zedd e D  ee ZG dd deZd d! ZdNd#d$ZdOd)d*ZdPd,d-Z dQd.d/Z!d0d1 Z"dRd3d4Z#dSd5d6Z$dTd:d;Z%dUd<d=Z&d>d? Z'd@dA Z(dVdGdHZ)dIdJ Z*dWdLdMZ+dS )X    N)cycle   )husl)
desaturateget_color_cycle)xkcd_rgbcrayons)get_colormap)color_palettehls_palettehusl_palettempl_palettedark_palettelight_palettediverging_paletteblend_palettexkcd_palettecrayon_palettecubehelix_paletteset_color_codes)
#4C72B0z#DD8452#55A868#C44E52#8172B3z#937860z#DA8BC3z#8C8C8C#CCB974#64B5CD)r   r   r   r   r   r   )
#4878D0z#EE854A#6ACC64#D65F5F#956CB4z#8C613Cz#DC7EC0z#797979#D5BB67#82C6E2)r   r   r   r   r    r!   )
#A1C9F4z#FFB482#8DE5A1#FF9F9B#D0BBFFz#DEBB9Bz#FAB0E4z#CFCFCF#FFFEA3#B9F2F0)r"   r#   r$   r%   r&   r'   )
#023EFFz#FF7C00#1AC938#E8000B#8B2BE2z#9F4800z#F14CC1z#A3A3A3#FFC400#00D7FF)r(   r)   r*   r+   r,   r-   )
#001C7Fz#B1400D#12711C#8C0800#591E71z#592F0Dz#A23582z#3C3C3C#B8850A#006374)r.   r/   r0   r1   r2   r3   )
#0173B2z#DE8F05#029E73#D55E00#CC78BCz#CA9161z#FBAFE4z#949494#ECE133#56B4E9)r4   r5   r6   r7   r8   r9   )deepZdeep6mutedZmuted6ZpastelZpastel6ZbrightZbright6darkZdark6Z
colorblindZcolorblind6
      	         )tab10tab20tab20btab20cSet1Set2Set3AccentPairedPastel1Pastel2Dark2c                 C   s   i | ]\}}|t |qS  )len.0kvrN   rN   L/var/www/html/django/DPS/env/lib/python3.9/site-packages/seaborn/palettes.py
<dictcomp>9       rU   c                   @   s0   e Zd ZdZdd Zdd Zdd Zdd	 Zd
S )_ColorPalettez?Set the color palette in a with statement, otherwise be a list.c                 C   s    ddl m} t | _||  | S )zOpen the context.r   set_palette)rcmodrY   r
   _orig_palette)selfrY   rN   rN   rT   	__enter__?   s    z_ColorPalette.__enter__c                 G   s   ddl m} || j dS )zClose the context.r   rX   N)rZ   rY   r[   )r\   argsrY   rN   rN   rT   __exit__F   s    z_ColorPalette.__exit__c                 C   s   dd | D }t |S )z<Return a color palette with hex codes instead of RGB values.c                 S   s   g | ]}t j|qS rN   )mplcolorsrgb2hex)rQ   rgbrN   rN   rT   
<listcomp>M   rV   z(_ColorPalette.as_hex.<locals>.<listcomp>)rW   )r\   hexrN   rN   rT   as_hexK   s    z_ColorPalette.as_hexc                 C   sj   d}t | }d||  d| d}t|  D ].\}}|d||  d| d| d| d	7 }q.|d	7 }|S )
z6Rich display of the color palette in an HTML frontend.7   z<svg  width="z
" height="">z	<rect x="z" y="0" width="z" style="fill:z*;stroke-width:2;stroke:rgb(255,255,255)"/>z</svg>)rO   	enumeraterf   )r\   snhtmlicrN   rN   rT   _repr_html_P   s     z_ColorPalette._repr_html_N)__name__
__module____qualname____doc__r]   r_   rf   ro   rN   rN   rN   rT   rW   =   s
   rW   c                  C   s(   dd } dd }| t jj_|t jj_dS )zASimplify the rich display of matplotlib color maps in a notebook.c                 S   sr   ddl }ddlm} ddl}d}||dd|d |d df}| |dd}| }||j|dd	 |	 S )
z.Generate a PNG representation of the Colormap.r   N)Image)i  2   r   T)bytespng)format)
ioPILrt   numpytilelinspaceBytesIO	fromarraysavegetvalue)r\   ry   rt   npZ
IMAGE_SIZEXpixels	png_bytesrN   rN   rT   
_repr_png_`   s    "z+_patch_colormap_display.<locals>._repr_png_c                 S   sH   ddl }|  }||d}d| j d d | j d d | d	 S )
z0Generate an HTML representation of the Colormap.r   Nasciiz
<img alt="z color map" ztitle=""zsrc="   )base64r   	b64encodedecodename)r\   r   r   
png_base64rN   rN   rT   ro   l   s(    z,_patch_colormap_display.<locals>._repr_html_N)r`   ra   Colormapr   ro   )r   ro   rN   rN   rT   _patch_colormap_display^   s    

r   Fc           
   	      sl  | du r"t  } |du rt| }nt| tsD| } |du r@t| }n|du rXt| d}| tv rlt|  } n|| dkrt||d} nd| dkrt||d} nL| 	 dkrt
dn4| drt| \}}t|g|R i |d	|i} n| d
r2| d\}}|d}|r |dd }t||||d} n| drz| d\}}|d}|rh|dd }t||||d} nn| dr| d\}}	|	d}	t|	||d} n:zt| ||d} W n& t
tfy   t
|  dY n0  dur fdd| D } |sht| fddt|D } zttjjj| } t| } W n" t
yf   t
d|  Y n0 | S )a  Return a list of colors or continuous colormap defining a palette.

    Possible ``palette`` values include:
        - Name of a seaborn palette (deep, muted, bright, pastel, dark, colorblind)
        - Name of matplotlib colormap
        - 'husl' or 'hls'
        - 'ch:<cubehelix arguments>'
        - 'light:<color>', 'dark:<color>', 'blend:<color>,<color>',
        - A sequence of colors in any format matplotlib accepts

    Calling this function with ``palette=None`` will return the current
    matplotlib color cycle.

    This function can also be used in a ``with`` statement to temporarily
    set the color cycle for a plot or set of plots.

    See the :ref:`tutorial <palette_tutorial>` for more information.

    Parameters
    ----------
    palette : None, string, or sequence, optional
        Name of palette or None to return current palette. If a sequence, input
        colors are used but possibly cycled and desaturated.
    n_colors : int, optional
        Number of colors in the palette. If ``None``, the default will depend
        on how ``palette`` is specified. Named palettes default to 6 colors,
        but grabbing the current palette or passing in a list of colors will
        not change the number of colors unless this is specified. Asking for
        more colors than exist in the palette will cause it to cycle. Ignored
        when ``as_cmap`` is True.
    desat : float, optional
        Proportion to desaturate each color by.
    as_cmap : bool
        If True, return a :class:`matplotlib.colors.ListedColormap`.

    Returns
    -------
    list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    set_palette : Set the default color cycle for all plots.
    set_color_codes : Reassign color codes like ``"b"``, ``"g"``, etc. to
                      colors from one of the seaborn palettes.

    Examples
    --------

    .. include:: ../docstrings/color_palette.rst

    N   hlsas_cmapr   jetzNo.ch:r   zlight::_r)reverser   zdark:zblend:,z is not a valid palette namec                    s   g | ]}t | qS rN   )r   )rQ   rn   )desatrN   rT   rd      rV   z!color_palette.<locals>.<listcomp>c                    s   g | ]}t  qS rN   )next)rQ   _)	pal_cyclerN   rT   rd      rV   z!Could not generate a palette for )r   rO   
isinstancestrQUAL_PALETTE_SIZESgetSEABORN_PALETTESr   r   lower
ValueError
startswith_parse_cubehelix_argsr   splitendswithr   r   r   r   KeyErrorr   rangemapr`   ra   colorConverterto_rgbrW   )
paletten_colorsr   r   r^   kwargsr   colorr   ra   rN   )r   r   rT   r
   z   sh    4

 



r
   r   {Gz?333333??c                    sv   |rd} t ddt| d dd }||7 }|d; }||t8 } fdd|D }|rjtj|dS t|S dS )	aC  
    Return hues with constant lightness and saturation in the HLS system.

    The hues are evenly sampled along a circular path. The resulting palette will be
    appropriate for categorical or cyclical data.

    The `h`, `l`, and `s` values should be between 0 and 1.

    .. note::
        While the separation of the resulting colors will be mathematically
        constant, the HLS system does not construct a perceptually-uniform space,
        so their apparent intensity will vary.

    Parameters
    ----------
    n_colors : int
        Number of colors in the palette.
    h : float
        The value of the first hue.
    l : float
        The lightness value.
    s : float
        The saturation intensity.
    as_cmap : bool
        If True, return a matplotlib colormap object.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    husl_palette : Make a palette using evenly spaced hues in the HUSL system.

    Examples
    --------
    .. include:: ../docstrings/hls_palette.rst

       r   r   Nc                    s   g | ]}t | qS rN   )colorsys
hls_to_rgbrQ   h_ilrj   rN   rT   rd   1  rV   zhls_palette.<locals>.<listcomp>r   )r   r}   intastyper`   ra   ListedColormaprW   )r   hr   rj   r   huesr   rN   r   rT   r     s    )r   ?c                    s   |rd} t ddt| d dd }||7 }|d; }|d9 }d9  d9   fdd	|D }|rttj|d
S t|S dS )a  
    Return hues with constant lightness and saturation in the HUSL system.

    The hues are evenly sampled along a circular path. The resulting palette will be
    appropriate for categorical or cyclical data.

    The `h`, `l`, and `s` values should be between 0 and 1.

    This function is similar to :func:`hls_palette`, but it uses a nonlinear color
    space that is more perceptually uniform.

    Parameters
    ----------
    n_colors : int
        Number of colors in the palette.
    h : float
        The value of the first hue.
    l : float
        The lightness value.
    s : float
        The saturation intensity.
    as_cmap : bool
        If True, return a matplotlib colormap object.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    hls_palette : Make a palette using evenly spaced hues in the HSL system.

    Examples
    --------
    .. include:: ../docstrings/husl_palette.rst

    r   r   r   Nr   ig  c   c                    s   g | ]}t | fd dqS )r   input_color_to_rgbr   r   rN   rT   rd   g  rV   z husl_palette.<locals>.<listcomp>Zhsl)r   r}   r   r`   ra   r   rW   )r   r   rj   r   r   r   r   rN   r   rT   r   8  s    'r   c           	      C   s   |  drh| dd }| dr2d}|dd }nd}t|ddg }|rX|ddd	 }t||dd
}nt| }| tv rtddt|  d| }ntddt|d dd	 }tt	t
||ddddf }|r|S t|S dS )a2  
    Return a palette or colormap from the matplotlib registry.

    For continuous palettes, evenly-spaced discrete samples are chosen while
    excluding the minimum and maximum value in the colormap to provide better
    contrast at the extremes.

    For qualitative palettes (e.g. those from colorbrewer), exact values are
    indexed (rather than interpolated), but fewer than `n_colors` can be returned
    if the palette does not define that many.

    Parameters
    ----------
    name : string
        Name of the palette. This should be a named matplotlib colormap.
    n_colors : int
        Number of discrete colors in the palette.

    Returns
    -------
    list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    Examples
    --------
    .. include: ../docstrings/mpl_palette.rst

    _dNr   r   TF   z#333333r   r   r   r      )r   r
   r   r	   MPL_QUAL_PALSr   r}   r   listr   tuplerW   )	r   r   r   sub_namer   palcmapbinsr   rN   rN   rT   r   n  s$    

"r   c                 C   sV   |dkrt j|  } n6|dkr:tj|  } tt| dd} n|dkrJt|  } tj	
| S )z+Add some more flexibility to color choices.r   r   r   r   xkcd)r   r   r   Zhusl_to_rgbr   r   clipr   r`   ra   r   )r   r   rN   rN   rT   r     s    
r   rc   c                 C   sZ   t | |}tj| \}}}d| d }	}
t ||	|
fdd}|rF||gn||g}t|||S )a  Make a sequential palette that blends from dark to ``color``.

    This kind of palette is good for data that range between relatively
    uninteresting low values and interesting high values.

    The ``color`` parameter can be specified in a number of ways, including
    all options for defining a color in matplotlib and several additional
    color spaces that are handled by seaborn. You can also use the database
    of named colors from the XKCD color survey.

    If you are using the IPython notebook, you can also choose this palette
    interactively with the :func:`choose_dark_palette` function.

    Parameters
    ----------
    color : base color for high values
        hex, rgb-tuple, or html color name
    n_colors : int, optional
        number of colors in the palette
    reverse : bool, optional
        if True, reverse the direction of the blend
    as_cmap : bool, optional
        If True, return a :class:`matplotlib.colors.ListedColormap`.
    input : {'rgb', 'hls', 'husl', xkcd'}
        Color space to interpret the input color. The first three options
        apply to tuple inputs and the latter applies to string inputs.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    light_palette : Create a sequential palette with bright low values.
    diverging_palette : Create a diverging palette with two colors.

    Examples
    --------
    .. include:: ../docstrings/dark_palette.rst

    333333?   r   r   r   r   Zrgb_to_huslr   r   r   r   r   r   rc   r   rj   r   Zgray_sZgray_lgrayra   rN   rN   rT   r     s    +
r   c                 C   sZ   t | |}tj| \}}}d| d }	}
t ||	|
fdd}|rF||gn||g}t|||S )ax  Make a sequential palette that blends from light to ``color``.

    The ``color`` parameter can be specified in a number of ways, including
    all options for defining a color in matplotlib and several additional
    color spaces that are handled by seaborn. You can also use the database
    of named colors from the XKCD color survey.

    If you are using a Jupyter notebook, you can also choose this palette
    interactively with the :func:`choose_light_palette` function.

    Parameters
    ----------
    color : base color for high values
        hex code, html color name, or tuple in `input` space.
    n_colors : int, optional
        number of colors in the palette
    reverse : bool, optional
        if True, reverse the direction of the blend
    as_cmap : bool, optional
        If True, return a :class:`matplotlib.colors.ListedColormap`.
    input : {'rgb', 'hls', 'husl', xkcd'}
        Color space to interpret the input color. The first three options
        apply to tuple inputs and the latter applies to string inputs.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    dark_palette : Create a sequential palette with dark low values.
    diverging_palette : Create a diverging palette with two colors.

    Examples
    --------
    .. include:: ../docstrings/light_palette.rst

    r   _   r   r   r   r   rN   rN   rT   r     s    (
r   K   ru   lightc                 C   s   t ttd| }td|d  }	|| ||f|	ddd}
||||f|	dd}t dgd	gd
| }|| }tt|
||g||d}|S )a  Make a diverging palette between two HUSL colors.

    If you are using the IPython notebook, you can also choose this palette
    interactively with the :func:`choose_diverging_palette` function.

    Parameters
    ----------
    h_neg, h_pos : float in [0, 359]
        Anchor hues for negative and positive extents of the map.
    s : float in [0, 100], optional
        Anchor saturation for both extents of the map.
    l : float in [0, 100], optional
        Anchor lightness for both extents of the map.
    sep : int, optional
        Size of the intermediate region.
    n : int, optional
        Number of colors in the palette (if not returning a cmap)
    center : {"light", "dark"}, optional
        Whether the center of the palette is light or dark
    as_cmap : bool, optional
        If True, return a :class:`matplotlib.colors.ListedColormap`.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    dark_palette : Create a sequential palette with dark values.
    light_palette : Create a sequential palette with light values.

    Examples
    --------
    .. include: ../docstrings/diverging_palette.rst

    )r<   r      r   Tr   )r   r   r   )ffffff?r   r   )/$?r   r   )r   r<   r   )dictr   r   r   r   r   concatenate)Zh_negZh_posrj   r   seprk   centerr   ZpalfuncZn_halfnegposmidpointmidr   rN   rN   rT   r     s    'r   c                    sb    fdd| D } d}t jj|| }|s^|tddt|ddddf }ttt	|}|S )aA  Make a palette that blends between a list of colors.

    Parameters
    ----------
    colors : sequence of colors in various formats interpreted by `input`
        hex code, html color name, or tuple in `input` space.
    n_colors : int, optional
        Number of colors in the palette.
    as_cmap : bool, optional
        If True, return a :class:`matplotlib.colors.ListedColormap`.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    Examples
    --------
    .. include: ../docstrings/blend_palette.rst

    c                    s   g | ]}t | qS rN   r   )rQ   r   r   rN   rT   rd   [  rV   z!blend_palette.<locals>.<listcomp>blendr   r   Nr   )
r`   ra   LinearSegmentedColormap	from_listr   r}   r   rW   r   r   )ra   r   r   r   r   r   Z	rgb_arrayrN   r   rT   r   E  s    &r   c                 C   s   dd | D }t |t|S )a  Make a palette with color names from the xkcd color survey.

    See xkcd for the full list of colors: https://xkcd.com/color/rgb/

    This is just a simple wrapper around the `seaborn.xkcd_rgb` dictionary.

    Parameters
    ----------
    colors : list of strings
        List of keys in the `seaborn.xkcd_rgb` dictionary.

    Returns
    -------
    palette
        A list of colors as RGB tuples.

    See Also
    --------
    crayon_palette : Make a palette with Crayola crayon colors.

    c                 S   s   g | ]}t | qS rN   )r   rQ   r   rN   rN   rT   rd   z  rV   z xkcd_palette.<locals>.<listcomp>r
   rO   ra   r   rN   rN   rT   r   d  s    r   c                 C   s   dd | D }t |t|S )a  Make a palette with color names from Crayola crayons.

    Colors are taken from here:
    https://en.wikipedia.org/wiki/List_of_Crayola_crayon_colors

    This is just a simple wrapper around the `seaborn.crayons` dictionary.

    Parameters
    ----------
    colors : list of strings
        List of keys in the `seaborn.crayons` dictionary.

    Returns
    -------
    palette
        A list of colors as RGB tuples.

    See Also
    --------
    xkcd_palette : Make a palette with named colors from the XKCD color survey.

    c                 S   s   g | ]}t | qS rN   )r   r   rN   rN   rT   rd     rV   z"crayon_palette.<locals>.<listcomp>r   r   rN   rN   rT   r   ~  s    r   皙?      ?皙?333333?r   c	                    s    fdd}	|	dd|	dd|	ddd	}
t jd
|
}t||t| }||ddddf  }|r~|ddd }|rt||d}|r|ddd }||}t j|d}|S t|S dS )aQ  Make a sequential palette from the cubehelix system.

    This produces a colormap with linearly-decreasing (or increasing)
    brightness. That means that information will be preserved if printed to
    black and white or viewed by someone who is colorblind.  "cubehelix" is
    also available as a matplotlib-based palette, but this function gives the
    user more control over the look of the palette and has a different set of
    defaults.

    In addition to using this function, it is also possible to generate a
    cubehelix palette generally in seaborn using a string starting with
    `ch:` and containing other parameters (e.g. `"ch:s=.25,r=-.5"`).

    Parameters
    ----------
    n_colors : int
        Number of colors in the palette.
    start : float, 0 <= start <= 3
        The hue value at the start of the helix.
    rot : float
        Rotations around the hue wheel over the range of the palette.
    gamma : float 0 <= gamma
        Nonlinearity to emphasize dark (gamma < 1) or light (gamma > 1) colors.
    hue : float, 0 <= hue <= 1
        Saturation of the colors.
    dark : float 0 <= dark <= 1
        Intensity of the darkest color in the palette.
    light : float 0 <= light <= 1
        Intensity of the lightest color in the palette.
    reverse : bool
        If True, the palette will go from dark to light.
    as_cmap : bool
        If True, return a :class:`matplotlib.colors.ListedColormap`.

    Returns
    -------
    palette
        list of RGB tuples or :class:`matplotlib.colors.ListedColormap`

    See Also
    --------
    choose_cubehelix_palette : Launch an interactive widget to select cubehelix
                               palette parameters.
    dark_palette : Create a sequential palette with dark low values.
    light_palette : Create a sequential palette with bright low values.

    References
    ----------
    Green, D. A. (2011). "A colour scheme for the display of astronomical
    intensity images". Bulletin of the Astromical Society of India, Vol. 39,
    p. 289-295.

    Examples
    --------
    .. include:: ../docstrings/cubehelix_palette.rst

    c                    s    fdd}|S )Nc                    sZ   |   }| d|  d }dt j d |    }||t | t |    S )Nr   r   r   )r   picossin)xxgaphi)gammahuep0p1rotstartrN   rT   r     s    z<cubehelix_palette.<locals>.get_color_function.<locals>.colorrN   )r   r   r   r   r   r   r   )r   r   rT   get_color_function  s    z-cubehelix_palette.<locals>.get_color_functiongKÿg9?gۅ:ҿgRQg)?        )redgreenblue	cubehelixNr   r   r   Zseaborn_cubehelix)	r`   ra   r   r   r}   r   tolistr   rW   )r   r   r   r   r   r   r<   r   r   r   cdictr   r   r   Zx_256Zpal_256rN   r   rT   r     s$    ;r   c                    s   |  dr| dd } | dr2d}| dd } nd}| sFg d|ifS | d	}d
d |D }dd |D }dd |D }tddddddd  fdd| D }|rd|d< ||fS )z3Turn stringified cubehelix params into args/kwargs.r   r   Nr   Tr   Fr   r   c                 S   s"   g | ]}d |vrt |dqS )= )floatstriprQ   r   rN   rN   rT   rd     rV   z)_parse_cubehelix_args.<locals>.<listcomp>c                 S   s   g | ]}d |v r| d qS )r  )r   r  rN   rN   rT   rd     rV   c                 S   s&   i | ]\}}| d t| d qS )r	  )r  r
  rP   rN   rN   rT   rU     rV   z)_parse_cubehelix_args.<locals>.<dictcomp>r   r   r   r   r   r<   )rj   rgr   r   dc                    s   i | ]\}}  |||qS rN   )r   rP   Z	kwarg_maprN   rT   rU     rV   )r   r   r   r   items)argstrr   all_argsr^   r   rN   r  rT   r     s(    


r   r:   c                 C   s   | dkrg d}nVt | ts*d}t|n>| tv rT| dsD| d } t|  dg }nd|  d}t|td|D ]2\}}tjj	
|}|tjj	j|< |tjj	j|< qrd	S )
a@  Change how matplotlib color shorthands are interpreted.

    Calling this will change how shorthand codes like "b" or "g"
    are interpreted by matplotlib in subsequent plots.

    Parameters
    ----------
    palette : {deep, muted, pastel, dark, bright, colorblind}
        Named seaborn palette to use as the source of colors.

    See Also
    --------
    set : Color codes can be set through the high-level seaborn style
          manager.
    set_palette : Color codes can also be set through the function that
                  sets the matplotlib color cycle.

    reset))r  r  r   )r  g      ?r  )r   r  r  )      ?r  r  )r  r  r  )r  r  r  )r  r  r  z0set_color_codes requires a named seaborn palette6)皙?r  r  z Cannot set colors with palette ''ZbgrmyckN)r   r   	TypeErrorr   r   r   zipr`   ra   r   r   cache)r   ra   errcoder   rc   rN   rN   rT   r     s    
	


r   )NNNF)r   r   r   r   F)r   r   r   r   F)r   F)r   FFrc   )r   FFrc   )r   ru   r   r   r   F)r   Frc   )	r   r   r   r   r   r   r   FF)r:   ),r   	itertoolsr   r{   r   
matplotlibr`   externalr   utilsr   r   ra   r   r   _compatr	   __all__r   r   r   copyr   updater  r   keysZQUAL_PALETTESrW   r   r
   r   r   r   r   r   r   r   r   r   r   r   r   r   rN   rN   rN   rT   <module>   sf   !
 	
6
6
6
3
0  
1
  
c#