当前位置: 首页 > wzjs >正文

网站banner怎么居中app广告联盟平台

网站banner怎么居中,app广告联盟平台,做网站的人月,网站策划案模板在数据监控领域,很多情况下需要对时序数据突增情况进行检测,下面记录简单的检测方法,仅供参考 import java.util.*; import java.util.stream.Collectors;public class AdaptiveSurgeDetector {public static class SurgePoint {String star…

在数据监控领域,很多情况下需要对时序数据突增情况进行检测,下面记录简单的检测方法,仅供参考

import java.util.*;
import java.util.stream.Collectors;public class AdaptiveSurgeDetector {public static class SurgePoint {String startTime;String endTime;double startValue;double endValue;double surgeRatio;boolean isConsecutive;int consecutiveCount;int minShowCount;public SurgePoint(String startTime, String endTime,double startValue, double endValue, double surgeRatio,boolean isConsecutive, int consecutiveCount, int minShowCount) {this.startTime = startTime;this.endTime = endTime;this.startValue = startValue;this.endValue = endValue;this.surgeRatio = surgeRatio;this.isConsecutive = isConsecutive;this.consecutiveCount = consecutiveCount;this.minShowCount = minShowCount;}@Overridepublic String toString() {if (isConsecutive) {return String.format("连续突增[%s 至 %s]: 起始值=%.2f, 结束值=%.2f, 突增比例=%.2f%%, 持续=%d次",startTime, endTime, startValue, endValue, surgeRatio, consecutiveCount);} else {return String.format("单点突增[%s]: 值=%.2f, 突增比例=%.2f%%",startTime, startValue, surgeRatio);}}}/*** 检测方法** @param timeSeriesData        时间序列Map对象* @param thresholdMultiplier   阈值* @param minShowCount          最小连续检测点* @param baselineSize          基础数据计算缓存大小* @return*/public static List<SurgePoint> detectSurges(Map<String, Object> timeSeriesData,double thresholdMultiplier, Integer minShowCount, Integer baselineSize) {// 转换并排序数据List<Map.Entry<String, Double>> sortedData = timeSeriesData.entrySet().stream().map(e -> new AbstractMap.SimpleEntry<>(e.getKey(), convertToDouble(e.getValue()))).sorted(Map.Entry.comparingByKey()).collect(Collectors.toList());List<SurgePoint> results = new ArrayList<>();List<Map.Entry<String, Double>> baselineData = new ArrayList<>();List<Map.Entry<String, Double>> surgeBuffer = new ArrayList<>();for (int i = 0; i < sortedData.size(); i++) {Map.Entry<String, Double> current = sortedData.get(i);// 第一个点作为初始基准if (i == 0) {baselineData.add(current);continue;}// 计算当前基准统计量double mean = calculateMean(baselineData);double stdDev = calculateStdDev(baselineData, mean);double threshold = stdDev > 0 ? thresholdMultiplier * stdDev : thresholdMultiplier * mean;double deviation = current.getValue() - mean;// 突增检测if (deviation > threshold) {surgeBuffer.add(current);} else {// 处理缓冲区的突增点if (!surgeBuffer.isEmpty()) {processSurgeBuffer(surgeBuffer, baselineData, results, thresholdMultiplier, minShowCount);surgeBuffer.clear();}// 当前点不是突增,添加到基准数据baselineData.add(current);// 保持基准数据大小不超过必要范围if (baselineData.size() > baselineSize) {baselineData.remove(0);}}}// 处理最后可能的突增序列if (!surgeBuffer.isEmpty()) {processSurgeBuffer(surgeBuffer, baselineData, results, thresholdMultiplier, minShowCount);}return results;}private static void processSurgeBuffer(List<Map.Entry<String, Double>> surgeBuffer,List<Map.Entry<String, Double>> baselineData,List<SurgePoint> results,double thresholdMultiplier,Integer minShowCount) {if (surgeBuffer.size() == 1 && minShowCount == 1) {// 单点突增Map.Entry<String, Double> point = surgeBuffer.get(0);double mean = calculateMean(baselineData);double surgeRatio = ((point.getValue() - mean) / mean) * 100;if(surgeRatio > 30) {results.add(new SurgePoint(point.getKey(),point.getKey(),point.getValue(),point.getValue(),surgeRatio,false,1,minShowCount));}} else if(surgeBuffer.size() >= minShowCount) {// 连续突增double mean = calculateMean(baselineData);double avgSurgeRatio = surgeBuffer.stream().mapToDouble(e -> ((e.getValue() - mean) / mean) * 100).average().orElse(0);if(avgSurgeRatio > 30) {results.add(new SurgePoint(surgeBuffer.get(0).getKey(),surgeBuffer.get(surgeBuffer.size() - 1).getKey(),surgeBuffer.get(0).getValue(),surgeBuffer.get(surgeBuffer.size() - 1).getValue(),avgSurgeRatio,true,surgeBuffer.size(),minShowCount));}}// 重置基准数据baselineData.clear();}private static double convertToDouble(Object value) {if (value instanceof Number) {return ((Number) value).doubleValue();}try {return Double.parseDouble(value.toString());} catch (Exception e) {return 0.0;}}private static double calculateMean(List<Map.Entry<String, Double>> data) {return data.stream().mapToDouble(Map.Entry::getValue).average().orElse(0);}private static double calculateStdDev(List<Map.Entry<String, Double>> data, double mean) {if (data.size() <= 1) return 0;double variance = data.stream().mapToDouble(e -> Math.pow(e.getValue() - mean, 2)).average().orElse(0);return Math.sqrt(variance);}public static void main(String[] args) {// 示例时间序列数据(包含单点突增和连续突增)Map<String, Object> timeSeriesData = new LinkedHashMap<>();timeSeriesData.put("2023-01-01 10:00", 10.0);timeSeriesData.put("2023-01-01 11:00", 10.0);timeSeriesData.put("2023-01-01 12:00", 50.0);timeSeriesData.put("2023-01-01 13:00", 13.0);timeSeriesData.put("2023-01-01 14:00", 12.0);timeSeriesData.put("2023-01-01 15:00", 10.0);timeSeriesData.put("2023-01-01 16:00", 11.0);timeSeriesData.put("2023-01-01 17:00", 16.0);timeSeriesData.put("2023-01-01 18:00", 100.0);timeSeriesData.put("2023-01-01 19:00", 10.0);timeSeriesData.put("2023-01-01 20:00", 140.0);timeSeriesData.put("2023-01-01 21:00", 110.0);timeSeriesData.put("2023-01-01 22:00", 110.0);timeSeriesData.put("2023-01-01 23:00", 110.0);timeSeriesData.put("2023-01-02 00:00", 60.0);timeSeriesData.put("2023-01-02 01:00", 22.0);timeSeriesData.put("2023-01-02 02:00", 25.0);timeSeriesData.put("2023-01-02 03:00", 28.0);Double threshold = 2.0;Integer miShowCount = 1;Integer baselineSize = 5;List<SurgePoint> surges = detectSurges(timeSeriesData, threshold, miShowCount, baselineSize);// 输出结果System.out.println("时间序列数据分析结果:");if (surges.isEmpty()) {System.out.println("未检测到明显突增点");} else {surges.forEach(System.out::println);}}
}

结果:

时间序列数据分析结果:
单点突增[2023-01-01 12:00]: 值=50.00, 突增比例=400.00%
连续突增[2023-01-01 17:00 至 2023-01-01 18:00]: 起始值=16.00, 结束值=100.00, 突增比例=404.35%, 持续=2次
连续突增[2023-01-01 20:00 至 2023-01-02 00:00]: 起始值=140.00, 结束值=60.00, 突增比例=960.00%, 持续=5
http://www.dtcms.com/wzjs/520246.html

相关文章:

  • 怎么在服务器上装WordPressseo查询外链
  • 可以做哪些有趣的网站我要软文网
  • 福永网站制作淘宝关键词搜索排行榜
  • 网页布局设计方法seo必备软件
  • 唐山网站制作企业廊坊网络推广优化公司
  • 杭州酒店团购网站建设网站优化塔山双喜
  • 厦门网站怎么做山东网站seo推广优化价格
  • 网页设计中用div做网站例子登封网站建设公司
  • 用dreamweaver做网站seo顾问多少钱
  • 将网站收藏至ie收藏夹怎么做2345网址导航下载桌面
  • wikidot网站怎么做谷歌google play下载
  • 国外做的比较的ppt网站有哪些快速seo关键词优化技巧
  • 大学英语作文网站今日头条官网首页
  • 寻找哈尔滨网站建设关键词营销优化
  • 建立网站需要多少钱网上营销策略有哪些
  • 广州网站建设 seo营销策略4p
  • 说旅游网页设计作业seo81
  • 网站内链建设不可忽视的地方如何推广外贸型网站
  • 哪个网站做批发比较好软文推广模板
  • 可以做哪些网站有哪些免费发布信息的平台有哪些
  • 唐山网站设计制作门户网站怎么做
  • html 网站 模板西安seo引擎搜索优化
  • 京东网站建设百度投流
  • 渭南 网站集约化建设国内免费发布产品的平台
  • 郑州做互联网推广的白杨seo教程
  • pc 手机自适应网站用什么做长沙网络推广营销
  • 做兼职的网站有哪些工作成功的营销案例及分析
  • 晋江网站建设费用百度后台登陆入口
  • 高德地图切换国外流程优化
  • 长沙制作网页的基本步骤北京谷歌优化