news 2026/4/15 3:10:25

找出数组中驻点和拐点

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
找出数组中驻点和拐点

找出数组中驻点和拐点,即一阶导数为零点和二阶导数为零点。代码定义了两个函数:find_first_deriv_zeros和find_second_deriv_zeros,用于找到一阶和二阶导数的零点索引。主函数中有一个示例数据数组,并调用这两个函数来输出零点的索引。
注意:边界点的处理可能需要特别考虑。例如,一阶导数的左边界使用前向差分,右边界使用后向差分,而中间点使用中心差分。同样,二阶导数的计算也需要处理边界点。

// stdafx.cpp : 只包括标准包含文件的源文件 // ConsoleApplication1.pch 将作为预编译头 // stdafx.obj 将包含预编译类型信息 #include "stdafx.h" #include <stdio.h> #include <stdlib.h> #include <time.h> #include <Windows.h> #include <math.h> #define EPSILON 1e-6 // 判断导数为零的阈值 #define MAX_DATA 1000 // 最大数据长度 // 计算一阶导数并返回零点索引 void compute_derivatives(float *data, int n, float *first_deriv, float *second_deriv, int *first_zeros, int *first_count, int *second_zeros, int *second_count) { *first_count = 0; *second_count = 0; if (n < 2) return; // 处理一阶导数 for (int i = 0; i < n; i++) { if (i == 0) { // 左边界前向差分 first_deriv[i] = (data[1] - data[0]) / 1.0f; } else if (i == n-1) { // 右边界后向差分 first_deriv[i] = (data[i] - data[i-1]) / 1.0f; } else { // 中心差分 first_deriv[i] = (data[i+1] - data[i-1]) / 2.0f; } } // 改进的一阶导数零点检测:检查符号变化 for (int i = 0; i < n-1; i++) { // 检查一阶导数是否变号 if (first_deriv[i] * first_deriv[i+1] < 0) { // 一阶导数变号,说明此处有极值点 // 记录i和i+1中函数值更大的点(假设是极大值) int idx = (data[i] > data[i+1]) ? i : i+1; first_zeros[(*first_count)++] = idx; } else if (fabs(first_deriv[i]) < EPSILON) { // 一阶导数恰好为0(平坦区域),直接记录 first_zeros[(*first_count)++] = i; } } // 处理二阶导数 for (int i = 0; i < n; i++) { if (i == 0 || i == n-1) { // 边界使用前向/后向差分 second_deriv[i] = (2.0f*data[i] - 5.0f*data[i+1] + 4.0f*data[i+2] - data[i+3]) / 1.0f; } else if (i == 1) { // 近边界特殊处理 second_deriv[i] = (data[i+1] - 2.0f*data[i] + data[i-1]) / 1.0f; } else if (i == n-2) { // 近边界特殊处理 second_deriv[i] = (data[i+2] - 2.0f*data[i+1] + data[i]) / 1.0f; } else { // 中心差分 second_deriv[i] = (data[i+1] - 2.0f*data[i] + data[i-1]) / 1.0f; } // 记录零点 if (fabs(second_deriv[i]) < EPSILON) { second_zeros[(*second_count)++] = i; } } } int main() { // 示例数据(假设步长h=1) float data[] = {911, 914, 916, 918, 920, 922, 924, 926, 928, 930, 932, 934, 936, 938, 940, 942, 942, 939}; int n = sizeof(data)/sizeof(data[0]); // 导数存储数组 float first_deriv[MAX_DATA] = {0}; float second_deriv[MAX_DATA] = {0}; // 零点索引数组 int first_zeros[MAX_DATA] = {0}; int second_zeros[MAX_DATA] = {0}; int count1 = 0, count2 = 0; // 计算导数和零点 compute_derivatives(data, n, first_deriv, second_deriv, first_zeros, &count1, second_zeros, &count2); // 打印导数信息 printf("索引\t值\t一阶导数\t二阶导数\n"); printf("=====================================\n"); for(int i=0; i<n; i++) { printf("%d\t%.4f\t%.6f\t\t%.6f\n", i, data[i], first_deriv[i], second_deriv[i]); } // 打印零点信息 printf("\n一阶导数零点(驻点)索引: "); for(int i=0; i<count1; i++) printf("%d ", first_zeros[i]); printf("\n二阶导数零点(拐点)索引: "); for(int i=0; i<count2; i++) printf("%d ", second_zeros[i]); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 3:09:55

YOLOv8镜像支持ARM架构处理器运行

YOLOv8镜像支持ARM架构处理器运行 在智能摄像头、无人机和工业检测设备日益普及的今天&#xff0c;如何让高性能AI视觉模型真正“落地”到边缘端&#xff0c;成为开发者面临的核心挑战。传统深度学习部署多依赖x86服务器&#xff0c;但现实中的大量场景需要的是低功耗、小体积、…

作者头像 李华
网站建设 2026/4/13 7:49:21

YOLOv8训练时如何平衡精度与速度?

YOLOv8训练时如何平衡精度与速度&#xff1f; 在自动驾驶的感知系统中&#xff0c;一帧图像里可能包含数十个动态目标——行人、车辆、交通标志……模型不仅要“看得准”&#xff0c;还得“反应快”。稍有延迟&#xff0c;就可能导致决策失误。这种对高精度与低延迟的双重苛刻要…

作者头像 李华
网站建设 2026/4/9 20:26:26

YOLOv8推理时如何实现动态批处理?

YOLOv8推理时如何实现动态批处理&#xff1f; 在智能监控系统中&#xff0c;成百上千路摄像头同时上传视频帧&#xff0c;服务器该如何应对&#xff1f;如果每来一个请求就立即执行一次推理&#xff0c;GPU可能只用了20%的算力就在等待下一个任务——这种“小马拉大车”的窘境&…

作者头像 李华
网站建设 2026/4/15 3:09:00

分库分表适配难?资深架构师亲授PHP环境下10年沉淀的落地经验

第一章&#xff1a;分库分表的核心挑战与PHP环境适配困境在高并发、大数据量的现代Web应用中&#xff0c;单一数据库已难以承载业务增长的压力。分库分表作为提升数据库横向扩展能力的重要手段&#xff0c;被广泛应用于大型系统架构中。然而&#xff0c;在PHP这一广泛用于Web开…

作者头像 李华
网站建设 2026/4/14 18:17:16

手把手教你用PHP打造工业级视频流处理引擎,99%的人都不知道的底层逻辑

第一章&#xff1a;工业级视频流处理引擎的核心认知在现代多媒体应用中&#xff0c;工业级视频流处理引擎是支撑实时通信、智能监控、直播平台等高并发场景的底层基石。这类系统不仅要求极低的延迟和高吞吐能力&#xff0c;还需具备弹性扩展、容错恢复和协议兼容性等关键特性。…

作者头像 李华
网站建设 2026/4/14 14:34:34

PHP日志解析自动化实践(基于ELK+机器学习的异常检测架构)

第一章&#xff1a;PHP日志解析自动化实践概述在现代Web应用运维中&#xff0c;PHP日志是诊断系统异常、追踪用户行为和优化性能的重要数据源。随着系统规模扩大&#xff0c;手动查看和分析日志已无法满足实时性和效率需求&#xff0c;因此实现日志解析的自动化成为关键实践。自…

作者头像 李华