Python深度学习基于Tensorflow(7)视觉处理基础

news2024/11/20 12:30:13

文章目录

      • 视觉基础
        • 图像基础
        • 卷积层:图像的中全连接层的优化
        • 卷积核
        • tf.keras中的卷积函数
        • 池化层
      • 现代经典网络
        • DenseNet + 数据增强

图像的本质是一个矩阵, 矩阵中的一个点就是一个像素,如果像素大小为 1000 × 1000 1000 \times 1000 1000×1000,那么图像原本的宽和高都是1000;同时,为了丰富图像的色彩,加入了通道这一概念,通道一般有三个,由三原色组成:RGB 红色,绿色,蓝色;jpg图像格式就是三通道图像,而png有四个通道,最后一个通道表示透明程度;

视觉基础

图像基础

PIL中有九种不同模式。分别为1,L,P,RGB,RGBA,CMYK,YCbCr,I,F

模式描述补充
1模式“1”为二值图像,非黑即白。但是它每个像素用8个BIT表示,0表示黑,255表示白
L模式“L”为灰色图像,它的每个像素用8个BIT表示,0表示黑,255表示白,其他数字表示不同的灰度。从模式“RGB”转换为“L”模式是按照下面的公式转换的: L = R ∗ 299 / 1000 + G ∗ 587 / 1000 + B ∗ 114 / 1000 L = R * 299/1000 + G * 587/1000+ B * 114/1000 L=R299/1000+G587/1000+B114/1000
P模式“P”为8位彩色图像,它的每个像素用8个BIT表示,其对应的彩色值是按照调色板查询出来的。
RGBA模式“RGBA”为32位彩色图像,它的每个像素用32个BIT表示,其中24BIT表示红色、绿色和蓝色三个通道,另外8BIT表示ALPHA通道,即透明通道。
CMYK模式“CMYK”为32位彩色图像,它的每个像素用32个BIT表示。模式“CMYK”就是印刷四分色模式,它是彩色印刷时采用的一种套色模式,利用色料的三原色混色原理,加上黑色油墨,共计四种颜色混合叠加,形成所谓“全彩印刷”。四种标准颜色是:C:Cyan = 青色,又称为‘天蓝色’或是‘湛蓝’M:Magenta = 品红色,又称为‘洋红色’;Y:Yellow = 黄色;K:Key Plate(blacK) = 定位套版色(黑色)。
C = 255 − R C = 255 - R C=255R
M = 255 − G M = 255 - G M=255G
Y = 255 − B Y = 255 - B Y=255B
K = 0 K = 0 K=0
YCbCr模式“YCbCr”为24位彩色图像,它的每个像素用24个bit表示。YCbCr其中Y是指亮度分量,Cb指蓝色色度分量,而Cr指红色色度分量。人的肉眼对视频的Y分量更敏感,因此在通过对色度分量进行子采样来减少色度分量后,肉眼将察觉不到的图像质量的变化。模式“RGB”转换为“YCbCr”的公式如下:

Y = 0.257 ∗ R + 0.504 ∗ G + 0.098 ∗ B + 16 Y= 0.257*R+0.504*G+0.098*B+16 Y=0.257R+0.504G+0.098B+16
C b = − 0.148 ∗ R − 0.291 ∗ G + 0.439 ∗ B + 128 Cb = -0.148*R-0.291*G+0.439*B+128 Cb=0.148R0.291G+0.439B+128
C r = 0.439 ∗ R − 0.368 ∗ G − 0.071 ∗ B + 128 Cr = 0.439*R-0.368*G-0.071*B+128 Cr=0.439R0.368G0.071B+128
I模式“I”为32位整型灰色图像,它的每个像素用32个bit表示,0表示黑,255表示白,(0,255)之间的数字表示不同的灰度。在PIL中,从模式“RGB”转换为“I”模式是按照下面的公式转换的:从实验的结果看,模式“I”与模式“L”的结果是完全一样,只是模式“L”的像素是8bit,而模式“I”的像素是32bit。
F模式“F”为32位浮点灰色图像,它的每个像素用32个bit表示,0表示黑,255表示白,(0,255)之间的数字表示不同的灰度。模式“F”与模式“L”的转换公式是一样的,都是RGB转换为灰色值的公式,但模式“F”会保留小数部分,如实验中的数据。

