车道线分割项目记录-Discriminative_loss

2024-03-16 03:50

本文主要是介绍车道线分割项目记录-Discriminative_loss,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

 一、损失函数原理

1. L_var

2. L_dist

二、代码


 一、损失函数原理

 主要是看明白了每个符号代表的意思就能明白了。

1. L_var

L_var是方差损失,也就是一条车道线的像素点之间的方差越小越好。上面的式子中,前面两个求和以及1/C,1/N,就是为了平均这个损失值,取所有的车道线,再取所有的像素点,计算完了对所有车道线以及所有像素点求均值。其中C就是车道线数量,N_c就是对应车道线所包含的像素点数量

后半部分的[x]_+,这个式子就是取max(0, x),因为损失值最小是0,因此如果里面的数小于0了,结果就是0。

再往里,||a-b||,这个就是求距离了,是二范数,也就是求个欧式距离。二者之间的距离如果比设定的像素点相似度阈值\delta _v,比如设为0.5,比这个还小,那么就认为他们确定属于一条线了,结果就是没有损失,就是0。如果比阈值大,就是有损失。

这样应该就能看明白第一个式子了,就是取一条车道线对应的所有像素点的均值\mu _c,然后用预测的属于这条车道线的所有像素点x_i,和均值计算距离,再减去阈值作为损失,如果距离很大,就有损失,距离小于设定的阈值,就没损失。就可以了。

2. L_dist

L_dist是距离损失,也就是两个车道线之间的距离,这个距离应该越大越好,因此,对距离取个负号,就变成了越小越好,就符合损失函数的特征了。上面式子的前一部分,也是用来求均值的,因为我们是要对两两之间求距离,也就是说,假如我们有3根车道线,分别为0,1,2,那么计算距离的时候,是计算了0-1  0-2  1-0   1-2   2-1  2-0之间的距离,正反都算了,因此总共算了C(C-1)这么多次。后半段式子里面的\delta _d,就是我们设定的两条线的距离阈值,比如设为3,要是比这个距离小,比如是1.2,那就有损失,要是两条线距离很大,是8,那说明已经很好了,就没损失了。

至于下面的alpha和beta,就是权重因子。假如距离损失一算,是4,5,6这么大的数,而方差损失一算,是0.04,0.03这么大的数,数量级不一样,那么就需要调整了,通过权重因子,把他们调整到同一个数量级。回归损失没有用到,就不说了。

二、代码

代码这里需要注意的是,计算过程中不要用a += b这种形式,而是要用a = a+b,否则无法求导。

def Discriminative_Loss(self, instance_label, embedding_out, delta_v=0.5, delta_d=3.0):# 一张一张地算embd_dim = embedding_out.shape[1]batch_size = embedding_out.shape[0]L_var = torch.tensor(0, dtype=embedding_out.dtype, device=embedding_out.device)L_dist = torch.tensor(0, dtype=embedding_out.dtype, device=embedding_out.device)for i in range(batch_size):# 对于每一条车道线,每个像素都有4维的embedding,因此,均值也是4维的img = embedding_out[i]label = instance_label[i]# 那么四条车道线,对应四个均值,就是4*4的,如果embedding是5维,那四条车道线的均值就是4*5的。labels = torch.unique(label)labels = labels[labels != 0]  # 1,2,3,4centroid_means = []for lane in labels:# 取出对于这条车道线,有像素的那些点的Maskmask = (label == lane)# 根据mask,取出点,每个点是4维的embeddingmasked_img = img[:, mask]mean_lane = torch.mean(masked_img, dim=1)centroid_means.append(mean_lane)# m个embedding后的像素点都减去均值(4,1),在第0个维度求范数,就会消去第0个维度,得到m个值L_var = L_var + torch.mean(F.relu((torch.norm(masked_img - mean_lane.reshape(embd_dim, 1), dim=0)) - delta_v) ** 2) / len(labels)# 堆叠起来,就得到了(num_lanes, embedding_dim)的四条车道线的均值,利用这个去求范数centroid_means = torch.stack(centroid_means)if len(labels) > 1:# 比如车道线4条,embedding 维度是5的话,前面堆叠之后的shape就是(4,5)# 变成2个,一个是(4,1,5),一个是(1,4,5)# 这样对这两个相减,在“5”这个维度上求范数,消去这个维度,得到的就是(4,4)的范数结果# 第i行第j列代表第i个线对第j个线求的范数,因此对角线是0,上下两部分对称c = len(labels)centroid_means1 = centroid_means.reshape(-1, 1, embd_dim)centroid_means2 = centroid_means.reshape(1, -1, embd_dim)dist = torch.norm(centroid_means1 - centroid_means2, dim=2)dist =dist+ torch.eye(c, dtype=dist.dtype, device=dist.device) * delta_d# 对角线加上delta_d,再按照公式求即可L_dist = L_dist + torch.sum((F.relu(-dist + delta_d) ** 2) / (c * (c - 1) * 2))L_var =L_var / batch_sizeL_dist =L_dist / batch_sizereturn L_var, L_dist

这篇关于车道线分割项目记录-Discriminative_loss的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/814200

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示