国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

如何構建兩輪自平衡機器人

454398 ? 來源:wv ? 2019-10-18 09:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

步驟1:

1??蚣埽何业目蚣苤皇菍蓚€鋁制伺服支架用螺栓固定到兩個垂直的膠合板上,并與伺服支架固定在一起??蚣艿臉嫵苫蚺渲梅绞綄嶋H上并不重要。您可能應該將其調高一點,然后將電池放在頂部-多少錢總是一個問題,太高了,電動機將沒有足夠的扭矩來使車輪足夠快地旋轉,過低又可能使電動機太慢而無法轉動抓住機器人的傾斜。一塊水平的膠合板底部裝有Arduino Uno和電機控制器。

2。馬達:我使用了兩個無處不在的黃色齒輪馬達和車輪,每個到處都可以找到,價格分別為幾美元。它們的轉速約為110 rpm,足以平衡,但如果轉速約為200或300 rpm,那就太好了。它們的齒輪傾斜度很小,因此機器人總是會有點擺動。在將它們連接到電機控制器之前,您可能應該將兩個電機引線互相纏繞,以防止雜散電磁場干擾Arduino。在電動機引線兩端連接幾個電容器也是一個好主意。我用幾個拉鏈把電動機固定在車架上,效果很好。

3。馬達控制器:我使用了L293D迷你控制器,我非常喜歡它,因為我可以使用一個2s鋰電池為控制器供電,該控制器還可以為Arduino Uno供電-無需第二個電池。輕巧的重量減輕器和輕巧的重量,意味著機器人更容易平衡。

4。 MPU6050陀螺儀/加速度計:這是一個不錯的小模塊,用于測量機器人的傾斜角度。調用函數非常簡單。我將我的機器人安裝在arduino和機器人的傾斜軸上方。有些人說應該更高些,有些人說應該更低些,但是可以找到它在哪里。

5。 Arduino Uno:神經網絡將輕松以2k運行。

6。電源開關:連接電源開關以打開和關閉電池真的很值得。使機器人的使用變得比每次都要插入電池更容易。

7。 LIPO電池:我使用800mah 2s電池為所有電池供電。電池壽命通常約為連續運行20分鐘或更長時間。足夠用于測試和玩耍。

8。原理圖:最后一張照片是我連接所有模塊和電機的示意圖。

步驟2:加載并運行Arduino草圖

1。 MPU6050校準:在實際運行機器人之前,首先需要進行的是陀螺儀/加速度計的校準。下載位于以下位置的校準草圖:http://forum.arduino.cc/index.php?action = dlattach; 。..在執行之前,將您的機器人筆直站立,并在校準程序運行時不要移動它。除非您碰巧將MPU6050移動到機器人上的新位置,否則您只需運行一次校準例程。

運行時,它將向Arduino串行監視器輸出6個值需要三個才能放入草圖。

2。 NeuralNet-SelfBalancingRobot草圖:將以下草圖加載到Arduino Uno。您需要將GYRO/ACC參數更改為校準運行中的參數。然后運行草圖,查看機器人是否平衡。我的機器人會在地毯或床上保持相當不錯的平衡,但會四處運行,然后掉落在光滑的地板上。

我為我的機器人設置了PID代碼,其平衡與Neuro Net略有不同但是使用NN基本上沒有調整,只需加載草圖即可平衡。 PID例程需要大量的操作。

我可以將我的PID控制器上傳到SB機器人,而無需進行任何修改即可比較PID與NN軟件。 NN會在平衡點附近以較小的振蕩獲勝,但會在受到干擾的情況下輸給PID。但是我還沒有真正調整NN。

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

//神經網絡程序,使用S型函數并應用于簡單的自平衡機器人

//由商洛大學Jim Demello創建,2018年5月

//改編自Sean Hodgins神經網絡代碼:https://www.instructables.com/id/Arduino-Neural-Ne。

/修改了midhun_s自平衡機器人代碼:https://www.instructables.com/id/Arduino-Self-Bala.。.

/構建了我自己的自平衡機器人

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

#include“ MPU6050.h”

#包括“ math.h”

/**************************************** **********************************

網絡配置-為每個網絡自定義

************************************************** ****************/

const int PatternCount = 2;

const int InputNodes = 1;

const int Hidd enNodes = 3;

const int OutputNodes = 1;

const float LearningRate = 0.3;

