9.图像中值腐蚀膨胀滤波的实现

news2024/12/24 21:51:23

1 简介

  在第七章介绍了基于三种卷积前的图像填充方式,并生成了3X3的图像卷积模板,第八章运用这种卷积模板进行了均值滤波的FPGA实现与MATLAB实现,验证了卷积模板生成的正确性和均值滤波算法的MATLAB算法实现。
  由于均值滤波、中值滤波、腐蚀、膨胀都依赖与卷积核且实现较为简单,这里将对剩下的三种图像处理方式一起介绍。

2 处理前图像的生成。

  由于在第八章的中值滤波的试验需要放大观察,且去噪效果几乎看不到,这里我们先对灰度图添加随机的椒盐噪声,并利用添加椒盐噪声后的图像做数字图像处理的FPGA算法实现以及MATLAB算法验证。这样可以方便观察图像处理前后的差异。
  对图像随机添加椒盐噪声的MATLAB代码如下:

clear;
clc;
close all;
a = imread('../img/1920X1080_gray.bmp');
subplot(1,2,1),imshow(a),title('原图');

b=imnoise(a,'salt & pepper',0.01);
subplot(1,2,2),imshow(b),title('加入噪声密度:0.01的椒盐噪声');

imwrite(b,'../img/gray.bmp');

  添加前后的图像对比如下:
在这里插入图片描述
  可以看到图像现在有了一定数量的噪点。后续的图像处理均以添加椒盐噪声后的图像作为原始图像来处理。

3 三种算法的FPGA实现与MATLAB验证

3.1 中值滤波

  中值滤波是一种非线性的滤波方式,是一种排序滤波,它将图像的某一个像素点的灰度值设置成该点某一邻域窗口内所有像素点灰度值排序后的中值。
  中值滤波对孤立的噪点像素即椒盐噪声具有良好的滤波效果,且不同于均值滤波对图像边缘性的破坏,中值滤波不会显著性的使图像边缘变得模糊。
  1.用一个模板来移动窗口,并将模板中心与图中的某个像素位置重合;
  2.读取模板的像素值并按照大小进行排序;
  3.选取灰度序列中,最中间的一个灰度值;
  4.将灰度值赋值给模板中间的像素;

3.2 3X3模板的中值滤波的FPGA算法实现简介

  在3X3的卷积模板中,找出中值共需要经历七次排序。
  1.前三次排序分别对3X3模板的三行进行排序,得到min、mid、max。
  2.后三次排序在三个最小值中找出一个最大值,三个中值中找出一个中值,三个最大值中找出一个最小值。
  3.在步骤二找出的三个值中找出中值,这个值即为最终需要赋值的像数值。
中值滤波算法框图

3.2.1 sort_3模块

  由于3X3卷积模板中值滤波共需要经过七次三个数的排序,因此首先需要创建一个排序模块供中值滤波模块调用。三个数的排序模块代码如下:

`timescale 1ns / 1ps

module sort_3 #(
	parameter 	DW 	= 	8 				
	)(
 	input 	wire 				clk 		,
 	input 	wire  				rst_n 		,
 	input 	wire 				data_de 	,
 	input 	wire  	[DW-1:0]	data1 		,
  	input 	wire  	[DW-1:0]	data2 		,
 	input 	wire  	[DW-1:0]	data3 		,

 	output 	reg 				data_out_de ,
 	output 	reg 	[DW-1:0] 	min_data 	,
 	output 	reg 	[DW-1:0] 	mid_data 	, 
 	output 	reg 	[DW-1:0] 	max_data 				
);

always @(posedge clk)
	if(rst_n == 0)
		min_data 	<= 	0;
	else if(data1 <= data2 && data1 <= data3)
		min_data 	<= 	data1 	;
	else if(data2 <= data1 && data2 <= data3)
	 	min_data 	<= 	data2 	;
	else
	 	min_data 	<= 	data3 	; 

always @(posedge clk)
	if(rst_n == 0)
		mid_data 	<= 	0;
	else if((data1 <= data2 && data1 >= data3) || (data1 >= data2 && data1 <= data3))
		mid_data 	<= 	data1 	;
	else if((data2 <= data1 && data2 >= data3) || (data2 >= data1 && data2 <= data3))
	 	mid_data 	<= 	data2 	;
	else
	 	mid_data 	<= 	data3 	;

always @(posedge clk)
	if(rst_n == 0)
		max_data 	<= 	0;
	else if(data1 >= data2 && data1 >= data3)
		max_data 	<= 	data1 	;
	else if(data2 >= data1 && data2 >= data3)
	 	max_data 	<= 	data2 	;
	else
	 	max_data 	<= 	data3 	;

always @(posedge clk)
	if(rst_n == 0)
		data_out_de 	<= 	0;
	else
	 	data_out_de 	<= 	data_de;
endmodule

3.2.2 中值滤波模块

  中值滤波本身就是一种排序算法,只需要多次三个数的排序即可完成,因此此算法模块内部就是sort_3模块的例化与连接,代码如下:

`timescale 1ns / 1ps

