STM32F1控制步进电机,实现频率,占空比,脉冲个数控制
控制对象:安川步进电机
控制器: STM32F103C8T6最小系统板
功能:
1、输出PWM波驱动步进电机,PWM可调频、占空比;
2、在输出指定脉冲数目后进入中断,PWM停止输出。
实现方式:
采用主从定时器模式,tim1作为主定时器,tim2作为从定时器(计数器)。
配置引脚:
配置PWM
初始化时基(timebase)

初始化比较结构体

将TIM1定时器配置为主定时器并使能定时器
TIM_SelectInputTrigger( CNT_TIMx, TIM_TS_ITR0);
TIM_SelectSlaveMode( CNT_TIMx, TIM_SlaveMode_External1);
//配置从定时器
TIM_ITConfig( CNT_TIMx, TIM_IT_Update, DISABLE);
//使能定时器中断
#include "stm32f10x.h"
#include "pwm_output.h"
//宏定义
#define veloc_1 1
#define DTime_1 1000 //ms
#define veloc_2 1
#define DTime_2 1000 //ms
#define veloc_3 1
#define DTime_3 1000 //ms
#define veloc_4 1
#define DTime_4 1000 //ms
#define veloc_5 1
#define DTime_5 1000 //ms
#define veloc_6 1
#define DTime_6 1000 //ms
int main(void)
{
SystemInit(); //ÅäÖÃϵͳʱÖÓΪ72M
//划分位六个阶段,可输出不同频率、个数的PWM波
//每个阶段之间的延时时间也可分别设置
//占空比的设定在pwm_output.c文件,所以每个阶段的占空比恒定
//函数的参数分别为频率,脉冲个数以及延时时间
PWM_outset(veloc_1,100,DTime_1);
PWM_outset(veloc_2,100,DTime_2);
PWM_outset(veloc_3,100,DTime_3);
PWM_outset(veloc_4,100,DTime_4);
PWM_outset(veloc_5,100,DTime_5);
PWM_outset(veloc_6,100,DTime_6);
}
#include "pwm_output.h"
#include "misc.h"
//配置PWM_out函数
void TIM1_GPIO_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(PWM_TIM_CLK, ENABLE);
RCC_APB2PeriphClockCmd(PWM_TIM_GPIO_CLK, ENABLE);
GPIO_InitStructure.GPIO_Pin = PWM_TIM_PIN;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(PWM_TIM_GPIO_PORT, &GPIO_InitStructure);
}
void TIM1_Mode_Config(uint16_t TIM1_Prescaler, uint16_t TIM_Period, uint16_t CCR_A)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_OCInitTypeDef TIM_OCInitStructure;
/* Time base configuration */
TIM_TimeBaseStructure.TIM_Period = TIM_Period-1;
TIM_TimeBaseStructure.TIM_Prescaler = TIM1_Prescaler-1;
TIM_TimeBaseStructure.TIM_ClockDivision = 0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseStructure.TIM_RepetitionCounter=0;
TIM_TimeBaseInit(PWM_TIMx, &TIM_TimeBaseStructure);
/* PWM1 Mode configuration: Channel1 */
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_Pulse = CCR_A;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Set;
TIM_OC1Init(PWM_TIMx, &TIM_OCInitStructure);
TIM_SelectMasterSlaveMode( TIM1, TIM_MasterSlaveMode_Enable);
TIM_SelectOutputTrigger( TIM1, TIM_TRGOSource_Update);
TIM_OC1PreloadConfig(PWM_TIMx, TIM_OCPreload_Enable);
TIM_ARRPreloadConfig(PWM_TIMx, ENABLE);
/* TIM1 enable counter */
TIM_Cmd(PWM_TIMx, ENABLE);
TIM_CtrlPWMOutputs(PWM_TIMx, ENABLE);
}
void TIM1_PWM_Init(uint16_t TIM1_Prescaler, uint16_t TIM_Period, uint16_t CCR_A)
{
TIM1_GPIO_Config();
TIM1_Mode_Config(TIM1_Prescaler,TIM_Period,CCR_A);
}
//配置定时器
void TIM3_GPIO_Config(u32 PulseNum_A)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
NVIC_InitTypeDef NVIC_InitStructure;
RCC_APB1PeriphClockCmd( CNT_TIM_CLK, ENABLE);
TIM_TimeBaseStructure.TIM_Period = PulseNum_A;
TIM_TimeBaseStructure.TIM_Prescaler = 1;
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit( CNT_TIMx, &TIM_TimeBaseStructure);
TIM_SelectInputTrigger( CNT_TIMx, TIM_TS_ITR0);
TIM_SelectSlaveMode( CNT_TIMx, TIM_SlaveMode_External1);
TIM_ITConfig( CNT_TIMx, TIM_IT_Update, DISABLE);
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
NVIC_InitStructure.NVIC_IRQChannel = CNT_TIM_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init( &NVIC_InitStructure);
TIM_Cmd( TIM2, ENABLE);
}
//对应主函数
void PWM_outset(uint16_t p_freq ,uint32_t p_nums,int d_time)
{
//通过设定TIM2_PWM_Init后两个参数设置占空比
//第一个参数控制定时器周期
//第二个参数控制脉冲宽度
//两者做比值为占空比
TIM2_PWM_Init(p_freq,50000,25000); //TIM1
TIM_Cmd( TIM1, ENABLE);
TIM_CtrlPWMOutputs( TIM1, ENABLE);
TIM3_GPIO_Config(p_nums);
TIM_ClearITPendingBit( TIM2, TIM_IT_Update);
TIM_ITConfig( TIM2, TIM_IT_Update, ENABLE);
DelayNmS(d_time);
}
}
void TIM2_IRQHandler(void)
{
if (TIM_GetITStatus( TIM2, TIM_IT_Update) != RESET)
{
TIM_CtrlPWMOutputs( TIM1, DISABLE);
TIM_Cmd( TIM1, DISABLE);
TIM_Cmd( TIM2, DISABLE);
TIM_ITConfig( TIM2, TIM_IT_Update, DISABLE);
TIM_ClearITPendingBit( TIM2, TIM_IT_Update);
}
}
#define PWM_TIMx TIM1
#define PWM_TIM_CLK RCC_APB2Periph_TIM1
#define PWM_TIM_GPIO_CLK RCC_APB2Periph_GPIOA
#define PWM_TIM_PIN GPIO_Pin_8
#define PWM_TIM_GPIO_PORT GPIOA
#define CNT_TIMx TIM2
#define CNT_TIM_CLK RCC_APB1Periph_TIM2
#define CNT_TIM_GPIO_CLK RCC_APB2Periph_GPIOA
#define CNT_TIM_PIN GPIO_Pin_6
#define CNT_TIM_GPIO_PORT GPIOA
#define CNT_TIM_AF GPIO_AF_TIM2
#define CNT_TIM_IRQn TIM2_IRQn
#define CNT_TIM_Priority 3
#define CNT_TIM_IRQHandler TIM2_IRQHandler
当我在Rails控制台中按向上或向左箭头时,出现此错误:irb(main):001:0>/Users/me/.rvm/gems/ruby-2.0.0-p247/gems/rb-readline-0.4.2/lib/rbreadline.rb:4269:in`blockin_rl_dispatch_subseq':invalidbytesequenceinUTF-8(ArgumentError)我使用rvm来管理我的ruby安装。我正在使用=>ruby-2.0.0-p247[x86_64]我使用bundle来管理我的gem,并且我有rb-readline(0.4.2)(人们推荐的最少
我正在使用Ruby2.1.1和Rails4.1.0.rc1。当执行railsc时,它被锁定了。使用Ctrl-C停止,我得到以下错误日志:~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`gets':Interruptfrom~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`verify_server_version'from~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.
我将我的Rails应用程序部署到OpenShift,它运行良好,但我无法在生产服务器上运行“Rails控制台”。它给了我这个错误。我该如何解决这个问题?我尝试更新rubygems,但它也给出了权限被拒绝的错误,我也无法做到。railsc错误:Warning:You'reusingRubygems1.8.24withSpring.UpgradetoatleastRubygems2.1.0andrun`gempristine--all`forbetterstartupperformance./opt/rh/ruby193/root/usr/share/rubygems/rubygems
文章目录1.开发板选择*用到的资源2.串口通信(个人理解)3.代码分析(注释比较详细)1.主函数2.串口1配置3.串口2配置以及中断函数4.注意问题5.源码链接1.开发板选择我用的是STM32F103RCT6的板子,不过代码大概在F103系列的板子上都可以运行,我试过在野火103的霸道板上也可以,主要看一下串口对应的引脚一不一样就行了,不一样的就更改一下。*用到的资源keil5软件这里用到了两个串口资源,采集数据一个,串口通信一个,板子对应引脚如下:串口1,TX:PA9,RX:PA10串口2,TX:PA2,RX:PA32.串口通信(个人理解)我就从串口采集传感器数据这个过程说一下我自己的理解,
说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时
在我的Character模型中,我添加了:字符.rbbefore_savedoself.profile_picture_url=asset_path('icon.png')end但是,对于数据库中已存在的所有角色,它们的profile_picture_url为nil。因此,我想进入控制台并遍历所有这些并进行设置。在我试过的控制台中:Character.find_eachdo|c|c.profile_picture_url=asset_path('icon.png')end但这给出了错误:NoMethodError:undefinedmethod`asset_path'formain:O
当我进入Rails控制台时,我已将pry设置为加载代替irb。我找不到该页面或不记得如何将其恢复为默认行为,因为它似乎干扰了我的Rubymine调试器。有什么建议吗? 最佳答案 我刚发现问题,pry-railsgem。忘记了它的目的是让“railsconsole”打开pry。 关于ruby-on-rails-带有Pry的Rails控制台,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/question
我正在尝试将$stdout设置为临时写入一个文件,然后返回到一个文件。test.rb:old_stdout=$stdout$stdout.reopen("mytestfile.out",'w+')puts"thisgoesinmytestfile"$stdout=old_stdoutputs"thisshouldbeontheconsole"$stdout.reopen("mytestfile1.out",'w+')puts"thisgoesinmytestfile1:"$stdout=old_stdoutputs"thisshouldbebackontheconsole"这是输出。r
我在思考流量控制的最佳实践。我应该走哪条路?1)不要检查任何东西并让程序失败(更清晰的代码,自然的错误消息):defself.fetch(feed_id)feed=Feed.find(feed_id)feed.fetchend2)通过返回nil静默失败(但是,“CleanCode”说,你永远不应该返回null):defself.fetch(feed_id)returnunlessfeed_idfeed=Feed.find(feed_id)returnunlessfeedfeed.fetchend3)抛出异常(因为不按id查找feed是异常的):defself.fetch(feed_id
我真的只是不确定这意味着什么或我应该做什么才能让网页在我的本地主机上运行。现在它只是显示一个错误,上面写着“我们很抱歉,但出了点问题。”当我运行railsserver并在chrome中打开localhost:3000时。这是控制台输出:StartedGET"/users/sign_in"for127.0.0.1at2013-07-0512:07:07-0400ProcessingbyDevise::SessionsController#newasHTMLCompleted500InternalServerErrorin55msNoMethodError(undefinedmethod`