第五章 图像处理

文章目录

  • 前言
  • 一、图像金字塔
    • 1.高斯金字塔
    • 2.拉普拉斯金字塔
  • 二、图像轮廓
    • 1. 轮廓提取
    • 2. 轮廓绘制
    • 3. 轮廓特征
    • 4. 轮廓近似
    • 5. 轮廓标记
  • 三、模板匹配
  • 四、直方图
    • 1. 对比度
    • 2. 绘制直方图
    • 3. 均衡化
      • 3.1 理论
      • 3.2 代码
    • 4. CLAHE
  • 五、图像傅里叶变换
  • 总结


前言

本章讲讲解图像处理相关内容,包括图像金字塔、图像轮廓模板提取、直方图、图像傅里叶变换等。

一、图像金字塔

  • 含义: 图像金字塔是一种用于图像处理和计算机视觉的技术。它是一系列图像的集合,其中每个图像比前一个图像分辨率更低, 从而形成一种金字塔形的结构。这些图像可以由同一图像的不同分辨率版本生成,也可以是不同图像之间的扫描和缩小。
  • 作用: 在图像增强中,可以将图像分解为一系列不同分辨率的图像,然后对每个分辨率级别的图像进行处理,最终将它们合成为一张增强后的图像。在图像检测中,可以使用金字塔技术进行对象的尺度不变性检测。在目标跟踪中,可以在不同的尺度上搜索目标。
    在这里插入图片描述

1.高斯金字塔

  • 向下采样(缩小 图片):
    1. 首先进行高斯滤波
    2. 去除偶数的行、列
  • 向上采样(放大图片):
    1. 用零填充偶数行、列
      [ 10 30 56 96 ] ⇒ [ 10 0 30 0 0 0 0 0 56 0 96 0 0 0 0 0 ] \begin{bmatrix} 10& 30\\ 56&96\end{bmatrix}\Rightarrow \begin{bmatrix} 10 & 0 & 30 & 0\\ 0& 0 & 0 & 0\\ 56& 0& 96 &0 \\ 0& 0& 0&0\end{bmatrix} [10563096] 10056000003009600000
    2. 对放大的图片进行高斯卷积,从而可对零值进行填充
# 向上采样
cv2.pyrUp(src[, dst[, dstsize[, borderType]]]) -> dst
# 向下采样
cv2.pyrDown(src[, dst[, dstsize[, borderType]]]) -> dst

2.拉普拉斯金字塔

I i + 1 = I i − P y r U p ( p y r D o w n ( I i ) ) I_{i+1} = I_i - PyrUp(pyrDown(I_i)) Ii+1=IiPyrUp(pyrDown(Ii))
执行上面的公式,就能得到每一层的图像。

拉普拉斯金字塔和高斯金字塔是图像金字塔的两个重要概念,它们之间有以下不同点:

  1. 算法步骤不同:高斯金字塔是由原始图像不断进行下采样(降分辨率)和高斯滤波得到的,每次下采样都将图像的尺寸减半。而拉普拉斯金字塔则是由高斯金字塔依次上采样(放大)和减去对应的低分辨率图像得到的。

  2. 不同的金字塔目的:高斯金字塔主要用于图像降采样(缩小)和尺度空间分析,可以用于图像的尺度不变性特征描述,如SIFT、SURF算法等。拉普拉斯金字塔则主要用于对图像进行增强、边缘检测和图像融合等操作。

  3. 金字塔层数和大小:高斯金字塔的层数与原始图像的大小有关,尺寸越大,高斯金字塔的层数也就越多。而拉普拉斯金字塔通常与高斯金字塔大小相同,因为它是由高斯金字塔得到的。

  4. 局部特征信息:尽管可逆性和单尺度不变性有用,但仅仅用于描述局部特征时可能不够准确。因此,拉普拉斯金字塔通常能够提供比高斯金字塔更丰富的局部特征信息。

因此,根据不同的应用场景,可以选择高斯金字塔或拉普拉斯金字塔等适合的金字塔结构来处理图像。

二、图像轮廓

1. 轮廓提取

contours, hierarchy = cv2.findContours(image, mode, method[, contours[, hierarchy[, offset]]])