module mid_filter#(
    parameter DW = 8
)(
    input   wire                clk         ,
    input   wire                rst_n       ,

    input   wire                matrix_de   ,
    input   wire    [DW-1:0]    matrix11    ,
    input   wire    [DW-1:0]    matrix12    ,
    input   wire    [DW-1:0]    matrix13    ,
    input   wire    [DW-1:0]    matrix21    ,
    input   wire    [DW-1:0]    matrix22    ,
    input   wire    [DW-1:0]    matrix23    ,
    input   wire    [DW-1:0]    matrix31    ,
    input   wire    [DW-1:0]    matrix32    ,
    input   wire    [DW-1:0]    matrix33    ,

    output  wire                mid_data_de ,
    output  wire    [DW-1:0]    mid_data 
    );
wire  					matrix1_de 		;
wire  	[DW-1:0] 		min_data1 		;
wire  	[DW-1:0] 		mid_data1 		;
wire  	[DW-1:0] 		max_data1 		;

wire  					matrix2_de 		;
wire  	[DW-1:0] 		min_data2 		;
wire  	[DW-1:0] 		mid_data2 		;
wire  	[DW-1:0] 		max_data2 		;

wire  					matrix3_de 		;
wire  	[DW-1:0] 		min_data3 		;
wire  	[DW-1:0] 		mid_data3 		;
wire  	[DW-1:0] 		max_data3 		;

wire 					matrix4_de 		;
wire 	[DW-1:0] 		max_min_data	;

wire 					matrix5_de 		;
wire 	[DW-1:0] 		mid_mid_data	; 

wire 					matrix6_de 		;
wire 	[DW-1:0] 		min_max_data	;	

wire 					matrix7_de 		;
wire 	[DW-1:0] 		mid_filter_data	;	

sort_3 #(
	.DW 	(DW) 				
)u1_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix_de 		),
 	.data1 			(matrix11    	),
  	.data2 			(matrix12    	),
 	.data3 			(matrix13    	),

 	.data_out_de 	(matrix1_de 	),
 	.min_data 		(min_data1 		),
 	.mid_data 		(mid_data1 		), 
 	.max_data 		(max_data1 		)	
);

sort_3 #(
	.DW 	(DW) 				
)u2_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix_de 		),
 	.data1 			(matrix21    	),
  	.data2 			(matrix22    	),
 	.data3 			(matrix23    	),

 	.data_out_de 	(matrix2_de 	),
 	.min_data 		(min_data2 		),
 	.mid_data 		(mid_data2 		), 
 	.max_data 		(max_data2 		)	
);

sort_3 #(
	.DW 	(DW) 				
)u3_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix_de 		),
 	.data1 			(matrix31    	),
  	.data2 			(matrix32    	),
 	.data3 			(matrix33    	),

 	.data_out_de 	(matrix3_de 	),
 	.min_data 		(min_data3 		),
 	.mid_data 		(mid_data3 		), 
 	.max_data 		(max_data3 		)	
);





