多旋翼物流无人机节能轨迹规划(Python代码实现)

简介: 多旋翼物流无人机节能轨迹规划(Python代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥


🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。


⛳️座右铭:行百里者,半于九十。


📋📋📋本文目录如下:🎁🎁🎁


目录


💥1 概述


📚2 运行结果


🌈3 Python代码实现


🎉4 参考文献


💥1 概述

多旋翼物流无人机的节能轨迹规划是一项重要的技术,可以有效减少无人机的能量消耗,延长飞行时间,提高物流效率。下面是一些常见的节能轨迹规划方法:


最短路径规划:通过寻找起点和终点之间的最短路径,减少飞行距离,从而节省能量消耗。可以使用经典的最短路径算法如Dijkstra算法和A*算法来实现。


动态路径规划:考虑当前环境的动态变化,比如风速、天气状况和地形高度等因素,并实时优化飞行路径。这样可以避免飞行过程中遭受很大的阻力,从而减少能量消耗。


高效充电站布置:合理规划充电站的位置,使得无人机在物流任务执行过程中可以方便地进行补充能量。这样无人机可以减少回程飞行距离,节省能量。


光伏充电:在无人机上安装太阳能电池板,通过太阳能充电来提供能源。这种方式可以减少对传统电力的依赖,减少碳排放。


多机协同飞行:通过与其他物流无人机进行协同飞行,在空中形成集群,减少空气阻力,提高整体能源利用效率。


总之,节能轨迹规划为多旋翼物流无人机提供了较大的优化空间,通过合理规划飞行路径、优化充电策略以及使用新能源技术,可以显著减少能量消耗,提高物流效率。


本文考虑静态环境下无人机轨迹轨迹的可行性和能耗特性。


📚2 运行结果


a9c6d1d52f574c0bb6ecd8963485750b.png

ff6d5e2ce364425a9c13e2747e0b11e2.png

9760dc6ced36402c9beb44669ed2cfbd.png


部分代码:

def VelDataAboutTime():
    blocks = []
    b1 = Block(0, 0, 0, 150, 200, 200)   # (x1, y1, z1, x2, y2, z2)
    b2 = Block(100, 150, 120, 300, 400, 450)  # (x1, y1, z1, x2, y2, z2)
    b3 = Block(250, 350, 400, 500, 480, 500)   # (x1, y1, z1, x2, y2, z2)
    b4 = Block(420, 220, 200, 650, 400, 450)   # (x1, y1, z1, x2, y2, z2)
    b5 = Block(550, 80, 150, 650, 400, 300)   # (x1, y1, z1, x2, y2, z2)
    b6 = Block(600, 80, 50, 800, 150, 200)   # (x1, y1, z1, x2, y2, z2)
    blocks.append(b1)
    blocks.append(b2)
    blocks.append(b3)
    blocks.append(b4)
    blocks.append(b5)
    blocks.append(b6)
    block2Ds = []
    for b in blocks:
        block2Ds.append(Block2D(b.x1, b.y1, b.x2, b.y2))
    goal = [800, 100, 60]
    c_x = []  # 每段 (x1, x2)
    c_y = []  # 每段 (y1, y2)
    c_z = []  # 每段 (z1, z2)
    corridor = []
    for block in blocks:
        c_x.append([block.x1, block.x2])  # 提取出每一段的 (x1,x2)
        c_y.append([block.y1, block.y2])  # 提取出每一段的 (y1,y2)
        c_z.append([block.z1, block.z2])  # 提取出每一段的 (z1,z2)
    corridor.append(c_x)
    corridor.append(c_y)
    corridor.append(c_z)
    time = [
        [13, 21, 9, 12, 12, 13],
        [16, 23, 10, 13, 13, 15],
        [18, 25, 11, 15, 15, 16],
        [20, 27, 13, 16, 16, 18],
        [22, 29, 14, 18, 18, 19]
    ]
    # time = [13, 21, 9, 12, 12, 13]  # 80  2.68677585e+04
    # time = [16, 23, 10, 13, 13, 15] # 90  2.88795396e+04
    # time = [18, 25, 11, 15, 15, 16]  # 100  3.10684295e+04
    # time = [20, 27, 13, 16, 16, 18]  # 110   3.33565508e+04
    # time = [22, 29, 14, 18, 18, 19]  # 120  3.57001138e+04
    for i in range(5):
        print("============================================")
        energy, power, s, vel = UAV3D(time[i], goal, corridor)
        print(energy)
        """ save vel to excel """
        vel_x = list(np.array(vel[0]).flatten())
        vel_y = list(np.array(vel[1]).flatten())
        vel_z = list(np.array(vel[2]).flatten())
        for index in range(len(vel_x)):
            velocity = math.sqrt(vel_x[index] ** 2 + vel_y[index] ** 2 + vel_z[index] ** 2)
            CVXsheet.write(index, i, velocity)
    workbook.save('Velocity.xls')
def plot_blocks(blocks):
    plt.figure(1)
    ax = plt.axes(projection='3d')
    ax.set_xlabel('X(m)')
    ax.set_ylabel('Y(m)')
    ax.set_zlabel('Z(m)')
    # ax.set_xticks(np.linspace(0, 100, 4))
    # ax.set_yticks(np.linspace(0, 100, 4))
    # ax.set_zticks(np.linspace(0, 100, 4))
    ax.set_xlim(0, 1000)
    ax.set_ylim(0, 1000)


🌈3 Python代码实现


🎉4 参考文献

部分理论来源于网络,如有侵权请联系删除。

相关文章
|
2天前
|
数据处理 开发者 Python
Python中的列表推导式:一种优雅的代码简化技巧####
【10月更文挑战第15天】 本文将深入浅出地探讨Python中列表推导式的使用,这是一种强大且简洁的语法结构,用于从现有列表生成新列表。通过具体示例和对比传统循环方法,我们将揭示列表推导式如何提高代码的可读性和执行效率,同时保持语言的简洁性。无论你是Python初学者还是有经验的开发者,掌握这一技能都将使你的编程之旅更加顺畅。 ####
9 1
|
2天前
|
人工智能 IDE 测试技术
使用通义灵码提升Python开发效率:从熟悉代码到实现需求的全流程体验
作为一名Python开发者,我最近开始使用通义灵码作为开发辅助工具。它显著提高了我的工作效率,特别是在理解和修改复杂代码逻辑方面。通过AI编码助手,我能够在短时间内快速上手新项目,实现新需求,并进行代码优化,整体效率提升了60%以上。通义灵码不仅加快了代码生成速度,还增强了代码的健壮性和稳定性。
|
4天前
|
缓存 程序员 开发者
探索Python中的装饰器:一种优雅的代码增强技巧
【10月更文挑战第13天】 在本文中,我们将深入探讨Python中的装饰器,这是一种强大的工具,它允许程序员以简洁而高效的方式扩展或修改函数和类的行为。通过具体示例,我们将展示如何利用装饰器来优化代码结构,提高开发效率,并实现如日志记录、性能计时等常见功能。本文旨在为读者提供一个关于Python装饰器的全面理解,从而能够在他们的项目中灵活运用这一技术。
14 1
|
8天前
|
设计模式 开发者 Python
Python中的装饰器:简化代码与增强功能
【10月更文挑战第9天】在编程的世界里,效率和可读性是衡量代码质量的两大关键指标。Python语言以其简洁明了的语法赢得了无数开发者的青睐,而装饰器则是其独特魅力之一。本文将深入探讨装饰器的工作原理、使用方法以及如何通过自定义装饰器来提升代码的重用性和可维护性,让读者能够更加高效地编写出既优雅又功能强大的代码。
|
9天前
|
缓存 Python
探索Python中的装饰器:简化你的代码之道
【10月更文挑战第8天】在Python的世界里,装饰器就像是一把瑞士军刀,小巧却功能强大。它们能够优雅地修改函数的行为,让代码更加简洁而不失强大。本文将带你走进装饰器的奇妙世界,从基础概念到实战应用,一步步解锁装饰器的秘密,让你的Python代码更上一层楼。
|
8天前
|
设计模式 存储 缓存
Python中的装饰器:提高代码可读性和复用性
【10月更文挑战第9天】Python中的装饰器:提高代码可读性和复用性
12 1
|
8天前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
56 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
9天前
|
设计模式 测试技术 开发者
Python中的装饰器:提升代码复用与模块化的艺术
本文将带你领略Python装饰器的魔力,探索如何通过装饰器来增强函数功能而不修改其代码。我们将从装饰器的基础概念出发,逐步深入到如何在实际项目中应用装饰器,以及如何编写自定义装饰器。文章最后,我们将通过一个实例,展示装饰器在日志记录和性能测试中的应用,让你的代码更加模块化和可重用。
|
9天前
|
Python
Python实用记录(十一):出现科学计数法如何在代码中恢复
本文介绍了如何在Python中处理科学计数法,包括如何将科学计数法转换为普通数字,以及如何设置NumPy的print选项来避免科学计数法的显示。
31 1
|
10天前
|
开发者 Python
探索Python中的列表推导式:简化代码的利器
在Python编程中,列表推导式是一种简洁而强大的工具,它允许开发者以一行代码实现复杂的列表操作。本文将深入探讨列表推导式的语法、优势以及实际应用,帮助读者更好地利用这一特性来优化代码。