《PlaneRCNN-单幅图像的三维平面检测与重建》论文中英文对照解读

本文主要是介绍《PlaneRCNN-单幅图像的三维平面检测与重建》论文中英文对照解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

论文地址:https://arxiv.org/pdf/1812.04072.pdf
代码地址:https://github.com/art-programmer/PlaneNet


PlaneRCNN: 3D Plane Detection and Reconstruction from a Single Image

PlaneRCNN:单幅图像的三维平面检测与重建

Figure 1
EN: Figure 1. This paper proposes a deep neural architecture, PlaneRCNN, that detects planar regions and reconstructs a piecewise planar depthmap from a single RGB image. From left to right, an input image, segmented planar regions, estimated depthmap, and reconstructed planar surfaces.
CH: 图1.本论文提出了一种深度神经结构 PlaneRCNN,它可以检测平面区域并从单个RGB图像重建分段平面深度图。 从左到右,依次为输入图像,分段平面区域,估计深度图和重建平面表面。

Abstract
论文摘要

EN: This paper proposes a deep neural architecture, PlaneRCNN, that detects and reconstructs piecewise planar surfaces from a single RGB image. PlaneRCNN employs a variant of Mask R-CNN to detect planes with their plane parameters and segmentation masks. PlaneRCNN then jointly refines all the segmentation masks with a novel loss enforcing the consistency with a nearby view during training. The paper also presents a new benchmark with more finegrained plane segmentations in the ground-truth, in which, PlaneRCNN outperforms existing state-of-the-art methods with significant margins in the plane detection, segmentation, and reconstruction metrics. PlaneRCNN makes an important step towards robust plane extraction, which would have an immediate impact on a wide range of applications including Robotics, Augmented Reality, and Virtual Reality.
CH: 本论文提出了一种深度神经网络结构 PlaneRCNN,它可以从单个RGB图像中检测和重建分段平面。PlaneRCNN 为了检测出平面的平面参数和分割掩膜而采用了 Mask R-CNN 的变种算法。然后,PlaneRCNN 联合细化所有的分割掩膜,在训练期间形成一个新的 loss,强制得与该 loss 就近的视图保持一致。本文还提出了一个新的基准用于在真实样本中能有更细粒度的平面分割;其中,在平面检测,平面分割,重建平面的指标上,PlaneRCNN 性能要远优于现有的最先进的方法。而且 PlaneRCNN 向成熟稳健的平面检测迈出了重要的一步,这将对包括机器人技术,增强现实技术和虚拟现实在内的广泛应用产生直接影响。

1. Introduction
1. 引言

EN: Planar regions in 3D scenes offer important geometric cues in a variety of 3D perception tasks such as scene understanding , scene reconstruction , and robot navigation. Accordingly, piecewise planar scene reconstruction has been a focus of computer vision research for many years, for example, plausible recovery of planar structures from a single image, volumetric piecewise planar reconstruction from point clouds, and Manhattan depthmap reconstruction from multiple images.
CH: 3D场景中的平面区域为各种3D类的感知任务,例如场景理解,场景重建,和机器人导航等,提供了重要的几何信息;因此,分段平面场景重建一直是计算机视觉研究的焦点;比如,从单个图像中合理的恢复平面结构,从点云数据中进行体积分段平面重建,以及根据多个图像重建曼哈顿深度图。

EN: A difficult yet fundamental task is the inference of a piecewise planar structure from a single RGB image, posing two key challenges. First, 3D plane reconstruction from a single image is an ill-posed problem, requiring rich scene priors. Second, planar structures abundant in man-made environments often lack textures, requiring global image understanding as opposed to local texture analysis. Recently, PlaneNet and PlaneRecover made a breakthrough by introducing the use of Convolutional Neural Networks (CNNs) and formulating the problem as a plane segmentation task. While generating promising results, they suffer from three major limitations: 1) Missing small surfaces; 2) Requiring the maximum number of planes in a single image a priori; and 3) Poor generalization across domains (e.g., trained for indoors images and tested outdoors).
CH: 一个困难但基本的任务是从单个RGB图像中推断出来分段平面结构,这产生了两个关键的挑战。首先是:从单个图像重建3D平面是一个不稳定的命题,需要丰富的场景先验信息。其次是:在人造环境中丰富的平面结构通常缺乏质地纹理,需要全局图像理解而不是局部纹理分析。最近,PlaneNet 和 PlaneRecover 通过使用卷积神经网络(CNN)取得了突破性的进展,并将该问题描述为一个平面分割任务;虽然有了一些希望,但仍受到三个主要的制约:1.缺少小的平面,2.需要事先给出单个图像中的最大平面数,3.跨域的泛化能力比较差(比如室内图像的训练和室外的测试)。

EN: This paper proposes a novel deep neural architecture, PlaneRCNN, that addresses these issues and more effectively infers piecewise planar structure from a single RGB image (Fig. 1). PlaneRCNN consists of three components.
CH: 本论文提出了一种新型的深度神经网络结构-PlaneRCNN,它解决了以上问题,并能更加有效的从单个RGB图像中推断出该图像的分段平面结构(如图1)。PlaneRCNN由三部分组成。

EN: The first component is a plane detection network built upon Mask R-CNN [14]. Besides an instance mask for each planar region, we also estimate the plane normal and perpixel depth values. With known camera intrinsics, we can further reconstruct the 3D planes from the detected planar regions. This detection framework is more flexible and can handle an arbitrary number of planar regions in an image. To the best of our knowledge, this paper is the first to introduce a detection network, common in object recognition, to the depthmap reconstruction task. The second component is a segmentation refinement network that jointly optimizes extracted segmentation masks to more coherently explain a scene as a whole. The refinement network is designed to handle an arbitrary number of regions via a simple yet effective neural module. The third component, the warping-loss module, enforces the consistency of reconstructions with another view observing the same scene during training and improves the plane parameter and depthmap accuracy in the detection network via end-to-end training.
CH: 第一部分是建立在 Mask R-CNN 基础上的平面检测网络。除了每个平面区域的实例掩膜之外,我们还估计平面法线和每个像素的深度值。利用已知的相机内在函数,我们可以从检测到的平面区域进一步的重建3D平面。这个检测框架更加的灵活,可以处理一张图片里任意数量的平面区域。据我们所知,本论文是第一个将目标识别中常见的检测网络引入深度图重构任务中的。第二部分是一个分割细化网络,联合优化提取到的分割掩膜,以便于更加连贯一致的解释整个场景。这个细化网络通过设计一个简单但有效的神经模块来处理任意数量的平面。第三部分是翘曲损失模块,在训练中强制让同一个场景中不同视角观察的重建平面保持一致,在端到端的检测网络中提高平面参数和深度图的精度。

