【人工智能】-- 智能机器人

2a20c54b85e042bfa2440367ae4807e9.gif

https://blog.csdn.net/2302_76516899?spm=1000.2115.3001.5343

个人主页:欢迎来到 Papicatch的博客

 课设专栏 :学生成绩管理系统

专业知识专栏: 专业知识 

文章目录

🍉引言

🍉机器人介绍

🍈机器人硬件

🍍机械结构

🍍传感器

🍍控制系统 

🍍能源系统

🍍通信模块

🍈开发环境

🍍ROS(Robot Operating System)

🍍Python

🍍C++

🍍Arduino

🍍V-REP(Virtual Robot Experimentation Platform)

🍈ROS 基本操作详细介绍

🍍工作空间(Workspace)

🍍创建工作空间

🍍创建 ROS 包(Package)

🍍编译包和工作空间 

🍍运行节点(Node)

🍍查看节点信息

🍍发布(Publish)和订阅(Subscribe)话题(Topic)

🍍查看话题信息

🍍服务(Service)和客户端(Client)

🍍参数(Parameter)

🍈OpenCV 在机器人视觉开发

🍍图像采集与预处理

🍍目标检测与识别

🍍特征提取与匹配

🍍视觉跟踪

🍍深度估计

🍍图像拼接与全景图生成

🍈语言合成开发

🍍原理和方法

🍍开发流程

🍍关键技术和挑战

🍍常用工具和框架

🍍应用领域

🍈SLAM激光雷达建图

🍍激光雷达原理

🍍SLAM 流程

🍍关键技术

🍍建图算法

🍍应用场景

🍉总结


2a20c54b85e042bfa2440367ae4807e9.gif

🍉引言

        在当今科技飞速发展的时代,智能机器人正逐渐成为改变我们生活和工作方式的重要力量。

        智能机器人拥有强大的感知能力,它们能够通过传感器收集周围环境的信息,例如光线、声音、温度等。这使得它们可以迅速对环境变化做出反应。比如在家庭中,扫地机器人能够感知家具的位置,避免碰撞,高效完成清扫任务。

        在工业领域,智能机器人的精度和效率更是令人瞩目。它们可以不知疲倦地进行重复且高精度的操作,大幅提高生产效率和产品质量。例如汽车生产线上的焊接机器人,能够精准地完成复杂的焊接工作,且质量稳定。

        智能机器人还具备出色的学习和适应能力。通过不断接收数据和反馈,它们能够优化自己的行为和决策。例如客服机器人,随着与用户交流次数的增加,能够更准确地理解用户需求并提供更满意的回答。

        然而,智能机器人的发展也带来了一些挑战。比如可能导致部分传统岗位的消失,引发就业结构的调整。但从另一方面看,这也促使人们提升自身技能,去从事更具创造性和复杂的工作。

🍉机器人介绍

🍈机器人硬件

STM32硬件框架图

机器人的硬件系统是其实现各种功能的基础,主要包括以下几个关键部分:

🍍机械结构

  • 机身框架:通常由高强度的金属材料或复合材料制成,为机器人的其他部件提供支撑和安装基础。例如,工业机器人的机身框架需要具备足够的刚性和稳定性,以承受重负载和高精度的操作。
  • 关节和驱动器:用于实现机器人的运动,常见的关节类型有旋转关节和直线关节。驱动器可以是电动、液压或气动的,如电动关节中的伺服电机,能够精确控制关节的运动角度和速度。
  • 末端执行器:根据机器人的应用需求而定,如机械爪用于抓取物体,喷枪用于喷漆等。

🍍传感器

  • 位置和姿态传感器:如编码器、陀螺仪和加速度计等,用于测量机器人关节的位置、速度和姿态信息,以实现精确的运动控制。
  • 视觉传感器:包括摄像头、深度相机等,使机器人能够感知周围环境的图像和物体的形状、颜色等特征。例如,服务机器人可以通过视觉传感器识别用户的面部表情和手势。
  • 力传感器:安装在机器人的关节或末端执行器上,用于检测接触力和力矩,实现力控操作。比如在装配机器人中,力传感器可以确保零件的装配精度和避免过度用力损坏零件。

