class plotnine.stats.stat_summary_bin(mapping=None, data=None, **kwargs)[source]

Summarise y values at x intervals


stat_summary_bin(mapping=None, data=None, geom='pointrange',
                 position='identity', na_rm=False, bins=30, random_state=None,
                 fun_ymax=None, boundary=None, fun_y=None, fun_data=None,
                 fun_args=None, fun_ymin=None, breaks=None, binwidth=None,

Only the mapping and data can be positional, the rest must be keyword arguments. **kwargs can be aesthetics (or parameters) used by the geom.

mappingaes, optional

Aesthetic mappings created with aes(). If specified and inherit.aes=True, it is combined with the default mapping for the plot. You must supply mapping if there is no plot mapping.


Default value



The bold aesthetics are required.

Options for computed aesthetics

'bin'    # bin identifier
'width'  # bin width
'ymin'   # ymin computed by the summary function
'ymax'   # ymax computed by the summary function

Calculated aesthetics are accessed using the stat function. e.g. 'stat(ymin)'.

datadataframe, optional

The data to be displayed in this layer. If None, the data from from the ggplot() call is used. If specified, it overrides the data from the ggplot() call.

geomstr or geom, optional (default: geom_pointrange)

The statistical transformation to use on the data for this layer. If it is a string, it must be the registered and known to Plotnine.

positionstr or position, optional (default: position_identity)

Position adjustment. If it is a string, it must be registered and known to Plotnine.

na_rmbool, optional (default: False)

If False, removes missing values with a warning. If True silently removes missing values.

binwidthfloat or tuple, optional (default: None)

The width of the bins. The default is to use bins bins that cover the range of the data. You should always override this value, exploring multiple widths to find the best to illustrate the stories in your data.

binsint or tuple, optional (default: 30)

Number of bins. Overridden by binwidth.

breaksarray-like(s), optional (default: None)

Bin boundaries. This supercedes the binwidth, bins and boundary arguments.

boundaryfloat or tuple, optional (default: None)

A boundary between two bins. As with center, things are shifted when boundary is outside the range of the data. For example, to center on integers, use width=1 and boundary=0.5, even if 1 is outside the range of the data. At most one of center and boundary may be specified.

fun_datastr or function, optional

One of ['mean_cl_boot', 'mean_cl_normal', 'mean_sdl', 'median_hilow'] or any function that takes a array and returns a dataframe with three rows indexed as y, ymin and ymax. Defaults to 'mean_cl_boot'.

fun_yfunction, optional (default: None)

Any function that takes a array-like and returns a value fun_ymin : function (default:None) Any function that takes an array-like and returns a value

fun_ymaxfunction, optional (default: None)

Any function that takes an array-like and returns a value

fun_argsdict, optional (default: None)

Arguments to any of the functions. Provided the names of the arguments of the different functions are in not conflict, the arguments will be assigned to the right functions. If there is a conflict, create a wrapper function that resolves the ambiguity in the argument names.

random_stateint or RandomState, optional

Seed or Random number generator to use. If None, then numpy global generator numpy.random is used.


The binwidth, bins, breaks and bounary arguments can be a tuples with two values ((xaxis-value, yaxis-value)) of the required type.