EN: The paper also presents a new benchmark for the piecewise planar depthmap reconstruction task. We collected 100,000 images from ScanNet and generated the corresponding ground-truth by utilizing the associated 3D scans. The new benchmark offers 14.7 plane instances per image on the average, in contrast to roughly 6 instances per image in the existing benchmark.
CH: 本论文还为分段平面深度图重建任务提出了一个新的基准。我们从 ScanNet (一个拥有标注过 3D 室内场景重构信息的大规模 RGB-D 数据集。)中搜集了100000张图像,并利用相关的3D扫描来生成对应的真实样本。这个新的基准平均每张图像可以提供14.7个平面实例,而现有的基准大致上一张图像才6个实例。

EN: The performance is evaluated via plane detection, segmentation, and reconstruction metrics, in which PlaneRCNN outperforms the current state-of-the-art with significant margins. Especially, PlaneRCNN is able to detect small planar surfaces and generalize well to new scene types.
CH: 通过平面检测、分割、重建作为评估性能的标准,PlaneRCNN 的效果要优于当下最新的技术水平,特别是,PlaneRCNN 能检测到小的平面,并能很好地应用到新的场景类型。

EN: The contributions of the paper are two-fold:
Technical Contribution: The paper proposes a novel neural architecture PlaneRCNN, where 1) a detection network extracts an arbitrary number of planar regions; 2) a refinement network jointly improves all the segmentation masks; and 3) a warping loss improves plane-parameter and depthmap accuracy via end-to-end training.
System Contribution: The paper provides a new benchmark for the piecewise planar depthmap reconstruction task with much more fine-grained annotations than before, in which PlaneRCNN makes significant improvements over the current state-of-the-art.
CH: 本论文的主要贡献有两方面:
技术贡献:本论文提出了一个新的神经网络结构:PlaneRCNN,分为三个模块:1.检测神经网络用来检测任意数量的平面区域,2.细化网络联合优化提取到的分割掩膜,3.翘曲损失模块通过端到端的训练提高平面参数和深度图的精度。
系统贡献:本论文为分段平面深度图重建任务提供了一个更加精细的评估基准,并且 PlaneRCNN 在当下最先进技术的基础上取得了重大提升。

2. Related Work
2. 相关工作

EN: For 3D plane detection and reconstruction, most traditional approaches require multiple views or depth information as input. They generate plane proposals by fitting planes to 3D points, then assign a proposal to each pixel via a global inference. Deng et al. proposed a learning-based approach to recover planar regions, while still requiring depth information as input.
CH: 对于3D平面检测及重建,大多数传统的处理方法需要多个视图或深度信息作为输入;他们将多个平面拟合成3D点来生成平面候选区域,然后通过一个全局推断来为每个像素点分配候选区域。Deng等人提出了一个基于学习的方法用来恢复平面区域,但该方法仍然需要深度信息的输入。

EN: Recently, PlaneNet revisited the piecewise planar depthmap reconstruction problem with an end-to-end learning framework from a single indoor RGB image. PlaneRecover later proposed an un supervised learning approach for outdoor scenes. Both PlaneNet and PlaneRecover formulated the task as a pixel-wise segmentation problem with a fixed number of planar regions (i.e., 10 in PlaneNet and 5 in PlaneRecover), which severely limits the expressiveness of their reconstructions and generalization capabilities to different scene types. We address these limitations by utilizing a detection network, commonly used for object recognition.
CH: 最近,PlaneNet 通过从单个的室内RGB图像得到的端到端的学习框架重新看待了分段平面深度图重建问题。PlaneRecover 后来提供了一种针对室外场景的非监督学习方法。PlaneRecover 和 PlaneNet 都将任务描述成一个有固定平面数量的像素分割问题,(i.e.:PlaneNet 的10个平面和 PlaneRecover 的5个平面)严重限制了不同场景类型重建和泛化能力的表现。我们用一般物体识别的检测网络处理了这些限制。

EN: Detection-based framework has been successfully applied to many 3D understanding tasks for objects, for example, predicting object shapes in the form of bounding boxes, wire-frames, or template-based shape compositions. However, the coarse representation employed in these methods lack the ability to accurately model complex and cluttered indoor scenes.
CH: 基于检测的框架现在已经成功得应用于许多3D理解得任务,比如:以边界框、线框、或基于组成模板得形状来预测物体形状。然而,这些方法中粗略得表示缺乏精确建模复杂混乱室内场景得能力。

EN: In addition to the detection, joint refinement of segmentation masks is also a key to many applications that require precise plane parameters or boundaries. In recent semantic segmentation techniques, fully connected conditional random field (CRF) is proven to be effective for localizing segmentation boundaries. CRFasRNN further makes it differentiable for end-to-end training. CRF only utilizes low-level information, and global context is further exploited via RNNs, more general graphical models, or novel neural architectural designs. These segmentation refinement techniques are NOT instance-aware, merely inferring a semantic label at each pixel and cannot distinguish multiple instances belonging to the same semantic category.
CH: 除了检测以外,分割掩膜得联合细化,对于一些需要精确平面参数和边界得应用来说,也很关键。在最近得语义分割技术中,全连接条件随机场(CRF)被证明了对于局部得分割边界是有效的,CRFasRNN 在端到端的训练中促进了它的可辨别性。CRF 使用的只是低级信息,通过 RNNs,更通用的图形模型,或者新型的神经架构设计进一步使用全局的上下文信息。这些分割细化技术不是实例感知的,仅仅是在每个像素上进行的推断,并不能区别多个实例属于同一个语义的种类。

