OpenCV图像的基本操作

图像的基本操作(Python)

素材图

P1:die.jpg

在这里插入图片描述

P2:cool.jpg

在这里插入图片描述

V:rabbit.mp4, 下载地址

在这里插入图片描述

读取展示-图像

import cv2img_1 = cv2.imread('./die.jpg')  # default cv2.IMREAD_COLOR
print("die.jpg shape(imread default) : ", img_1.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("die default", img_1)img_2 = cv2.imread('./die.jpg', cv2.IMREAD_GRAYSCALE)  # 指定为灰度图
print("die.jpg shape(imread gray) : ", img_2.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("die gray", img_2)
cv2.imwrite("./grayscale.jpg", img_2)  # 保存图像信息img_3 = cv2.imread('./cool.jpg')  # default cv2.IMREAD_COLOR
print("cool.jpg shape(imread default) : ", img_3.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("cool default", img_3)cv2.waitKey(0)  # 单位是毫秒
cv2.destroyAllWindows()  # 释放所有窗口

在这里插入图片描述

cv2.imshow()

原型:cv2.imshow(winname, mat)

参数:

  • winname(窗口名称): 字符串,表示显示窗口的名称。
  • mat(图像矩阵): 要显示的图像矩阵,通常是一个NumPy数组。

返回值:

功能:

cv2.imshow 主要是用于显示图像,而不是播放视频。**当你使用 cv2.imshow 显示视频帧时,它只会显示当前帧,并不会按照视频的原速度播放。**你需要在代码中通过循环读取视频的帧,并将每一帧传递给 cv2.imshow,以模拟视频的播放效果。

注意: 如果两次imshow的winname相同的话,那将自动关闭前一个窗口。

cv2.waitKey()

原型:cv2.waitKey([delay])

参数:

  • delay(延迟时间): 表示等待时间的毫秒数,如果设置为0,表示无限等待用户输入。默认值是0。

返回值:

  • 返回按键的 ASCII 值(整数)。如果没有按键被按下,返回-1。

功能:

  • 等待用户按下键盘上的按键。
  • 在指定的延迟时间内等待用户输入,然后继续执行程序。

cv2.destroyAllWindows()

原型:cv2.destroyAllWindows()

参数:

返回值:

功能:

  • 关闭所有通过 cv2.namedWindow()cv2.imshow() 创建的窗口。通常在程序执行的最后调用这个函数,以确保在程序结束时关闭所有图形界面窗口,防止它们在程序退出后仍然保留。

cv2.imread()

原型:cv2.imread(filename [,flags])

参数:

  • filename(文件名): 要读取的图像文件的路径。
  • flags(标志): 可选参数,表示如何读取图像。默认值是 cv2.IMREAD_COLOR,表示以彩色图像的形式读取。可以使用以下常量:
    • cv2.IMREAD_COLOR: 以彩色图像形式读取(默认值),注:OpenCV读取的图像是BGR格式,而非RGB
    • cv2.IMREAD_GRAYSCALE: 以灰度图像形式读取。
    • cv2.IMREAD_UNCHANGED: 读取包括 alpha 通道在内的所有图像信息。

返回值:

  • 读取的图像数据,以 NumPy 数组的形式表示。

功能:

  • 读取指定路径下的图像文件,并将其加载到一个 NumPy 数组中,以便在程序中进行处理和分析。

cv2.imwrite()

原型: cv2.imwrite(filename, img [,params])

参数:

  • filename(文件名): 要写入的目标文件的路径。
  • img(图像数据): 要写入文件的图像数据,通常是一个 NumPy 数组。
  • params(可选参数): 写入文件时的附加参数。可以指定图像质量、压缩格式等。

返回值:

  • 如果成功写入文件,则返回 True;否则返回 False

功能:

  • 将图像数据写入指定的文件。

读取展示-视频

import cv2# 打开视频文件
cap = cv2.VideoCapture('./rabbit.mp4')# 检查视频是否成功打开
if not cap.isOpened():print("Error: 无法打开视频文件.")opn = 0
else:opn = 1while opn:# 读取视频帧ret, frame = cap.read()# 检查是否成功读取帧(视频播放完成退出)if not ret:print("Error: 无法读取帧.")break# 转换为灰度帧gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 在窗口中显示帧cv2.imshow('Video Player', gray)# 检查用户是否按下了 'q' 键,如果是则退出循环if cv2.waitKey(25) & 0xFF == 27:break# 释放资源
cap.release()
cv2.destroyAllWindows()

在这里插入图片描述

cv2.VideoCapture()

原型:cv2.VideoCapture([filename or index, apiPreference])

参数:

  • filename(可选): 视频文件的路径。
  • index(可选): 摄像头设备的索引号,用于选择要使用的摄像头。通常从0开始递增。
  • apiPreference(可选): 指定视频捕获 API 的首选项。可以是 cv2.CAP_ANYcv2.CAP_V4L2cv2.CAP_FFMPEG 等。

功能:

  • 打开一个视频文件、摄像头或其他图像来源,准备读取帧。
  • 提供方法用于从视频源中读取帧,获取视频的参数等信息。

返回值:

  • VideoCapture 对象:一个用于从视频源读取帧的对象。下面介绍该对象常用属性:

    1. read()

      • 读取视频的下一帧。
      • 返回一个布尔值 ret,表示帧是否成功读取,以及帧的图像数据frame(视频帧的 NumPy 数组)。
      ret, frame = cap.read()
      
    2. get(propId)

      • 获取视频的属性值,例如帧的宽度、高度、帧速率等。
      • propId 是用于指定要获取的属性的标识符。
      width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
      height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
      
    3. set(propId, value)

      • 设置视频的属性值,例如帧的宽度、高度、帧速率等。
      • propId 是用于指定要设置的属性的标识符,value 是要设置的属性值。
      cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640)
      cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
      
    4. release()

      • 释放 VideoCapture 对象占用的资源,关闭视频源。
      cap.release()
      
    5. isOpened()

      • 检查 VideoCapture 对象是否成功打开了视频源。
      if not cap.isOpened():print("Error: Could not open video source.")
      

cv2.cvtColor()

原型:cv2.cvtColor(src, code)

参数:

  • src(源图像): 要进行颜色空间转换的输入图像,通常是一个 NumPy 数组。
  • code(颜色空间转换代码): 指定颜色空间转换的方式,如 cv2.COLOR_BGR2GRAY 表示将 BGR 彩色图转换为灰度图。
  • 还有两个可选参数,用于设置输出图像的尺寸、深度、通道数,这里不进行介绍。

返回值:

  • 转换后的图像,仍是一个 NumPy 数组。

功能:

  • 将输入图像从一个颜色空间转换到另一个颜色空间。

其他:(关于code的其他可选项)

  1. BGR 转灰度:cv2.COLOR_BGR2GRAY
  2. BGR 转HSV:cv2.COLOR_BGR2HSV
  3. BGR 转RGB:cv2.COLOR_BGR2RGB
  4. 灰度转BGR:cv2.COLOR_GRAY2BGR
  5. RGB 转BGR:cv2.COLOR_RGB2BGR

ROI(感兴趣的范围——裁剪)

图像数据的表示方式:

用 “:” 表示区间(左闭右开)

import cv2
img = cv2.imread('./die.jpg')
print(img.shape)  #(40, 240, 3)# 取三维矩阵的前一行、前两列、深度为all
print(img[0:1, 0:2], "\n")
# [[[40 39 83]     [[[BGR][BGR]  ]  ]
#   [39 38 82]]]   三维 —— 图像(r * w) * BGR(h = 3)# 取三维矩阵的前一行、前两列、深度为0
print(img[0:1, 0:2, 0], "\n")
# [[40 39]]      二维 (r * w)  仅显示BGR其中之一(B)print(img[0:1, 0:2, 1], "\n")
# [[39 38]]        仅显示(G)print(img[0:1, 0:2, 2], "\n")
# [[83 82]]        仅显示(R)

查看图像指定区域(imshow时可实现裁剪效果):

import cv2
img = cv2.imread('./die.jpg')
print(img.shape)cv2.imshow("image", img)
cv2.imshow("cut", img[50:150, 0:200])cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

提取/合并 图像的R、G、B

import cv2img = cv2.imread('./die.jpg')# 提取   如果直接show相当于灰度图像,把颜色值当作亮度
img_B = img[:, :, 0]
img_G = img[:, :, 1]
img_R = img[:, :, 2]
# 合并   合并时要注意维度保持一致
img_T = cv2.merge((img_B, img_G, img_R))

在这里插入图片描述

置空通道 (e.g只保留R通道)

import cv2img = cv2.imread('./die.jpg')img_T = img.copy()img_T[:, :, 0] = 0  # 置空 B 通道
img_T[:, :, 1] = 1  # 置空 G 通道cv2.imshow("img_T", img_T)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

cv2.merge()

原型:cv2.merge(mv[, dst])

参数:

  • mv:包含要合并的图像通道的序列(例如,一个包含三个通道的元组或列表)。
  • dst:输出图像,可选。

返回值:

如果指定了 dst 参数,则返回输出图像 dst;否则,返回合并后的图像。

功能:

cv2.merge 函数用于将多个单通道的图像合并成一个多通道的图像。通常,在图像处理中,图像被拆分为单个通道进行处理,然后再合并回来。mv 参数是一个包含要合并的图像通道的序列,通常是一个包含多个单通道图像的元组或列表。在合并时要注意每个通道的尺寸和数据类型保持一致,并注意通道的顺序。

关于dst参数

手动指定 dst 和使用返回值接收的主要区别在于对输出图像的处理和内存管理

手动指定 dst

  • 如果你手动指定了 dst,则你需要提前创建一个多通道的数组,用于存储合并后的结果。这样可以避免在函数内部创建新的数组,有助于更好地控制内存的分配和释放。
  • 通过手动指定 dst,你可以在函数调用之后继续使用这个数组,而不需要将它的内容复制到其他数组中。

使用返回值接收:

  • 如果你使用返回值接收合并后的结果,那么函数会在内部创建一个新的多通道数组,并将合并后的图像存储在其中。这个新数组将作为函数的返回值返回。
  • 使用返回值接收合并后的图像时,你不需要提前创建输出数组,但需要注意新数组的内存管理。你可能需要确保及时释放不再需要的内存,以避免内存泄漏。

在实际应用中,选择手动指定 dst 还是使用返回值接收通常取决于对内存和代码结构的特定需求。如果你有特定的内存管理需求或者想要更好地控制输出数组的生命周期,那么手动指定 dst 可能更为合适。否则,使用返回值接收通常更为简便。

缩放&融合

import cv2img1 = cv2.imread('./die.jpg')
img2 = cv2.imread('./cool.jpg')# 两张图片尺寸不一致不能进行计算(融合)
print(img1.shape)  # (240, 240, 3)
print(img2.shape)  # (1000, 1000, 3)img2_T = cv2.resize(img2, (240, 240))res = cv2.addWeighted(img1, 0.4, img2_T, 0.6, 0)cv2.imshow("blend", res)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

按缩放因子进行scale

import cv2img = cv2.imread('./die.jpg')
print(img.shape)  # (240, 240, 3)# 将y坐标拉伸2倍数,x不变
img_T = cv2.resize(img, (0, 0), fx=1, fy=2)
print(img.shape)  # (240, 240, 3)cv2.imshow("img", img)
cv2.imshow("scale", img_T)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

cv2.resize()

原型:cv2.resize(src, dsize[, dst[, fx[, fy[, interpolation]]]])

参数:

  • src: 输入图像。

  • dsize: 输出图像的大小,可以是元组 (width, height) 或者 None

  • dst: 输出图像,可选。

  • fx: 沿水平轴的缩放因子,可选。

  • fy: 沿垂直轴的缩放因子,可选。

  • interpolation: 插值方法,用于图像的缩放。默认为 cv2.INTER_LINEAR

    常见的插值方法包括:

    • cv2.INTER_NEAREST: 最近邻插值
    • cv2.INTER_LINEAR: 线性插值(默认)
    • cv2.INTER_CUBIC: 三次样条插值
    • cv2.INTER_AREA: 区域插值

返回值:

  • 返回缩放后的图像。

功能:

  • 该函数用于调整图像大小,可以进行放大或缩小。可以通过指定输出图像的大小 (dsize) 或者缩放因子 (fx, fy) 来控制缩放的程度

cv2.addWeighted()

函数原型:cv2.addWeighted(src1, alpha, src2, beta, gamma[, dst[, dtype]])

参数:

  • src1:第一个输入图像。
  • alphasrc1 的权重。
  • src2:第二个输入图像。
  • betasrc2 的权重。
  • gamma:添加到每个和的标量值,用于调整输出图像的亮度。
  • dst:输出图像,可选。
  • dtype:输出图像的数据类型,可选。

返回值:

  • 如果指定了 dst 参数,则返回输出图像 dst;否则,返回合并后的新图像。

功能:

  • cv2.addWeighted 函数用于将两个图像线性组合,即按照一定的权重相加。具体而言,它的计算公式为:

d s t = s r c 1 × a l p h a + s r c 2 × b e t a + g a m m a dst=src1×alpha+src2×beta+gamma dst=src1×alpha+src2×beta+gamma

  • 这个函数在图像混合、图像融合、对比度调整等方面非常有用。例如,可以使用 cv2.addWeighted 将两个图像按照一定的比例融合,调整图像的对比度和亮度。

数值计算

cv2.add()

img1 = img1 + 5   # 每个像素值都增加了5
imgT = img2 + img1  # img1 的每个像素值都与相应位置上的 img2 的像素值相加# 因为每个值都是uint8,所以可能会出现越界溢出的情况(%256)
# cv2.add()  可以实现饱和截断(溢出时会保持在255)
cv2.add(img1,img2)

matplotlib.pyplot绘制子图

import cv2
import matplotlib.pyplot as plt
import numpy as np                # 暂时没用到# 读取图像
img1 = cv2.imread('./die.jpg')
img2 = cv2.imread('./grayscale.jpg')
img3 = cv2.imread('./cool.jpg')# 使用Matplotlib显示不同边界填充方式的图像(221: 2*2的网格的第1个位置)
plt.subplot(221), plt.imshow(img1), plt.title('die')
plt.subplot(222), plt.imshow(img2), plt.title('grayscale')
plt.subplot(223), plt.imshow(img3), plt.title('cool')plt.show()
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

边界填充

import cv2
import matplotlib.pyplot as plt
import numpy as np                # 暂时没用到# 读取图像
img = cv2.imread('./die.jpg')# 定义上、下、左、右填充的大小
top_size, bottom_size, left_size, right_size = (70, 70, 70, 70)# 使用不同的边界填充方式生成新的图像
replicate = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, borderType=cv2.BORDER_REPLICATE)
reflect = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_REFLECT)
reflect101 = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_REFLECT_101)
wrap = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_WRAP)
constant = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_CONSTANT, value=0)# 使用Matplotlib显示不同边界填充方式的图像(231: 2*3的网格的第1个位置)
plt.subplot(231), plt.imshow(img), plt.title('ORIGINAL')
plt.subplot(232), plt.imshow(replicate), plt.title('REPLICATE')
plt.subplot(233), plt.imshow(reflect), plt.title('REFLECT')
plt.subplot(234), plt.imshow(reflect101), plt.title('REFLECT_101')
plt.subplot(235), plt.imshow(wrap), plt.title('WRAP')
plt.subplot(236), plt.imshow(constant), plt.title('CONSTANT')# 显示图像
plt.show()# 关闭所有OpenCV窗口
cv2.destroyAllWindows()