🍍控制系统 

  • 控制器:通常是一个高性能的微处理器或计算机,负责处理传感器数据、生成控制指令和执行算法。
  • 驱动器控制器:将控制器发出的指令转换为驱动器所需的电信号,实现对电机、液压泵等驱动器的精确控制。

🍍能源系统

  • 电池:为移动机器人或便携式机器人提供电能,如家用扫地机器人使用锂电池。
  • 电源供应:对于固定安装的机器人,通过电源线连接到市电网络获取稳定的电源。

🍍通信模块

  • 有线通信:如以太网、USB 等,用于与外部设备进行高速数据传输和控制指令的交互。
  • 无线通信:如 Wi-Fi、蓝牙等,使机器人能够与其他设备进行灵活的通信,方便远程控制和数据传输。

        以一款常见的工业搬运机器人为例,其机械结构采用坚固的铝合金框架,配备高精度的电动关节和强大的抓取末端执行器。通过安装在关节处的编码器和力传感器,以及机身顶部的视觉摄像头,能够精确感知物体的位置和状态,并在控制器的指挥下完成准确的搬运操作。同时,通过 Wi-Fi 模块与工厂的控制系统进行通信,实现协同工作。

🍈开发环境

🍍ROS(Robot Operating System)

  • 这是一个广泛使用的开源机器人操作系统,提供了丰富的功能包和工具,支持多种编程语言(如 C++、Python)。
  • 具有强大的通信机制,便于不同组件之间的数据交换和协作。
  • 例如,通过 ROS 可以轻松集成激光雷达、摄像头等传感器,并实现机器人的导航、路径规划等功能。
  • 提供了直观的图形化编程界面,适合算法设计和仿真。
  • 有专门的机器人工具箱,可用于机器人运动学、动力学建模和控制算法开发。
  • 比如在设计机器人的轨迹跟踪控制器时,可以在 Simulink 中进行快速建模和仿真验证。

🍍Python

  • 简单易学,拥有丰富的科学计算和机器学习库(如 NumPy、SciPy、TensorFlow 等)。
  • 常用于开发机器人的感知、决策和控制算法。
  • 例如,使用 Python 中的 OpenCV 库处理摄像头采集的图像数据。

🍍C++

  • 执行效率高,适合对性能要求严格的机器人底层驱动和实时控制程序开发。
  • 例如,在编写机器人关节的运动控制代码时,C++ 可以确保实时性和准确性。

🍍Arduino

  • 对于简单的机器人项目和硬件原型开发非常方便。
  • 有大量的开源库和硬件扩展板可供选择。
  • 比如制作一个小型的移动机器人,可以使用 Arduino 控制电机和读取传感器数据。

🍍V-REP(Virtual Robot Experimentation Platform)

  • 一款强大的机器人仿真软件,支持多种机器人模型和传感器的模拟。
  • 可以在虚拟环境中进行机器人的开发和测试,减少实际实验的成本和风险。

🍍Unity

  • 主要用于开发具有良好可视化效果的机器人交互应用和虚拟现实场景。

🍈ROS 基本操作详细介绍

        ROS(Robot Operating System)是一个用于机器人开发的开源框架,以下是一些基本操作的详细介绍:

🍍工作空间(Workspace)

  • 工作空间是开发 ROS 项目的目录结构。
  • 通常包含 src(存放源代码)、build(编译生成的中间文件)和 devel(可执行文件和环境设置脚本)等文件夹。

🍍创建工作空间

  • 在终端中使用以下命令创建工作空间:
    mkdir -p ~/catkin_ws/srccd ~/catkin_wscatkin_make

🍍创建 ROS 包(Package)

  • 在工作空间的 src 目录下,使用以下命令创建包:
    cd ~/catkin_ws/srccatkin_create_pkg <package_name> <dependencies>
  • 例如:catkin_create_pkg my_package roscpp rospy std_msgs

🍍编译包和工作空间 

  • 在工作空间的根目录下执行 catkin_make 命令进行编译。

🍍运行节点(Node)

  • 节点是 ROS 中的基本执行单元。
  • 例如,运行一个名为 my_node 的节点:
    rosrun <package_name> <node_name>