sort_3 #(
	.DW 	(DW) 				
)u4_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix1_de 	),
 	.data1 			(max_data1    	),
  	.data2 			(max_data2    	),
 	.data3 			(max_data3    	),

 	.data_out_de 	(matrix4_de 	),
 	.min_data 		(max_min_data 	),
 	.mid_data 		( 				), 
 	.max_data 		( 				)	
);

sort_3 #(
	.DW 	(DW) 				
)u5_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix1_de 	),
 	.data1 			(mid_data1    	),
  	.data2 			(mid_data2    	),
 	.data3 			(mid_data3    	),

 	.data_out_de 	(matrix5_de 	),
 	.min_data 		( 			 	),
 	.mid_data 		(mid_mid_data 	), 
 	.max_data 		( 				)	
);

sort_3 #(
	.DW 	(DW) 				
)u6_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix1_de 	),
 	.data1 			(min_data1    	),
  	.data2 			(min_data2    	),
 	.data3 			(min_data3    	),

 	.data_out_de 	(matrix6_de 	),
 	.min_data 		( 			 	),
 	.mid_data 		(min_max_data 	), 
 	.max_data 		( 				)	
);




sort_3 #(
	.DW 	(DW) 				
)u7_sort_3(
 	.clk 			(clk 			),
 	.rst_n 			(rst_n 			),
 	.data_de 		(matrix4_de 	),
 	.data1 			(max_min_data   ),
  	.data2 			(mid_mid_data   ),
 	.data3 			(min_max_data   ),

 	.data_out_de 	(matrix7_de 	),
 	.min_data 		( 			 	),
 	.mid_data 		(mid_filter_data), 
 	.max_data 		( 				)	
);

assign mid_data 	= mid_filter_data	;
assign mid_data_de 	= matrix7_de		;

endmodule

  例化后用vivado查看连线有
在这里插入图片描述

3.2.3 中值滤波的顶层连接

`timescale 1ns / 1ps
module top_mid_filter#(
    parameter COL       = 1920  ,
    parameter ROW       = 1080  ,
    parameter PADDING   = 2     ,
    parameter DW        = 8     
)(
    input   wire                clk             ,
    input   wire                rst_n           ,
    input   wire                data_de         ,
    input   wire    [DW-1:0]    data            ,
    output  wire                mid_data_de     ,
    output  wire    [DW-1:0]    mid_data          
);

wire    [DW-1:0]      matrix11    ;
wire    [DW-1:0]      matrix12    ;
wire    [DW-1:0]      matrix13    ;
wire    [DW-1:0]      matrix21    ;
wire    [DW-1:0]      matrix22    ;
wire    [DW-1:0]      matrix23    ;
wire    [DW-1:0]      matrix31    ;
wire    [DW-1:0]      matrix32    ;
wire    [DW-1:0]      matrix33    ;    

padding_matrix #(
	.COL 	    (COL        ),
	.ROW 	    (ROW        ),
	.PADDING    (PADDING    )
)u_padding_matrix(
 	.clk 		    (clk 		    ),
 	.rst_n 		    (rst_n 		    ),

 	.data 		    (data 		    ),
 	.data_de 	    (data_de 	    ), 

 	.matrix_de 	    (matrix_de 	    ),
 	.matrix11 	    (matrix11 	    ),
 	.matrix12 	    (matrix12 	    ),
 	.matrix13 	    (matrix13 	    ),
 	.matrix21 	    (matrix21 	    ),
 	.matrix22 	    (matrix22 	    ),
 	.matrix23 	    (matrix23 	    ),
 	.matrix31 	    (matrix31 	    ),
 	.matrix32 	    (matrix32 	    ),
 	.matrix33 	    (matrix33 	    )
);

mid_filter #(
    .DW         (DW)
)u_mid_filter(
    .clk            (clk            ),
    .rst_n          (rst_n          ),

    .matrix_de      (matrix_de      ),
    .matrix11       (matrix11       ),
    .matrix12       (matrix12       ),
    .matrix13       (matrix13       ),
    .matrix21       (matrix21       ),
    .matrix22       (matrix22       ),
    .matrix23       (matrix23       ),
    .matrix31       (matrix31       ),
    .matrix32       (matrix32       ),
    .matrix33       (matrix33       ),

    .mid_data_de    (mid_data_de    ),
    .mid_data       (mid_data       )
    );
endmodule

  例化后用vivado查看连线有
在这里插入图片描述

3.3 中值滤波的FPGA仿真

  仿真依旧是img_gen模块读取pre.txt的像素数据,tb顶层写回仿真后的像素数据到mid_filter.txt文本。

`timescale 1ns / 1ps