const float Momentum = 0.9;

const float InitialWeightMax = 0.5;

const float Success = 0.0015;

float Input [PatternCount] [InputNodes] = {

{0},//左傾斜

{1}//傾斜

//{-1}//傾斜

//{0,1,1,0} ,//左右左右發光

//{0,1,0,0},//左右左右發光

//{1,1,1,0} ,//頂部,左側和右側的燈光

};

const float Target [PatternCount] [OutputNodes] = {

{0,},////左傾斜

{1,}//右傾斜

//{-1,}//左移動

//{0.65, 0.55},//LEFT MOTOR SLOW

//{0.75,0.5},//LEFT MOTOR FASTER

};

/***** ************************************************** ***********

終端網絡配置

********************** ***************/

int i,j,p,q,r;

int ReportEvery1000;

int RandomizedIndex [PatternC ount];

長時間訓練周期;

浮動Rando;

浮動誤差= 2;

浮動累積;

float Hidden [HiddenNodes];

float Output [OutputNodes];

float HiddenWeights [InputNodes + 1] [HiddenNodes];

float OutputWeights [HiddenNodes + 1] [OutputNodes];

float HiddenDelta [HiddenNodes];

float OutputDelta [OutputNodes];

float ChangeHiddenWeights [InputNodes + 1] [HiddenNodes] ;

float ChangeOutputWeights [HiddenNodes +1] [OutputNodes];

#define leftMotorPWMPin 6

#define leftMotorDirPin 7

#define rightMotorPWMPin 5

#define rightMotorDirPin 4

#define sampleTime 0.005

MPU6050 mpu;

int16_t accY,accZ,gyroX;

int motorPower,gyroRate;

float accAngle,gyroAngle,currentAngle,prevAngle = 0,error,prevError = 0,errorSum = 0;

字節數= 0;

long previousMillis = 0;

unsigned long currentMillis;

long loopTimer = 4;

void setMotors(int leftMotorSpeed,int rightMotorSpeed){

//串行.print(“ leftMotorSpeed =”); Serial.print(leftMotorSpeed); Serial.print(“ rightMotorSpeed =”); Serial.println(rightMotorSpeed);

if(leftMotorSpeed》 = 0){

AnalogWrite(leftMotorPWMPin,leftMotorSpeed);

digitalWrite(leftMotorDirPin,LOW);

}

else {//如果leftMotorSpeed為《0,則將dir設置為反向

AnalogWrite(leftMotorPWMPin, 255 + leftMotorSpeed);

digitalWrite(leftMotorDirPin,HIGH);

}

if(rightMotorSpeed》 = 0){

AnalogWrite (rightMotorPWMPin,rightMotorSpeed);

digitalWrite(rightMotorDirPin,LOW);

}

else {

AnalogWrite(rightMotorPWMPin,255 + rightMotorSpeed);

digitalWrite(rightMotorDirPin,HIGH);

}

}

void setup(){

Serial.begin(115200);

Serial.println(“啟動程序”);

randomSeed(analogRead(A1));//收集一個隨機ADC樣本以進行隨機化。

ReportEvery1000 = 1;

for(p = 0; p

RandomizedIndex [ p] = p;

}

Serial.println(“ do train_nn”);

train_nn();

delay( 1000);

//將電動機控制和PWM引腳設置為輸出模式

pinMode(leftMotorPWMPin,OUTPUT);

pinMode(leftMotorDirPin,OUTPUT);

pinMode(rightMotorPWMPin,OUTPUT);

pinMode(rightMotorDirPin,OUTPUT);

//初始化MPU6050并設置偏移值

mpu.initialize();

mpu.setYAccelOffset(2113);//通過校準例程

mpu.setZAccelOffset(1122);

mpu.setXGyroOffset(7);

Serial.print(“ End在以下位置初始化MPU: “); Serial.println(米利斯());

}

///////////////

/主循環/

/////////////

void loop(){

drive_nn();

}

///////////////////////////////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////////////////

/使用了訓練有素的神經網絡要驅動機器人

void drive_nn()

