亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

無刷電機小車開發(fā)記錄03——PWM信號輸入捕獲驅(qū)動

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:未知 ? 2023-10-20 02:00 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言


??好吧,轉(zhuǎn)眼一看,距離上一篇文章已經(jīng)過去了兩個月了。只能說工作和家庭的各種事情確實太多了,人到中年屬于自己的時間確實越來越少了,再不過來調(diào)一下這個小車估計都要生銹了。所以今天過來接著做下一步工作。之前是完成了BSP的移植和導(dǎo)入,接下來就要嘗試移植FOC算法了,開源的FOC算法也比較多,我這里打算利用SimpleFOC進行移植。本身的SimpleFOC是基于C++的,這里要移植成C代碼。另外,SimpleFOC的SDK其中已經(jīng)適配了很多種類的傳感器驅(qū)動器以及無刷電機。如果硬件使用的是它已經(jīng)適配的方案,則只需要簡單配置一下就可以驅(qū)動了。而我這里是要在RTThread下移植FOC,更傾向于使用RTThread的框架,所以各種傳感器和驅(qū)動器的適配計劃加到RTThread的驅(qū)動這邊來做。FOC那邊只移植SimpleFOC的核心算法即可。所以在正式移植FOC算法之前,還需要先搭建用到的底層驅(qū)動。今天就先整理一下讀取磁編碼器PWM信號的輸入捕獲驅(qū)動的移植記錄。其實某些適配更好的BSP內(nèi)的RTThread驅(qū)動庫里面已經(jīng)有了輸入捕獲驅(qū)動,但只是捕獲了輸入脈寬的時間,而我這里需要的是捕獲PWM信號的占空比,也就對應(yīng)了磁編碼器探測到的電機位置。但大體功能類似,所以隨便找一個類似的底層驅(qū)動進行一下修改和移植即可。

磁編碼器簡介


??我這里用的是賽卓電子的國產(chǎn)磁編碼器芯片SC60228,詳情請看其數(shù)據(jù)手冊,主要特性如下:

wKgaomUxb86Ad0frAADRKt9ULqs978.jpg

移植RTT驅(qū)動


??這個比較簡單,因為RTT驅(qū)動庫內(nèi)已經(jīng)有了“rt_inputcapture.c”的驅(qū)動文件,在SDK的“rt-thread/components/drivers/misc”目錄下。只不過大多數(shù)的BSP沒有做對應(yīng)的適配而已。那先不管BSP那邊的適配問題,先把這個C文件和對應(yīng)的頭文件拷貝一份,比如我重命名為“PWM_input_capture.c”和“PWM_input_capture.h”。

wKgaomUxb86AJ7ovAABMOSbJPxk665.png

然后代碼內(nèi)容改動不大,主要改的是返回的數(shù)據(jù)除了脈寬時間還有一個周期時間,這樣就可以計算輸入PWM信號的占空比了。另外,原有的驅(qū)動上使用的是ringbuffer做了一個數(shù)據(jù)緩存,這樣數(shù)據(jù)處理可以異步話,什么時候需要什么時候把緩存內(nèi)的數(shù)據(jù)全部讀走即可。但各人考慮,我應(yīng)用的場合是用這個信號來驅(qū)動無刷電機,這個PWM信號的輸入頻率也才1Khz,市面上大多數(shù)的無刷電機驅(qū)動,底層控制頻率基本都達到了10Khz以上。所以我這里肯定不需要異步處理的,會直接用這個信號觸發(fā)底層控制。而且控制效果還需要測試,如果轉(zhuǎn)速上不去或者抖動厲害的話,可能還需要想辦法插值細化或者改用SPI讀取編碼器數(shù)據(jù)(這也是為什么硬件上做了兩種接口的原因,就是想去測試探索一些好玩的東西)。所以我這里是直接去掉了ringbuffer,加入了信號量。到時候上層開一個線程去等待這個信號量去跑FOC算法。頭文件修改如下:


		

