扩散模型,快速入门和基于python实现的一个简单例子(复制可直接运行)

news2025/1/12 9:49:17

提示:内容丰富,收藏本文,以免忘记哦

文章目录

  • 一、扩散模型
  • 二、一个简单的迭代式扩散模型的例子
      • 温度扩散模型
      • python代码实现
      • 差分近似模拟拉普拉斯算子
  • 三、扩散模型和深度学习进行结合
      • 简介
      • 用python和torch的代码实现
  • 四、扩散模型与生成模型
      • 第二类扩散模型(重点)
      • 区别
      • 示例
  • 五、深度学习结合扩散模型和PINN方法的区别与联系
      • 却别与联系
      • 两者结合的简单例子
      • 结合起来的python代码
      • 两者结合的优势
  • 六、总结


一、扩散模型

本文要记录的大概内容:

扩散模型(Diffusion Model) 是一种用于描述物质或信息在空间中传播和扩散的数学模型。它广泛应用于物理学、生态学、社会科学等领域,用于研究和解释各种扩散现象的行为和特征。

扩散模型基于扩散方程(Diffusion Equation),它描述了物质或信息的扩散过程。扩散方程通常是一个偏微分方程,其中考虑了扩散物质的浓度、时间和空间变化。其一般形式如下:

∂C/∂t = D∇²C

其中,∂C/∂t 表示浓度随时间的变化率,D 是扩散系数,∇² 表示拉普拉斯算子,C 表示物质或信息的浓度分布。

扩散模型的基本假设是:

物质或信息会沿着浓度梯度的方向从高浓度区域向低浓度区域传播,直到达到均衡状态。
该模型考虑了扩散物质的浓度梯度和扩散速率,并可以预测和分析扩散过程中的行为。

在不同领域中,扩散模型具有不同的应用。例如,在物理学中,扩散模型可以用于描述热量、质量和电荷的传导过程;在生态学中,可以用于研究物种的扩散和种群的分布;在社会科学中,可以用于分析信息传播、疾病传播和意见形成等。

扩散模型通常使用数值方法进行求解,如有限元法、有限差分法或蒙特卡洛模拟等。这些方法可以模拟和预测扩散过程中的行为,并提供对系统动力学的理解。

扩散模型是一种重要的数学工具,用于研究和解释物质或信息在空间中传播和扩散的过程。它在多个学科领域中都有广泛的应用,为我们理解和预测自然和社会现象提供了有价值的工具。


以下是本篇文章正文内容,下面案例可供参考

二、一个简单的迭代式扩散模型的例子

温度扩散模型

简介:一个简单的扩散模型的例子是在一维空间中模拟热量的扩散过程。我们可以假设一个细长的杆,其中一端受到热源的加热,而另一端保持冷却。我们的目标是模拟热量如何在杆内扩散和分布。

python代码实现

注意,本代码中不包含任何深度学习框架或算法

import numpy as np
import matplotlib.pyplot as plt

# 定义模型参数
length = 10  # 杆的长度
num_points = 100  # 空间离散点数
dx = length / (num_points - 1)  # 离散点之间的间距
num_steps = 1000  # 时间步数
dt = 0.001  # 时间步长
diffusion_coefficient = 0.1  # 扩散系数

# 初始化温度分布
temperature = np.zeros(num_points)
temperature[0] = 1.0  # 初始条件:热源在一端

# 进行扩散模拟
for step in range(num_steps):
    new_temperature = temperature.copy()

    for i in range(1, num_points - 1):
        # 使用离散扩散方程进行更新
        new_temperature[i] = temperature[i] + diffusion_coefficient * (
            temperature[i+1] - 2 * temperature[i] + temperature[i-1]) * dt / dx**2

    temperature = new_temperature

# 绘制结果
x = np.linspace(0, length, num_points)
plt.plot(x, temperature, color='blue', linewidth=2)
plt.xlabel('Position')
plt.ylabel('Temperature')
plt.title('Diffusion of Heat')

# 添加网格线
plt.grid(True, linestyle='--', linewidth=0.5, alpha=0.7)