其中:

  • image:输入的图像,应该是二值图像,每个像素的值要么为0,要么为255,表示前景和背景两种颜色。
  • mode:轮廓检索模式,是一个枚举值,取值范围包括:
    • cv2.RETR_EXTERNAL:只检测最外层的轮廓,即只返回边缘轮廓;
    • cv2.RETR_LIST:检测所有的轮廓,并返回其完整的列表;
    • cv2.RETR_CCOMP:检测所有的轮廓,但只返回两级轮廓结构,即外层轮廓和内层轮廓;
    • cv2.RETR_TREE:检测所有的轮廓,并返回完整的轮廓树结构。
  • method:轮廓近似方法,是一个枚举值,取值范围包括:
    • cv2.CHAIN_APPROX_NONE:存储所有的轮廓点,每个点的坐标(x,y)都存储;
    • cv2.CHAIN_APPROX_SIMPLE:仅保留轮廓的端点,只需存储它们的坐标即可,例如矩形轮廓仅需要4个点的坐标即可。
  • contours:输出参数,返回检测到的轮廓,每个轮廓是一个由像素坐标表示的Numpy数组。
  • hierarchy:输出参数,返回轮廓的层级关系,每个轮廓由4个值(父级轮廓编号,下一级轮廓编号,第一个子级轮廓编号,前一个兄弟轮廓编号)表示。
    hierarchy的理解

2. 轮廓绘制

cv2.drawContours()是OpenCV提供的一个函数,能够在图像中绘制轮廓。

该函数的语法如下:

cv2.drawContours(image, contours, contourIdx, color, thickness=None, lineType=None, hierarchy=None, maxLevel=None, offset=None)

参数解释如下:

  • image: 要绘制轮廓的图像。
  • contours: 一个由轮廓点集组成的列表,可以通过cv2.findContours()函数获取。该参数可以是一个单独的轮廓(Point集合),也可以是多个轮廓的列表。
  • contourIdx: 指定要绘制的轮廓的编号。如果是负数,则表示要绘制所有的轮廓。
  • color: 轮廓颜色,可以是RGB元组或BGR元组。
  • thickness: 轮廓线条粗细,默认值为1.
  • lineType: 线条类型,默认值为8-connectivity(即cv2.LINE_8),也可以设置为4-connectivity(即cv2.LINE_4)或CV_AA。
  • hierarchy: 轮廓层级信息,可选参数。
  • maxLevel: 可以绘制的轮廓的最大级别,可选参数。
  • offset: 轮廓计算的偏移量,可选参数。

3. 轮廓特征

在OpenCV中,对于图像中的轮廓,有许多特征可以用来描述和分析这些轮廓。下面列出了一些主要的轮廓特征:

  1. 轮廓面积:轮廓曲线所包含的面积大小,可以用cv2.contourArea()函数计算。

  2. 轮廓周长:轮廓曲线的长度,可以用cv2.arcLength()函数计算。

  3. 轮廓近似:通过降低轮廓点数目来近似表示轮廓形状,可以用cv2.approxPolyDP()函数进行处理。

  4. 轮廓重心:轮廓曲线所包含区域的质心点坐标,可以用cv2.moments()函数计算。

  5. 轮廓方向:轮廓曲线的方向,可以用cv2.fitEllipse()cv2.minAreaRect()函数分别拟合椭圆或矩形来计算。

  6. 轮廓凸包:包含轮廓曲线所有点的凸边形,可以用cv2.convexHull()函数计算。

  7. 轮廓缺陷:凸包与轮廓曲线之间的差距,可以用cv2.convexityDefects()函数计算。

这些轮廓特征可以结合使用,用来分析图像中的轮廓形状和特征。在实际应用中,轮廓特征常常被用来进行目标检测、图像分类和图像识别等任务。

4. 轮廓近似

  • 原理: 在这里插入图片描述
    首先连接A、B两点,然后在弧线AB上找一点,使得该点到直线AB上的距离最大,记该点为C,该距离为d,若d小于指定的数值,则用直线AB代替弧线AB,否则则以C为中间点,再分别判断弧线AC与弧线CB的近似。

在OpenCV中,cv2.approxPolyDP()函数可以对轮廓进行近似处理,以减少轮廓点的数量,简化轮廓曲线,从而提高图像处理的效率。该函数的语法如下:

cv2.approxPolyDP(curve, epsilon, closed[, approxCurve])

参数解释如下:

  • curve: 输入的轮廓,一般是一个由点组成的列表或Numpy数组。
  • epsilon: 指定近似程度,即对轮廓的最大误差。如果指定的距离小于epsilon,那么就会被认为是同一曲线上的点。
  • closed: 指定是否是闭合曲线,如果为True,表示曲线是闭合的,否则为打开的曲线。
  • approxCurve: 输出的近似轮廓,可以是numpy数组或空对象。如果不指定输出数组,则函数会返回近似轮廓的坐标点数组。

该函数的返回值表示的是近似轮廓的坐标点,可以通过对输出数组的大小来确定近似后曲线上的点的数量。epsilon的值受影响因素较多,需要根据具体情况进行设定。

近似处理的效果往往受到调节参数的影响,如果epsilon设置得过小,处理得过度,则可能会丢失重要的轮廓信息;如果epsilon设置得过大,则可能会保留过多的轮廓信息,增加了计算量,并且可能导致轮廓的误检和漏检等问题。因此,在进行轮廓近似时,需要根据具体情况进行参数的调适,以达到最佳的处理效果。

5. 轮廓标记

  • 作用: 用一个形状(矩形、圆圈等)将轮廓标记出来。
# 背景画布
canvabg = img.copy()
# 获取轮廓
cnt0 = contours[0]
# 矩形边框
startx,starty,width,height = cv2.boundingRect(cnt0)
cv2.rectangle(canvabg,(startx,starty),(startx + width,starty + height),(0,255,0),2)
# 获取轮廓
cnt1 = contours[2]
# 圆圈外框
(cx,cy),radius = cv2.minEnclosingCircle(cnt1)
cv2.circle(canvabg,(int(cx),int(cy)),int(radius),(255,0,0),2)

在这里插入图片描述

三、模板匹配

  • 思路: 将模板图片当作卷积核与被匹配的图像进行卷积操作,然后根据具体匹配算法计算出每一步卷积操作的置信度,根据置信度来确定模板图像在被匹配图像中的位置。

在OpenCV中,使用cv2.matchTemplate()函数可以实现图像匹配的功能。图像匹配是指在一幅图片中查找某个感兴趣区域(通常是一个模板图像)在该图像中的位置和数量。

cv2.matchTemplate()函数的语法如下:

cv2.matchTemplate(image, templ, method[, result[, mask]]) → result

参数解释如下:

  • image: 输入图像,应该是8位或32位浮点型的灰度图像。
  • templ: 模板图像,在输入图像中查找的图像区域。与输入图像具有相同的数据类型和通道数。
  • method:
    • 平方差匹配(cv2.TM_SQDIFF):此匹配方法会依次比较输入图像和模板图像中像素点的差值平方,并返回差值的总和。匹配结果越小,匹配度越高。

    • 归一化平方差匹配(cv2.TM_SQDIFF_NORMED):此匹配方法与平方差匹配方法类似,但会将匹配结果归一化,即匹配结果越小,匹配度越高。

    • 相关匹配(cv2.TM_CCORR):此匹配方法将输入图像和模板图像进行互相关运算,并返回相关系数的最大值。匹配结果越大,匹配度越高。

    • 归一化相关匹配(cv2.TM_CCORR_NORMED):此匹配方法与相关匹配方法类似,但会将匹配结果归一化,即匹配结果越大,匹配度越高。

    • 系数匹配(cv2.TM_CCOEFF):此匹配方法会计算输入图像和模板图像之间的相关系数,然后从相关系数图像中找到最大值。匹配结果越大,匹配度越高。

    • 归一化系数匹配(cv2.TM_CCOEFF NORMED):计算归一化相关系数,计算出来的值越接近1,越相关。

  • result: 匹配结果,一般不需要指定该参数,函数会自动创建。其大小为输入图像大小减去模板图像大小加1,是一个二维数组。
  • mask: 遮罩,如果指定,则只在遮罩区域内进行模板匹配。
import numpy as np
import cv2
import matplotlib.pyplot as plt


img = cv2.imread("F:/MyOpenCV/ai.jpg")
imgTmp = cv2.imread("F:/MyOpenCV/aitemp.jpg")

