Skip to content

Commit

Permalink
Fix plotting of just the relevant part of the spectrum
Browse files Browse the repository at this point in the history
  • Loading branch information
matteobachetti committed Sep 26, 2023
1 parent d2df1ee commit e29dcbb
Showing 1 changed file with 12 additions and 3 deletions.
15 changes: 12 additions & 3 deletions stingray/crossspectrum.py
Original file line number Diff line number Diff line change
Expand Up @@ -1075,9 +1075,14 @@ def plot(
fig = plt.figure("crossspectrum")
ax = fig.add_subplot(1, 1, 1)

ax.plot(self.freq, np.abs(self.power), marker, color="b", label="Amplitude")
ax.plot(self.freq, self.power.real, marker, color="r", alpha=0.5, label="Real Part")
ax.plot(self.freq, self.power.imag, marker, color="g", alpha=0.5, label="Imaginary Part")
if np.any(np.iscomplex(self.power.imag)):
ax.plot(self.freq, np.abs(self.power), marker, color="b", label="Amplitude")
ax.plot(
self.freq, self.power.imag, marker, color="g", alpha=0.5, label="Imaginary Part"
)
ax.plot(self.freq, self.power.real, marker, color="r", alpha=0.5, label="Real Part")
else:
ax.plot(self.freq, np.abs(self.power), marker, color="b")

if labels is not None:
try:
Expand All @@ -1087,6 +1092,10 @@ def plot(
simon("``labels`` must have two labels for x and y axes.")
# Not raising here because in case of len(labels)==1, only
# x-axis will be labelled.
else:
ax.set_xlabel("Frequency (Hz)")
ax.set_ylabel(f"Power ({self.norm})")

ax.legend(loc="best")

if axis is not None:
Expand Down

0 comments on commit e29dcbb

Please sign in to comment.