Построение графика броуновского движения с пунктирной линией, указывающей значения

Построение графика броуновского движения с пунктирной линией, указывающей значения

Я хочу построить график, похожий на тот, что показан ниже, в LaTeX (через TikZ или что-то еще). Я уже нашел способ построить график броуновского пути. Однако я не знаю, как добавить пунктирные линии, показанные на рисунке ниже. Эти линии создаются, когда броуновский путь достигает определенного значения, и метки будут буквами, а не цифрами. Спасибо!

Пример

На самом деле, метод построения броуновского пути, который я нашел, находится здесь: Как нарисовать броуновское движение в tikz/pgf

Мне не нужно добавлять верхнюю или нижнюю границу, как в ответах по этой ссылке. Но мне нужно добавить несколько пунктирных линий для некоторых конкретных значений.

решение1

Вот попытка использованияМетапостзавернутый вluamplib. Скомпилируйте с помощью lualatex, перейдите по ссылкам для получения более подробной информации.

введите описание изображения здесь

\RequirePackage{luatex85}
\documentclass[border=5mm]{standalone}
\usepackage{luamplib}
\begin{document}
\mplibtextextlabel{enable}
\begin{mplibcode}
beginfig(1);

% set a seed, so it is repeatable (it will work fine if you 
% delete this, but you will get a different path...)
randomseed := 1288.27463;

numeric a, u, v, wt, N, hi, lo;
% parameters
a = 0;
N = 100;
lo = -hi = infinity;
wt = 2/5; % weight - larger = more random

% scales
u = 1mm; % scale
v = 1cm;

% make the brownian path, keeping track of the hi and lo points
% you could use uniformdeviate or calculate a more complicated
% distribution here instead of "normaldeviate"
path A;
A = (origin for t=1 upto N: 
        hide( 
            if a>hi: hi := a; fi if a<lo: lo := a; fi 
            a := a + wt * normaldeviate; 
        )
        -- (t,a) 
     endfor) xscaled u yscaled v;

% draw in the axes nicely
drawoptions(withcolor 1/2 white);
draw ((0,lo)--(0,hi)) scaled v;
for i=ceiling(lo) upto floor(hi) : 
    draw (left--right) scaled 2 shifted (0,i*v);
    label.lft("$" & decimal i & "$", (0,i*v)); 
endfor
draw (origin--right) scaled (N*u);

% draw the markers at the desired points along the brownian motion path
drawoptions(dashed evenly scaled 1/2 withcolor 2/3 blue);

z0 = point 44 of A; 
draw (x0,-16) -- z0 -- (-16,y0); 
label.bot("$T_0$", (x0,-16));
label.lft("$M_0$", (-16,y0));

z1 = point 81 of A; 
draw (x1,-16) -- z1 -- (-16,y1); 
label.bot("$T_1$", (x1,-16));
label.lft("$M_1$", (-16,y1));

% etc...

% finally draw the path on top of everything else
drawoptions(withcolor 2/3 red);
draw A;

drawoptions();
endfig;
\end{mplibcode}
\end{document}

Связанный контент