在这里插入图片描述

cv2.copyMakeBorder()

函数原型:cv2.copyMakeBorder(src, top, bottom, left, right, borderType[, dst[, value]])

参数:

  • src:输入图像。
  • topbottomleftright:指定在每个边界添加的像素数。
  • borderType
    • BORDER_REPLICATE:复制法,也就是复制最边缘像素。
    • BORDER_REFLECT:反射法,对感兴趣的图像中的像素在两边进行复制例如:fedcba|abcdefgh|hgfedcb
    • BORDER_REFLECT_101:反射法,也就是以最边缘像素为轴,对称,gfedcb|abcdefgh|gfedcba
    • BORDER_WRAP:外包装法cdefgh|abcdefgh|abcdefg
    • BORDER_CONSTANT:常量法,常数值填充。
  • dst:输出图像,可选。
  • value:当 borderTypecv2.BORDER_CONSTANT 时使用的边界常数。

返回值:

  • 如果指定了 dst 参数,则返回输出图像 dst;否则,返回添加边界后的新图像。

功能:

  • cv2.copyMakeBorder 函数用于在图像的四个边界上添加边界。你可以指定要添加的像素数以及边界的类型。不同的 borderType 选项会导致不同的边界填充方式。

  • 这个函数在图像处理中常用于图像扩展、填充以及处理边界条件的情况,例如在进行卷积运算时。

      

