当前位置: 首页 > article >正文

计算机视觉-OpenCV图像处理

1.Matplotlib数据可视化(绘制图像直方图、可视化矩阵)

# Matplotlib 数据可视化(绘制图像直方图、可视化矩阵)
# 本节主要讲解如何使用 Matplotlib 绘制图像直方图和可视化矩阵。
# 1. 绘制图像直方图
# 2. 可视化矩阵# 1. 绘制图像直方图
import cv2
import matplotlib.pyplot as plt
import numpy as np# 读取图像并转换为灰度图,读取后的 image 是一个二维数组,每个元素代表一个像素的灰度值。
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)  #将图像转换为灰度图(像素值范围 0 到 255)# 绘制图像和直方图
plt.figure(figsize=(12, 6))plt.subplot(1, 2, 1) #创建一个1行2列的子图,当前激活第1个子图
plt.imshow(image, cmap='gray')  #将图像以矩阵形式可视化。cmap='gray' 指定使用灰度颜色。
plt.title('Grayscale Image')
plt.axis('off') #关闭坐标轴plt.subplot(1, 2, 2) #创建一个1行2列的子图,当前激活第2个子图
# plt.hist 函数要求输入是一维数组,所以需要使用 ravel() 方法将二维或三维的图像数组转换为一维数组
plt.hist(image.ravel(), bins=256, range=[0, 256], color='r', alpha=0.5)  #绘制直方图
plt.title('Histogram')  #设置标题
plt.xlabel('Pixel Value')  #设置x轴标签
plt.ylabel('Frequency')  #设置y轴标签plt.tight_layout()  #自动调整子图参数,使之填充整个图像区域
plt.show()  #显示图像和直方图

# 2. 可视化矩阵
import numpy as np
import matplotlib.pyplot as plt# 创建一个包含3x3个元素的随机矩阵
arr = np.random.rand(3, 3)# 可视化矩阵
# imshow 是 matplotlib.pyplot 中的一个函数,用于将数组(矩阵)以图像的形式显示出来。
# 在这个例子中,它将 arr 矩阵中的每个元素映射为图像中的一个像素,像素的颜色由元素的值决定。
# cmap='viridis':cmap 参数指定了颜色映射(colormap),即如何将数组中的数值映射为不同的颜色。
# 'viridis' 是 matplotlib 提供的一种颜色映射方案,它是一种连续的、感知均匀的颜色映射,从蓝色到黄色渐变,常用于可视化连续的数值数据。
plt.imshow(arr, cmap='viridis')  #将矩阵以矩阵形式可视化。cmap='viridis' 指定使用 viridis 颜色。
# 在图像旁边添加一个颜色条。颜色条用于显示颜色与数值之间的对应关系,通过颜色条可以直观地了解图像中不同颜色所代表的数值大小。
plt.colorbar()  #添加颜色条
plt.title('Matrix Visualization')  #设置标题
plt.show()  #显示图像


2.OpenCV图像处理

  • 滤波操作(去除噪声)
  • 边缘检测(提取图像中的边缘)
  • 特征点检测(检测图像中的关键点)

练习任务:写一个简单的OpenCV脚本,提取两个图像的ORB特征并进行匹配。

滤波操作

滤波用于平滑图像、去除噪声。常见的滤波器有 均值滤波、高斯滤波和中值滤波

