stm32-定时器输入捕获

news2025/1/11 16:58:16

目录

一、输入捕获简介

二、输入捕获框图

1.定时器总框图

2.输入捕获框图 

3.主从触发模式

三、固件库实现 

1.定时器测量PWM频率

2.PWMI模式 


一、输入捕获简介

二、输入捕获框图

1.定时器总框图

 上图可知,四个输入捕获和输出比较共用4CCR寄存器,且输入捕获和输出比较的CH口是同一个,所以同一个通道同一时间只能使用一种功能

  • 输入滤波器和边沿检测器一旦检测到电平跳变,就会将CNT的值写入CCR中,类似于中断的作用

2.输入捕获框图 

分频器:

滤波器:

3.主从触发模式

主模式: 这个主模式的输出可以是PWM,即我的看法是主模式是用来作为其他定时器的输入的,比如我们用定时器1的PWMOC输出作为TIM2的输入捕获波型

触发源选择和从模式:即触发从模式的方式,比如我们可以用通道1的滤波后的定时器输入作为触发器,来触发从模式的复位,即通道一每接收到一次边沿跳变(具体的高低是我们自己设置的),就会触发从模式CNT清零

三、固件库实现 

1.定时器测量PWM频率

  • TIM3用于输出比较产生PWM,TIM4用于输入捕获,只有CH1和CH2有从模式
  • TIM4的配置同TIM3的前面一致,不过TIM4的ARR给到了65536-1 防止溢出时还未检测完频率
  • 初始化输入捕获单元,选上升沿---TIM_ICInit
  • 配置触发源--TIM_SelectInputTrigger
  • 配置从模式为RESET--TIM_SelectSlaveMode
  • 启动定时器,TIM_Cmd(TIM4,ENABLE);//CNT开始自增
  • 在主函数里用库函数设置TIM3的PSC和CRR,初始化的时候TIM3的ARR设置为100-1,这个数字好计算,用库函数读取N(CNT)

#include "bsp_tim.h"

//TIM3--CH1--PA6
void TIM3_OC_Config()
{
	//开启时钟

	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);//开启PWM引脚

	//重定义
	GPIO_PinRemapConfig(GPIO_PartialRemap_TIM3,ENABLE);
	//初始化GPIO
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStruct.GPIO_Mode  = GPIO_Mode_AF_PP;//复用推挽,手册可看
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
	GPIO_Init(GPIOA,&GPIO_InitStruct);
	
	//选择时基单元的时钟-为内部时钟--定时器上电后默认是内部时钟,故不写这一个也行
	TIM_InternalClockConfig(TIM3);
	//初始化时基单元
	TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
	
	TIM_TimeBaseInitStruct.TIM_Prescaler = 720-1;//PSC-预分频器
	TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数 
	TIM_TimeBaseInitStruct.TIM_Period = 100-1;//ARR寄存器-重装载寄存器
	TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;/*不分频----滤波器的采样频率,可以由内部时钟直接提供,
																													也可以由内部时钟加一个时钟分频而来,
																													分频系数就是由TIM_ClockDivision决定*/
	TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0;//重复计数器,只有高级定时器才有
	TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStruct);
	
	//初始化OC-输出比较结构体
	TIM_OCInitTypeDef TIM_OCInitStruct;
	TIM_OCStructInit(&TIM_OCInitStruct);//因为结构体里面的成员有些是高级定时器采用得到,所以这里就先全部初始化一遍,然后再配置具体的值
	TIM_OCInitStruct.TIM_OCMode = TIM_OCMode_PWM1;//输出比较模式
	TIM_OCInitStruct.TIM_OutputState = TIM_OutputState_Enable;
	//TIM_OCInitStruct.TIM_Pulse = 50;//CRR   --设置频率1KHZ,占空比50%,分辨率1%的PWM波型
	TIM_OCInitStruct.TIM_Pulse = 0;//用固件库的一个函数 TIM_SetCompare2 直接配置CRR
	TIM_OCInitStruct.TIM_OCPolarity = TIM_OCPolarity_High;//输出比较极性
	TIM_OC1Init(TIM3,&TIM_OCInitStruct);//CH1通道
	
	
	//启动定时器
	TIM_Cmd(TIM3,ENABLE);

}
void PWM_SetCompare1(uint16_t Compare)//设置CRR,即比较值
{
	TIM_SetCompare1(TIM3,Compare);
}
void PWM_SetPrescaler(uint16_t Prescaler)//设置PSC
{
	TIM_PrescalerConfig(TIM3,Prescaler,TIM_PSCReloadMode_Immediate);//不使用影子寄存器
}
//TIM4--CH1--PB6
void TIM4_IC_Config()
{
	//开启时钟
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);//开启PWM引脚

	//初始化GPIO
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStruct.GPIO_Mode  = GPIO_Mode_IN_FLOATING;//浮空输入
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
	GPIO_Init(GPIOB,&GPIO_InitStruct);
	
	//选择时基单元的时钟-为内部时钟--定时器上电后默认是内部时钟,故不写这一个也行
	TIM_InternalClockConfig(TIM4);
	//初始化时基单元
	TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
	
	TIM_TimeBaseInitStruct.TIM_Prescaler = 72-1;//PSC-预分频器-->fc = 72M/PSC = 1M
	TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数 
	TIM_TimeBaseInitStruct.TIM_Period = 65536-1;//ARR寄存器-重装载寄存器
	TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;/*不分频----滤波器的采样频率,可以由内部时钟直接提供,
																													也可以由内部时钟加一个时钟分频而来,
																													分频系数就是由TIM_ClockDivision决定*/
	TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0;//重复计数器,只有高级定时器才有
	TIM_TimeBaseInit(TIM4,&TIM_TimeBaseInitStruct);
	
	//初始化输入捕获单元
	TIM_ICInitTypeDef TIM_ICInitStruct;
	TIM_ICInitStruct.TIM_Channel = TIM_Channel_1;//输入通道
	TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising;//上升沿
	TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_DirectTI;//直连通道 ,不交叉
	TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//不分频--每次触发都有效
	TIM_ICInitStruct.TIM_ICFilter = 0xF;//滤波器参数
	TIM_ICInit(TIM4,&TIM_ICInitStruct);
	
	//配置触发源
	TIM_SelectInputTrigger(TIM4,TIM_TS_TI1FP1);
	//配置从模式为RESET
	TIM_SelectSlaveMode(TIM4,TIM_SlaveMode_Reset);
	//启动定时器
	TIM_Cmd(TIM4,ENABLE);//CNT开始自增

}