Numpy

.shape

shapeNumPy 数组的一个属性。在 NumPy 中,shape 用于获取数组的维度信息。

示例:array.shape

返回值:

  • 一个元组(tuple),表示数组的维度。

功能:

  • 提供数组的维度信息,以元组的形式返回。
  • 对于二维数组,返回的元组包含两个元素,表示行数和列数;对于三维数组,包含三个元素,以此类推。

.copy()

  在NumPy中,copy() 方法用于创建数组的副本(复制)。这个方法返回一个新的数组对象,该对象是原始数组的完整副本,包括数据和属性。这意味着对新数组的任何更改都不会影响原始数组,反之亦然。

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

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

相关文章

2024年生物技术与医学科学国际学术研讨会(ISBAMS 2024)

2024年生物技术与医学科学国际学术研讨会(ISBAMS 2024) 重要信息 会议官网:http://www.isbams.com会议地址:上海召开日期:2024/2/20截稿日期:2024/2/10 (先投稿,先审核,先…

jmeter接口自动化测试工具在企业开展实际的操作

在企业使用jmeter开展实际的接口自动化测试工具,建议按如下操作流程, 可以使整个接口测试过程更规范,更有效。 接口自动化的流程: 1、获取到接口文档:swagger、word、excel ... 2、熟悉接口文档然后设计测试用例&am…

