TikZ-Funktionsnummer zu groß

TikZ-Funktionsnummer zu groß

Ich möchte zwei Betaverteilungen zeichnen, indem ich eine vorherige und eine nachfolgende Verteilung vergleiche, aber es scheint, dass die Koeffizienten für LaTeX zu groß sind. Wie behebe ich das, ohne die Funktion zu ändern? Es enthält einige Fehler, darunter Dimension too largeund Number too big.

\documentclass[10pt]{article}  
\usepackage{pgf,tikz}  
\usetikzlibrary{arrows}  
\pagestyle{empty}  
\begin{document}  
\definecolor{qqccqq}{rgb}{0,0.8,0}  
\definecolor{qqttcc}{rgb}{0,0.2,0.8}  
\begin{tikzpicture}[line cap=round,line join=round,>=triangle 45,x=8.333333333333332cm,y=1.0cm]  
\draw[->,color=black] (-0.1,0) -- (1.1,0);  
\foreach \x in {,0.2,0.4,0.6,0.8,1}  
\draw[shift={(\x,0)},color=black] (0pt,2pt) -- (0pt,-2pt) node[below] {\footnotesize $\x$};  
\draw[color=black] (1.04,0.04) node [anchor=south west] { $\theta$};  
\draw[->,color=black] (0,-0.5) -- (0,5.5);    
\foreach \y in {,1,2,3,4,5}    
\draw[shift={(0,\y)},color=black] (2pt,0pt) -- (-2pt,0pt) node[left] {\footnotesize $\y$};  
\draw[color=black] (0pt,-10pt) node[right] {\footnotesize $0$};  
\clip(-0.1,-0.5) rectangle (1.1,5.5);  
\draw[dash pattern=on 1pt off 1pt,color=qqttcc, smooth,samples=100,domain=8.000000000003847E-7:0.9999990727280006] plot(\x,{3682570000*(1-(\x))^(10.67)*(\x)^(21.49)});  
\draw[color=qqccqq, smooth,samples=100,domain=8.000000000003847E-7:0.9999990727280006] plot(\x,{2120.93*(1-(\x))^(2.67)*(\x)^(9.49)});  
\draw (0.49,4.17) node[anchor=north west] {$g(\theta|D)$};  
\draw (0.89,3.23) node[anchor=north west] {$g(\theta)$};  
\end{tikzpicture}  
\end{document}

Antwort1

Erwägen Sie auch eine Asymptote-Option, da diese beim Zeichnen von Graphen recht leistungsfähig ist, insbesondere bei einem Kurvenarray. Ein Beispiel unten organisiert Funktionen in einem Array; andere Eigenschaften wie Farbe, Breite, Beschriftung usw. können ebenfalls in Arrays organisiert werden, um in einer Schleife gezeichnet zu werden. Außerdem ywird die -Koordinate der Beschriftung als Punkt auf der Kurve berechnet. asy-plot.tex

\documentclass{standalone}
\usepackage{lmodern}
\usepackage[inline]{asymptote}
\begin{document}  
\begin{asy}
import graph;
size(250,170,IgnoreAspect);
real xMin=8.000000000003847e-7;
real xMax=0.9999990727280006;
int n=100;

typedef real Func(real x);

Func[] f={
   new real(real x){return 3682570000*(1-x)^(10.67)*x^(21.49);},
   new real(real x){return 2120.93*(1-x)^2.67*x^9.49;},
};

pen dashed=linetype(new real[] {4,3}); // set up dashed pattern

pen[] curvePen={rgb(0,0.8,0)+dashed,rgb(0,0.2,0.8),};
real[] curveWidth={1.6pt,2pt};
Label[] lab={
  Label("$g(\theta\,\vert D)$",(0.6,f[0](0.6))),
  Label("$g(\theta)$",(0.9,f[1](0.9))),
};

for(int i=0;i<f.length;++i){
  draw(graph(f[i], xMin ,xMax ,n),curvePen[i]+curveWidth[i]);
  label(lab[i],UnFill(2pt));
}

