Datei:Dual-freq wave packet Fourier-transformed.svg

Originaldatei (SVG-Datei, Basisgröße: 768 × 768 Pixel, Dateigröße: 26 KB)

Diese Datei und die Informationen unter dem roten Trennstrich werden aus dem zentralen Medienarchiv Wikimedia Commons eingebunden.

Zur Beschreibungsseite auf Commons


Beschreibung

Beschreibung See Python code below
Datum
Quelle Eigenes Werk
Urheber Rainald62
Andere Versionen File:2FrequenzenPuls.png File:2FrequenzenPuls-FFT.png
import numpy as np
from scipy.stats import norm
from matplotlib.pyplot import subplots, rcParams

def std_of_distribution(grid, cnt):
    return np.sqrt(np.cov(grid, aweights=cnt, ddof=0))

N = 2**12
T = 20
std_t = 1/np.sqrt(2*np.pi)
t = np.linspace(-T/2, T/2, N, endpoint=False)
def h(t): return 1/(std_t*np.sqrt(2*np.pi))*np.exp(-0.5*(t/std_t)**2)
# std_of_distribution(t, h(t)) # std_t, ok.

f1 = 2.5
f2 = 7
def f(t): return h(t)*(4*np.cos(f1*2*np.pi*t)
                      +2*np.cos(f2*2*np.pi*t))
