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)

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

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

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

编辑推荐精选

Trae

Trae

字节跳动发布的AI编程神器IDE

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

AI工具TraeAI IDE协作生产力转型热门
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

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

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

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

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

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

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

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

下拉加载更多