EN: Instance-aware joint segmentation refinement poses more challenges. Traditional methods model the scene as a graph and use graphical model inference techniques to jointly optimize all instance masks. With a sequence of heuristics, these methods are often not robust. To this end, we will propose a segmentation refinement network that jointly optimizes an arbitrary number of segmentation masks on top of a detection network.
CH: 实例感知的联合分割细化造成了更多的挑战。传统的方法将场景当作图形来建模,然后使用图形的模型推理技术来联合优化所有的实例任务。通过一系列的启发式算法,这些方法经常表现得不够稳健。为此,我们提出了一个能在检测网络上联合优化任意数量分割掩码的分割细化网络。

3. Approach
3. 方法

EN: PlaneRCNN consists of three main components (See Fig. 2): a plane detection network, a segmentation refinement network, and a warping loss module. Built upon Mask R-CNN, the plane proposal network (Sec. 3.1) detects planar regions given a single RGB image and predicts 3D plane parameters together with a segmentation mask for each planar region. The refinement network (Sec. 3.2) takes all detected planar regions and jointly optimizes their masks. The warping loss module (Sec. 3.3) enforces the consistency of reconstructed planes with another view observing the same scene to further improve the accuracy of plane parameters and depthmap during training.
CH: PlaneRCNN 由三个模块构成:一个检测网络,一个分割细化网络和一个翘曲损失模块。基于 Mask R-CNN,这个平面候选网络(3.1节)给一个给定的RGB图像中检测平面区域,并且一起预测每个平面的3D平面参数和分割掩膜。这个细化网络(3.2节)拿到所有检测出来的平面区域联合优化它们的分割掩膜。翘曲损失模块(3.3节)通过在训练中强制保持同一场景观察到的不同视图的重建平面保持一致,进一步提高了平面参数和深度图的精度。

3.1. Plane Detection Network
3.1. 平面检测网络

EN: Mask R-CNN was originally designed for semantic segmentation, where images contain instances of varying categories (e.g., person, car, train, bicycle and more). Our problem has only two categories ”planar” or ”non-planar”, defined in a geometric sense. Nonetheless, Mask R-CNN works surprisingly well in detecting planes in our experiments. It also enables us to handle an arbitrary number of planes, where existing approaches need the maximum number of planes in an image a priori (i.e., 10 for PlaneNet and 5 for PlaneRecover ).
CH: Mask R-CNN 是被设计用来进行图像语义分割的,这些图像包含不同类别的实例(e.g.person, car, train, bicycle and more)。我们的问题中只含有两个类别:平面和非平面,是在几何意义下的。尽管如此,在我们的实验中 Mask R-CNN 在检测平面的表现依然好得出奇。目前其他的方法需要事先给出一个图像平面的最大数量(i.e., PlaneNet需要输入十个,PlaneRecover需要输五个 ),Mask R-CNN 能让我们处理任意数量的平面。
Figure 2
EN: Figure 2. Our framework consists of three building blocks: 1) a plane detection network based on Mask R-CNN, 2) a segmentation refinement network that jointly optimizes extracted segmentation masks, and 3) a warping loss module that enforces the consistency of reconstructions with a nearby view during training.
CH: 图二:我们的框架由三部分组成:1)一个基于 Mask R-CNN 的平面检测网络,2)一个用来联合优化提取的分割掩膜的分割细化网络,3)一个用来在训练中强制保持就近视图的重建平面一致的翘曲损失模块。

EN: We treat each planar region as an object instance and let Mask R-CNN detect such instances and estimate their segmentation masks. The remaining task is to infer 3D plane parameters, which consists of the normal and the offset information. While CNNs have been successful for depthmap and surface normal estimation, direct regression of plane offset turns out to be a challenge (even with the use of CoordConv). Instead of direct regression, we solve it in three steps: (1) predict a normal per planar instance, (2) estimate a depthmap for an entire image, and (3) use a simple algebraic formula (Eq. 1) to calculate the plane offset (which is differentiable for end-to-end training). We now explain how we modify Mask-RCNN to perform these three steps.
CH: 我们将每个平面区域当作可检测的对象实例,让 Mask R-CNN 去检测并估算它们的分割掩膜。剩下的任务是推断3D平面参数,包括法线和偏移信息。虽然 CNN 已经成功的用于深度图和平面法线的估算,但平面偏移的直接回归结果仍是个挑战(即使使用 CoordConv),不使用直接回归,我们用三步来解决它:1)预测每个平面实例的法线,2)估算整个图像的深度图,3)使用简单的代数公式(Eq.1)去计算平面偏移(在端到端的训练中是可区分的)。现在就来解释如何修改 Mask R-CNN 来实现这三步。

EN: Plane normal estimation: Directly attaching a parameter regression module after the ROI pooling produces reasonable results, but we borrow the idea of 2D anchor boxes for bounding box regression to further improve accuracy. More precisely, we consider anchor normals and estimate a plane normal in the local camera coordinate frame by 1) picking an anchor normal, 2) regressing the residual 3D vector, and 3) normalizing the sum to a unit-length vector.
CH: 平面法线的估算:在 ROL pooling 层后面附加上一个参数回归模块得到一个相对合理的结果,除此之外,我们还针对边界框回归借用了2D anchor box 的思想来进一步提高准确率。更确切的说我们认为锚定法线和在局部相机坐标系中估算平面法线要通过三步:1)选择一个锚定法线,2)3D残差向量的回归,3)将和标准化为单位长度向量。

EN: Anchor normals are defined by running the K-means clustering algorithm on the plane normals in 10, 000 randomly sampled training images. We use k = 7 and the cluster centers become anchor normals, which are up-facing, down-facing, and horizontal vectors roughly separated by 45◦ in our experiments (See Fig. 3).
CH: 通过在10000个随机采样的训练图像的平面法线上运行 K-means 聚类算法确定了锚定法线。我们设置 k 值为7,聚类中心为锚定法线,在我们的实验中,它们的方向是向上,向下还有和水平向量的夹角大致为45°。(看图三)