# 调整坐标轴范围和刻度
plt.xlim(0, length)
plt.ylim(0, 1.2)
plt.xticks(np.arange(0, length+1, 2))
plt.yticks(np.arange(0, 1.3, 0.2))

plt.show()

在这个示例中,我们通过离散化空间和时间来模拟热量的扩散过程。代码中的参数可以根据需要进行调整,例如杆的长度、离散点数、时间步数和扩散系数。通过迭代更新温度分布,我们可以观察到热量如何从热源逐渐扩散到整个杆上,并最终达到稳定的温度分布。
tu

图1. 该图是扩散模型的结果position代表位置也就是长度,Temperature代表温度。

差分近似模拟拉普拉斯算子

在给出的代码中,并没有直接使用拉普拉斯算子。实际上,我们在离散化扩散方程时使用了近似的差分形式来模拟拉普拉斯算子。

具体来说,以下代码片段中的部分实现了离散化的扩散方程:

for step in range(num_steps):
    new_temperature = temperature.copy()

    for i in range(1, num_points - 1):
        # 使用离散扩散方程进行更新
        new_temperature[i] = temperature[i] + diffusion_coefficient * (
            temperature[i+1] - 2 * temperature[i] + temperature[i-1]) * dt / dx**2

    temperature = new_temperature

在这段代码中,我们使用了差分形式近似了拉普拉斯算子。
具体来说:

temperature[i+1] - 2 * temperature[i] + temperature[i-1]

部分表示了温度在位置i处的二阶导数。通过乘以diffusion_coefficient、dt和除以dx**2,我们将差分形式应用于离散化的扩散方程。

这种差分形式的近似实际上是一种常用的方法,用于在离散空间中近似模拟微分方程中的导数项。在这个例子中,我们通过差分形式近似了拉普拉斯算子的作用,以模拟热量在空间中的扩散过程


三、扩散模型和深度学习进行结合

简介

当结合扩散模型和深度学习时,一种常见的方法是使用卷积神经网络(Convolutional Neural Network,简称CNN)来学习扩散过程中的模式和规律。以下是一个简单的例子,使用Python和PyTorch来实现扩散模型与深度学习的结合。
这个代码实现了一个使用卷积神经网络(CNN)结合扩散模型的预测模型。具体来说,它使用CNN学习了扩散模型中的温度分布变化规律,并通过训练来预测给定初始温度分布下的最终温度分布。

该模型的结构如下:

输入层:输入是一个一维的温度分布数据,表示为形状为 (1, 1, num_points) 的张量,其中 num_points 是空间离散点数。
卷积层1:使用3个卷积核,输入通道数为1,输出通道数为16,卷积核大小为3,填充为1,激活函数为ReLU。
卷积层2:使用3个卷积核,输入通道数为16,输出通道数为1,卷积核大小为3,填充为1,不使用激活函数。
输出层:输出是预测的最终温度分布,形状与输入相同。

模型的训练过程如下:

  1. 首先,将初始温度分布和目标温度分布转换为PyTorch张量,作为训练数据。
  2. 初始化模型、优化器和损失函数(均方误差损失)。
  3. 迭代训练模型:对于每个训练步骤,将模型的预测结果与目标温度分布计算损失,并通过反向传播来更新模型参数。
  4. 在训练完成后,使用训练好的模型对初始温度分布进行预测,得到最终温度分布的预测结果。
  5. 最后,通过可视化将目标温度分布和预测结果进行比较。

总结起来,这个模型使用卷积神经网络来学习扩散过程中的温度分布变化,通过训练来预测给定初始温度分布下的最终温度分布。

用python和torch的代码实现

import torch
import torch.nn as nn
import torch.optim as optim
import numpy as np
import matplotlib.pyplot as plt

# 模型参数
length = 10
num_points = 100
dx = length / (num_points - 1)
num_steps = 1000
dt = 0.001
diffusion_coefficient = 0.1

# 生成训练数据
x = np.linspace(0, length, num_points)
temperature_init = np.sin(np.pi * x / length)  # 初始温度分布为正弦函数
temperature_target = np.exp(-x)  # 目标温度分布为指数函数

