知識蒸餾 - 各類概率分布

知識蒸餾 - 各類概率分布

flyfish
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述
請添加圖片描述

一、離散概率分布

離散分布描述的是取值為離散值(如0,1,2,…)的隨機變量的概率規律,通常用概率質量函數(PMF) 表示某一取值的概率。

1. 伯努利分布(Bernoulli Distribution)
  • 定義:描述單次隨機試驗的結果,僅有兩種可能(“成功”或“失敗”),是最簡單的離散分布。
  • 核心參數:成功概率 ppp0≤p≤10 \leq p \leq 10p1),失敗概率為 1?p1-p1?p
  • 概率質量函數(PMF)
    P(X=k)=pk(1?p)1?kP(X=k) = p^k (1-p)^{1-k}P(X=k)=pk(1?p)1?k,其中 k=0k=0k=0(失敗)或 k=1k=1k=1(成功)。
  • 適用場景:單次試驗的二元結果,如“拋一次硬幣是否正面朝上”“一次抽獎是否中獎”。
  • 特點:僅含一次試驗,結果非0即1;是所有離散分布的基礎,多次獨立伯努利試驗可擴展為其他分布(如二項分布)。
2. 二項分布(Binomial Distribution)
  • 定義:描述 nnn 次獨立重復的伯努利試驗中,“成功”次數的概率分布。
  • 核心參數:試驗次數 nnn(正整數)、單次成功概率 ppp0≤p≤10 \leq p \leq 10p1)。
  • 概率質量函數(PMF)
    P(X=k)=(nk)pk(1?p)n?kP(X=k) = \binom{n}{k} p^k (1-p)^{n-k}P(X=k)=(kn?)pk(1?p)n?k,其中 k=0,1,...,nk=0,1,...,nk=0,1,...,n(nk)\binom{n}{k}(kn?) 為組合數(從n次中選k次成功的方式數)。
  • 適用場景:多次獨立試驗的成功次數,如“拋10次硬幣正面朝上的次數”“100件產品中不合格品的數量”。
  • 特點:試驗獨立且每次成功概率相同;當 n=1n=1n=1 時,退化為伯努利分布;均值為 npnpnp,方差為 np(1?p)np(1-p)np(1?p)
3. 泊松分布(Poisson Distribution)
  • 定義:描述“一定時間/空間內,某隨機事件發生次數”的概率分布。
  • 核心參數:發生率 λ\lambdaλλ>0\lambda > 0λ>0,表示單位時間/空間內事件的平均發生次數)。
  • 概率質量函數(PMF)
    P(X=k)=λke?λk!P(X=k) = \frac{\lambda^k e^{-\lambda}}{k!}P(X=k)=k!λke?λ?,其中 k=0,1,2,...k=0,1,2,...k=0,1,2,...(事件發生次數),eee 為自然常數,k!k!k! 為k的階乘。
  • 適用場景:稀有事件的發生次數,如“1小時內客服接到的電話次數”“1平方米布料上的瑕疵數”“一天內醫院的急診人數”。
  • 特點:事件獨立發生,且發生率恒定;均值和方差均為 λ\lambdaλ;當二項分布中 nnn 很大、ppp 很小時(np≈λnp \approx \lambdanpλ),可近似為泊松分布。
4. 幾何分布(Geometric Distribution)
  • 定義:描述“在一系列獨立伯努利試驗中,首次獲得成功所需要的試驗次數”的概率分布。
  • 核心參數:單次試驗成功概率 ppp0<p≤10 < p \leq 10<p1)。
  • 概率質量函數(PMF)
    P(X=k)=(1?p)k?1pP(X=k) = (1-p)^{k-1} pP(X=k)=(1?p)k?1p,其中 k=1,2,...k=1,2,...k=1,2,...(首次成功時的試驗次數,至少為1)。
  • 適用場景:首次成功前的試驗次數,如“首次命中目標前的射擊次數”“首次抽到紅球前的抽獎次數”。
  • 特點:無記憶性(即“前k次失敗不影響后續成功的概率”);均值為 1/p1/p1/p(平均需要 1/p1/p1/p 次試驗才能首次成功),方差為 (1?p)/p2(1-p)/p^2(1?p)/p2
5. 負二項分布(Negative Binomial Distribution)
  • 定義:描述“在一系列獨立伯努利試驗中,獲得第 rrr 次成功時所需要的總試驗次數”的概率分布(幾何分布是其 r=1r=1r=1 時的特例)。
  • 核心參數:目標成功次數 rrr(正整數)、單次試驗成功概率 ppp0<p≤10 < p \leq 10<p1)。
  • 概率質量函數(PMF)
    P(X=k)=(k?1r?1)pr(1?p)k?rP(X=k) = \binom{k-1}{r-1} p^r (1-p)^{k-r}P(X=k)=(r?1k?1?)pr(1?p)k?r,其中 k=r,r+1,...k=r,r+1,...k=r,r+1,...(總試驗次數,至少為 rrr)。
  • 適用場景:需要多次成功的試驗次數,如“第5次命中目標時的總射擊次數”“第3次賣出產品時的總客戶接待數”。
  • 特點:可視為 rrr 個獨立幾何分布的和;均值為 r/pr/pr/p,方差為 r(1?p)/p2r(1-p)/p^2r(1?p)/p2

二、連續概率分布

連續分布描述的是取值為連續區間(如實數域)的隨機變量的概率規律,通常用概率密度函數(PDF) 表示某一區間內的概率密度(需通過積分計算區間概率)。

6. 均勻分布(Uniform Distribution)
  • 定義:描述“隨機變量在區間 ([a,b]) 內所有取值的概率密度均相等”的分布。
  • 核心參數:區間下界 aaa 和上界 bbba<ba < ba<b)。
  • 概率密度函數(PDF)
    f(x)={1b?a若?a≤x≤b0其他 f(x) = \begin{cases} \frac{1}{b-a} & \text{若 } a \leq x \leq b \\ 0 & \text{其他} \end{cases} f(x)={b?a1?0??axb其他?
  • 適用場景:等可能結果的連續取值,如“隨機選擇的時間點在[0,24小時]內的分布”“隨機測量的誤差在[-0.5,0.5]內的分布”。
  • 特點:概率密度恒定(矩形分布);均值為 (a+b)/2(a+b)/2(a+b)/2,方差為 (b?a)2/12(b-a)^2/12(b?a)2/12;區間內任意子區間的概率與子區間長度成正比。
7. 正態分布(Normal Distribution)
  • 定義:又稱“高斯分布”,是自然界最常見的連續分布,呈對稱的鐘形曲線。
  • 核心參數:均值 μ\muμ(曲線中心位置)、標準差 σ\sigmaσ(曲線寬窄,σ>0\sigma > 0σ>0)。
  • 概率密度函數(PDF)
    f(x)=1σ2πe?(x?μ)22σ2f(x) = \frac{1}{\sigma \sqrt{2\pi}} e^{-\frac{(x-\mu)^2}{2\sigma^2}}f(x)=σ2π?1?e?2σ2(x?μ)2?,其中 xxx 為任意實數,eee 為自然常數。
  • 適用場景:大量獨立隨機因素影響的結果,如“人群身高/體重分布”“測量誤差分布”“考試分數分布”。
  • 特點:對稱性(關于 x=μx=\mux=μ 對稱);“3σ法則”(約99.7%的取值落在 [μ?3σ,μ+3σ][\mu-3\sigma, \mu+3\sigma][μ?3σ,μ+3σ] 內);中心極限定理表明,大量獨立隨機變量的和近似服從正態分布;標準正態分布(μ=0,σ=1\mu=0, \sigma=1μ=0,σ=1)是基礎,可通過標準化轉換(Z=(X?μ)/σZ=(X-\mu)/\sigmaZ=(X?μ)/σ)將任意正態分布轉化為標準正態分布。
8. 指數分布(Exponential Distribution)
  • 定義:描述“兩次獨立隨機事件發生的時間間隔”的概率分布(與泊松分布對應:泊松分布描述事件發生次數,指數分布描述事件間隔時間)。
  • 核心參數:率參數 λ\lambdaλλ>0\lambda > 0λ>0,表示單位時間內事件的平均發生次數,與泊松分布的 λ\lambdaλ 一致)。
  • 概率密度函數(PDF)
    f(x)={λe?λx若?x≥00若?x<0 f(x) = \begin{cases} \lambda e^{-\lambda x} & \text{若 } x \geq 0 \\ 0 & \text{若 } x < 0 \end{cases} f(x)={λe?λx0??x0?x<0?
  • 適用場景:事件間隔時間,如“兩次設備故障的時間間隔”“兩次客戶到達的時間間隔”“電池壽命”。
  • 特點:無記憶性(即“已使用t小時的設備,剩余壽命與新設備相同”);均值為 1/λ1/\lambda1/λ(平均間隔時間),方差為 1/λ21/\lambda^21/λ2;取值范圍為非負實數。
9. 伽瑪分布(Gamma Distribution)
  • 定義:描述“多個獨立指數分布變量的總和”的概率分布(指數分布是其形狀參數 a=1a=1a=1 時的特例)。
  • 核心參數:形狀參數 aaaa>0a > 0a>0,可理解為“事件次數”)、率參數 β\betaββ>0\beta > 0β>0,與指數分布的 λ\lambdaλ 類似)。
  • 概率密度函數(PDF)
    f(x)={βaΓ(a)xa?1e?βx若?x≥00若?x<0 f(x) = \begin{cases} \frac{\beta^a}{\Gamma(a)} x^{a-1} e^{-\beta x} & \text{若 } x \geq 0 \\ 0 & \text{若 } x < 0 \end{cases} f(x)={Γ(a)βa?xa?1e?βx0??x0?x<0?
    其中 Γ(a)\Gamma(a)Γ(a) 為伽瑪函數(當 aaa 為整數時,Γ(a)=(a?1)!\Gamma(a)=(a-1)!Γ(a)=(a?1)!)。
  • 適用場景:多個事件間隔的總和,如“3次電話呼叫的總時間”“5個零件的總壽命”;當 aaa 為整數時,也稱為“愛爾朗分布”(Erlang Distribution),常用于排隊論。
  • 特點:形狀隨 aaa 變化(aaa 增大時逐漸接近正態分布);均值為 a/βa/\betaa/β,方差為 a/β2a/\beta^2a/β2
10. 卡方分布(Chi-Squared Distribution)
  • 定義:描述“k個獨立標準正態變量的平方和”的概率分布(是伽瑪分布的特例:當形狀參數 a=k/2a=k/2a=k/2、率參數 β=1/2\beta=1/2β=1/2 時)。
  • 核心參數:自由度 kkk(正整數,對應標準正態變量的個數)。
  • 概率密度函數(PDF)
    f(x)={12k/2Γ(k/2)x(k/2)?1e?x/2若?x≥00若?x<0 f(x) = \begin{cases} \frac{1}{2^{k/2} \Gamma(k/2)} x^{(k/2)-1} e^{-x/2} & \text{若 } x \geq 0 \\ 0 & \text{若 } x < 0 \end{cases} f(x)={2k/2Γ(k/2)1?x(k/2)?1e?x/20??x0?x<0?
  • 適用場景:統計檢驗中,如“方差的假設檢驗”“擬合優度檢驗”“獨立性檢驗”;是t分布和F分布的基礎。
  • 特點:取值非負,右偏分布(隨 kkk 增大逐漸對稱);均值為 kkk,方差為 2k2k2k;若 X~χ2(k1)X \sim \chi^2(k_1)Xχ2(k1?)Y~χ2(k2)Y \sim \chi^2(k_2)Yχ2(k2?),則 X+Y~χ2(k1+k2)X+Y \sim \chi^2(k_1+k_2)X+Yχ2(k1?+k2?)(可加性)。
11. t分布(t-Distribution)
  • 定義:描述“小樣本均值標準化后”的概率分布,當總體標準差未知時,用樣本標準差替代后推導得到。
  • 核心參數:自由度 vvv(正整數,通常為樣本量減1,v=n?1v = n-1v=n?1)。
  • 概率密度函數(PDF)
    f(x)=Γ((v+1)/2)vπΓ(v/2)(1+x2v)?(v+1)/2f(x) = \frac{\Gamma((v+1)/2)}{\sqrt{v\pi} \Gamma(v/2)} \left(1 + \frac{x^2}{v}\right)^{-(v+1)/2}f(x)=vπ?Γ(v/2)Γ((v+1)/2)?(1+vx2?)?(v+1)/2,其中 xxx 為任意實數。
  • 適用場景:小樣本(n<30n < 30n<30)的均值檢驗,如“小樣本下總體均值的區間估計”“單樣本t檢驗”“兩獨立樣本t檢驗”。
  • 特點:形狀類似正態分布,但尾部更厚(對極端值更敏感);隨自由度 vvv 增大,逐漸接近標準正態分布(v→∞v \to \inftyv 時完全一致);均值為0(v>1v > 1v>1 時),方差為 v/(v?2)v/(v-2)v/(v?2)v>2v > 2v>2 時)。
12. F分布(F-Distribution)
  • 定義:描述“兩個獨立卡方分布變量分別除以各自自由度后的比值”的概率分布。
  • 核心參數:分子自由度 d1d_1d1? 和分母自由度 d2d_2d2?(均為正整數)。
  • 概率密度函數(PDF)
    f(x)={Γ((d1+d2)/2)Γ(d1/2)Γ(d2/2)(d1d2)d1/2x(d1/2)?1(1+d1d2x)?(d1+d2)/2若?x≥00若?x<0 f(x) = \begin{cases} \frac{\Gamma((d_1+d_2)/2)}{\Gamma(d_1/2)\Gamma(d_2/2)} \left(\frac{d_1}{d_2}\right)^{d_1/2} x^{(d_1/2)-1} \left(1 + \frac{d_1}{d_2}x\right)^{-(d_1+d_2)/2} & \text{若 } x \geq 0 \\ 0 & \text{若 } x < 0 \end{cases} f(x)=????Γ(d1?/2)Γ(d2?/2)Γ((d1?+d2?)/2)?(d2?d1??)d1?/2x(d1?/2)?1(1+d2?d1??x)?(d1?+d2?)/20??x0?x<0?
  • 適用場景:方差比較,如“方差分析(ANOVA)”(檢驗多組均值是否有差異)、“兩總體方差比的假設檢驗”。
  • 特點:取值非負,右偏分布;形狀由兩個自由度共同決定;若 F~F(d1,d2)F \sim F(d_1,d_2)FF(d1?,d2?),則 1/F~F(d2,d1)1/F \sim F(d_2,d_1)1/FF(d2?,d1?)(倒數性質)。
import numpy as np
import matplotlib.pyplot as plt
from scipy import stats# 設置中文顯示
#plt.rcParams["font.family"] = ["SimHei"]
plt.rcParams["font.family"] = ['AR PL UMing CN']#Linux
plt.rcParams["axes.unicode_minus"] = False  # 解決負號顯示問題def save_distribution_plot(plot_func, params, title_cn, title_en, x_label, y_label,filename_cn, filename_en, params_str, is_discrete=True):"""生成并保存分布圖像的通用函數(不含公式)"""plt.figure(figsize=(10, 7))plot_func(*params)# 標題組合中英文plt.title(f"{title_cn}\n{title_en}", fontsize=14)# 設置軸標簽plt.xlabel(x_label, fontsize=12)plt.ylabel(y_label, fontsize=12)plt.grid(alpha=0.3)plt.tight_layout()  # 緊湊布局,無需為公式預留空間# 生成包含中英文的文件名filename = f"{filename_cn}_{filename_en}_{params_str}.jpg"plt.savefig(filename, dpi=300, bbox_inches='tight')plt.close()# 1. 伯努利分布
def plot_bernoulli():x = [0, 1]p = 0.6pmf = [1 - p, p]plt.bar(x, pmf, color='skyblue', width=0.5)plt.xticks(x)plt.ylim(0, 1.1)return pp = plot_bernoulli()
save_distribution_plot(plot_bernoulli, [], f'伯努利分布 (p={p})', f'Bernoulli Distribution (p={p})','隨機變量值 (Random Variable Value)', '概率 (Probability)','伯努利分布', 'bernoulli', f'p{p}', True
)# 2. 二項分布
def plot_binomial():n, p = 10, 0.4x = np.arange(0, n + 1)pmf = stats.binom.pmf(x, n, p)plt.bar(x, pmf, color='salmon', width=0.6)plt.ylim(0, 0.35)return n, pn, p = plot_binomial()
save_distribution_plot(plot_binomial, [], f'二項分布 (n={n}, p={p})', f'Binomial Distribution (n={n}, p={p})','成功次數 (Number of Successes)', '概率 (Probability)','二項分布', 'binomial', f'n{n}_p{p}', True
)# 3. 泊松分布
def plot_poisson():lambda_p = 4x = np.arange(0, 16)pmf = stats.poisson.pmf(x, lambda_p)plt.bar(x, pmf, color='lightgreen', width=0.7)plt.ylim(0, 0.25)return lambda_plambda_p = plot_poisson()
save_distribution_plot(plot_poisson, [], f'泊松分布 (λ={lambda_p})', f'Poisson Distribution (λ={lambda_p})','事件發生次數 (Number of Occurrences)', '概率 (Probability)','泊松分布', 'poisson', f'lambda{lambda_p}', True
)# 4. 幾何分布
def plot_geometric():p = 0.3x = np.arange(1, 11)pmf = stats.geom.pmf(x, p)plt.bar(x, pmf, color='purple', width=0.6)plt.ylim(0, 0.35)return pp = plot_geometric()
save_distribution_plot(plot_geometric, [], f'幾何分布 (p={p})', f'Geometric Distribution (p={p})','首次成功前的試驗次數 (Trials Until First Success)', '概率 (Probability)','幾何分布', 'geometric', f'p{p}', True
)# 5. 負二項分布
def plot_negative_binomial():r, p = 5, 0.6x = np.arange(5, 16)pmf = stats.nbinom.pmf(x - r, r, p)plt.bar(x, pmf, color='orange', width=0.7)plt.ylim(0, 0.25)return r, pr, p = plot_negative_binomial()
save_distribution_plot(plot_negative_binomial, [], f'負二項分布 (r={r}, p={p})', f'Negative Binomial Distribution (r={r}, p={p})','第r次成功時的試驗次數 (Trials Until r-th Success)', '概率 (Probability)','負二項分布', 'negative_binomial', f'r{r}_p{p}', True
)# 6. 均勻分布
def plot_uniform():a, b = 2, 8x = np.linspace(a - 1, b + 1, 1000)pdf = stats.uniform.pdf(x, loc=a, scale=b - a)plt.plot(x, pdf, color='red')plt.fill_between(x, pdf, alpha=0.3, color='red')plt.ylim(0, 0.2)return a, ba, b = plot_uniform()
save_distribution_plot(plot_uniform, [], f'均勻分布 (a={a}, b={b})', f'Uniform Distribution (a={a}, b={b})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','均勻分布', 'uniform', f'a{a}_b{b}', False
)# 7. 正態分布
def plot_normal():mu, sigma = 0, 2x = np.linspace(mu - 4*sigma, mu + 4*sigma, 1000)pdf = stats.norm.pdf(x, mu, sigma)plt.plot(x, pdf, color='blue')plt.fill_between(x, pdf, alpha=0.3, color='blue')plt.ylim(0, 0.25)return mu, sigmamu, sigma = plot_normal()
save_distribution_plot(plot_normal, [], f'正態分布 (μ={mu}, σ={sigma})', f'Normal Distribution (μ={mu}, σ={sigma})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','正態分布', 'normal', f'mu{mu}_sigma{sigma}', False
)# 8. 指數分布
def plot_exponential():lambda_exp = 0.5x = np.linspace(0, 6, 1000)pdf = stats.expon.pdf(x, scale=1/lambda_exp)plt.plot(x, pdf, color='green')plt.fill_between(x, pdf, alpha=0.3, color='green')plt.ylim(0, 0.6)return lambda_explambda_exp = plot_exponential()
save_distribution_plot(plot_exponential, [], f'指數分布 (λ={lambda_exp})', f'Exponential Distribution (λ={lambda_exp})','時間間隔 (Time Interval)', '概率密度 (Probability Density)','指數分布', 'exponential', f'lambda{lambda_exp}', False
)# 9. 伽瑪分布
def plot_gamma():a, beta = 2, 1x = np.linspace(0, 6, 1000)pdf = stats.gamma.pdf(x, a, scale=1/beta)plt.plot(x, pdf, color='brown')plt.fill_between(x, pdf, alpha=0.3, color='brown')plt.ylim(0, 1.0)return a, betaa, beta = plot_gamma()
save_distribution_plot(plot_gamma, [], f'伽瑪分布 (a={a}, β={beta})', f'Gamma Distribution (a={a}, β={beta})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','伽瑪分布', 'gamma', f'a{a}_beta{beta}', False
)# 10. 卡方分布
def plot_chi2():k = 3x = np.linspace(0, 15, 1000)pdf = stats.chi2.pdf(x, k)plt.plot(x, pdf, color='cyan')plt.fill_between(x, pdf, alpha=0.3, color='cyan')plt.ylim(0, 0.7)return kk = plot_chi2()
save_distribution_plot(plot_chi2, [], f'卡方分布 (k={k})', f'Chi-squared Distribution (k={k})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','卡方分布', 'chi2', f'k{k}', False
)# 11. t分布
def plot_t():v = 5x = np.linspace(-5, 5, 1000)pdf = stats.t.pdf(x, v)plt.plot(x, pdf, color='magenta')plt.fill_between(x, pdf, alpha=0.3, color='magenta')plt.ylim(0, 0.4)return vv = plot_t()
save_distribution_plot(plot_t, [], f't分布 (v={v})', f't-Distribution (v={v})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','t分布', 't_distribution', f'v{v}', False
)# 12. F分布
def plot_f():d1, d2 = 5, 10x = np.linspace(0, 4, 1000)pdf = stats.f.pdf(x, d1, d2)plt.plot(x, pdf, color='gray')plt.fill_between(x, pdf, alpha=0.3, color='gray')plt.ylim(0, 1.0)return d1, d2d1, d2 = plot_f()
save_distribution_plot(plot_f, [], f'F分布 (d1={d1}, d2={d2})', f'F-Distribution (d1={d1}, d2={d2})','隨機變量值 (Random Variable Value)', '概率密度 (Probability Density)','F分布', 'f_distribution', f'd1{d1}_d2{d2}', False
)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/94043.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/94043.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/94043.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

軟件測試-Selenium學習筆記

""" 目標&#xff1a; driver.find_element() 需求&#xff1a; 1. 使用driver.find_element()方法 2. 輸入用戶名&#xff1a;admin 3. 輸入密碼&#xff1a;123456 """ # 導包 from selenium import webdriver from time import …

知微傳感3D相機上位機DkamViewer使用:給相機升級固件

寫在前面 本人從事機器視覺細分的3D相機行業。編寫此系列文章主要目的有&#xff1a; 1、便利他人應用相機&#xff0c;本系列文章包含公司所出售相機的SDK的使用例程及詳細注釋&#xff1b;2、促進行業發展及交流。 知微傳感Dkam系列3D相機可以應用于定位分揀、焊接焊縫提取、…

CMake進階: CMake Modules---簡化CMake配置的利器

目錄 1.簡介 2.為什么需要 CMake Modules&#xff1f; 3.內置模塊&#xff1a;開箱即用的工具 3.1.依賴查找模塊&#xff08;FindXXX.cmake&#xff09; 3.2.功能檢測模塊&#xff08;CheckXXX.cmake&#xff09; 3.3.通用工具模塊&#xff08;如 FetchContent.cmake、CT…

【Docker】Ubuntu上安裝Docker(網絡版)

【Docker】Ubuntu上安裝Docker注意&#xff1a;一、環境準備1. 系統要求2. 卸載舊版本二、安裝步驟1.配置倉庫源2.安裝 Docker引擎3.驗證安裝情況三、解決報錯1、檢查網絡連接2、檢查Docker服務狀態3、換源4.重載生效、重啟服務、查看是否配置成功5.驗證解決情況四、權限與配置…

Socket 編程 TCP

TCP 網絡程序 和剛才 UDP 類似. 實現一個簡單的英譯漢的功能。TCP是面向字節流的可靠傳輸&#xff0c;如同前文的管道流&#xff0c;只要是流&#xff0c;它的操作就是文件的寫出與讀入。TCP socket API 詳解下面介紹程序中用到的 socket API,這些函數都在 sys/socket.h 中。so…

使用AWS S3 + Lambda + MediaConvert 實現上傳視頻文件并自動轉碼

前言 最近團隊在做短視頻平臺的技術調研&#xff0c;其中有一個環節便是音視頻開發&#xff0c;即對用戶上傳的視頻進行自適應轉碼。自適應的原理其實就是預先將視頻轉換為幾個常用的分辨率&#xff0c;app端根據用戶手機分辨率拉取相應分辨率的視頻。 目前嘗試了兩種方案&…

QT之QWaitCondition降低cpu占用率,從忙等待到高效同步

在多線程編程中&#xff0c;線程間的同步是一個核心問題。在處理線程等待時&#xff0c;經常會寫出高CPU占用率的代碼&#xff0c;其中最典型的就是使用忙等待&#xff08;busy waiting&#xff09;。本文將詳細介紹如何使用Qt框架中的QWaitCondition類來優雅地解決這一問題&am…

pcl求平面點云的邊界凸包點

基本流程1&#xff0c;讀入點云&#xff0c;并去除無效點2&#xff0c;擬合平面3&#xff0c;去除離平面距離較遠的點4&#xff0c;對點云進行平面投影5&#xff0c;進行convex_hull運算初學者&#xff0c;暫時不知道能用來干嘛。練手還是非常不錯的&#xff01;#define _CRT_S…

Windows系統上使用GIT

首先破除一下畏懼心理&#xff1a;在Windows上使用git和在linux系統中的使用方法是一樣的&#xff0c;只是安裝方式沒那么便捷&#xff0c;畢竟linux中安裝git只需要一行命令 GIT下載地址 如果你的電腦的CPU是64位的&#xff0c;就點擊&#xff1a; Git-2.50.1-64-bit.exe 如果…

《設計模式之禪》筆記摘錄 - 17.模板方法模式

模板方法模式的定義模板方法模式(Template Method Pattern)是如此簡單&#xff0c;以致讓你感覺你已經能夠掌握其精髓了。其定義如下&#xff1a;Define the skeleton of an algorithm in an operation, deferring some steps to subclasses.Template Method lets subclasses r…

SpreadJS 協同服務器 MongoDB 數據庫適配支持

為了支持 SpreadJS 協同編輯場景&#xff0c;協同服務器需要持久化存儲文檔、操作、快照及里程碑數據。本文介紹了 MongoDB 數據庫適配器的實現方法&#xff0c;包括集合初始化、適配器接口實現以及里程碑存儲支持。 一、MongoDB 集合初始化 協同編輯服務需要以下集合&#x…

Ubuntu 主機名:精通配置與管理

主機名&#xff08;hostname&#xff09;是Linux系統中用于標識網絡上特定設備的名稱&#xff0c;它在網絡通信、服務配置&#xff08;如 Kubernetes 集群、數據庫&#xff09;以及日志記錄中扮演著至關重要的角色。對于初學者來說&#xff0c;配置主機名似乎很簡單&#xff0c…

C/C++ 協程:Stackful 手動控制的工程必然性

&#x1f680; C/C 協程&#xff1a;Stackful 手動控制的工程必然性 引用&#xff1a; C/C 如何正確的切換協同程序&#xff1f;&#xff08;基于協程的并行架構&#xff09; #mermaid-svg-SXgplRf3WRYc8A7l {font-family:"trebuchet ms",verdana,arial,sans-serif;…

新手向:使用STM32通過RS485通信接口控制步進電機

新手向&#xff1a;使用STM32通過RS485通信接口控制步進電機 準備工作 本文使用的STM32芯片是STM32F407ZGTx&#xff0c;使用的電機是57步進電機&#xff0c;驅動器是用的是時代超群的RS485總線一體化步進電機驅動器&#xff08;42 型&#xff1a;ZD-M42P-485&#xff09;。使…

設計模式筆記_行為型_命令模式

1.命令模式介紹命令模式&#xff08;Command Pattern&#xff09;是一種行為設計模式&#xff0c;它將請求或操作封裝為對象&#xff0c;使得可以用不同的請求對客戶端進行參數化。命令模式的核心思想是將方法調用、請求或操作封裝到一個獨立的命令對象中&#xff0c;從而使得客…

詳解MySQL中的多表查詢:多表查詢分類講解、七種JOIN操作的實現

精選專欄鏈接 &#x1f517; MySQL技術筆記專欄Redis技術筆記專欄大模型搭建專欄Python學習筆記專欄深度學習算法專欄 歡迎訂閱&#xff0c;點贊&#xff0b;關注&#xff0c;每日精進1%&#xff0c;與百萬開發者共攀技術珠峰 更多內容持續更新中&#xff01;希望能給大家帶來…

vue3+elemeent-plus, el-tooltip的樣式修改不生效

修改后的樣式&#xff0c;直接貼圖&#xff0c;經過刪除出現懸浮1、在書寫代碼的時候切記effect“light”&#xff0c;如果你需要的是深色的樣式:disabled"!multiple" 是否禁用<el-tooltip effect"light" placement"top" content"請先選…

網頁作品驚艷亮相!這個浪浪山小妖怪網站太治愈了!

大家好呀&#xff01;今天要給大家分享一個超級治愈的網頁作品——浪浪山小妖怪主題網站&#xff01;這個純原生開發的項目不僅顏值在線&#xff0c;功能也很能打哦&#xff5e;至于靈感來源的話&#xff0c;要從一部動畫說起。最近迷上了治愈系動畫&#xff0c;就想做一個溫暖…

搭建最新--若依分布式spring cloudv3.6.6 前后端分離項目--步驟與記錄常見的坑

首先 什么拉取代碼&#xff0c;安裝數據庫&#xff0c;安裝redis&#xff0c;安裝jdk這些我就不說了 導入數據庫 &#xff1a;數據庫是分庫表的 &#xff0c;不要建錯了 【一定要注意&#xff0c;不然nacos讀取不到配置文件】這個是給nacos用的這個是給項目配置或項目用的2. 服…

分布式唯一 ID 生成方案

在復雜分布式系統中&#xff0c;往往需要對大量的數據和消息進行唯一標識。如在美團點評的金融、支付、餐飲、酒店、貓眼電影等產品的系統中&#xff0c;數據日漸增長&#xff0c;對數據分庫分表后需要有一個唯一 ID 來標識一條數據或消息&#xff0c;數據庫的自增 ID 顯然不能…