Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network

  • 摘要
  • 论文主体
  • 实现代码
    • Dataset
    • Model
    • SRGAN
    • 实现结果

摘要

Despite the breakthroughs in accuracy and speed of single image super-resolution using faster and deeper convolutional neural networks, one central problem remains largely unsolved: how do we recover the finer texture details when we super-resolve at large upscaling factors? The behavior of optimization-based super-resolution methods is
principally driven by the choice of the objective function.Recent work has largely focused on minimizing the mean squared reconstruction error. The resulting estimates have
high peak signal-to-noise ratios, but they are often lacking high-frequency details and are perceptually unsatisfying in the sense that they fail to match the fidelity expected at
the higher resolution. In this paper, we present SRGAN,a generative adversarial network (GAN) for image superresolution (SR). To our knowledge, it is the first framework capable of inferring photo-realistic natural images for 4×upscaling factors. To achieve this, we propose a perceptual loss function which consists of an adversarial loss and a content loss. The adversarial loss pushes our solution to the natural image manifold using a discriminator network that is trained to differentiate between the super-resolved
images and original photo-realistic images. In addition, we use a content loss motivated by perceptual similarity instead of similarity in pixel space. Our deep residual network
is able to recover photo-realistic textures from heavily downsampled images on public benchmarks. An extensive mean-opinion-score (MOS) test shows hugely significant
gains in perceptual quality using SRGAN. The MOS scores obtained with SRGAN are closer to those of the original high-resolution images than to those obtained with any
state-of-the-art method.

论文主要讲述GAN应用于超分辨率的研究。作者们命名了一种对抗神经网络为SRGAN,它可以很好地将低分辨率图像恢复成原始高分辨率图像。在MOS测试中,SRGAN取得了比传统方法都更高的得分。

论文主体

https://arxiv.org/pdf/1609.04802v5.pdf

实现代码

读这篇论文的主要工作就是把论文中的方法复现一下,github中有许多同类型的开源项目,但由于版本更迭的问题,直接down下来的代码往往会有许多bug。在这里记录一下调试代码的全过程。

Dataset

数据集下载网址:http://mmlab.ie.cuhk.edu.hk/projects/CelebA.html
celebA是一个人脸数据集,包含几十万张不同的人脸图片,同时这些数据已经是裁剪好的,并且经过压缩后占用空间都非常小,非常适合进行需要大量人脸图片的训练。

之后构建dataset.py来读取dataset。

dataset.py

import glob
import random
import os
import numpy as npimport torch
from torch.utils.data import Dataset
from PIL import Image
import torchvision.transforms as transforms# Normalization parameters for pre-trained PyTorch models
mean = np.array([0.485, 0.456, 0.406])
std = np.array([0.229, 0.224, 0.225])class ImageDataset(Dataset):def __init__(self, root, hr_shape):hr_height, hr_width = hr_shape# Transforms for low resolution images and high resolution imagesself.lr_transform = transforms.Compose([transforms.Resize((hr_height // 4, hr_height // 4), Image.BICUBIC),transforms.ToTensor(),transforms.Normalize(mean, std),])self.hr_transform = transforms.Compose([transforms.Resize((hr_height, hr_height), Image.BICUBIC),transforms.ToTensor(),transforms.Normalize(mean, std),])self.files = sorted(glob.glob(root + "/*.*"))def __getitem__(self, index):img = Image.open(self.files[index % len(self.files)])img_lr = self.lr_transform(img)img_hr = self.hr_transform(img)return {"lr": img_lr, "hr": img_hr}def __len__(self):return len(self.files)

注意这里指定的读取路径是文件中的每一个图片,也就是如果用data/img_align_celeba文件夹来存储数据的话,需要将图片全部解压放置在data/img_align_celeba中。

Model

直接用github中写好的论文中的网络结构

models.py