# 将数据转换为PyTorch张量
temperature_init = torch.tensor(temperature_init, dtype=torch.float).view(1, 1, -1)
temperature_target = torch.tensor(temperature_target, dtype=torch.float).view(1, 1, -1)

# 定义卷积神经网络模型
class DiffusionModel(nn.Module):
    def __init__(self):
        super(DiffusionModel, self).__init__()
        self.conv1 = nn.Conv1d(1, 16, kernel_size=3, padding=1)
        self.conv2 = nn.Conv1d(16, 1, kernel_size=3, padding=1)

    def forward(self, x):
        x = torch.relu(self.conv1(x))
        x = self.conv2(x)
        return x

# 初始化模型和优化器
model = DiffusionModel()
optimizer = optim.Adam(model.parameters(), lr=0.01)
loss_fn = nn.MSELoss()

# 训练模型
for step in range(num_steps):
    optimizer.zero_grad()
    temperature_pred = model(temperature_init)
    loss = loss_fn(temperature_pred, temperature_target)
    loss.backward()
    optimizer.step()

    # 打印损失
    if (step+1) % 100 == 0:
        print(f"Step [{step+1}/{num_steps}], Loss: {loss.item()}")

# 使用训练好的模型进行预测
with torch.no_grad():
    temperature_pred = model(temperature_init)

# 可视化结果
temperature_pred = temperature_pred.squeeze().numpy()
plt.plot(x, temperature_target.squeeze().numpy(), label='Target')
plt.plot(x, temperature_pred, label='Prediction')
plt.xlabel('Position')
plt.ylabel('Temperature')
plt.title('Diffusion Model with CNN')
plt.legend()
plt.show()

最终结果如下:
在这里插入图片描述


四、扩散模型与生成模型

第二类扩散模型(重点)

第二类 扩散模型(Diffusion Models,DM) 是一种生成模型,其基本思想是通过逐步添加噪声来生成数据,并通过反向过程逐步还原数据。它的本质是一个马尔可夫架构,其中训练过程利用了深度学习的反向传播(BP)算法,但它更注重于数学层面的创新。

在扩散模型中,通过迭代地应用噪声函数,数据逐渐变得模糊或含有噪声。然后,通过反向推理的方式,模型尝试逐步还原每一步加入的噪声,从而还原出无噪声的原始数据。这个过程可以看作是在马尔可夫链中进行的,每一步的噪声预测依赖于前一步的状态。

与传统的生成模型相比,扩散模型在训练过程中使用了深度学习的反向传播算法,通过最小化还原后数据与原始数据之间的差异来优化模型参数。这使得模型能够学习到数据的概率分布,并生成具有与原始数据相似特征的样本。

尽管扩散模型使用了深度学习的反向传播算法进行训练,但其核心思想是基于数学层面的创新,通过马尔可夫架构和逐步还原的方式生成数据。它在图像生成、图像修复和数据增强等任务中展现了出色的性能和创新性。

区别

与提到的在一维空间中模拟热量扩散的例子,它是一种基于物理学的扩散模型,特别是热传导方程。这个模型描述了热量在一维空间中的传播过程,它是一种连续性模型。

与此相比,扩散模型(Diffusion Models,DM)是指一类生成模型,如扩散变分自编码器(Diffusion Variational Autoencoders,Diffusion VAEs)或扩散生成对抗网络(Diffusion Generative Adversarial Networks,Diffusion GANs)。这些模型使用了一种基于深度学习的方法,通过逆扩散过程生成数据样本。

虽然这两种模型中都存在“扩散”这个词,但它们的概念和应用是不同的。物理学中的扩散模型用于描述物质或能量在空间中的传播,而生成模型中的扩散模型用于生成数据样本。

因此,在你提到的例子中,我们可以将其称为热传导模型或热传导方程,而不是生成模型中的扩散模型。这两类模型有不同的目的和方法,应用于不同的领域和问题。

示例

一个常见的例子是扩散变分自编码器(Diffusion Variational Autoencoders,Diffusion VAEs)。下面是一个简单的用Python实现的扩散变分自编码器的例子:

import torch
import torch.nn as nn
import torch.optim as optim
from torch.distributions import Normal