uint32_t IC_Get_Freq(void)
{
	return 1000000 / (TIM_GetCapture1(TIM4)+1);//fc/N   fc = 1M-->我们在上方配置的PSC为72-1
											//这里加1是为了凑整,--->不然测出来是1001
											//未连接PB6和PA6的时候是1000000是因为CRR1寄存器复位值为0,0+1=1 所以1M/1=1M
}
int main()
{
	OLED_Init();
	USART_Config();
	TIM3_OC_Config();
	TIM4_IC_Config();
	//配置TIM3的输出PWM频率和占空比				//CK_PSC = 72M   ARR+1 已经配置好了是100
	PWM_SetPrescaler(720-1);		//Freq = CK_PSC / (PSC+1)/(ARR+1)
	PWM_SetCompare1(50); 				//占空比 Duty = CCR /(ARR+1)
	//此时Freq = 72000000/720/100 = 1000
	while(1)
	{
		i = IC_Get_Freq();
		OLED_ShowNum(1,1,i,7);
	}
}

2.PWMI模式 

PA6提供PWM
PB6接收PWM
接收的时候分两个通道接收,通道一接收频率,通道二接收占空比
--因为一个CCR寄存器只能接收一种数据
占空比 = 高电平时间/总时间,只用一个CCR无法测量
所以把CCR2当做测量高电平时间的工具
相当于把PWM信号通过CH1的通道输入到两个CCR中,所以最后只用测CH1的PWM就行
通道一上升沿
通道二下降沿
选CH1的RESET,->选中的触发输入(TRGI)的上升沿重新初始化计数器,并且产生一个更新寄存器的信号。
所以CCR1是上升沿->上升沿,即整个PWM
CCR2是从下降沿->上升沿
所以Duty = CCR2/CCR1

TIM_PWMIConfig()

使用这个函数可快速配置通道二,其原理就是用if语句判断当前已经配置好的通道,然后进行另一个通道的反向配置 

#include "bsp_tim.h"

