【STM32的通用定時器CR1的CKD[1:0]: 時鐘分頻因子 (Clock division)】

在 STM32 的通用定時器(如 TIM2, TIM3, TIM4, TIM5 等)中,CR1 (Control Register 1) 寄存器中的 CKD[1:0] (Clock division) 位域是一個與抗干擾和數字濾波相關的設置,它并不直接影響定時器計數器 (CNT) 的計數頻率(計數頻率由預分頻器 PSC 決定)。它的主要作用是控制定時器內部時鐘 (CK_INT) 相對于外部時鐘 (ETR) 或外部觸發輸入 (TIx) 的數字濾波器采樣頻率,以及死區時間生成的時鐘基準

核心概念:

  1. 定時器時鐘源 (CK_PSC) 這是驅動定時器預分頻器 (PSC) 和計數器 (CNT) 的最終時鐘源。它可以來自內部時鐘 (CK_INT)、外部時鐘模式 1 (ETR)、外部時鐘模式 2 (TIx) 或內部觸發輸入 (ITRx)

  2. 數字濾波器: 定時器對外部輸入信號(如 ETR, TI1, TI2)有內置的數字濾波器,用于抑制高頻噪聲(毛刺)。濾波器通過采樣輸入信號來工作。

  3. 死區時間生成: 在高級定時器 (TIM1, TIM8) 中用于互補 PWM 輸出時,需要插入死區時間以防止上下管同時導通。死區時間的分辨率也需要一個時鐘基準。

CKD[1:0] 的作用: 它定義了用于數字濾波采樣死區時間分辨率的時鐘 (t_DTS) 相對于定時器內部時鐘 (CK_INT) 的分頻關系。

CKD[1:0] 的取值與含義:

CKD[1:0]分頻因子數字濾波/死區時間基準時鐘 (t_DTS)說明抗干擾能力延遲/分辨率
0001t_DTS = t_CK_INT不分頻。采樣頻率最高。最低最小
0112t_DTS = 2 * t_CK_INT2 分頻。采樣頻率為 CK_INT 的一半。中等中等
1024t_DTS = 4 * t_CK_INT4 分頻。采樣頻率為 CK_INT 的四分之一。最高最大
113ReservedReserved保留。勿使用此設置。--

詳細解釋:

  1. 對數字濾波器的影響:

    • 數字濾波器通過檢測 N 個連續的 t_DTS 周期內輸入信號是否穩定為高或低電平來判斷有效邊沿。N 是可配置的(通過 TIMx_CCMRx 寄存器的 ICxF[3:0] 位)。

    • CKD 決定了 t_DTS 的周期長度:

      • CKD=00 (t_DTS = t_CK_INT):濾波器采樣頻率最高。能過濾掉更窄的毛刺(即更高頻的噪聲),但對信號真實邊沿的延遲最小

      • CKD=01 (t_DTS = 2*t_CK_INT):采樣頻率中等。能過濾中等寬度的毛刺,延遲中等。

      • CKD=10 (t_DTS = 4*t_CK_INT):采樣頻率最低。能過濾更寬的毛刺(即較低頻的噪聲),但對信號真實邊沿的延遲最大

    • 選擇原則: 如果外部輸入信號環境噪聲大(毛刺多且寬),選擇更高的分頻因子(如 10 - 4分頻)可以更好地抑制噪聲,但會增加信號延遲。如果環境比較干凈或者需要低延遲,選擇低的分頻因子(如 00 - 不分頻或 01 - 2分頻)。

    • 影響的功能模塊:

      • 輸入捕獲通道: 用于測量脈沖寬度、頻率等。CKD[1:0] 影響捕獲到信號邊沿的準確性和抗噪性。

      • 外部時鐘模式: 當使用外部信號作為計數器時鐘源時(ETRTIx)。

      • 外部觸發輸入 (ETR): 用于復位、啟動、停止計數器或觸發從模式操作(如門控模式)。

      • 觸發輸出 (TRGO): 在某些從模式(如復位模式)下,CKD[1:0] 也會影響 TRGO 信號對外部觸發輸入的響應。

  2. 對死區時間生成的影響 (僅高級定時器 TIM1/TIM8):

    • 死區時間 (DTG) 的值是以 t_DTS 的倍數來配置的。

    • CKD 決定了 t_DTS 的周期長度,從而決定了死區時間的最小步進(分辨率):

      • CKD=00t_DTS 最小,死區時間分辨率最高(能配置更精細的死區時間)。

      • CKD=10t_DTS 最大,死區時間分辨率最低(配置步進變大)。

    • 選擇原則: 如果需要非常精細地控制死區時間,選擇低的分頻因子(如 00)。如果對死區時間精度要求不高,或者 CK_INT 頻率很高導致 t_DTS 已經足夠小,可以選擇更高的分頻因子以換取更好的抗噪能力(如果同時使用了外部觸發輸入)。

  3. 對定時器基本在代碼中配置: 通過設置 TIMx->CR1 寄存器的 CKD[1:0] 位。

    // 示例:設置 CKD[1:0] = 01 (2分頻)
    TIMx->CR1 &= ~TIM_CR1_CKD; // 先清零 CKD 位
    TIMx->CR1 |= TIM_CR1_CKD_1; // CKD[1:0] = 01 (TIM_CR1_CKD_1 宏通常對應 0x0200)
  4. 計數 (CNT) 頻率的影響:

    • CKD 設置對定時器計數器 CNT 的計數頻率 (CK_CNT) 完全沒有影響!

