久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3596|回復: 7
打印 上一主題 下一主題
收起左側

程序進入if 語句中就出不來了 江湖救急啊

[復制鏈接]
跳轉到指定樓層
樓主
ID:228467 發表于 2017-11-30 20:59 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
我用 mpu6050 模塊讀取當前傾角(用的是野火的例程),當達到某一角度時,電機啟動 延時一段時間,這個控制程序是放在 main 函數 while(1) 的 if 語句中,可是不明白為什么程序進入 if 語句中就出不來了,然后電機就一直在那工作。唉,都快急死了。還請各位大哥大姐都來幫幫我,感激不盡!!!
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:155507 發表于 2017-11-30 21:29 | 只看該作者
你好!沒有原理圖,沒有程序,這怎么分析問題的所在
發一下 程序和原理圖
回復

使用道具 舉報

板凳
ID:228467 發表于 2017-11-30 22:03 | 只看該作者
---------------這是main 函數----------------
#include "stm32f10x.h"
#include "bsp_usart.h" // 包含 串口 頭文件
#include "delay.h" // 包含 延時 頭文件
//#include "bsp_TiMbase.h" // 包含 基本定時器 頭文件
#include "stm32f10x_spi.h"
#include "ioi2c.h" // 包含 I2C 頭文件
#include "MPU6050.h" // 包含 MPU6050 頭文件
#include "control.h" // 包含 控制程序 頭文件
#include "bsp_adc.h" // 包含 adc 頭文件
#include "motor.h"   // 包含 電機 頭文件

float Pitch,Roll,Yaw,fanguanjiao;

//*************************************************************
//* 函數名:DelayTime_ms
//* 描述  :Time           延時的時間 MS
//* 輸入  :無
//* 輸出  :無
//*************************************************************
void delay_1ms(u32 time)  
{  
  u32 i=8000*time;  
  while(i--);  
}

//*************************************************************
//* 函數名:DelayTime_us
//* 描述  :1us延時函數
//* 輸入  :Time           延時的時間 US
//* 輸出  :無       
//*************************************************************
void delay_1us(u32 time)  
{  
  u32 i=8*time;  
  while(i--);  
}


/**
  * @brief  主函數
  * @param  無
  * @retval 無
  */
int main(void)
{       
//                float Pitch,Roll,Yaw;
        USART_Config();       
        ADCx_Init();
        // 配置串口
//  BASIC_TIM_Init();
        delay_init();
        IIC_Init();
        NVIC_Configuration();          //設置NVIC中斷分組2:2位搶占優先級,2位響應優先級
        DMP_Init();
        Motor_12_Config(); //L298電機驅動初始化
        printf("\r\n ----這是一個ADC單通道DMA讀取實驗----\r\n");
       
        while (1)
        {               
                  ADCcaclulate();
                        printf("Read_DMP Return is %d\n",Read_DMP(&Pitch,&Roll,&Yaw));
                  fanguanjiao = Pitch;
//                printf("Pitch is:%f,Roll is:%f,Yaw is:%f\n",Pitch,Roll,Yaw);
                  printf("fanguanjiao is:%f",fanguanjiao);

                  if(fanguanjiao>30)
                        {
                         Motor_1_PRun();
                         delay_1ms(2000);
                         Motor_1_STOP();
                         delay_1ms(1000);
                   Motor_1_NRun();
                         delay_1ms(2000);       
                        }                                                               
//    printf("Read_DMP Return is %d\n",Read_DMP(&Pitch,&Roll,&Yaw));
//                printf("Pitch is:%f,Roll is:%f,Yaw is:%f\n",Pitch,Roll,Yaw);
        }
}

-----------------------這是mpu6050.c-------------
#include "MPU6050.h"
#include "IOI2C.h"
#include "bsp_usart.h"
#include <math.h>
#include "inv_mpu_dmp_motion_driver.h"
#include "inv_mpu.h"
#include "delay.h"
/**************************************************************************/
#define PRINT_ACCEL     (0x01)
#define PRINT_GYRO      (0x02)
#define PRINT_QUAT      (0x04)
#define ACCEL_ON        (0x01)
#define GYRO_ON         (0x02)
#define MOTION          (0)
#define NO_MOTION       (1)
#define DEFAULT_MPU_HZ  (200)
#define FLASH_SIZE      (512)
#define FLASH_MEM_START ((void*)0x1800)
#define q30  1073741824.0f