result = cv2.matchTemplate(img, imgTmp, cv2.TM_SQDIFF_NORMED)
minVal, maxVal, minLoc, maxLoc = cv2.minMaxLoc(result)
x, y = minLoc
h, w, t = imgTmp.shape
cv2.rectangle(img, minLoc, (x + w, y + h), (255, 0, 0), 2)

cv2.imshow("img", img)
cv2.imshow("imgsim", imgTmp)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

四、直方图

1. 对比度

  • 定义: 对比度是指图像中最亮和最暗区域之间的差异度量,即白和黑之间的差异程度。在数字图像处理中,对比度可用于调整图像的明暗程度,通常是通过调整图像中像素的亮度和颜色值来实现。较高的对比度可以使图像更加清晰明亮,而较低的对比度则会使图像显得柔和、模糊或无法分辨。

2. 绘制直方图

在这里插入图片描述
直方图的横坐标为像素通道值的取值范围,纵坐标为数值出现的次数。

cv2.calcHist() 可以用于计算灰度图像的直方图,也可以用于计算彩色图像的直方图。

cv2.calcHist() 的语法如下:

hist = cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])

参数说明如下:

  • images: 输入的图像,以 numpy 数组的形式提供。如果要计算灰度图像的直方图,则 images 的维度应该是二维的,而对于彩色图像,则应该是三维的,其中第三维表示图像的颜色通道。传递给函数的图像应该是一个列表,即使你只使用单个图像,也要将图像包装在列表中。
  • channels: 要统计的颜色通道的索引列表。对于灰度图像,此参数应该为 [0],对于彩色图像,则通常是 [0, 1, 2] 表示三个颜色通道。
  • mask: 可选的掩码图像,用于指定参与直方图计算的像素位置。只有在掩码图像中对应位置像素值为非零值时,才会将该位置的像素纳入直方图计算。
  • histSize: 直方图的bin数量,也就是区间数量。该参数应该为一个列表,每个元素表示一个通道的bin数量。
  • ranges: 直方图的像素值范围,也就是区间范围。该参数应该为一个列表,每个元素表示一个通道的像素值范围。
  • hist: 可选的输出直方图数组对象。
  • accumulate: 可选的累加标志。

cv2.calcHist() 的返回值是一个numpy数组,表示所计算的直方图。对于灰度图像,返回的是一维数组;对于彩色图像,返回的是一个三维数组,其中每个维度分别表示BGR三个通道的直方图。

img = cv2.imread("F:/MyOpenCV/hello.jpg")
b, g, r = cv2.split(img)
imgGray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

histGray = cv2.calcHist([imgGray], [0], None, [256], [0, 256])

# 绘制直方图
plt.plot(histGray)
plt.xlim([0, 256])
plt.xlabel("灰度值")
plt.ylabel("像素数量")
plt.show()

在这里插入图片描述

注:也可以使用matplotlib的方法,plt.hist(data, histSize)其中data为直方图的一维数组,因此图像数据调用ravel函数。

3. 均衡化

3.1 理论

  • 目的: 将原图像通过变换,得到一幅灰度直方图的灰度值均匀分布的新图像。对在图像中像素个数多的灰度级进行展宽,而对像素个数少的灰度级进行缩减。从而达到清晰图像的目的。最理想的情况就是变换后,像素灰度概率完全一样的,但是实际上做不到那么平均。
    在这里插入图片描述

3.2 代码

cv2.equalizeHist(src:image[, dst]) -> dst:image

在这里插入图片描述