//TIM3--CH1--PA6
void TIM3_OC_Config()
{
	//开启时钟

	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);//开启PWM引脚

	//重定义
	GPIO_PinRemapConfig(GPIO_PartialRemap_TIM3,ENABLE);
	//初始化GPIO
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStruct.GPIO_Mode  = GPIO_Mode_AF_PP;//复用推挽,手册可看
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
	GPIO_Init(GPIOA,&GPIO_InitStruct);
	
	//选择时基单元的时钟-为内部时钟--定时器上电后默认是内部时钟,故不写这一个也行
	TIM_InternalClockConfig(TIM3);
	//初始化时基单元
	TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
	
	TIM_TimeBaseInitStruct.TIM_Prescaler = 720-1;//PSC-预分频器
	TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数 
	TIM_TimeBaseInitStruct.TIM_Period = 100-1;//ARR寄存器-重装载寄存器
	TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;/*不分频----滤波器的采样频率,可以由内部时钟直接提供,
																													也可以由内部时钟加一个时钟分频而来,
																													分频系数就是由TIM_ClockDivision决定*/
	TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0;//重复计数器,只有高级定时器才有
	TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStruct);
	
	//初始化OC-输出比较结构体
	TIM_OCInitTypeDef TIM_OCInitStruct;
	TIM_OCStructInit(&TIM_OCInitStruct);//因为结构体里面的成员有些是高级定时器采用得到,所以这里就先全部初始化一遍,然后再配置具体的值
	TIM_OCInitStruct.TIM_OCMode = TIM_OCMode_PWM1;//输出比较模式
	TIM_OCInitStruct.TIM_OutputState = TIM_OutputState_Enable;
	//TIM_OCInitStruct.TIM_Pulse = 50;//CRR   --设置频率1KHZ,占空比50%,分辨率1%的PWM波型
	TIM_OCInitStruct.TIM_Pulse = 0;//这里的CRR就不需要了,用固件库的一个函数 TIM_SetCompare2 直接配置CRR
	TIM_OCInitStruct.TIM_OCPolarity = TIM_OCPolarity_High;//输出比较极性
	TIM_OC1Init(TIM3,&TIM_OCInitStruct);//CH1通道
	
	
	//启动定时器
	TIM_Cmd(TIM3,ENABLE);

}
void PWM_SetCompare1(uint16_t Compare)//设置CRR,即比较值
{
	TIM_SetCompare1(TIM3,Compare);
}
void PWM_SetPrescaler(uint16_t Prescaler)//设置PSC
{
	TIM_PrescalerConfig(TIM3,Prescaler,TIM_PSCReloadMode_Immediate);//不使用影子寄存器
}
//TIM4--CH1--PB6-频率
// 			CH2--PB7-占空比	
void TIM4_IC_Config()
{
	//开启时钟
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);//开启PWM引脚

	//初始化GPIO
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStruct.GPIO_Mode  = GPIO_Mode_IN_FLOATING;//浮空输入
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
	GPIO_Init(GPIOB,&GPIO_InitStruct);
	
	//选择时基单元的时钟-为内部时钟--定时器上电后默认是内部时钟,故不写这一个也行
	TIM_InternalClockConfig(TIM4);
	//初始化时基单元
	TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
	
	TIM_TimeBaseInitStruct.TIM_Prescaler = 72-1;//PSC-预分频器-->fc = 72M/PSC = 1M
	TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数 
	TIM_TimeBaseInitStruct.TIM_Period = 65536-1;//ARR寄存器-重装载寄存器
	TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;/*不分频----滤波器的采样频率,可以由内部时钟直接提供,
																													也可以由内部时钟加一个时钟分频而来,
																													分频系数就是由TIM_ClockDivision决定*/
	TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0;//重复计数器,只有高级定时器才有
	TIM_TimeBaseInit(TIM4,&TIM_TimeBaseInitStruct);
	
	//初始化输入捕获单元
	TIM_ICInitTypeDef TIM_ICInitStruct;
	TIM_ICInitStruct.TIM_Channel = TIM_Channel_1;//输入通道
	TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising;//上升沿
	TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_DirectTI;//直连通道 ,不交叉
	TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//不分频--每次触发都有效
	TIM_ICInitStruct.TIM_ICFilter = 0xF;//滤波器参数
	TIM_ICInit(TIM4,&TIM_ICInitStruct);
	
	TIM_PWMIConfig(TIM4,&TIM_ICInitStruct);//由该函数的具体实现可知,我们上面配置的通道一,该函数就会给我们配置成通道二和应该更改的参数
	//作用同下
	/*
	TIM_ICInitStruct.TIM_Channel = TIM_Channel_2;//输入通道
	TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Falling;//下降沿
	TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_IndirectTI;//交叉
	TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//不分频--每次触发都有效
	TIM_ICInitStruct.TIM_ICFilter = 0xF;//滤波器参数
	TIM_ICInit(TIM4,&TIM_ICInitStruct);
	*/
	
	//配置触发源
	TIM_SelectInputTrigger(TIM4,TIM_TS_TI1FP1);
	//配置从模式为RESET
	TIM_SelectSlaveMode(TIM4,TIM_SlaveMode_Reset);//选中的触发输入(TRGI)的上升沿重新初始化计数器,并且产生一个更新寄存器的信号。--SMCR_SMS
	TIM_SelectMasterSlaveMode(TIM4,TIM_MasterSlaveMode_Enable);//使能主从模式--SMCR_MSM
	//启动定时器
	TIM_Cmd(TIM4,ENABLE);//CNT开始自增

}

