首先庆幸一下发现了一个非常好的python人工智能项目的入门网站MURTAZA’S WORKSHOP,上面的教程涵盖了opencv、self-drivng、robotics、arduino、raspberry pi等多个现在非常流行的主题。大约花了两天的时间跟着网站的教程走完了自动驾驶模拟(self-drivng simulation)这个课程,并且完成了从数据采集、数据预处理、数据训练到模型部署推理的全过程,下面进行复盘。

一、预备知识

完成这个项目,需要预备一下知识:

  • python的基础知识,主要是程序流程控制、模块函数调用、生成器、numpy、装饰器等基础知识。如果基础不牢固,可以参考python-basics进行学习;
  • anadonda和pycharm的使用,主要是使用anadonda建立虚拟环境,并且在pycharm中在建立的环境中搭建工程项目。
  • 图像处理的基本知识,主要是opencv的一些基本操作。如果对opencv不了解,可以参考learn opencv in 3 hours进行学习;
  • 深度学习(Deep Learning)、卷积神经网络(CNN)相关的基础知识,主要知道网络的结构和工作原理即可,内部的数学推导细节可以暂时不了解(因为确实很难)。这一块在b站上有很多视频教程,当然在MURTAZA’s Workshop的网站中也可以找到相关介绍。
  • 命令行(cmd)界面的使用,因为安装python模块命令行中比较方便,所以推荐使用。在windows中,可以使用cmd,操作方法是win+R,然后输入cmd进入,在mac中,则运行terminal即可。windows的操作详见windows下打开命令提示符的方式 。最后我们将进入以下界面。在这里插入图片描述

二、预装环境

  • Udacity的self-driving-car-sim模拟器,点击链接可以进入github下载界面,根据自己的操作系统来选择对应的下载。 在这里插入图片描述
  • Pycharm点击可以根据自己的操作系统下载对应的pycharm,pycharm是目前公认的最适合python变成的编辑器,可以选择社区版本(community)和专业版(professional),社区版是免费的。具体界面如下所示: 在这里插入图片描述
  • Anaconda,点击进入anaconda官网个人版下载界面,根据自己的操作系统进行下载,推荐下载3.7版本的,在安装的时候,会自动安装python3.7,但让要注意一定要把path的√点上。 我们可以使用conda命令来进行虚拟环境的搭建,这样比较适合做项目管理。使得不同的项目之间隔离开来。在这里插入图片描述

三、预装模块

在做这个项目的时候,我们需要预装一些模块,如在数据预处理阶段和训练阶段,我们需要安装以下模块:

  • opencv-python (python图像处理模块)
  • pandas (python数据处理模块)
  • numpy (python数组数据处理模块)
  • matplotlib (python科学作图模块)
  • sklearn (python机器学习模块)
  • tensorflow (深度学习框架,如果有Nvidia显卡的话,可以下载gpu版本tensorflow-gpu,这样可以快很多)
  • imgaug(python图像增强模块)
    在测试和验证阶段,我们需要安装以下模块:
  • socketio
  • eventlet
  • flask
  • base64
  • tensorlow
    首先,我们使用以下指令建立虚拟环境,如我们建立一个名为py3.7,指定python版本为3.7的虚拟环境,可以这样操作:
conda creat --name py3.7 python=python3.7

然后,我们可以使用conda的激活方法来进入这个虚拟环境:

conda activate py3.7

这样我们可以看到在cmd中,

我们可以在建立好的虚拟环境中使用pip install或者conda install进行下载,比如我们下载opencv-python,就可以使用以下指令:

pip install opencv-python

我们也可以使用空格作为分隔符,把多个模块名字罗列在命令后面,这样就可以实现批量下载,如

pip install pandas numpy sklearn

四、驾驶数据的采集

我们打开模拟器软件beta_simulator.exe,在过场动画之后可以进入初始化界面如下:
在这里插入图片描述
在这里插入图片描述
我们在训练阶段,使用Training Mode
在这里插入图片描述
进入之后,点击Record按钮,可以选择采集数据存放的路径。
小车会自动前行,我们只需要通过箭头方向键来控制方向,就可以让小车在道路上行驶,模拟器会以一定的频率采集图像和小车的状态数据,每次都会有左中右三张照片拍摄,并且记录方向盘的角度、油门、刹车、行车速度等等,存在一个名为“driving_log.csv"的文件当中,我们会在后面的程序中处理这些数据。
在这里插入图片描述
在这里插入图片描述

