了解如何使用非洲野生动物数据集训练YOLO 模型来detect 野生动物,并使用该模型对未见过的图像进行推断。
了解如何使用非洲野生动物数据集训练YOLO 模型来detect 野生动物,并使用该模型对未见过的图像进行推断。
我们星球上的野生动物种类繁多,从嗡嗡作响的蜜蜂到高耸的大象,保护这种生物多样性是维持平衡生态系统的关键。然而,由于栖息地丧失、偷猎和气候变化,保护工作变得越来越具有挑战性。所有这些因素都会对野生动物种群产生负面影响。
传统的 动物监测 方法,例如手动分析相机陷阱图像和进行实地调查,速度可能很慢,并且需要大量资源。这些努力往往无法有效地覆盖大面积和庞大的人群。
为了克服这些局限性,人工智能(AI)可被用作保护野生动物的有效工具。具体来说,计算机视觉模型如 Ultralytics YOLO11等计算机视觉模型可以分析图像和视频等视觉数据,自动进行动物的实时识别和跟踪。
YOLO11 支持的对象检测和实例分割等计算机视觉任务在这方面非常有用。通过分析视觉数据,这些任务可以帮助我们收集重要数据、识别生态模式并更有效地应对环境威胁。
在本文中,我们将介绍训练YOLO11 detect 动物的过程。让我们开始吧
在进入教程之前,让我们先来看看培训和使用YOLO11 所需的不同设置选项和工具。
您需要的主要工具是Ultralytics Python 软件包,它可以让您轻松使用YOLO 模型完成训练、检测对象和运行推论等任务。要使用Ultralytics 软件包,您需要设置一个运行代码的环境,有多种选项可供选择。
以下是一些用于设置开发环境的最受欢迎的选项:
虽然你还可以在 Ultralytics 官方文档中找到其他设置环境的选项,但上面提到的三个选项只需要很少的设置,而且易于使用,是快速上手的理想选择。
在本教程中,我们将展示如何使用Google Colab、Jupyter Notebooks 或简单的Python 文件设置和训练YOLO11 ,因为所有这些环境的步骤都非常相似。
选定开发环境后,要训练YOLO11 专门detect 野生动物,我们需要一个高质量的标注图像数据集。每张图片都应清晰显示动物的位置和类型,以便模型能够通过监督学习来识别动物。
在本教程中,我们将使用非洲野生动物数据集。该数据集由Ultralytics Python 软件包提供支持,专门用于检测非洲生态系统中常见的动物。它包含四个关键物种的注释图像:水牛、大象、犀牛和斑马。

以下是非洲野生动物数据集的一些主要特征:
现在我们已经探索了非洲野生动物数据集,可以开始训练YOLO11 模型来detect 图像中的动物了。这个过程包括设置开发环境、训练YOLO11 模型和评估模型性能。
首先,我们要准备一个用于训练和测试模型的环境。可以使用Google Colab、Jupyter Notebook 或简单的Python 文件,这取决于你的偏好。相应地创建一个新的Google Colab 笔记本、Jupyter 笔记本或Python 文件。
如果您使用的是Google Colab,环境默认在CPU (中央处理器)上运行,这会减慢训练速度。为了加快进程,尤其是对于较大的模型,您可以将运行时切换为使用GPU。在Google Colab 中,您可以导航到菜单中的 "运行时 "选项卡,选择 "更改运行时类型",然后将硬件加速器设置为GPU (最好是 T4GPU)。这对缩短训练时间非常重要。
接下来,无论你使用哪种环境,都需要安装Ultralytics Python 软件包。如果你使用的是基于笔记本的环境Google Colab 或 Jupyter),请运行以下以感叹号(!)开头的命令
pip install ultralytics安装好Ultralytics 软件包后,下一步就是加载YOLO11 模型并准备训练数据集。首先,我们加载YOLO11 模型,该模型已在一般物体检测任务中经过预训练。这个预训练模型为我们提供了一个良好的起点,因为它已经学会了如何detect 各种物体。
然后,我们使用 YAML 文件指定 数据集,其中包含有关图像和标签的信息。此文件告诉模型在哪里可以找到数据集以及应该学习识别哪些对象。
Ultralytics 软件包支持非洲野生动物数据集,因此在开始训练时会自动下载,省去了手动设置的麻烦。
准备好数据集后,模型开始训练。模型将多次遍历数据集,这个过程称为跨多个 epoch 的训练,以提高其识别图像中动物的能力。在此过程中,图像将被调整为一致的大小以进行处理,并且模型将一次处理一定数量的图像,这称为一个批次。这有助于模型更有效地学习。
简而言之,当运行下面的代码片段时,模型被加载,数据集被自动下载,训练开始运行,根据非洲野生动物数据集detect 动物。
from ultralytics import YOLO
model = YOLO("yolo11n.pt")
results = model.train(data="african-wildlife.yaml", epochs=30, batch=8)运行上面的代码片段后,模型将根据我们给它的设置开始训练。我们通过代码告诉模型遍历训练图像 30 次。因此,这意味着模型将查看数据集中的所有图像 30 次,每次学习更多。
想象一下,您正在尝试学习如何绘制动物。第一次绘制时,它可能看起来不太好,但是在反复练习之后,您会开始变得更好。每次您再次尝试时,您都会从出错的地方学习并进行修复。这就是每个 epoch 为模型所做的事情 - 它查看图像,犯错误,从中学习,并且每次都变得更擅长识别动物。
如果训练代码成功运行,您将看到以下输出,因为训练正在进行中:

训练过程完成后,您可以查看并验证模型的性能指标。在Google Colab 中,您可以导航到 "runs "文件夹,然后是 "detect"文件夹,最后是 "train "文件夹,在这里您可以找到显示关键性能指标的日志。
对于Python 环境下的用户,训练结果默认保存在当前工作目录下的 "runs/train/"目录中。每次训练运行都会创建一个新的子目录(例如,runs/train/exp、runs/train/exp2 等),在这里可以找到日志和其他与训练相关的输出结果。
如果您使用CLI,则可以通过 "yolo settings"命令轻松访问这些结果和设置,该命令允许您查看或修改路径以及与训练日志和实验细节相关的其他配置。
在这些日志中,您还可以找到一些图表,通过查看这些图表,您可以了解模型训练过程的进展情况。这些图表在训练完成后创建,显示了模型是否随着时间的推移通过减少错误和提高准确性而得到改进。
它们track 模型的进展,显示训练期间损失(模型预测值与实际值之间的差值)的减少情况以及准确度的提高情况。这有助于您了解模型识别动物的学习效果,以及在训练结束时模型的进步程度。

此外,以下是您可以用来评估模型性能的一些指标的详细信息:
这些评估指标可以帮助微调模型,以提高准确性,然后再在实际应用中使用。
现在,我们已经对YOLO11 进行了训练和评估,是时候用它来分析图像并进行推断了。您可以使用数据集中的测试图像,也可以使用不同来源的新图像。
我们将使用下面的代码片段在测试数据集中的图像上运行模型。它从Ultralytics 库中导入了必要的模块。然后,它定义了存储在结果目录中的最佳模型权重文件("best.pt")的路径。自定义训练的YOLO11 模型将使用这些权重加载。
之后,设置来自非洲野生动物测试数据集的图像的路径。该模型应用于此图像进行对象检测,生成结果,并保存输出(例如,检测到的对象或注释)。
from ultralytics import settings
best_model_path = results.save_dir / "weights/best.pt"
model = YOLO(best_path)
image_path = f"{settings['datasets_dir']}/african-wildlife/test/images/1 (168).jpg"
img_results = model(image_path, save=True) 下图所示的输出图像将保存在detect /检测目录下的 "predict "文件夹中。对于后续测试,将创建 "predict2"、"predict3 "等新文件夹来存储图像。

要测试来自不同来源的图像,您可以使用下面的代码。我们使用了来自 Pexels 的图像。您可以使用相同的图像或任何其他相关图像。
best_model_path = results.save_dir / "weights/best.pt"
model = YOLO(best_path)
img2_results = model("https://images.pexels.com/photos/18341011/pexels-photo-18341011/free-photo-of-elephant-and-zebras-in-savannah.png", save=True)下图所示的输出图像将保存在相应的文件夹中。

像YOLO11 这样的模型可以detect 和track 动物,从而实现各种实际应用。以下是视觉人工智能可用于支持野生动物保护工作的一些关键领域:
像YOLO11 这样的计算机视觉模型可以自动检测和跟踪动物,从而在野生动物保护方面发挥关键作用。有了视觉人工智能,我们就可以处理来自各种来源的大量图像和视频,从而有可能进行准确的野生动物评估。
尤其是Ultralytics YOLO11,它是实时物体检测的最佳选择,非常适合反盗猎监视、行为分析和生态系统监测等任务。通过将人工智能驱动的模型融入到保护工作中,我们可以更好地保护物种,改善生物多样性跟踪,并做出更明智的决策来保护濒危野生动物。
加入我们的社区,探索GitHub 存储库,了解有关计算机视觉的更多信息。在我们的解决方案页面上了解更多与医疗保健领域的人工智能和制造业中的计算机视觉相关的应用。查看Ultralytics 许可选项,开始使用视觉人工智能。