xaxis("",0,1.049,RightTicks(Step=0.1,step=0.05),EndArrow);
yaxis("",0,5-0.15,LeftTicks(Step=1,step=0.5),EndArrow);
\end{asy}
\end{document}

Um es zu verarbeiten latexmk, erstellen Sie die Datei latexmkrc:

sub asy {return system("asy '$_[0]'");}
add_cus_dep("asy","eps",0,"asy");
add_cus_dep("asy","pdf",0,"asy");
add_cus_dep("asy","tex",0,"asy");

und führen Sie aus latexmk -pdf asy-plot.tex. Das Ergebnis sieht wie folgt aus:

Bildbeschreibung hier eingeben

Antwort2

Keine direkte Antwort, aber ich würde pgfplotses dafür verwenden. Vielleicht fpulöst es das Problem, wenn man die Bibliothek an der richtigen Stelle einschaltet, aber man muss keine Achsen usw. zeichnen, also denke ich, dass das viel praktischer ist.

\documentclass{standalone}
\usepackage{pgfplots}
\usetikzlibrary{arrows}  
\definecolor{qqccqq}{rgb}{0,0.8,0}
\definecolor{qqttcc}{rgb}{0,0.2,0.8}
\begin{document}  
\begin{tikzpicture}[line cap=round,line join=round]
\begin{axis}[
    axis lines=middle,
    every inner x axis line/.append style={-triangle 45},
    every inner y axis line/.append style={-triangle 45},
    enlargelimits]
\addplot[dash pattern=on 1pt off 1pt,color=qqttcc, smooth,samples=100,domain=8.000000000003847E-7:0.9999990727280006] plot(\x,{3682570000*(1-(\x))^(10.67)*(\x)^(21.49)});  
\addplot[color=qqccqq, smooth,samples=100,domain=8.000000000003847E-7:0.9999990727280006] plot(\x,{2120.93*(1-(\x))^(2.67)*(\x)^(9.49)});  
\node at (axis cs:0.49,4.17) {$g(\theta|D)$};  
\node at (axis cs:0.89,3.23) {$g(\theta)$};  
\end{axis}
\end{tikzpicture}
\end{document}

Bildbeschreibung hier eingeben

Das Problem im Zusammenhang mit Ihrer Bearbeitung besteht darin, dass die Zahlen zum Ende der Domäne hin zu klein werden. Um dies zu zeigen, habe ich auf der Y-Achse auf die Logarithmusachse umgestellt. TeX kann diese Genauigkeit nicht verarbeiten, aber die fpuBibliothek von TikZ oder pgfplotsstandardmäßig kann bis zu einem gewissen Grad damit umgehen und wird mit einem Fehler bei der Division durch Null beendet. Andernfalls pgfplotskönnen gnuplotAnweisungen außerhalb von TeX ausgeführt werden. Bitte lesen Sie das Handbuch von. pgfplotsAußerdem müssen Sie nicht jede Farbe definieren, die Sie verwenden. xcolor ist ein ziemlich leistungsfähiges Paket, sodass Sie Farbmischfunktionen verwenden können. Hier ist ein minimales Beispiel ohne Achseneinstellungen usw., um zu zeigen, wie einfach es zu verwenden ist:

\documentclass{standalone}
\usepackage{pgfplots}
\pgfplotsset{compat=1.8} % The latest version on CTAN
\begin{document}  
\begin{tikzpicture}
\begin{semilogyaxis}
\addplot[red,smooth,samples=100,domain=0.0:1.0] {(3.1415926535*sin(((x)*3.1415926535)*180/pi))/2};  
\addplot[green!80!black, smooth,samples=100,domain=0.0:1.0] {(x)^1^2*(1-(x))^8*sin(((x)*3.1415926535)*180/pi)*1/(3.44*10^(-7))};  
\addplot[blue!80!green, ultra thick,smooth,samples=100,domain=0.0:1.0] {2.718281828^((-((x)-0.58)^2)/(0.1^2*2))/(abs(0.1)*sqrt(3.1415926535*2))};
\end{semilogyaxis}
\end{tikzpicture}
\end{document}

Bildbeschreibung hier eingeben

verwandte Informationen