1structpwm_inputcapture_data 2{ 3rt_uint32_tpulsewidth_us;//脈寬 4rt_uint32_tpulsecycle_us;//周期 5}; 6structpwm_inputcapture_device 7{ 8structrt_deviceparent; 9conststructpwm_inputcapture_ops*ops; 10rt_sem_t*sem; 11structpwm_inputcapture_datapulse_param; 12}; 13/** 14*captureoperators 15*/ 16structpwm_inputcapture_ops 17{ 18rt_err_t(*init)(structpwm_inputcapture_device*inputcapture); 19rt_err_t(*open)(structpwm_inputcapture_device*inputcapture); 20rt_err_t(*close)(structpwm_inputcapture_device*inputcapture); 21}; 22voidpwm_hw_inputcapture_isr(structpwm_inputcapture_device*inputcapture); 23rt_err_trt_device_pwm_inputcapture_register(structpwm_inputcapture_device*inputcapture, 24constchar*name, 25void*data);

C文件主要修改的是回調(diào)函數(shù),把之前的數(shù)據(jù)加入ringbuffer的操作改成了釋放信號量,其它地方的修改都是一些簡單的適配,由于C代碼較多,我這里就不都貼出來了,相信大家肯定會自己完成適配,甚至比我的還要適配的好。而我的代碼,等我第一期的功能開發(fā)完了,會整體開源出來。C代碼主要修改的回調(diào)函數(shù)如下:


		

1voidrt_hw_pwm_inputcapture_isr(structpwm_inputcapture_device*inputcapture) 2{ 3rt_sem_release(inputcapture->sem); 4if(inputcapture->parent.rx_indicate!=RT_NULL) 5inputcapture->parent.rx_indicate(&inputcapture->parent,1); 6}

適配BSP驅(qū)動


??BSP驅(qū)動的適配稍微麻煩一點,如果大家能找到其它類似BSP內(nèi)的相似驅(qū)動可以進行移植,那我這里簡單找了一下并沒有找到,所以仿照RTT的驅(qū)動適配方式,自己適配了一下。主要實現(xiàn)要點就是開啟每個Timer的CH0和CH1雙通道對CI0或者CI1輸入的PWM信號進行采樣,一個捕獲脈寬,一個捕獲周期,從而得到占空比。剩下的就是一些向下調(diào)用GD32的驅(qū)動庫API,向上適配RTT的驅(qū)動接口。同樣,下面只給出主要的初始化代碼和中斷處理代碼,其它的可自行實現(xiàn)或者關(guān)注我后續(xù)開源的代碼。


		

1rt_err_tpwm_inputcap_init(structpwm_inputcapture_device*pwm_incap) 2{ 3uint32_tsys_clk_freq; 4uint32_ttimer_prescaler=1; 5uint32_ttrigger_ch; 6timer_parameter_structTimerConfig; 7timer_ic_parameter_structTimerICConfig; 8structgd32_pwm_inputcapture_device*pwm_incap_device; 9pwm_incap_device=(structgd32_pwm_inputcapture_device*)pwm_incap; 10rcu_periph_clock_enable(pwm_incap_device->timer_rcu); 11rcu_periph_clock_enable(pwm_incap_device->GPIO_rcu); 12gpio_init(pwm_incap_device->GPIOx,GPIO_MODE_IN_FLOATING,GPIO_OSPEED_50MHZ,pwm_incap_device->PINx); 13sys_clk_freq=rcu_clock_freq_get(CK_SYS); 14LOG_I("systemclockfrequency:%d",sys_clk_freq); 15TimerConfig.alignedmode=TIMER_COUNTER_EDGE; 16TimerConfig.clockdivision=TIMER_CKDIV_DIV1; 17TimerConfig.counterdirection=TIMER_COUNTER_UP; 18TimerConfig.period=65535U; 19do{ 20if(sys_clk_freq/timer_prescaler/TimerConfig.periodinput_freq_min) 21break; 22if(timer_prescaler==65536) 23{ 24rt_kprintf("cannotconfiguretheprescalerforinputsignalfrequency:%dhz ",pwm_incap_device->input_freq_min); 25returnRT_ERROR; 26} 27timer_prescaler++; 28}while(1); 29TimerConfig.prescaler=timer_prescaler-1; 30TimerConfig.repetitioncounter=0; 31timer_init(pwm_incap_device->timerx,&TimerConfig); 32LOG_I("%stimerprescaler:%d",pwm_incap_device->name,timer_prescaler); 33TimerICConfig.icfilter=10; 34TimerICConfig.icpolarity=TIMER_IC_POLARITY_RISING; 35TimerICConfig.icprescaler=TIMER_IC_PSC_DIV1; 36TimerICConfig.icselection=TIMER_IC_SELECTION_DIRECTTI; 37timer_input_pwm_capture_config(pwm_incap_device->timerx,pwm_incap_device->input_ch,&TimerICConfig); 38timer_interrupt_flag_clear(pwm_incap_device->timerx,TIMER_INT_FLAG_UP); 39timer_interrupt_enable(pwm_incap_device->timerx,TIMER_INT_UP); 40trigger_ch=((pwm_incap_device->input_ch==TIMER_CH_0)?TIMER_SMCFG_TRGSEL_CI0FE0:TIMER_SMCFG_TRGSEL_CI1FE1); 41timer_input_trigger_source_select(pwm_incap_device->timerx,trigger_ch); 42timer_slave_mode_select(pwm_incap_device->timerx,TIMER_SLAVE_MODE_RESTART); 43timer_external_trigger_config(pwm_incap_device->timerx,TIMER_EXT_TRI_PSC_OFF,TIMER_ETP_RISING,10); 44NVIC_SetPriority(pwm_incap_device->timerx_irqn,3); 45NVIC_EnableIRQ(pwm_incap_device->timerx_irqn); 46timer_enable(pwm_incap_device->timerx); 47returnRT_EOK; 48} 49voidpwm_inputcapture_update_isr(structgd32_pwm_inputcapture_device*device) 50{ 51uint32_twidth_ch; 52/*TIMUpdateevent*/ 53if(timer_interrupt_flag_get(device->timerx,TIMER_INT_FLAG_UP)!=RESET) 54{ 55timer_interrupt_flag_clear(device->timerx,TIMER_INT_FLAG_UP); 56device->pwm_inputcap.pulse_param.pulsecycle_us=timer_channel_capture_value_register_read(device->timerx,device->input_ch); 57width_ch=((device->input_ch==TIMER_CH_0)?(TIMER_CH_1):(TIMER_CH_0)); 58device->pwm_inputcap.pulse_param.pulsewidth_us=timer_channel_capture_value_register_read(device->timerx,width_ch); 59rt_hw_pwm_inputcapture_isr(device); 60} 61}

修改工程構(gòu)建文件


修改相關(guān)SConscript文件

??在“l(fā)ibraries/gd32_drivers/SConscript”文件內(nèi)的適當(dāng)位置加入如下代碼:


		

1ifGetDepend(['RT_USING_PWM_INPUT_CAPTURE']): 2src+=['drv_pwm_inputcapture.c']

??在“rt-thread/components/drivers/misc/SConscript”文件內(nèi)的適當(dāng)位置加入如下代碼:


		

1ifGetDepend(['RT_USING_INPUT_CAPTURE']): 2src=src+['rt_inputcapture.c']

??意思很簡單,就是當(dāng)rtconfig.h內(nèi)定義了”RT_USING_PWM_INPUT_CAPTURE”宏,則把“drv_pwm_inputcapture.c”和“rt_inputcapture.c”驅(qū)動文件加入工程,更準(zhǔn)確的是加入編譯。

修改相關(guān)Kconfig文件

??在“rt-thread/components/drivers/Kconfig”文件內(nèi)的適當(dāng)位置加入如下代碼:


		

1configRT_USING_INPUT_CAPTURE 2bool"UsingINPUTCAPTUREdevicedrivers" 3defaultn

??管理BSP驅(qū)動代碼的Kconfig文件不再librares目錄下,而是在board目錄下。于是在“board/Kconfig”文件內(nèi)的適當(dāng)位置,仿照其它驅(qū)動加入如下代碼:


		

1menuconfigBSP_USING_PWM_INPUTCAPTURE 2bool"Enablepwminputcapture" 3defaultn 4selectRT_USING_PWM_INPUT_CAPTURE 5ifBSP_USING_PWM_INPUTCAPTURE 6configBSP_USING_PWM_INPUTCAPTURE1 7bool"Enablepwminputcapture1" 8defaultn 9configBSP_USING_PWM_INPUTCAPTURE2 10bool"Enablepwminputcapture2" 11defaultn 12configBSP_USING_PWM_INPUTCAPTURE3 13bool"Enablepwminputcapture3" 14defaultn 15configBSP_USING_PWM_INPUTCAPTURE4 16bool"Enablepwminputcapture4" 17defaultn 18configBSP_USING_PWM_INPUTCAPTURE5 19bool"Enablepwminputcapture5" 20defaultn 21configBSP_USING_PWM_INPUTCAPTURE6 22bool"Enablepwminputcapture6" 23defaultn 24endif

??意思也比較簡單,我這里適配了6個PWM的輸入捕獲驅(qū)動,并且利用“select”語句,在BSP的驅(qū)動管理里面自動開啟了RTT驅(qū)動里面的“RT_USING_PWM_INPUT_CAPTURE”選項。修改完上述代碼后,就可以用menuconfig命令或者RTThreadIDE的RT-Thread Settings圖形配置界面內(nèi)進行配置了:

wKgaomUxb86AcVJtAAC__4hZpLo688.png

測試


??驅(qū)動有了,再在頂層邏輯內(nèi)創(chuàng)建并實現(xiàn)兩個測試線程:


		

1intmain(void) 2{ 3... 4rt_thread_tMotorL_encoder_thread; 5MotorL_encoder_thread=rt_thread_create("MotorLEncoder",MotorLEncoder_thread_entry,RT_NULL,1024,4,20); 6rt_thread_startup(MotorL_encoder_thread); 7rt_thread_tMotorR_encoder_thread; 8MotorR_encoder_thread=rt_thread_create("MotorREncoder",MotorREncoder_thread_entry,RT_NULL,1024,4,20); 9rt_thread_startup(MotorR_encoder_thread); 10... 11} 12voidMotorLEncoder_thread_entry(void*parameter) 13{ 14rt_device_tLpwm_input_dev; 15rt_uint16_twait_i; 16structpwm_inputcapture_device*inputcap_dev; 17Lpwm_input_dev=rt_device_find("pwm_inputcap1"); 18if(Lpwm_input_dev==RT_NULL) 19return; 20inputcap_dev=(structpwm_inputcapture_device*)Lpwm_input_dev; 21rt_device_open(Lpwm_input_dev,RT_DEVICE_OFLAG_RDONLY); 22while(1) 23{ 24if(inputcap_dev->sem!=RT_NULL) 25{ 26rt_sem_take(inputcap_dev->sem,RT_WAITING_FOREVER); 27if(wait_i++>=1000) 28{ 29rt_kprintf("MotorLencoder: %d ",inputcap_dev->pulse_param.pulsewidth_us*10000/inputcap_dev->pulse_param.pulsecycle_us); 30wait_i=0; 31} 32} 33} 34} 35voidMotorREncoder_thread_entry(void*parameter) 36{ 37rt_device_tRpwm_input_dev; 38rt_uint16_twait_i; 39structpwm_inputcapture_device*inputcap_dev; 40Rpwm_input_dev=rt_device_find("pwm_inputcap3"); 41if(Rpwm_input_dev==RT_NULL) 42return; 43inputcap_dev=(structpwm_inputcapture_device*)Rpwm_input_dev; 44rt_device_open(Rpwm_input_dev,RT_DEVICE_OFLAG_RDONLY); 45while(1) 46{ 47if(inputcap_dev->sem!=RT_NULL) 48{ 49rt_sem_take(inputcap_dev->sem,RT_WAITING_FOREVER); 50if(wait_i++>=1000) 51{ 52rt_kprintf("MotorRencoder:%d ",inputcap_dev->pulse_param.pulsewidth_us*10000/inputcap_dev->pulse_param.pulsecycle_us); 53wait_i=0; 54} 55} 56} 57}

??目前只是實現(xiàn)了大概1S鐘打印一次編碼器位置,一圈的機械角度范圍擴大到了0~10000(我用的是12位磁編碼器,分辨率是4096,我這里統(tǒng)一歸一化到了10000),終端輸出如下:

wKgaomUxb86AWvABAADp-6S53R4467.png

??可以看到,慢慢向一個方向推動小車,兩個編碼器的變化規(guī)律是相反的,和實際的兩個電機對向安裝相匹配,實際使用的時候按照其中一個為基準(zhǔn),把另外一個編碼器數(shù)據(jù)反向即可。

??只看其中一個輪子,輸出頻率改為原有的1Khz,輸出值轉(zhuǎn)換為浮點的角度值,可得到如下的測試曲線:

wKgaomUxb8-ASU3AAABtDl44Qdk079.jpg

靜止不動,暫時也沒有驅(qū)動電機,也就沒有電機的電磁干擾,在次條件下測得的靜態(tài)數(shù)據(jù)如下,靜態(tài)穩(wěn)定度在0.2度左右,比12位的最小測量精度0.088度大了二倍多一點:

wKgaomUxb8-ASXSrAACu0yvNQTo492.jpg

相關(guān)鏈接


本系列首篇文章鏈接:

https://club.rt-thread.org/ask/article/5c0c4ba7eb4ab1ad.html

———————End——————

wKgaomUxb9CAVirTAHiX-BnG6Ho919.gif

點擊閱讀原文進入官網(wǎng)

?


原文標(biāo)題:無刷電機小車開發(fā)記錄03——PWM信號輸入捕獲驅(qū)動

文章出處:【微信公眾號:RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • RT-Thread
    +關(guān)注

    關(guān)注

    32

    文章

    1517

    瀏覽量

    44029

原文標(biāo)題:無刷電機小車開發(fā)記錄03——PWM信號輸入捕獲驅(qū)動

文章出處:【微信號:RTThread,微信公眾號:RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    瑞芯微RK3506開發(fā)PWM輸入捕獲驅(qū)動調(diào)試記錄

    本文演示PWM輸入信號采集,基于觸覺智能RK3506開發(fā)板,搭載3核Cortex-A7+Cortex-M0多核異構(gòu)處理器,支持2路CANFD,5路串口,RGB、MIPI、音頻、USB2
    的頭像 發(fā)表于 09-08 13:48 ?854次閱讀
    瑞芯微RK3506<b class='flag-5'>開發(fā)</b>板<b class='flag-5'>PWM</b><b class='flag-5'>輸入</b><b class='flag-5'>捕獲</b><b class='flag-5'>驅(qū)動</b>調(diào)試<b class='flag-5'>記錄</b>

    藏不住了!LD63006 這顆無刷電機驅(qū)動芯片,把 “硬核性能” 焊死在參數(shù)里

    LD63006是一款直流無刷電機驅(qū)動芯片。通過霍爾信號輸入PWM 波進行驅(qū)動控制。支持單、
    的頭像 發(fā)表于 08-28 15:33 ?428次閱讀
    藏不住了!LD63006 這顆<b class='flag-5'>無刷電機</b><b class='flag-5'>驅(qū)動</b>芯片,把 “硬核性能” 焊死在參數(shù)里

    CW32L011電機驅(qū)動開發(fā)板——驅(qū)動無刷電機

    無刷電機
    13532945151
    發(fā)布于 :2025年08月22日 14:35:44

    CW32L011無刷電機驅(qū)動測試

    最近網(wǎng)上看到CW32生態(tài)社區(qū)-李工的生態(tài)圈有100百元的無刷電機驅(qū)動開源硬件及軟件方案,一不小心申請了一塊,這里記錄初次調(diào)試結(jié)果。開源鏈接CW32L011電機
    發(fā)表于 08-16 13:10

    如何捕獲PWM信號?

    開始計時。 每當(dāng)TCPWM0捕獲PWM信號的上升沿時通過觸發(fā)trriger,讓TCPWM1從0開始重新計數(shù)。 當(dāng)PWM信號停止
    發(fā)表于 08-08 06:47

    無刷電機驅(qū)動MOSFET

    講解當(dāng)無葉風(fēng)扇送出柔風(fēng)時,內(nèi)部13萬轉(zhuǎn)無刷電機正被MOSFET精準(zhǔn)驅(qū)動;掃地機鉆進7cm縫隙,7組電機協(xié)同完成毫米級貼邊清掃;電動牙刷以31,000次/分鐘振動清潔齒縫,筋膜槍在50μs內(nèi)響應(yīng)力度調(diào)節(jié),而高空作業(yè)無人機正用高壓水
    的頭像 發(fā)表于 06-09 11:09 ?582次閱讀
    <b class='flag-5'>無刷電機</b>的<b class='flag-5'>驅(qū)動</b>MOSFET

    無刷電機驅(qū)動MOSFET

    當(dāng)無葉風(fēng)扇送出柔風(fēng)時,內(nèi)部13萬轉(zhuǎn)無刷電機正被MOSFET精準(zhǔn)驅(qū)動;掃地機鉆進7cm縫隙,7組電機協(xié)同完成毫米級貼邊清掃;電動牙刷以31,000次/分鐘振動清潔齒縫,筋膜槍在50μs內(nèi)響應(yīng)力度調(diào)節(jié)
    的頭像 發(fā)表于 06-06 16:26 ?619次閱讀
    <b class='flag-5'>無刷電機</b>的<b class='flag-5'>驅(qū)動</b>MOSFET

    使用STM32捕獲PWM時同時捕獲2個通道時會出現(xiàn)捕獲的頻率值不準(zhǔn)確是什么原因?qū)е碌模?/a>

    在使用STM32F103芯片的2個定時器捕獲2路PWM波時,當(dāng)2路信號同時輸入時,會出現(xiàn)捕獲的頻率不準(zhǔn)確,但是分開一路一路的
    發(fā)表于 04-27 08:39

    使用STM32捕獲PWM時同時捕獲2個通道時會出現(xiàn)捕獲的頻率值不準(zhǔn)確的問題,是什么原因?qū)е碌模?/a>

    在使用STM32F103芯片的2個定時器捕獲2路PWM波時,當(dāng)2路信號同時輸入時,會出現(xiàn)捕獲的頻率不準(zhǔn)確,但是分開一路一路的
    發(fā)表于 04-25 08:29

    使用STM32捕獲PWM時同時捕獲2個通道時會出現(xiàn)捕獲的頻率值不準(zhǔn),為什么?

    在使用STM32F103芯片的2個定時器捕獲2路PWM波時,當(dāng)2路信號同時輸入時,會出現(xiàn)捕獲的頻率不準(zhǔn)確,但是分開一路一路的
    發(fā)表于 04-22 10:43

    CW32L010 Motor Control Driver無刷電機驅(qū)動板上手體驗

    CW32L010無刷電機驅(qū)動開發(fā)板上手體驗
    的頭像 發(fā)表于 12-26 09:26 ?1646次閱讀
    CW32L010 Motor Control Driver<b class='flag-5'>無刷電機</b><b class='flag-5'>驅(qū)動</b>板上手體驗

    其利天下技術(shù)·電機慣量是什么意思?無刷電機驅(qū)動開發(fā)

    電機慣量是影響電機穩(wěn)定工作以及能量效率的重要因素。作為無刷電機驅(qū)動方案開發(fā)商,我們聊聊電機慣量的
    的頭像 發(fā)表于 12-23 17:32 ?2864次閱讀
    其利天下技術(shù)·<b class='flag-5'>電機</b>慣量是什么意思?<b class='flag-5'>無刷電機</b><b class='flag-5'>驅(qū)動</b><b class='flag-5'>開發(fā)</b>

    無刷電機正弦波驅(qū)動原理分析

    在上一期芝識課堂里,大家應(yīng)該已經(jīng)學(xué)會如何用方波驅(qū)動無刷電機運轉(zhuǎn),下一步我們來一起嘗試用正弦波驅(qū)動無刷電機,學(xué)習(xí)如何改變電機工作速度的實戰(zhàn)技
    的頭像 發(fā)表于 12-02 10:00 ?2755次閱讀
    <b class='flag-5'>無刷電機</b>正弦波<b class='flag-5'>驅(qū)動</b>原理分析

    其利天下技術(shù)|引起無刷電機抖動的原因及解決辦法·無刷電機驅(qū)動方案

    無刷電機的抖動問題,我相信不少工程師在調(diào)試的過程中都會遇到過。能讓無刷電機在啟動瞬間能夠?qū)崿F(xiàn)平滑啟動,是考驗工程師能力的提升之一。今天我們來探討一下這個話題,無刷電機啟動時出現(xiàn)抖動可能由多種原因?qū)е?/div>
    的頭像 發(fā)表于 11-20 16:08 ?3447次閱讀
    其利天下技術(shù)|引起<b class='flag-5'>無刷電機</b>抖動的原因及解決辦法·<b class='flag-5'>無刷電機</b><b class='flag-5'>驅(qū)動</b>方案

    淺談無刷電機的工作流程

    上一期的芝識課堂,我們跟大家一起分析了無刷電機的四個功能單元,并詳細分析了PWM和逆變器單元的工作情況,今天我們繼續(xù)來熟悉無刷電機工作流程中另外兩個重要的部分——轉(zhuǎn)子位置檢測和波形驅(qū)動
    的頭像 發(fā)表于 11-12 13:46 ?1498次閱讀
    淺談<b class='flag-5'>無刷電機</b>的工作流程