? ? ?5. 與輸入濾波器 (ICxF[3:0], ETF[3:0]) 的關系:CKD[1:0] 設置的tDTS 是輸入濾波器工作的基礎時鐘。

? ? ? ?輸入濾波器配置位(如 IC1F[3:0] 用于輸入通道 1)決定了需要連續采樣到多少次穩定電平才確認有效邊沿(N=2, 4, 6, 8 等)。實際能濾除的噪聲最小寬度是 N * tDTS。因此,CKD[1:0] 和輸入濾波器位 共同決定了濾波器的性能

?

總結與使用建議:

  • CKD[1:0] 的核心作用是設置 t_DTS 時鐘,用于數字濾波采樣和死區時間分辨率。

  • 它不改變定時器計數器 (CNT) 的計數頻率,計數頻率由預分頻器 (PSC) 控制。

  • 選擇 CKD 值是一個在抗干擾能力 (噪聲抑制) 和響應速度/分辨率 (延遲) 之間的權衡:

    • 高噪聲環境: 選擇 CKD=10 (4分頻) 獲得最強的抗噪能力(過濾更寬的毛刺),但信號延遲最大,死區時間分辨率最低。

    • 低噪聲環境或需要低延遲/高分辨率: 選擇 CKD=00 (不分頻) 獲得最小的信號延遲和最高的死區時間分辨率,但抗噪能力最弱(只能過濾很窄的毛刺)。

    • 折中方案: CKD=01 (2分頻) 提供中等性能。

  • 如果不使用外部觸發輸入 (ETR, TIx) 或者使用但環境非常干凈,并且不使用高級定時器的死區時間(或者對死區分辨率要求不高),通常保持默認值 CKD=00 即可。

  • 如果遇到外部信號誤觸發問題(噪聲引起),嘗試增大 CKD 值(并配合配置濾波器的采樣數 ICxF)是首要的解決方案之一。

簡單記憶:

  • CKD“清潔度/延遲 開關”

  • 00“快快凈凈” (響應快,環境干凈時用)。

  • 10“慢慢抗臟” (抗干擾強,響應慢,環境臟時用)。

  • 01“折中之道”

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84869.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84869.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84869.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

渲染學進階內容——機械動力的渲染系統(2)

Flywheel代碼 這篇來研究一下實例 InstanceHandle 接口深度解析 接口核心作用 InstanceHandle 是 Flywheel 渲染引擎中的 GPU實例句柄 接口,它提供了對底層渲染實例的直接控制能力。這個接口是**實例化渲染(Instanced Rendering)**系統的核心操作接口,與之前討論的 Vis…

Redis:極速緩存與數據結構存儲揭秘

Redis —— 這個強大又靈活的 開源、內存中的數據結構存儲系統。它常被用作數據庫、緩存、消息代理和流處理引擎。 核心特點 (為什么它這么受歡迎?): 內存存儲 (In-Memory): 數據主要存儲在 RAM 中,讀寫操作直接在內存中進行。核心優勢&…

vulnyx Diff3r3ntS3c writeup

信息收集 arp-scan nmap 這里默認的話是只有80端口的,這個22端口是我拿到root后開的 獲取userFlag 直接上web看看 掃個目錄 把網頁拉到最下面可以看到一個文件上傳點 我們嘗試上傳一個php文件 失敗了,那xxx呢 上傳成功了,看來后端的后綴名…

【構建】CMake 構建系統重點內容