转载自:Python图像处理库PIL中图像格式转换(一)_image .pixel-CSDN博客

卷积层:图像的中全连接层的优化

这里以单通道图像为例子,图像为 [ X i , j ] [X_{i,j}] [Xi,j],假设隐藏层为 [ H i , j ] [H_{i,j}] [Hi,j]; 如果使用全连接,有: H i , j = ∑ k ∑ l [ W k , l ] i , j [ X k , l ] H_{i,j} =\sum_k\sum_l[W_{k,l}]_{i,j} [X_{k,l}] Hi,j=kl[Wk,l]i,j[Xk,l]这样首先有几个缺点:1. 参数量爆炸式增长; 2. 这相当于把矩阵展开成了向量,丢失了位置信息组成的局部信息;

图像有两个性质:一个是局部性,一个是平移不变性;假设我们需要识别一张图像,我们不可能去关注所有的像素,假设目标是一只马,我们关注的是:它有几条腿,几只眼睛,站着还是坐着等等;这些都是局部信息,从局部信息推导全局信息这是一只马;平移不变性表示我们在局部获取的信息目标是相同的,比如我们要看一只马有几条腿,我们是从局部一个一个查找腿,最后汇总局部的结果,一共有4条腿;

这里使 k = i + a k=i+a k=i+a l = j + b l=j+b l=j+b,有: H i , j = ∑ a ∑ b [ W a , b ] i , j [ X i + a , j + b ] H_{i,j} =\sum_a\sum_b[W_{a,b}]_{i,j} [X_{i+a,j+b}] Hi,j=ab[Wa,b]i,j[Xi+a,j+b]
添加局部性我们可以把 a a a b b b 不设置为宽和高这种全局参数,改小一点,如改成 [ − Δ , Δ ] [-\Delta, \Delta] [Δ,Δ] ,有: H i , j = ∑ a = − Δ Δ ∑ b = − Δ Δ [ W a , b ] i , j [ X i + a , j + b ] H_{i,j} =\sum_{a=-\Delta}^\Delta\sum_{b=-\Delta}^\Delta[W_{a,b}]_{i,j} [X_{i+a,j+b}] Hi,j=a=ΔΔb=ΔΔ[Wa,b]i,j[Xi+a,j+b]
由于平移不变性 [ W a , b ] i , j [W_{a,b}]_{i,j} [Wa,b]i,j 应该与 i , j i,j i,j 无关,有 [ W a , b ] i , j = [ W a , b ] [W_{a,b}]_{i,j}=[W_{a,b}] [Wa,b]i,j=[Wa,b],得到: H i , j = ∑ a = − Δ Δ ∑ b = − Δ Δ [ W a , b ] [ X i + a , j + b ] H_{i,j} =\sum_{a=-\Delta}^\Delta\sum_{b=-\Delta}^\Delta[W_{a,b}] [X_{i+a,j+b}] Hi,j=a=ΔΔb=ΔΔ[Wa,b][Xi+a,j+b]
这就是卷积层的实质! 这里 W W W被称为卷积核或者过滤器,是该层唯一一个可学习的权重,因此参数量大大减少;

卷积核

卷积核是卷积过程的核心, 卷积核主要是垂直卷积核,水平卷积核;这两个核在不同算子下面不一样,算子总结:

![[Pasted image 20240509131825.png]]

垂直卷积核,水平卷积核能够检测图像的水平边缘,垂直边缘等;

![[Pasted image 20240509133400.png]]

上述图片的代码如下:

from PIL import Image
import numpy as np
import scipy as sp
import pandas as pd
import matplotlib.pyplot as plt

# 导入图片
img = np.array(Image.open('demo.jpg').convert('L'))

# 设置算子
scharr = np.array([[ -3-3j, 0-10j,  +3 -3j],
                   [-10+0j, 0+ 0j, +10 +0j],
                   [ -3+3j, 0+10j,  +3 +3j]])