# OpenCV 提供了丰富的图像处理功能,我们将重点介绍以下操作
# 滤波操作(去除噪声)
# 边缘检测(提取图像中的边缘)
# 特征点检测(检测图像中的关键点)# 滤波用于平滑图像、去除噪声。常见的滤波器有 均值滤波、高斯滤波和中值滤波。
# 均值滤波:将图像中的每个像素替换为其周围像素的平均值。
# 高斯滤波:将图像中的每个像素替换为其周围像素的加权平均值。
# 中值滤波:将图像中的每个像素替换为其周围像素的中值。import cv2
import matplotlib.pyplot as plt
import numpy as np# 读取图像
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)# 均值滤波
# cv2.blur() 函数用于对图像进行均值滤波。第一个参数是输入图像,第二个参数是滤波核的大小。
# 滤波核的大小决定了滤波的效果,核的大小越大,滤波效果越明显。
# 例如,当核的大小为 (3, 3) 时,表示 3x3 的滤波核,对图像进行均值滤波。
blur_image = cv2.blur(image, (3, 3))# 高斯滤波
# cv2.GaussianBlur() 函数用于对图像进行高斯滤波。第一个参数是输入图像,第二个参数是高斯核的大小,第三个参数是高斯核的标准差。
# 高斯核的大小和标准差决定了滤波的效果,高斯核的大小越大,滤波效果越明显。
# 例如,当高斯核的大小为 (3, 3),标准差为 0 时,表示 3x3 的高斯核,对图像进行高斯滤波。
gaussian_image = cv2.GaussianBlur(image, (3, 3), 0)# 中值滤波
# cv2.medianBlur() 函数用于对图像进行中值滤波。第一个参数是输入图像,第二个参数是滤波核的大小。
# 中值滤波适用于去除椒盐噪声,即图像中的黑白点噪声。
# 例如,当核的大小为 3 时,表示 3x3 的滤波核,对图像进行中值滤波。
median_image = cv2.medianBlur(image, 3)# 显示图像和滤波结果
plt.figure(figsize=(12, 6))
plt.subplot(1, 3, 1), plt.imshow(blur_image, cmap='gray'), plt.title('Mean Blur')
plt.subplot(1, 3, 2), plt.imshow(gaussian_image, cmap='gray'), plt.title('Gaussian Blur')
plt.subplot(1, 3, 3), plt.imshow(median_image, cmap='gray'), plt.title('Median Blur')
plt.show()

边缘检测

边缘检测用于提取图像中的轮廓,Canny 边缘检测是最常用的方法。

# 边缘检测用于检测图像中的边缘。常见的边缘检测算法有 Sobel算子、Scharr算子、Laplacian算子和Canny算子。
# Canny算子:通过多步操作检测图像中的边缘。# 读取图像
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)# Canny 边缘检测
# cv2.Canny() 函数用于对图像进行 Canny 边缘检测。第一个参数是输入图像,第二个参数是阈值1,第三个参数是阈值2。
# 阈值1 和阈值2 用于控制边缘检测的灵敏度,边缘检测结果取决于这两个阈值的选择。
edges = cv2.Canny(image, 100, 200)# 显示原图和边缘检测结果
plt.figure(figsize=(12, 6))
plt.subplot(1, 2, 1)# plt.subplot() 函数用于在当前图形窗口中创建一个子图布局。它接受三个整数参数,分别表示子图布局的行数、列数和当前子图的编号。
# (1, 2, 1) 表示将图形窗口划分为 1 行 2 列的子图布局,当前要操作的是第 1 个子图(从左到右、从上到下编号)。
plt.imshow(image, cmap='gray')
# plt.imshow() 用于显示图像。image 是要显示的图像数组,通常是一个 numpy 数组。
# cmap='gray' 指定使用灰度颜色映射来显示图像,适用于单通道的灰度图像。
plt.title('Original Image')
# 为当前子图设置标题,标题内容为 'Original Image',表明该子图显示的是原始图像。
plt.axis('off')
# 隐藏当前子图的坐标轴,使图像显示更加简洁。plt.subplot(1, 2, 2), plt.imshow(edges, cmap='gray'), plt.title('Canny Edges')
plt.axis('off')
plt.show()

特征点检测

SIFT

https://medium.com/@deepanshut041/introduction-to-sift-scale-invariant-feature-transform-65d7f3a72d40

# SIFT特征点检测# 读取图像
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)# 初始化 SIFT 特征检测器
sift = cv2.SIFT_create()# 检测图像中的关键点和描述符
# sift.detectAndCompute() 是 SIFT 检测器对象的一个方法,用于同时检测图像中的关键点并计算这些关键点的描述子。# 该方法接受两个参数:
# 第一个参数是输入的图像(这里是之前读取的灰度图像 image),
# 第二个参数是一个掩码图像,用于指定在哪些区域进行关键点检测,None 表示对整个图像进行检测。# 该方法返回两个值:
# keypoints 是一个包含检测到的关键点信息的列表,每个关键点是一个 cv2.KeyPoint 对象,包含关键点的位置、尺度、方向等信息;
# descriptors 是一个 numpy 数组,包含每个关键点对应的描述子,描述子是一个用于表示关键点特征的向量,通常用于后续的特征匹配。
keypoints, descriptors = sift.detectAndCompute(image, None)# 绘制关键点
# cv2.drawKeypoints() 是 OpenCV 中用于在图像上绘制关键点的函数。
# 它接受四个参数:
# 第一个参数是输入的图像(这里是原始的灰度图像 image),
# 第二个参数是关键点列表(keypoints),
# 第三个参数是输出图像,如果为 None 则表示在输入图像上直接绘制关键点;
# 第四个参数 color 用于指定绘制关键点的颜色,这里 (0, 255, 0) 表示绿色。
# 该函数返回一个绘制了关键点的图像 sift_image。
image_with_keypoints = cv2.drawKeypoints(image, keypoints, None, color=(0, 255, 0))# 显示原图和绘制了关键点的图像
plt.figure(figsize=(12, 6))
plt.subplot(1, 2, 1), plt.imshow(image, cmap='gray'), plt.title('Original Image'), plt.axis('off')
plt.subplot(1, 2, 2), plt.imshow(image_with_keypoints), plt.title('Image with Keypoints'), plt.axis('off')
plt.show()