module img_gen
#(
 	parameter 	ACTIVE_IW 	= 	1920 	,
 	parameter 	ACTIVE_IH 	= 	1080 	,
 	parameter 	TOTAL_IW 	= 	2200 	,
 	parameter 	TOTAL_IH 	= 	1100 	,
 	parameter 	H_START 	= 	100 	,
 	parameter 	V_START 	= 	4 		 		
)(
	input 	wire 				clk 	,
	input 	wire 				rst_n 	,
	output 	reg 				vs 		,
	output 	reg  	 	 		de 		,
	output 	reg 	[7:0] 		data 	
);

reg  	[7:0] 	raw_array 	 [ACTIVE_IW*ACTIVE_IH-1:0];

integer i;
initial begin
	for (i=0 ;i<ACTIVE_IH*ACTIVE_IW ; i=i+1) begin
		raw_array[i] = 0;
	end
end

initial begin
	$readmemh("H:/picture/Z7/lesson8/data/pre.txt",raw_array);
end

reg 	[15:0] 	hcnt 	;
reg 	[15:0] 	vcnt 	;

reg 			h_de 	;
reg 			v_de  	;

reg  			index_de 	;
reg 	[31:0] 	index 	 	;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		hcnt <= 'd0;
	else if(hcnt == TOTAL_IW - 1)
		hcnt <= 'd0;
	else 
		hcnt <= hcnt + 1'b1;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		vcnt <= 'd0;
	else if(hcnt == TOTAL_IW - 1 && vcnt == TOTAL_IH - 1)
		vcnt <= 'd0;
	else if(hcnt == TOTAL_IW - 1)
		vcnt <= vcnt + 1'b1;
	else 
		vcnt <= vcnt;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		vs <= 'd0;
	else if(vcnt>=2)
		vs <= 1'b1;
	else 
		vs <= 1'b0;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		h_de <= 'd0;
	else if(hcnt >= H_START && hcnt < H_START + ACTIVE_IW)
		h_de <= 1'b1;
	else 
		h_de <= 1'b0;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		v_de <= 'd0;
	else if(vcnt >= V_START && vcnt < V_START + ACTIVE_IH)
		v_de <= 1'b1;
	else 
		v_de <= 1'b0;