# 定义扩散变分自编码器的类
class DiffusionVAE(nn.Module):
    def __init__(self, input_dim, hidden_dim, latent_dim):
        super(DiffusionVAE, self).__init__()
        
        # 编码器
        self.encoder = nn.Sequential(
            nn.Linear(input_dim, hidden_dim),
            nn.ReLU(),
            nn.Linear(hidden_dim, latent_dim),
        )
        
        # 解码器
        self.decoder = nn.Sequential(
            nn.Linear(latent_dim, hidden_dim),
            nn.ReLU(),
            nn.Linear(hidden_dim, input_dim),
            nn.Sigmoid(),
        )
        
    def forward(self, x):
        # 编码
        z = self.encoder(x)
        
        # 生成随机噪声
        epsilon = torch.randn_like(z)
        
        # 逆扩散过程
        reconstructed_x = self.decoder(z + epsilon)
        
        return reconstructed_x, z

# 定义训练函数
def train(model, data, num_epochs, batch_size):
    criterion = nn.BCELoss()
    optimizer = optim.Adam(model.parameters(), lr=0.001)
    
    num_batches = len(data) // batch_size
    
    for epoch in range(num_epochs):
        for batch_idx in range(num_batches):
            # 获取当前批次的数据
            batch = data[batch_idx * batch_size : (batch_idx + 1) * batch_size]
            
            # 前向传播
            reconstructed_batch, z = model(batch)
            
            # 计算重构损失和KL散度
            reconstruction_loss = criterion(reconstructed_batch, batch)
            kl_divergence = 0.5 * torch.sum(z.pow(2) - torch.log(1 + z.pow(2)))
            
            # 总损失
            loss = reconstruction_loss + kl_divergence
            
            # 反向传播和优化
            optimizer.zero_grad()
            loss.backward()
            optimizer.step()
            
        # 打印当前epoch的损失
        print('Epoch [{}/{}], Loss: {:.4f}'.format(epoch+1, num_epochs, loss.item()))

# 示例数据
data = torch.randn(1000, 100)

# 创建扩散变分自编码器的实例
model = DiffusionVAE(input_dim=100, hidden_dim=256, latent_dim=64)

# 训练模型
train(model, data, num_epochs=10, batch_size=64)

这个例子展示了如何使用PyTorch实现一个简单的扩散变分自编码器。模型包括一个编码器和一个解码器,通过逆扩散过程进行训练。训练过程中,使用重构损失和KL散度来衡量重构的准确性和潜在空间的正则化。最终,模型在训练数据上逐渐学习生成数据样本。


五、深度学习结合扩散模型和PINN方法的区别与联系

却别与联系

深度学习结合扩散模型和PINN(Physics-Informed Neural Networks)方法都是用于建模和求解物理系统的方法。它们在目标和实现方式上存在一些差异和联系。

目标:

  1. 深度学习结合扩散模型的目标是通过使用深度神经网络学习扩散过程中的模式和规律,从给定的初始条件预测最终的温度分布。它依赖于大量的数据来训练神经网络,并可以通过反向传播算法进行优化。

  2. PINN方法的目标是将已知的物理方程(如扩散方程)作为约束条件嵌入到神经网络中,通过优化神经网络参数来满足这些物理方程的约束条件。它利用神经网络的非线性拟合能力来逼近物理系统的解,并通过优化算法(如梯度下降)来调整网络参数。

实现方式:

  1. 深度学习结合扩散模型使用卷积神经网络等深度学习模型,通过训练数据来学习扩散过程中的模式和规律。它主要关注于数据驱动的建模和预测,不需要显式地使用物理方程。

  2. PINN方法将物理方程嵌入到神经网络的结构中,通过网络的输入和输出来表示物理系统的状态和约束条件。它通过优化网络参数来同时满足数据和物理方程的约束条件,从而得到物理系统的解。PINN方法更注重于使用物理方程进行建模和求解。
    优点和适用性:

  3. 深度学习结合扩散模型在处理复杂的非线性扩散过程时具有较强的拟合能力和灵活性。它适用于复杂的实际问题,尤其是当物理方程难以解析求解或者缺乏准确的物理参数时。

  4. PINN方法将物理方程作为先验知识嵌入到神经网络中,可以更好地利用物理系统的结构和特性。它适用于需要准确的物理解释和较少训练数据的问题,可以提供更好的泛化性能。