static signed char gyro_orientation[9] = {-1, 0, 0,
                                           0,-1, 0,
                                           0, 0, 1};

static  unsigned short inv_row_2_scale(const signed char *row)
{
    unsigned short b;

    if (row[0] > 0)
        b = 0;
    else if (row[0] < 0)
        b = 4;
    else if (row[1] > 0)
        b = 1;
    else if (row[1] < 0)
        b = 5;
    else if (row[2] > 0)
        b = 2;
    else if (row[2] < 0)
        b = 6;
    else
        b = 7;      // error
    return b;
}


static  unsigned short inv_orientation_matrix_to_scalar(
    const signed char *mtx)
{
    unsigned short scalar;
    scalar = inv_row_2_scale(mtx);
    scalar |= inv_row_2_scale(mtx + 3) << 3;
    scalar |= inv_row_2_scale(mtx + 6) << 6;


    return scalar;
}

static void run_self_test(void)
{
    int result;
    long gyro[3], accel[3];

    result = mpu_run_self_test(gyro, accel);
    if (result == 0x7) {
        /* Test passed. We can trust the gyro data here, so let's push it down
         * to the DMP.
         */
        float sens;
        unsigned short accel_sens;
        mpu_get_gyro_sens(&sens);
        gyro[0] = (long)(gyro[0] * sens);
        gyro[1] = (long)(gyro[1] * sens);
        gyro[2] = (long)(gyro[2] * sens);
        dmp_set_gyro_bias(gyro);
        mpu_get_accel_sens(&accel_sens);
        accel[0] *= accel_sens;
        accel[1] *= accel_sens;
        accel[2] *= accel_sens;
        dmp_set_accel_bias(accel);
                printf("setting bias succesfully ......\r\n");
    }
}



uint8_t buffer[14];

int16_t  MPU6050_FIFO[6][11];
int16_t Gx_offset=0,Gy_offset=0,Gz_offset=0;


/**************************實現函數********************************************
*函數原型:                void  MPU6050_newValues(int16_t ax,int16_t ay,int16_t az,int16_t gx,int16_t gy,int16_t gz)
*功  能:            將新的ADC數據更新到 FIFO數組,進行濾波處理
*******************************************************************************/