【python】爬取豆瓣影评保存到Excel文件中【附源码】

欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 【往期相关文章】 爬取豆瓣电影排行榜Top250存储到Excel文件中 爬取豆瓣电影排行榜TOP250存储到CSV文件中 爬取知乎热榜Top50保存到Excel文件中 爬取百度热搜排行榜Top50可视化 爬取斗鱼直播照片保存到本地目录 爬…

仓储管理系统——软件工程报告(详细设计)④

详细设计 一、系统功能模块的划分 根据系统的功能性需求,本文将部队仓库管理系统分为以下六大模块:系统管理模 块、基础数据模块、出入库管理模块、库存管理模块、仓库信息管理模块、作业管理模 块,每个模块内部又分为很多小功能模块&#…

win10+elasticsearch8.12 安装教程

Elasticsearch是一种搜索引擎,本地安装完成之后,可使用其他编程语言(例如python)与elasticsearch建立连接,然后使用python脚本搜索elasticsearch中的数据 1下载 elasticsearch elasticsearch最新版官网下载链接 点击…

颠覆式创新:LAXCUS分布式操作系统7.0

在这轮AI浪潮中,英伟达已经获得了硬件算力入口,Laxcus要获取软件算力入口。 有几位网友想了解我们正在研发的Laxcus分布式操作系统7.0的情况。应他们要求,今天就说说Laxcus 7.0版本。Laxcus 7.0是一个全新的操作系统,具有很多独特…