4. CLAHE

  • 直方图均衡化问题:

    • 全局效果,导致原来比较亮的地方变得更亮 原来暗的地方变得更暗 从而会导致细节的丢失。
    • 可能导致噪点的放大。
  • 思路: 将图片进行拆分,然后分别对每个部分进行均衡化处理,且对每个部分的直方图概率分布做限制。

  • 算法实现:

    1. 图像分块
    2. 找每个块的中心点
    3. 分别计算每个块的灰度直方图,并进行阈值限制
    4. 得到每个块的直方图分布后,根据直方图均衡化算法对每个块的中心点进行均衡化处理。只对中心点进行均衡化是为了加快计算速度。
    5. 根据中心点均衡化后的灰度值,利用差值算法计算图像块剩余像素的灰度值。
  • 代码:

    # 生成自适应均衡化算法 
    # clipLimit :阈值,1 表示不做限制。值越大,对比度越大
    # tileGridSize:如何拆分图像
    clahe = cv2.createCLAHE([, clipLimit[, tileGridSize]]) -> retval
    # 对像素通道进行自适应均值化处理
    dst = clahe.apply(src)
    
    

    cv2.createCLAHE 函数可接受三个参数,分别是 clipLimit、tileGridSize 和 tileGridSizeX(取代 tileGridSize),其中:

    • clipLimit:保持对比度等级的限制值,这个值越小,保持的对比度等级越高;
    • tileGridSize:将图像分成的矩形块的大小,以像素为单位。该参数应该是奇数。若在 tileGridSizeX 参数中指定,那么就不需要输入该参数。
    • tileGridSizeX:同 tileGridSize,用于指定矩形块的大小。

五、图像傅里叶变换

  • 扩展阅读
    • 傅里叶变换
    • 二维傅里叶变换
    • 图像傅里叶

5.1 正弦平面波

在这里插入图片描述

  • 直观定义: 将一维正弦曲线朝着纵向的一个方向上将其拉伸得到一个三维的波形,然后将波形的幅值变化用二维平面进行表示,再将二维平面波绘制成灰度图,从而波峰为255白色 波谷为0黑色,中间是一个灰度的过渡。
  • 数学参数:
    • 正弦波:频率w, 幅值A,相位 φ \varphi φ
    • 拉伸方向:在二维坐标中,向量可以写为 n → = ( μ , v ) \overrightarrow{n} = (\mu, v) n =(μ,v)

5.2 二维傅里叶变换

  • 思想: 二维傅里叶变换中,认为二维数据是由无数个正弦平面波所构成。
    在这里插入图片描述
  • 离散傅里叶变换公式:
    F ( u , v ) = 1 M N ∑ x = 0 M − 1 ∑ y = 0 N − 1 f ( x , y ) e − i 2 π ( u x M + v y N ) F(u,v) = \frac{1}{MN}\sum_{x=0}^{M-1}\sum_{y=0}^{N-1}f(x,y)e^{-i2\pi(\frac{ux}{M}+\frac{vy}{N})} F(u,v)=MN1x=0M1y=0N1f(x,y)ei2π(Mux+Nvy)
  • 参数的解释:
    在这里插入图片描述

5.3 二维傅里叶变换结果 F ( u , v ) F(u, v) F(u,v)

  • (u, v)拉伸方向的向量
  • w = u 2 + v 2 w = \sqrt{u^2 + v^2} w=u2+v2 向量的模表示正弦波的频率
  • F(u, v):复数, 隐含了正弦波的幅值A和相位 φ \varphi φ。详细的还是看上面的扩展阅读吧。

5.4 傅里叶变换的实现

OpenCV提供了dft(src:np.float[, dst[, flags[, nonzeroRows]]]) -> dst来进行傅里叶变换,参数含义如下:

  • src:输入的单通道图像,必须为浮点型
  • dst:输出的复数形式的结果,大小与src一致
  • flags:变换操作的附加选项,通常可以设置为cv2.DFT_COMPLEX_OUTPUT表示输出为复数
  • nonzeroRows:当输入图像的尺寸不是2的幂次方时,必须手动指定变换中心(如果输入图像大小为偶数,则默认中心为图像的中心,否则中心为左上角)
  • n:可选参数,指定变换的大小,通常为src的尺寸
  • 返回值是是双通道,第一个通道是实部,第二个通道是虚部

在这里插入图片描述

注:由于离散傅里叶变换具有共轭对称性 因此只有四分之一是有效的其他是翻转的。
在这里插入图片描述

  • 频谱图中心化:
    方便用于滤波操作。
    # 频谱中心化
    shiftA = np.fft.fftshift(A)
    

在这里插入图片描述

5.5 傅里叶滤波

  • 思路:
    1. 对图像灰度进行傅里叶变换,得到频域结果
    2. 将要删除的频率所对应的傅里叶变换结果全部置为0+i0
    3. 对修改后的傅里叶变换结果进行傅里叶反变换

5.5.1 低通滤波

将低频部分的结果全部置为零