prewitt = np.array([[ -1-1j, 0-1j,  +1 -1j],
                    [ -1+0j, 0+0j,  +1 +0j],
                    [ -1+1j, 0+1j,  +1 +1j]])

# 计算卷积
new_imgs = [img]
for in2 in [scharr, prewitt]:
    new_img = sp.signal.convolve2d(img, in2, boundary='fill', mode='same')
    new_imgs.append(new_img)

# 作图
fig, axes = plt.subplots(1,3, figsize=(10,4))
axes[0].imshow(np.abs(new_imgs[0]), cmap='gray')
axes[0].axis('off')
axes[0].set_title('origin')
axes[1].imshow(np.abs(new_imgs[1]), cmap='gray')
axes[1].axis('off')
axes[1].set_title('scharr')
axes[2].imshow(np.abs(new_imgs[2]), cmap='gray')
axes[2].axis('off')
axes[2].set_title('prewitt')
plt.show()

这里对二维卷积的 modeboundary 进行讨论

参数解释
in1输入的二维数组
in2输入的二维数组,代表卷积核
mode卷积类型:“fulll”,“valid”,“same”
boundary边界填充方式:“fill”,“warp”,“symm”
fillvalue当boundary="fill"时,设置边界填充的方式,默认为0

mode的形象化如下图:

![[Pasted image 20240509135025.png]]

boundary的形象化如下图:

![[Pasted image 20240509140833.png]]

在神经网络中,还有一个参数叫步幅,默认步幅为1,这个很好理解,在计算卷积的时候,隔一个还是多个进行卷积计算,超出就不管了;

多通道图片进行卷积的话,相当于多了一个维度的卷积核,对应相加后再整体相加;

![[Pasted image 20240509143412.png]]

tf.keras中的卷积函数

详细可以看:

深入浅出理解转置卷积Conv2DTranspose_convtranspose2d-CSDN博客

Conv2d

tf.keras.layers.Conv2D(
filters,
kernel_size,
strides=(1, 1),
padding=‘valid’,
data_format=None,
dilation_rate=(1, 1),
groups=1,
activation=None,
use_bias=True,
kernel_initializer=‘glorot_uniform’,
bias_initializer=‘zeros’,
kernel_regularizer=None,
bias_regularizer=None,
activity_regularizer=None,
kernel_constraint=None,
bias_constraint=None,
**kwargs)

  • filters:过滤器数量,对应输出的通道数
  • kernel_size:过滤器的尺寸,好像网上大多数教程说2维卷积其尺寸是二维的,其实并不是:为了对通道数进行处理,过滤器的尺寸后面还加了一个维度,其维度值等于输入的通道数;加上filters,其真实维度为 [kernel_size_1, kernel_size_2, input_c, output_c]
  • stride:步幅;
  • padding:有两种取值,valid ,same。其意义和上面的一致;
  • dilation:卷积核分散计算;

dilation具体形式如图:

请添加图片描述

输入维度 ( N , W , H , C ) (N, W, H, C) (N,W,H,C)
输出维度 ( N , W + 2 p a d d i n g − d i a t i o n × ( k e r n e l s i z e − 1 ) − 1 s t r i d e + 1 , H + 2 p a d d i n g − d i a t i o n × ( k e r n e l s i z e − 1 ) − 1 s t r i d e + 1 , f i l t e r ) (N,\frac{W + 2padding-diation \times (kernelsize - 1) -1 }{stride} + 1,\frac{H + 2padding-diation \times (kernelsize - 1) -1 }{stride} + 1,filter) (N,strideW+2paddingdiation×(kernelsize1)1+1,strideH+2paddingdiation×(kernelsize1)1+1,filter)

Conv2DTranspose

tf.keras.layers.Conv2DTranspose(
filters,
kernel_size,
strides=(1, 1),
padding=‘valid’,
output_padding=None,
data_format=None,
dilation_rate=(1, 1),
activation=None,
use_bias=True,
kernel_initializer=‘glorot_uniform’,
bias_initializer=‘zeros’,
kernel_regularizer=None,
bias_regularizer=None,
activity_regularizer=None,
kernel_constraint=None,
bias_constraint=None,
**kwargs)