C++技术要点总结, 面试必备, 收藏起来慢慢看

目录 1. 语言对比 1.1 C 11 新特性 2.2 C 和 C 的区别 2.3 Python 和 C 的区别 2. 编译内存相关 2.1. C 程序编译过程 2.2. C 内存管理 2.3. 栈和堆的区别 2.4. 变量的区别 2.5. 全局变量定义在头文件中有什么问题? 2.6. 内存对齐 2.7. 什么是内存泄露 …

ISO27001认证:企业与个人发展的必备之选

ISO27001认证,对于企业和个人来说,都具有极高的价值和重要性。作为国际权威的信息安全管理体系标准,它为企业提供了保障信息安全、防范风险和提升竞争力的有力工具。 💼对企业的价值: ISO27001认证可以帮助企业满足国家…

【通过docker安装常用软件镜像】1.镜像 2.安装 redis,jdk,nginx

1)官网镜像网站 hello-world - Official Image | Docker Hub 2)安装镜像测试例子 Redis 1.查询redis [rootlocalhost ~]# docker search redis NAME DESCRIPTION STARS OFFICIAL redis …

rancher和k8s接口地址,Kubernetes监控体系,cAdvisor和kube-state-metrics 与 metrics-server

为了能够提前发现kubernetes集群的问题以及方便快捷的查询容器的各类参数,比如,某个pod的内存使用异常高企 等等这样的异常状态(虽然kubernetes有自动重启或者驱逐等等保护措施,但万一没有配置或者失效了呢)&#xff0…

