一个经过充分测试的、全面的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.org或pkg.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 中包含了许多辅助目标,用于常见操作如代码检查、测试、代码覆盖率报告等。
git checkout -b some-thing)go test -cover 或 make test)go vet . 或 make lint)git commit -am '做了某事')git push origin some-thing)为使过程尽可能顺畅,请也考虑以下步骤:
examples/main.go 中添加新功能的简单示例README.md 文档部分更新任何新导出的 APImake coverage 检查)git rebase -i new-feature 将提交压缩成单个工作单元这不是贡献者必需的,主要是作为我这个仓库维护者的提醒。发布新版本时,我们应该更新 CHANGELOG.md 和 DOCUMENTATION.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,你需要创建一个个人访问令牌,并在要求输入密码时使用它。
版权所有 (c) 2014-2023 Montana Flynn (https://montanaflynn.com)
特此免费授予任何获得本软件副本和相关文档文件("软件")的人不受限制地处理本软件的权利,包括但不限于使用、复制、修改、合并、发布、分发、再许可和/或销售软件副本的权利,并允许向其提供本软件的人这样做,但须符合以下条件:
上述版权声明和本许可声明应包含在本软件的所有副本或实质性部分中。
本软件按"原样"提供,不提供任何明示或暗示的担保,包括但不限于适销性、特定用途适用性和非侵权性的担保。在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是在合同诉讼、侵权行为还是其他方面,由软件或软件的使用或其他交易引起的、由软件引起的或与之相关的索赔、损害或其他责任。


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


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


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


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


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


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


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