Ardusub源码剖析(1)——AP_Arming_Sub

代码

AP_Arming_Sub.h

#pragma once#include <AP_Arming/AP_Arming.h>class AP_Arming_Sub : public AP_Arming {
public:AP_Arming_Sub() : AP_Arming() { }/* Do not allow copies */CLASS_NO_COPY(AP_Arming_Sub);bool rc_calibration_checks(bool display_failure) override;bool pre_arm_checks(bool display_failure) override;bool has_disarm_function() const;bool disarm(AP_Arming::Method method, bool do_disarm_checks=true) override;bool arm(AP_Arming::Method method, bool do_arming_checks=true) override;protected:bool ins_checks(bool display_failure) override;
};

AP_Arming_Sub.cpp

#include "AP_Arming_Sub.h"
#include "Sub.h"bool AP_Arming_Sub::rc_calibration_checks(bool display_failure)
{const RC_Channel *channels[] = {sub.channel_roll,sub.channel_pitch,sub.channel_throttle,sub.channel_yaw};return rc_checks_copter_sub(display_failure, channels);
}bool AP_Arming_Sub::has_disarm_function() const {bool has_shift_function = false;// make sure the craft has a disarm button assigned before it is armed// check all the standard btn functionsfor (uint8_t i = 0; i < 16; i++) {switch (sub.get_button(i)->function(false)) {case JSButton::k_shift :has_shift_function = true;break;case JSButton::k_arm_toggle :return true;case JSButton::k_disarm :return true;}}// check all the shift functions if there's shift assignedif (has_shift_function) {for (uint8_t i = 0; i < 16; i++) {switch (sub.get_button(i)->function(true)) {case JSButton::k_arm_toggle :case JSButton::k_disarm :return true;}}}return false;
}bool AP_Arming_Sub::pre_arm_checks(bool display_failure)
{if (armed) {return true;}// don't allow arming unless there is a disarm button configuredif (!has_disarm_function()) {check_failed(display_failure, "Must assign a disarm or arm_toggle button");return false;}return AP_Arming::pre_arm_checks(display_failure);
}bool AP_Arming_Sub::ins_checks(bool display_failure)
{// call parent class checksif (!AP_Arming::ins_checks(display_failure)) {return false;}// additional sub-specific checksif (check_enabled(ARMING_CHECK_INS)) {char failure_msg[50] = {};if (!AP::ahrs().pre_arm_check(false, failure_msg, sizeof(failure_msg))) {check_failed(ARMING_CHECK_INS, display_failure, "AHRS: %s", failure_msg);return false;}}return true;
}bool AP_Arming_Sub::arm(AP_Arming::Method method, bool do_arming_checks)
{static bool in_arm_motors = false;// exit immediately if already in this functionif (in_arm_motors) {return false;}in_arm_motors = true;if (!AP_Arming::arm(method, do_arming_checks)) {AP_Notify::events.arming_failed = true;in_arm_motors = false;return false;}#if HAL_LOGGING_ENABLED// let logger know that we're armed (it may open logs e.g.)AP::logger().set_vehicle_armed(true);
#endif// disable cpu failsafe because initialising everything takes a whilesub.mainloop_failsafe_disable();// notify that arming will occur (we do this early to give plenty of warning)AP_Notify::flags.armed = true;// call notify update a few times to ensure the message gets outfor (uint8_t i=0; i<=10; i++) {AP::notify().update();}#if CONFIG_HAL_BOARD == HAL_BOARD_SITLsend_arm_disarm_statustext("Arming motors");
#endifAP_AHRS &ahrs = AP::ahrs();sub.initial_armed_bearing = ahrs.yaw_sensor;if (!ahrs.home_is_set()) {// Reset EKF altitude if home hasn't been set yet (we use EKF altitude as substitute for alt above home)// Always use absolute altitude for ROV// ahrs.resetHeightDatum();// AP::logger().Write_Event(LogEvent::EKF_ALT_RESET);} else if (!ahrs.home_is_locked()) {// Reset home position if it has already been set before (but not locked)if (!sub.set_home_to_current_location(false)) {// ignore this failure}}hal.util->set_soft_armed(true);// enable output to motorssub.enable_motor_output();// finally actually arm the motorssub.motors.armed(true);#if HAL_LOGGING_ENABLED// log flight mode in case it was changed while vehicle was disarmedAP::logger().Write_Mode((uint8_t)sub.control_mode, sub.control_mode_reason);
#endif// reenable failsafesub.mainloop_failsafe_enable();// perf monitor ignores delay due to armingAP::scheduler().perf_info.ignore_this_loop();// flag exiting this functionin_arm_motors = false;// if we do not have an ekf origin then we can't use the WMM tablesif (!sub.ensure_ekf_origin()) {gcs().send_text(MAV_SEVERITY_WARNING, "Compass performance degraded");if (check_enabled(ARMING_CHECK_PARAMETERS)) {check_failed(ARMING_CHECK_PARAMETERS, true, "No world position, check ORIGIN_* parameters");return false;}}// return successreturn true;
}bool AP_Arming_Sub::disarm(const AP_Arming::Method method, bool do_disarm_checks)
{// return immediately if we are already disarmedif (!sub.motors.armed()) {return false;}if (!AP_Arming::disarm(method, do_disarm_checks)) {return false;}#if CONFIG_HAL_BOARD == HAL_BOARD_SITLsend_arm_disarm_statustext("Disarming motors");
#endifauto &ahrs = AP::ahrs();// save compass offsets learned by the EKF if enabledif (ahrs.use_compass() && AP::compass().get_learn_type() == Compass::LEARN_EKF) {for (uint8_t i=0; i<COMPASS_MAX_INSTANCES; i++) {Vector3f magOffsets;if (ahrs.getMagOffsets(i, magOffsets)) {AP::compass().set_and_save_offsets(i, magOffsets);}}}// send disarm command to motorssub.motors.armed(false);// reset the missionsub.mission.reset();#if HAL_LOGGING_ENABLEDAP::logger().set_vehicle_armed(false);
#endifhal.util->set_soft_armed(false);// clear input holdssub.clear_input_hold();return true;
}