EN: We replace the object category prediction in the original Mask R-CNN with the anchor ID prediction, and append one separate fully connected layer to regress the 3D residual vector for each anchor normal (i.e., 21 = 3 × 7 output values). To generate supervision for each ground-truth plane normal, we find the closest anchor normal and compute the residual vector. We use the cross-entropy loss for the anchor normal selection, and the smooth L1 loss for the residual vector regression as in the bounding box regression of Mask R-CNN.
CH: 我们将原来 Mask R-CNN 中的目标类别检测替换为现在的锚点 ID 预测,并且为了每个锚定法线的3D残差向量回归添加了一个单独的全连接层。(i.e.21=3x7输出值)为了每个真实样本平面法线生成的有效性,我们找到最靠近的锚定法线并计算残差向量。我们用交叉熵损失来进行锚定法线的选择,用 L1 损失来进行残差向量的回归,就像 Mask R-CNN 网络里 bounding box 的回归。
FIgure 3
EN: Figure 3. We estimate a plane normal by first picking one of the 7 anchor normals and then regressing the residual 3D vector. Anchor normals are defined by running the K-means clustering algorithm on the ground-truth plane normal vectors.
CH: 图三:我们首先通过选取7个锚定法线中的一个来估算平面法线,然后回归3D残差向量。通过在真实样本的平面法线向量上运行 K-means 聚类算法确定锚定法线。

EN: Depthmap estimation: While local image analysis per region suffices for surface normal prediction, global image analysis is crucial for depthmap inference. We add a decoder after the feature pyramid network (FPN) in Mask R-CNN to estimate the depthmap D for an entire image. For the depthmap decoder, we use a block of 3 × 3 convolution with stride 1 and 4 × 4 deconvolution with stride 2 at each level. Lastly, bilinear upsampling is used to generate a depthmap in the same resolution as the input image (640 × 640).
CH: 深度图的估算:虽然局部图像分析的每个区域可以满足表面法线的预测,但全局图像分析对于深度图信息是很重要的。为了估算整个图像得深度图 D,我们在 Mask R-CNN 的 FPN(特征金字塔提取网络)后面加上了一个解码器。我们在这个深度图解码器的每一层都用了一个尺寸为 3x3,步长为 1 的卷积核和一个尺寸为 4x4,步长为 2 的卷积核。最后,利用双线性上采样的方法得到和输入图像尺寸(640 × 640)相同的深度图。

EN: Plane offset estimation: Given a plane normal n n n, it is straightforward to estimate the plane offset d d d:
d = ∑ i m i ( n T ( z i K − 1 x i ) ) ∑ i m i d={{\sum_{i}m_i(n^T(z_iK^{-1}x_i))}\over{\sum_{i}m_i}} d=imiimi(nT(ziK1xi))
where K K K is the 3 × 3 camera intrinsic matrix, x i x_i xi is the i t h i_{th} ith pixel coordinate in a homogeneous representation, z i z_i zi is its predicted depth value, and m i m_i mi is an indicator variable which becomes 1 if the pixel belongs to the plane. The summation is over all the pixels in the image. Note that we do not have a loss on the plane offset parameter, which did not make differences in the results. However, the plane offset influences the warping loss module below.
CH: 平面偏移估计:给定一个平面法线 n n n,简单的去估算平面偏移 d d d,公式如上;其中 K K K 是尺寸为 3x3 的相机内置矩阵, x i x_i xi 是齐次表示中的第 i t h i_{th} ith个像素坐标, z i z_i zi 是预测出来的深度值, m i m_i mi 是一个状态变量,就是如果这个像素属于这个平面就为 1。 这个总和要超过这个图像的所有像素。 注意,我们的平面偏移参数没有损失,不会对结果造成影响。但是平面偏移会对下面的翘曲损失产生影响。

3.2. Segmentation Refinement Network
3.2. 分割细化网络

EN: The plane detection network predicts segmentation masks independently. The segmentation refinement network jointly optimizes all the masks, where the major challenge lies in the varying number of detected planes. One solution is to assume the maximum number of planes in an image, concatenate all the masks, and pad zero in the missing entries. However, this does not scale to a large number of planes, and is prone to missing small planes.
CH: 平面检测网络独立检测分割掩膜。这个分割细化网络联合优化所有的掩膜,在这里主要的挑战是检测出来的平面数量不同。有一种解决方案是假定一张图像中平面的最大数量,然后联结所有的掩膜,把缺少的那部分用 0 填充。但是,这样做不能拓展到更多的平面,也容易丢失掉小的平面。

EN: Instead, we propose a simple yet effective module, ConvAccu, based on the idea of non-local module. ConvAccu processes each plane segmentation mask represented in the entire image window with a convolution layer. We then calculate and concatenate the mean feature volumes over all the other planes at the same level before passing to the next level (See Fig. 2). This resembles the non-local module and can effectively aggregate information from all the masks. We built an U-Net architecture using ConvAccu modules with details illustrated in Appendix A.
CH: 相反,我们基于 non-local 模块的思想。提出了一个简单并且有效的方法,ConvAccu。ConvAccu 用卷积层处理在整个图像中表示的每个平面分割掩膜。然后,我们计算并联结同一层面上的所有其他平面的平均特征量,并进入下一层面(见图二)。这种方式类似于 non-local 模块的思想,可以有效的聚合所有掩膜的信息。我们使用 ConvAccu 模块构造了 U-Net 结构,详细信息在附录A。

EN: Refined plane masks are concatenated at the end and compared against ground-truth with a cross-entropy loss. Note that besides the plane mask, the refinement network also takes the original image, the union of all the other plane masks, the reconstructed depthmap (for planar and non-planar regions), and a 3D coordinate map for the specific plane as input. The target segmentation mask is generated on the fly during training by assigning a ground-truth mask with the largest overlap. Planes without any assigned ground-truth masks do not receive supervision.
CH: 最后将精确的平面掩膜联结起来,使用交叉熵损失和真实样本进行比较。注意除了平面掩膜,分割细化网络还使用了原始图像,其他所有平面掩膜的并集,重建的深度图(对于平面和非平面区域),和特定平面的3D坐标图作为输入。在训练中通过分派有最大重叠的真实样本生成目标分割掩膜。没有分派真实样本掩膜的平面不会接受联结。

3.3. Warping Loss Module
3.3. 翘曲损失模块