{

Serial.println(“ Running NN Drive”);

while(Error 《成功){

currentMillis = millis();

float TestInput [] = {0,0};

if(currentMillis-previousMillis》 loopTimer) {//每5毫秒或更長時間進行一次計算

Serial.print(“ currentMillis =”); Serial.println(currentMillis);

/////////////////////////////////////

//計算incli的角度國家//

//////////////////////////////////////////

accY = mpu.getAccelerationY();

accZ = mpu.getAccelerationZ();

gyroX = mpu.getRotationX();

accAngle = atan2(accY,accZ)* RAD_TO_DEG;

gyroRate = map(gyroX,-32768,32767 ,-250,250);

gyroAngle =(float)gyroRate * sampleTime;

///////////////////////////////////////////////////////////////////

//補充過濾器///////////////////////////////////////////

////////////////////////////////////////////////////////////////////

currentAngle = 0.9934 *(prevAngle + gyroAngle)+ 0.0066 *(accAngle);

//Serial.print(“currentAngle=“); Serial.print(currentAngle); Serial.print(“ error =”); Serial.println(error);

//錯誤= currentAngle-targetAngle;//不使用

float nnInput = currentAngle;

//Serial.print(“ nnInput =”); Serial.println(nnInput);

nnInput = map(nnInput,-30,30,0,100);//將傾斜角度范圍映射到0到100

TestInput [0] = float(nnInput)/100;//轉換為0到1

//Serial.print(“ testinput =”); Serial.println(TestInput [0]);

InputToOutput(TestInput [0]) ;//輸入到ANN以獲取輸出

//Serial.print(”output =“); Serial.println(Output [0]);

///////////////////////////////////////////

//在之后設置電動機功率約束它//

///////////////////////////////////////////

motorPower =輸出[0] * 100;//從0轉換為1

//如果(motorPower 《50)motorPower = motorPower * -1;

motorPower = map(motorPower,0,100,-300,300 );

motorPower = motorPower +(motorPower * 6.0);//需要乘數以使車輪在接近平衡點時足夠快地旋轉

//Serial.print(“motorPower =“); Serial.println(motorPower);

motorPower = constrain(motorPower,-255,255);

prevAngle = currentAngle;

previousMillis = currentMillis;

}//結束毫秒循環

//如果(abs(error)》 30)motorPower = 0;//如果跌落則關閉電動機

//motorPower = motorPower + error;

setMotors(motorPower,motorPower);

}

}//drive_nn()函數的結尾

///在培訓時顯示信息

無效到Terminal()

{

for(p = 0; p

Serial.println();

Serial.print(“ Training Pattern:”);

Serial.println(p);

Serial.print(“ Input”);

for(i = 0; i

Serial.print(Input [p] [i],DEC);

Serial.print(“”);

}

Serial.print (“ Target”);

for(i = 0; i

Serial.print(Target [p] [i],DEC);

Serial.print(“”);

}

/********************* **************

計算隱藏層激活

***************************************** *********************************/

for(i = 0; i

Accum = HiddenWeights [InputNodes] [i];

for(j = 0; j

累計+ =輸入[p] [j] * HiddenWeights [j] [i];

}

隱藏[i] = 1.0/(1.0 + exp(-Accum));//激活功能

}

/****************************** ******************************************

計算輸出層激活并計算錯誤

******************************************* ***************************/

用于(i = 0; i

累計= OutputWeights [HiddenNodes] [i];

for(j = 0; j 《隱藏節點; j ++){

累計+ =隱藏[j] * OutputWeights [j] [i];

}

輸出[i] = 1.0/(1.0 + exp(-Accum));

}

Serial.print(“ Output”);

for(i = 0; i

Serial.print(Output [i],5);

Serial.print(“”);

}

}

}

無效InputToOutput(float In1 )

{

float TestInput [] = {0};

TestInput [0] = In1;

//TestInput [ 1] = In2;//未使用

//TestInput [2] = In3;//未使用

//TestInput [3] = In4;//不使用

/****************************************** ****************************

計算隱藏層激活

**** ************************************************** ************/

for(i = 0; i

Accum = HiddenWeights [InputNodes] [i];

for(j = 0; j

累計+ = TestInput [j] * HiddenWeights [j] [i];

}

隱藏[i] = 1.0/(1.0 + exp(-Accum));

}

/********* ************************************************** *******

計算輸出層激活并計算錯誤

********************** ***************/

for(i = 0; i

Accum = OutputWeights [HiddenNodes] [i];

for(j = 0; j

累計+ =隱藏[j] * OutputWeights [j] [i];

}

輸出[i] = 1.0/(1.0 + exp(-Accum));

}

//#ifdef調試

Serial.print(“輸出”);

對于(i = 0 ;我

Serial.print(Output [i],5);

Serial.print(“”);

}

//#endif

}