always @(posedge clk or negedge rst_n)
	if(!rst_n)
		index_de <= 'd0;
	else if(h_de == 1'b1 && v_de == 1'b1)
		index_de <= 1'b1;
	else 
		index_de <= 1'b0;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		index <= 'd0;
	else if(index == ACTIVE_IW * ACTIVE_IH-1)
		index <= 0;
	else if(index_de == 1'b1)
		index <= index + 1;
	else 
		index <= index;

always @(posedge clk or negedge rst_n)
	if(!rst_n)
		de <= 'd0;
	else 
		de <= index_de;

always @(posedge clk or negedge rst_n)begin
	if(index_de == 1'b1)
		data 	<= 	raw_array[index];
	else 
		data 	<= 0;
end
endmodule

`timescale 1ns / 1ps



module tb_top_mid_filter(

    );

reg 	clk 	;
reg 	rst_n 	;

wire 	[7:0] 	data 	;
wire 			de  	;

wire 			vs  	;

wire    [7:0]   mid_data;
wire            mid_data_de;
	
integer 	outfile;
always #5 clk 	<= 	~clk;
initial 	begin
	clk 	<= 0;
	rst_n 	= 0;
	#100
	rst_n 	= 1;
	outfile = $fopen("H:/picture/Z7/lesson8/data/mid_filter.txt","w");
end

img_gen
#(
 	.ACTIVE_IW 	(1920 	),
 	.ACTIVE_IH 	(1080 	),
 	.TOTAL_IW 	(2200 	),
 	.TOTAL_IH 	(1100 	),
 	.H_START 	(4 	 	),
 	.V_START 	(4 	 	) 		
)u_img_gen(
	.clk 	 	(clk 	 	),
	.rst_n 	 	(rst_n 	 	),
	.vs 		(vs 		),
	.de 		(de 		),
	.data 	 	(data 	 	)
);

top_mid_filter#(
    .COL       ( 1920  ),
    .ROW       ( 1080  ),
    .PADDING   ( 2     ),
    .DW        ( 8     )
)u_top_mid_filter(
    .clk            (clk            ),
    .rst_n          (rst_n          ),
    .data_de        (de             ),
    .data           (data           ),
    .mid_data_de    (mid_data_de    ),
    .mid_data       (mid_data       )  
);

reg 	vs_r 	;

always @(posedge clk)
	if(rst_n == 0)
		vs_r 	<= 1'b0;
	else 
		vs_r 	<= vs;

always @(posedge clk)
	if(~vs&&vs_r)
		$stop;
	else if(mid_data_de)
 		$fdisplay(outfile,"%h\t",mid_data);		

endmodule

3.3 中值滤波的MATLAB算法实现与验证

  中值滤波的MATLAB算法实现如下:

clc;
clear all;
GRAY = imread('../img/gray.bmp');
[row,col] = size(GRAY);
GRAY = double(GRAY);
mid_filter_padding = zeros(row+2,col+2);
mid_filter_result  =   zeros(row,col);
for i = 1:row
    for j = 1:col
        mid_filter_padding(i+1,j+1) = GRAY(i,j);
    end
end

for i = 1:row+2
    mid_filter_padding(i,1) = mid_filter_padding(i,2);
    mid_filter_padding(i,col+2) = mid_filter_padding(i,col+1);
end

for i = 1:col+2
   mid_filter_padding(1,i) = mid_filter_padding(2,i);
   mid_filter_padding(row+2,i) = mid_filter_padding(row+1,i);
end

for i = 2:row+1
    for j = 2:col+1
        matrix11 = mid_filter_padding(i-1,j-1);
        matrix12 = mid_filter_padding(i-1,j);
        matrix13 = mid_filter_padding(i-1,j+1);
        
        matrix21 = mid_filter_padding(i,j-1);
        matrix22 = mid_filter_padding(i,j);
        matrix23 = mid_filter_padding(i,j+1);
        
        matrix31 = mid_filter_padding(i+1,j-1);
        matrix32 = mid_filter_padding(i+1,j);
        matrix33 = mid_filter_padding(i+1,j+1); 

        sort_buf = sort([matrix11,matrix12,matrix13,matrix21,matrix22,matrix23,matrix31,matrix32,matrix33],'ascend');

        mid_filter_result(i-1,j-1) = sort_buf(1,5);
    end
end
matlab_Y = uint8(floor(mid_filter_result));

a = textread('../data/mid_filter.txt','%s');
IMdec1 = hex2dec(a);

col = 1920;
row = 1080;

IM1 = reshape(IMdec1,col,row);
fpga_Y = uint8(IM1)';

b = textread('../data/pre.txt','%s');
IMdec2 = hex2dec(b);

col = 1920;
row = 1080;

IM2 = reshape(IMdec2,col,row);
gray = uint8(IM2)';

subplot(1,3,1)
imshow(gray),title('原始图像');
subplot(1,3,2)
imshow(matlab_Y),title('MATLAB中值滤波算法图像');
subplot(1,3,3)
imshow(fpga_Y),title('FPGA中值滤波算法图像');

sub = matlab_Y - fpga_Y;

min_sub = min(min(sub));
max_sub = max(max(sub));

在这里插入图片描述
  MATLAB算法实现与FPGA仿真结果完全一致,验证通过。由于在添加椒盐噪声的时候,添加的是孤立的噪声点,完美符合中值滤波算法,所以还原效果最好,但是当椒盐噪声的像素点过多的时候,中值滤波需要更大的卷积模板,且也会一定程度的使边缘模糊。

3.2 腐蚀与膨胀滤波

  中值滤波是取卷积模板的中位数做滤波算法,但是当单个椒盐噪点的面积过大时,此算法并不适用,腐蚀算法就是取卷积模板的最小值,膨胀就是取卷积模板的最大值。因此只需要在中值滤波的基础上改变卷积的连线即可。腐蚀和膨胀经常成对的使用,具体使用方式可以参考图像的膨胀与腐蚀这篇文章。
  这里只分别贴出对图像进行腐蚀和膨胀的处理前后效果图。
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

【QT+QGIS跨平台编译】054:【exiv2lib+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

点击查看专栏目录 文章目录 一、exiv2lib介绍二、文件下载三、文件分析四、pro文件五、编译实践一、exiv2lib介绍 exiv2lib 是一个用于处理图像元数据的开源 C++ 库。它可用于读取、编辑和写入图像文件中的 Exif 元数据(Exchangeable Image File Format,可交换图像文件格式)…

怎么打包出release.aar包

第一种 选择build variant 更改成release 第二钟 在gradle中选择相应任务来编译 选择assemble release如果没有这个选项&#xff0c;可能是你没有开启那个Task 收集的选项

机器学习——降维算法-奇异值分解(SVD)

机器学习——降维算法-奇异值分解&#xff08;SVD&#xff09; 在机器学习中&#xff0c;降维是一种常见的数据预处理技术&#xff0c;用于减少数据集中特征的数量&#xff0c;同时保留数据集的主要信息。奇异值分解&#xff08;Singular Value Decomposition&#xff0c;简称…

为 Linux 中的 Docker 配置阿里云和网易云国内镜像加速下载中心

由于默认情况下&#xff0c;Docker 的镜像下载中心默认为国外的镜像中心&#xff0c;使用该镜像中心拉去镜像会十分缓慢&#xff0c;所以我们需要配置国内的 Docker 镜像下载中心&#xff0c;加速 Docker 镜像的拉取。Docker 的国内镜像下载中心常用的有&#xff1a;阿里云、网…

微信小程序(黑马优购:购物车页面)

1.渲染商品页面 <template><view><!-- 商品列表的标题区域 --><view class"cart-title"><!-- 左侧的图标 --><uni-icons type"shop" size"18"></uni-icons><!-- 右侧的文本 --><text class…

力扣 1143. 最长公共子序列

题目来源&#xff1a;https://leetcode.cn/problems/longest-common-subsequence/description/ C题解&#xff08;思路来源代码随想录&#xff09;&#xff1a;动态规划。 1. 确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i][j]&#xff1a;长度为[0, i - 1]…

Python之Opencv进阶教程(1):图片模糊

1、Opencv提供了多种模糊图片的方法 加载原始未经模糊处理的图片 import cv2 as cvimg cv.imread(../Resources/Photos/girl.jpg) cv.imshow(girl, img)1.1 平均值 关键代码 # Averaging 平均值 average cv.blur(img, (3, 3)) cv.imshow(Average Blur, average)实现效果 1.2…

备战蓝桥杯---贪心刷题1

话不多说&#xff0c;直接看题&#xff1a; 本质是一个数学题&#xff1a; 我们令xi<0表示反方向传递&#xff0c;易得我们就是求每一个xi的绝对值之和min,我们令平均值为a爸。 易得约束条件&#xff1a; x1-x2a1-a,x2-x3a2-a..... 解得x1x1-0,x2x1-((n-1)*a-a2-...an)。…

通过搜索引擎让大模型获取实时数据-实现类似 perplexity 的效果

文章目录 一、前言二、初衷三、实现方式四、总结 一、前言 汇报一下这周末的工作&#xff0c;主要是开发了一门课程&#xff1a;通过搜索引擎让大模型获取实时数据&#xff0c;第一次开发一门课程&#xff0c;难免会有很多不熟悉和做的不好的地方。 已经训练好的大模型有气数…

今天起,Windows可以一键召唤GPT-4了

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了人工智能中文站https://ai.weoknow.com 每天给大家更新可用的国内可用chatGPT资源 发布在https://it.weoknow.com 更多资源欢迎关注 微软 AI 大计的最后一块拼图完成了&#xff1f; 把 Copilot 按钮放在 Window…

【Linux】权限的基本概念

在本篇博客中&#xff0c;作者将会讲解在linux系统中&#xff0c;权限的基本概念。 一.什么是权限 通俗的讲&#xff0c;权限是用来约束人的。比如说&#xff1a;你买了某软件的vip会员&#xff0c;那么你就可以执行相对操作&#xff0c;如果你没买&#xff0c;则就会有权限约束…

Linux的中间件

我们先补充点关于awk的内容 awk的用法其实很广。 $0 表示整条记录 变量&#xff1a; NF 一行中有多少个字段&#xff08;表示字段数&#xff09; NR &#xff1a; 代表当前记录的序号&#xff0c;从1开始计数。每读取一条记录&#xff0c;NR的值就会自动增加1。&#xff08;…

基于ssm旅游资源网站(java项目+文档+源码)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的旅游资源网站。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 旅游资源网站的主要使用者分为管理…

稀碎从零算法笔记Day35-LeetCode:字典序的第K小数字

要考虑完结《稀碎从零》系列了哈哈哈 这道题和【LC.42 接雨水】&#xff0c;我愿称之为【笔试界的颜良&文丑】 题型&#xff1a;字典树、前缀获取、数组、树的先序遍历 链接&#xff1a;440. 字典序的第K小数字 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1…

Pytorch 下载失败原因

错误信息&#xff1a; ERROR: Could not find a version that satisfies the requirement torch (from versions: none) ERROR: No matching distribution found for torch 解决方案&#xff1a; 在官网看到&#xff0c;它需要python3.8-3.11的环境。过高和过低的版本都不…

番外篇 | 手把手教你如何用YOLOv8实现行人/车辆等过线统计

前言:Hello大家好,我是小哥谈。目标检测行人/车辆等过线统计是一种常见的视频分析任务,用于统计行人/车辆等在指定区域内过线的次数。这个任务通常需要使用目标检测算法来识别行人/车辆等,并使用计数器算法来统计过线的次数。🌈 目录 🚀1.本文介绍 🚀2.实现

LeetCode刷题【链表,图论,回溯】

目录 链表138. 随机链表的复制148. 排序链表146. LRU 缓存 图论200. 岛屿数量994. 腐烂的橘子207. 课程表 回溯 链表 138. 随机链表的复制 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random &#xff0c;该指针可以指向链表中的任何节点或空节…

2024年泰迪杯数据挖掘B题详细思路代码文章教程

目前b题已全部更新包含详细的代码模型和文章&#xff0c;本文也给出了结果展示和使用模型说明。 同时文章最下方包含详细的视频教学获取方式&#xff0c;手把手保姆级&#xff0c;模型高精度&#xff0c;结果有保障&#xff01; 分析&#xff1a; 本题待解决问题 目标&#…

K8S之Secret的介绍和使用

Secret Secret的介绍Secret的使用通过环境变量引入Secret通过volume挂载Secret Secret的介绍 Secret是一种保护敏感数据的资源对象。例如&#xff1a;密码、token、秘钥等&#xff0c;而不需要把这些敏感数据暴露到镜像或者Pod Spec中。Secret可以以Volume或者环境变量的方式使…

Valkey是一个新兴的开源项目,旨在成为Redis的替代品,背后得到了AWS、Google、Oracle支持

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…