EN: The warping loss module enforces the consistency of reconstructed 3D planes with a nearby view during training. Specifically, our training samples come from RGB-D videos in ScanNet, and the nearby view is defined to be the one 20 frames ahead from the current. The module first builds a depthmap for each frame by 1) computing depth values from the plane equations for planar regions and 2) using pixel-wise depth values predicted inside the plane detection network for the remaining pixels. Depthmaps are converted to 3D coordinate maps in the local camera coordinate frames (i.e., a 3D coordinate instead of a depth value per pixel) by using the camera intrinsic information.
CH: 翘曲损失模块在训练期间强制使附近视图的重建3D平面保持一致。我们的训练样本是 ScanNet 中的 RGB-D 视频,这个附近视图被明确规定为是当下一帧的前二十帧。这个模块首先通过两点(1.从平面等式中计算平面区域的深度值,2.在平面检测网络里给剩余的像素点用像素点的深度信息预测)给每一帧图像构造一个深度图。在局部相机坐标系中(i.e.每个像素点的3D坐标而不是深度信息),使用相机的内在信息,将深度图转化为3D坐标图。

EN: The warping loss is then computed as follows. Let M c M_c Mc and M n M_n Mn denote the 3D coordinate maps of the current and the nearby frames, respectively. For every 3D point P n P_n Pn(∈ M n M_n Mn) in the nearby view, we use the camera pose information to project to the current frame, and use a bilinear interpolation to read the 3D coordinate P c P_c Pc from M c M_c Mc. We then transform P c P_c Pc to the coordinate frame of the nearby view based on the camera pose and compute the 3D distance between the transformed coordinate P c t P^t_c Pct and P n P_n Pn. L2 norm of all such 3D distances divided by the number of pixels is the loss. We ignore pixels that project outside the current image frame during bilinear interpolation.
CH: 然后如下计算这个翘曲损失模块。让 M c M_c Mc M n M_n Mn 分别表示当前帧和临近帧的3D坐标图。对于每个临近视图中的3D点 P n P_n Pn(∈ M n M_n Mn),我们使用相机姿态信息来投射到当前帧,并且使用双线性插值从 M c M_c Mc 中读取3D坐标 P c P_c Pc 。然后我们基于相机姿态将 P c P_c Pc 转换到临近视图的坐标系,并且计算变换后的坐标 P c t P^t_c Pct P n P_n Pn 的3D距离。所有这种3D距离的 L2 范数除以像素点的数量就是这个损失。我们忽略在双线性插值期间投射到当前帧之外的像素点。

EN: The projection, un-projection, and coordinate frame transformation are all simple algebraic operations, whose gradients can be passed for training. Note that the warping loss module and the nearby view is utilized only during training to boost geometric reconstruction accuracy, and the system runs on a single image at test time.
CH: 投射,非投射和坐标系变换都是简单的代数运算,梯度是通过训练的。注意这个翘曲损失模块和临近视图仅仅是在训练中为了提高几何重建精度而使用的,而且,这个系统在测试的时候是在单个图像上运行的。

4. Benchmark construction
4. 基准构造

EN: Following steps described in PlaneNet, we build a new benchmark from RGB-D videos in ScanNet. We add the following three modifications to recover more fine-grained planar regions, yielding 14.7 plane instances per image on the average, which is more than double the PlaneNet dataset containing 6.0 plane instances per image.
CH: 根据在 PlaneNet 中的步骤描述,我们从 ScanNet 的 RGB-D 视频中构造了一个新的基准。我们加了如下三个修改来恢复更细粒度的平面区域,平均每张图有 14.7 个平面实例,比 PlaneNet 中提到的每张图的 6 个平面的二倍还要多。

EN: First, we keep more small planar regions by reducing the plane area threshold from 1% of the image size to 0.16% (i.e., 500 pixels) and not dropping small planes when the total number is larger than 10.
Second, PlaneNet merges co-planar planes into a single region as they share the same plane label. The merging of two co-planar planes from different objects causes loss of semantics. We skip the merging process and keep all instance segmentation masks.
Third, the camera pose quality in ScanNet degrades in facing 3D tracking failures, which causes misalignment between image and the projected ground-truth planes. Since we use camera poses and aligned 3D models to generate ground-truth planes, we detect such failures by the discrepancy between our ground-truth 3D planes and the raw depthmap from a sensor. More precisely, we do not use images if the average depth discrepancy over planar regions is larger than 0.1m. This simple strategy removes approximately 10% of the images.
CH: 第一:我们通过将平面区域的阈值从图片尺寸的 1% 降低到了 0.16%(i.e.500个像素点)来保留更多的小平面区域,并且当平面数大于10时,不丢弃小的平面。
第二:PlaneNet 把一些共平面合并为一个单独的平面为了让它们有相同的平面类别。 这种从不同实例合并平面的方式会丢失掉语义信息。我们跳过了这个合并过程,保留了所有的实例分割掩膜。
第三:ScanNet 里的相机姿态质量在3D追踪失败的时候会降低,这就导致了图像与真实实例平面的投射会发生不重合的情况。自从我们使用相机姿态和对齐的3D模型来生成真实实例平面,我们通过比较生成的真实实例平面和来自传感器的原始深度图的差异来检测这种失败。更确切的来说,如果在平面区域上的平均深度差值大于 0.1m 我们就不会使用这张图片。这个简单的策略大约可以删除 10% 的图片。

5. Experimental results
5. 实验结果