y = f(t)
dt = T/N
fft = dt*np.fft.rfft(y)
betrag = np.abs(fft)
freq = np.linspace(0, 0.5/dt, N//2 + 1)
df = freq[1]
energy_y = dt*sum(y**2)
energyℱy = df*sum(betrag**2)*2
h_sig = betrag[int(.5+f1/df)]*np.exp(-.5)
peak = slice(0, int(f1/df*2))
std_f = std_of_distribution(freq[peak], betrag[peak])

rcParams['svg.fonttype'] = 'none' # text as utf8, not curves
fig, (axt, axf) = subplots(2, figsize=(8, 8), gridspec_kw={'hspace': 0})
axt.axhline(0, ls='-', c='k', lw=.5)
axt.plot(t, y, 'r-')
axt.set_xlabel('t in s')
axt.set_ylabel('y(t) in √Watt')
#axt.set_xlabel('t in s')
axt.set_xlim(-3.5*std_t, 3.5*std_t)
axt.set_xticks(np.arange(-3, 4)*round(std_t, 1))
axt.spines['bottom'].set_position('zero')
axf.set_xlabel('f in Hz')
axf.set_ylabel('|ℱ y|(f) in √Joule per Hz')
axf.plot(-freq, betrag, 'b-')
axf.plot( freq, betrag, 'b-')
axf.set_ylim(0)
axf.set_xlim(-9, 9)
axf.set_xticks([-7, -2.5, 2.5, 7])
axf.set_yticks([0, 1, 2])
axf.vlines(f1, h_sig*.9, h_sig*1.1, colors='k', linewidths=0.5)
axf.annotate(f'{std_f:.1f} Hz', xy=(f1+std_f, h_sig),
             textcoords='offset fontsize', xytext=(1.2, 0.22), # 0.22? 0 shall yield a level line!
             arrowprops=dict(arrowstyle='->', shrinkB=0, relpos=(1.1,0)))
axf.annotate(' ', xy=(f1, h_sig),
             textcoords='offset fontsize', xytext=(-1.2, 0.22),
             arrowprops=dict(arrowstyle='->', shrinkB=0, relpos=(-1.1,0)))
fig.tight_layout()
fig.show()

print(f'{energy_y:.2f} J total signal energy')
print(f'{energyℱy:.2f} J total spectral energy') # same, ok.
print(f'{std_t:.4f} s pulse width (σ)')
print(f'{std_f:.4f} Hz peak width') # std_t*std_f = 1/(2π), ok.

Lizenz

Ich, der Urheberrechtsinhaber dieses Werkes, veröffentliche es hiermit unter der folgenden Lizenz:
GNU head Es ist erlaubt, die Datei unter den Bedingungen der GNU-Lizenz für freie Dokumentation, Version 1.2 oder einer späteren Version, veröffentlicht von der Free Software Foundation, zu kopieren, zu verbreiten und/oder zu modifizieren; es gibt keine unveränderlichen Abschnitte, keinen vorderen und keinen hinteren Umschlagtext.

Der vollständige Text der Lizenz ist im Kapitel GNU-Lizenz für freie Dokumentation verfügbar.

w:de:Creative Commons
Namensnennung Weitergabe unter gleichen Bedingungen
Diese Datei ist unter den Creative Commons-Lizenzen Namensnennung – Weitergabe unter gleichen Bedingungen 4.0 International, 3.0 nicht portiert, 2.5 Allgemein, 2.0 Allgemein und 1.0 Allgemein lizenziert.
Dieses Werk darf von dir
  • verbreitet werden – vervielfältigt, verbreitet und öffentlich zugänglich gemacht werden
  • neu zusammengestellt werden – abgewandelt und bearbeitet werden
Zu den folgenden Bedingungen:
  • Namensnennung – Du musst angemessene Urheber- und Rechteangaben machen, einen Link zur Lizenz beifügen und angeben, ob Änderungen vorgenommen wurden. Diese Angaben dürfen in jeder angemessenen Art und Weise gemacht werden, allerdings nicht so, dass der Eindruck entsteht, der Lizenzgeber unterstütze gerade dich oder deine Nutzung besonders.
  • Weitergabe unter gleichen Bedingungen – Wenn du das Material wiedermischst, transformierst oder darauf aufbaust, musst du deine Beiträge unter der gleichen oder einer kompatiblen Lizenz wie das Original verbreiten.
Du darfst es unter einer der obigen Lizenzen deiner Wahl verwenden.

Kurzbeschreibungen

Ergänze eine einzeilige Erklärung, was diese Datei darstellt.

In dieser Datei abgebildete Objekte

Motiv

Urheber

Einige Werte ohne einen Wikidata-Eintrag

Autor (Text): Rainald62
Wikimedia-Benutzername: Rainald62

Urheberrechtsstatus

urheberrechtlich geschützt

Lizenz

Creative Commons Namensnennung - Weitergabe unter gleichen Bedingungen 2.0

Creative Commons Namensnennung – Weitergabe unter gleichen Bedingungen 4.0 International

Creative Commons Namensnennung - Weitergabe unter gleichen Bedingungen 1.0

Creative Commons Namensnennung – Weitergabe unter gleichen Bedingungen 2.5 generisch

Creative Commons Namensnennung – Weitergabe unter gleichen Bedingungen 3.0 Generisch

GNU-Lizenz für freie Dokumentation Version 1.2 oder später

Quelle der Datei

durch Hochlader/in erstelltes Original

Datum der Gründung, Erstellung, Entstehung, Erbauung

25. Oktober 2024

Dateiversionen

Klicke auf einen Zeitpunkt, um diese Version zu laden.

Version vomVorschaubildMaßeBenutzerKommentar
aktuell13:24, 26. Okt. 2024Vorschaubild der Version vom 13:24, 26. Okt. 2024768 × 768 (26 KB)Rainald62magnitude | |
21:51, 25. Okt. 2024Vorschaubild der Version vom 21:51, 25. Okt. 2024768 × 768 (26 KB)Rainald62{{Information |Description=See Python code below |Source={{own}} |Date=2024-10-25 |Author= Rainald62 |Permission= |other_versions=File:2FrequenzenPuls.png File:2FrequenzenPuls-FFT.png }} <pre> import numpy as np from scipy.stats import norm from matplotlib.pyplot import subplots, rcParams def std_of_distribution(grid, cnt): return np.sqrt(np.cov(grid, aweights=cnt, ddof=0)) N = 2**12 T = 20 std_t = 1/np.sqrt(2*np.pi) t = np.linspace(-T/2, T/2, N, endpoint=F...

Die folgende Seite verwendet diese Datei:

Metadaten