Skip to content

Commit c5eff0f

Browse files
committed
DOC: Improve log scale example
- Remove https://matplotlib.org/stable/gallery/scales/semilogx_demo.html It is redundant to the other log scale example. - Explain that semilogx/semilogy/loglog are shortcuts. - Tune data/visualization
1 parent c11175d commit c5eff0f

File tree

2 files changed

+25
-42
lines changed

2 files changed

+25
-42
lines changed
Lines changed: 25 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -1,34 +1,41 @@
11
"""
2-
========
3-
Log Demo
4-
========
2+
=========
3+
Log scale
4+
=========
55
66
Examples of plots with logarithmic axes.
7+
8+
You can set the x/y axes to be logarithmic by passing "log" to `~.Axes.set_xscale` /
9+
`~.Axes.set_yscale`.
10+
11+
Since plotting data on semi-logarithmic or double-logarithmic scales is very common,
12+
the functions `~.Axes.semilogx`, `~.Axes.semilogy`, and `~.Axes.loglog` are shortcuts
13+
for setting the scale and plotting data; e.g. ``ax.semilogx(x, y)`` is equivalent to
14+
``ax.set_xscale('log'); ax.plot(x, y)``.
715
"""
816

917
import matplotlib.pyplot as plt
1018
import numpy as np
1119

12-
# Data for plotting
13-
t = np.arange(0.01, 20.0, 0.01)
20+
fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(2, 2, layout='constrained')
1421

15-
# Create figure
16-
fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(2, 2)
17-
18-
# log y axis
19-
ax1.semilogy(t, np.exp(-t / 5.0))
20-
ax1.set(title='semilogy')
22+
# log x axis
23+
t = np.arange(0.01, 10.0, 0.01)
24+
ax1.semilogx(t, np.sin(2 * np.pi * t))
25+
ax1.set(title='semilogx')
2126
ax1.grid()
2227

23-
# log x axis
24-
ax2.semilogx(t, np.sin(2 * np.pi * t))
25-
ax2.set(title='semilogx')
28+
# log y axis
29+
x = np.arange(10)
30+
ax2.semilogy(x, 2**x, 'x:', base=2)
31+
ax2.set(title='semilogy with base 2')
2632
ax2.grid()
2733

34+
2835
# log x and y axis
29-
ax3.loglog(t, 20 * np.exp(-t / 10.0))
30-
ax3.set_xscale('log', base=2)
31-
ax3.set(title='loglog base 2 on x')
36+
x = np.array([1, 10, 100, 1000, 10000])
37+
ax3.loglog(x, 5 * x, 'o--')
38+
ax3.set(title='loglog')
3239
ax3.grid()
3340

3441
# With errorbars: clip non-positive values
@@ -38,10 +45,9 @@
3845

3946
ax4.set_xscale("log", nonpositive='clip')
4047
ax4.set_yscale("log", nonpositive='clip')
41-
ax4.set(title='Errorbars go negative')
48+
ax4.set(title='loglog with errorbars going negative')
4249
ax4.errorbar(x, y, xerr=0.1 * x, yerr=5.0 + 0.75 * y)
4350
# ylim must be set after errorbar to allow errorbar to autoscale limits
4451
ax4.set_ylim(bottom=0.1)
4552

46-
fig.tight_layout()
4753
plt.show()

galleries/examples/scales/semilogx_demo.py

Lines changed: 0 additions & 23 deletions
This file was deleted.

0 commit comments

Comments
 (0)