//訓練神經網絡

void train_nn(){

/*** ************************************************** *************

初始化HiddenWeights和ChangeHiddenWeights

******************* ***************/

int prog_start = 0;

Serial.println(“開始培訓。..”);

//digitalWrite(LEDYEL,LOW);

for(i = 0; i

for(j = 0; j 《= InputNodes; j ++){

ChangeHiddenWeights [j] [i ] = 0.0;

Rando = float(random(100))/100;

HiddenWeights [j] [i] = 2.0 *(Rando-0.5)* InitialWeightMax;

}

}

//digitalWrite(LEDYEL,HIGH);

/************ ************************************************** ****

初始化OutputWeights和ChangeOutputWeights

**************************** ******************************************/

//digitalW rite(LEDRED,LOW);

for(i = 0;我

for(j = 0; j 《= HiddenNodes; j ++){

ChangeOutputWeights [j] [i] = 0.0;

Rando = float(random(100))/100;

OutputWeights [j] [i] = 2.0 *(Rando-0.5)* InitialWeightMax;

}

}

//digitalWrite(LEDRED,HIGH);

//SerialUSB.println(”Initial/Untrained Outputs:“);

//toTerminal();

/****************************************** ****************************

開始訓練

****** ************************************************** **********/

用于(TrainingCycle = 1; TrainingCycle 《2147483647; TrainingCycle ++){

/*********** ************************************************** *****

隨機分配訓練模式的順序

************************** ********************************************/

用于( p = 0; p

q = random(PatternCount);

r = RandomizedIndex [p];

RandomizedIndex [p] = RandomizedIndex [q];

RandomizedIndex [q] = r;

}

錯誤= 0.0;

/*************************************** **************************************

以隨機順序遍歷每種訓練模式

************************************************** ********************/

為(q = 0; q

p = RandomizedIndex [q];

/************************* **********************************************

隱藏計算層激活

********************************************* *****************************/

//digitalWrite(LEDYEL,LOW);

表示(i = 0; i

累計= HiddenWeights [InputNodes] [i];

for(j = 0; j

累計+ =輸入[p] [j] *隱藏重量[j] [i];

}

隱藏[i] = 1.0/(1.0 + exp(-Accum));

}

//digitalWrite(LEDYEL,HIGH);

/*********** ************************************************** *****

計算輸出層激活并計算錯誤

************************ *************/

//digitalWrite(LEDRED,LOW);

for(i = 0; i

Accum = OutputWeights [HiddenNodes] [i];

for(j = 0; j

累計+ =隱藏[j] * OutputWeights [j] [i];

}

Output [i] = 1.0/(1.0 + exp(-Accum));

OutputDelta [i] =(Target [p] [i]-Output [ i])*輸出[i] *(1.0-輸出[i]);

錯誤+ = 0.5 *(目標[p] [i]-輸出[i])*(目標[p] [i]-Output [i]);

}

//Serial.println(Output [0] * 100);

//digitalWrite( LEDRED,HIGH);

/***************************************** *********************************

向后傳播到隱藏層的錯誤

** ************************************************** **************/

//digitalWrite(LEDYEL,LOW);

for(i = 0;我

累計= 0.0;

對于(j = 0; j

累計+ = OutputWeights [i] [j ] * OutputDelta [j];

}

HiddenDelta [i] =累積*隱藏[i] *(1.0-隱藏[i]);

}

//digitalWrite(LEDYEL,HIGH);

/************************* **********************************************

更新內部-》隱藏重量

****************************************** ********************************/

//digitalWrite(LEDRED,LOW);

for(i = 0; i

ChangeHiddenWeights [InputNodes] [i] = LearningRate * HiddenDelta [i] +動量* ChangeHiddenWeights [InputNodes] [i];

HiddenWeights [InputNodes] [i] + = ChangeHiddenWeights [InputNodes] [i];

for(j = 0; j

ChangeHiddenWeights [ j] [i] =學習率*輸入[p] [j] * HiddenDelta [i] +動量* ChangeHiddenWeights [j] [i];

HiddenWeights [j] [i] + = ChangeHiddenWeights [j ] [i];

}

}

//digitalWrite(LEDRED,HIGH);

/************************************************* *********************

隱藏更新-》輸出權重

******** ************************************************** ********/

//digitalWrite(LEDYEL,LOW);

for(i = 0;我

ChangeOutputWeights [HiddenNodes] [i] =學習率* OutputDelta [i] +動量* ChangeOutputWeights [HiddenNodes] [i];

OutputWeights [HiddenNodes] [i] ] + = ChangeOutputWeights [HiddenNodes] [i];

for(j = 0; j

ChangeOutputWeights [j] [i] = LearningRate * Hidden [ j] * OutputDelta [i] +動量* ChangeOutputWeights [j] [i];

OutputWeights [j] [i] + = ChangeOutputWeights [j] [i];

}

}

//digitalWrite(LEDYEL,HIGH);

}

/********** ************************************************** ******

每100個周期將數據發送到終端進行顯示并在OLED上繪制圖形

*************** ************************************************** */

ReportEvery1000 = ReportEvery1000-1;

如果(ReportEvery1000 == 0)

{

int graphNum = TrainingCycle/100 ;

int graphE1 =錯誤* 1000;

int graphE = map(graphE1,3,80,47,0);

Serial.print(“ TrainingCycle:“);

Se rial.print(TrainingCycle);

Serial.print(“ Error =”);

Serial.println(Error,5);

toTerminal() ;

if(TrainingCycle == 1)

{

ReportEvery1000 = 99;

}

否則

{

ReportEvery1000 = 100;

}

}

/******* ************************************************** *********

如果錯誤率小于預定閾值,則結束

*************** ************************************************** */

如果(錯誤《成功)中斷;

}

}