import torch.nn as nn
import torch.nn.functional as F
import torch
from torchvision.models import vgg19
import mathclass FeatureExtractor(nn.Module):def __init__(self):super(FeatureExtractor, self).__init__()vgg19_model = vgg19(pretrained=True)self.feature_extractor = nn.Sequential(*list(vgg19_model.features.children())[:18])def forward(self, img):return self.feature_extractor(img)class ResidualBlock(nn.Module):def __init__(self, in_features):super(ResidualBlock, self).__init__()self.conv_block = nn.Sequential(nn.Conv2d(in_features, in_features, kernel_size=3, stride=1, padding=1),nn.BatchNorm2d(in_features, 0.8),nn.PReLU(),nn.Conv2d(in_features, in_features, kernel_size=3, stride=1, padding=1),nn.BatchNorm2d(in_features, 0.8),)def forward(self, x):return x + self.conv_block(x)class GeneratorResNet(nn.Module):def __init__(self, in_channels=3, out_channels=3, n_residual_blocks=16):super(GeneratorResNet, self).__init__()# First layerself.conv1 = nn.Sequential(nn.Conv2d(in_channels, 64, kernel_size=9, stride=1, padding=4), nn.PReLU())# Residual blocksres_blocks = []for _ in range(n_residual_blocks):res_blocks.append(ResidualBlock(64))self.res_blocks = nn.Sequential(*res_blocks)# Second conv layer post residual blocksself.conv2 = nn.Sequential(nn.Conv2d(64, 64, kernel_size=3, stride=1, padding=1), nn.BatchNorm2d(64, 0.8))# Upsampling layersupsampling = []for out_features in range(2):upsampling += [# nn.Upsample(scale_factor=2),nn.Conv2d(64, 256, 3, 1, 1),nn.BatchNorm2d(256),nn.PixelShuffle(upscale_factor=2),nn.PReLU(),]self.upsampling = nn.Sequential(*upsampling)# Final output layerself.conv3 = nn.Sequential(nn.Conv2d(64, out_channels, kernel_size=9, stride=1, padding=4), nn.Tanh())def forward(self, x):out1 = self.conv1(x)out = self.res_blocks(out1)out2 = self.conv2(out)out = torch.add(out1, out2)out = self.upsampling(out)out = self.conv3(out)return outclass Discriminator(nn.Module):def __init__(self, input_shape):super(Discriminator, self).__init__()self.input_shape = input_shapein_channels, in_height, in_width = self.input_shapepatch_h, patch_w = int(in_height / 2 ** 4), int(in_width / 2 ** 4)self.output_shape = (1, patch_h, patch_w)def discriminator_block(in_filters, out_filters, first_block=False):layers = []layers.append(nn.Conv2d(in_filters, out_filters, kernel_size=3, stride=1, padding=1))if not first_block:layers.append(nn.BatchNorm2d(out_filters))layers.append(nn.LeakyReLU(0.2, inplace=True))layers.append(nn.Conv2d(out_filters, out_filters, kernel_size=3, stride=2, padding=1))layers.append(nn.BatchNorm2d(out_filters))layers.append(nn.LeakyReLU(0.2, inplace=True))return layerslayers = []in_filters = in_channelsfor i, out_filters in enumerate([64, 128, 256, 512]):layers.extend(discriminator_block(in_filters, out_filters, first_block=(i == 0)))in_filters = out_filterslayers.append(nn.Conv2d(out_filters, 1, kernel_size=3, stride=1, padding=1))self.model = nn.Sequential(*layers)def forward(self, img):return self.model(img)

SRGAN

最后编写训练模块

srgan.py

