o 6��fŨ � @ s� d Z g d�ZddlZddlZddlZddlmZ ddlmZ ddl m Z mZ ddlm Z mZ ddlmZmZmZmZmZmZmZmZ dd lmZ dd lmZmZ G dd� de�Zd d� Zdd� Zdd� Z dd� Z!dd� Z"dd� Z#dd� Z$dOdd�Z%dd� Z&d d!� Z'd"d#� Z(dPd$d%�Z)d&d'� Z*d(d)� Z+d*d+� Z,dQd-d.�Z-d/d0� Z.d1d2� Z/d3d4d5�d6d7�Z0dPd8d9�Z1dPd:d;�Z2dPd<d=�Z3dPd>d?�Z4dPd@dA�Z5dBdC� Z6dDdE� Z7edFdG�Z8dHdI� Z9dJdK� Z:zddLl;m:Z: W n e<y� Y nw G dMdN� dN�Z=dS )Ra� Basic statistics module. This module provides functions for calculating statistics of data, including averages, variance, and standard deviation. Calculating averages -------------------- ================== ================================================== Function Description ================== ================================================== mean Arithmetic mean (average) of data. fmean Fast, floating point arithmetic mean. geometric_mean Geometric mean of data. harmonic_mean Harmonic mean of data. median Median (middle value) of data. median_low Low median of data. median_high High median of data. median_grouped Median, or 50th percentile, of grouped data. mode Mode (most common value) of data. multimode List of modes (most common values of data). quantiles Divide data into intervals with equal probability. ================== ================================================== Calculate the arithmetic mean ("the average") of data: >>> mean([-1.0, 2.5, 3.25, 5.75]) 2.625 Calculate the standard median of discrete data: >>> median([2, 3, 4, 5]) 3.5 Calculate the median, or 50th percentile, of data grouped into class intervals centred on the data values provided. E.g. if your data points are rounded to the nearest whole number: >>> median_grouped([2, 2, 3, 3, 3, 4]) #doctest: +ELLIPSIS 2.8333333333... This should be interpreted in this way: you have two data points in the class interval 1.5-2.5, three data points in the class interval 2.5-3.5, and one in the class interval 3.5-4.5. The median of these data points is 2.8333... Calculating variability or spread --------------------------------- ================== ============================================= Function Description ================== ============================================= pvariance Population variance of data. variance Sample variance of data. pstdev Population standard deviation of data. stdev Sample standard deviation of data. ================== ============================================= Calculate the standard deviation of sample data: >>> stdev([2.5, 3.25, 5.5, 11.25, 11.75]) #doctest: +ELLIPSIS 4.38961843444... If you have previously calculated the mean, you can pass it as the optional second argument to the four "spread" functions to avoid recalculating it: >>> data = [1, 2, 2, 4, 4, 4, 5, 6] >>> mu = mean(data) >>> pvariance(data, mu) 2.5 Statistics for relations between two inputs ------------------------------------------- ================== ==================================================== Function Description ================== ==================================================== covariance Sample covariance for two variables. correlation Pearson's correlation coefficient for two variables. linear_regression Intercept and slope for simple linear regression. ================== ==================================================== Calculate covariance, Pearson's correlation, and simple linear regression for two inputs: >>> x = [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> y = [1, 2, 3, 1, 2, 3, 1, 2, 3] >>> covariance(x, y) 0.75 >>> correlation(x, y) #doctest: +ELLIPSIS 0.31622776601... >>> linear_regression(x, y) #doctest: LinearRegression(slope=0.1, intercept=1.5) Exceptions ---------- A single exception is defined: StatisticsError is a subclass of ValueError. )� NormalDist�StatisticsError�correlation� covariance�fmean�geometric_mean� harmonic_mean�linear_regression�mean�median�median_grouped�median_high� median_low�mode� multimode�pstdev� pvariance� quantiles�stdev�variance� N��Fraction)�Decimal)�groupby�repeat)�bisect_left�bisect_right)�hypot�sqrt�fabs�exp�erf�tau�log�fsum)� itemgetter)�Counter� namedtuplec @ s e Zd ZdS )r N)�__name__� __module__�__qualname__� r+ r+ �1/opt/alt/python310/lib64/python3.10/statistics.pyr � s r c C s� d}i }|j }t}t| t�D ] \}}t||�}tt|�D ]\}}|d7 }||d�| ||<