\documentclass[border=5mm]{standalone}
\usepackage{luamplib}
\begin{document}
\mplibtextextlabel{enable}
\begin{mplibcode}
vardef pi_quarters(expr n) =
save s, f, q; string s, f; numeric q;
s = if n < 0: "-" else: "" fi; q = abs(n);
if q mod 4 = 0: f = if q > 4: decimal 1/4 q else: "" fi;
elseif q mod 2 = 0: f = "\frac{" & decimal 1/2 q & "}{2}";
else: f = "\frac{" & decimal q & "}{4}";
fi TEX("$\scriptstyle" & s & f & "\pi$")
enddef;
beginfig(1);
numeric u, pi; u = 50; pi = 3.141592653589793;
path xx, yy;
xx = (3.5 left -- 3.6 right) scaled u;
yy = (1.1 down -- 1.2 up) scaled u;
path ss;
ss = origin for t=1 upto 360: -- (t, sind(t)) endfor;
ss := ss shifted 360 left & ss;
ss := ss xscaled (pi/180) scaled u;
drawoptions(dashed withdots scaled 1/4);
draw ((1/4 pi, 0) .. (1/4 pi, sind(45))) scaled u;
draw ((1/2 pi, 0) .. (1/2 pi, sind(90))) scaled u;
draw ((3/4 pi, 0) .. (3/4 pi, sind(135))) scaled u;
drawoptions();
draw ss
cutbefore yy shifted point 0 of xx
cutafter yy shifted point 1 of xx
withcolor 3/4 blue;
draw ss shifted (-1/2 pi * u ,0)
cutbefore yy shifted point 0 of xx
cutafter yy shifted point 1 of xx
withcolor 2/3 red;
drawarrow xx; label.rt(TEX("$t$"), point 1 of xx);
drawarrow yy; label.top(TEX("$u(t)$"), point 1 of yy);
for i=-4, -3, -2, -1, 1, 2, 3, 4:
draw (down--up) scaled 2 shifted (pi * i/4 * u, 0);
label.bot(pi_quarters(i), (pi * i/4 * u, -2));
endfor
endfig;
\end{mplibcode}
\end{document}