解析

头文件

.h代码定义了一个名为 AP_Arming_Sub 的 C++ 类,它继承自 AP_Arming 类。此类提供了一个子类化 AP_Arming 的例子,其中添加了一些基类的方法。以下是详细解释:

#pragma once
  • #pragma once 是一个预处理器指令,用于防止文件被多次包含。当编译器看到这个指令时,它会确保该文件在一个编译过程中只被包含一次,即使它被多次 #include
#include <AP_Arming/AP_Arming.h>
  • 这行代码包含了 AP_Arming 类定义的头文件。AP_Arming 是一个库负责处理无人机启动和关闭相关的逻辑。
class AP_Arming_Sub : public AP_Arming {
  • 这里定义了一个新的类 AP_Arming_Sub,它继承自 AP_Arming 类。public 关键字表示 AP_Arming 是一个公共基类。
public:AP_Arming_Sub() : AP_Arming() { }
  • 这部分定义了一个公共构造函数 AP_Arming_Sub。构造函数使用成员初始化列表语法 : AP_Arming() 来调用基类 AP_Arming 的构造函数。
    /* Do not allow copies */CLASS_NO_COPY(AP_Arming_Sub);
  • 这一行是一个注释,说明了不希望这个类被复制。虽然 CLASS_NO_COPY 宏在这里没有被定义,但它通常用于在类定义中禁用复制构造函数和赋值操作符,以防止类的无意复制。
    bool rc_calibration_checks(bool display_failure) override;bool pre_arm_checks(bool display_failure) override;bool has_disarm_function() const;
  • 这些是 AP_Arming_Sub 类的公共成员函数声明。它们覆盖了基类 AP_Arming 中的虚函数。override 关键字明确表示这些函数是覆盖基类的虚函数。
    • rc_calibration_checks:用于执行遥控器校准检查。
    • pre_arm_checks:用于执行武器启动前的检查。
    • has_disarm_function:用于检查是否解锁。
    bool disarm(AP_Arming::Method method, bool do_disarm_checks=true) override;bool arm(AP_Arming::Method method, bool do_arming_checks=true) override;
  • 这些函数覆盖了基类中的武器解除和武器启动功能,允许子类自定义这些行为。Method 是一个属于 AP_Arming 类的枚举类型,用于指定解除或启动武器的方法。
protected:bool ins_checks(bool display_failure) override;
  • 这部分声明了一个受保护的成员函数 ins_checks,它覆盖了基类中的虚函数。protected 关键字表示这个函数是供派生类和基类内部使用的,但不供外部访问。这个函数用于执行惯性导航系统(INS)检查。

源文件

#include "AP_Arming_Sub.h"
#include "Sub.h"
  • 这两行包含了必要的头文件,以便编译器知道 AP_Arming_Sub 类和 Sub 类(或结构体)的定义。
  • "AP_Arming_Sub.h" 是包含 AP_Arming_Sub 类声明的头文件。
  • "Sub.h" 包含一个名为 Sub 的类或结构体的定义,这个 Sub 类(以下称为“子类”)代表一个特定的无人机子系统的配置。
AP_Arming_Sub::rc_calibration_checks(bool display_failure)
bool AP_Arming_Sub::rc_calibration_checks(bool display_failure)
{
  • 这里定义了 AP_Arming_Sub 类的 rc_calibration_checks 成员函数。此函数接受一个布尔参数 display_failure,它指示是否应该显示校准失败的信息。
    const RC_Channel *channels[] = {sub.channel_roll,sub.channel_pitch,sub.channel_throttle,sub.channel_yaw};
  • 这里定义了一个 RC_Channel 类型的指针数组 channels,它包含指向四个不同通道的指针。这些通道通常代表多旋翼或无人机的遥控器控制通道:
    • channel_roll:横滚通道,控制无人机左右倾斜。
    • channel_pitch:俯仰通道,控制无人机前后倾斜。
    • channel_throttle:油门通道,控制无人机的升力。
    • channel_yaw:偏航通道,控制无人机的旋转方向。
  • sub 是一个 Sub 类型的对象,它包含了这些通道的引用或指针。
    return rc_checks_copter_sub(display_failure, channels);
}
  • 这行代码调用了 rc_checks_copter_sub 函数(这个函数可能在当前文件或其他文件中定义),并将 display_failurechannels 数组作为参数传递。这个函数的目的是执行具体的遥控器校准检查,并返回一个布尔值,指示检查是否通过。
  • 返回值会被传递回调用 rc_calibration_checks 的地方,指示校准检查是否成功。
AP_Arming_Sub::has_disarm_function() const
bool AP_Arming_Sub::has_disarm_function() const {
  • has_disarm_functionAP_Arming_Sub 类的一个 const 成员函数,这意味着它不会修改类的任何成员变量。const 关键字用在成员函数的声明和定义中,以确保函数调用不会改变对象的状态。
    bool has_shift_function = false;
  • 定义一个布尔变量 has_shift_function,用于跟踪是否存在“shift”功能按钮。
    // make sure the craft has a disarm button assigned before it is armed// check all the standard btn functionsfor (uint8_t i = 0; i < 16; i++) {switch (sub.get_button(i)->function(false)) {case JSButton::k_shift :has_shift_function = true;break;case JSButton::k_arm_toggle :return true;case JSButton::k_disarm :return true;}}
  • 这段代码遍历前16个按钮(假设设备有16个按钮),检查每个按钮的标准功能(非“shift”功能)。
  • sub.get_button(i) 获取第 i 个按钮对象的指针。
  • function(false) 调用按钮对象的 function 方法,传递 false 表示不检查“shift”功能。
  • 如果按钮的功能是 JSButton::k_shift,则设置 has_shift_functiontrue
  • 如果按钮的功能是 JSButton::k_arm_toggleJSButton::k_disarm,则直接返回 true,因为这表示存在解除武器功能。
    // check all the shift functions if there's shift assignedif (has_shift_function) {for (uint8_t i = 0; i < 16; i++) {switch (sub.get_button(i)->function(true)) {case JSButton::k_arm_toggle :case JSButton::k_disarm :return true;}}}
  • 如果检测到有 shift 功能按钮,则再次遍历所有按钮,这次检查它们的“shift”功能。
  • function(true)这次传递 true 来检查按钮的“shift”功能。
  • 如果任何一个按钮的“shift”功能是 JSButton::k_arm_toggleJSButton::k_disarm,则返回 true
    return false;
}
  • 如果遍历所有按钮后没有找到解除武器功能,则返回 false
AP_Arming_Sub::pre_arm_checks(bool display_failure)
bool AP_Arming_Sub::pre_arm_checks(bool display_failure)
  • bool: 表示这个函数返回一个布尔类型的值,即truefalse
  • AP_Arming_Sub::: 指定pre_arm_checks函数是AP_Arming_Sub类的成员函数。
  • pre_arm_checks: 函数名,意味着执行预启动检查。
  • (bool display_failure): 函数接收一个名为display_failure的布尔型参数,这个参数用来决定是否显示检查失败的信息。
{if (armed) {return true;}
  • 这段代码检查一个名为armed的变量(一个成员变量,表示系统是否已经启动)。
  • 如果系统已经启动(armedtrue),则函数直接返回true,不需要进行进一步的检查。
    // don't allow arming unless there is a disarm button configuredif (!has_disarm_function()) {check_failed(display_failure, "Must assign a disarm or arm_toggle button");return false;}
  • 这部分代码检查是否存在一个配置好的解锁按钮。
  • !has_disarm_function(): 如果has_disarm_function()函数返回false(表示没有配置解锁按钮),则执行以下代码。
  • check_failed(display_failure, "Must assign a disarm or arm_toggle button"): 调用一个名为check_failed的函数,它用来记录错误信息或显示错误消息。传递的字符串说明了错误的原因。
  • return false;: 如果没有配置解锁按钮,则返回false,表示预检查失败。
    return AP_Arming::pre_arm_checks(display_failure);
}
  • 这行代码调用基类AP_Armingpre_arm_checks函数,继续执行进一步的预启动检查。
  • 如果这个基类的预检查也返回true,则整个pre_arm_checks函数返回true,否则返回false
AP_Arming_Sub::ins_checks(bool display_failure)
bool AP_Arming_Sub::ins_checks(bool display_failure)
  • bool: 表示这个函数返回一个布尔类型的值,即truefalse
  • AP_Arming_Sub::: 指定ins_checks函数是AP_Arming_Sub类的成员函数。
  • ins_checks: 函数名,意味着执行与INS相关的预启动检查。
  • (bool display_failure): 函数接收一个名为display_failure的布尔型参数,用来决定是否显示检查失败的信息。
{// call parent class checksif (!AP_Arming::ins_checks(display_failure)) {return false;}
  • 这段代码调用基类AP_Armingins_checks函数,执行与INS相关的通用预启动检查。
  • 如果基类的检查返回false,表示检查失败,那么这个函数也立即返回false
    // additional sub-specific checksif (check_enabled(ARMING_CHECK_INS)) {
  • 这段代码检查是否启用了特定的检查项ARMING_CHECK_INScheck_enabled根据传入的参数来确定是否执行后续的检查。
        char failure_msg[50] = {};if (!AP::ahrs().pre_arm_check(false, failure_msg, sizeof(failure_msg))) {check_failed(ARMING_CHECK_INS, display_failure, "AHRS: %s", failure_msg);return false;}}
  • char failure_msg[50] = {};: 定义一个字符数组failure_msg,用来存储可能的错误信息,大小为50个字符。
  • AP::ahrs().pre_arm_check(false, failure_msg, sizeof(failure_msg)): 调用AP::ahrs()对象的pre_arm_check方法。AP::ahrs()返回一个AHRS(Attitude and Heading Reference System)类的实例。pre_arm_check方法执行与AHRS相关的检查,如果检查失败,它将错误信息写入failure_msg数组,并返回false
  • 如果pre_arm_check返回false,则执行以下代码:
    • check_failed(ARMING_CHECK_INS, display_failure, "AHRS: %s", failure_msg);: 调用check_failed函数,它用于记录错误信息或显示错误消息。它接收检查项标识符ARMING_CHECK_INS,是否显示失败的标志display_failure,以及格式化的错误信息字符串,其中%s将被failure_msg中的内容替换。
    • return false;: 如果检查失败,则返回false
    return true;
}
  • 如果所有的检查都通过,则函数返回true
