\documentclass[border=5mm]{standalone}
\usepackage{luamplib}
\begin{document}
\mplibtextextlabel{enable}
\begin{mplibcode}
beginfig(1);
numeric u, minx, s, maxx;
u = 42; minx = -3; s = 1/4; maxx = 1/256 mlog(4.5);
path xx; xx = (-3u, 0) -- (5u, 0);
path yy; yy = xx rotated 90;
path ee, ll, nn;
ee = (for x = minx step s until maxx - s:
(x, mexp(256x)){1, mexp(256x)} ...
endfor (maxx, mexp(256 maxx)){1, mexp(256 maxx)}) scaled u;
ll = ee reflectedabout(origin, dir 45);
nn = (for x=1 step s until 4-s: (x, 1/x) ... endfor (4, 1/4)) scaled u;
nn := reverse nn reflectedabout(origin, dir 45) & nn;
drawoptions(withcolor 7/8);
draw unitsquare xscaled mexp(256) scaled u;
draw unitsquare yscaled mexp(256) scaled u;
drawoptions(withcolor 3/4);
forsuffixes $ = ee, ll:
path T$; T$ = (left--right) scaled 2u rotated 45
shifted directionpoint dir 45 of $;
draw T$;
endfor
draw interpath(1/2, T.ee, T.ll) dashed evenly;
drawoptions(withcolor 2/3 blue);
draw ee; label.top("$e^x$", point infinity of ee);
drawoptions(withcolor 2/3 red);
draw ll; label.top("$\ln(x)$", point infinity of ll);
drawoptions();
draw nn; label.urt("$1/x$", point 0 of nn);
drawarrow xx; label.rt("$x$", point 1 of xx);
drawarrow yy; label.top("$y$", point 1 of yy);
dotlabel.lft("$e$", (0, mexp(256) * u));
dotlabel.bot("$e$", (mexp(256) * u, 0));
dotlabel.ulft("$1$", (0, u));
dotlabel.lrt("$1$", (u, 0));
endfig;
\end{mplibcode}
\end{document}