🍍查看节点信息

  • 使用 rosnode list 命令查看当前运行的节点列表。
  • rosnode info <node_name> 查看指定节点的详细信息。

🍍发布(Publish)和订阅(Subscribe)话题(Topic)

  • 节点通过发布和订阅话题进行通信。
  • 发布数据:
    import rospyfrom std_msgs.msg import Stringdef publisher():rospy.init_node('publisher_node', anonymous=True)pub = rospy.Publisher('my_topic', String, queue_size=10)rate = rospy.Rate(10)  # 10Hzwhile not rospy.is_shutdown():message = "Hello, ROS!"pub.publish(message)rate.sleep()if __name__ == '__main__':try:publisher()except rospy.ROSInterruptException:pass
  • 订阅数据:
    import rospyfrom std_msgs.msg import Stringdef callback(data):rospy.loginfo(rospy.get_caller_id() + "I heard %s", data.data)def subscriber():rospy.init_node('subscriber_node', anonymous=True)rospy.Subscriber("my_topic", String, callback)rospy.spin()if __name__ == '__main__':subscriber()

🍍查看话题信息

  • rostopic list 查看当前活跃的话题列表。
  • rostopic info <topic_name> 查看指定话题的详细信息。
  • rostopic echo <topic_name> 打印话题上发布的数据。

🍍服务(Service)和客户端(Client)

  • 服务用于节点之间的请求-响应通信。
  • 定义服务:
    from my_package.srv import AddTwoInts, AddTwoIntsResponsedef add_two_ints(req):return AddTwoIntsResponse(req.a + req.b)
  • 服务端代码:
    import rospyfrom my_package.srv import AddTwoIntsrospy.init_node('add_two_ints_server')s = rospy.Service('add_two_ints', AddTwoInts, add_two_ints)rospy.spin()
  • 客户端代码:
    import rospyfrom my_package.srv import AddTwoIntsdef call_add_two_ints():rospy.wait_for_service('add_two_ints')try:add_two_ints = rospy.ServiceProxy('add_two_ints', AddTwoInts)resp1 = add_two_ints(1, 2)return resp1.sumexcept rospy.ServiceException as e:print("Service call failed: %s" % e)if __name__ == "__main__":print("Result: %s" % call_add_two_ints())

🍍参数(Parameter)

  • 节点可以使用参数来配置。
  • 设置参数:rosparam set <parameter_name> <value>
  • 获取参数:rosparam get <parameter_name>

🍈OpenCV 在机器人视觉开发

        OpenCV(Open Source Computer Vision Library)是一个广泛应用于计算机视觉领域的开源库,在机器人视觉开发中发挥着重要作用。

🍍图像采集与预处理

  • 机器人可以通过摄像头采集图像。使用 OpenCV 可以对采集到的图像进行去噪、灰度化、二值化等预处理操作,以提高后续图像处理的效率和准确性。
  • 例如,通过高斯滤波去除图像中的噪声,增强图像的质量。

🍍目标检测与识别

  • 利用 OpenCV 的各种算法和函数,实现对特定目标的检测和识别。
  • 如使用 Haar 特征和级联分类器进行人脸检测,或者基于形状、颜色等特征识别特定的物体。

🍍特征提取与匹配

  • 提取图像中的特征点,如 SIFT(Scale-Invariant Feature Transform)、SURF(Speeded Up Robust Features)等,并进行特征匹配,用于机器人的定位、地图构建等任务。
  • 例如,在机器人同时定位与地图构建(SLAM)中,通过特征匹配来确定机器人在环境中的位置。

🍍视觉跟踪

  • 实现对运动目标的跟踪。
  • 可以使用基于颜色、形状或特征的跟踪算法,让机器人能够持续跟踪感兴趣的目标。

🍍深度估计

  • 结合立体视觉或结构光等技术,使用 OpenCV 估计场景的深度信息,帮助机器人理解环境的三维结构。

🍍图像拼接与全景图生成

  • 当机器人需要获取更广阔的视野时,可以将多个图像拼接成全景图。

以下是一个简单的示例,展示如何使用 OpenCV 进行图像中的圆形物体检测:

