【算法】FFT-1(递归实现)(不包括IFFT)

FFT

      • 多项式
      • 多项式乘法
      • 复数及运算
      • 导数
      • 泰勒公式及展开式
      • 欧拉公式
      • 单位根
    • FFT
      • Code
    • IFFT

多项式

我们从课本中可以知道,一个 n − 1 n-1 n1 次的多项式可以写成 a 0 + a 1 x + a 2 x 2 + a 3 x 3 + ⋯ + a n − 1 x n − 1 a_{0}+a_{1}x+a_{2}x^2+a_{3}x^3+\dots+a_{n-1}x^{n-1} a0+a1x+a2x2+a3x3++an1xn1

用高级一点的表示法就是:
一个 n − 1 n-1 n1 n n n 项多项式 f ( x ) f(x) f(x) 可以表示为:

f ( x ) = ∑ i = 0 n − 1 a i x i f(x)=\sum_{i=0}^{n-1}a_ix^i f(x)=i=0n1aixi

所以我们可以用每一项的系数来表示 f ( x ) f(x) f(x),即

f ( x ) = { a 0 , a 1 , a 2 , … , a n − 1 } f(x)=\{a_0,a_1,a_2,\dots,a_{n-1}\} f(x)={a0,a1,a2,,an1}

俗称系数表示法。

但是,当我们把这个多项式看成一个函数时,我们将 n n n 个不同的 x x x 带入,会得到 n n n 个不一样的 y y y,而我们就得到了 n n n 个点的坐标,它们确定唯一的多项式 f ( x ) f(x) f(x)

证明很简单,直接待定系数法就可以解决。

那么 f ( x ) f(x) f(x) 还可以用这 n n n 个点表示:

f ( x ) = { ( x 0 , y 0 ) , ( x 1 , y 1 ) , ( x 2 , y 2 ) , … , ( x n − 1 , y n − 1 ) } f(x)=\{(x_0,y_0),(x_1,y_1),(x_2,y_2),\dots,(x_{n-1},y_{n-1})\} f(x)={(x0,y0),(x1,y1),(x2,y2),,(xn1,yn1)}

(其中 y i = f ( x i ) y_i=f(x_i) yi=f(xi))

俗称点值表示法。

多项式乘法

对于两个系数表示法表示的多项式 f ( x ) f(x) f(x) g ( x ) g(x) g(x),如果要计算它们的乘积 h ( x ) h(x) h(x),我们需要枚举 f ( x ) f(x) f(x) 的每一项和 g ( x ) g(x) g(x) 的每一项相乘,最后累计,时间复杂度 O ( n 2 ) O(n^2) O(n2)

那么换成点值表示呢?时间复杂度为 O ( n ) O(n) O(n)

Why?

设两个多项式 f ( x ) f(x) f(x) g ( x ) g(x) g(x) 分别为:

f ( x ) = { ( x 0 , y 1 0 ) , ( x 1 , y 1 1 ) , ( x 2 , y 1 2 ) , … , ( x n − 1 , y 1 n − 1 ) } f(x)=\{(x_0,y1_0),(x_1,y1_1),(x_2,y1_2),\dots,(x_{n-1},y1_{n-1})\} f(x)={(x0,y10),(x1,y11),(x2,y12),,(xn1,y1n1)}

(其中 y 1 i = f ( x i ) y1_i=f(x_i) y1i=f(xi))

g ( x ) = { ( x 0 , y 2 0 ) , ( x 1 , y 2 1 ) , ( x 2 , y 2 2 ) , … , ( x n − 1 , y 2 n − 1 ) } g(x)=\{(x_0,y2_0),(x_1,y2_1),(x_2,y2_2),\dots,(x_{n-1},y2_{n-1})\} g(x)={(x0,y20),(x1,y21),(x2,y22),,(xn1,y2n1)}

(其中 y 2 i = g ( x i ) y2_i=g(x_i) y2i=g(xi))

那么结果 h ( x ) h(x) h(x) 为:

h ( x ) = { ( x 0 , y 2 0 ⋅ y 1 0 ) , ( x 1 , y 2 1 ⋅ y 1 1 ) , ( x 2 , y 2 2 ⋅ y 1 2 ) , … , ( x n − 1 , y 2 n − 1 ⋅ y 1 n − 1 ) } h(x)=\{(x_0,y2_0 \cdot y1_0),(x_1,y2_1 \cdot y1_1),(x_2,y2_2 \cdot y1_2),\dots,(x_{n-1},y2_{n-1} \cdot y1_{n-1})\} h(x)={(x0,y20y10),(x1,y21y11),(x2,y22y12),,(xn1,y2n1y1n1)}

好,我们就结束了

但是怎么将系数表示法转换为点值表示法呢?


复数及运算

高中课本里讲过复数,不过不知道也没关系,这里会讲。

定义:复数单位 i i i 满足 i 2 = − 1 i^2=-1 i2=1,则形如 a + b i a+bi a+bi 的数为复数。 ( a , b ∈ R ) (a,b\in R) (a,bR)

其中 a a a 叫做实部, b b b 叫做虚部, i i i 为虚数单位。

所以有 − 7 = 7 i \sqrt{-7}=\sqrt7i 7 =7 i

类似平面直角坐标系,在复平面直角坐标系中,复数为其中的一个点。

如下图:

点(3,2)表示的复数为 3 + 2 i 3+2i 3+2i

它也可以表示为( 1 3 , θ \sqrt 13,\theta 1 3,θ

定义:一个复数的模为它到原点的距离。

及复数 z = a + b i z=a+bi z=a+bi 的模记为 ∣ z ∣ = a 2 + b 2 |z|=\sqrt{a^2+b^2} z=a2+b2

一个复数的共轭复数为其虚部取反。

及复数 z = a + b i z=a+bi z=a+bi 的共轭复数为 z ˉ = a − b i \bar{z}=a-bi zˉ=abi z z ˉ = a 2 + b 2 z \bar{z} = a^2 +b^2 zzˉ=a2+b2

其实就跟共轭根式差不多。

复数的运算其实跟实数的运算差不多。

z 1 = a + b i z_1 = a + bi z1=a+bi z 2 = c + d i z_2 = c + di z2=c+di

加减法:实部和虚部分别相加减:

z 1 ± z 2 = ( a ± c ) + ( b ± d ) i z_1 \pm z_2 = (a \pm c) + (b \pm d)i z1±z2=(a±c)+(b±d)i

乘法:硬算出奇迹(拆完后合并同类项)

z 1 z 2 = ( a c − b d ) + ( b c + a d ) i z_1z_2 = (ac - bd) + (bc + ad)i z1z2=(acbd)+(bc+ad)i

( a 1 , θ 1 ) ( a 2 , θ 2 ) = ( a 1 a 2 , θ 1 + θ 2 ) (a_1,\theta_1)(a_2,\theta_2)=(a_1a_2,\theta_1+\theta_2) (a1,θ1)(a2,θ2)=(a1a2,θ1+θ2)

除法:化简

z 1 z 2 = a + b i c + d i = ( a + b i ) ( c − d i ) ( c + d i ) ( c − d i ) = a c − b d i 2 + b c i − a d i c 2 − d 2 i 2 = ( a c + b d ) + ( b c − a d ) i c 2 + d 2 \dfrac{z_1}{z_2} = \dfrac{a+bi}{c+di}=\dfrac{(a+bi)(c-di)}{(c+di)(c-di)}=\dfrac{ac-bdi^2+bci-adi}{c^2-d^2i^2}=\dfrac{(ac+bd)+(bc-ad)i}{c^2+d^2} z2z1=c+dia+bi=(c+di)(cdi)(a+bi)(cdi)=c2d2i2acbdi2+bciadi=c2+d2(ac+bd)+(bcad)i

导数

和初中的 y = … y=\dots y= 不一样,我们用 f ( x ) f(x) f(x) 来表示一个关于 x x x 的函数。

一般地,已知函数 y = f ( x ) y=f(x) y=f(x) x 0 , x 1 x_0,x_1 x0,x1 是其定义域内不同两点,记 Δ x = x 1 − x 0 , Δ y = y 1 − y 0 = f ( x 1 ) − f ( x 0 ) = f ( x 0 + Δ x ) − f ( x 0 ) \Delta x=x_1-x_0,\Delta y=y_1-y_0=f(x_1)-f(x_0)=f(x_0+\Delta x)-f(x_0) Δx=x1x0,Δy=y1y0=f(x1)f(x0)=f(x0+Δx)f(x0),则当 Δ x ≠ 0 \Delta x\neq 0 Δx=0 时,商 f ( x 0 + Δ x ) − f ( x 0 ) Δ x = Δ y Δ x \frac{f(x_0+\Delta x)-f(x_0)}{\Delta x}=\frac{\Delta y}{\Delta x} Δxf(x0+Δx)f(x0)=ΔxΔy 称作函数 y = f ( x ) y=f(x) y=f(x)在区间 $[x_0,x_0 +_\Delta x] $ 上的平均变化率。

Δ x \Delta x Δx 趋近于 0 0 0 时,平均变化率 Δ y Δ x = f ( x 0 + Δ x ) − f ( x 0 ) Δ x \frac{\Delta y}{\Delta x}=\frac{f(x_0+\Delta x)-f(x_0)}{\Delta x} ΔxΔy=Δxf(x0+Δx)f(x0) 趋近于一个常数 l l l,那么常数 l l l 称为函数 f ( x ) f(x) f(x) 在点 x 0 x_0 x0 的瞬时变化率。

趋近于可以用符号 → \to 表示,所以上面那句话可以这样表示:

Δ x → 0 \Delta x \to 0 Δx0 时, f ( x 0 + Δ x ) − f ( x 0 ) Δ x → l \frac{f(x_0+\Delta x)-f(x_0)}{\Delta x} \to l Δxf(x0+Δx)f(x0)l

或记作:

lim ⁡ Δ x → 0 f ( x 0 + Δ x ) − f ( x 0 ) Δ x = l \lim_{\Delta x \to 0} \frac{f(x_0+\Delta x)-f(x_0)}{\Delta x}=l limΔx0Δxf(x0+Δx)f(x0)=l

函数在 x 0 x_0 x0 的瞬时变化率,通常称为 f ( x ) f(x) f(x) x = x 0 x=x_0 x=x0 处的导数,并记作 f ′ ( x 0 ) f'(x_0) f(x0)

注意,是 f ′ f' f

那么对于函数 f ( x ) f(x) f(x) 怎么求导呢?

如下:

{ ( x a ) ′ = a x a − 1 ( c ) ′ = 0 ( e x ) ′ = e x ( ln ⁡ x ) ′ = 1 x ( sin ⁡ x ) ′ = cos ⁡ x ( cos ⁡ x ) ′ = sin ⁡ x } \begin{Bmatrix} (x^a)'=ax^{a-1} \\ (c)'=0 \\ (e^x)'=e^x \\ (\ln x)'=\frac{1}{x} \\ (\sin x)'=\cos x \\ (\cos x)'=\sin x \end{Bmatrix} (xa)=axa1(c)=0(ex)=ex(lnx)=x1(sinx)=cosx(cosx)=sinx

例如 f ( x ) = x 2 f(x)=x^2 f(x)=x2,则 f ′ ( x ) = 2 x f'(x)=2x f(x)=2x

最后再说一点 f ′ ( x ) f'(x) f(x) 表示函数 f ( x ) f(x) f(x) x x x 取值为几时切线的斜率。

泰勒公式及展开式

泰勒公式:

f ( x ) = f ( x 0 ) + f ′ ( x 0 ) ( x − x 0 ) + f ′ ′ ( x 0 ) 2 ! ( x − x 0 ) 2 + ⋯ + f ( n ) ( x 0 ) n ! ( x − x 0 ) n + R n + 1 ( x ) f(x)=f(x_0)+f'(x_0)(x-x_0)+\frac{f''(x_0)}{2!}(x-x_0)^2+\dotsb +\frac{f^{(n)}(x_0)}{n!}(x-x_0)^n+R_{n+1}(x) f(x)=f(x0)+f(x0)(xx0)+2!f′′(x0)(xx0)2++n!f(n)(x0)(xx0)n+Rn+1(x)

其中 R R R 为误差。

那么当 x 0 = 0 x_0=0 x0=0 时,得到麦克劳林公式:

f ( x ) = f ( 0 ) + f ′ ( 0 ) x + f ′ ′ ( 0 ) 2 ! x 2 + ⋯ + f ( n ) ( 0 ) n ! x n + R n + 1 ( x ) f(x)=f(0)+f'(0)x+\frac{f''(0)}{2!}x^2+\dotsb +\frac{f^{(n)}(0)}{n!}x^n+R_{n+1}(x) f(x)=f(0)+f(0)x+2!f′′(0)x2++n!f(n)(0)xn+Rn+1(x)

所以我们就有了以下几个展开式:

{ e x = 1 + x + x 2 2 ! + x 3 3 ! + ⋯ + x n n ! + ⋯ ln ⁡ ( 1 + x ) = x − x 2 2 + x 3 3 + ⋯ + ( − 1 ) n − 1 x n n + ⋯ sin ⁡ x = ∑ k = 0 ∞ ( − 1 ) k x 2 k + 1 ( 2 k + 1 ) ! cos ⁡ x = ∑ k = 0 ∞ ( − 1 ) k x 2 k ( 2 k ) ! } \begin{Bmatrix} e^x=1+x+\frac{x^2}{2!}+\frac{x^3}{3!}+\dotsb+\frac{x^n}{n!}+\dotsb \\ \ln(1+x)=x-\frac{x^2}{2}+\frac{x^3}{3}+\dotsb+(-1)^{n-1}\frac{x^n}{n}+\dotsb \\ \sin x=\sum_{k=0}^{\infty}(-1)^k\frac{x^{2k+1}}{(2k+1)!} \\ \cos x=\sum_{k=0}^{\infty}(-1)^k\frac{x^{2k}}{(2k)!} \end{Bmatrix} ex=1+x+2!x2+3!x3++n!xn+ln(1+x)=x2x2+3x3++(1)n1nxn+sinx=k=0(1)k(2k+1)!x2k+1cosx=k=0(1)k(2k)!x2k

欧拉公式

接上文,展开 e i x e^{ix} eix,得:
e i x = 1 + i x − x 2 2 ! − i x 3 3 ! + x 4 4 ! + i x 5 5 ! − x 6 6 ! − i x 7 7 ! + ⋯ ) e^{ix}=1+ix-\frac{x^2}{2!}-i\frac{x^3}{3!}+\frac{x^4}{4!}+i\frac{x^5}{5!}-\frac{x^6}{6!}-i\frac{x^7}{7!}+\dotsb) eix=1+ix2!x2i3!x3+4!x4+i5!x56!x6i7!x7+)
e i x = ( 1 − x 2 2 ! + x 4 4 ! − x 6 6 ! + ⋯ ) + i ( x − x 3 3 ! + x 5 5 ! − 7 3 7 ! + ⋯ ) e^{ix}=(1-\frac{x^2}{2!}+\frac{x^4}{4!}-\frac{x^6}{6!}+\dotsb) +i(x-\frac{x^3}{3!}+\frac{x^5}{5!}-\frac{7^3}{7!}+\dotsb) eix=(12!x2+4!x46!x6+)+i(x3!x3+5!x57!73+)

e i x = cos ⁡ x + i sin ⁡ x e^{ix}=\cos x+i\sin x eix=cosx+isinx

x = π x=\pi x=π 带入:

e i π = cos ⁡ π + i sin ⁡ π = − 1 e^{i\pi}=\cos \pi + i\sin \pi=-1 e=cosπ+isinπ=1

所以欧拉恒等式出来:

e i π + 1 = 0 e^{i\pi}+1=0 e+1=0

单位根

n n n 为正整数,若 x n = 1 x^n=1 xn=1 ,则 x x x n n n 次单位根。

下文默认 n = 2 m , m n=2^m,m n=2m,m为正整数。

根据上文的欧拉公式,我们可知 e 2 k π i = cos ⁡ 2 k π + i sin ⁡ 2 k π = 1 e^{2k \pi i}=\cos 2k\pi+i\sin 2k\pi=1 e2kπi=cos2+isin2=1,故 n n n 次单位根分别是: e 2 k π i n = cos ⁡ 2 k π n + i sin ⁡ 2 k π n , ( k = 0 , 1 , 2 , … , n − 1 ) e^{\frac{2k\pi i}{n}}=\cos \frac{2k\pi}{n}+i\sin \frac{2k\pi}{n},(k=0,1,2,\dots,n-1) en2kπi=cosn2+isinn2,(k=0,1,2,,n1)

接上文复数的知识,每个单位根在复平面上的坐标为 ( cos ⁡ 2 k π n , sin ⁡ 2 k π n ) (\cos \frac{2k\pi}{n},\sin \frac{2k\pi}{n}) (cosn2,sinn2)
如图:

在一个标准复平面坐标系上,以 1 1 1 为半径画一个圆, n n n次单位根可以想象为把这个圆平分为 n n n 分中每一个点。

我们用 ω n 1 , ω n 2 , ω n 3 , … , ω n n \omega_n^1,\omega_n^2,\omega_n^3,\dots,\omega_n^n ωn1,ωn2,ωn3,,ωnn 来表示 n n n 次单位根的每一个根,及方程的每一个解。

所以有 ω n k = cos ⁡ k 2 π n + i sin ⁡ k 2 π n \omega_n^k=\cos k\frac{2\pi}{n}+i\sin k\frac{2\pi}{n} ωnk=coskn2π+isinkn2π

如当 n = 4 n=4 n=4时, ω 4 = 1 , − 1 , i , − 1 \omega_4=1,-1,i,-1 ω4=1,1,i,1

如当 n = 1 n=1 n=1 时, ω 1 = 1 \omega_1=1 ω1=1

单位根的性质:

ω 2 n 2 k = ω n k = − ω n k + n 2 \omega_{2n}^{2k}=\omega_{n}^{k}=-\omega _n^{k+\frac{n}{2}} ω2n2k=ωnk=ωnk+2n

ω n 0 = ω n n = 1 \omega_n^0=\omega_n^n=1 ωn0=ωnn=1

ω 2 n 2 k = cos ⁡ 2 k 2 π 2 n + i sin ⁡ 2 k 2 π 2 n = ω n k \omega_{2n}^{2k}=\cos 2k \frac{2\pi}{2n}+i\sin 2k \frac{2\pi}{2n}=\omega_n^k ω2n2k=cos2k2n2π+isin2k2n2π=ωnk

ω n n 2 = cos ⁡ n 2 ⋅ 2 π n + i sin ⁡ n 2 ⋅ 2 π n = cos ⁡ π + i sin ⁡ π = − 1 \omega_n^{\frac{n}{2}}=\cos \frac{n}{2}\cdot \frac{2\pi}{n}+i\sin \frac{n}{2}\cdot \frac{2\pi}{n}=\cos \pi+i\sin \pi=-1 ωn2n=cos2nn2π+isin2nn2π=cosπ+isinπ=1

FFT

n n n 为偶数, k < n 2 k<\frac{n}{2} k<2n

A ( x ) = a 0 + a 1 x + a 2 x 2 + a 3 x 3 + ⋯ + a n − 1 x n − 1 A(x)=a_{0}+a_{1}x+a_{2}x^2+a_{3}x^3+\dots+a_{n-1}x^{n-1} A(x)=a0+a1x+a2x2+a3x3++an1xn1
A 1 ( x ) = a 0 + a 2 x + a 4 x 2 + ⋯ + a n − 2 x n 2 − 1 A_1(x)=a_0+a_2x+a_4x^2+\cdots+a_{n-2}x^{\frac{n}{2}-1} A1(x)=a0+a2x+a4x2++an2x2n1
A 2 ( x ) = a 1 + a 3 x + a 5 x 2 + ⋯ + a n − 1 x n 2 − 1 A_2(x)=a_1+a_3x+a_5x^2+\cdots+a_{n-1}x^{\frac{n}{2}-1} A2(x)=a1+a3x+a5x2++an1x2n1
所以有:
A ( x ) = A 1 ( x 2 ) + x A 2 ( x 2 ) A(x)=A_1(x^2)+xA_2(x^2) A(x)=A1(x2)+xA2(x2)
A ( ω n k ) = A 1 ( ω n 2 k ) + ω n k A 2 ( ω n 2 k ) A(\omega_n^k)=A_1(\omega_n^{2k})+\omega_n^kA_2(\omega_n^{2k}) A(ωnk)=A1(ωn2k)+ωnkA2(ωn2k)
A ( ω n k + n 2 ) = A 1 ( ω n 2 k + n ) + ω n k + n 2 A 2 ( ω n 2 k + n ) = A 1 ( ω n 2 k ) − ω n k A 2 ( ω n 2 k ) A(\omega_n^{k+\frac{n}{2}})=A_1(\omega_n^{2k+n})+\omega_n^{k+\frac{n}{2}}A_2(\omega_n^{2k+n})=A_1(\omega_n^{2k})-\omega_n^kA_2(\omega_n^{2k}) A(ωnk+2n)=A1(ωn2k+n)+ωnk+2nA2(ωn2k+n)=A1(ωn2k)ωnkA2(ωn2k)

发现了什么?没错,只有后面一坨是相反的,这说明我们可以 O ( 1 ) O(1) O(1) 通过第一个式子得出第二个式子

所以 k k k 只要枚举前 n 2 \frac{n}{2} 2n 个数就可以了,问题缩小了一半,而缩小后还能继续缩小,所以我们用类似线段树的分治(递归)来解决它,时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn)

Code

void fft(int limit,complex *a,int type)
{if(limit==1) return ;complex a1[limit>>1],a2[limit>>1];for(int i=0;i<=limit;i+=2)a1[i>>1]=a[i],a2[i>>1]=a[i+1];fft(limit>>1,a1,type);fft(limit>>1,a2,type);complex Wn=complex(cos(2.0*Pi/limit),type*sin(2.0*Pi/limit)),w=complex(1,0);for(int i=0;i<(limit>>1);i++,w=w*Wn)a[i]=a1[i]+w*a2[i],a[i+(limit>>1)]=a1[i]-w*a2[i];
}

IFFT

但是光有点值还是不够的,我们还要转换为数值,这就是 IFFT。
至于还有一个迭代优化。
我们下篇博客再讲。

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

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

相关文章

智能优化算法应用:基于蝴蝶算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于蝴蝶算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于蝴蝶算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.蝴蝶算法4.实验参数设定5.算法结果6.参考文献7.MATLAB…

简易版扫雷+代码分析

前言&#xff1a; 实验一个简易版的扫雷&#xff0c;也要两百来行的代码&#xff0c;因此为了代码整洁&#xff0c;维护起来方便&#xff0c;这里我们和前期实现的三子棋一样&#xff0c;也弄一个游戏的头文件game.h用来装各种头文件以及函数的声明以及宏定义、预处理信息&…

windows的bat文件(学习笔记)

简介 通过windows的cmd执行的批处理&#xff0c;扩展名可以是.bat或.cmd&#xff08;类似linux的shell脚本&#xff09; 所有语句符号不区分大小写 帮助提示信息&#xff1a;命令 /? 1 基本语法 (1) 注释&#xff1a;rem 注释文本不执行 (2) 关闭盘符输出&#xff1a;e…

最新AI创作系统ChatGPT网站运营源码、支持GPT-4-Turbo模型,图片对话识图理解,支持DALL-E3文生图

一、AI创作系统 SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作ChatGPT&#xff1f;小编这里写一个详细图文教程吧&#xff01;本系统使用NestjsVueTypescript框架技术&#xff0c;持续集成AI能力到本系统。支持OpenAI DALL-E3文生图&#xff0c;…

技术面时,一定要掌握这3个关键点

前言 现在有这么多优秀的测试工程师&#xff0c;大家都知道技术面试是不可避免的一个环节&#xff0c;一般技术面试官都会通过自己的方式去考察你的技术功底与基础理论知识。 如果你参加过一些大厂面试&#xff0c;肯定会遇到一些这样的问题&#xff1a; 1、看你项目都用到了…

HttpRunner原来还能这么用,大开眼界!!!

hook机制 Httprunner 框架中的 hook 机制相当于unittest框架中的 setup , teardown 函数&#xff0c;用来进行测试用例执行之前的环境初始化以及测试用例执行完毕之后的环境清理操作。 httprunner 中的 hooks 机制可以用在测试用例层级也可以用在测试步骤层级&#xff0c;其关键…

北邮22级信通院数电:Verilog-FPGA(10)第十周实验 实现移位寄存器74LS595(仿真方法验证)

北邮22信通一枚~ 跟随课程进度更新北邮信通院数字系统设计的笔记、代码和文章 持续关注作者 迎接数电实验学习~ 获取更多文章&#xff0c;请访问专栏&#xff1a; 北邮22级信通院数电实验_青山如墨雨如画的博客-CSDN博客 使用FPGA开发板验证的教程&#xff0c;请参考 北邮…

数据在内存中的存储练习题

数据在内存中的存储练习题 文章目录 数据在内存中的存储练习题1. 练习一2.练习二3. 练习三4. 练习四5. 练习五6. 练习六7. 总结 1. 练习一 #include <stdio.h>int main() {char a -1;signed b -1;unsigned char c -1;printf("a %d b %d c %d", a, b, c)…

MySQL InnoDB 引擎底层解析(二)

6.2.InnoDB 的表空间 表空间是一个抽象的概念&#xff0c;对于系统表空间来说&#xff0c;对应着文件系统中一个或多个实际文件&#xff1b;对于每个独立表空间来说&#xff0c;对应着文件系统中一个名为表名.ibd 的实际文件。大家可以把表空间想象成被切分为许许多多个页的池…

华为云IoT与OpenHarmony深度协同,加速设备上鸿即上云【云驻共创】

本次专题论坛探讨了华为云IoT与Open Harmony的深度协同、边缘屏蔽硬件差异、实现智慧隧道全方位智能化管理&#xff0c;以及华为云与Open Harmony生态的合作。同时也介绍了华为云物联网卡平台、HTTP2协议以及华为物联网在交通领域的应用。 一&#xff0e;华为云IoT与Open Harm…

Interactive Visual Data Analysis

Words&Contents Home | Interactive Visual Data Analysis Book Outline 这本书对视觉、互动和分析方法进行了系统而全面的概述&#xff0c;作为数据可视化方面比较好的读物&#xff1b; 目录 Words&Contents Book Outline &#xff08;一&#xff09;Introduct…

Jina AI 的 8K 向量模型上线 AWS Marketplace,支持本地部署!

在当前多模态 AI 和大模型技术风头正劲的背景下&#xff0c;Jina AI 始终领跑于创新前沿&#xff0c;技术领先。2023 年 10 月 30 日&#xff0c;Jina AI 隆重推出 jina-embeddings-v2&#xff0c;这是全球首款支持 8192 输入长度的开源向量大模型&#xff0c;其性能媲美 OpenA…

【uni-app】uniapp中弹出输入框的示例

uni.showModal({title: 请输入企业名称,content: ,editable: true, //是否显示输入框placeholderText: 请输入企业名称, //输入框提示内容confirmText: 确认,cancelText: 取消,success: (res) > {if (res.confirm) {this.checkDesc.name res.content;// console.log(输入的…

vue3(二)-基础入门之列表循环、数组变动检测、filter模糊查询、事件修饰符

一、列表循环 of 和 in 都是一样的效果 html代码&#xff1a; <div id"app"><ul><li v-for"item of datalist">{{ item }}</li></ul><ul><li v-for"item in dataobj">{{ item }}</li></u…

Java游戏 王者荣耀

GameFrame类 所需图片&#xff1a; package 王者荣耀;import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyAdapter; import java.awt.event.KeyEvent; import java.io.File; import java.util.ArrayList…

关于elementui和ant design vue无法禁止浏览器自动填充问题

以and design vue 为例&#xff1a; 图标用来显隐账号密码 html&#xff1a; <a-form-model-item label"账号密码:" prop"password"><a-input v-if"passwordTab" ref"passwordInput" v-model"form.password" typ…

数据结构算法-贪心算法

引言 贪心&#xff1a;人只要有 “需求“ &#xff0c;都会有有点“贪“&#xff0c; 这种“贪“是一种选择&#xff0c;或者“”取舍“ RTS&#xff08;即时战略&#xff09;游戏&#xff1a; 帝国时代里 首先确保拥有足够的人口 足够的粮食&#xff0c;足够的战略资源 足够的…

MicroPython STM32F4 RTC功能使用介绍

MicroPython STM32F4 RTC功能使用介绍 &#x1f516;STM32和ESP32 RTC功能差不多&#xff0c;相关篇《MicroPython ESP32 RTC功能使用介绍》&#x1f4cc;固件刷可参考前面一篇《STM32刷Micropython固件参考指南》&#x1f33f; 相关篇《Micropython STM32F4入门点灯》&#x1…

Aapche Dubbo 不安全的 Java 反序列化 (CVE-2019-17564)

漏洞描述 Apache Dubbo 是一个高性能的、基于 Java 的开源 RPC 框架。 Apache Dubbo 支持不同的协议&#xff0c;它的 HTTP 协议处理程序是 Spring Framework 的 .org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter Spring Framework 的安全警告显示&am…

MySQL表连接

文章目录 MySQL内外连接1.内连接2.外连接&#xff08;1&#xff09;左外连接&#xff08;2)右外连接 3.简单案例 MySQL内外连接 1.内连接 内连接的SQL如下&#xff1a; SELECT ... FROM t1 INNER JOIN t2 ON 连接条件 [INNER JOIN t3 ON 连接条件] ... AND 其他条件;说明一下…