Skip to content

aubo_control 日志分析

aubo_control日志存放路径: /root/arcs_ws/log/

1.日志结构分析

以上图为例

  • 日志等级
    TRACE_L3: 表示最详细的日志级别,通常用于调试目的。
    TRACE_L2: 表示次详细的日志级别,通常用于调试目的。
    TRACE_L1: 表示最少的日志级别,通常用于调试目的。
    DEBUG: 表示调试信息级别,用于输出程序运行时的调试信息。
    INFO: 表示信息级别,用于输出程序运行时的一般信息。
    WARNING: 表示警告级别,用于输出程序运行时的警告信息。
    ERROR: 表示错误级别,用于输出程序运行时的错误信息。

  • 日志类别
    rob1: 机器人
    legacy_robot1:硬件抽象层
    RuntimeMachine:运行状态
    aubo_script:脚本
    aubo_comm:rpc服务端
    core:核心
    SimHW:仿真
    rob1::alg:算法层

2.版本号获取

关键字 aubo_control version

如下图所示,0.26.0-alpha.7+9fa6e19 就是版本号

3.安全状态

关键字 SafetyModeType

SafetyModeType.Undefined // 安全状态待定
SafetyModeType.Normal // 正常运行模式
SafetyModeType.ReducedMode // 缩减运行模式
SafetyModeType.Recovery // 启动时如果在安全限制之外, 机器人将进入恢复模式
SafetyModeType.Violation // 超出安全限制(根据安全配置, 例如速度超限等)
SafetyModeType.ProtectiveStop // 软件触发的停机(保持轨迹, 不抱闸, 不断电)
SafetyModeType.SafeguardStop // IO触发的防护停机(不保持轨迹, 抱闸, 不断电)
SafetyModeType.SystemEmergencyStop // 系统急停:急停信号由外部输入(可配置输入), 不对外输出急停信号
SafetyModeType.RobotEmergencyStop // 机器人急停:控制柜急停输入或者示教器急停按键触发, 对外输出急停信号
SafetyModeType.Fault // 机械臂硬件故障或者系统故障

eg.

06/02/23 09:11:34.024340 [20425] INFO      rob1:alarm -  C30039: Safety mode changed: SafetyModeType.Normal
06/02/23 11:25:19.127938 [20425] INFO      rob1:alarm -  C30039: Safety mode changed: SafetyModeType.Undefined

4.机器人状态

关键字 RobotModeType

RobotModeType.Disconnected // 没有连接到机械臂本体(机械臂本体航插线断开)
RobotModeType.ConfirmSafety // 正在进行安全配置, 断电状态下进行
RobotModeType.Booting // 机械臂本体正在上电初始化
RobotModeType.PowerOff // 机械臂本体处于断电状态
RobotModeType.PowerOn // 机械臂本体上电成功, 刹车暂未松开(抱死), 关节初始状态未获取
RobotModeType.Idle // 机械臂上电成功, 刹车暂未松开(抱死), 电机不通电, 关节初始状态获取完成
RobotModeType.BrakeReleasing // 机械臂上电成功, 刹车正在松开
RobotModeType.BackDrive // 反向驱动:刹车松开, 电机不通电
RobotModeType.Running // 机械臂刹车松开, 运行模式, 控制权由硬件移交给软件
RobotModeType.Maintaince // 维护模式: 包括固件升级、参数写入等

eg.

05/31/23 20:40:29.878073 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.PowerOff
05/31/23 20:40:40.092940 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.ConfirmSafety
05/31/23 20:40:40.153198 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.Booting
05/31/23 20:40:41.155260 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.PowerOn
05/31/23 20:40:42.152681 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.Idle
05/31/23 20:40:52.433359 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.BrakeReleasing
05/31/23 20:40:53.433309 [64825] INFO      rob1:alarm -  C30045: Robot mode changed: RobotModeType.Running

5.运行时状态切换

关键字 Runtime machine mode