float IC_Get_Freq(void)
{
	return 1000000 / (float)(TIM_GetCapture1(TIM4)+1);//fc/N   fc = 1M
																		//这里加1是为了凑整,--->不然测出来是1001
																		//未连接PB6和PA6的时候是1000000是因为CRR1寄存器复位值为0,0+1=1 所以1M/1=1M
}
float IC_Get_Duty(void)
{
	return (float)(100*(1+TIM_GetCapture2(TIM4)))/(1+TIM_GetCapture1(TIM4));//*100->为了显示的是整数,各加一是为了看着舒服
}









int main()
{
	OLED_Init();
	USART_Config();
	TIM3_OC_Config();
	TIM4_IC_Config();
	//配置TIM3的输出PWM频率和占空比				//CK_PSC = 72M   ARR+1 已经配置好了是100
	PWM_SetPrescaler(720-1);		//Freq = CK_PSC / (PSC+1)/(ARR+1)
	PWM_SetCompare1(50); 				//占空比 Duty = CCR /(ARR+1)
	//此时Freq = 72000000/720/100 = 1000
	while(1)
	{
		i = IC_Get_Freq();
		j = IC_Get_Duty();
		OLED_ShowNum(1,1,i,7);
		OLED_ShowNum(3,1,j,3);
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1520002.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于SpringBoot和Echarts的全国地震可视化分析实战

目录 前言 一、后台数据服务设计 1、数据库查询 2、模型层对象设计 3、业务层和控制层设计 二、Echarts前端配置 1、地图的展示 2、次数排名统计 三、最终结果展示 1、地图展示 2、图表展示 总结 前言 在之前的博客中基于SpringBoot和PotsGIS的各省地震震发可视化分…

【C++】类的默认成员函数及其特性(万字详解)

🦄个人主页:修修修也 🎏所属专栏:C ⚙️操作环境:Visual Studio 2022 目录 类对象函数的核心设计----This指针 This指针是什么? This指针的特性 类的默认成员函数 构造函数 构造函数的定义 构造函数的特性 析构函数 析构函数概念 析构函数的特…

.NET开源快速、强大、免费的电子表格组件

今天大姚给大家分享一个.NET开源(MIT License)、快速、强大、免费的电子表格组件,支持数据格式、冻结、大纲、公式计算、图表、脚本执行等。兼容 Excel 2007 (.xlsx) 格式,支持WinForm、WPF和Android平台:ReoGrid。 项…

【Hadoop】Hadoop概述与核心组件

目录 Hadoop概述Hadoop 发展历史Hadoop 三大发行版本1.Apache Hadoop(常用)2.Cloudera Hadoop3.Hortonworks Hadoop优势优势总结——4高(高可靠、高扩展、高效、高容错) Hadoop组成1.HDFS管理者:NameNode(n…

分布式CAP理论

CAP理论:一致性(Consistency)、可用性(Availability)和分区容错性(Partition tolerance)。是Eric Brewer在2000年提出的,用于描述分布式系统基本性质的定理。这三个性质在分布式系统…

贪心算法(算法竞赛、蓝桥杯)--均分纸牌

1、B站视频链接&#xff1a;A30 贪心算法 P1031 [NOIP2002 提高组] 均分纸牌_哔哩哔哩_bilibili 题目链接&#xff1a;[NOIP2002 提高组] 均分纸牌 - 洛谷 #include <bits/stdc.h> using namespace std; int n,a[101],av,cnt;int main(){scanf("%d",&n);…

Android SystemServer进程解析

SystemServer进程在android系统中占了举足轻重的地位&#xff0c;系统的所有服务和SystemUI都是由它启动。 一、SystemServer进程主函数流程 1、主函数三部曲 //frameworks/base/services/java/com/android/server/SystemServer.java /** * The main entry point from zy…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Navigator)

路由容器组件&#xff0c;提供路由跳转能力。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 可以包含子组件。 接口 Navigator(value?: {target: string, type?: NavigationType}) …

从0开始回顾MySQL --- 三范式与表设计

什么是数据库设计三范式 数据库表设计的原则。教你怎么设计数据库表有效&#xff0c;并且节省空间。 三范式 第一范式&#xff1a;任何一张表都应该有主键&#xff0c;每个字段是原子性的不能再分 以下表的设计不符合第一范式&#xff1a;无主键&#xff0c;并且联系方式可拆…

信雅纳网络测试的二次开发集成:XOA(Xena Open-Source Automation)开源自动化测试

目录 XOA是什么 XOA CLI XOA Python API ​XOA Python Test Suite/测试套件 XOA Converter Source Code XOA是什么 XOA&#xff08;Xena Open-Source Automation&#xff09;是一个开源的测试自动化框架&#xff0c;追求“高效、易用、灵活”的跨操作系统的开发框架。能…

量子遗传算法优化VMD参数,五种适应度函数任意切换,最小包络熵、样本熵、信息熵、排列熵、排列熵/互信息熵...

关于量子遗传算法&#xff0c;在众多文献均有应用。下面简述一下原理。 &#xff08;1&#xff09;量子比特编码 子遗传算法通过引入量子比特来完成基因的存储和表达。量子比特是量子信息中的概念&#xff0c;它与经典比特不同&#xff0c;是因为它可以在同一时刻处于两个状态的…

Docker安装蜜罐Hfish

前言 无意中发现公司的一台服务器被爆破&#xff0c;修改了密码&#xff0c;为了确定内网是否安装需要搭建一个蜜罐来看一下是否存在隐患。 如何安装Docker&#xff0c;请查看我另一篇文章 https://blog.csdn.net/l1677516854/article/details/136751211 一、拉取镜像 dock…

SwiftUI组件 - AsyncImage

SwiftUI组件-AsyncImage import SwiftUIstruct AsyncImageBootcamp: View {let url URL(string: "https://picsum.photos/200")var body: some View {/// Mark - iOS15 以后才有的方法ScrollView {AsyncImage(url: url, content: { returnImage inreturnImage.resiz…

鸿蒙开发实战:【音频组件】

简介 音频组件用于实现音频相关的功能&#xff0c;包括音频播放&#xff0c;录制&#xff0c;音量管理和设备管理。 图 1 音频组件架构图 基本概念 采样 采样是指将连续时域上的模拟信号按照一定的时间间隔采样&#xff0c;获取到离散时域上离散信号的过程。 采样率 采样…

【AI】创建自己的基于会话的自定义模型的ChatGPT

【AI】创建自己的基于会话的自定义模型的ChatGPT 目录 【AI】创建自己的基于会话的自定义模型的ChatGPT开篇功能设计步骤详解1. 爬取Web数据2. 拆分文档3. 创建向量嵌入4. 将向量嵌入存储在Chroma中5. 用户提出问题6. 创建提问的向量嵌入7. 语义搜索向量数据库8. 生成提示9. 提…

【AAAI 2024】解锁深度表格学习(Deep Tabular Learning)的关键:算术特征交互

近日&#xff0c;阿里云人工智能平台PAI与浙江大学吴健、应豪超老师团队合作论文《Arithmetic Feature Interaction is Necessary for Deep Tabular Learning》正式在国际人工智能顶会AAAI-2024上发表。本项工作聚焦于深度表格学习中的一个核心问题&#xff1a;在处理结构化表格…

【网络安全】 MSF提权

本文章仅用于信息安全学习&#xff0c;请遵守相关法律法规&#xff0c;严禁用于非法途径。若读者因此作出任何危害网络安全的行为&#xff0c;后果自负&#xff0c;与作者无关。 环境准备&#xff1a; 名称系统位数IP攻击机Kali Linux6410.3.0.231客户端Windows 76410.3.0.234…

基于GA优化的CNN-GRU-Attention的时间序列回归预测matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1卷积神经网络&#xff08;CNN&#xff09;在时间序列中的应用 4.2 长短时记忆网络&#xff08;LSTM&#xff09;处理序列依赖关系 4.3 注意力机制&#xff08;Attention&#xff09; 4…

CSS之字体镂空

方法一(有缺陷)&#xff1a; <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>Examples</title> <style> .num1{-webkit-text-stroke: 0.4px red; }</style> </head> <body><div clas…

神策分析 Copilot 成功通过网信办算法备案,数据分析 AI 化全面落地

近日&#xff0c;神策数据严格遵循《互联网信息服务深度合成管理规定》&#xff0c;已完成智能数据问答算法备案。该算法基于大模型技术&#xff0c;专注于为客户提供数据指标查询和数据洞察方面的专业回答。 神策分析 Copilot 运用神策数据智能数据问答算法&#xff0c;聚焦分…