五、代码编写

5.1. 训练阶段的代码

本教程中,将训练阶段分成了十个步骤,分别下载了程序的注释中(Step1-Step10),然后保存到TrainingSimulation.py文件中,注意到,为了代码的可读性,十个步骤中使用了函数调用的方法,函数具体的流程算法在utlis.py模块实现。

TrainingSimulation.py

##print some infomation for remind
print('Setting Up')
##ignore some warnings from tensorflow
import os
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '3'
from utlis import *
from sklearn.model_selection import train_test_split
###Step 1:ReadData
path = "myData"
data = importDataInfo(path)
###Step 2:Visualization the balanced data, remove the redundent data
data = balanceData(data, display=False)
###Step 3:Create the numpy data that contain the images and its steering info
imagesPath, steerings = loadData(path, data)
###Step 4:Separate the data into training and validation data using sklearn
# xTrain, xVal, yTrain, yVal = train_test_split(imagesPath, steerings, test_size=0.2, random_state=10)
# print('Total training Images:', len(xTrain))
# print('Total validation Images', len(xVal))
xTrain, xVal, yTrain, yVal = train_test_split(imagesPath, steerings, test_size=0.2,random_state=10)
print('Total Training Images: ',len(xTrain))
print('Total Validation Images: ',len(xVal))
###Step 5:Augument the images to create more pictures for training
# imgRe = preProcess(mpimg.imread('test.jpg'))
# plt.imshow(imgRe)
# plt.show()
###Step 6:Pre-process adding Flip, pan, zoom and so on
###Step 7:generate more images as training samples
###Step 8:create model using keras
model = createModel()
model.summary()
###Step 9:train the model
# model.fit(batchGen(xTrain,yTrain,10,1),steps_per_epoch=20,epochs=2,\
# 		  validation_data=batchGen(xVal,yVal,10,0),validation_steps=20)
history = model.fit(batchGen(xTrain, yTrain, 100, 1),steps_per_epoch=300,epochs=10,validation_data=batchGen(xVal, yVal, 100, 0),validation_steps=200)
# Step 10: Saving & Plotting
model.save('model.h5')
print('Model Saved')
plt.plot(history.history['loss'])
plt.plot(history.history['val_loss'])
plt.legend(['Training','Validation'])
plt.ylim([0,1])
plt.title('Loss')
plt.xlabel('Epoch')
plt.show()

utlils.py