其参数和Conv2D基本一致,从矩阵的角度出发,卷积的实质还是矩阵运算,不过多了变形的步骤:

请添加图片描述

![[Pasted image 20240509154437.png]]
请添加图片描述

Y = C X Y=CX Y=CX
Conv2DTranspose 主要利用逆变换的方式

s=1, p=0, k=3s=2, p=0, k=3s=2, p=1, k=3

从图中可以看到,有些块被重复利用了,这会照成一种棋盘效应,图像中的某个部位要比其他部位颜色更深;这是上采样照成的一种负面效应,信息只是看起来增长了;

反卷积和棋盘伪影 — Deconvolution and Checkerboard Artifacts (distill.pub)

这里有两种解决办法:

  1. 使kernel size能够被stride整除;

前面关于棋盘效应产生的原因就提到了,当kernel size不能被stride整除时会出现这种问题,那一个直观的方法就是让它能够被整除。但是,有研究指出,即使这样也无法从根本避免这个问题,因为我们不知道网络学到了什么样的卷积权重,无法解决;

  1. 双线性插值+卷积;

这是一个有效的解决方法,双线性插值可以减小插值的像素和原输入像素值的大小差异,再进行卷积可以避免该问题产生,如下所示:

One approach is to make sure you use a kernel size that is divided by your stride, avoiding the overlap issue. This is equivalent to “sub-pixel convolution,” a technique which has recently had success in image super-resolution 8. However, while this approach helps, it is still easy for deconvolution to fall into creating artifacts.
Another approach is to separate out upsampling to a higher resolution from convolution to compute features. For example, you might resize the image (using nearest-neighbor interpolation or bilinear interpolation) and then do a convolutional layer. This seems like a natural approach, and roughly similar methods have worked well in image super-resolution (eg. 9).

两个概念:特征图,感受野;特征图指的是卷积层的输出;感受野指的是某层某一输出的值依赖于原输入的值的范围,可以得到随着卷积层变多,感受野越大;

池化层

池化层是下采样算法,其是为了解决图像特征太多导致过拟合的问题,同时可以降低模型的参数量;池化相当于用一个值去代表一个二维矩阵;

池化层分为局部池化和全局池化:局部池化是对图像某一局部用数值代替,全局池化是对图像用数值代替;

最大池化:用最大值去代替矩阵,平均池化:用平均值去代替矩阵;

tf.keras.layers.MaxPool2D(
pool_size=(2, 2),
strides=None,
padding=‘valid’,
data_format=None,
**kwargs,
)

tf.keras.layers.GlobalMaxPool2D(*args, **kwargs)

data_format 表示输入的维度的顺序,默认是 channels_last,对应 ( b a t c h , h e i g h t , w i d t h , c h a n n e l s ) (batch, height, width, channels) (batch,height,width,channels);还有一个 channels_first 对应 ( b a t c h , c h a n n e l s , h e i g h t , w i d t h ) (batch,channels,height, width) (batch,channels,height,width),其他参数的参数意义和卷积一样;

现代经典网络

![[无标题.jpg]]

下面博客对经典卷积神经网络进行了总结:经典卷积神经网络总结_卷积神经网络报告-CSDN博客

DenseNet + 数据增强

这里以猫狗数据集为例子

导入数据

import matplotlib.pyplot as plt
import tensorflow as tf

(x_train, y_train), (x_test, y_test) = tf.keras.datasets.cifar10.load_data()
# x_train.shape, y_train.shape, x_test.shape, y_test.shape
# ((50000, 32, 32, 3), (50000, 1), (10000, 32, 32, 3), (10000, 1))

index_name = {
    0:'airplane',
    1:'automobile',
    2:'bird',
    3:'cat',
    4:'deer',
    5:'dog',
    6:'frog',
    7:'horse',
    8:'ship',
    9:'truck'
}

建立数据集:

def process_data(img, label):
    img = tf.cast(img, tf.float32) / 255.0
    img = tf.image.random_crop(img, [28,28,3])
    img = tf.image.random_flip_up_down(img)
    img = tf.image.random_flip_left_right(img)
    img = tf.image.random_brightness(img, max_delta=0.5)
    return img, label