void  MPU6050_newValues(int16_t ax,int16_t ay,int16_t az,int16_t gx,int16_t gy,int16_t gz)
{
unsigned char i ;
int32_t sum=0;
for(i=1;i<10;i++){        //FIFO 操作
MPU6050_FIFO[0][i-1]=MPU6050_FIFO[0][i];
MPU6050_FIFO[1][i-1]=MPU6050_FIFO[1][i];
MPU6050_FIFO[2][i-1]=MPU6050_FIFO[2][i];
MPU6050_FIFO[3][i-1]=MPU6050_FIFO[3][i];
MPU6050_FIFO[4][i-1]=MPU6050_FIFO[4][i];
MPU6050_FIFO[5][i-1]=MPU6050_FIFO[5][i];
}
MPU6050_FIFO[0][9]=ax;//將新的數據放置到 數據的最后面
MPU6050_FIFO[1][9]=ay;
MPU6050_FIFO[2][9]=az;
MPU6050_FIFO[3][9]=gx;
MPU6050_FIFO[4][9]=gy;
MPU6050_FIFO[5][9]=gz;

sum=0;
for(i=0;i<10;i++){        //求當前數組的合,再取平均值
   sum+=MPU6050_FIFO[0][i];
}
MPU6050_FIFO[0][10]=sum/10;

sum=0;
for(i=0;i<10;i++){
   sum+=MPU6050_FIFO[1][i];
}
MPU6050_FIFO[1][10]=sum/10;

sum=0;
for(i=0;i<10;i++){
   sum+=MPU6050_FIFO[2][i];
}
MPU6050_FIFO[2][10]=sum/10;

sum=0;
for(i=0;i<10;i++){
   sum+=MPU6050_FIFO[3][i];
}
MPU6050_FIFO[3][10]=sum/10;

sum=0;
for(i=0;i<10;i++){
   sum+=MPU6050_FIFO[4][i];
}
MPU6050_FIFO[4][10]=sum/10;

sum=0;
for(i=0;i<10;i++){
   sum+=MPU6050_FIFO[5][i];
}
MPU6050_FIFO[5][10]=sum/10;
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_setClockSource(uint8_t source)
*功  能:            設置  MPU6050 的時鐘源
* CLK_SEL | Clock Source
* --------+--------------------------------------
* 0       | Internal oscillator
* 1       | PLL with X Gyro reference
* 2       | PLL with Y Gyro reference
* 3       | PLL with Z Gyro reference
* 4       | PLL with external 32.768kHz reference
* 5       | PLL with external 19.2MHz reference
* 6       | Reserved
* 7       | Stops the clock and keeps the timing generator in reset
*******************************************************************************/
void MPU6050_setClockSource(uint8_t source){
    IICwriteBits(devAddr, MPU6050_RA_PWR_MGMT_1, MPU6050_PWR1_CLKSEL_BIT, MPU6050_PWR1_CLKSEL_LENGTH, source);

}

/** Set full-scale gyroscope range.
* @param range New full-scale gyroscope range value
* @see getFullScaleRange()
* @see MPU6050_GYRO_FS_250
* @see MPU6050_RA_GYRO_CONFIG
* @see MPU6050_GCONFIG_FS_SEL_BIT
* @see MPU6050_GCONFIG_FS_SEL_LENGTH
*/
void MPU6050_setFullScaleGyroRange(uint8_t range) {
    IICwriteBits(devAddr, MPU6050_RA_GYRO_CONFIG, MPU6050_GCONFIG_FS_SEL_BIT, MPU6050_GCONFIG_FS_SEL_LENGTH, range);
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_setFullScaleAccelRange(uint8_t range)
*功  能:            設置  MPU6050 加速度計的最大量程
*******************************************************************************/
void MPU6050_setFullScaleAccelRange(uint8_t range) {
    IICwriteBits(devAddr, MPU6050_RA_ACCEL_CONFIG, MPU6050_ACONFIG_AFS_SEL_BIT, MPU6050_ACONFIG_AFS_SEL_LENGTH, range);
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_setSleepEnabled(uint8_t enabled)
*功  能:            設置  MPU6050 是否進入睡眠模式
                                enabled =1   睡覺
                            enabled =0   工作
*******************************************************************************/
void MPU6050_setSleepEnabled(uint8_t enabled) {
    IICwriteBit(devAddr, MPU6050_RA_PWR_MGMT_1, MPU6050_PWR1_SLEEP_BIT, enabled);
}

/**************************實現函數********************************************
*函數原型:                uint8_t MPU6050_getDeviceID(void)
*功  能:            讀取  MPU6050 WHO_AM_I 標識         將返回 0x68
*******************************************************************************/
uint8_t MPU6050_getDeviceID(void) {

    IICreadBytes(devAddr, MPU6050_RA_WHO_AM_I, 1, buffer);
    return buffer[0];
}

/**************************實現函數********************************************
*函數原型:                uint8_t MPU6050_testConnection(void)
*功  能:            檢測MPU6050 是否已經連接
*******************************************************************************/
uint8_t MPU6050_testConnection(void) {
   if(MPU6050_getDeviceID() == 0x68)  //0b01101000;
   return 1;
           else return 0;
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_setI2CMasterModeEnabled(uint8_t enabled)
*功  能:            設置 MPU6050 是否為AUX I2C線的主機
*******************************************************************************/
void MPU6050_setI2CMasterModeEnabled(uint8_t enabled) {
    IICwriteBit(devAddr, MPU6050_RA_USER_CTRL, MPU6050_USERCTRL_I2C_MST_EN_BIT, enabled);
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_setI2CBypassEnabled(uint8_t enabled)
*功  能:            設置 MPU6050 是否為AUX I2C線的主機
*******************************************************************************/
void MPU6050_setI2CBypassEnabled(uint8_t enabled) {
    IICwriteBit(devAddr, MPU6050_RA_INT_PIN_CFG, MPU6050_INTCFG_I2C_BYPASS_EN_BIT, enabled);
}

/**************************實現函數********************************************
*函數原型:                void MPU6050_initialize(void)
*功  能:            初始化         MPU6050 以進入可用狀態。
*******************************************************************************/
void MPU6050_initialize(void) {
    MPU6050_setClockSource(MPU6050_CLOCK_PLL_XGYRO); //設置時鐘
    MPU6050_setFullScaleGyroRange(MPU6050_GYRO_FS_2000);//陀螺儀最大量程 +-1000度每秒
    MPU6050_setFullScaleAccelRange(MPU6050_ACCEL_FS_2);        //加速度度最大量程 +-2G
    MPU6050_setSleepEnabled(0); //進入工作狀態
         MPU6050_setI2CMasterModeEnabled(0);         //不讓MPU6050 控制AUXI2C
         MPU6050_setI2CBypassEnabled(0);         //主控制器的I2C與        MPU6050的AUXI2C        直通。控制器可以直接訪問HMC5883L
}




/**************************************************************************
函數功能:MPU6050內置DMP的初始化
入口參數:無
返回  值:無
作    者:平衡小車之家
**************************************************************************/
void DMP_Init(void)
{
   u8 temp[1]={0};
   i2cRead(0x68,0x75,1,temp);
         printf("mpu_set_sensor complete ......\r\n");
        if(temp[0]!=0x68)NVIC_SystemReset();
        if(!mpu_init())
  {
          if(!mpu_set_sensors(INV_XYZ_GYRO | INV_XYZ_ACCEL))
                   printf("mpu_set_sensor complete ......\r\n");
          if(!mpu_configure_fifo(INV_XYZ_GYRO | INV_XYZ_ACCEL))
                   printf("mpu_configure_fifo complete ......\r\n");
          if(!mpu_set_sample_rate(DEFAULT_MPU_HZ))
                   printf("mpu_set_sample_rate complete ......\r\n");
          if(!dmp_load_motion_driver_firmware())
                  printf("dmp_load_motion_driver_firmware complete ......\r\n");
          if(!dmp_set_orientation(inv_orientation_matrix_to_scalar(gyro_orientation)))
                   printf("dmp_set_orientation complete ......\r\n");
          if(!dmp_enable_feature(DMP_FEATURE_6X_LP_QUAT | DMP_FEATURE_TAP |
                DMP_FEATURE_ANDROID_ORIENT | DMP_FEATURE_SEND_RAW_ACCEL | DMP_FEATURE_SEND_CAL_GYRO |
                DMP_FEATURE_GYRO_CAL))
                   printf("dmp_enable_feature complete ......\r\n");
          if(!dmp_set_fifo_rate(DEFAULT_MPU_HZ))
                   printf("dmp_set_fifo_rate complete ......\r\n");
          run_self_test();
          if(!mpu_set_dmp_state(1))
                   printf("mpu_set_dmp_state complete ......\r\n");
  }
}
/**************************************************************************
函數功能:讀取MPU6050內置DMP的姿態信息
入口參數:無
返回  值:無
作    者:平衡小車之家
**************************************************************************/
uint8_t Read_DMP(float* Pitch,float* Roll,float* Yaw)
{       
                short gyro[3], accel[3], sensors;
                float q0=1.0f,q1=0.0f,q2=0.0f,q3=0.0f;
          unsigned long sensor_timestamp;
                unsigned char more;
                long quat[4];
                                if(dmp_read_fifo(gyro, accel, quat, &sensor_timestamp, &sensors, &more)) return 1;               
                                if (sensors & INV_WXYZ_QUAT)
                                {   
                                         q0=quat[0] / q30;
                                         q1=quat[1] / q30;
                                         q2=quat[2] / q30;
                                         q3=quat[3] / q30;
                                         *Pitch = (float)asin(-2 * q1 * q3 + 2 * q0* q2)* 57.3;        
                                         *Roll = (float)atan2(2 * q2 * q3 + 2 * q0 * q1, -2 * q1 * q1 - 2 * q2* q2 + 1)* 57.3; // roll
                                         *Yaw = (float)atan2(2*(q1*q2 + q0*q3),q0*q0+q1*q1-q2*q2-q3*q3) * 57.3;
//                                         delay_ms(10);
                                         return 0;
                                }       
                                else return 2;                               
}
/**************************************************************************
函數功能:讀取MPU6050內置溫度傳感器數據
入口參數:無
返回  值:攝氏溫度
作    者:平衡小車之家
**************************************************************************/
int Read_Temperature(void)
{          
          float Temp;
          Temp=(I2C_ReadOneByte(devAddr,MPU6050_RA_TEMP_OUT_H)<<8)+I2C_ReadOneByte(devAddr,MPU6050_RA_TEMP_OUT_L);
                if(Temp>32768) Temp-=65536;
                Temp=(36.53+Temp/340)*10;
          return (int)Temp;
}
//------------------End of File----------------------------
回復

使用道具 舉報

地板
ID:228467 發表于 2017-12-2 10:16 | 只看該作者
沒有人嗎?
回復

使用道具 舉報

5#
ID:232585 發表于 2017-12-2 11:10 | 只看該作者
你先加輸出定位問題的原因在哪  這么多代碼很難幫你分析具體問題的
回復

使用道具 舉報

6#
ID:255508 發表于 2017-12-2 11:15 | 只看該作者
簡單啊!!!分析下:如果 在沒有滿足 fanguanjiao>30的條件下  電機是不會轉動,程序運行之后當滿足  fanguanjiao>30條件之后  電機開始轉動。程序再次循環呢???fanguanjiao>30條件是沒有滿足,可你沒有編寫fanguanjiao>30不滿足關閉電機的程序啊!!!所以電機一直在轉動。解決方案...  
                  if(fanguanjiao>30)
                        {
                         Motor_1_PRun();
                         delay_1ms(2000);
                         Motor_1_STOP();
                         delay_1ms(1000);
                   Motor_1_NRun();
                         delay_1ms(2000);        
                        }
                else
                  {
                    //關閉電機的程序
                   }



你測試下
回復

使用道具 舉報

7#
ID:228467 發表于 2017-12-3 13:07 | 只看該作者
szb0321 發表于 2017-12-2 11:15
簡單啊!!!分析下:如果 在沒有滿足 fanguanjiao>30的條件下  電機是不會轉動,程序運行之后當滿足  fang ...

多謝了,我已經找到原因了,是6050的刷新速度太快了
回復

使用道具 舉報

8#
ID:228467 發表于 2017-12-3 13:08 | 只看該作者
無線電菜蟲 發表于 2017-12-2 11:10
你先加輸出定位問題的原因在哪  這么多代碼很難幫你分析具體問題的

還是謝謝你來評論,我把問題解決了
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 巨大荫蒂视频欧美另类大 | 国产在线观看一区二区三区 | 一级a性色生活片久久毛片 一级特黄a大片 | 日韩一级精品视频在线观看 | 91精品国产91久久久久久不卞 | 亚洲精品久久久蜜桃 | 日本精品视频在线 | 国产成人精品免费 | 99九色| 欧美日韩成人影院 | 国产日韩欧美在线观看 | av片免费观看 | 北条麻妃一区二区三区在线视频 | 一级黄色影片在线观看 | 中文字幕av在线 | 一级欧美日韩 | 播放一级黄色片 | 精品日韩| 亚洲欧美日韩精品久久亚洲区 | 97精品一区二区 | 一区二区三区四区在线视频 | 亚洲成人av | 精精国产xxxx视频在线野外 | 国产精品99999999 | 一级毛片视频在线 | 亚洲国产高清高潮精品美女 | 欧美日韩高清免费 | 99久久99久久精品国产片果冰 | 在线观看中文字幕 | 欧美视频1 | 91精品久久久久久久久99蜜臂 | 日本a∨视频 | 九色综合网 | 欧美午夜一区 | 亚洲免费影院 | 激情一区二区三区 | 日韩精品一区二区三区中文在线 | 99re视频在线观看 | 中文字幕电影在线观看 | 情侣酒店偷拍一区二区在线播放 | 精品无码久久久久久国产 |