import cv2
import numpy as npdef detect_circles(image_path):# 读取图像image = cv2.imread(image_path)# 转换为灰度图像gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 进行高斯模糊blurred = cv2.GaussianBlur(gray, (9, 9), 2)# 霍夫圆检测circles = cv2.HoughCircles(blurred, cv2.HOUGH_GRADIENT, 1, 20,param1=50, param2=30, minRadius=0, maxRadius=0)if circles is not None:circles = np.uint16(np.around(circles))for i in circles[0, :]:# 绘制圆形cv2.circle(image, (i[0], i[1]), i[2], (0, 255, 0), 2)cv2.circle(image, (i[0], i[1]), 2, (0, 0, 255), 3)cv2.imshow('Circles Detected', image)cv2.waitKey(0)cv2.destroyAllWindows()detect_circles('image.jpg')

        在实际的机器人视觉开发中,通常会结合机器人的运动控制、传感器数据融合等方面,充分发挥 OpenCV 的图像处理能力,为机器人提供准确的环境感知和决策依据。

🍈语言合成开发

        语言合成,也称为文本到语音(Text-to-Speech,TTS)转换,是将输入的文本转换为可听的语音输出的技术。以下是对语言合成开发的详细介绍:

🍍原理和方法

  • 基于规则的方法:使用预定义的语音规则和模式将文本转换为语音。但这种方法灵活性较差,语音质量有限。
  • 拼接合成:将预先录制的语音片段拼接起来生成语音。语音的自然度相对较高,但需要大量的录音数据和复杂的拼接算法。
  • 参数合成:通过对语音参数(如基频、时长、幅度等)进行建模来生成语音。具有较高的灵活性,但可能在自然度上稍逊一筹。
  • 深度学习方法:特别是基于神经网络的模型,如循环神经网络(RNN)、长短时记忆网络(LSTM)和 Transformer 架构,已经成为当前语言合成的主流方法。这些模型能够学习从文本到语音特征的复杂映射,生成更加自然和流畅的语音。

🍍开发流程

  • 数据收集:收集大量的文本和对应的语音数据,用于模型的训练。
  • 文本预处理:对输入的文本进行清洗、分词、词性标注等处理,以便模型更好地理解。
  • 特征提取:从语音数据中提取声学特征,如梅尔频率倒谱系数(MFCC)等。
  • 模型训练:使用选择的方法和架构训练模型,优化模型的参数以最小化预测语音与真实语音之间的差异。
  • 模型评估:使用各种指标,如主观听觉测试(MOS)、客观指标(如相似度、失真度等)来评估模型的性能。
  • 优化和调整:根据评估结果对模型进行优化,调整超参数、增加数据、改进模型结构等。
  • 部署和集成:将训练好的模型部署到实际应用中,与其他系统进行集成,如语音助手、有声读物生成等。

🍍关键技术和挑战

  • 韵律和情感表达:使合成的语音具有正确的语调、重音和情感色彩,以提高自然度和表现力。
  • 多语言支持:能够处理多种语言的文本,并生成相应语言的自然语音。
  • 个性化:根据特定的说话人特征生成个性化的语音。
  • 实时性:在一些应用场景中,如实时交互系统,需要快速生成语音。
  • 模型压缩和优化:以便在资源受限的设备上运行。

🍍常用工具和框架

  • TensorFlow:广泛使用的深度学习框架,可用于构建和训练语言合成模型。
  • PyTorch:另一个流行的深度学习框架,提供了灵活的开发环境。
  • Mozilla TTS:一个基于 Python 的开源 TTS 工具包。
  • Microsoft Azure Cognitive Services - Speech:提供了强大的语音合成服务,可通过 API 调用。

🍍应用领域

  • 智能语音助手:如手机中的语音助手、智能音箱等。
  • 有声读物和电子书籍:将文字内容转换为语音,方便阅读。
  • 导航系统和语音提示:为驾驶、出行等提供语音导航。
  • 辅助教学和学习:为教育软件生成语音讲解。
  • 客服机器人:通过语音回答用户的问题。

        例如,使用 TensorFlow 开发一个基于 Transformer 的语言合成模型,首先需要定义模型的架构,包括编码器和解码器部分,然后使用准备好的数据集进行训练。在训练过程中,通过不断调整学习率、层数等参数来优化模型性能。训练完成后,可以将模型部署到服务器上,通过网络接口接收文本输入,并返回合成的语音数据。