batch_size = 64
AUTOTUNE = tf.data.experimental.AUTOTUNE
train_data = tf.data.Dataset.from_tensor_slices((x_train, y_train))
test_data = tf.data.Dataset.from_tensor_slices((x_test, y_test))
train_data = train_data.map(process_data).batch(batch_size)
test_data = test_data.map(process_data).batch(batch_size)

自定义层

class Conv_block(tf.keras.layers.Layer):
    def __init__(self, filters):
        super(Conv_block, self).__init__()
        self.bn = tf.keras.layers.BatchNormalization(axis=3, epsilon=1e-6)
        self.conv_1 = tf.keras.layers.Conv2D(filters, 3, padding='same')
        self.conv_2 = tf.keras.layers.Conv2D(filters, 1, padding='same')
        self.concat = tf.keras.layers.Concatenate()

    def call(self, x):
        x = self.bn(x)
        x = tf.keras.activations.relu(x)
        x1 = self.conv_1(x)
        x2 = self.conv_2(x)
        x = self.concat([x1, x2])
        return x

class Transition_block(tf.keras.layers.Layer):
    def __init__(self, filters, stride):
        super(Transition_block, self).__init__()
        self.bn = tf.keras.layers.BatchNormalization(axis=3, epsilon=1e-6)
        self.conv = tf.keras.layers.Conv2D(filters, 3, padding='same')
        self.maxpool = tf.keras.layers.MaxPooling2D(padding='same', strides=2)

    def call(self, x):
        x = self.bn(x)
        x = tf.keras.activations.relu(x)
        x = self.conv(x)
        x = self.maxpool(x)
        return x


class Dense_block(tf.keras.layers.Layer):
    def __init__(self, filters, stride, blocks=3):
        super(Dense_block, self).__init__()
        self.conv_block_list = [Conv_block(filters) for _ in range(blocks)]
        self.transition_block = Transition_block(filters*2, stride)

    def call(self, x):
        for conv_block in self.conv_block_list:
            x = conv_block(x)
        x = self.transition_block(x)
        return x

建立模型:

class CustomModel(tf.keras.Model):
    def __init__(self, filters_list=[4,8,16]):
        super(CustomModel, self).__init__(self)
        self.dense_block_list = [Dense_block(filters, stride=2, blocks=3) for filters in filters_list]
        self.global_pool = tf.keras.layers.GlobalAveragePooling2D()
        self.dense_final = tf.keras.layers.Dense(10, activation='softmax')
        
    def call(self, x):
        for dense_block in self.dense_block_list:
            x = dense_block(x)
        x = self.global_pool(x)
        x = self.dense_final(x)
        return x

model = CustomModel()
model.compile(
    loss=tf.keras.losses.sparse_categorical_crossentropy,
    optimizer='adam',
    metrics=[tf.keras.metrics.sparse_categorical_accuracy]
)

开始训练:

model.fit(train_data, epochs=10)

训练结果

Epoch 1/10
782/782 [==============================] - 13s 13ms/step - loss: 1.9584 - sparse_categorical_accuracy: 0.2602 - val_loss: 1.8581 - val_sparse_categorical_accuracy: 0.2886
Epoch 2/10
782/782 [==============================] - 10s 13ms/step - loss: 1.7564 - sparse_categorical_accuracy: 0.3421 - val_loss: 1.8680 - val_sparse_categorical_accuracy: 0.3110
Epoch 3/10
782/782 [==============================] - 10s 13ms/step - loss: 1.6269 - sparse_categorical_accuracy: 0.3994 - val_loss: 1.5945 - val_sparse_categorical_accuracy: 0.4117
Epoch 4/10
782/782 [==============================] - 10s 13ms/step - loss: 1.5092 - sparse_categorical_accuracy: 0.4506 - val_loss: 1.4653 - val_sparse_categorical_accuracy: 0.4673
Epoch 5/10
782/782 [==============================] - 9s 12ms/step - loss: 1.4051 - sparse_categorical_accuracy: 0.4891 - val_loss: 1.4340 - val_sparse_categorical_accuracy: 0.4818
Epoch 6/10
782/782 [==============================] - 10s 12ms/step - loss: 1.3170 - sparse_categorical_accuracy: 0.5240 - val_loss: 1.3246 - val_sparse_categorical_accuracy: 0.5269
Epoch 7/10
782/782 [==============================] - 10s 13ms/step - loss: 1.2470 - sparse_categorical_accuracy: 0.5515 - val_loss: 1.3144 - val_sparse_categorical_accuracy: 0.5209
Epoch 8/10
782/782 [==============================] - 10s 12ms/step - loss: 1.1866 - sparse_categorical_accuracy: 0.5733 - val_loss: 1.2512 - val_sparse_categorical_accuracy: 0.5572
Epoch 9/10
782/782 [==============================] - 10s 13ms/step - loss: 1.1420 - sparse_categorical_accuracy: 0.5896 - val_loss: 1.1930 - val_sparse_categorical_accuracy: 0.5681
Epoch 10/10
782/782 [==============================] - 10s 13ms/step - loss: 1.1046 - sparse_categorical_accuracy: 0.6040 - val_loss: 1.1394 - val_sparse_categorical_accuracy: 0.5952

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

