bsp_Calculus.cpp D:/gitt/MicrochipFor32/bsp_Device/bsp_math/bsp_Calculus.cpp 浏览该文件的文档.00001 /*---------------------------------------------------------------------------------------------------- 00002 # 00003 # Copyright (c) 2022 Yuankang Liang(XerolySkinner) 00004 # 00005 # 本软件按原样提供,无任何明示或暗示 00006 # 在任何情况下,作者都不承担任何损害赔偿责任 00007 # 00008 # 使用的许可声明: 00009 # 1. 不得歪曲本软件的来源,你不能声称你编写了原始软件. 00010 # 2. 免费授予以任何目的,前提是版权声明出现在所有副本中. 00011 # 并且版权声明和许可声明同时出现. 00012 # 3. 你有使用,复制,修改,分发,和销售本软件的许可. 00013 # 4. 如果你在产品中使用,产品文档中的声明是赞赏的但不是必须的. 00014 # 5. 本通知不得从任何来源删除或更改. 00015 # 00016 # Yuankang Liang(XerolySkinner) 00017 # E-mail:zabbcccbbaz@163.com 00018 # QQ:2715099320 00019 # Mobile Phone:13005636215 00020 # 00021 # All rights reserved. 00022 */ 00023 00035 //---------------------------------------------------------------------------------------------------- 00036 // 头文件 00037 #include "bsp_Calculus.h" 00039 //---------------------------------------------------------------------------------------------------- 00040 // 类函数 00046 float bsp_Differential::Differential(float var) { 00047 static float old=var; 00048 float result= (var - old) / dt; 00049 old = var; 00050 return result;} 00052 //---------------------------------------------------------------------------------------------------- 00053 // 类函数 00059 float bsp_Integral::Integral(float var) { 00060 results += var * dt; 00061 return results;} 00062 //---------------------------------------------------------------------------------------------------- 00067 void bsp_Integral::Integral_set(float results) { 00068 bsp_Integral::results = results;} 00069 //---------------------------------------------------------------------------------------------------- 00075 u32 bsp_Integral::Integral_makelist(u32 len) { 00076 result_list = (float*)malloc(sizeof(float)* len); 00077 result_len = len; 00078 Integral_clslist(); 00079 return (u32)result_list;} 00080 //---------------------------------------------------------------------------------------------------- 00086 float bsp_Integral::Integral_list(float var) { 00087 static u32 len=0; 00088 results += var * dt; 00089 // 保存历史 00090 result_list[len] = var * dt; 00091 // 轮盘转 00092 ++len; 00093 if (len == result_len)len = 0; 00094 // 去除尾值 00095 if (len < result_len - 1) 00096 results -= result_list[len + 1]; 00097 else 00098 results -= result_list[0]; 00099 // 00100 return results;} 00101 //---------------------------------------------------------------------------------------------------- 00105 void bsp_Integral::Integral_dellist(void) { 00106 free(result_list); 00107 result_len = 0; 00108 result_list = NULL;} 00109 //---------------------------------------------------------------------------------------------------- 00113 void bsp_Integral::Integral_clslist(void) { 00114 if (result_list == NULL)return; 00115 for (u32 i = 0; i < result_len; i++) 00116 result_list[i] = 0;}