EN: We have implemented our network in PyTorch. We use pre-trained Mask R-CNN and initialize the segmentation refinement network with the existing model. We train the network end-to-end on an NVIDIA TitanX GPU for 10 epochs with 100,000 randomly sampled images from training scenes in ScanNet. We use the same scale factor for all losses. For the detection network, we scale the image to 640 × 480 and pad zero values to get a 640 × 640 input image. For the refinement network, we scale the image to 256 × 192 and align the detected instance masks with the image based on the predicted bounding boxes.
CH: 我们已经用 PyTorch 实现了我们的网络结构。我们使用 Mask R-CNN 的预训练模型进行训练,并使用现有的模型初始化分割细化网络。我们使用 ScanNet 训练场景里的随机100,000张实例图片在 NVIDIA TitanX GPU 上进行了十轮端到端的训练。我们对所有的 loss 采用同样的比例系数。对于检测网络,我们将图像缩放成 640 × 480 的尺寸,并用 0 填充成 640 × 640 的尺寸用作网络输入。对于分段网络,我们将图像缩放成 256 × 192 的尺寸,并基于预测的 bounding boxes 将检测到的实例掩膜和图像对齐。
Figure 4
EN: Figure 4. Plane-wise accuracy against baselines. PlaneRCNN outperforms all the competing methods except when the depth threshold is very small and MWS-G can fit 3D planes extremely accurately by utilizing the ground truth depth values.
CH: 图四:平面检测的基准对比。PlaneRCNN 要优于所有的竞赛方法,除了当深度阈值非常小的时候 MWS-G 能利用真实实例深度值非常准确的拟合3D平面。

5.1. Qualitative evaluations
5.1. 实验评估

EN: Fig. 5 demonstrates our reconstructions results for ScanNet testing scenes. PlaneRCNN is able to recover planar surfaces even for small objects. We include more examples in Appendix B.
CH: 图五:在 ScanNet 的测试场景上演示我们模型的3D重建结果。PlaneRCNN 即便是小的实例也能恢复平面信息。在附录B中有更多的示例。
Figure 5
EN: Figure 5. Piecewise planar reconstruction results by PlaneRCNN.
CH: 图五:PlaneRCNN 的分段平面重建结果。

EN: Fig. 6 compares PlaneRCNN against two competing methods, PlaneNet and PlaneRecover, on a variety of scene types from unseen datasets (except the SYNTHIA dataset is used for training by PlaneRecover). Note that PlaneRCNN and PlaneNet are trained on the ScanNet which contains indoor scenes, while PlaneRecover is trained on the SYNTHIA dataset (i.e., the 7th and 8th rows in the figure) which consist of synthetic outdoor scenes. The figure shows that PlaneRCNN is able to reconstruct most planes in varying scene types from unseen datasets regardless of their sizes, shapes, and textures. In particular, our results on the KITTI dataset are surprisingly better than PlaneRecover for planes close to the camera. In indoor scenes, our results are consistently better than both PlaneNet and PlaneRecover. We include more examples in Appendix B.
CH: 图六:在未知的数据集的各种场景类型下(除了 SYNTHIA 数据集被 PlaneRecover 用来训练)比较 PlaneRCNN 和两个竞赛方法(PlaneNet 和 PlaneRecover)的检测效果。注意 PlaneRCNN 和PlaneNet 是在 ScanNet 的室内数据集训练的,PlaneRecover 是用SYNTHIA 室外数据集训练的。(i.e.在图的第七行和第八行)这个图展示的是在未知的数据集上,不管它们的尺寸,形状和内容,PlaneRCNN 都能够重建不同场景类型的大部分平面。特别是,在 KITTI 数据集上,靠近相机的平面,我们的结果要出乎意料的比 PlaneRecover 的效果好。在室内的场景中,我们的效果也比 PlaneNet 和 PlaneRecover都要好。在附录B中有更多的示例。
Figure 6
EN: Figure 6. Plane segmentation results on unseen datasets without
fine-tuning.
CH: 图六:未知的数据集的识别结果。

5.2. Plane reconstruction accuracy
5.2. 平面重建准确率

EN: Following PlaneNet, we evaluate plane detection accuracy by measuring the plane recall with a fixed Intersection over Union (IOU) threshold 0.5 and a varying depth error threshold (from 0 to 1m with an increment of 0.05m). The accuracy is measured inside the overlapping regions between the ground-truth and inferred planes. Besides PlaneNet, we compare against Manhattan World Stereo (MWS), which is the most competitive tradi-tional MRF-based approach as demonstrated in prior evaluations. MWS requires a 3D point cloud as an input, and we either use the point cloud from the groundtruth 3D planes (MWS-G) or the point cloud inferred by our depthmap estimation module in the plane detection network (MWS). PlaneRecover was originally trained with the assumption of at most 5 planes in an image. We find it difficult to train PlaneRecover successfully for cluttered indoor scenes by simply increasing the threshold. We believe that PlaneNet, which is explicitly trained on ScanNet, serves as a stronger competitor for the evaluation.
CH: 在 PlaneNet 之后,我们通过测量固定 IOU 阈值为0.5和非固定深度误差阈值(0-1m,增量为0.05m)的平面召回量来评判平面检测的准确性。这个准确性是在真实样本和检测出样本的重叠区域下计算测量的。除了 PlaneNet 之外,我们还和 Manhattan World Stereo (MWS) 进行了比较,作为之前评估演示的,这是最具竞争力的传统的 MRF 算法。MWS 需要3D点云数据作为输入,我们可以用真实样本的3D点云数据,也可以用我们平面检测网络中的深度图估计模块推算的点云数据。PlaneRecover 最初训练的是假设一张图5个平面。我们发现很难通过简单的提高阈值来使 PlaneRecover 在杂乱无章的室内场景中训练成功。我们相信,在这个评估中,在 ScanNet 上明确训练的 PlaneNet 可以作为一个强劲的对手。

EN: As demonstrated in Fig. 4, PlaneRCNN significantly outperforms all other methods, except when the depth threshold is small and MWS-G can fit planes extremely accurately with the ground-truth depth values. Nonetheless, even with ground-truth depth information, MWS-G fails in extracting planar regions robustly, leading to lower recalls in general. Our results are superior also qualitatively as shown in Fig. 7
CH: 如图四所示,PlaneRCNN 已经显著的优于其他所有的方法,除了当深度阈值非常小的时候 MWS-G 能利用真实实例深度值非常准确的拟合3D平面。但是,即使有真实样本的深度信息,MWS-G 还是失败在平面区域提取上,导致一般情况下召回率的降低。我们的结果是更优的,如图七所示。
Figure 7
EN: Figure 7. Plane segmentation comparisons. From left to right: input image, MWS with inferred depths, MWS with ground-truth depths, PlaneNet, Ours, and ground-truth.
CH: 图七:平面分割对比。

5.3. Geometric accuracy
5.3. 几何精确度