AP_Arming_Sub::arm(AP_Arming::Method method, bool do_arming_checks)
bool AP_Arming_Sub::arm(AP_Arming::Method method, bool do_arming_checks)
{static bool in_arm_motors = false;
  • 声明一个静态布尔变量in_arm_motors,用于防止函数重入。
    // exit immediately if already in this functionif (in_arm_motors) {return false;}
  • 如果in_arm_motorstrue,表示函数已经在执行中,为了避免重入,直接返回false
    in_arm_motors = true;
  • 设置in_arm_motorstrue,表示当前正在执行启动过程。
    if (!AP_Arming::arm(method, do_arming_checks)) {AP_Notify::events.arming_failed = true;in_arm_motors = false;return false;}
  • 调用基类AP_Armingarm方法尝试启动。如果返回false,表示启动失败,设置通知事件,重置in_arm_motors,并返回false
#if HAL_LOGGING_ENABLED// let logger know that we're armed (it may open logs e.g.)AP::logger().set_vehicle_armed(true);
#endif
  • 如果启用了日志记录功能,通知日志系统车辆已启动。
    // disable cpu failsafe because initialising everything takes a whilesub.mainloop_failsafe_disable();
  • 禁用主循环故障安全,因为在初始化过程中可能会有较长时间的延迟。
    // notify that arming will occur (we do this early to give plenty of warning)AP_Notify::flags.armed = true;// call notify update a few times to ensure the message gets outfor (uint8_t i=0; i<=10; i++) {AP::notify().update();}
  • 设置通知标志表明车辆将要启动,并通过多次调用更新函数确保通知消息被发送。
#if CONFIG_HAL_BOARD == HAL_BOARD_SITLsend_arm_disarm_statustext("Arming motors");
#endif
  • 如果配置为SITL(软件在环仿真),发送状态文本消息表明正在启动电机。
    AP_AHRS &ahrs = AP::ahrs();
  • 获取AHRS(姿态和航向参考系统)实例的引用。
    sub.initial_armed_bearing = ahrs.yaw_sensor;
  • 设置初始启动时的航向。
    if (!ahrs.home_is_set()) {// Reset EKF altitude if home hasn't been set yet (we use EKF altitude as substitute for alt above home)// Always use absolute altitude for ROV// ahrs.resetHeightDatum();// AP::logger().Write_Event(LogEvent::EKF_ALT_RESET);} else if (!ahrs.home_is_locked()) {// Reset home position if it has already been set before (but not locked)if (!sub.set_home_to_current_location(false)) {// ignore this failure}}
  • 如果家位置未设置,则重置EKF高度;如果家位置未锁定,则重置为当前位置。
    hal.util->set_soft_armed(true);
  • 设置软启动标志,表明系统已启动。
    // enable output to motorssub.enable_motor_output();
  • 启用电机输出。
    // finally actually arm the motorssub.motors.armed(true);
  • 最终启动电机。
#if HAL_LOGGING_ENABLED// log flight mode in case it was changed while vehicle was disarmedAP::logger().Write_Mode((uint8_t)sub.control_mode, sub.control_mode_reason);
#endif
  • 如果启用了日志记录,记录当前的飞行模式。
    // reenable failsafesub.mainloop_failsafe_enable();
  • 重新启用主循环故障安全。
    // perf monitor ignores delay due to armingAP::scheduler().perf_info.ignore_this_loop();
  • 通知性能监视器忽略由于启动导致的延迟。
    // flag exiting this functionin_arm_motors = false;
  • 标记退出此函数,将in_arm_motors重置为false
    // if we do not have an ekf origin then we can't use the WMM tablesif (!sub.ensure_ekf_origin()) {gcs().send_text(MAV_SEVERITY_WARNING, "Compass performance degraded");if (check_enabled(ARMING_CHECK_PARAMETERS)) {check_failed(ARMING_CHECK_PARAMETERS, true, "No world position, check ORIGIN_* parameters");return false;}}
  • 如果EKF原点未设置,则发送警告并检查是否启用了参数检查。如果启用了,则记录失败并返回false
    // return successreturn true;
}
  • 如果所有步骤都成功完成,则返回true
AP_Arming_Sub::disarm(const AP_Arming::Method method, bool do_disarm_checks)
bool AP_Arming_Sub::disarm(const AP_Arming::Method method, bool do_disarm_checks)
{
  • 声明一个返回布尔值的函数disarm,它接收两个参数:解锁方法method和一个布尔值do_disarm_checks,后者指定是否执行解锁前的检查。
    // return immediately if we are already disarmedif (!sub.motors.armed()) {return false;}
  • 如果电机已经处于未启动状态(即已解锁),则立即返回false
    if (!AP_Arming::disarm(method, do_disarm_checks)) {return false;}
  • 调用基类AP_Armingdisarm方法尝试解锁。如果返回false,表示解锁失败,因此直接返回false
#if CONFIG_HAL_BOARD == HAL_BOARD_SITLsend_arm_disarm_statustext("Disarming motors");
#endif
  • 如果配置为SITL(软件在环仿真),发送状态文本消息表明正在解锁电机。
    auto &ahrs = AP::ahrs();
  • 获取AHRS(姿态和航向参考系统)实例的引用。
    // save compass offsets learned by the EKF if enabledif (ahrs.use_compass() && AP::compass().get_learn_type() == Compass::LEARN_EKF) {for (uint8_t i=0; i<COMPASS_MAX_INSTANCES; i++) {Vector3f magOffsets;if (ahrs.getMagOffsets(i, magOffsets)) {AP::compass().set_and_save_offsets(i, magOffsets);}}}
  • 如果启用了指南针,并且EKF学习了指南针偏移量,则保存这些偏移量。
    // send disarm command to motorssub.motors.armed(false);
  • 向电机发送解锁命令,将电机设置为未启动状态。
    // reset the missionsub.mission.reset();
  • 重置任务,可能是指飞行任务或一系列预定的动作。
#if HAL_LOGGING_ENABLEDAP::logger().set_vehicle_armed(false);
#endif
  • 如果启用了日志记录功能,通知日志系统车辆已解锁。
    hal.util->set_soft_armed(false);
  • 更新软启动状态,表明系统已解锁。
    // clear input holdssub.clear_input_hold();
  • 清除输入保持状态,这可能是为了确保在解锁后不会有任何悬挂的输入命令影响系统。
    return true;
}
  • 如果解锁过程成功完成,则返回true

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/62614.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

玻璃效果和窗户室内效果模拟

一、玻璃效果 首先来讲如何模拟玻璃效果。玻璃的渲染包括三部分&#xff0c;普通场景物体的渲染、反射和折射模拟、毛玻璃模拟。作为场景物体&#xff0c;那么类似其它场景物体Shader一样&#xff0c;可以使用PBR、BlingPhong或者Matcap&#xff0c;甚至三阶色卡通渲染都可以。…

某东图标点选验证码

注意&#xff0c;本文只提供学习的思路&#xff0c;严禁违反法律以及破坏信息系统等行为&#xff0c;本文只提供思路 如有侵犯&#xff0c;请联系作者下架 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。…

九、Ubuntu Linux操作系统

一、Ubuntu简介 Ubuntu Linux是由南非人马克沙特尔沃思(Mark Shutteworth)创办的基于Debian Linux的操作系统&#xff0c;于2004年10月公布Ubuntu是一个以桌面应用为主的Linux发行版操作系统Ubuntu拥有庞大的社区力量&#xff0c;用户可以方便地从社区获得帮助其官方网站:http…

fastdds:编译、安装并运行helloworld

fastdds安装可以参考官方文档&#xff1a; 3. Linux installation from sources — Fast DDS 3.1.0 documentation 从INSTALLATION MANUAL这一节可以看出来&#xff0c;fastdds支持的操作系统包括linux、windows、qnx、MAC OS。本文记录通过源码和cmake的方式来安装fastdds的…

mybatis:You have an error in your SQL syntax;

完整报错You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near false, false, false, false, false, false, false, false, false, false, false, at line 1 SQL: INSERT INTO user …

MappingJackson2HttpMessageConverter

MappingJackson2HttpMessageConverter 默认只支持 application/json 格式&#xff0c;&#xff0c;如果服务器返回的是text/plain不能转换 扩展一个可以转换text/plain的转换器&#xff1a; public class RestTemplateMessageConverter extends MappingJackson2HttpMessageCo…

7. 现代卷积神经网络

文章目录 7.1. 深度卷积神经网络&#xff08;AlexNet&#xff09;7.2. 使用块的网络&#xff08;VGG&#xff09;7.3. 网络中的网络&#xff08;NiN&#xff09;7.4. 含并行连结的网络&#xff08;GoogLeNet&#xff09;7.5. 批量规范化7.5.1. 训练深层网络7.5.2. 批量规范化层…

监控视频汇聚平台:Liveweb视频监控管理平台方案详细介绍

Liveweb国标视频综合管理平台是一款以视频为核心的智慧物联应用平台。它基于分布式、负载均衡等流媒体技术进行开发&#xff0c;提供广泛兼容、安全可靠、开放共享的视频综合服务。该平台具备多种功能&#xff0c;包括视频直播、录像、回放、检索、云存储、告警上报、语音对讲、…

常用函数的使用错题汇总

目录 new/delete malloc/free1. 语言和类型2. 内存分配3. 内存释放4. 安全性和类型安全5. 其他特性总结 线程停止文件流 new/delete malloc/free malloc/free 和 new/delete 是 C/C 中用于动态内存管理的两种方式&#xff0c;它们有一些重要的区别。以下是这两种方式的比较&…

Istio笔记01--快速体验Istio

Istio笔记01--快速体验Istio 介绍部署与测试部署k8s安装istio测试istio 注意事项说明 介绍 Istio是当前最热门的服务网格产品&#xff0c;已经被广泛应用于各个云厂商和IT互联网公司。企业可以基于Istio轻松构建服务网格&#xff0c;在接入过程中应用代码无需更改&#xff0c;…

ffmpeg RTP PS推流

要实现 CRtpSendPs 类&#xff0c;使其能够将 H264 数据通过 RTP PS 流推送到指定的 URL&#xff0c;并支持 TCP 和 UDP 传输方式&#xff0c;您需要使用 FFmpeg 库。以下是该类的实现示例&#xff0c;包括必要的初始化、推流和退出函数。 步骤 初始化 FFmpeg 库&#xff1a;…

爬取boss直聘上海市人工智能招聘信息+LDA主题建模

爬取boss直聘上海市人工智能招聘信息 import time import tqdm import random import requests import json import pandas as pd import os from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriv…

入门数据结构JAVADS——如何构建一棵简单二叉排序树

目录 前言 什么是二叉排序树 二叉排序树的特点 二叉排序树示意图 构建二叉排序树 插入元素 搜索元素 删除元素 完整代码 结尾 前言 在整个十一月,笔者因为一些原因停笔了,但马上迈入12月进而进入2025年,笔者决定不再偷懒了,继续更新以促进学习的积极性.闲话说到这,今天…

40分钟学 Go 语言高并发:GC原理与优化

GC原理与优化 一、GC基础知识概览 方面核心概念重要性优化目标GC算法三色标记法、并发GC⭐⭐⭐⭐⭐理解GC工作原理垃圾回收策略触发条件、回收步骤⭐⭐⭐⭐⭐掌握GC过程GC调优参数设置、性能监控⭐⭐⭐⭐优化GC效果内存管理内存分配、内存逃逸⭐⭐⭐⭐⭐减少内存压力 让我们…

梯度爆炸与消失

梯度爆炸和梯度消失 一、概念解析 &#xff08;一&#xff09;梯度爆炸 定义 在深度神经网络训练的反向传播过程中&#xff0c;梯度爆炸是指梯度的值过大的现象。这会使模型的参数更新出现异常。 产生原因 深层网络与链式法则&#xff1a;深度神经网络按链式法则计算某层权重…

linux 文件权限,修改权限,系统调用

参考chmod 777 到底是啥 ???看完这个你就完全懂了&#xff01;-CSDN博客 ls -l 查看当前目录文件的权限 会有一个十位的东西 分别为 d:这是一个文件夹 后面3*3位分别表示所有者用户&#xff0c;同组用户&#xff0c;其他用户的读(r)&#xff0c;写(w)&#xff0c;执行(x)…

notepad++文件github下载

1、github下载网址&#xff1a;Releases notepad-plus-plus/notepad-plus-plus GitHub 2、找到操作系统支持的软件&#xff1a; 3、CSDN下载链接&#xff1a;https://download.csdn.net/download/u013083576/90046203

【Spark源码分析】基于Spark3.4.2源码分析SparkSQL执行过程

基于Spark3.4.2源码分析SparkSQL执行过程 文章目录 基于Spark3.4.2源码分析SparkSQL执行过程基本执行流程Unresolved逻辑计划树相关类RuleExector相关类 详细代码SparkSessionAbstractSqlParserDatasetQueryExecutionAnalyzerRuleExecutorCheckAnalysis 附录CTE简述SQL解析器Qu…

PHP和GD库如何根据像素绘制图形

使用PHP和GD库&#xff0c;你可以根据像素绘制各种图形&#xff0c;比如点、线、矩形、圆形等。GD库是PHP的一个扩展&#xff0c;它提供了一系列用于创建和处理图像的函数。以下是一个简单的示例&#xff0c;展示如何使用GD库根据像素绘制图形。 安装GD库 首先&#xff0c;确…

kafka admin client 如何计算kafka发送速度

文章目录 方法 1&#xff1a;使用 AdminClient 获取消息数量示例代码&#xff1a;计算 Kafka 生产速度代码解释&#xff1a;解释&#xff1a;结果示例&#xff1a;方法 2&#xff1a;使用 Kafka JMX 监控JMX 指标&#xff1a; 总结&#xff1a; 要使用 Kafka Admin Client 来计…