🍈SLAM激光雷达建图

        SLAM(Simultaneous Localization and Mapping,即时定位与地图构建)技术结合激光雷达在机器人和自动驾驶等领域中具有重要应用,以下是对 SLAM 激光雷达建图的详细分析:

🍍激光雷达原理

        激光雷达通过发射激光束并测量反射光的时间和强度来获取周围环境的距离信息。它能够快速、精确地扫描周围物体,提供大量的点云数据。

🍍SLAM 流程

  • 传感器数据采集:激光雷达不断扫描环境,获取点云数据。
  • 前端处理:
    • 特征提取:从点云中提取有代表性的特征,如直线、平面等。
    • 数据关联:将当前帧的特征与之前的帧进行匹配和关联。
  • 位姿估计:根据数据关联结果,估计机器人的位姿(位置和姿态)。
  • 后端优化:
    • 构建优化问题:将位姿估计的误差作为优化目标。
    • 求解优化:使用非线性优化算法(如高斯牛顿法、列文伯格-马夸尔特法等)来优化位姿和地图。
  • 地图构建:
    • 点云融合:将不同时刻获取的点云整合到一个统一的地图中。
    • 地图表示:可以采用栅格地图、八叉树地图等形式来表示环境。

🍍关键技术

  • 特征提取与匹配:高效准确地提取和匹配特征对于数据关联和位姿估计至关重要。
  • 回环检测:检测机器人是否回到之前访问过的位置,以消除累积误差。
  • 鲁棒性:应对环境中的动态物体、噪声和传感器误差等干扰。
  • 实时性:在保证精度的前提下,能够快速处理数据并实时更新地图。

🍍建图算法

  • GMapping:基于粒子滤波的算法,适用于较小规模的环境。
  • Cartographer:使用图优化的方法,能够构建高质量的二维地图。
  • LOAM(LiDAR Odometry and Mapping):针对激光雷达数据特点设计的算法,在速度和精度上有较好的平衡。

🍍应用场景

  • 室内机器人导航:如仓储机器人、清洁机器人等。
  • 自动驾驶:为车辆提供环境感知和定位信息。
  • 虚拟现实和增强现实:构建虚拟环境的地图。

        例如,在一个仓储环境中,使用安装有激光雷达的移动机器人进行 SLAM 建图。激光雷达扫描到的点云数据经过前端处理提取特征,通过位姿估计确定机器人的位置,后端优化消除累积误差,最终构建出仓库的二维栅格地图。机器人可以根据这个地图进行自主导航和货物搬运。

🍉总结

        智能机器人作为现代科技的杰出成果,正以前所未有的速度改变着我们的生活和工作方式。

        智能机器人融合了众多先进技术,如人工智能、机器学习、传感器技术、计算机视觉和自然语言处理等。它们具备强大的感知能力,能够精准地获取和理解周围环境的信息,通过复杂的算法和模型进行分析和决策。

        在工业领域,智能机器人不知疲倦地执行着高精度、高重复性的任务,大幅提升了生产效率和产品质量,降低了生产成本和人为错误。从汽车制造到电子产品组装,它们的身影无处不在。

        在服务行业,智能机器人为人们提供了便捷和高效的服务。例如,在医疗领域,它们可以协助医生进行手术、照顾患者;在物流行业,它们能够实现货物的分拣和搬运;在家庭中,它们可以承担清洁、安防等任务。

        智能机器人还在不断拓展其应用领域,如教育、科研、娱乐等。它们可以作为个性化的学习伙伴,激发学生的学习兴趣;在科研中,协助科学家进行复杂的实验和数据采集;在娱乐方面,为人们带来全新的互动体验。

        然而,智能机器人的发展也带来了一些挑战。例如,可能导致部分传统岗位的消失,引发就业结构的调整;在安全和伦理方面,也需要制定相关的法规和准则,以确保其合理、安全地应用。

        尽管存在挑战,但智能机器人的发展前景依然广阔。随着技术的不断进步,它们将变得更加智能、灵活和人性化,为人类创造更多的价值,成为推动社会进步和发展的重要力量。