ORB

# ORB特征检测
import cv2
import matplotlib.pyplot as plt# 读取图像并转换为灰度图
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)# 初始化 ORB 检测器
orb = cv2.ORB_create()# 检测关键点和计算描述子
keypoints, descriptors = orb.detectAndCompute(image, None)# 在图像上绘制关键点
orb_image = cv2.drawKeypoints(image, keypoints, None, color=(0, 255, 0))# 显示结果
plt.figure(figsize=(12, 6))
plt.subplot(1, 2, 1), plt.imshow(image, cmap='gray'), plt.title('Original Image'), plt.axis('off')
plt.subplot(1, 2, 2), plt.imshow(orb_image), plt.title('Image with ORB Keypoints'), plt.axis('off')
plt.show()

Harris 角点检测

# Harris 角点检测
# Harris 角点检测是一种用于检测图像中角点的方法,角点是图像中两条边缘交汇的点。import cv2
import numpy as np
import matplotlib.pyplot as plt# 读取图像
image = cv2.imread('cat.jpg', cv2.IMREAD_GRAYSCALE)# np.float32():将图像数据类型转换为 32 位浮点型。因为 cv2.cornerHarris() 函数要求输入的图像数据类型为浮点型,所以需要进行类型转换。
gray = np.float32(image)# OpenCV 提供了 cv2.cornerHarris() 函数用于进行 Harris 角点检测。
# gray:输入的灰度图像(已转换为浮点型)。
# 2:角点检测中使用的邻域大小,即每个像素周围考虑的邻域范围。这里表示使用 2x2 的邻域。
# 3:Sobel 算子的孔径大小,用于计算图像的梯度。
# 0.04:Harris 角点检测的自由参数,用于控制角点响应函数的计算,通常取值在 0.04 到 0.06 之间。
# 该函数返回一个与输入图像大小相同的数组 dst,数组中的每个元素表示对应像素的角点响应值。
dst = cv2.cornerHarris(gray, 2, 3, 0.04)
# 对 dst 数组进行膨胀操作。膨胀操作可以扩大角点响应值的区域,使角点更加明显,方便后续的角点筛选。
dst = cv2.dilate(dst, None)# dst > 0.01 * dst.max():这是一个布尔数组,用于筛选出角点响应值大于 0.01 * dst.max() 的像素位置。
# dst.max() 表示 dst 数组中的最大值,0.01 * dst.max() 是一个阈值,只有角点响应值大于该阈值的像素才被认为是角点。
image[dst > 0.01 * dst.max()] = 255# 显示结果原图像和 Harris 角点检测结果
plt.figure(figsize=(12, 6))
plt.subplot(1, 2, 1), plt.imshow(image, cmap='gray'), plt.title('Original Image'), plt.axis('off')
plt.subplot(1, 2, 2), plt.imshow(dst, cmap='gray'), plt.title('Harris Corners'), plt.axis('off')
plt.show()


写一个简单的OpenCV脚本,提取两个图像的ORB特征并进行匹配