import numpy as np
import cv2
import matplotlib.pyplot as plt


img = cv2.imread("F:/MyOpenCV/ai.jpg")
yuv = cv2.cvtColor(img, cv2.COLOR_BGR2YUV)
yfloat = np.float32(yuv[:, :, 0])  # 其实就是取了灰度图

dft = cv2.dft(yfloat, flags=cv2.DFT_COMPLEX_OUTPUT)  # 生成频谱图
dftShift = np.fft.fftshift(dft)  # 中心化

centerRow = int(dftShift.shape[0] / 2)  # 宽的中心
centerCol = int(dftShift.shape[1] / 2)  # 列的中心

mask = np.zeros(dftShift.shape, dtype=np.uint8)  # 构造一个掩膜
mask[centerRow - 30 : centerRow + 30, centerCol - 30 : centerCol + 30, :] = 1
dftShift = dftShift * mask  # 按位乘

dft = np.fft.ifftshift(dftShift)  # 先反中心化
idft = cv2.idft(dft)  # 再反傅里叶

iyDft = cv2.magnitude(idft[:, :, 0], idft[:, :, 1])  # 转为实数
iy = np.uint8(iyDft / iyDft.max() * 255)  # 映射

yuv[:, :, 0] = iy
imgRes = cv2.cvtColor(yuv, cv2.COLOR_YUV2BGR)


cv2.imshow("imgRes", imgRes)


cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

5.5.2 高通滤波

类似于低通 改一下掩膜就行 效果如下(有点恐怖 下次还是使用灰度图吧)
在这里插入图片描述

总结

最近在忙实验室的项目,本篇搞的有点慢,这两天把它弄完。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/25276.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VITS语音生成模型详解及中文语音生成训练

1 VITS模型介绍 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)是一种结合变分推理(variational inference)、标准化流(normalizing flows)和对抗训练的高表现力语…

fastjson 1.2.24 反序列化导致任意命令执行漏洞复现

前言 fastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,的作用就是把java对象转换为json形式,也可 以用来将json转换为java对象。 fastjson在解析json的过程中,支持使用autoType来实例化某一个具体的类&#xff…

20230530论文整理·1-课题组1

个人观点,现在的NLP文章,有些是在做积木,微创新,有些文章,是可以的,读起来很美,有些,太过逆了,吃起来没味道,反胃。 文章目录 1.CODEIE: Large Code Generat…

TreeMap(1):TreeMap介绍

1 TreeMap的特点 概念: TreeMap是一个双列集合,是Map的子类。底层由红黑树结构构成。 特点: 元素中键不能重复元素会按照大小顺序排序 2 TreeMap的数据结构 2.1二叉查找树 2.1.1二叉查找树的定义 特点: 若左子树不空&#…

从C语言到C++_13(string的模拟实现)深浅拷贝+传统/现代写法

前面已经对 string 类进行了简单的介绍和应用,大家只要能够正常使用即可。 在面试中,面试官总喜欢让学生自己 来模拟实现string类, 最主要是实现string类的构造、拷贝构造、赋值运算符重载以及析构函数。 为了更深入学习STL,下面我…

乐谱文件转换,支持批量mscz、mxl、musicxml转mp3等格式

我是一个喜欢听音乐的人,每天都会在路上听着歌放松自己。但是有时候想要听的歌并没有下载下来,或者格式不兼容。 最近我发现了一个神奇的软件——mscz转mp3,可以把乐谱文件转成mp3格式! 软件界面简洁明了,使用也非常…

【JavaSE】Java基础语法(四十四):XML解析

文章目录 1. 概述2.标签的规则3. 语法规则【应用】4. xml解析【应用】 1. 概述 万维网联盟(W3C) 万维网联盟(W3C)创建于1994年,又称W3C理事会。1994年10月在麻省理工学院计算机科学实验室成立。 建立者: Tim Berners-Lee (蒂姆伯纳斯李)。 是Web技术领域…

Hive安装部署

1、Hive安装地址 ①Hive官网地址 Apache Hive ②文档查看地址 GettingStarted - Apache Hive - Apache Software Foundation ③下载地址 Index of /dist/hive ④github地址 GitHub - apache/hive: Apache Hive 2、 安装Hive 1)把apache-hive-3.1.3-bin.ta…