2a20c54b85e042bfa2440367ae4807e9.gif

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

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

相关文章

One day for Chinese families

周围生活中的普通家庭的一天流程&#xff1a; 【上班的一天】 【放假的一天】 有家庭的人&#xff0c;上班流程&#xff1a; 01&#xff09;准备早餐&#xff0c;牛奶&#xff0c;面包 02&#xff09;叫娃娃起床&#xff0c;一般要蛮久的&#xff1b;沟通交流 -- 哄娃娃 -- 生气…

【TB作品】基于ATmega48的开机登录程序设计

使用Proteus仿真软件设计一个开机登录程序,单片机选用ATmegga48. 基础要求: 1.程序启动后在LCD1602液晶屏上提示用户通过独立按键输入密码(6位)。 2.密码输入错误则在屏幕上提示密码错误,密码输入正确则在屏幕上提示密 码正确后等待约3秒后进入主界面,在屏幕中央显示HelloWorld…

windows下编译ffmpeg 最详细教程

1 Ffmpeg下载地址&#xff1a;FFmpeg 使用命令下载 git clone https://git.ffmpeg.org/ffmpeg.git ffmpeg 下载完成后会发现如下目录&#xff1a; 2 msys2下载地址&#xff1a;MSYS2 解压好后&#xff0c;选择一个非空路径安装&#xff0c;安装好后路径如下&#xff1a; 为…

自己动手实现语音识别

声音的本质是震动,震动的本质是位移关于时间的函数,波形文件(.wav)中记录了不同采样时刻的位移。 通过傅里叶变换,可以将时间域的声音函数分解为一系列不同频率的正弦函数的叠加,通过频率谱线的特殊分布,建立音频内容和文本的对应关系,以此作为模型训练的基础。 语音mfc…

ROS——坐标系管理、监听与广播、常用可视化工具

坐标系管理 TF功能包 小海龟追踪实验 ros版本(20.04)的tf安装命令: sudo apt-get install ros-noetic-turtle-tf 解决因python版本出现的无法生成跟随海龟&#xff1a; sudo ln -s /usr/bin/python3 /usr/bin/python ( -s 软链接,符号链接) ln命令&#xff08;英文全拼&#…

grpc-go服务端接口添加

【1】新建一个目录whgserviceproto&#xff0c;目录下新建一个proto包&#xff1a;whgserviceproto.proto &#xff08;注意目录和包名称保持一致&#xff09; //协议为proto3 syntax "proto3"; // 指定生成的Go代码在你项目中的导入路径 option go_package"…

代理模式详解、RESTFul风格、Spring IOC

Day49 代理模式proxy 概念&#xff1a; 代理(Proxy)是一种设计模式&#xff0c;提供了对目标对象另外的访问方式&#xff0c;即通过代理对象访问目标对象.这样做的好处是:可以在目标对象实现的基础上,增强额外的功能操作,即扩展目标对象的功能. 代理模式分为静态代理和动态代理…

开源数据科学平台Anaconda简介

开源数据科学平台Anaconda简介 零、时光宝盒 最近&#xff0c;某金融行业女性选择以跳楼的形式结束自己的生命&#xff0c;这件不幸的事情成了热门话题&#xff0c;各种猜测的都有&#xff0c;有些人评论的话真的很过分。我想起前段时间看到的&#xff0c;有个女学生跳江&#…

【论文解读】AGENTLESS:揭开基于LLM的软件工程代理的神秘面纱,重塑软件工程自动化新基线

&#x1f4dc; 文献卡 英文题目: Agentless: Demystifying LLM-based Software Engineering Agents;作者: Chunqiu Steven Xia; Yinlin Deng; Soren Dunn; Lingming ZhangDOI: 10.48550/arXiv.2407.01489摘要翻译: 大型语言模型&#xff08;LLM&#xff09;的最新进展显著推进…

进程的控制-ps和kill命令