EN: We propose a new metric in evaluating the quality of piecewise planar surface reconstruction by mixing the inferred depthmaps and the ground-truth plane segmentations. More precisely, we first generate a depthmap from our reconstruction by following the process in the warping loss evaluation (Sec. 3.3). Next, for every ground-truth planar segment, we convert depth values in the reconstructed depthmap to 3D points, fit a 3D plane by SVD, and normalize the plane coefficients to make the normal component into a unit vector. Finally, we compute the mean and the area-weighted mean of the parameter differences to serve as the evaluation metrics. Besides the plane parameter metrics, we also consider depthmap metrics commonly used in the literature. We evaluate over the NYU dataset for a fair comparison. Table 1 shows that, with more flexible detection network, PlaneRCNN generalizes much better without fine-tuning. PlaneRCNN also outperforms PlaneNet in every metric after fine tuning using the ground-truth depths from the NYU dataset.
CH: 我们提出了一个新的方法,来评估分段平面重建的好坏,即通过联合检测的深度图和真实样本的平面分割。更准确的说,我们首先通过翘曲损失评估的过程,从重建中生成深度图;然后,对于每个真实样本平面片段,我们把重建的深度图中的深度值转换成3D点,通过 SVD 拟合3D平面,通过归一化平面系数将法向量变成单位向量;最后,我们计算参数差异的均值和面积加权均值作为评估指标。除了这个平面参数标准以外,我们也使用论文中常用的深度图评估标准。为了一个公平的比较环境,我们在 NYU 的数据集上进行评判。表1显示:通过更灵活的检测网络,PlaneRCNN 在不经过 fine-tuning 的情况下也有比较好的泛化性。PlaneRCNN 在经过 NYU 的数据集样本的 fine-tuning 训练后在每个评估指标上都要优于PlaneNet。
Table 1

5.4. Ablation studies
5.4. 模型简化测试

EN: PlaneRCNN adds the following components to the Mask R-CNN backbone: 1) the pixel-wise depth estimation network; 2) the anchor based plane normal regression; 3) the warping loss module; and 4) the segmentation refinement network. Contribution of each component, we measure performance changes while adding the components one by one. Following, we evaluate the plane segmentation quality by three clustering metrics: variation of information (VOI), Rand index (RI), and segmentation covering ( SC). To further assess the geometric accuracy, we compute the average precision (AP) with IOU threshold 0.5 and three different depth error thresholds [0.4m, 0.6m, 0.9m]. A larger value means higher quality for all the metrics except For VOI.
CH: PlaneRCNN 在 Mask R-CNN 的主干网络里添加了以下组件:1)像素点的深度估计网络,2)以锚点为基础的平面法线回归,3)翘曲损失模块,4)分割细化网络。为了明确每个组件的贡献程度,我们通过一个一个的添加这些组件,然后测量比较性能的改变。接着,我们评估这个分割的好坏通过三个指标:信息差异指标(VOI),兰德指数(RI)和分割覆盖(SC)。为了更进一步的评估几何精度,我们用 IOU 阈值为0.5和三个不同的深度误差阈值[0.4m, 0.6m, 0.9m]来计算平均精度(AP)。值越大意味着除了VOI之外所有的指标的可参考度越高。
Figure 8
EN: Figure 8. Effects of the segmentation refinement network and the warping loss module. Top: the refinement network narrows the gap between adjacent planes. Bottom: the warping loss helps to correct erroneous plane geometries using the second view.
CH: 图八:分割细化网络和翘曲损失模块的影响度

EN: Table 2 shows that all the components have a positive contribution to the final performance. Fig. 8 further highlights the contributions of the warping loss module and the segmentation refinement network qualitatively. The first example shows that the segmentation refinement network fills in gaps between adjacent planar regions, while the second example shows that the warping loss module improves reconstruction accuracy with the help from the second view.
CH: 表2展示了所有的组件对于模型最终性能的积极贡献。图八进一步突出了分割细化网络和翘曲损失模块的贡献。第一个例子表明分割细化网络可以更好的填充相邻平面之间的间隙,第二个例子表明翘曲损失模块在第二个视图的帮助下提高了重建任务的精度。
Table 2
EN: Table 2. Ablation studies on the contributions of the four components in PlaneRCNN. Plane segmentation and detection metrics are calculated over the ScanNet dataset. PlaneNet represents the competing state-of-the-art.
CH: 表二。关于 PlaneRCNN 中四个组件的模型简化测试。平面分割和检测指标是在 ScanNet 数据集上计算的。PlaneNet 代表的是最先进的技术水平。

5.5. Occlusion reasoning
5.5. 遮挡推理

EN: A simple modification allows PlaneRCNN to infer occluded/invisible surfaces and reconstruct layered depthmap models. We add one more mask prediction module to PlaneRCNN to infer the complete mask for each plane instance.
CH: 一个简单的改变可以让 PlaneRCNN 推断出被遮挡的平面并且重建分层的深度图模型。我们向 PlaneRCNN 中添加了一个掩膜预测模块,为了推断出每个平面实例的完整掩膜。

EN: The key challenge for training the network with occlu-sion reasoning is to generate ground-truth complete mask for supervision. In our original process, we fit planes to aligned 3D scans to obtain ground-truth 3D planar surfaces, then rasterize the planes to an image with a depth testing. We remove the depth testing and generate a “complete mask” for each plane. Besides disabling depth checking, we further complete the mask for layout structures based on the fact that layout planes are behind other geometries. First, we collect all planes which have layout labels (e.g., wall and floor), and compute the convexity and concavity between two planes in 3D space. Then for each combination of these planes, we compute the corresponding complete depthmap by using the greater depth value for two convex planes and using the smaller value for two concave ones. A complete depthmap is valid if 90% of the complete depthmap is behind the visible depthmap (with 0.2m tolerance to handle noise). We pick the valid complete depthmap which has the most support from visible regions of layout planes.
CH: 训练含有遮挡推理网络的关键挑战是监督生成真实实例的完整掩膜。在我们的原始过程中,我们拟合被校准3D扫描的平面获得真实实例的3D平面,然后用深度测试将平面栅格化为图像。我们移除每个平面的深度测试并且生成一个完整的掩膜。除了禁用深度测试以外,我们基于布局平面落后于其他的几何体的事实进一步的完善了用于布局平面的掩膜。首先,我们收集所有具有布局标签的平面(e.g.墙和门),并且计算两个平面在3D空间的凹凸度。然后对于这些平面的每种组合,我们通过对凸面平面用较大的深度值,对凹面平面用较小的深度值, 来计算对应的完整的深度图。如果90%的完整深度图在可见深度图之后(噪声容差为0.2m),那么这个完整深度图是有效的。我们挑选的有效完整深度图是布局平面的可见区域最支持的。

