stats

stats

功能全面的 Go 统计库

Stats 是一个无依赖的 Go 统计库,提供中位数、标准差、相关性分析等统计函数。经过全面测试,支持多种数据类型,并有详细 API 文档。适用于数据分析、机器学习等需要统计计算的 Go 项目,助力开发者高效实现各类统计功能。

Golang统计库数据分析开源项目数学计算Github

Stats - Go语言统计包

一个经过充分测试的、全面的Go语言统计库/包/模块,无任何依赖。

如果您有任何建议、问题或错误报告,请创建一个issue,我会尽最大努力满足您的需求。此外,简单地为该仓库加星表示您对项目的支持,这将不胜感激!

安装

go get github.com/montanaflynn/stats

使用示例

所有函数可以在examples/main.go中查看,但这里给出一个简单的示例:

// 首先准备一些源数据 data := []float64{1.0, 2.1, 3.2, 4.823, 4.1, 5.8} // 你也可以使用不同的类型,比如: // data := stats.LoadRawData([]int{1, 2, 3, 4, 5}) // data := stats.LoadRawData([]interface{}{1.1, "2", 3}) // 等等... median, _ := stats.Median(data) fmt.Println(median) // 3.65 roundedMedian, _ := stats.Round(median, 0) fmt.Println(roundedMedian) // 4

文档

完整的API文档可在GoDoc.orgpkg.go.dev上查看。

你也可以使用以下命令离线查看文档:

# 命令行
godoc .              # 显示所有导出的API
godoc . Median       # 显示单个函数
godoc -ex . Round    # 显示带示例的函数
godoc . Float64Data  # 显示类型和方法

# 本地网站
godoc -http=:4444    # 在4444端口启动godoc服务器
open http://localhost:4444/pkg/github.com/montanaflynn/stats/

导出的API如下:

var ( ErrEmptyInput = statsError{"输入不能为空。"} ErrNaN = statsError{"不是一个数字。"} ErrNegative = statsError{"不能包含负值。"} ErrZero = statsError{"不能包含零值。"} ErrBounds = statsError{"输入超出范围。"} ErrSize = statsError{"长度必须相同。"} ErrInfValue = statsError{"值是无穷大。"} ErrYCoord = statsError{"Y值必须大于零。"} ) func Round(input float64, places int) (rounded float64, err error) {} type Float64Data []float64 func LoadRawData(raw interface{}) (f Float64Data) {} func 自相关(数据 Float64Data, 滞后数 int) (float64, error) {} func 切比雪夫距离(数据点X, 数据点Y Float64Data) (距离 float64, 错误 error) {} func 相关性(数据1, 数据2 Float64Data) (float64, error) {} func 协方差(数据1, 数据2 Float64Data) (float64, error) {} func 总体协方差(数据1, 数据2 Float64Data) (float64, error) {} func 累积和(输入 Float64Data) ([]float64, error) {} func 描述统计(输入 Float64Data, 允许NaN bool, 百分位数 *[]float64) (*描述, error) {} func 自定义百分位函数描述统计(输入 Float64Data, 允许NaN bool, 百分位数 *[]float64, 百分位函数 func(Float64Data, float64) (float64, error)) (*描述, error) {} func(输入 Float64Data) (float64, error) {} func 欧几里得距离(数据点X, 数据点Y Float64Data) (距离 float64, 错误 error) {} func 几何平均数(输入 Float64Data) (float64, error) {} func 调和平均数(输入 Float64Data) (float64, error) {} func 四分位距(输入 Float64Data) (float64, error) {} func 曼哈顿距离(数据点X, 数据点Y Float64Data) (距离 float64, 错误 error) {} func 最大值(输入 Float64Data) (最大值 float64, 错误 error) {} func 平均值(输入 Float64Data) (float64, error) {} func 中位数(输入 Float64Data) (中位数 float64, 错误 error) {} func 中位数绝对偏差(输入 Float64Data) (中位数绝对偏差 float64, 错误 error) {} func 总体中位数绝对偏差(输入 Float64Data) (中位数绝对偏差 float64, 错误 error) {} func 中铰(输入 Float64Data) (float64, error) {} func 最小值(输入 Float64Data) (最小值 float64, 错误 error) {} func 闵可夫斯基距离(数据点X, 数据点Y Float64Data, lambda float64) (距离 float64, 错误 error) {} func 众数(输入 Float64Data) (众数 []float64, 错误 error) {} func 正态分布Box_Muller随机变量(位置 float64, 尺度 float64, 大小 int) []float64 {} func 正态分布累积分布函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布熵(位置 float64, 尺度 float64) float64 {} func 正态分布拟合(数据 []float64) [2]float64{} func 正态分布置信区间(alpha float64, 位置 float64, 尺度 float64) [2]float64 {} func 正态分布逆生存函数(p float64, 位置 float64, 尺度 float64) (x float64) {} func 正态分布对数累积分布函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布对数概率密度函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布对数生存函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布均值(位置 float64, 尺度 float64) float64 {} func 正态分布中位数(位置 float64, 尺度 float64) float64 {} func 正态分布矩(n int, 位置 float64, 尺度 float64) float64 {} func 正态分布概率密度函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布百分点函数(p float64, 位置 float64, 尺度 float64) (x float64) {} func 正态分布百分点函数随机变量(位置 float64, 尺度 float64, 大小 int) []float64 {} func 正态分布生存函数(x float64, 位置 float64, 尺度 float64) float64 {} func 正态分布统计量(位置 float64, 尺度 float64,string) []float64 {} func 正态分布标准差(位置 float64, 尺度 float64) float64 {} func 正态分布方差(位置 float64, 尺度 float64) float64 {} func 皮尔逊相关系数(数据1, 数据2 Float64Data) (float64, error) {} func 百分位数(输入 Float64Data, 百分比 float64) (百分位数 float64, 错误 error) {} func 最近秩百分位数(输入 Float64Data, 百分比 float64) (百分位数 float64, 错误 error) {} func 总体方差(输入 Float64Data) (总体方差 float64, 错误 error) {} func 采样(输入 Float64Data, 取样数 int, 替换 bool) ([]float64, error) {} func 样本方差(输入 Float64Data) (样本方差 float64, 错误 error) {} func S形函数(输入 Float64Data) ([]float64, error) {} func 软最大值(输入 Float64Data) ([]float64, error) {} func 稳定采样(输入 Float64Data, 取样数 int) ([]float64, error) {} func StandardDeviation(输入 Float64Data) (标准差 float64, 错误 error) {} func StandardDeviationPopulation(输入 Float64Data) (总体标准差 float64, 错误 error) {} func StandardDeviationSample(输入 Float64Data) (样本标准差 float64, 错误 error) {} func StdDevP(输入 Float64Data) (总体标准差 float64, 错误 error) {} func StdDevS(输入 Float64Data) (样本标准差 float64, 错误 error) {} func Sum(输入 Float64Data) (float64, 错误 error) {} func Trimean(输入 Float64Data) (float64, error) {} func VarP(输入 Float64Data) (总体方差 float64, 错误 error) {} func VarS(输入 Float64Data) (样本方差 float64, 错误 error) {} func Variance(输入 Float64Data) (方差 float64, 错误 error) {} func ProbGeom(a int, b int, p float64) (几何概率 float64, 错误 error) {} func ExpGeom(p float64) (几何期望 float64, 错误 error) {} func VarGeom(p float64) (几何方差 float64, 错误 error) {} type Coordinate struct { X, Y float64 } type Series []Coordinate func ExponentialRegression(s Series) (regressions Series, err error) {} func LinearRegression(s Series) (regressions Series, err error) {} func LogarithmicRegression(s Series) (regressions Series, err error) {} type Outliers struct { Mild Float64Data Extreme Float64Data } type Quartiles struct { Q1 float64 Q2 float64 Q3 float64 } func Quartile(input Float64Data) (Quartiles, error) {} func QuartileOutliers(input Float64Data) (Outliers, error) {}

贡献

无论大小,我们都欢迎提交拉取请求。我在 Makefile 中包含了许多辅助目标,用于常见操作如代码检查、测试、代码覆盖率报告等。

  1. 复刻仓库并克隆你的复刻版本
  2. 创建新分支(git checkout -b some-thing
  3. 进行所需更改
  4. 确保测试通过(go test -covermake test
  5. 运行代码检查并修复问题(go vet .make lint
  6. 提交更改(git commit -am '做了某事'
  7. 推送分支(git push origin some-thing
  8. 提交拉取请求

为使过程尽可能顺畅,请也考虑以下步骤:

  • examples/main.go 中添加新功能的简单示例
  • README.md 文档部分更新任何新导出的 API
  • 保持 100% 代码覆盖率(可以用 make coverage 检查)
  • 使用 git rebase -i new-feature 将提交压缩成单个工作单元

发布

这不是贡献者必需的,主要是作为我这个仓库维护者的提醒。发布新版本时,我们应该更新 CHANGELOG.mdDOCUMENTATION.md

首先安装用于生成 Markdown 文件和发布的工具:

go install github.com/davecheney/godoc2md@latest
go install github.com/golangci/golangci-lint/cmd/golangci-lint@latest
brew tap git-chglog/git-chglog
brew install gnu-sed hub git-chglog

然后你可以运行这些 make 指令:

# 生成 DOCUMENTATION.md
make docs

然后我们可以创建 CHANGELOG.md、新的 git 标签和 GitHub 发布:

make release TAG=v0.x.x

为了在发布时验证 hub,你需要创建一个个人访问令牌,并在要求输入密码时使用它。

MIT 许可证

版权所有 (c) 2014-2023 Montana Flynn (https://montanaflynn.com)

特此免费授予任何获得本软件副本和相关文档文件("软件")的人不受限制地处理本软件的权利,包括但不限于使用、复制、修改、合并、发布、分发、再许可和/或销售软件副本的权利,并允许向其提供本软件的人这样做,但须符合以下条件:

上述版权声明和本许可声明应包含在本软件的所有副本或实质性部分中。

本软件按"原样"提供,不提供任何明示或暗示的担保,包括但不限于适销性、特定用途适用性和非侵权性的担保。在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是在合同诉讼、侵权行为还是其他方面,由软件或软件的使用或其他交易引起的、由软件引起的或与之相关的索赔、损害或其他责任。

编辑推荐精选

博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

热门AI工具AI办公办公工具智能排版AI生成PPT博思AIPPT海量精品模板AI创作
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

AI助手热门AI工具AI创作AI辅助写作讯飞绘文内容运营个性化文章多平台分发
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

热门AI工具生产力协作转型TraeAI IDE
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多