数据结构-顺序表

数据结构-顺序表 线性表顺序表的概念和结构静态顺序表和动态顺序表 接口的实现顺序表的初始化顺序表的打印顺序表的销毁顺序表的增容顺序表的尾插顺序表的尾删顺序表的头插顺序表的头删顺序表的任意位置插入顺序表的任意位置删除顺序表中元素的查找 完整代码 线性表 线性表是n…

MyBatis 环境搭建+基本使用

目录 MyBatis创建MyBatis环境搭建MyBatis模式开发MyBatis 获取动态参数(查询操作)${} 直接替换#{} 占位符模式替换like查询(模糊查询)多表查询一对一的表映射一对多的表映射 增、删、改操作改操作删除操作增加操作添加用户添加用户…

JVM学习(十三):面试中绕不开的String

目录 一、String 的基本特性 1.1 String类的声明 1.2 String的存储方式在jdk9中的变更 1.3 Stirng 的不可变性 二、String的内存分配 2.1 字符串常量池是什么 2.2 底层原理与默认值 2.3 字符串常量池所在位置 三、字符串的拼接操作 3.1 拼接操作结果存放位置 …

es elasticsearch 九 索引index 定制分词器 type结构后期弃用原因 定制动态映射 动态映射模板 零停机重建索引

目录 索引index 定制分词器 Type底层结构及弃用原因 定制 dynamic mapping 定制dynamic mapping template 动态映射模板 零停机重建索引 生产环境应该度别名数据 索引index Put /index Stings 分片 Mapping 映射 Aliases 别名 增加 Put my_index2 { "se…

软考A计划-试题模拟含答案解析-卷七

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&am…

从C语言到C++_12(string相关OJ题)(leetcode力扣)

上一篇已经讲了string类的接口函数,然后根据查文档刷了牛客和力扣58最后一个单词的长度, 还有力扣415字符串相加,这篇继续跟着查文档来刷力扣题,体会C刷题的方便。 目录 917. 仅仅反转字母 - 力扣(LeetCode&#xf…

Linux 实操篇-组管理和权限管理

Linux 实操篇-组管理和权限管理 Linux 组基本介绍 在linux 中的每个用户必须属于一个组,不能独立于组外。在linux 中每个文件有所有者、所在组、其它组的概念。 所有者所在组其它组改变用户所在的组 文件/目录所有者 一般为文件的创建者,谁创建了该文件&#x…

计算机视觉:卷积核的运行过程

本文重点 我们前面从直观角度理解了卷积神经网络的卷积在特征提取的作用,本节课程我们从数学角度来看一下,卷积是如何计算的? 计算步骤 1. 将卷积核与输入图像的某一部分进行逐元素相乘。 2. 将相乘后的结果求和,得到卷积核在该部分的输出值。 3. 重复以上步骤,将卷积核…

【shiro】shiro整合JWT——3.执行流程

前言 shiro整合JWT系列,主要记录核心思路–如何在shiroredis整合JWTToken。 上一篇中,主要讲如何在shiro框架中配置Jwt,以及token执行的流程。 该篇主要梳理整个代码的执行流程。 ps:本文主要以记录核心思路为主,以下…

uCOSii消息邮箱管理

uCOSii消息邮箱管理 (MESSAGE MAILBOX MANAGEMENT) 消息邮箱主要用于中断和任务之间进行邮件传递,或者是在任务与任务之间进行邮件交换。 我个人觉得,了解uCOSii消息邮箱的几个重要函数,还是有必要的。不是所有人都给我们测试案例。 1、重…

R语言混合效应(多水平/层次/嵌套)模型及贝叶斯实现技术

回归分析是科学研究中十分重要的数据分析工具。随着现代统计技术发展,回归分析方法得到了极大改进。混合效应模型(Mixed effect model),即多水平模型(Multilevel model)/分层模型(Hierarchical Model)/嵌套…

如何快速运用R语言实现生物群落(生态)数据统计分析与绘图

R 语言作的开源、自由、免费等特点使其广泛应用于生物群落数据统计分析。生物群落数据多样而复杂,涉及众多统计分析方法。本次以生物群落数据分析中的最常用的统计方法回归和混合效应模型、多元统计分析技术及结构方程等数量分析方法为主线,通过多个来自…