# 写一个简单的OpenCV脚本,提取两个图像的ORB特征并进行匹配。import cv2
import numpy as np
import matplotlib.pyplot as plt# 读取图像
img1 = cv2.imread('ORB1.jpg',cv2.IMREAD_GRAYSCALE)
img2 = cv2.imread('ORB2.jpg',cv2.IMREAD_GRAYSCALE)# 创建ORB特征检测器,nfeatures=500 设定ORB检测的最大特征点数为500,数值越大,提取的特征点越多。
orb = cv2.ORB_create(nfeatures=500)# 检测特征点并计算描述符
# detectAndCompute() 方法同时检测特征点 (keypoints) 和计算它们的描述符 (descriptors)。
# kp1, des1 是 img1 的特征点和描述符,kp2, des2 是 img2 的特征点和描述符。
# keypoints 包含特征点的位置、大小、方向等信息,descriptors 是描述这些特征点的向量。
kp1, des1 = orb.detectAndCompute(img1, None)
kp2, des2 = orb.detectAndCompute(img2, None)# 创建BF匹配器
# cv2.BFMatcher 创建一个暴力匹配器 (BFMatcher)。
# cv2.NORM_HAMMING 表示使用 汉明距离(适用于二进制特征描述符,如 ORB、BRIEF)。
# crossCheck=True 使匹配更加严格:只有当 A 的最佳匹配是 B,同时 B 的最佳匹配也是 A 时,它们才会被视为匹配。
bf = cv2.BFMatcher(cv2.NORM_HAMMING, crossCheck=True)# 匹配描述符,bf.match(des1, des2) 在两幅图像的特征描述符之间进行匹配,返回 matches(匹配点对列表)。
matches = bf.match(des1, des2)# 按距离排序
# sorted() 函数对所有匹配点对按照它们之间的距离进行排序。
# key=lambda x: x.distance 表示按照匹配点对的距离进行排序。
matches = sorted(matches, key=lambda x: x.distance)# 绘制匹配结果
# drawMatches() 方法绘制匹配结果。
# matches[:60] 表示只绘制前60个匹配点对。
# matchColor=(0, 255, 0) 表示匹配点对的颜色为绿色。
# singlePointColor=(0, 0, 255) 表示特征点的颜色为红色。
img3 = cv2.drawMatches(img1, kp1, img2, kp2, matches[:60], None, matchColor=(0, 255, 0),singlePointColor=(0, 0, 255))# 显示结果
plt.figure(figsize=(16, 8))
plt.axis('off')
plt.imshow(img3)
plt.show()

相关文章:

计算机视觉-OpenCV图像处理

1.Matplotlib数据可视化(绘制图像直方图、可视化矩阵) # Matplotlib 数据可视化(绘制图像直方图、可视化矩阵) # 本节主要讲解如何使用 Matplotlib 绘制图像直方图和可视化矩阵。 # 1. 绘制图像直方图 # 2. 可视化矩阵# 1. 绘制图…...

【论文笔记】Transformer^2: 自适应大型语言模型

Code repo: https://github.com/SakanaAI/self-adaptive-llms 摘要 自适应大型语言模型(LLMs)旨在解决传统微调方法的挑战,这些方法通常计算密集且难以处理多样化的任务。本文介绍了Transformer(Transformer-Squared)…...

【医学影像AI】50个眼科影像数据集(1)分类任务

【医学影像】50个眼科影像数据集(1)分类任务 【医学影像】50个眼科影像数据集(2)分割任务 【医学影像】50个眼科影像数据集(3)其它任务 【医学影像AI】50 个眼科影像数据集(1)分类任…...

2025年-G4--lc75--Best Time to Buy and Sell Stock(java版)

