Paper -- 建筑物高度估计 -- 基于深度学习、图像处理和自动地理空间分析的街景图像建筑高度估算
论文题目: Building height estimation from street-view imagery using deep learning, image processing and automated geospatial analysis
中文题目: 基于深度学习、图像处理和自动地理空间分析
的街景图像建筑高度估算
作者: Ala’a Al-Habashna, Ryan Murdoch
作者单位: 加拿大统计局特别业务项目中心数据探索和集成实验室
,加拿大渥太华
投稿时间:2023年5月16日
修改时间:2023年8月24日
接受时间:2023年9月28日
在线发表时间:2023年11月11日
期刊: Multimedia Tools and Applications
中国科学院SCI期刊分区的四区
摘要
近年来,许多研究致力于从街景图像中提取有关建筑和基础设施、交通与移动性、步行性以及健康与福祉的有价值数据
- 本文提出了
两种算法及其实现方法
,用于利用深度学习(DL)
和高级图像与地理空间数据处理算法
,从街景图像中自动估算建筑高度
- BHEDC算法:基础算法,用于估算建筑高度。
- iBHEDC算法:改进版算法,增加了
新的组件和优化步骤
。
- 本文旨在通过改进现有算法 (BHEDC),提出一种新的方法(iBHEDC),以提高建筑高度估算的精度和效率
点击查看BHEDC论文解析: https://tancer.blog.csdn.net/article/details/144121336
背景
建筑高度
是城市建模与规划、城市与经济分析等领域的重要数据。传统方法
依赖于昂贵的测量设备
或高分辨率遥感图像
,而街景图像提供了一种低成本、高可用性
的替代方案。- 尽管街景图像在地理空间数据提取中具有潜力,但如何从中准确估算建筑高度仍然是一个挑战,尤其是在复杂的城市环境中
相关研究
- 步行性分析:Smith等人提出了一种方法,通过街景图像提取
人行道的存在及质量数据
,用于设计步行友好型城市
。 - 道路表面分类:Marianingsih和Utaminingrum使用街景图像训练分类器,将道路表面
分类
为多种类型(如沥青、砾石
) - 视觉定位:通过与
地理标记图像
的比较,预测图像的地理位置
- Zhao等人提出了一种基于
语义分割和边缘检测
的建筑高度估算方法。 - Al-Habashna提出了BHEDC算法,利用
街景图像和建筑轮廓数据
进行高度估算。
方法
iBHEDC算法概述
- 预处理与语义分割:对输入图像进行
预处理
,使用CNN生成语义分割图像
,提取建筑物区域。 - 建筑维度提取:通过
颜色变换
和单应性变换
,提取建筑物在图像中的高度
。 - 轮廓与顶部点提取:使用
Ramer-Douglas-Peucker算法
提取建筑轮廓,并确定建筑顶部点
。 - 高度估算:结合
相机投影模型
和校正因子
,估算实际建筑高度
。
相关处理技术概览:
- 颜色变换:对图像像素进行
颜色变换
,以避免语义分割输出中的问题。 - 单应性变换:将图像归一化为
零俯仰角
图像。 - 语义分割:使用训练好的CNN生成
语义分割图像
- 阈值处理:提取
建筑物像素区域
,并通过提取最大连通区域
消除无关子区域。 - 轮廓提取:使用
Ramer-Douglas-Peucker算法
对轮廓进行近似,提取建筑物的顶部点
。 - 相机投影模型:结合图像中的建筑维度和
相机元数据
,估算实际建筑高度
数据集和评价指标
数据集
数据集包含400个建筑物
的街景图像
及其对应的建筑轮廓数据。
数据来源包括多个平台(如Open Street Map
和其他地理空间数据平台
)。
评价指标
高度估算精度:通过与真实建筑高度
的对比,评估算法的准确性。
算法鲁棒性:在复杂场景
(如遮挡、光照变化)下测试算法的表现
iBHEDC 算法(改进版建筑高度估算算法)高层次工作流程的框架图
整个工作流程从获取街景图像开始,通过数据预处理、深度学习相关处理、地理空间数据分析和图像处理一步步实现建筑高度的估算
- 获取测试图像
步骤:从Google Street-View Static API
中获取街景图像
。
目的:为算法的后续分析提供原始测试数据,确保街景图像具有良好的质量
,并附带元数据信息
(如图像的地理位置、相机信息等)。 - 图像预处理
步骤:对图像实施必要的预处理
操作。
内容:可能包括图像的裁剪、去噪、颜色校正
以及对元数据的验证和标准化处理。
作用:提高图像质量,确保后续深度学习和图像处理步骤的结果准确性和可靠性。 - 基于深度学习的语义分割
步骤:利用深度学习模型
(如卷积神经网络,CNNs)对图像进行语义分割
,以识别建筑物区域。
功能:通过像素级分割
,为后续的建筑物轮廓提取和高度估算提供信息。 - 下载建筑轮廓数据
步骤:从地图数据平台(如 Open Street Map)
下载与图像相关的建筑轮廓数据
(building footprint data)。
作用:获取建筑物的基本地理轮廓,为估算实际建筑高度提供地理空间信息支持。 - 地理空间处理与建筑与相机距离计算
步骤:结合地理空间数据
和图像元数据
计算建筑物与相机的位置和距离
。
方法:包括图像与地理位置的对应
以及基于透视技术的距离计算
。
目的:通过相机与目标建筑物的空间关系,完善建筑高度的估算公式。 - 提取建筑物图像维度
步骤:应用图像处理技术
提取建筑物在图像中的高度
(如顶部点到底部点的像素距离)。
技术:使用边缘检测、形状提取以及轮廓拟合等技术,从语义分割图像提取建筑物的主要维度。 - 估算建筑高度
步骤:通过相机投影模型
结合上述提取的建筑维度
和相机-建筑距离
,估算实际建筑高度。
方法:使用几何关系和透视变换技术,将图像中以像素表示的建筑物高度转换为实际物理高度。
在 iBHEDC 算法中提取建筑图像维度详细流程
该图主要描述了如何从语义分割
后的图像中提取建筑物在图像中的高度
流程主要三大部分:
- 语义分割与图像预处理:对图像进行
强度变换(Intensity Transformation
)、变换校正(Plane-to-Plane Homography)
和语义分割
等处理。- 应用强度变换(Apply Intensity Transformation on the Image)
作用:通过调整像素值分布,提高图像的对比度
,从而增强建筑物的清晰度。
方法:可能包括直方图均衡化
或伽马校正
。 - 应用平面到平面单应性变换(Apply Plane-to-Plane Homography if Needed)
作用:校正
由于相机角度造成的建筑物倾斜问题
,使得图像中的建筑物呈现直立状态
。
方法:将非垂直平面
的像素校正到同一视角(垂直)平面。 - 使用语义分割识别图像中的建筑物(Use Semantic Segmentation to Identify Buildings in the Image)
作用:通过卷积神经网络(CNN)等深度学习方法,将建筑物区域从图像中精准分割出来
,标记背景和建筑物像素区域。
- 应用强度变换(Apply Intensity Transformation on the Image)
- 建筑轮廓提取:通过
阈值
和连通性分析
提取建筑物的连通区域以及轮廓- 应用搜索区域算法确定建筑区域(Apply the Search-Region Algorithm to Determine the Building’s Region)
作用:通过分析建筑物的位置和大小,划定建筑物的感兴趣区域(Region of Interest)
。 - 应用图像阈值处理获取建筑像素(Apply Image Thresholding to Obtain Pixels of Buildings)
作用:根据像素强度,将图像二值化
,提取与建筑物相关的像素区域。 - 提取最大的连通区域(Extract the Biggest Connected Component)
作用:分析连通像素区域(Connected Components),保留覆盖面积最大的区域
,排除无关或背景噪声
。
- 应用搜索区域算法确定建筑区域(Apply the Search-Region Algorithm to Determine the Building’s Region)
- 高度计算:找到建筑轮廓的
最高点
,根据校正
获取建筑在图像中的大致高度- 提取轮廓(Extract the Contour)
作用:通过边界检测,提取建筑物像素区域的边缘轮廓
,形成精确的建筑物形状信息。 - 轮廓拟合(Approximate the Contour)
方法:使用Ramer-Douglas-Peucker 算法
对轮廓进行多边形拟合,从而去除冗余复杂信息,保留重要的轮廓特征。 - 在拟合轮廓中获取最高点(Get the Highest Point in the Approximated Contour)
功能:通过分析轮廓顶点
,确定建筑物在图像中的最高位置
,为后续高度计算提供基础数据。 - 计算大致的建筑图像高度(Calculate the Approximate Building-Image Height)
方法:计算建筑物最高点
和最低点
在图像中的像素间距,得出建筑在图片中的高度。 - 应用建筑图像高度校正(Apply Building-Image Height Correction)
功能:通过结合图像元数据
(如相机和建筑距离)、视角参数
进行校正,得到更准确的图像高度。
- 提取轮廓(Extract the Contour)
预处理步骤对输入图像的影响
左图(a):原始街景图像,体现了捕获数据的初始状态,但可能包含一些不利影响,比如色彩不均、光照问题、视角偏差等。
右图(b):经过强度变换(Intensity Transformation)和图像校正(Plane-to-Plane Homography)后的图像,处理后建筑物呈现更好的可见性,同时减小了因拍摄角度引起的倾斜和失真问题
-
强度变换(Intensity Transformation)
目的:增强图像的对比度
,为后续任务提供更清晰的边缘
与物体分界线
。- 直方图均衡化(Histogram Equalization):均衡像素的分布,突出重要视觉特征。
- 伽马校正(Gamma Correction):调整图像的亮度,修复过暗或过亮区域。
-
单应性变换(Plane-to-Plane Homography)
目的:校正因相机拍摄角度
引起的图像倾斜
和投影变形
问题。- 利用地面平面和垂直建筑平面的几何特性,对图像进行投影变换。
- 将带有倾斜感的建筑物拉直,使其在图像中看起来更加正立。
视觉改进:从左图到右图,光照和建筑物边界的清晰度明显提高
,图像大部分噪声消除
,例如色彩均衡和锐化效果。
建筑形状拉直:预处理后的图像中,建筑物看上去更加对齐
,并且轮廓(如建筑的边缘和顶部点)更易于识别
预处理步骤对语义分割的影响
左图(a):未经处理的原始街景图像
(来自 Google Street View)。
右图(b):未经预处理情况下
的语义分割结果
,展示了算法在分割建筑物区域时的失败案例
左图 (a):显示经过伽马校正
(Gamma Correction)后的预处理图像,目的是改善图像亮度和对比度
。
右图 (b):展示了在应用预处理后
,语义分割的改进结果。图示中不同颜色代表语义分割后的分类结果,例如建筑物、草地、天空等。
定义感兴趣的区域
图6中的分割是令人满意的;然而,相邻的建筑被组合成一个单一的连接组件
(都是同一个连接子区域的一部分)
高度估计的下一步是识别建筑物子区域中的最高点。然而,当相邻的建筑组合成一个连接的组件时,最高点可能属于错误的建筑。为了帮助避免选择属于不正确建筑物的点,开发了以下水平搜索区域识别算法。
红色闭合线
代表建筑物的实际轮廓的俯视投影
,提供了与视线方向相关的边界信息
。
所有分割点
显示了建筑边缘在该坐标系下的表现,是高度提取过程中最核心的数据来源
绿色直线
代表了摄像机视线方向
,直接与目标建筑进行对准。
用于定义建筑物的中心线,对应建筑投影区域的主要方向
。
蓝色虚线三角形
表示建筑物的感兴趣区域投影范围,可根据相机视角范围(Field of View, FOV)定义。
角度范围为 θ m i n \theta_{min} θmin ~ θ m a x \theta_{max} θmax,分别为感兴趣区域的两侧边界
(a) 语义分割结果:显示经过语义分割模型
处理后的街景图像,图像中使用不同颜色表示各语义类别(如建筑物、道路、天空等)。
(b) 提取的搜索区域:表示从语义分割结果中提取的感兴趣区域
(搜索区域),主要聚焦于与建筑物相关的部分,为后续建筑高度
估算奠定基础。
建筑物轮廓提取和顶点检测
(a) 最大连通区域 (Largest connected component):提取了被语义分割所得的建筑物区域中最大的连通区域
,排除了无关区域。
白色区域代表建筑物,黑色区域则为背景或被过滤掉的小连通区域。
只保留覆盖面积最大的连通区域,以确保目标区域的完整性,同时消除语义分割时可能的误分类噪声
(b) 建筑轮廓与顶部点 (Building contour and top points):基于最大连通区域,进一步提取建筑轮廓并标注建筑的顶部点
,为后续的高度计算提供关键数据。
黑色线条显示建筑物的轮廓线,是通过对最大连通区域进行边缘检测获取的。
图中标注了两个点:
红色点
:建筑物的一个参考顶点,可能是初步提取的最高点。
黄色点
:最终确定的建筑物最高点,用于估算建筑高度。
建筑高度估算的两步关键流程
(a) 搜索区域与顶点标注
背景
: 输入图像经过语义分割后,在图中使用不同颜色表示不同区域(如道路、天空、建筑等)。
黄色和紫色垂直线
: 界定了感兴趣的搜索区域,表示专业算法关注的建筑物宽度范围。
黑色轮廓
: 表示算法识别出的建筑物边界线,用于高度估算的基础。
浅蓝圆点
: 标记了建筑物的最高点,用于估算高度的顶部点位置。
(b) 高度估算结果
绿色水平线
: 对应建筑物的顶部轮廓线,用于估算高度的上界。
红色水平线
: 表示建筑物的底部线,通常与地面或一层的标准高度对齐。
黄色和紫色垂直线
: 对应搜索区域的左右边界,与左图 (a) 保持一致。
数字“7.596”
: 表示算法根据顶部和底部线的位置,结合摄像机参数估算出的建筑物实际高度
。
流程如下:
- 语义分割与目标区域提取:
输入的街景图像首先经过语义分割
,标注出建筑、天空、地面等不同类别,并生成分割掩模(如(a) 图所示)。
检测感兴趣区域的关键部分
,定义上边界
和下边界
,排除非建筑部分(如天空和道路)。 - 搜索区域划分与轮廓标记:
垂直方向上通过黄色
和紫色线
,划定建筑物的搜索范围,确保建筑物的完整性。
利用轮廓检测技术提取建筑物的边界
,并标记建筑物的最高点
(蓝色圆点)。 - 实际高度估算:
在右图(b) 对应的实际图像中,绘制顶部线(绿色)
和底部线(红色)
。
借助建筑物在图像中的位置、高度像素差异
以及摄像机参数
,利用几何投影关系计算建筑物的实际高度。
最终结果以数值形式显示(如“7.596”)
平面单应性变换和校正
(a) 原始输入图像,未经任何处理的街景视图;
(b) 经平面单应性变换(plane-to-plane homography)和校正后的图像,解决了建筑物倾斜和畸变的问题
通过平面映射算法(plane-to-plane homography),解决由于相机视角产生的
透视失真问题
, 建筑物得以“拉直”,变得垂直于图像。
校正后消除了由于拍摄角度导致的透视变形。
整体图像的框架和比例更规则,为后续的语义分割奠定了良好基础。
(c ) 基于校正图像生成的语义分割结果,显示了不同语义类别标记的像素区域
通俗解释:平面单应性变换(Homography Matrix)及应用
在建筑高度估算中,原始图像通常会因为相机的拍摄角度(pitch值
)不同而发生透视失真。
- 例如,拍摄高楼时,街景相机通常会向上倾斜。这会导致建筑看起来像是“向后倾斜”的样子,使图像中的线条并非垂直。
- 为了计算建筑高度,我们需要把这些倾斜的图像矫正为“正视图”,就好像是在建筑正前方以零角度拍摄的一样
什么是平面单应性 (Homography)?
单应性是描述同一平面上
两幅图像之间几何关系的数学模型。
- 假设你从
两个不同角度
拍摄同一平面
(例如建筑正面),图像会因拍摄角度不同而呈现变化(透视失真)。 - 单应性变换可以
调整一幅图像
,将它“对齐”到另一幅图像,使两幅图像的内容匹配(同步)。
如何实现单应性变换?
单应性用 3×3的矩阵 H H H 表示,它将一个图像的点映射到另一个图像中对应的点
p ′ = H ⋅ p p' = H \cdot p p′=H⋅p
- p p p:在原图像中的一点(用坐标 x , y x, y x,y 表示);
- p ′ p' p′:在变换后新图像中的对应点;
- H H H:单应性矩阵,描述两幅图像之间的几何关系。
过程解释:
- 原始问题:相机倾斜的影响
在街景图像中,建筑由于相机的拍摄角度可能会产生倾斜或畸变
,这会破坏建筑的真实比例和高度
。
例如,当相机仰视拍摄时,建筑上部会显得比下部更小
,这种失真会导致高度估算不准确。 - 如何校正?使用单应性变换
首先,我们需要两幅图像:- 一个初始倾斜角度(有pitch)的图像;
- 一个假设为零倾斜角度(无pitch)的标准图像。
- 然后,我们选取两幅图像中对应的点对(例如同一个窗户的角点)。
- 只需选取至少 4 对点,这些点经过计算可以生成一个单应性变换矩阵 H H H
- 使用矩阵 H H H,可以将倾斜图像的所有像素点“投影”为
零倾斜角度
的标准视图,就像是从建筑的正面直接拍下来的效果
使用校正模型对建筑物实际高度估算结果的影响
(a) 搜索区域的分割结果,通过语义分割模型标注出建筑物的相关区域;
(b) 使用校正模型的高度估算结果,考虑透视失真的校正后,计算出较为准确的建筑物高度 (47.772)
(c ) 未使用校正模型的高度估算结果,未考虑透视失真,仅通过简单像素高度
计算出的高度值 (28.273)
校正模型作用:
- 修复**拍摄角度(如仰视拍摄)**导致的建筑顶部“远小近大”的透视失真问题。
- 使用
基于校正因子的数学模型
(关于校正模型的详细请查看论文),将图像中的像素高度正确映射到实际高度。
自动选择相机仰视角度 (pitch)
自动选取合适的仰视角度是为了使建筑物的顶部
能够完全出现在图像
中,同时去除冗余部分(如天空)
流程开始:
- 设置初始 pitch 值为 0
初始化
相机的仰视角度 0°,并将此角度作为初始输入。 - 图像捕获与分割
在当前 pitch 值
下,获取图像并进行语义分割
,以识别建筑物区域
以及判断建筑物是否完全显示
。 - 判断顶端连通区域是否出现在图像顶部
如果分割结果表明建筑物的连通区域
延伸到顶部,说明当前视角适合拍摄
。流程结束。
如果没有延伸到顶部,说明相机的视角需要调整。 - 增加 pitch 值
以一定的步长
增加pitch 值
(通常为固定的角度,例如 5° 或 10°),重新获取图像
并重复前述检查。 - 最高 pitch 值限制
如果 pitch 增加到最大值
时仍无法满足要求,说明无法获取到完整的建筑物顶部区域。流程停止
,并显示“No pitch value found”。 - 使用已有图片
若未找到顶端对应的 pitch 值,可以选择使用最接近的
下载图像进行后续处理
从OpenStreetMap (OSM) 数据中提取建筑的边界轮廓以及节点信息
(a) 建筑边界在 OSM 中的整体视图
(b) 建筑边界上的一个具体节点,作为后续分析的关键地理参考点
相机到建筑物水平距离的几何模型
Camera (相机位置):
表示相机在拍摄场景中的位置,作为坐标原点。使用相机参数(如焦距)结合几何关系估算建筑物的相对距离和高度。
Building(建筑物):
建筑物是目标对象,其底部靠近地面,被投影到不同的距离平面。
虚线框(黄色矩形框):
表示建筑物在相机视场中的投影视图
,模拟建筑在二维图像空间的数据表示。
关键距离:
红色箭头
d m d_m dm:表示 实际测量的相机到建筑物的距离
,通过平面测量或 GPS 数据获得。
蓝色箭头
d ′ d' d′:表示 相机到建筑物的投影距
离,是一个在计算中应用的几何约束距离
。
绿色箭头
:垂直方向上的辅助距离,用于连通不同设施或几何关系
高度补正:
通过蓝色箭头
d ′ d' d′ 代替红色箭头
d m d_m dm 参与计算,消除相机角度对建筑高度估算的误差
高度计算
公式:
h ^ b = h u ⋅ d ′ / f + h c \hat{h}_b=h_u\cdot d^{\prime}/f+h_c h^b=hu⋅d′/f+hc
- h ^ b \hat{h}_b h^b: 估算的建筑高度 (Estimated Building Height)。
- h u h_u hu: 建筑最高点相对于图像的中线(水平中线)所占的
像素高度
,表示为像素单位的垂直距离 - d ′ d' d′: 相机到建筑的
水平距离 (Projected Distance to the Building)
- f f f: 相机的焦距 (Focal Length)
- h c h_c hc: 相机距地面的高度, 表示相机安装点到地面的固定高度,即
相机本身的基础高度
,通常由相机持有者(如人或车辆)的高度
决定,为一个常量
效果
展示了针对不同类型住宅建筑的高度估算结果示例
(a) 与 (b):高层公寓建筑 (apartment buildings)
在每张图片顶部显示了估算出的建筑高度值,分别为 44.451 米和 35.401 米。
两栋建筑均为城市中常见的高层公寓楼
,模型通过远程拍摄图像对其高度完成了估计。
(c ) 与 (d):低层住宅 (houses)
图片展示了独立式住宅的高度估算值,分别为 9.152 米和 9.154 米。
这些建筑大多为二层普通民用住宅
,是常见的低矮建筑。
针对不同类型的 非住宅建筑(Non-residential Buildings) 的高度估算结果可视化示例
(a) 办公楼 (Office Building)
估算高度为 21.683 米,属于较高类型的建筑。
(b) 小型办公建筑 (Small Office Building)
估算高度为 8.714 米,是一种相对较低的办公场所建筑。
(c ) 零售店 (Retail Store)
估算高度为 12.069 米,为常见的中型商业建筑高度。
(d) 餐厅 (Restaurant)
估算高度为 6.315 米,为低矮的单层小型商业建筑
两种算法**(BHEDC 和 iBHEDC)** 在建筑高度估算任务中的 绝对误差分析结果:
- iBHEDC
显著优于
BHEDC
iBHEDC(改进后的建筑高度估算算法) 中各项改进对估算性能提升的贡献
Image preprocessing(图像预处理):
对误差减少的贡献为 0.13 米
。
通过改进图像预处理步骤,优化了输入数据质量,对误差减少的贡献较小。
Search region identification(搜索区域识别):
对误差减少的贡献为 1.27 米
。
这是贡献最大的改进模块,表明通过更精确地定位建筑的搜索区域,显著提高了高度估算的准确性。
Post-homography height correction(单应性后高度校正):
对误差减少的贡献为 0.81 米
。
单应性(Homography)变换后进行校正,有效修正了几何偏差,显著减少了误差。
Projected camera-building distance(投影相机-建筑距离校正):
对误差减少的贡献为 0.34 米
。
通过精确估算相机与建筑之间的投影距离,纠正了距离测量误差,带来了适度的性能提升
挑战
该图说明由于相机到建筑物
的距离测量错误
,可能导致建筑高度估算出现偏差的问题
两条测量线:
红色线
:错误的距离测量线
表示从相机到建筑“入口”的距离,这是假设中的错误测量路径。
绿色线
:正确的距离测量线
表示从相机到建筑主体的基底(最靠近主结构的点)的距离,这是准确的测量路径
质疑
- 数据集是否
足够多样化
以涵盖不同类型的建筑和城市环境? - 数据集中是否包含
足够多的复杂场景
(如遮挡、光照变化)以验证算法的鲁棒性? - 在实际应用中,街景图像的
质量和分辨率
可能会影响算法的表现,这一点是否被充分考虑? - 系统在
实时应用
中的表现如何,例如在动态城市环境
中的部署?
相关文章:
Paper -- 建筑物高度估计 -- 基于深度学习、图像处理和自动地理空间分析的街景图像建筑高度估算
论文题目: Building height estimation from street-view imagery using deep learning, image processing and automated geospatial analysis 中文题目: 基于深度学习、图像处理和自动地理空间分析的街景图像建筑高度估算 作者: Ala’a Al-Habashna, Ryan Murdoch 作者单位: …...
开发一套ERP 第八弹 RUst 插入数据
更全面的报错,方便检查错误在哪里,现代高级语言越来越智能 还是得看下原文档怎么操作的 src 目录为crate 的根目录 想在crate 中模块相互引入需要在 main 中声明,各个模块,然后才能在各个模块中相互引入和使用 原始工程引入,避免直接使用 lib.rs 回合cargo 中的一些 工程管理出…...
回退用 git revert 还是 git reset?
git revert 会生成一个新的 commit 来记录此次操作;git reset 是把 HEAD 指针向前挪动一次,会减少一个 commit。 回退用 git revert 回退还是用 git reset,核心就一点: 是否需要记录这次回退。 如果需要记录这次回退,…...
【docker】多阶段构建与基础构建,及企业案例展示
基础构建与多阶段构建对比 基础构建(单阶段构建) 在基础构建中,所有构建过程和最终的应用程序都在同一个镜像中进行,构建工具和最终应用程序都会在最终镜像中。 这样构建镜像时会包含所有的构建工具和依赖,因此最终镜…...
基于链表的基础笔试/面试题
1. 反转链表 问题描述:反转一个单向链表。 示例: 输入:1 → 2 → 3 → 4 → 5 输出:5 → 4 → 3 → 2 → 1 class ListNode {int val;ListNode next;ListNode(int x) {val x;} }public class LinkedList {public ListNode …...
SARIMA 模型Matlab代码
% 导入数据 data readtable(data.xlsx); % 假设数据在第一列 y data{:, 1}; % 获取第一列数据% 划分训练集和测试集,80% 训练,20% 测试 trainSize floor(0.8 * length(y)); trainData y(1:trainSize); testData y(trainSize1:end);% 创建时间序列…...
第八课 Unity编辑器创建的资源优化_特效篇(Particle System)详解
无论是CPU还是GPU,粒子系统对其的影响面都是不容小觑的。随着项目的重度化和3A化,玩家的口味变挑剔了、游戏玩法复杂度变高了、画面的特效表现变复杂了......所以我们还是更加谨慎地对待粒子系统。 特效(Particle System) 游戏效…...
Oracle对比表与表之间的结构
自己首先想到的就是,navicat有提供结构同步 但是有些时候情况不一样,比如我遇到的是连接不同,而且是互相同步,以最多的列的那个表为样 没有说一个固定的源 那么还可以通过导出表结构去另一个库中执行看是否报错,以此来判断结构的不同 但是我感觉有点儿麻烦 最后想到通过sql语…...
基于JSP+MySQL的网上招聘系统的设计与实现
摘要 在这样一个经济飞速发展的时代,人们的生存与生活问题已成为当代社会需要关注的一个焦点。对于一个刚刚 踏入社会的年轻人来说,他对就业市场和形势了解的不够详细,同时对自己的职业规划也很模糊,这就导致大量的 时间被花费在…...
【Linux】进程地址空间(虚拟地址vs物理地址vs页表)
Linux 进程概念补充【Linux】 进程是什么(不熟悉的兄弟可以看看)。 1. C/C内存分布图 对于有c/c基础的同学相信对上面的图片并不陌生,实际上其描述的并不是正真的物理内存,而是虚拟内存,我们把它叫做进程地址空间 。 2…...
pytorch 融合 fuse 学习笔记
目录 fuse_lora 作用是什么 fuse_modules源码解读 fuse_lora 作用是什么 在深度学习模型微调场景下(与 LoRA 相关) 参数融合功能 在使用 LoRA(Low - Rank Adaptation)对预训练模型进行微调后,fuse_lora函数的主要作…...
在 Ubuntu 20.04 上使用 Lux 下载 Bilibili 视频的详细教程
在 Ubuntu 20.04 上使用 Lux 下载 Bilibili 视频的详细教程 在 Ubuntu 20.04 上使用 Lux 下载 Bilibili(哔哩哔哩)视频的完整和详细步骤如下,包括使用预编译二进制文件的安装方法: 1. 安装依赖 确保你的系统已安装 FFmpeg&…...
【eclipse】快捷键
【eclipse】快捷键 编辑导航重构调试复制其他快速生成 Eclipse 提供了丰富的快捷键来帮助开发者提高工作效率。 以下是一些常用的 Eclipse 快捷键,它们覆盖了编辑、导航、重构、调试等多个方面。 这些快捷键能够显著提升开发效率,尤其是在处理大型项目时…...
集成开发环境(IDE)的使用技巧插件配置
在开发过程中,集成开发环境(IDE)的使用技巧和插件配置对提高工作效率、优化代码质量和加速调试至关重要。 一、IDE使用技巧 1. 代码导航 跳转到定义(Go to Definition):快速跳转到函数、类或变量的定义位…...
【如何提升代码工程质量】code review篇
应该对于基本上所有软件相关的公司来说,都有committer机制,即代码写好之后会提交合并请求,待相关人员code review通过后再进行合入,所以code review就是代码合入代码仓库的最后一道关卡,对于代码质量的影响也是不容忽视…...
Qt 面试题学习13_2024-12-1
Qt 面试题 1、 QString与基本数据类型如何转换?2、常用数据结构3、进程之间的道信方式有哪些? 1、 QString与基本数据类型如何转换? 1、将QString转换为基本数据类型通过QString的各种转换函数,可以将QString转换为int、float、double等基本数据类型。 QStri…...
Hive 安装与架构详解
Hive 安装(基于 Ubuntu 系统) 为了学习 Hive 的相关操作,我们需要先安装 Hive,以下是基于 Ubuntu 系统安装 Hive 的步骤: 下载 Hive 我们将使用 hive-0.13.1-cdh5.3.2 版本,当然你可以根据需要下载最新的…...
前端入门指南:模块打包器是什么?模块打包器的工作原理与实践
前言 在前端开发的生态系统中,随着项目复杂度和规模的不断提升,代码管理和优化变得至关重要。模块化开发作为一种有效的代码组织方式,极大地提升了代码的可维护性和复用性。 然而,面对大量的模块和复杂的依赖关系,如…...
初识ProtoBuf以及环境搭建(Win和Ubuntu)
初始ProtoBuf 序列化和反序列化的概念 序列化:把对象转换为字节序列的过程 称为对象的序列化。 反序列化:把字节序列恢复为对象的过程 称为对象的反序列化。 什么情况下需要序列化和反序列化? 存储数据:当你想把的内存中的对象状…...
springboot366高校物品捐赠管理系统(论文+源码)_kaic
毕 业 设 计(论 文) 高校物品捐赠管理系统设计与实现 摘 要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此ÿ…...
【Python网络爬虫笔记】5-(Request 带参数的get请求) 爬取豆瓣电影排行信息
目录 1.抓包工具查看网站信息2.代码实现3.运行结果 1.抓包工具查看网站信息 请求路径 url:https://movie.douban.com/typerank请求参数 页面往下拉,出现新的请求结果,参数start更新,每次刷新出20条新的电影数据 2.代码实现 # 使用网络爬…...
递归算法讲解(c基础)
递归的定义 递归是指在函数的定义中使用函数自身的方法。它是一种解决问题的策略,将一个大型复杂的问题逐步分解为规模更小的、与原问题相似的子问题来解决。当子问题的规模足够小,达到一个可以直接求解的基本情况(也称为终止条件)…...
AJAX一、axios使用,url组成(协议,域名,资源路径)查询参数和化简,错误处理,请求/响应报文,状态码,接口文档,
一、AJAX是什么 概念 : AJAX是一种与服务器(后端)通信的技术 二、请求库axios的基本用法 1导包 2使用 // 1. 发请求 axios({ url: 请求地址 }).then(res > { // 2.接收并使用数据 }) <body><p class"province"…...
QT6学习第六天 初识QML
QT6学习第六天 创建Qt Quick UI项目使用Qt Quick DesignerQML 语法基础导入语句 import对象 object 和属性 property布局注释表达式和属性绑定QML 编码约定 设置应用程序图标 创建Qt Quick UI项目 如果你有只测试QML相关内容快速显示界面的需求,这时可以创建Qt Qui…...
映射vim键位,基本功能键位表(未更完)
键位映射:建议使用jj代替esc,毕竟esc离手那么远 linux下修改方法是:vim /etc/vim/vimrc 在该文件尾添加inoremap jj <Esc>该方法可以同样可以用到其他键位映射上 i:表示这个映射是在插入模式(insert mode)下有效…...
Python学习笔记(5)Python的创建型设计模式
创建型设计模式(Creational Design Patterns),主要关注对象的创建机制。这类模式可以使得系统更加独立于如何创建、组合和表示其对象。通过将这些职责分离出来,创建型设计模式有助于提高代码的灵活性和复用性。 本书的范例代码已经…...
qt QAnimationDriver详解
1、概述 QAnimationDriver是Qt框架中提供的一个类,它主要用于自定义动画帧的时间控制和更新。通过继承和实现QAnimationDriver,开发者可以精确控制动画的时间步长和更新逻辑,从而实现丰富和灵活的动画效果。QAnimationDriver与QAbstractAnim…...
零拷贝相关知识点(一)
前言 大家好,我是程序员田螺。 零拷贝是老生常谈的问题啦,大厂非常喜欢问。比如Kafka为什么快,RocketMQ为什么快等,都涉及到零拷贝知识点。最近技术讨论群几个伙伴分享了阿里、虾皮的面试真题,也都涉及到零拷贝。因此…...
STM32的CAN波特率计算
公式: CAN波特率 APB总线频率 / (BRP分频器 1)/ (SWJ BS1 BS2) SWJ一般为1。 例如STM32F407的,CAN1和CAN2都在在APB1下,频率是42000000 如果想配置成1M波特率,则计算公式为:...
简单好用的折线图绘制!
折线图的概念及作用: 折线图(Line Chart)是一种常见的图表类型,用于展示数据的变化趋势或时间序列数据。它通过一系列的数据点(通常表示为坐标系中的点)与这些点之间的线段相连,直观地展示变量…...
做网站 怎么赚钱吗/爱战网关键词挖掘查询工具
〇、摘要 munin是用于Linux系统(也可以监控windows系统)的监控软件。munin除了可以监控系统的各项数值之外,最大的好处是可以自己编写插件自定义监控需要的数值。整个系统的架构简单明了,操作方便。如果是使用Debian或者Ubuntu安装…...
江苏网站建设官网/网站排名推广
一,按键的按下抬起等识别方法 void Update (){int key1 0;int key2 0;if (Input.GetKeyDown (KeyCode.A)){Debug.Log("A按下一次");} if (Input.GetKey (KeyCode.A)){//记录按下的帧数,判断特定按键按下不抬起key1;Debug.Log("A连按…...
好网站推荐一下/品牌推广内容
微软等数据结构算法面试100题系列之网友精彩回复 [一] ------------------------------ 作者:July 飞雪 一直不断有网友来信,想要微软等100题的答案,可由于整理这100题的答案,分量太大。 所以,后60题的答案,一直迟迟…...
linux下网站开发/广点通广告平台
保定市竞秀区委宣传部17日透露,该区一企业将在保定范围投放10000台集商品售卖、信息传播和大数据采集等功能于一体的智能自动售货机。 据保定和金创业空间总经理李强介绍,在“互联网+”时代,智能自动售货机被称为“永不下班的超级…...
宁波企业网站制作/google中文搜索引擎
(点击上方公众号,可快速关注)来源:Float_Luuu,my.oschina.net/andylucc/blog/539783今天查了很多资料,主要是想搞清楚写JAVA和CacheLine有什么关系以及我们如何针对CacheLine写出更好的JAVA程序。CPU和内存CPU是计算机的大脑&…...
教育机构网站建设方案/免费推广产品的网站
今天想要在Linux下查看机器上MCH(北桥)芯片,ICH(南桥)信息,在网上找方法。通过命令lspci | grep -i host\ bridge查看北桥芯片只今天想要在Linux下查看机器上MCH(北桥)芯片,ICH(南桥)信息,在网上找方法。通过命令lspci | grep -i …...