import pandas as pd
import numpy as np
import cv2
import os
import random
from matplotlib import pyplot as plt
from sklearn.utils import shuffle
import matplotlib.image as mpimg
from imgaug import augmenters as iaa
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Convolution2D,Flatten,Dense
from tensorflow.keras.optimizers import Adamdef getName(filePath):return filePath.split('\\')[-1]def importDataInfo(path):colums = ['Center','Left','Right','Steering','Throttle','Brake','Speed']data = pd.read_csv(os.path.join(path,'driving_log.csv'),names = colums, skipinitialspace=True, skiprows=1, engine="python")# print(data.head())# print(data['Center'][0])# print(getName(data['Center'][0]))data['Center']=data['Center'].apply(getName)# print(data.head())print(data.shape[0])return datadef balanceData(data,display=True):# the number of bins plotednBins = 15samplesPerBin = 500hist,bins = np.histogram(data['Steering'],nBins)#hist is the numbers of the points that lie in each range#bins is the array that stores each range# print(bins)if display:center = (bins[:-1] + bins[1:])*0.5# transform bins into center# little technique that creates the original as zero# for the bins array is symmetrical# print(center)# notice that if we want to visualize the data using bar, we need to get their centersplt.bar(center,hist,width = 0.06)# draw a line that starts from point (-1,samplesPerBin) to the point (1,samplesPerBin)plt.plot((-1,1),(samplesPerBin,samplesPerBin))plt.show()removeIndexList = []for j in range(nBins):binDataList = []for i in range(len(data['Steering'])):if data['Steering'][i] >= bins[j] and data['Steering'][i] <= bins[j+1]:binDataList.append(i)binDataList = shuffle(binDataList)binDataList = binDataList[samplesPerBin:]removeIndexList.extend(binDataList)print('Removed Images: ', len(removeIndexList))data.drop(data.index[removeIndexList],inplace = True)print('Remaining Images: ', len(data))if display:hist, _ = np.histogram(data['Steering'],nBins)plt.bar(center,hist,width = 0.06)plt.plot((-1,1),(samplesPerBin,samplesPerBin))plt.show()return datadef loadData(path,data):imagesPath = []steering = []for i in range(len(data)):indexed_data = data.iloc[i]imagesPath.append(f'{path}/IMG/{indexed_data[0]}')steering.append(indexed_data[3])imagesPath = np.asarray(imagesPath)steering = np.asarray(steering)return imagesPath,steeringdef augmentImage(imgPath,steering):img =  mpimg.imread(imgPath)if np.random.rand() < 0.5:pan = iaa.Affine(translate_percent={"x": (-0.1, 0.1), "y": (-0.1, 0.1)})img = pan.augment_image(img)if np.random.rand() < 0.5:zoom = iaa.Affine(scale=(1, 1.2))img = zoom.augment_image(img)if np.random.rand() < 0.5:brightness = iaa.Multiply((0.2, 1.2))img = brightness.augment_image(img)if np.random.rand() < 0.5:img = cv2.flip(img, 1)steering = - steeringreturn img, steeringdef preProcess(img):img = img[60:135,:,:]img = cv2.cvtColor(img,cv2.COLOR_RGB2YUV)img = cv2.GaussianBlur(img,(3,3),0)img = cv2.resize(img,(200,66))img = img/255return imgdef batchGen(imagesPath, steeringList, batchSize, trainFlag):while True:imgBatch = []steeringBatch = []for i in range(batchSize):index = random.randint(0, len(imagesPath) - 1)if trainFlag:img, steering = augmentImage(imagesPath[index], steeringList[index])else:img = mpimg.imread(imagesPath[index])steering = steeringList[index]img = preProcess(img)imgBatch.append(img)steeringBatch.append(steering)print(steering)yield np.asarray(imgBatch), np.asarray(steeringBatch)def createModel():model = Sequential()model.add(Convolution2D(24,(5,5),(2,2),input_shape=(66,200,3),activation='elu'))model.add(Convolution2D(36,(5,5),(2,2),activation='elu'))model.add(Convolution2D(48,(5,5),(2,2),activation='elu'))model.add(Convolution2D(64,(3,3),activation='elu'))model.add(Convolution2D(64,(3,3),activation='elu'))model.add(Flatten())model.add(Dense(100,activation='elu'))model.add(Dense(50,activation='elu'))model.add(Dense(10,activation='elu'))model.add(Dense(1))model.compile(Adam(lr=0.0001),loss='mse')return model# imgRe = prePrecess(mpimg.imread('test.jpg'))
# plt.imshow(imgRe)
# plt.show()

运行之后,我们可以得到神经网络训练的loss曲线和模型文件"model.h5"
在这里插入图片描述
在这里插入图片描述

5.2 测试阶段

测试阶段,我们需要编写测试文件test.py配合模拟器软件加载训练好的模型文件进行仿真测试。测试代码如下:

Test.py