RuntimeState.Running // 正在运行中
RuntimeState.Retracting // 倒退
RuntimeState.Pausing // 暂停中
RuntimeState.Paused // 暂停状态
RuntimeState.Stepping // 单步执行中
RuntimeState.Stopping // 受控停止中(保持原有轨迹)
RuntimeState.Stopped // 已停止
RuntimeState.Aborting // 停止(最大速度关节运动停机)

eg.

06/01/23 19:29:27.986594 [1387] INFO      RuntimeMachine - Runtime machine mode changed from RuntimeState.Stopped to RuntimeState.Running
06/01/23 19:29:28.151599 [1387] INFO      RuntimeMachine - Runtime machine mode changed from RuntimeState.Running to RuntimeState.Stopping
06/01/23 19:38:00.422546 [1378] INFO      RuntimeMachine - Runtime machine mode changed from RuntimeState.Running to RuntimeState.Pausing
06/01/23 19:38:00.577581 [1378] INFO      RuntimeMachine - Runtime machine mode changed from RuntimeState.Pausing to RuntimeState.Paused
06/01/23 19:38:41.692580 [1378] INFO      RuntimeMachine - Runtime machine mode changed from RuntimeState.Paused to RuntimeState.Stopped

6.ALARM 警报

关键字 rob1:alarm

eg.

06/01/23 19:38:00.412963 [1378] ERROR     rob1:alarm -  C10022: joint3 error: collision
06/02/23 08:54:20.642999 [1378] ERROR     rob1:alarm -  C10021: joint3 error: target speed out of range

7.脚本运行逻辑分析

以下面这个工程为例:

首先会启动脚本线程

install_dir: /root/arcs
01/02/70 22:41:26.964153 [39278] WARNING   RuntimeMachine - runtime_machine.cpp:718 AAAAAAbort...
01/02/70 22:41:26.964172 [39278] INFO      aubo_script - script_executor.h:26 Start script thread...
01/02/70 22:41:26.965349 [39274] TRACE_L1  RuntimeMachine - runtime_machine.cpp:566 Runtime machine mode RuntimeState.Stopped not changed. Event RuntimeEventType.Abort ignored.
01/02/70 22:41:26.965521 [39275] INFO      rob1 - motion_control.cpp:1822 MotionControl abort
01/02/70 22:41:26.965547 [39275] INFO      rob1::alg - trajectory_plan.hpp:1125 tpStop(StopType::EMERGENCY) ignored while PlanStatus is IDLE
01/02/70 22:41:26.965608 [39275] INFO      rob1::alg - aral::updatePlanStartPoint - trajectory_setup.cpp:300 设置规划器下一段路径起始关节角为:  0.463262 -0.156283   1.43775 0.0233074    1.5708  0.463262 关节速度为: 0 0 0 0 0 0 关节加速度为: 0 0 0 0 0 0
01/02/70 22:41:26.965644 [39275] INFO      rob1::alg - aral::initiateRobotModel - trajectory_setup.cpp:94 默认设置的关节最大速度: [2.5964 2.5964 2.5964 3.1105 3.1105 3.1105] 关节最大加速度: [15.7 15.7 15.7 15.7 15.7 15.7] 笛卡尔空间最大速度: [   2 3.14] 笛卡尔空间最大加速度: [ 5 22] 
01/02/70 22:41:26.965862 [39275] INFO      rob1::alg - aral::scaleVelAndAcc - trajectory_speed_adjust.cpp:12 用户设置的速度比例: 1 加速度比例: 1 缓冲点个数: 0
01/02/70 22:41:26.965881 [39275] DEBUG     rob1::alg - trajectory_plan.hpp:174 Init last target 0.463262,-0.156283,1.43775,0.0233074,1.5708,0.463262
01/02/70 22:41:26.966459 [39344] INFO      aubo_script - script_executor.h:46 Run script:

然后发送脚本给控制器

local aubo = require('aubo')
local sched = sched or aubo.sched
local math = aubo.math or math