matlab对负数开立方根得到虚数的解决方案

问题描述:在matlab中,对负数开立方根,不出意外你将得到虚数。 例如 − 27 3 \sqrt[3]{-27} 3−27 ​,我们知道其实数解是-3,但在matlab中的计算结果如下: 问题原因:matlab中的立方根运算是在…

【iOS ARKit】人脸检测追踪基础

在计算机人工智能(Artificial Inteligence,AI)物体检测识别领域,最先研究的是人脸检测识别,目前技术发展最成熟的也是人脸检测识别。人脸检测识别已经广泛应用于安防、机场、车站、闸机、人流控制、安全支付等众多社会领域&#x…

提高供电可靠性:配网故障定位装置的实际应用与效果

随着电力系统的不断发展,提高供电可靠性成为了业界关注的焦点。在这个过程中,恒峰智慧科技研发的配网故障定位装置发挥着越来越重要的作用。本文将详细介绍一种基于行波测距技术的配网故障定位装置HFP-GZS1000,以及其在实际应用中的效果。 一…

3d gaussian splatting介绍整理

3D 高斯分布是用于实时辐射场渲染的 3D 高斯分布中描述的一种光栅化技术,它允许实时渲染从小图像样本中学习到的逼真场景。 paper github 本文翻译整理自: blog: Introduction to 3D Gaussian Splatting DDPMs - Part 2 给出一些2D图片,用…

PyTorch 添加 C++ 拓展

参考内容:pytorch添加C拓展简单实战编写及基本功能测试 文章目录 第一步:编写 C 模块test.htest.cpp 第二步:编写 setup.py第三步:安装 C 模块第四步:验证安装第五步:C 模块使用test_cpp1.pytest_cpp2.py 运…

信息安全认证首选CISP-PTE

🔥在信息安全领域,CISP-PTE认证正逐渐成为行业的新星。作为中国信息安全测评中心推出的专业认证,CISP-PTE为信息安全从业者提供了国内Z高标准的资质培训。 🎯为什么选择CISP-PTE? 1️⃣业界认可:CISP-PTE是…

oracle10g rac节点启动没进程没日志

一节点正常运行,二节点通过crsctl start crs启动,发现alert日志及所有日志都没生成,oracle用户下连一个相关进程都没有清理缓存:rm -rf /tmp/.oracle/服务挨个启动也无效:/etc/init.evmd run >/dev/null 2>&…

如何训练和导出模型

介绍如何通过DI-engine使用DQN算法训练强化学习模型 一、什么是DQN算法 DQN算法,全称为Deep Q-Network算法,是一种结合了Q学习(一种价值基础的强化学习算法)和深度学习的算法。该算法是由DeepMind团队在2013年提出的,…

2024亚马逊开店教程:开店准备与注册流程指南

随着新一年的到来,亚马逊开启了新一轮的卖家入驻,并且针对新卖家优化了入驻流程,下面为大家简单整理一下最新亚马逊入驻教程,有想要入驻开店的小伙伴速速看过来! 一、开店前准备 1、账号环境准备 为了防止账号由于网…

将 Amazon Bedrock 与 Elasticsearch 和 Langchain 结合使用

Amazon Bedrock 是一项完全托管的服务,通过单一 API 提供来自 AI21 Labs、Anthropic、Cohere、Meta、Stability AI 和 Amazon 等领先 AI 公司的高性能基础模型 (FMs) 选择,以及广泛的 构建生成式 AI 应用程序所需的功能,简化开发,…