1.题目描述 2.思路 思路1: 3.java代码实现 class Solution {public int maxProfit(int[] prices) {// //初始化最小价格为最大值,最大利润为0// int minPriceInteger.MAX_VALUE;// int maxProfit0;// //遍历价格数组// for (int price : prices)// …...

STM32 PWM脉冲宽度调制介绍

目录 背景 PWM 模式 影子寄存器和预装载寄存器 PWM对齐模式 PWM 边沿对齐模式 向上计数配置 向下计数的配置 PWM 中央对齐模式 程序 第一步、使能GPIOB组、AFIO、TIM3外设时钟 第二步、输出通道端口配置​编辑 第三步、定时器配置产生频率 第四步、PWM输出配置 第…...

WebGPU顶点插槽(Vertex Buffer Slot)使用指南

本文将通过完整代码示例和逐行注释,详细解释WebGPU中顶点缓冲区的配置方法,特别针对shaderLocation参数与着色器的对应关系进行重点说明。 一、顶点数据定义与缓冲区创建 // 定义顶点数据结构(逻辑层) // 包含位置(position)、颜…...

JSP(学习自用)

一、本质 JSP解析后就是Servlet类的java代码。 二、jsp内嵌java代码 1、声明脚本 用于声明属性和方法。 <%!//声明脚本//用于声明属性和方法public void test(){}String easyName"张三"; %> 2、运行脚本 相当于在service方法中写代码 <% //运行脚本…...

ZYNQ TCP Server PS端千兆网口速率低问题,要修改BSP中LWIP配置参数

用VITIS教程里面 TCP UDP应用工程例程 打算测试PS端千兆网口速率。ZYNQ核心板用黑金的&#xff0c;外部板子自画的网口电路和其它电路。TCP SERVER时 iperf测试速率 只有60~70Mbit/s&#xff1f;然后用UDP SERVER方式&#xff0c;发现能达到 950Mbit/s&#xff1f;&#xff1f;…...

毕业设计—基于Spring Boot的社区居民健康管理平台的设计与实现

&#x1f393; 毕业设计大揭秘&#xff01;想要源码和文章&#xff1f;快来私信我吧&#xff01; Hey小伙伴们~ &#x1f44b; 毕业季又来啦&#xff01;是不是都在为毕业设计忙得团团转呢&#xff1f;&#x1f914; 别担心&#xff0c;我这里有个小小的福利要分享给你们哦&…...

【计算机网络】数据链路层数据帧(Frame)格式

在计算机网络中&#xff0c;数据帧&#xff08;Frame&#xff09; 是数据链路层的协议数据单元&#xff08;PDU&#xff09;&#xff0c;用于在物理介质上传输数据。数据帧的格式取决于具体的链路层协议&#xff08;如以太网、PPP、HDLC 等&#xff09;。以下是常见数据帧格式的…...

机器学习PCA和LDA

主成分分析&#xff08;PCA, Principal Component Analysis&#xff09;和线性判别分析&#xff08;LDA, Linear Discriminant Analysis&#xff09;是两种常用的降维方法&#xff0c;它们虽然都用于数据降维&#xff0c;但核心思想和应用场景不同。 PCA&#xff08;主成分分析…...

C#: String s = new String(“Hello“)无法编译?编程语言字符集有两个?为什么这种变量名“\u0061\u0062”都能编译通过?

C#: String s new String("Hello")无法编译? C# String类型是literal常量&#xff0c;默认不能用new创建&#xff0c;但可以在unsafe下用char *字符串指针创建。 char* charPtr stackalloc char[2]; charPtr[0] H; charPtr[1] \0; String myString new Strin…...

Visual Studio Code使用ai大模型编成

1、在Visual Studio Code搜索安装roo code 2、去https://openrouter.ai/settings/keys官网申请个免费的配置使用...

nlp|微调大语言模型初探索(1),LLaMA-Factory

前言 微调模型通常比从零开始训练一个模型的技术要求低。公司不需要拥有大量的深度学习专家&#xff0c;利用现有的开源工具和库&#xff08;如Hugging Face的Transformers等&#xff09;&#xff0c;中小型公司可以轻松地使用和微调大型模型&#xff0c;从而快速实现AI能力的集…...

c++TinML转html

cTinML转html 前言解析解释转译html类定义开头html 结果这是最终效果&#xff08;部分&#xff09;&#xff1a; ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/6cf6c3e3c821446a84ae542bcc2652d4.png) 前言 在python.tkinter设计标记语言(转译2-html)中提到了将Ti…...

Gentleman:优雅的Go语言HTTP客户端工具包

gentlemen介绍&#xff0c;特点等 插件驱动架构&#xff1a;Gentleman的核心特点是其插件系统&#xff0c;允许用户注册和重用各种自定义插件&#xff0c;如重试策略或动态服务器发现&#xff0c;以增强HTTP客户端的功能。 中间件层&#xff1a;项目内置了一个上下文感知的层次…...

JDK1.8新特性面试题

lambda表达式 Lambda表达式极大地简化了匿名内部类的创建&#xff0c;促进了函数式编程风格。开发者可以更简洁地定义只有一行代码的函数对象&#xff0c;并将其作为参数传递给方法或者赋值给变量。 三要素&#xff1a; 形式参数、箭头、代码块 &#xff08;形式参数&#xf…...

Windchill-PDM-设置环境

Web 浏览器和 Java 插件版本 请确保 Windchill PDMLink 支持您使用的 Web 浏览器及 Java 插件的版本。PTC 软件对照表内列出了所支持的浏览器和插件。 软件一览表列出了平台、操作系统以及经认证可以在 Windows 和 UNIX 操作系统上与 此版本一起使用的第三方产品的组合。产品和…...

《蓝耘服务器:领先架构、技术创新与行业应用全景解析》

&#x1f31f; 嗨&#xff0c;我是Lethehong&#xff01;&#x1f31f; &#x1f30d; 立志在坚不欲说&#xff0c;成功在久不在速&#x1f30d; &#x1f680; 欢迎关注&#xff1a;&#x1f44d;点赞⬆️留言收藏&#x1f680; &#x1f340;欢迎使用&#xff1a;小智初学…...

前端【技术方案】重构项目

1. 明确重构目标 优化性能 减少页面加载时间降低资源占用 提升代码可维护性 更规范的代码风格更清晰的代码结构更明确的模块设计 扩展功能 为项目添加新功能改进现有功能 2. 评估项目现状 审查代码 全面检查现有代码&#xff0c;找出代码中的问题&#xff0c;如代码冗余、耦合…...

C#中反射的原理介绍及常见的应用场景介绍

反射&#xff08;Reflection&#xff09;是C#中的一种机制&#xff0c;允许程序在运行时获取类型信息并动态调用其成员。通过反射&#xff0c;程序可以访问程序集、模块、类型及其成员&#xff08;如方法、属性、字段等&#xff09;&#xff0c;并能在运行时创建对象、调用方法…...

uniapp webview嵌入外部h5网页后的消息通知

最近开发了个oa系统&#xff0c;pc端的表单使用form-create开发&#xff0c;form-create 是一个可以通过 JSON 生成具有动态渲染、数据收集、验证和提交功能的表单生成组件。移动端使用uniapp开发&#xff0c;但是因为form-create移动端只支持vant&#xff0c;不支持uniapp。官…...

java听书项目

项目的架构 网关:1路由转发 2.认证鉴权(token)3.统一处理(跨域) Mysql:关系型数据库 ES:搜索数据库 Redis:页面级缓存,会话状态存储 GitLab:私有托管平台 K8S:自动化部署、扩展和管理容器化应用程序的开源系统 Jenkins:自动化部署 1.环境搭建 创建一个父工程…...

iOS 获取设备占用内存

获取应用占用内存 获取应用进程占用内存 - (NSUInteger)memoryUsage {task_vm_info_data_t vmInfo;mach_msg_type_number_t count TASK_VM_INFO_COUNT;kern_return_t result task_info(mach_task_self(), TASK_VM_INFO, (task_info_t)&vmInfo, &count);if (result …...

C#功能测试

List 内部元素为引用 src[0]为"11" List<Source> src new List<Source>(); src.Add(new Source() { Name "1", Age 1, Description "1" }); src.Add(new Source() { Name "2", Age 2, Description "2"…...

js第八题

题八&#xff1a;滚动弹幕 要求&#xff1a; 1.页面上漂浮字体大小不一、颜色不一&#xff0c;从左向右滚动的弹幕&#xff1b; 2.底部中间有一个发送功能&#xff0c;可以发送新的弹幕&#xff1b; 3.底部的发送部分可以向下收起和弹出。 html <div id"danmu-con…...

第35次CCF计算机软件能力认证 python 参考代码

题目列表1. 密码2. 字符串变换3. 补丁应用4. 通讯延迟5. 木板切割题目列表 第35次CCF计算机软件能力认证 1. 密码 n = int(input()) for _ in range(n):s =...

2025百度快排技术分析:模拟点击与发包算法的背后原理

一晃做SEO已经15年了&#xff0c;2025年还有人问我如何做百度快速排名&#xff0c;我能给出的答案就是&#xff1a;做好内容的前提下&#xff0c;多刷刷吧&#xff01;百度的SEO排名算法一直是众多SEO从业者研究的重点&#xff0c;模拟算法、点击算法和发包算法是百度快速排名的…...

国产FPGA开发板选择

FPGA开发板是学习和开发FPGA的重要工具&#xff0c;选择合适的开发板对学习效果和开发效率至关重要。随着国产FPGA的发展&#xff0c;淘宝上的许多FPGA开发板店铺也开始进行国产FPGA的设计和销售&#xff0c;本文将对国产FPGA和相关店铺做个简单梳理&#xff0c;帮助有需要使用…...

DeepSeek+即梦 做AI视频

DeepSeek做AI视频 制作流程第一步&#xff1a;DeepSeek 生成视频脚本和分镜 第二步&#xff1a;生成分镜图片绘画提示词第三步&#xff1a;生成分镜图片第四步&#xff1a;使用可灵 AI 工具&#xff0c;将生成的图片转成视频。第五步&#xff1a;剪映成短视频 DeepSeek 真的强&…...