请求prometheus数据然后使用tensorflow计算正则模型

使用tensorflow 计算正则模型, 数据来源为Prometheus的数据近7天的数据, 然后计算了90%区间的上下限和当前值的概率密度

python 复制代码
import requests
import pandas as pd
import tensorflow as tf
from datetime import datetime, timedelta

# 定义 Prometheus 查询的参数
url = "http://{your_path}/api/v1/query_range"
## 查询的QL
query = 'sum(alter_count{group="namespace"})'
start_time = int((datetime.now() - timedelta(days=7)).timestamp())
end_time = int(datetime.now().timestamp())

# 构建查询参数
params = {
    "query": query,
    "start": start_time,
    "end": end_time,
    "step": "1h"
}

# 发起 GET 请求
response = requests.get(url, params=params)

# 解析响应数据
data = response.json()['data']['result']

# 处理数据
results = []
for item in data:
    for value in item['values']:
        results.append({
            'timestamp': pd.to_datetime(value[0], unit='s'),
            'value': float(value[1])
        })
# 将数据转化为 DataFrame
df = pd.DataFrame(results)
df.set_index('timestamp', inplace=True)

# 构建 TensorFlow 模型
mean_value = tf.cast(df['value'].mean(), tf.float32)
std_dev = tf.cast(df['value'].std(), tf.float32)

# 取最后值, 也就是当前值
input_data = df.iloc[-1]['value']
input_data = tf.cast(input_data, tf.float32)  # 将输入数据转换为 float32 类型
result = tf.exp(-tf.square(input_data - mean_value) / (2 * tf.square(std_dev))) / (std_dev * tf.sqrt(2 * 3.14159))
print("当前数据 {} 的正态分布概率密度值为: {}".format(input_data.numpy(), result.numpy()))
# 计算命中 80% 区间的上下界
lower_bound = mean_value + tf.math.erfinv(-0.45) * std_dev
upper_bound = mean_value + tf.math.erfinv(0.45) * std_dev

print("命中 90% 区间的上界为: {}".format(upper_bound.numpy()))
print("命中 90% 区间的下界为: {}".format(lower_bound.numpy()))
相关推荐
CryptoPP11 分钟前
对接BSE交易所获取数据。
python·金融·数据挖掘·数据分析·区块链
老歌老听老掉牙18 分钟前
PyQt5中RadioButton互斥选择的实现方法
开发语言·python·qt
Pyeako20 分钟前
Opencv计算机视觉
人工智能·python·深度学习·opencv·计算机视觉
还不秃顶的计科生26 分钟前
LeetCode 热题 100第一题:两数之和python版本
python·算法·leetcode
2401_8414956433 分钟前
【Python高级编程】2026 丙午马年元旦祝福程序
python·动画·tkinter·程序·pyinstaller·元旦·turtle
该醒醒了~34 分钟前
使用auto-py-to-exe打包python程序exe并添加图标和ico文件
python
idealzouhu36 分钟前
【Android】深入浅出 JNI
android·开发语言·python·jni
兜兜转转了多少年1 小时前
《Python 应用机器学习:代码实战指南》笔记2 从0理解机器学习 —— 核心概念全解析
笔记·python·机器学习
reasonsummer1 小时前
【教学类-70-04】20251231小2班幼儿制作折纸方镜(八卦神兽镜)
python·通义万相
IT·小灰灰1 小时前
大模型API成本优化实战指南:Token管理的艺术与科学
人工智能·python·数据分析