需要注意的是,深度学习结合扩散模型和PINN方法并不是相互排斥的方法,而是可以互补使用的。在实际应用中,根据问题的特点和需求,可以选择合适的方法或将它们结合起来,以得到更好的建模和求解效果。

两者结合的简单例子

一个简单的例子是通过结合深度学习和PINN方法来求解具有非线性边界条件的扩散方程。在这个例子中,我们将使用深度学习来学习扩散过程中的模式和规律,并将物理方程的约束条件嵌入到神经网络中。

考虑一个一维扩散问题,扩散方程的形式为:

∂u/∂t = ∂²u/∂x²

其中,u是温度分布,t是时间,x是空间。

我们将在一个区域[0, L]上求解该方程,并假设边界条件为非线性的。具体而言,我们定义边界条件为:

u(0, t) = sin(t)
u(L, t) = exp(-t)

我们希望通过深度学习和PINN方法来求解在给定初始条件:

u(x, 0) = sin(πx/L)

的情况下,扩散方程的解。

结合起来的python代码

在这个例子中,我们首先定义了一个扩散方程模型,使用多层感知机(MLP)来近似扩散方程的解。然后,我们构建了训练数据,包括空间和时间上的网格点以及对应的精确解。接下来,我们定义了PINN模型,其中包含了MLP结构,并定义了损失函数和优化器。在训练过程中,我们使用自动微分计算了模型的梯度,并根据扩散方程的物理约束计算了残差。最后,我们使用训练好的模型进行预测,并将预测结果可视化。

import torch
import torch.nn as nn
import torch.optim as optim
import numpy as np
import matplotlib.pyplot as plt

# 定义扩散方程模型
class DiffusionModel(nn.Module):
    def __init__(self):
        super(DiffusionModel, self).__init__()
        self.fc = nn.Sequential(
            nn.Linear(2, 10),
            nn.ReLU(),
            nn.Linear(10, 10),
            nn.ReLU(),
            nn.Linear(10, 1)
        )

    def forward(self, x):
        return self.fc(x)

# 构建训练数据
L = 1.0
num_points = 100
t_initial = 0.0
t_final = 1.0
x = np.linspace(0, L, num_points)
t = np.linspace(t_initial, t_final, num_points)
x_mesh, t_mesh = np.meshgrid(x, t)
x_flat = x_mesh.flatten()
t_flat = t_mesh.flatten()
u_exact = np.sin(np.pi * x_mesh / L) * np.exp(-t_mesh)
u_exact = u_exact.flatten()

# 转换为张量
x_train = torch.tensor([x_flat, t_flat], dtype=torch.float).t().requires_grad_(True)
u_train = torch.tensor(u_exact, dtype=torch.float).unsqueeze(1)

# 定义PINN模型
model = DiffusionModel()

# 定义损失函数
loss_fn = nn.MSELoss()

# 定义优化器
optimizer = optim.Adam(model.parameters(), lr=0.01)

# 训练模型
num_epochs = 1000
for epoch in range(num_epochs):
    optimizer.zero_grad()

    # 前向传播
    u_pred = model(x_train)
    x_grad = torch.autograd.grad(u_pred, x_train, grad_outputs=torch.ones_like(u_pred), create_graph=True)[0]
    u_t = x_grad[:, 1].unsqueeze(1)
    u_x = x_grad[:, 0].unsqueeze(1)
    u_xx = torch.autograd.grad(u_x, x_train, grad_outputs=torch.ones_like(u_pred), create_graph=True)[0][:, 0].unsqueeze(1)

    # 物理约束
    residual = u_t - u_xx

    # 计算损失
    loss = loss_fn(residual, torch.zeros_like(residual)) + loss_fn(u_pred[0], u_train[0])

    # 反向传播和优化
    loss.backward()
    optimizer.step()

    if (epoch + 1) % 100 == 0:
        print(f"Epoch [{epoch+1}/{num_epochs}], Loss: {loss.item()}")

