首页
/ EGADS 项目使用教程

EGADS 项目使用教程

2024-10-09 14:49:37作者:霍妲思

1. 项目的目录结构及介绍

EGADS(Extensible Generic Anomaly Detection System)是一个用于自动检测大规模时间序列数据中异常的开源Java包。以下是EGADS项目的目录结构及其介绍:

egads/
├── doc/
│   └── 项目文档和说明文件
├── lib/
│   └── Synthetic_Anomalies/
│       └── 合成异常数据相关文件
├── src/
│   └── 项目源代码
├── .gitignore
├── travis.yml
├── LICENSE
├── README.md
├── pom.xml
└── screwdriver.yaml

目录结构说明:

  • doc/:包含项目的文档和说明文件。
  • lib/Synthetic_Anomalies/:包含合成异常数据的相关文件。
  • src/:项目的源代码目录。
  • .gitignore:Git忽略文件配置。
  • travis.yml:Travis CI配置文件。
  • LICENSE:项目许可证文件。
  • README.md:项目介绍和使用说明。
  • pom.xml:Maven项目配置文件。
  • screwdriver.yaml:Screwdriver CI配置文件。

2. 项目的启动文件介绍

EGADS项目的启动文件主要是通过Java命令行来运行。以下是启动EGADS的示例命令:

java -Dlog4j.configurationFile=src/test/resources/log4j2.xml -cp target/egads-*-jar-with-dependencies.jar com.yahoo.egads.Egads src/test/resources/sample_config.ini src/test/resources/sample_input.csv

启动文件说明:

  • log4j.configurationFile:指定Log4j2的配置文件路径。
  • cp:指定包含所有依赖的JAR文件路径。
  • com.yahoo.egads.Egads:EGADS的主类。
  • sample_config.ini:配置文件路径。
  • sample_input.csv:输入数据文件路径。

3. 项目的配置文件介绍

EGADS的配置文件通常是一个INI格式的文件,用于指定各种参数和模型配置。以下是一个示例配置文件的内容及其说明:

# 只显示不早于这个时间的异常
# 如果设置为0,则只输出最后一个时间戳的异常
MAX_ANOMALY_TIME_AGO = 999999999

# 表示时间序列应按多少进行聚合
# 如果设置为1或更小,则忽略此设置
AGGREGATION = 1

# OP_TYPE指定操作类型
# 选项:DETECT_ANOMALY, UPDATE_MODEL, TRANSFORM_INPUT
OP_TYPE = DETECT_ANOMALY

# TS_MODEL指定时间序列模型类型
# 选项:AutoForecastModel, DoubleExponentialSmoothingModel, MovingAverageModel, MultipleLinearRegressionModel, NaiveForecastingModel, OlympicModel, PolynomialRegressionModel, RegressionModel, SimpleExponentialSmoothingModel, TripleExponentialSmoothingModel, WeightedMovingAverageModel, SpectralSmoother, NullModel
TS_MODEL = OlympicModel

# AD_MODEL指定异常检测模型类型
# 选项:ExtremeLowDensityModel, AdaptiveKernelDensityChangePointDetector, KSigmaModel, NaiveModel, DBScanModel, SimpleThresholdModel
AD_MODEL = ExtremeLowDensityModel

配置文件说明:

  • MAX_ANOMALY_TIME_AGO:指定只显示不早于某个时间的异常。
  • AGGREGATION:指定时间序列的聚合方式。
  • OP_TYPE:指定操作类型,如检测异常、更新模型等。
  • TS_MODEL:指定时间序列模型类型。
  • AD_MODEL:指定异常检测模型类型。

通过以上配置文件,可以灵活地调整EGADS的行为,以适应不同的使用场景。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
270
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
909
541
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
341
1.21 K
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
142
188
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
377
387
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
63
58
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.1 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
87
4