CMake 構建系統重點內容 1 基本語法與結構 cmake_minimum_required() 指定使用的最低 CMake 版本,防止不同版本行為不一致: cmake_minimum_required(VERSION 3.16)project() 定義項目名稱、語言和版本: project(MyApp VERSION 1.0 LANGU…

Packagerun:VSCode 擴展 快捷執行命令

Packagerun:VSCode 快捷命令擴展(兼容cursor) Packagerun 是一個為 前端和node開發者設計的 VSCode 擴展,旨在簡化 package.json 中腳本的執行,并支持自定義命令以提升開發效率。通過右鍵菜單、快捷鍵或自定義配置&am…

【C語言】計算機組成、計算機語言介紹

1.1 計算機組成 1946年2月14日,由美國軍方定制的世界上第一臺電子計算機“電子數字積分計算機”( ENIAC Electronic Numerical And Calculator)在美國賓夕法尼亞大學問世。 計算機(俗稱電腦)堪稱是人類智慧的結晶,隨著計算機的不斷發展,各行各…

(九)山東大學軟件學院項目實訓-基于大模型的模擬面試系統-面試對話標題自動總結

面試對話標題自動總結 主要實現思路:每當AI回復用戶之后,調用方法查看當前對話是否大于三條,如果大于則將用戶的兩條和AI回復的一條對話傳給DeepSeek讓其進行總結(后端),總結后調用updateChatTopic進行更新…

降階法求解偏微分方程

求解給定的四個偏微分方程,采用降階法,令 v = u x v = u_x v=ux?,從而將原方程轉化為關于 v v v 的一階方程。 方程 u x y = 0 u_{xy} = 0 uxy?=0 令 v = u x v = u_x v=ux?,則方程變為 v y = 0 v_y = 0 vy?=0。解得 v = C 1 ( x ) v = C_1(x) v=C1?(x),即 u …

提的缺陷開發不改,測試該怎么辦?

經歷長時間的細致檢查,逐條執行數十條測試用例,終于發現一處疑似缺陷。截圖留存、粘貼日志,認真整理好各項信息,將它提交到缺陷管理系統。可不到五分鐘,這條缺陷就被打回了。開發人員給出的回復十分簡潔:“…

【Flutter】Widget、Element和Render的關系-Flutter三棵樹

【Flutter】Widget、Element和Render的關系-Flutter三棵樹 一、前言 在 Flutter 中,所謂的“三棵樹”是指: Widget Tree(部件樹)Element Tree(元素樹)Render Tree(渲染樹) 它們是…

IO之詳解cin(c++IO關鍵理解)

目錄 cin原理介紹 控制符(hex、oct、dec) cin如何檢查輸入 cin與字符串 cin.get(char ch) cin.get(void) istream &get(char*,int) istream &get(char*,int,char) istream &getline(char*,int); 遇到文件結尾EOF 無法完成一次完整輸入:設置f…

Bootstrap 5學習教程,從入門到精通, Bootstrap 5 分頁(Pagination)知識點及案例代碼(13)

Bootstrap 5 分頁(Pagination)知識點及案例代碼 Bootstrap 5 提供了強大的分頁組件,幫助開發者輕松實現分頁功能。以下是關于 Bootstrap 5 分頁的詳細語法知識點以及一個完整的案例代碼,包含詳細注釋,幫助初學者快速上…

Dina靶機滲透

1.信息查詢 1.1. Ip查詢 arp-scan -l 192.168.220.137 1.2. 端口收集 nmap -T4 -A -p- 192.168.220.137 1.3. 目錄掃描 dirsearch -u 192.168.220.137 -e* -i 200 通過訪問 robots.txt 文件發現有些禁止訪問得目錄 User-agent: *Disallow: /ange1Disallow: /angel1Dis…

通俗理解存儲過程注入

【通俗理解】存儲過程注入:SQL注入的“豪華升級版” 一、從廚房做菜說起:為什么需要存儲過程? 想象你經營一家連鎖餐廳,每道菜的制作流程非常復雜(比如“招牌紅燒肉”需要先焯水、再炒糖色、最后慢燉1小時&#xff09…

【算法】基于中位數和MAD魯棒平均值計算算法

問題 在項目中,需要對異常值進行剔除,需要一種魯棒性比較好的方法,總結了一個實踐方法。 方法 基于中位數和MAD(中位數絕對偏差)的魯棒平均值計算算法的詳細過程,按照您要求的步驟分解: 算法…

插入點(position) 和對齊點(AlignmentPoint)詳解——CAD c#二次開發

在 AutoCAD 中,文本對象的位置由插入點(position) 和對齊點(Alignment Point) 共同控制,兩者的關系取決于文本的對齊方式。以下是詳細說明: 一、插入點與對齊點的定義 1. 插入點(p…

QT打包應用

本次工程使用qt mingGw 64-bit 下面詳細介紹下windows平臺qt應用程序打包流程 1、先編譯項目的release版本生成exe文件 2、創建腳本運行windeployqt.exe完成打包 rundeploy.bat腳本 set PATHE:\Tools\qt\Qt5\5.14.2\mingw73_64\bin;%PATH% windeployqt.exe MyDesignWidget.ex…

[軟件測試]:什么是自動化測試?selenium+webdriver-manager的安裝,實現你的第一個腳本

目錄 1. 什么是自動化測試? 回歸測試 自動化分類 2. web自動化測試 3. selenium 1. 什么是自動化測試? 通過自動化測試工具,編寫腳本,自動執行測試用例,主要用于回歸測試,性能測試等重復測試任務 常…

使用OpenCV和Python進行圖像掩膜與直方圖分析

文章目錄 引言1. 準備工作2. 加載并顯示原始圖像3. 創建掩膜3. 應用掩膜5. 計算并顯示直方圖6. 結果分析7. 總結 引言 在圖像處理中,掩膜(Mask)是一個非常重要的概念,它允許我們選擇性地處理圖像的特定區域。今天,我將通過一個實際的例子來展…

Genio 1200 Evaluation MT8395平臺安裝ubuntu

官網教程: Getting Started with Genio 1200 Evaluation Kit — Ubuntu on Genio documentation Windows PC工具: Setup Tool Environment (Windows) — IoT Yocto documentation 鏡像下載地址: Install Ubuntu on MediaTek Genio | Ubu…