# 使用训练好的模型进行预测
with torch.no_grad():
    u_pred = model(x_train)

# 可视化结果
u_pred = u_pred.view(num_points, num_points).numpy()
plt.imshow(u_pred, extent=[0, L, t_initial, t_final], origin='lower', aspect='auto')
plt.colorbar(label='Temperature')
plt.xlabel('Position')
plt.ylabel('Time')
plt.title('Diffusion Equation Solution')
plt.show()

输出结果:
在这里插入图片描述

两者结合的优势

通过结合深度学习和PINN方法,我们可以在不需要显式求解扩散方程的情况下,通过学习数据和物理方程的约束条件来预测扩散过程中的温度分布。深度学习部分可以帮助我们学习扩散过程中的模式和规律,而PINN方法则确保模型满足扩散方程的物理约束条件。这种结合可以提高模型的准确性和泛化能力,尤其在面对复杂的非线性扩散问题时具有优势。


六、总结

扩散模型是一种数学模型,用于描述物质在空间中的传播和扩散过程。它基于扩散方程,该方程描述了物质浓度或温度在时间和空间上的变化。扩散模型假设物质沿着浓度或温度梯度的方向传播,并受到浓度差或温度差的驱动。通过解析或数值方法求解扩散方程,可以预测物质在不同时间和位置上的分布,从而在许多领域中应用于理解和解决扩散相关的问题,如化学反应、热传导、生物医学等。

深度学习结合扩散模型和PINN方法可以用于求解物理系统,其中深度学习通过学习数据模式来预测结果,PINN方法将物理方程约束嵌入神经网络中。它们的结合可以提高模型的准确性和泛化能力,特别适用于复杂非线性问题。

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

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

相关文章

Android Bitmap 模糊效果实现 (二)

文章目录 Android Bitmap 模糊效果实现 (二)使用 Vukan 模糊使用 RenderEffect 模糊使用 GLSL 模糊RS、Vukan、RenderEffect、GLSL 效率对比 Android Bitmap 模糊效果实现 (二) 本文首发地址 https://blog.csdn.net/CSqingchen/article/details/134656140 最新更新地址 https:/…

Java之API(上):Integer

前言: 这一次内容主要是围绕Java开发中的一些常用类,然后主要是去学习这些类里面的方法。 一、高级API: (1)介绍:API指的是应用程序编程接口,API可以让编程变得更加方便简单。Java也提供了大量API供程序开发者使用&…

Vue框架学习笔记——侦听(监视)属性watch:天气案例+immediate+deep深度监听