import argparse
import os
import numpy as np
import math
import itertools
import sysimport torchvision.transforms as transforms
from torchvision.utils import save_image, make_gridfrom torch.utils.data import DataLoader
from torch.autograd import Variablefrom models import *
from datasets import *import torch.nn as nn
import torch.nn.functional as F
import torchos.makedirs("images", exist_ok=True)
os.makedirs("saved_models", exist_ok=True)parser = argparse.ArgumentParser()
parser.add_argument("--epoch", type=int, default=0, help="epoch to start training from")
parser.add_argument("--n_epochs", type=int, default=200, help="number of epochs of training")
parser.add_argument("--dataset_name", type=str, default="img_align_celeba_demo", help="name of the dataset")
parser.add_argument("--batch_size", type=int, default=4, help="size of the batches")
parser.add_argument("--lr", type=float, default=0.0002, help="adam: learning rate")
parser.add_argument("--b1", type=float, default=0.5, help="adam: decay of first order momentum of gradient")
parser.add_argument("--b2", type=float, default=0.999, help="adam: decay of first order momentum of gradient")
parser.add_argument("--decay_epoch", type=int, default=100, help="epoch from which to start lr decay")
parser.add_argument("--n_cpu", type=int, default=8, help="number of cpu threads to use during batch generation")
parser.add_argument("--hr_height", type=int, default=256, help="high res. image height")
parser.add_argument("--hr_width", type=int, default=256, help="high res. image width")
parser.add_argument("--channels", type=int, default=3, help="number of image channels")
parser.add_argument("--sample_interval", type=int, default=500, help="interval between saving image samples")
parser.add_argument("--checkpoint_interval", type=int, default=50, help="interval between model checkpoints")
opt = parser.parse_args()
print(opt)cuda = torch.cuda.is_available()hr_shape = (opt.hr_height, opt.hr_width)# Initialize generator and discriminator
generator = GeneratorResNet()
discriminator = Discriminator(input_shape=(opt.channels, *hr_shape))
feature_extractor = FeatureExtractor()# Set feature extractor to inference mode
feature_extractor.eval()# Losses
criterion_GAN = torch.nn.MSELoss()
criterion_content = torch.nn.L1Loss()if cuda:generator = generator.cuda()discriminator = discriminator.cuda()feature_extractor = feature_extractor.cuda()criterion_GAN = criterion_GAN.cuda()criterion_content = criterion_content.cuda()if opt.epoch != 0:# Load pretrained modelsgenerator.load_state_dict(torch.load("saved_models/generator_%d.pth"))discriminator.load_state_dict(torch.load("saved_models/discriminator_%d.pth"))# Optimizers
optimizer_G = torch.optim.Adam(generator.parameters(), lr=opt.lr, betas=(opt.b1, opt.b2))
optimizer_D = torch.optim.Adam(discriminator.parameters(), lr=opt.lr, betas=(opt.b1, opt.b2))Tensor = torch.cuda.FloatTensor if cuda else torch.Tensordataloader = DataLoader(ImageDataset("../../data/%s" % opt.dataset_name, hr_shape=hr_shape),batch_size=opt.batch_size,shuffle=True,num_workers=3,
)# ----------
#  Training
# ----------for epoch in range(opt.epoch, opt.n_epochs):for i, imgs in enumerate(dataloader):# Configure model inputimgs_lr = Variable(imgs["lr"].type(Tensor))imgs_hr = Variable(imgs["hr"].type(Tensor))# Adversarial ground truthsvalid = Variable(Tensor(np.ones((imgs_lr.size(0), *discriminator.output_shape))), requires_grad=False)fake = Variable(Tensor(np.zeros((imgs_lr.size(0), *discriminator.output_shape))), requires_grad=False)# ------------------#  Train Generators# ------------------optimizer_G.zero_grad()# Generate a high resolution image from low resolution inputgen_hr = generator(imgs_lr)# Adversarial lossloss_GAN = criterion_GAN(discriminator(gen_hr), valid)# Content lossgen_features = feature_extractor(gen_hr)real_features = feature_extractor(imgs_hr)loss_content = criterion_content(gen_features, real_features.detach())# Total lossloss_G = loss_content + 1e-3 * loss_GANloss_G.backward()optimizer_G.step()# ---------------------#  Train Discriminator# ---------------------optimizer_D.zero_grad()# Loss of real and fake imagesloss_real = criterion_GAN(discriminator(imgs_hr), valid)loss_fake = criterion_GAN(discriminator(gen_hr.detach()), fake)# Total lossloss_D = (loss_real + loss_fake) / 2loss_D.backward()optimizer_D.step()# --------------#  Log Progress# --------------batches_done = epoch * len(dataloader) + iif batches_done % opt.sample_interval == 0:# Save image grid with upsampled inputs and SRGAN outputsimgs_lr = nn.functional.interpolate(imgs_lr, scale_factor=4)gen_hr = make_grid(gen_hr, nrow=1, normalize=True)imgs_lr = make_grid(imgs_lr, nrow=1, normalize=True)img_grid = torch.cat((imgs_lr, gen_hr), -1)save_image(img_grid, "images/%d.png" % batches_done, normalize=False)sys.stdout.write("[Epoch %d/%d] [D loss: %f] [G loss: %f]"% (epoch+1, opt.n_epochs, loss_D.item(), loss_G.item()))print(" ")if opt.checkpoint_interval != -1 and (epoch+1) % opt.checkpoint_interval == 0:# Save model checkpointstorch.save(generator.state_dict(), "saved_models/generator_%d.pth" % epoch)torch.save(discriminator.state_dict(), "saved_models/discriminator_%d.pth" % epoch)