print('Setting UP')
import osos.environ['TF_CPP_MIN_LOG_LEVEL'] = '3'
import socketio
import eventlet
import numpy as np
from flask import Flask
from tensorflow.keras.models import load_model
import base64
from io import BytesIO
from PIL import Image
import cv2#### FOR REAL TIME COMMUNICATION BETWEEN CLIENT AND SERVER
sio = socketio.Server()
#### FLASK IS A MICRO WEB FRAMEWORK WRITTEN IN PYTHON
app = Flask(__name__)  # '__main__'maxSpeed = 10def preProcess(img):img = img[60:135, :, :]img = cv2.cvtColor(img, cv2.COLOR_RGB2YUV)img = cv2.GaussianBlur(img, (3, 3), 0)img = cv2.resize(img, (200, 66))img = img / 255return img@sio.on('telemetry')
def telemetry(sid, data):speed = float(data['speed'])image = Image.open(BytesIO(base64.b64decode(data['image'])))image = np.asarray(image)image = preProcess(image)image = np.array([image])steering = float(model.predict(image))throttle = 1.0 - speed / maxSpeedprint(f'{steering}, {throttle}, {speed}')sendControl(steering, throttle)@sio.on('connect')
def connect(sid, environ):print('Connected')sendControl(0, 0)def sendControl(steering, throttle):sio.emit('steer', data={'steering_angle': steering.__str__(),'throttle': throttle.__str__()})if __name__ == '__main__':model = load_model('model.h5')app = socketio.Middleware(sio, app)### LISTEN TO PORT 4567eventlet.wsgi.server(eventlet.listen(('', 4567)), app)

特备要注意的是,在测试阶段,tensorflow可能会报错,这个时候,可以考虑使用以下指令重装tensorflow:

conda remove tensorflow 
conda install -c conda-forge tensorflow  

运行成功过之后,我们看到在pycharm中会出现这样的提醒:
在这里插入图片描述

这个时候,我们就可以再次打开模拟器软件,选择Autonomous Mode,从而用模型进行自动驾驶了。
在这里插入图片描述
我们可以看到,在模拟器中,汽车可以良好的运行,达到了自动驾驶的效果
在这里插入图片描述
但是,在一些边界,出现了卡出的情况,那是因为在训练的时候基本上是在大马路中间行驶的,如果我们需要处理这些边界情况,需要多进行边界环境的训练。
在这里插入图片描述
这样,我们就完成了“使用Tesenflow建立CNN模型进行自动驾驶模拟”这个入门级的AI项目,希望对大家有帮助,如果有纰漏,也请大家指出。

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