步驟3:最終注釋

1。這些參數可能只需要一點點就可以播放,尤其是可以增加NN輸出值的乘法器。當電動機接近平衡時,必須使用該倍增器來提高電動機的轉速。事實證明,這幾乎迫使機器人成為爆炸式,平衡式機器人。如果在平衡點附近的電動機的值不夠高,則機器人將在電動機具有足夠的rpm來捕捉下降之前倒下。

2。也許可以使用比S形函數更好的激活函數。有人說tanf函數更有用。我認為真正需要的只是一個簡單的f(x)函數。對這個領域的任何人都會真正感興趣。

3。這是一個簡單的單輸入,多個隱藏節點和單個輸出神經網絡,而且肯定會產生過大的殺傷力,因為PID控制器會更簡單,并且您實際上可以使用僅一行代碼的簡單P控制器來達到平衡。但是,我不必像PID控制器那樣對這個NN進行調整,所以這很酷。使用更多的輸入將很有趣,您可以簡單地將陀螺儀的值設置為兩個輸入,而將加速度計設置為三個輸入神經網絡的另一個。然后,您將不需要補充過濾器,因為神經網絡將充當過濾器。不確定如何操作,但嘗試可能很有趣。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 機器人
    +關注

    關注

    213

    文章

    31098

    瀏覽量

    222384
  • Arduino
    +關注

    關注

    190

    文章

    6526

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RK3576機器人核心:三屏異顯+八路攝像頭,重塑機器人交互與感知

    ?!?利用開發板上的MIPI CSI1和CSI2接口,完整接入8路攝像頭,實現了所有通道的視頻預覽與采集,為機器人構建了全方位的視覺感知系統。卓越性能表現:· CPU占用率:34%· DDR占用率:50
    發表于 10-29 16:41

    ASM1042A3S車規級CANFD芯片在兩輪車和平衡車控制器方案中的技術應用

    摘要 本文以國科安芯推出的ASM1042A3S車規級CAN FD芯片為例,討論在兩輪車與平衡車控制器方案中的技術應用。通過對芯片核心技術特點的詳細分析,結合兩輪車和平衡車控制器的實際需
    的頭像 發表于 10-23 17:49 ?709次閱讀

    Arduino Uno l兩輪平衡機器人 電機驅動無輸出求解

    Arduino Uno l兩輪平衡機器人 電機驅動無輸出求解
    發表于 10-15 06:36

    機器人競技幕后:磁傳感器芯片激活 “精準感知力”

    支撐機器人競技能力的核心力量,深刻改變著競技機器人的能力邊界。 磁傳感器芯片為機器人運動提供 “精準導航”。在動態平衡系統中,像昆泰芯 KTH71 系列磁傳感器芯片,通過檢測地磁場與
    發表于 08-26 10:02

    電動兩輪車儀表盤2.0時代來臨,開啟智慧出行新潮流

    電動兩輪車2.0時代2004年電動自行車企業大規模成立以來,兩輪電動車在技術和市場方面都取得了顯著進展。隨著技術的創新和市場需求的增長,兩輪電動車將繼續受到更多消費者的關注和接受,成
    的頭像 發表于 08-07 15:45 ?1111次閱讀
    電動<b class='flag-5'>兩輪</b>車儀表盤2.0時代來臨,開啟智慧出行新潮流

    工業機器人的特點

    的基礎,也是三者的實現終端,智能制造裝備產業包括高檔數控機床、工業機器人、自動化成套生產線、精密儀器儀表、智能傳感器、汽車自動化焊接線、柔性自動化生產線、智能農機、3D 打印機等領域。而智能制造裝備中工業
    發表于 07-26 11:22

    晶華微新歐標兩輪車BMS解決方案

    目前,隨著市場對于輕便兩輪車的需求增加,鋰電池在電動兩輪車動力系統中的普及率也進一步提升。對于電池系統的智能化、自動化控制,以及對電池系統的實時狀態監測顯得越來越重要。
    的頭像 發表于 07-09 11:47 ?1960次閱讀
    晶華微新歐標<b class='flag-5'>兩輪</b>車BMS解決方案

    輪式移動機器人電機驅動系統的研究與開發

    【摘 要】以嵌入式運動控制體系為基礎,以移動機器人為研究對象,結合三結構輪式移動機器人,對二差速驅動轉向自主移動機器人運動學和動力學空間
    發表于 06-11 14:30

    兩輪平衡電動車及其電機控制器設計

    摘要:兩輪平衡電動車的平衡原理源自倒立擺模型,為研制兩輪
    發表于 06-09 16:15

    盤點#機器人開發平臺

    地瓜機器人RDK X5開發套件地瓜機器人RDK X5開發套件產品介紹 旭日5芯片10TOPs算力-電子發燒友網機器人開發套件 Kria KR260機器人開發套件 Kria KR260-
    發表于 05-13 15:02

    詳細介紹機場智能指路機器人的工作原理

    ,配備高性能的電機和傳動裝置,為機器人提供穩定的動力輸出。通過精確的電機控制算法,機器人可以實現前進、后退、轉彎等各種動作,并且能夠根據不同的地面狀況和行走需求,靈活調整行走速度和姿態。 平衡與穩定性
    發表于 05-10 18:26

    【「# ROS 2智能機器人開發實踐」閱讀體驗】視覺實現的基礎算法的應用

    與地圖構建:讓機器人理解環境 第8章聚焦SLAM(同步定位與地圖構建)技術,介紹了SLAM Toolbox和Cartographer大主流框架。我的學習體會如下: SLAM的核心原
    發表于 05-03 19:41

    【「# ROS 2智能機器人開發實踐」閱讀體驗】機器人入門的引路書

    ROS的全稱:Robot Operating System 機器人操作系統 ROS的 目的 :ROS支持通用庫,是通信總線,協調多個傳感器 為了解決機器人里各廠商模塊不通用的問題,讓機器人快速開發
    發表于 04-30 01:05

    杰發科技持續賦能兩輪車智能化升級

    作為兩輪車保有量大國,當下我國兩輪車行業正處在智能化變革前夜。2025慕尼黑上海電子展期間,四維圖新旗下杰發科技現場召開兩輪車智能融合儀表芯片解決方案技術宣講會,希望以多年車規級芯片及系統研發經驗,為
    的頭像 發表于 04-22 15:48 ?1081次閱讀
    杰發科技持續賦能<b class='flag-5'>兩輪</b>車智能化升級

    北京機器人傳感器公司金鋼科技數千萬元Pre-A融資

    ? ? 日前,機器人用磁編碼器領域企業北京金鋼科技有限公司(以下簡稱“金鋼科技”)宣布完成Pre-A融資和Pre-A+融資,兩輪融資總額共計數千萬元,將被用于技術研發和市場推廣。P
    的頭像 發表于 04-18 18:38 ?2087次閱讀
    北京<b class='flag-5'>機器人</b>傳感器公司金鋼科技數千萬元Pre-A<b class='flag-5'>輪</b>融資