原作者构建的srgan.py运行环境在控制台中,这样便于使用但不适合调试。为了方便地调试还是用IDE打开更好一些。

代码中有几个需要注意的问题:

①首先是版本问题,这里要求pytorch为最新版,否则utils的读取可能会出现调包路径错误的问题。

②在dataloader中

dataloader = DataLoader(ImageDataset("../../data/%s" % opt.dataset_name, hr_shape=hr_shape),batch_size=opt.batch_size,shuffle=True,num_workers=3,
)

当出现samle读取数据量为0的错误时,将shuffle=True改为False。
当出现内存错误时,将num_workers=3改为0或直接默认为0。原因是Win系统中不能完美兼容多线程,很多时候因为指定了多个线程内存会莫名的溢出,改为0最保险。

③关于刚开始的默认参数:
batch_size,lr默认数值效果都很好,暂时还未尝试其他取值
epoch因为数据量巨大,应该酌情缩小一些(尝试了只用1k张图片跑epoch50,效果还可以)
checkpoint_interval和sample_interval都是监督训练进度的参数,保存模型和实时对比超分辨率恢复的情况。

实现结果

100张图像,epoch200,sample_interval取500(实际上就是batch跑了多少次,整个除法真上流
保存的部分结果如下:

初始:在这里插入图片描述
500次:
在这里插入图片描述
1000次:
在这里插入图片描述
2000次:
在这里插入图片描述

3000次:
在这里插入图片描述

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Python学习笔记(四)

    Python学习笔记(四) 主题:递归关键字:递归 斐波那契数列(Fibonacci)的实现:递归、迭代 汉诺塔(Hanoi)问题1、递归 >>> def recursion():return recursion()函数调用自己设置递归层数的方法: >>> import sys >>> sys.setrecursionlimit(10) …...

    2024/5/3 5:28:02
  2. 进程间的通讯方式

    进程间的通信方式 通信方式总览每个进程的用户地址空间都是独立的,一般而言是不能互相访问的,但内核空间是每个进程都共享的,所以进程之间要通信必须通过内核。1、管道(匿名管道) 如果你学过 Linux 命令,那你肯定很熟悉「|」这个竖线。 $ ps auxf | grep mysql上面命令行…...

    2024/4/18 5:17:37
  3. 【日常】-腾讯往年笔试-压缩算法

    题目描述 小Q想要给他的朋友发送一个神秘字符串,但是他发现字符串的过于长了,于是小Q发明了一种压缩算法对字符串中重复的部分进行了压缩,对于字符串中连续的m个相同字符串S将会压缩为m|S,例如字符串ABCABCABC将会被压缩为[3|ABC],现在小Q的同学收到了小Q发送过来的字符串…...

    2024/4/28 22:28:59
  4. mac 杀掉占用某个端口的进程

    lsof -i :端口 kill -9 进程id...

    2024/4/17 8:15:50
  5. Kafka生产者帮助文档

    Kafka生产者步骤可以将输入流中的信息通过Kafka服务器发布给订阅了主题的Kafka消费者。该步骤有“建立连接”、“其他选项”两个标签页。“建立连接”标签页配置信息如图1所示。图1 “建立连接”标签页配置信息下文详细解释各控件的含义:1、步骤名称:步骤的名称,在单一转换中…...

    2024/4/22 23:57:49
  6. Java小程序:生产者-消费者 的经典问题 (多线程)

    描述: 有 生产者、消费者、产品。要求产品的数量大于20生产者暂停生产;产品为0,消费者暂停消费,有产品则可以消费 代码:产品类:class ProductNum{private int number=0;public synchronized void Import() {if(number<20) {number++;notify();}else {try {wait();} ca…...

    2024/5/3 4:01:48
  7. 实例变量、类变量(static静态变量)区别

    二者都属于类成员变量,static修饰的为类变量(也称为静态变量),无修饰的称为实例变量。类变量从类定义时就开始存在,直到完全销毁。类变量作为类本身的一个成员,与类本生共存亡;实例变量,作为实例的一个成员,与实例共存亡。只要类存在,类变量就可以访问。实例变量在每…...

    2024/4/11 21:35:45
  8. MySQL探险-3、查询

    文章目录一、概览:二、关键步骤分析:  ①查询缓存    查询缓存的内存管理  ②解析和预处理  ③查询优化器  ④查询执行引擎  ⑤返回结果三、SQL 的查询执行顺序:四、SQL 的 Join 关系:五、MySQL 常用函数:  ①字符函数  ②数学函数  ③日期函数  ④…...

    2024/4/22 15:10:36
  9. 【“工业大数据预测”系列】——第3篇:基于统计和信号的特征提取

    文章目录1 基于统计的时域特征1.1 均方根(Root Mean Square, RMS)1.2 方差(Variance)1.3 最大值(Max)和最小值(Min)1.4 偏度(Skewness)1.5 峰峰值(Peak to Peak, PP)1.6 峰度(Kurtosis)2 基于频谱分析的频域特征提取2.1 谱偏态系数2.2 谱峰态系数2.3 谱功率3 基于小波包能量的时…...

    2024/4/26 16:06:43
  10. 转encode64(base64)

    针对于富文本带标签操作或者带;传输失败问题 js转encode64进行传输 area: encode64($(#area).val())后台获取area,转回UTF-8 DeBase64(area)public static string DeBase64(this string str){if (string.IsNullOrWhiteSpace(str)){return string.Empty;}return HttpUtility.Ur…...

    2024/4/14 16:22:50
  11. 读取文件夹所有文件,并按顺序保存

    import os import cv2 from PIL import Image path = "path" #文件夹目录 files= os.listdir(path) #得到文件夹下的所有文件名称 i=0 for file in files: #遍历文件夹 img = Image.open(path + file)img.save(path + %d.png %(i))i += 1...

    2024/5/2 17:17:54
  12. Thread: 在JAVA中 创建 #线程# 的方法

    一、继承Thread类1.创建一个方法继承于Thread 2.重写Tread中的run方法,将线程要执行的操作声明在run() 中 3.创建Thread类的子类的对象 4.通过创建的对象调用start方法: ①使创建的线程执行; ②调用线程的run方法 ③可以使用Thread的匿名对象调用start,需要重写run() 5.不能通…...

    2024/4/14 10:50:19
  13. 关于解决mybatis的org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.hua

    假如常规方法解决不了,看不出毛病的话,应该是resource下静态目录创建时,比如创建了mybatis.mapper的文件夹里存放mapper.xml文件,这种创建方法默认为一个文件夹,应该mybatis/mapper创建就ok了...

    2024/4/27 10:16:13
  14. SAP中发票校验凭证与取消发票校验凭证后继记账对比

    以下图的采购订单历史为例展示发票校验凭证与取消发票校验凭证后继记账对比分别打开两笔互为冲销关系的发票5105627420和5105627637;并分别打开其后继凭证;对比观察两行凭证的记账规律;...

    2024/4/19 8:22:33
  15. 浙大PAT数据结构与算法题目集(中文)题解集复习用

    7-1 最大子列和问题 (20分)(dp或贪心) 给定K个整数组成的序列{ N1, N2, …, N**K },“连续子列”被定义为{ N**i, N**i+1, …, N**j },其中 1≤i≤j≤K。“最大子列和”则被定义为所有连续子列元素的和中最大者。例如给定序列{ -2, 11, -4, 13, -5, -2 },其连续子列{ 11, …...

    2024/4/25 16:33:15
  16. Java初学总结(十七)学生管理系统

    package com.wangxing.bean; /*** 保存学生信息的java类* @author Administrator**/ public class Student {//学生学号private int stuid;//学生姓名private String stuname;//学生年龄private int stuage;//学生地址private String stuaddress;//由于上面定义的保存学…...

    2024/4/19 3:23:15
  17. Swagger2中配置添加全局header

    目录引入maven依赖添加配置类说明 引入maven依赖 <dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.9.2</version> </dependency> <dependency><groupId>io.s…...

    2024/4/25 22:13:42
  18. 应用支撑平台的演变

    1.认知过程 一开始做售前,碰到了“五横两纵图”,其中应用支撑平台是长这样的:细看了文档内容发现,是公司本身的开发环境(我们暂且称之为“公司1”),“公司1”是这样描述的:“本公司多年来在政府电子政务领域积累了丰富的行业知识,结合行业特点,按照SOA思想设计,以业…...

    2024/4/10 11:18:08
  19. 扩展Vue.js组件

    您的Vue应用程序中是否有共享类似选项的组件,甚至模板标记?使用公共选项和标记创建基本组件,然后扩展基本组件以创建子组件,这是一个好主意。这样的体系结构将帮助您在代码中应用DRY原则(不要重复您自己),这将使您的代码更具可读性,并减少错误的可能性。Vue提供了一些功能…...

    2024/4/30 17:28:19
  20. 浏览器重置样式

    body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, fieldset, legend, button, input, textarea, th, td { margin: 0;padding: 0 } body, button, input, select, textarea { font: 12px “microsoft yahei”;line-height: 1.5;-ms-overf…...

    2024/4/20 15:42:10

最新文章

  1. 关于前后端的参数传递

    以前端javascript&#xff0c;后端nodejsexpress为例&#xff0c;后端可以从前端发来的request里获取这些属性&#xff1a;header、query、url、params、body&#xff0c;其中params和query是从url中解析获得&#xff0c;不过express已帮我们做好了&#xff0c;就不用我们自己再…...

    2024/5/3 9:40:30
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 天书奇谈_源码_搭建架设_3D最新天启版_自带假人

    本教程仅限学习使用&#xff0c;禁止商用&#xff0c;一切后果与本人无关&#xff0c;此声明具有法律效应&#xff01;&#xff01;&#xff01;&#xff01; 一. 效果演示 天书奇谈_源码_搭建架设 环境&#xff1a; centos7.6 &#xff0c; 放开所有端口 源码获取 https://…...

    2024/5/1 8:05:09
  4. 【蓝桥杯嵌入式】13届程序题刷题记录及反思

    一、题目分析 考察内容&#xff1a; led按键&#xff08;短按&#xff09;PWM输出&#xff08;PA1&#xff09;串口接收lcd显示 根据PWM输出占空比调节&#xff0c;高频与低频切换 串口接收&#xff08;指令解析&#xff09;【中断接收】 2个显示界面 led灯闪烁定时器 二…...

    2024/5/1 13:46:04
  5. Mybatis--TypeHandler使用手册

    TypeHandler使用手册 场景&#xff1a;想保存user时 teacher自动转String &#xff0c;不想每次保存都要手动去转String&#xff1b;从DB查询出来时&#xff0c;也要自动帮我们转换成Java对象 Teacher Data public class User {private Integer id;private String name;priva…...

    2024/5/1 14:21:06
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/2 11:19:01
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/2 16:04:58
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/2 23:55:17
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/2 9:47:31
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/2 9:47:31
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/2 6:03:07
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/2 9:47:30
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/2 23:47:43
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/2 5:31:39
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/3 1:55:15
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/2 9:47:28
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/2 9:47:27
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/3 1:55:09
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/2 8:37:00
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/2 9:47:26
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/2 9:47:25
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/2 23:47:16
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/2 18:46:52
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/3 7:43:42
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/3 1:54:59
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57