相关文章

  1. python爬虫学习路径(后面那个有点难,烦请大佬进行技术指点)

    python爬虫 基本概念:编写一段程序,我们把相关数据爬取下来的含义 怎么使用呢?我们需要网络编程的基础,request实际上也是一个爬虫,理论基础在网络编程,可以见我的demo 但是爬虫虽然方便,但是有一些网站为了安全会设置反爬虫机制。具体怎么操作,后面我们慢慢说。 1. 网…...

    2024/4/23 2:40:50
  2. SSM Web项目部署(环境配置+打成War包+Tomcat部署)

    SSM Web项目部署(环境配置+打成War包+Tomcat部署) 网路很多资料很乱很杂,本人亲自部署了一个SSM传统的web项目在阿里云服务器上,操作系统是Ubuntu16.04。打包工具使用IDEA。 1、Linux安装jdk1.8 1)使用远程文件传输过去压缩包tar.gz 2)使用 tar -zxvf <文件名>解压…...

    2024/4/9 18:54:04
  3. 一日一练——Python小白练习册第0001题

    正处于寒假中,作者偶然看到Github上新手Python练习小程序。于是决定开始刷题。在此期间记录学习过程。还望感兴趣的各位能指点其不足之处和多多交流。第 0001 题: 做为 Apple Store App 独立开发者,你要搞限时促销,为你的应用生成激活码(或者优惠券),使用 Python 如何生…...

    2024/4/24 7:24:17
  4. Ubantu无网环境下安装RabbitMQ(使用.deb包)

    文章目录一、资源地址二、安装步骤 一、资源地址 RabbitMQ官网安装教程: https://www.rabbitmq.com/install-debian.html RabbitMQ .deb 安装包github下载地址:https://github.com/rabbitmq/rabbitmq-server/releases RabbitMQ与Erlang版本匹配对照表: https://www.rabbitmq…...

    2024/4/9 18:58:56
  5. Protocol Buffers数据编码

    Protocol Buffers这是要多快好省的建设社会主义啊。理想还是要有的嘛,这里我就来介绍一个向“理想”迈进的GRPC。GRPC首先满足二进制和跨语言这两条,二进制说明压缩效率高,跨语言说明更灵活。但是又是二进制,又是跨语言,这就相当于两个人沟通,你不但说方言,还说缩略语,…...

    2024/4/18 3:58:44
  6. 读薄《C和指针》第6章 指针

    这是我读《C和指针》第6章做的笔记,过一遍指针知识点,希望能对你有所帮助。 内存 每个字节(byte)包含8个位,可以存储无符号值0至255,或有符号值-128至127。每个字节通过地址来标识。 为了存储更大的值,我们把两个或更多个字节合在一起作为一个更大的内存单位。例如四个字…...

    2024/4/9 18:58:57
  7. 二叉树的层序遍历

    leetcode 二叉树的层序遍历 给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点) 实例: 二叉树:[3,9,20,null,null,15,7]3/ \9 20/ \ 15 7返回其层次遍历结果: [[3],[9,20],[15,7] ]解法1:队列法 解题思路:二叉树的层次遍历就是…...

    2024/4/9 18:58:53
  8. windows安装python的gdal环境简略提要

    首先注意安装的不是gdal而是python的gdal从这个网址https://www.lfd.uci.edu/~gohlke/pythonlibs/#gdal中找到和你python版本对应的whl文件,举例,我用的是python3.8,64位操作系统,所以我下载下面那个:下载完成之后 打开cmd切换到该文件所在目录,执行命令: pip install GDA…...

    2024/4/21 21:09:06
  9. 深入浅出Mysql - 优化篇

    枚举类如何实现 1.JDK1.5之前需要自定义枚举类 2.JDK 1.5 新增的 enum 关键字用于定义枚举类 3.若枚举只有一个对象, 则可以作为一种单例模式的实现方式。 枚举类的属性 1.枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰 2.枚举类的使用 private final 修饰…...

    2024/4/9 18:58:53
  10. Unity Shader中常用函数及其几何意义--持续更新ing

    常用函数--打死都记不住的小知识点的兄弟篇函数汇总smoothsteppow(x,a)radio(x,a) 函数汇总 这里提供所有涉及到的函数,详解在下面。。函数名 备注dot(A,B) AB为向量,求B在A方向上的投影长度,返回float。saturate(x) if (x<=0) return 0;else if(x>=1) return 1;else …...

    2024/4/24 13:09:17
  11. SpringBoot2.0以上版本之缓存入门使用

    首先缓存机制定义:当把方法放入缓存中后,方法查询到的结果会自动放入缓存,当再次调用该函数获取值的时候会直接从缓存中获取不通过进入方法内部进行执行(可以实现值获取的高效快速性能)。实现步骤:/*** 搭建基本的开发环境* 1. 创建涉及到的数据库表* 2. 创建bean封装数据…...

    2024/4/19 8:19:59
  12. 使用C#实现OPC-UA服务端

    C#实现OPC-UA服务端前言引入Nuget包初始化节点树实时刷新数据动态添加节点客户端读取历史数据客户端写入数据启动服务端总结 前言 最近接手了一个项目,做一个 OPC-UA 服务端?刚听到这个消息我是一脸懵,发自灵魂的三问“OPC-UA是什么?”、“要怎么做?”、“有什么用?”。 …...

    2024/4/23 22:26:52
  13. 如何根据参数类型重载__init__方法?

    本文翻译自:How to overload __init__ method based on argument type? Lets say I have a class that has a member called data which is a list. 假设我有一个类,该类具有一个名为data的成员,该成员是一个列表。 I want to be able to initialize the class with, for e…...

    2024/4/19 3:17:54
  14. UVA - 10288 Coupons(期望的性质)

    题目链接假设已经收集了kkk个图案,那么拿到一个新图案的概率为n−kn\frac{n-k}{n}nn−k​,根据期望的性质,概率为p的期望会在1/p次后发生,那么答案就是∑i=1nnn−i\sum_{i=1}^{n}\frac{n}{n-i}∑i=1n​n−in​ 实际上LRJ在紫书上是手推证明了这个性质(说实话这个证明我看不…...

    2024/4/9 18:58:46
  15. 关于企业所得税率你了解多少?又如何降低税负呢?

    首先我国不论是企业还是居民个人,只要达到了纳税标准,都需要缴纳一定比率的税收,如个人薪资收入,劳务报酬,稿酬,特许权使用费等综合收入都要按照相应的税率计征个人所得税。 从事经营发展的企业更是如此,我们的企业所得税税率大致分为以下几种: 基础税率25%,小微企业5…...

    2024/4/17 15:56:35
  16. linux命令使用

    1.替换文件中的字符串,把str1替换为str2 sed -i s/"str1"/"str2"/g `grep "str1" -rl ./`...

    2024/4/9 18:58:45
  17. 学完之后我也会更新集合内容的博客

    枚举类如何实现 1.JDK1.5之前需要自定义枚举类 2.JDK 1.5 新增的 enum 关键字用于定义枚举类 3.若枚举只有一个对象, 则可以作为一种单例模式的实现方式。 枚举类的属性 1.枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰 2.枚举类的使用 private final 修饰…...

    2024/4/13 11:22:28
  18. js运算符优先级

    ...

    2024/4/20 10:10:31
  19. Django丨用户认证

    用户认证(Auth)组件Django用户认证(Auth)组件一般用在用户的登录注册上,用于判断当前的用户是否合法,并跳转到登录成功或失败页面。 Django用户认证(Auth)组件需要导入auth模块 # 认证模块 from django.contrib import auth# 对应数据库 from django.contrib.auth.mode…...

    2024/4/18 3:57:31
  20. rabbitmq启动报错Socket closed解决方案

    任务管理器里删除 erlng.exe (可能端口被占用)...

    2024/4/12 5:29:34

最新文章

  1. Linux服务器安装谷歌浏览器

    当我们使用自动化的时候&#xff0c;还想要将它部署到服务器上那么我们就需要安装谷歌或者其他浏览器&#xff0c;这里是以谷歌浏览器为例子 首先就是你的有安装包 我们到官网下载&#xff1a;https://www.google.cn/intl/zh-CN/chrome/&#xff0c;需要科学上网 进入官网之…...

    2024/4/24 14:19:08
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. C# 构建可定时关闭的异步提示弹窗

    C# 构建可定时关闭的异步提示弹窗 引言1、调用接口的实现2、自动定时窗口的实现 引言 我们在最常用最简单的提示弹框莫过于MessageBox.Show( )的方法了&#xff0c;但是使用久了之后&#xff0c;你会发现这个MessageBox并不是万能的&#xff0c;有事后并不想客户去点击&#x…...

    2024/4/23 6:37:29
  4. 解析大语言模型训练三阶段

    大语言模型的训练过程一般包括3个阶段&#xff1a;预训练&#xff08;Pre-training&#xff09;、SFT&#xff08;有监督的微调&#xff0c;Supervised-Finetuning&#xff09;以及RLHF&#xff08;基于人类反馈的强化学习&#xff0c;Reinforcement Learning from Human Feedb…...

    2024/4/23 6:25:26
  5. 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/4/24 0:58:35
  6. 【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/4/24 1:17:44
  7. 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/4/24 11:04:21
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

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

    2024/4/24 9:59:40
  9. VB.net WebBrowser网页元素抓取分析方法

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

    2024/4/24 11:04:20
  10. 【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/4/24 11:04:20
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

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

    2024/4/24 9:58:43
  12. 【ES6.0】- 扩展运算符(...)

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

    2024/4/24 11:04:19
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

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

    2024/4/24 11:04:19
  14. Go语言常用命令详解(二)

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

    2024/4/24 11:04:18
  15. 用欧拉路径判断图同构推出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/4/24 11:04:18
  16. 【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/4/24 11:04:17
  17. 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/4/24 1:18:42
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

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

    2024/4/24 1:18:59
  19. --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/4/24 11:04:13
  20. 基于深度学习的恶意软件检测

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

    2024/4/24 11:04:13
  21. JS原型对象prototype

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

    2024/4/24 11:04:13
  22. C++中只能有一个实例的单例类

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

    2024/4/24 9:54:49
  23. python django 小程序图书借阅源码

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

    2024/4/24 10:43:15
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

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

    2024/4/24 1:02:34
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

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

    2022/11/19 21:17:18
  26. 错误使用 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,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
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:16:58
  44. 如何在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