local sleep = sched.sleep
local thread = sched.thread
local sync = sched.sync
local run = sched.run
local kill = sched.kill
local halt = sched.halt
function p_Untitled_1()
    _ENV = sched.select_robot(1)
    setCollisionStopType(1)
    setCollisionLevel(6)
    setHomePosition({0,-0.2617993877991494,1.74532925199433,0.4363323129985824,1.570796326794897,0}    )
    modbusDeleteAllSignals()
    setDigitalInputActionDefault()
    setDigitalOutputRunstateDefault()
    setStandardDigitalInputAction(5, StandardInputAction.SlowDown1)
    setStandardDigitalInputAction(6, StandardInputAction.SlowDown2)
    setPayload(0, {0,0,0}, {0,0,0}, {0,0,0,0,0,0,0,0,0})
    setTcpOffset({0,0,0,0,0,0})
    setPlanContext(sched.current_thread_id(), 1, "初始变量")
    u57fau5ea7 = {0,0,0,0,0,0}
    u5de5u5177 = {0,0,0,0,0,0}
    u8defu70b9_0_p = {0.5390862712266159,0.133468772007148,0.422298607209269,3.141531022869428,-3.489163597303444e-05,1.570796327999991}    
    u8defu70b9_0_q = {0.463262,-0.156283,1.43775,0.0233074,1.5708,0.463262}    
    u8defu70b9_1_p = {0.5390862712266159,0.1334687720071478,0.2316999396105196,3.141531022869428,-3.489163597303869e-05,1.570796327999991}    
    u8defu70b9_1_q = {0.4632619999999994,-0.2827666499844659,1.81194934240131,0.523990392385776,1.5708,0.4632619999999999}    
    
    
    function str_cat(str1, str2)
        return tostring(str1) .. tostring(str2)
    end
    
    local function calculate_point_to_move_towards(feature, direction, position_distance)
        local posDir={direction[1], direction[2], direction[3]}
        if (math.norm(posDir) < 1e-6) then
            return getTargetTcpPose()
        end
        local direction_vector_normalized=math.normalize(posDir)
        local displacement_pose={direction_vector_normalized[1] * position_distance,direction_vector_normalized[2] * position_distance,direction_vector_normalized[3] * position_distance,0,0,0}

        local wanted_displacement_in_base_frame=poseSub(poseTrans(feature, displacement_pose), feature)
        return poseAdd(getTargetTcpPose(), wanted_displacement_in_base_frame)
    end
    setPlanContext(sched.current_thread_id(), 2, "程序")
    setPlanContext(sched.current_thread_id(), 3, "关节运动")
    setPlanContext(sched.current_thread_id(), 4, "路点_0")
    moveJoint(inverseKinematics(u8defu70b9_0_q, u8defu70b9_0_p), 1.39626, 1.0472, 0, 0)
    
    setPlanContext(sched.current_thread_id(), 5, "路点_1")
    moveJoint(inverseKinematics(u8defu70b9_1_q, u8defu70b9_1_p), 1.39626, 1.0472, 0, 0)
end

local app = {
  PRIORITY = 1000, -- set the app priority, which determines app execution order
  VERSION = "0.1",
  VENDOR = "Aubo Robotics",
}

function app:start(api)
  --
  self.api = api
  print("start---")
  p_Untitled_1()
end

function app:robot_error_handler(name, err)
  --
  print("An error hanppen to robot "..name)
end

-- return our app object
return app

可以查看脚本在工程中的行号

8.崩溃日志

崩溃日志存放路径: /root/arcs_ws/log/.crash/

9.诊断数据

诊断数据存放路径: /root/arcs_ws/log/.trace

control_log_5