EN: Fig. 9 shows the new view synthesis examples, in which the modified PlaneRCNN successfully infers occluded surfaces, for example, floor surfaces behind tables and chairs. Note that a depthmap is rendered as a depth mesh model (i.e., a collection of small triangles) in the figure. The layered depthmap representation enables new applications such as artifacts-free view synthesis, better scene completion, and object removal. This experiment demonstrates yet another flexibility and potential of the proposed PlaneRCNN architecture.
CH: 图九展示了新视图的合成例子,其中修改过后的 PlaneRCNN 成功的推测出了被遮挡的平面,例如桌子和椅子后面的地板表面。注意深度图被渲染成图中的深度网格模型(i.e.小三角形的集合)。这个分层的深度图显示可以实现新的应用,例如不掺杂人工的视图合成,更好的场景完善和目标移除。这个实验还验证了提出的 PlaneRCNN 架构的其他灵活性和潜能。
Figure 9
EN: Figure 9. New view synthesis results with the layered depthmap models. A simple modification allows PlaneRCNN to also infer occluded surfaces and reconstruct layered depthmap models.
CH: 图九:用分层深度图模型的新视图合成结果。一个简单的改变可以让 PlaneRCNN 推断出被遮挡的平面并且重建分层的深度图模型。

6. Conclusion and future work
6. 结论及未来的展望

EN: This paper proposes PlaneRCNN, the first detection based neural network for piecewise planar reconstruction from a single RGB image. PlaneRCNN learns to detect planar regions, regress plane parameters and instance masks, globally refine segmentation masks, and utilize a neighboring view during training for a performance boost. PlaneRCNN outperforms competing methods by a large margin based on our new benchmark with fine-grained plane annotations. An interesting future direction is to process an image sequence during inference which requires learning correspondences between plane detections.
CH: 本篇论文提出的 PlaneRCNN,是第一个用于单张RGB图像检测并分段重建3D平面的神经网络。PlaneRCNN 学习检测平面区域,平面参数回归,实例化掩膜,全局细化分割掩膜,以及在训练中利用临近视图来提高最终的性能。PlaneRCNN 在我们基于细粒度平面注释的新基准上,大幅的超越其他的竞赛方法。未来一个有趣的方向是在平面检测中需要学习呼应的推断期间去处理图像序列。

Appendices
附录

EN: Refinement of the Network Architecture In Figure 10, we illustrate the detailed architecture of the segmentation refinement network to support the descriptions shown in Figures 2 and 2. 3.2.
CH: 在图十中详细说明了分割细化网络的详细体系结构。
Figure 10
EN: Figure 10. Refinement network architecture. The network takes both global information (i.e., the input image, the reconstructed depthmap and the pixel-wise depthmap) and instance-specific information (i.e., the instance mask, the union of other masks, and the coordinate map of the instance) as input and refines instance mask with a U-Net rchitecture. Each convolution in the encoder is replaced by a ConvAccu module to accumulate features from other masks.
CH: 图十:细化网络的结构。这个网络同时接受全局信息(i.e.输入图片,重建的深度图和像素级的深度图)和特定实例的信息(I.e.实例化掩膜,其他掩膜的并集,实例的坐标图)作为输入,并且用一个 U-Net 结构细化实例掩膜。编码器中的每个卷积都被 ConvAccu 模块所取代,为了从其他掩膜中积累特征。

EN: More qualitative results. We show more qualitative results of our method, PlaneRCNN, on the test scenes from ScanNet in Fig. 11 and Fig. 12.
CH: 更多的识别结果。
Figure 11
Figure 12

个人网站:心安便是归处
GitHub:oh,ss

这篇关于《PlaneRCNN-单幅图像的三维平面检测与重建》论文中英文对照解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis与缓存解读

《Redis与缓存解读》文章介绍了Redis作为缓存层的优势和缺点,并分析了六种缓存更新策略,包括超时剔除、先删缓存再更新数据库、旁路缓存、先更新数据库再删缓存、先更新数据库再更新缓存、读写穿透和异步... 目录缓存缓存优缺点缓存更新策略超时剔除先删缓存再更新数据库旁路缓存(先更新数据库,再删缓存)先更新数

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

hdu1240、hdu1253(三维搜索题)

1、从后往前输入,(x,y,z); 2、从下往上输入,(y , z, x); 3、从左往右输入,(z,x,y); hdu1240代码如下: #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#inc

hdu4826(三维DP)

这是一个百度之星的资格赛第四题 题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1004&cid=500 题意:从左上角的点到右上角的点,每个点只能走一遍,走的方向有三个:向上,向下,向右,求最大值。 咋一看像搜索题,先暴搜,TLE,然后剪枝,还是TLE.然后我就改方法,用DP来做,这题和普通dp相比,多个个向上

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

AI hospital 论文Idea

一、Benchmarking Large Language Models on Communicative Medical Coaching: A Dataset and a Novel System论文地址含代码 大多数现有模型和工具主要迎合以患者为中心的服务。这项工作深入探讨了LLMs在提高医疗专业人员的沟通能力。目标是构建一个模拟实践环境,人类医生(即医学学习者)可以在其中与患者代理进行医学

MCU7.keil中build产生的hex文件解读

1.hex文件大致解读 闲来无事,查看了MCU6.用keil新建项目的hex文件 用FlexHex打开 给我的第一印象是:经过软件的解释之后,发现这些数据排列地十分整齐 :02000F0080FE71:03000000020003F8:0C000300787FE4F6D8FD75810702000F3D:00000001FF 把解释后的数据当作十六进制来观察 1.每一行数据

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL