日本a√视频在线,久久青青亚洲国产,亚洲一区欧美二区,免费g片在线观看网站

        <style id="k3y6c"><u id="k3y6c"></u></style>
        <s id="k3y6c"></s>
        <mark id="k3y6c"></mark>
          
          

          <mark id="k3y6c"></mark>

          "); //-->

          博客專欄

          EEPW首頁 > 博客 > 8/20浪涌測(cè)試波形時(shí)域轉(zhuǎn)頻域的解釋及仿真思路(基于Python)

          8/20浪涌測(cè)試波形時(shí)域轉(zhuǎn)頻域的解釋及仿真思路(基于Python)

          發(fā)布人:深圳比創(chuàng)達(dá) 時(shí)間:2025-06-18 來源:工程師 發(fā)布文章

          1.引言

          在電子工程和電磁兼容性(EMC)領(lǐng)域,8/20μs浪涌波形是一種標(biāo)準(zhǔn)的感應(yīng)雷,常用于模擬雷電引起的瞬態(tài)過電流。這個(gè)波形因其陡峭的上升沿(8μs)和較長的下降沿(20μs)而得名,能夠很好地模擬雷電沖擊對(duì)電子設(shè)備的影響。今天,我將帶領(lǐng)大家一步步了解如何通過仿真分析8/20μs浪涌波形的時(shí)域特性,并將其轉(zhuǎn)換到頻域進(jìn)行分析,揭示其頻率成分。2.時(shí)域分析

          2.1 8/20μs浪涌波形的定義

          8/20μs浪涌波形是一種典型的雙指數(shù)脈沖波形,其數(shù)學(xué)表達(dá)式可以表示為:

          數(shù)學(xué)表達(dá)式.png


          其中:

          spacer.gif33a49752ec254a4285e87a28db23726.png

          這個(gè)公式看起來有點(diǎn)復(fù)雜,但其實(shí)就是在兩個(gè)指數(shù)函數(shù)之間做差,從而得到一個(gè)脈沖波形。簡單來說,就是用一個(gè)快速下降的指數(shù)函數(shù)減去一個(gè)更慢下降的指數(shù)函數(shù),形成一個(gè)快速上升、緩慢下降的脈沖。

          2.2仿真生成時(shí)域波形

          在代碼中,`generate_8_20_waveform`函數(shù)通過上述公式生成8/20μs浪涌波形。具體步驟如下:

          1.使用`np.linspace`生成時(shí)間數(shù)組`time`,表示仿真時(shí)間范圍。

          2.計(jì)算電流波形`current`,使用雙指數(shù)函數(shù)模擬上升沿和下降沿。

          3.對(duì)波形進(jìn)行歸一化處理,確保峰值電流為4kA。

          生成的時(shí)域波形,展示了8/20μs浪涌波形的典型特性。

          3.頻域分析

          3.1時(shí)域到頻域的轉(zhuǎn)換

          為了分析8/20μs浪涌波形的頻率成分,需要將其從時(shí)域轉(zhuǎn)換到頻域。這一過程可以通過快速傅里葉變換(FFT)實(shí)現(xiàn)。FFT的基本原理是將時(shí)域信號(hào)分解為不同頻率成分的疊加,從而得到信號(hào)的頻譜。

          在代碼中,`analyze_frequency_domain`函數(shù)使用`scipy.fft.fft`計(jì)算信號(hào)的頻域表示。具體步驟如下:

          1.計(jì)算信號(hào)的FFT,得到復(fù)數(shù)頻譜。

          2.提取頻率數(shù)組`freq`和幅度譜`magnitude`。

          3.對(duì)幅度譜進(jìn)行歸一化處理,使其單位為“kA/Hz”。

          3.2頻域波形的特性

          8/20μs浪涌波形的頻域特性可以通過其頻譜圖進(jìn)行分析。由于該波形是一個(gè)瞬態(tài)脈沖,其頻譜通常呈現(xiàn)寬帶特性,包含從低頻到高頻的成分。

          在代碼中,頻域波形以對(duì)數(shù)-對(duì)數(shù)(log-log)尺度繪制。頻譜圖展示了信號(hào)在不同頻率下的幅度分布。通過頻譜圖可以觀察到:

          -信號(hào)在低頻段(如1MHz以下)具有較高的幅度。

          -隨著頻率的增加,幅度逐漸減小,但仍然包含高頻成分。

          3.3頻域分析的意義

          頻域分析對(duì)于理解8/20μs浪涌波形的特性具有重要意義:

          1.頻譜特性:頻域分析可以揭示信號(hào)在不同頻率下的能量分布,有助于設(shè)計(jì)濾波器或保護(hù)電路。

          2.電磁兼容性:通過頻域分析,可以評(píng)估信號(hào)對(duì)其他設(shè)備的干擾特性,從而優(yōu)化電磁兼容性設(shè)計(jì)。

          3.實(shí)際應(yīng)用:頻域特性可以用于驗(yàn)證設(shè)備在不同頻率下的抗干擾能力。

          4.仿真思路總結(jié)

          4.1仿真流程

          1.時(shí)域波形生成:

          -使用雙指數(shù)函數(shù)生成8/20μs浪涌波形。

          -確保波形的峰值電流為4kA。

          2.頻域分析:

          -使用FFT將時(shí)域信號(hào)轉(zhuǎn)換為頻域信號(hào)。

          -計(jì)算頻率數(shù)組和幅度譜。

          3.結(jié)果可視化:

          -繪制時(shí)域波形圖,展示8/20μs浪涌波形的時(shí)域特性。

          -繪制頻域波形圖,展示信號(hào)的頻譜特性。

          4.2仿真結(jié)果分析

          通過仿真可以得到以下結(jié)論:

          -8/20μs浪涌波形在時(shí)域上表現(xiàn)為一個(gè)快速上升、緩慢下降的脈沖。

          -在頻域上,該波形呈現(xiàn)寬帶特性,包含從低頻到高頻的成分。

          -頻域分析可以為電磁兼容性設(shè)計(jì)和濾波器設(shè)計(jì)提供重要參考。

          5.結(jié)論

          通過對(duì)8/20μs浪涌波形的時(shí)域和頻域分析,可以全面理解其特性及其對(duì)電子設(shè)備的影響。時(shí)域分析揭示了波形的瞬態(tài)特性,而頻域分析則揭示了其頻率成分。這種分析方法對(duì)于設(shè)計(jì)抗干擾電路和優(yōu)化電磁兼容性具有重要意義。

           

          通過本文的仿真思路和代碼實(shí)現(xiàn),進(jìn)一步探索8/20μs浪涌波形的特性,并將其應(yīng)用于實(shí)際工程中。希望這篇文章能幫助大家更好地理解8/20μs浪涌波形的時(shí)域轉(zhuǎn)頻域分析,同時(shí)也希望大家在學(xué)習(xí)過程中能夠保持好奇心和探索精神,不斷進(jìn)步!



          826bfb1fb3c1f460c09775b82b247d11.png



          附代碼:

          1. import numpy as np
          import matplotlib.pyplot as plt
          from scipy.fft import fft, fftfreq
          #import B-tron EMC

          # Set font to support English display
          plt.rcParams["font.family"] = ["DejaVu Sans", "Arial", "sans-serif"]
          plt.rcParams["axes.unicode_minus"] = False  # Ensure minus sign display


          def generate_8_20_waveform(duration=100e-6, samples=10000):
              """
              Generate 8/20μs standard lightning impulse current waveform

              Parameters:
                  duration: Simulation duration (seconds)
                  samples: Number of sampling points

              Returns:
                  time: Time array (seconds)
                  current: Current array (kA)
              """
              t = np.linspace(0, duration, samples)

              # 8/20μs waveform parameters
              tau1 = 8e-6  # Front time constant
              tau2 = 20e-6  # Tail time constant
              amplitude = 4  # Amplitude (kA)

              # Calculate current waveform (exponential decay model)
              current = amplitude * (np.exp(-t / tau2) - np.exp(-t / tau1))

              # Normalize to make peak value 4kA
              current = current / np.max(current) * amplitude

              return t, current


          def analyze_frequency_domain(time, signal, sampling_freq):
              """
              Perform frequency domain analysis

              Parameters:
                  time: Time array (seconds)
                  signal: Signal array
                  sampling_freq: Sampling frequency (Hz)

              Returns:
                  freq: Frequency array (Hz)
                  magnitude: Amplitude spectrum
              """
              n = len(signal)
              yf = fft(signal)
              freq = fftfreq(n, 1 / sampling_freq)[:n // 2]
              magnitude = 2.0 / n * np.abs(yf[:n // 2])

              return freq, magnitude


          def plot_waveforms(time, current, freq, magnitude):
              """Plot time-domain and frequency-domain waveforms"""
              fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(10, 10))

              # Time-domain waveform
              ax1.plot(time * 1e6, current)  # Convert time to μs
              ax1.set_title('8/20μs Lightning Impulse Current Waveform (Time Domain)')
              ax1.set_xlabel('Time (μs)')
              ax1.set_ylabel('Current (kA)')
              ax1.grid(True)

              # Mark peak value and time parameters
              peak_idx = np.argmax(current)
              t_peak = time[peak_idx] * 1e6
              ax1.annotate(f'Peak: {current[peak_idx]:.2f} kA\nTime: {t_peak:.2f} μs',
                           xy=(t_peak, current[peak_idx]),
                           xytext=(t_peak + 5, current[peak_idx] * 0.8),
                           arrowprops=dict(facecolor='black', shrink=0.05))

              # Frequency-domain waveform (log-log scale)
              ax2.loglog(freq, magnitude)
              ax2.set_title('Frequency Spectrum of 8/20μs Lightning Impulse Current')
              ax2.set_xlabel('Frequency (MHz)')
              ax2.set_ylabel('Magnitude (kA/Hz)')
              ax2.grid(True, which='both', linestyle='--', alpha=0.7)

              # Add spectral feature annotations
              freq_1MHz = np.interp(1e6, freq, magnitude)
              freq_10MHz = np.interp(1e7, freq, magnitude)



              ax2.annotate(f'1 MHz: {freq_1MHz:.2e} kA/Hz',
                           xy=(1e6, freq_1MHz),
                           xytext=(1e6 * 2, freq_1MHz * 3),
                           arrowprops=dict(facecolor='black', shrink=0.05))

              ax2.annotate(f'10 MHz: {freq_10MHz:.2e} kA/Hz',
                           xy=(1e7, freq_10MHz),
                           xytext=(1e7 * 2, freq_10MHz * 3),
                           arrowprops=dict(facecolor='black', shrink=0.05))

              plt.tight_layout()
              return fig


          def main():
              # Generate 8/20μs waveform
              time, current = generate_8_20_waveform(duration=100e-6, samples=10000)

              # Calculate sampling frequency
              sampling_freq = len(time) / (time[-1] - time[0])

              # Frequency domain analysis
              freq, magnitude = analyze_frequency_domain(time, current, sampling_freq)

              # Plot waveforms
              fig = plot_waveforms(time, current, freq, magnitude)

              # Display waveforms
              plt.show()

              # Print magnitude at key frequencies
              print("8/20μs Waveform Frequency Characteristics:__B-tron")


          if __name__ == "__main__":
              main()

           


          *博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。


          關(guān)鍵詞: 浪涌

          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