数据内容:

  • Event occurred time: 事件出现时间
  • Robot type: 机器人型号
  • Software version: 软件版本
  • Joint firmware version: 关节驱动版本
  • Masterboard firmware version: 接口板版本
  • Tool firmware version: 工具固件版本
  • Pedestal firmware version: 底座固件版本
  • Gravity: 重力(由三个参数表示,分别为重力在x、y、z方向上的分量)
  • dyn_param: 动力学参数
  • torq_constant: 力矩系数
  • Joints max torq: 关节最大力矩
  • Fc、Fs、Ft1、Ft2、Ft3、Fv0、Fv1、Fv2、Fv3、Vs、c1、c2、constant、frac、miu、mode、pre_friction均为摩擦力参数
  • qmix: 关节最小极限值
  • qman: 关节最大极限值
  • Time:时间
  • Id: 轨迹的id
  • SafetyMode:安全状态
    1. UNDEF: Undefined (未定义模式)
    2. NOR: Normal (正常模式)
    3. RED: ReducedMode (缩减模式)
    4. REC: Recovery (恢复模式)
    5. VIO: Violation (违规操作)
    6. PS: ProtectiveStop (保护性停止)
    7. SS: SafeguardStop (安全防护停止)
    8. SES: SystemEmergencyStop (系统紧急停止)
    9. RES: RobotEmergencyStop (机器人紧急停止)
    10. FAULT: Fault(故障)
  • RobotMode:机器人状态
    1. NC: NoController (无控制器)
    2. DC: Disconnected (未连接)
    3. CONF: ConfirmSafety (正在进行安全配置, 断电状态下进行)
    4. BOOT: Booting (机械臂本体正在上电初始化)
    5. POFF: PowerOff (机械臂本体处于断电状态)
    6. PON: PowerOn (机械臂本体上电成功, 刹车暂未松开(抱死), 关节初始状态未获取)
    7. IDLE: Idle (机械臂上电成功, 刹车暂未松开(抱死), 电机不通电, 关节初始状态获取完成)
    8. REL: BrakeReleasing (机械臂上电成功, 刹车正在松开)
    9. BKD: BackDrive (反向驱动:刹车松开, 电机不通电)
    10. RUN: Running (机械臂刹车松开, 运行模式, 控制权由硬件移交给软件)
    11. MT: Maintaince (维护模式: 包括固件升级、参数写入等)
    12. ERR: Error
  • pose1 ~pose6: TCP实际位置(基于基坐标系下的描述)
  • tcp_speed1~tcp_speed6: TCP实际速度
  • elbow_speed1~elbow_speed6: ELBOW 实际速度
  • q1、q2、q3、q4、q5、q6:实际关节角度
  • qd1、qd2、qd3、qd4、qd5、qd6:实际关节速度
  • qdd1、qdd2、qdd3、qdd4、qdd5、qdd6:实际关节加速度
  • current1、current2、current3、current4、current5、current6:关节电流
  • voltage1、voltage2、voltage3、voltage4、voltage5、voltage6:关节电压
  • temperature1、temperature2、temperature3、temperature4、temperature5、temperature6:关节温度
  • torq1~torq6: 关节力矩
  • target_q1、target_q2、target_q3、target_q4、target_q5、target_q6:目标关节角
  • target_qd1、target_qd2、target_qd3、target_qd4、target_qd5、target_qd6:目标速度
  • target_qdd1、target_qdd2、target_qdd3、target_qdd4、target_qdd5、target_qdd6:目标加速度
  • target_curr1~target_curr6: 关节目标电流
  • plan_pose1~plan_pose6: TCP规划位置
  • plan_q1~plan_q6: 规划的关节位置
  • plan_qd1~plan_qd6: 规划的关节速度
  • plan_qdd1~plan_qdd6: 规划的关节加速度
  • plan_curr1~plan_curr6: 拖动算法计算出的指令电流
  • Mass: 负载质量
  • Com_x、Com_y、Com_z: 负载质心
  • inertia1~inertia6: 负载惯量,分别为[Ixx, Iyy, Izz, Ixy, Ixz, Iyz]
  • friction1~friction6: 摩擦力矩
  • forces1~forces6: 力传感器读数
  • freedrive: 是否使能拖动