ps 查看进程信息 部分参数&#xff1a; a : 显示现行终端机下的所有程序&#xff0c;包括其他用户的程序 u: 以用户为主的格式来显示程序状况 x: 显示所有程序&#xff0c;不以 终端机来区分 kill 向指定的进程发送信号 kill 可将指定的信息送至程序。预设的信息为 SIG…

OpenAI突然停止中国API使用,出海SaaS产品如何化挑战为机遇?

2023年是AI爆发的年代&#xff0c;人工智能带来的信息裂变刷新了整个SaaS行业。在这个AI引领的时代&#xff0c;我们不应该单纯依赖工具本身&#xff0c;而是要理解如何将这些AI功能与行业相结合。 然而&#xff0c;上周OpenAI宣布禁止对中国提供API服务&#xff0c;有一些用户…

六、数据可视化—flask框架入门(爬虫及数据可视化)

六、数据可视化—flask框架入门&#xff08;爬虫及数据可视化&#xff09; 1&#xff0c;数据可视化简介2&#xff0c;flask&#xff08;1&#xff09;创建flask项目&#xff08;2&#xff09;开启debug模式&#xff08;3&#xff09;通过访问路径传递参数&#xff08;4&#x…

图的应用之最短路径

引入 应用 算法思想 Dijistra算法 用于解决单个顶点间的最短路径问题 将顶点看成两部分&#xff1a; 最短路径顶点集合A与尚未确定最短路径顶点集合B。 先将顶点按最短路径由小到大依次加入到A中&#xff0c;选择由源点到A中最短的顶点&#xff0c;并记录距离与顶点&#xf…

身体(body)的觉醒:如果你贪婪,给你整个宇宙都不够

佛&#xff0c;是一个梵文的汉语音译词&#xff0c;指觉醒者。 何谓觉醒&#xff1f;什么的觉醒&#xff1f;其实很简单&#xff0c;就是身体的觉醒。 佛的另一个名字&#xff0c;叫菩提&#xff0c;佛就是菩提&#xff0c;菩提老祖&#xff0c;就是佛祖。 一、body&#xff…

Lambda架构

1.Lambda架构对大数据处理系统的理解 Lambda架构由Storm的作者Nathan Marz提出&#xff0c;其设计目的在于提供一个能满足大数据系统关键特性的架构&#xff0c;包括高容错、低延迟、可扩展等。其整合离线计算与实时计算&#xff0c;融合不可变性、读写分离和复杂性隔离等原则&…

3.js - 裁剪平面(clipIntersection:交集、并集)

看图 代码 // ts-nocheck// 引入three.js import * as THREE from three// 导入轨道控制器 import { OrbitControls } from three/examples/jsm/controls/OrbitControls// 导入lil.gui import { GUI } from three/examples/jsm/libs/lil-gui.module.min.js// 导入tween import …

深度解析Ubuntu版本升级:LTS版本升级指南

深度解析Ubuntu版本升级&#xff1a;Ubuntu版本生命周期及LTS版本升级指南 Ubuntu是全球最受欢迎的Linux发行版之一&#xff0c;其版本升级与维护策略直接影响了无数用户的开发和生产环境。Canonical公司为Ubuntu制定了明确的生命周期和发布节奏&#xff0c;使得社区、企业和开…

Spring AOP源码篇三之 xml配置

简单代码示例, 了解Spring AOP基于xml的基本用法 xml配置&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-insta…

django之url路径

方式一&#xff1a;path 语法&#xff1a;<<转换器类型:自定义>> 作用&#xff1a;若转换器类型匹配到对应类型的数据&#xff0c;则将数据按照关键字传参的方式传递给视图函数 类型&#xff1a; str: 匹配除了”/“之外的非空字符串。 /test/zvxint: 匹配0或任何…

golang线程池ants-实现架构

1、总体架构 ants协程池&#xff0c;在使用上有多种方式(使用方式参考这篇文章&#xff1a;golang线程池ants-四种使用方法)&#xff0c;但是在实现的核心就一个&#xff0c;如下架构图&#xff1a; 总的来说&#xff0c;就是三个数据结构&#xff1a; Pool、WorkerStack、goW…