sqlx执行案例

SQLx简介 SQLx是Rust语言中的一个异步SQL数据库连接库,它支持多种数据库,如PostgreSQL、MySQL和SQLite。SQLx提供了简单的API和异步执行查询的能力,使得Rust程序员可以轻松地与数据库交互1。 本章节以PostgreSQL为例。 目录结构 cargo.tom…

OpenCV4.8 VS2019 MFC编程出现的诡异现象

OpenCV4.8及OpenCV4.4 VS2019MFC编程在调用imred()函数时,debug X64试运行没问题。 release X64试运行时出现下面错误。 void CEasyPictureDlg::OnBnClickedOpen() {CFileDialog fdlg(TRUE, NULL, 0, OFN_HIDEREADONLY | OFN_OVERWRITEPROMP…

苹果iPad M4:Console级别图形和AI强大功能

苹果iPad M4:Console级别图形和AI强大功能 Apple近日发布了最新的M4芯片,旨在为iPad Pro系列带来明显的性能提升和电池续航时间延长。在本篇报道中,我们将详细介绍M4芯片的特点、性能改进和为创意专业人士带来的影响。 M4芯片的强大功能 …

初学者理解Transformer,本文is all you need

要问现在AI领域哪个概念最热,必然是openAI推出chatGPT之后引发的大模型。然而这项技术的起源,都来自一篇google公司员工的神作“Attention Is All You Need”——本文标题也是一种致敬^_^,目前已有近12万的引用(还在增长)。 在“Attention Is…

独家新闻:CSCWD 2024会议现场即时报道 天津之眼夜色如梦

会议之眼 快讯 备受瞩目的第27届国际计算机协同计算与设计大会(CSCWD 2024)于2024年5月8日在中国天津梅江中心皇冠假日酒店盛大开幕!来自世界各地的专家学者齐聚一堂,共同探讨和分享在智能设计、制造和协同工作领域的最新研究成果…

EasyExcel导出带自定义下拉框数据的Excel模板

文章目录 前言📝一、导入依赖二、创建导出工具1.创建模板实体类2.创建自定义注解3.添加动态选择接口4.EasyExcelUtil工具类 三、导出、导入Excel接口1.导出接口2.导入接口3.导出结果 总结 前言📝 在项目中导入excel时需要通过下拉框选择值传入&#xff…

2024 VMware VCP一条龙通关-送题库

VMware VCP-DCV 2024(2V0-21.23)认证考试,2024年可高分通过。 1.5. An administrator has a host profile named Standard-Config. The administrator wants to change the other host profiles to use only the storage configuration setti…

ICode国际青少年编程竞赛- Python-2级训练场-for循环练习2

ICode国际青少年编程竞赛- Python-2级训练场-for循环练习2 1、 for i in range(5):Dev.step(9 - i * 2)Dev.turnLeft()2、 for i in range(3):Spaceship.step(i 1)Spaceship.turnRight()Spaceship.step(i 1)Spaceship.turnLeft()3、 for i in range(4):Dev.step(10 - i…

《Video Mamba Suite》论文笔记(1)Mamba在时序建模中的作用

原文链接 https://arxiv.org/abs/2403.09626https://arxiv.org/abs/2403.09626 原文代码 https://github.com/OpenGVLab/video-mamba-suitehttps://github.com/OpenGVLab/video-mamba-suite 原文笔记 What 《Video Mamba Suite: State Space Model as a Versatile Altern…

BS-Diff | 扩散模型在骨抑制任务上的首次登场!

摘要 胸部 X 射线(CXR)是肺部筛查中常用的低剂量方式。然而,由于大约 75% 的肺部区域与骨骼重叠,这反过来又阻碍了疾病的检测和诊断,因此 CXR 的功效受到了一定程度的影响。作为一种补救措施,骨抑制技术已…

PPT职场课:话术+技巧+框架+案例,告别只会念PPT不会讲(8节课)

课程目录 001-讲PPT如何开场及导入?5个简单实用的方法.mp4 002-讲PPT如何过渡衔接结尾?6类话术争来就用.mp4 003-掌握这3个逻辑表达万能框架,搞定98的PPT.mp4 004-学会这3种PPT结构讲解技巧告别只会念不会讲(上).mp4 005-学会这3种PPT结构讲解技巧告别只会念…

部署 Sentinel 控制台:实现流量管理和监控

序言 Sentinel 是阿里巴巴开源的一款流量防护与监控平台,它可以帮助开发者有效地管理微服务的流量,实现流量控制、熔断降级、系统负载保护等功能。本文将介绍如何在项目中部署和配置 Sentinel 控制台,实现微服务的流量防护和监控。 一、Sen…

JAVA(三)常用类和API

目录 常用类与基础API---String String的内存结构 构造器和常用方法 字符串构建 String与其他结构间的转换 String的常用API 系列1:常用方法 系列2:查找 系列3:字符串截取 系列4:和字符/字符数组相关 系列5:开头…

无人直播需要什么软件系统?最新AI实景自动无人直播软件:智能化引领直播拓客新时代

随着互联网的快速发展(无人直播招商加盟:hzzxar)直播行业已经成为商家品牌推广和商品销售的热门方式。近年来,人工智能技术的飞速发展,催生了一款令人惊叹的AI实景自动无人直播软件,为商家提供了全新的直播…

Facebook消息群发脚本的制作思路!

在数字化社交日益盛行的今天,Facebook作为全球最大的社交平台之一,为企业和个人提供了广阔的交流与合作空间。 然而,手动向大量用户发送消息既耗时又低效,因此,开发一款能够自动群发消息的脚本成为了许多人的需求&…

渗透之sql注入----二次注入

目录 二次注入的原理: 实战: 第一步:找注入点 找漏洞: 注入大概过程: 第二步:开始注入 二次注入的原理: 二次注入是由于对用户输入的数据过滤不严谨,导致存在异常的数据被出入…

树和二叉树的定义和基本术语

文章目录 前言一、树的定义二、树的基本术语三、二叉树的定义总结 前言 T_T此专栏用于记录数据结构及算法的(痛苦)学习历程,便于日后复习(这种事情不要啊)。所用教材为《数据结构 C语言版 第2版》严蔚敏。 一、树的定义…

HTTP请求三方接口绕过https证书检查

问题:在http请求https接口过程中经常会遇到SSL证书检查或者证书过期 ** sun.security.validator.ValidatorException: PKIX path validation failed: java.security.cert.CertPathValidatorException: validity check failed ** 解决办法:绕过证书检查…

Vue--》从零开始打造交互体验一流的电商平台(一)

今天开始使用 vue3 ts 搭建一个电商项目平台,因为文章会将项目的每处代码的书写都会讲解到,所以本项目会分成好几篇文章进行讲解,我会在最后一篇文章中会将项目代码开源到我的github上,大家可以自行去进行下载运行,希…

了解tensorflow.js

1、浏览器中进行机器学习的优势 浏览器中进行机器学习,相对比与服务器端来讲,将拥有以下四大优势: 不需要安装软件或驱动(打开浏览器即可使用);可以通过浏览器进行更加方便的人机交互;可以通过…