- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 STM32F407VGT6
与 CubeMX
结合使用。因此,我从通用定时器开始,但我被预分频值和周期值困住了。
基本上我想每n
(其中n=1,2,3..)毫秒生成一个计时器中断并执行一些任务。计算周期和预分频值的公式有很多变化。
公式的一些版本是:
TIMupdateFreq(HZ) = Clock/((PSC-1)*(Period-1))
Update Event = TIM clk/((PSC+1)*(ARR+1)*(RCR+1))
Prescaler = ((((ClockSpeed) / ((period) / (1 / frequency))) + 0.5) - 1)
说到这个问题,我的核心时钟运行在 168 MHz,但我可以看到定时器连接到运行在 84 MHz 的 APB1 总线。
我尝试过生成 1 毫秒延迟的代码(根据作者的说法),在使用预分频值和周期值后,我生成了也生成 1 毫秒延迟的代码(凭直觉 - 无范围)。
该代码使用预分频值 41999 和周期 1999。
所以,
PSC - 41999
ARR - 1999
将此应用于第二个公式
更新事件 = TIM clk/((PSC+1)*(ARR+1)*(RCR+1))
更新事件 = 84000000/(42000*2000) = 1
(这是 1 毫秒的延迟吗?)
好的,现在我想了解如何选择 PSC = 41999
和 Period = 1999
?它纯粹基于假设吗?无论我使用什么公式,我都必须假设一个变量?如果我想要 1.5 或 2.3 或 4.9 之类的精确计时,如何计算预分频和周期?
此外,当我使用PSC=41999
和Period =999
时,更新事件值为2:
更新事件 = 84000000/(42000*1000) = 2
但是我每秒延迟两次。即 500 毫秒。
当我使用 PSC=39999
和 Period=4199
时,更新事件值为 0.5:
更新事件 = 84000000/(40000*4200) = 0.5
我的延迟为 2 毫秒。
最佳答案
TIMupdateFreq(HZ) = Clock/((PSC-1)*(Period-1))
这显然是错误的。计数器从0到寄存器值(含),总是比寄存器值多一个周期,而不是少一个周期。
Update Event = TIM clk/((PSC+1) * (ARR+1) * (RCR+1))
这个更好,但是通用定时器没有RCR
寄存器。您可以假设 RCR=0
,并省略*(RCR+1)
由公式可知。
Prescaler = ((((ClockSpeed) / ((period) / (1 / frequency))) + 0.5) - 1)
当不可能有整数解时,这会尝试对结果进行四舍五入。稍后详细介绍。
Update Event = 84000000/(42000*2000) = 1
(Is this 1ms Delay??)
不,这是一秒 (1s) 延迟,或 1 Hz 频率。
how this
PSC = 41999
andPeriod = 1999
are selected?
采用简单的公式,
Updatefrequency = TIM clk/((PSC+1)*(ARR+1))
重新排列
(PSC+1)*(ARR+1) = TIMclk/Updatefrequency
那么右侧有一个已知值,但左侧有两个未知值。最简单的解决方案是设置其中之一,例如PSC
至0
,和ARR
右侧值 - 1。
不幸的是,大多数定时器只有 16 位寄存器,因此当 TIMclk/Updatefrequency > 65535
时这将不起作用。 。 两者PSC
和ARR
必须介于 0 和 65535 之间。您必须找到满足这些约束的因式分解。
让我们看一个例子,您想要 2.3 秒的延迟。请注意,2.3s 是周期,而不是频率,因此您需要将其倒数代入公式中。
(PSC+1) * (ARR+1) = 84000000 / (1 / 2.3) = 84000000 * 2.3 = 193200000
幸运的是,末尾有很多零,您可以选择例如10000
作为预分频器( PSC=9999
),和 ARR
变成19320-1 = 19319
。如果所需的比率不是一个很好的整数,那么您应该求助于 integer factorization ,或者编写一个小程序来查找所有可能的除数 ( for(i=0;i<65536;i++) ...
)。
也可能根本没有精确的整数解,那么您仍然可以循环遍历所有可能的预分频器值,并查看哪一个给出的误差最小。
Update Event = 84000000/(42000*1000) = 2
But my delay is twice in every sec. i.e 500ms
注意尺寸。您在公式中使用频率,将 84 MHz 输入频率除以一些值,并得到2 Hz 结果。 2 Hz 频率意味着每秒发生两个事件,因此这些事件确实相隔 500 毫秒。
关于timer - STM32F4 定时器 - 计算周期和预分频,以生成 1 ms 延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51906691/
我正在使用计时器以相当长的间隔(2分钟)定期运行事件。一切正常。但是,我希望在创建计时器时立即触发该事件(而不是等待2分钟)。 请注意,我不能仅通过调用方法来执行此操作,因为它需要一些时间才能运行,并
我正在检查一些可怕的遗留代码,这些代码具有 Timer 事件以及一些包含 DoEvents 调用的冗长代码。简化版如下所示: Private Sub tmrProcess_Timer()
我正在尝试创建一个 Windows 窗体应用程序,我想实现一个计时器。 public void timerStart() { DateTime now = DateTime
我正在创建一个新类,以便使 System.Timers.Timer 类更好地满足我的需要。我像这样创建我的新类...... using System.Timers; class BtElapsedEv
我最近一直在检查一些可能的计时器,并且 System.Threading.Timer和 System.Timers.Timer对我来说是必要的(因为它们支持线程池)。 我正在制作一款游戏,我计划使用所
首先我要说的是,与其说这是一个需要解决的问题,不如说这是一个问题。我现在有了解决方案,对我来说一切正常。但是我想知道为什么第一次出现问题。 这是我现在拥有的代码,它的工作方式与我预期的一样:
在本文中:http://msdn.microsoft.com/en-us/magazine/cc164015.aspx作者声明 System.Threading.Timer 不是线程安全的。 从那时起
背景: 我有一个计时器,我用它来跟踪自 serialPort DataReceived 事件被触发以来已经过了多长时间。我正在为此创建自己的解决方案而不是使用内置的超时事件,因为我正在获取连续的数据流
我正在查看 Flutter Timer代码和 cancel() 方法。当我想删除一个计时器时,我可以使用这两行: timer.cancel(); timer = null; 或者我可以这样做: 定时器
我正在尝试使用 C# 中的计时器以五秒的间隔运行一个方法。虽然这段代码似乎不起作用。运行它时我没有收到任何错误,但程序(我在控制台中运行)在 IP.timer1.Start() 之后立即关闭。 tim
我正在尝试使用 C# 中的计时器以五秒的间隔运行一个方法。虽然这段代码似乎不起作用。运行它时我没有收到任何错误,但程序(我在控制台中运行)在 IP.timer1.Start() 之后立即关闭。 tim
我有错误显示: 'Timer' is an ambiguous reference between 'System.Windows.Forms.Timer' and 'System.Threading
在我的应用程序中,我必须定期向“兄弟”应用程序发送心跳。 使用 System.Timers.Timer/Threading.Timer 或使用带有 while 循环和 Thread.Sleep 的线程
我最近遇到了编写 Windows 服务的挑战。我需要定期请求一个 URL 并检查它的可用性。为此,我决定在 OnStart 中初始化一个计时器。服务方法并在 timer_Tick 中完成所有工作事件。
看来 System.Timers.Timer 实例通过某种机制保持事件状态,但 System.Threading.Timer 实例则不然。 示例程序,具有定期System.Threading.Time
我做了一个 goog.Timer对象 ( http://closure-library.googlecode.com/svn/docs/class_goog_Timer.html ) 与 new go
当您处理“原始”.net 计时器时,您可以传入等待句柄以在 Win32 计时器被销毁后调用,并且您可以假设您的回调不会被调用。 (并且计时器将被 GC 视为“死”) 如何使用 System.Timer
我想让 deoplete 自动完成建议弹出得更快,这需要设置 g:deoplete#auto_complete_delay help 说这需要 +timers 支持。如何在配置中启用此计时器? 谢谢!
我想知道是否有合理的方法来确定 Timers.Timer 对象的负载能力?或者,更确切地说,线程功能。有人知道使用 Timer 类启动大量(数百个)线程是否有任何问题? 编辑:为了工作,我们将启动一些
我正在创建一个 WindowsService,它的 Timer 绑定(bind)到具有无限循环的 EventHandler;我希望能够在服务的 OnStart() 方法中触发此计时器一次,然后在服务的
我是一名优秀的程序员,十分优秀!