文章目录 前文提要天气案例描述样例代码呈现效果:事件的响应中可以写一些简单的语句(不推荐) 侦听(监视)属性watch结合天气案例的第一种写法(New Vue)immediate: 侦听(监…

【Java数据结构 -- 包装类和泛型】

包装类和泛型 1. 包装类1.1 基本数据类型和对应的包装类1.2 装箱和拆箱1.3 自动装箱和自动拆箱1.4 自动装箱实际上是调用了valueOf()1.5 Integer包装类赋值注意点 2 什么是泛型3 引出泛型4 泛型的使用4.1 语法4.2 类型推导 5 裸类型6 泛型如何编译6.1 擦…

2019年8月21日 Go生态洞察:迁移到Go模块

🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…

【从删库到跑路 | MySQL总结篇】表的增删查改(进阶上)

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】🎈 本专栏旨在分享学习MySQL的一点学习心得,欢迎大家在评论区讨论💌 目录 一、数据…

数据增强让模型更健壮

在做一些图像分类训练任务时,我们经常会遇到一个很尴尬的情况,那就是: 明明训练数据集中有很多可爱猫咪的照片,但是当我们给训练好的模型输入一张戴着头盔的猫咪进行测试时,模型就不认识了,或者说识别精度很低。 很明显,模型的泛化能力太差,难道戴着头盔的猫咪就不是猫…

坚鹏:贵州银行西南财经大学零售业务数字化转型与场景营销策略

中国银保监会2022年1月正式发布了中国银保监会发布《关于银行业保险业数字化转型的指导意见》,这标准着中国银行业从局部的数字化转型向全面的数字化转型转变,进一步加速了银行数字化转型高潮的到来。 《关于银行业保险业数字化转型的指导意见》提出明确…

一次脚本测试的内存增长问题

问题背景 问题描述:进入应用的视频素材剪辑页面然后退出,脚本循环执行500次,内存增长156M 问题分析 分析增长曲线图 曲线反映了从0到500次脚本执行过程中adb shell dumpsys meminfo抓取内存的增长情况,可以看出是Native内存一直…

JavaScript解构对象

之前介绍了数组解构,本文来介绍一下对象如何解构; 前言 现在我们有这样的一个数组: const restaurant {name: Classico Italiano,location: Via Angelo Tavanti 23, Firenze, Italy,categories: [Italian, Pizzeria, Vegetarian, Organic…

LINUX入门篇【10】---进程篇【2】---进程状态

前言: 有了上一篇关于进程的初步认识和我们的PCB第一个数据段–标识符的讲解,接下来我们将继续讲解PCB的其他数据段,本篇要讲的是进程状态。 进程状态: 就像我们写贪吃蛇的时候,构建的游戏状态来判定游戏结束的方式…

1-1、汇编语言概述

语雀原文链接 文章目录 1、机器语言2、汇编语言(Assembly Language)汇编语言工作过程汇编语言三类指令 3、学习资料电子PDF课件论坛视频教程 1、机器语言 机器语言是机器指令的集合。机器指令展开来讲就是一台机器可以正确执行的命令。电子计算机的机器…

【uniapp】微信运行报错TypeError_ Cannot read property ‘FormData‘ of undefined

文章目录 一、报错详情:二、解决: 一、报错详情: 二、解决: npm install axios0.27.2 #或者 npm install axios1.3.4

SpringBoot——国际化

优质博文:IT-BLOG-CN 一、Spring 编写国际化时的步骤 【1】编写国际化配置文件; 【2】使用ResourceBundleMessageSource管理国际化资源文件; 【3】在页面使用ftp:message取出国际化内容; 二、SpringBoot编写国际化步骤 【1】创…

【算法优选】 动态规划之路径问题——壹

文章目录 🎋前言🎋[不同路径](https://leetcode.cn/problems/unique-paths/)🚩题目描述:🚩算法思路:🚩代码实现 🎋[不同路径二](https://leetcode.cn/problems/unique-paths-ii/desc…

金蝶Apusic应用服务器 任意文件上传漏洞复现

0x01 产品简介 金蝶Apusic应用服务器(Apusic Application Server,AAS)是一款标准、安全、高效、集成并具丰富功能的企业级应用服务器软件,全面支持JakartaEE8/9的技术规范,提供满足该规范的Web容器、EJB容器以及WebSer…

使用echars实现数据可视化

生活随笔 展翅飞翔之际 请下定决心不再回头 echars实现数据可视化 在搭建后台页面时,可能会遇到很多的表格,但有时表格所展现的数据并不能直观的体现出当前用户的宏观信息,所以就可以引入一个新的表格插件——echars 快速上手 - Handbook…

客户关系管理系统功能清单

客户关系管理系统功能清单 一、客户信息管理 1. 客户基本信息:包括客户名称、地址、电话、电子邮件等。 2. 客户关系信息:包括客户的购买历史、服务记录、支持案例等。 3. 客户分类信息:根据客户的重要程度、购买行为、偏好等因素&#xff…

01-鸿蒙4.0学习之开发环境搭建 HelloWorld

HarmonyOS开发学习 1.环境配置 1.下载地址 开发工具:DevEco Studio 3.1.1 Release 下载地址 安装选择快捷方式 安装nodejs和Ohpm 安装SDK 选择同意Accept 检测8项目是否安装成功 2.创建项目 —— hello word

美国高防云服务器的优劣势分析(相比普通云服务器)

在当前数字化时代,云服务器已经成为企业和个人进行在线业务的重要基础设施。而在选择云服务器时,很多人会面临一个问题:是选择普通云服务器还是高防云服务器?本文将从多个方面来分析美国高防云服务器相比普通云服务器的优势和劣势。 我们来看…