File:TaniaPlot.png: Difference between revisions

From Citizendium
Jump to navigation Jump to search
imported>Dmitrii Kouznetsov
(source)
(== Summary == Importing file)
Tag: Server-side upload
 
(One intermediate revision by one other user not shown)
Line 1: Line 1:
== Summary ==
== Summary ==
{{Image_Details|user
Importing file
|description  = Explicit plot of the [[Tania function]], <math>y=\mathrm{Tania}(x)</math>
|author      = [[User:Dmitrii Kouznetsov|Dmitrii Kouznetsov]]
|date-created = 2011 September 22
|pub-country  = Japan
|notes       
|versions    = http://tori.ils.uec.ac.jp/TORI/index.php/File:TaniaPlot.png
}}
== Licensing ==
{{CC|by|3.0}}
 
==Source==
 
=== [[C++]] generator of the curve===
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#define DB double
#define DO(x,y) for(x=0;x<y;x++)
using namespace std;
#include <complex>
typedef complex<double> z_type;
#define Re(x) x.real()
#define Im(x) x.imag()
#define I z_type(0.,1.)
 
z_type ArcTania(z_type z) {return z + log(z) - 1. ;}
 
z_type ArcTaniap(z_type z) {return 1. + 1./z ;}
 
z_type TaniaTay(z_type z) { int n; z_type s;
s=1.+z*(.5+z*(1./16.+z*(-1./192.+z*(-1./3072.+z*(1.3/6144.+z*(-4.7/147456.
//+z*(7.3/4128768.) //some reserve term
)))))); DO(n,3) s+=(z-ArcTania(s))/ArcTaniap(s); return s ; }
 
z_type TaniaNega(z_type z){int n;z_type s=exp(z-exp(z)+1.);
DO(n,4) s+=(z-ArcTania(s))/ArcTaniap(s); return s ; }
 
z_type TaniaBig(z_type z){int n;z_type s=z; s=z-log(s)+1.;
DO(n,3) s+=(z-ArcTania(s))/ArcTaniap(s); return s ; }
 
z_type TaniaS(z_type z){int n; z_type s,t=z+z_type(2.,-M_PI);t*=2./9.; t=I*sqrt(t);
s=-1.+t*(3.+t*(-3.+t*(.75+t*(.3+t*(.9/16.+t*(-.3/7.+t*(-12.51/224. //+t*(-.9/28.)
)))))));
DO(n,3) s+=(z-ArcTania(s))/ArcTaniap(s); return s ; }
 
z_type Tania(z_type z){ z_type t;
if( fabs(Im(z))< M_PI && Re(z)<-2.51) return TaniaNega(z);
if( abs(z)>7. || Re(z)>3.8 ) return TaniaBig(z);
if( Im(z) > .7 ) return TaniaS(z);
if( Im(z) < -.7) return conj(TaniaS(conj(z)));
return TaniaTay(z);
}
 
void ado(FILE *O, int X, int Y)
{      fprintf(O,"%c!PS-Adobe-2.0 EPSF-2.0\n",'%');
        fprintf(O,"%c%cBoundingBox: 0 0 %d %d\n",'%','%',X,Y);
        fprintf(O,"/M {moveto} bind def\n");
        fprintf(O,"/L {lineto} bind def\n");
        fprintf(O,"/S {stroke} bind def\n");
        fprintf(O,"/s {show newpath} bind def\n");
        fprintf(O,"/C {closepath} bind def\n");
        fprintf(O,"/F {fill} bind def\n");
        fprintf(O,"/o {.1 0 360 arc C S} bind def\n");
        fprintf(O,"/times-Roman findfont 20 scalefont setfont\n");
        fprintf(O,"/W {setlinewidth} bind def\n");
        fprintf(O,"/RGB {setrgbcolor} bind def\n");}
 
#define M(x,y) fprintf(o,"%6.3f %6.3f M\n",0.+x,0.+y);
#define L(x,y) fprintf(o,"%6.3f %6.3f L\n",0.+x,0.+y);
 
main(){ int j,k,m,n; DB x,y, a;
FILE *o;o=fopen("taniaplot.eps","w");ado(o,808,408);
fprintf(o,"404 4 translate\n 100 100 scale\n");
for(m=-4;m<5;m++){ M(m,0)L(m,4)}
for(n=0;n<5;n++){ M(-4,n)L(4,n)}
fprintf(o,".01 W 0 0 0 RGB S\n");
// for(n=0;n<380;n++){y=.02+.01*n; x=ArcTania(y); if(n==0)M(x,y) else L(x,y) }
for(n=0;n<82;n++){ x=-4.03+.1*n; y=Re(Tania(x)); if(n==0)M(x,y) else L(x,y) }
fprintf(o,".03 W 0 .5 0 RGB S\n");
fprintf(o,"showpage\n%cTrailer",'%'); fclose(o);
      system("epstopdf taniaplot.eps");
      system(    "open taniaplot.pdf"); //these 2 commands may be specific for macintosh
getchar(); system("killall Preview");// if run at another operational sysetm, may need to modify
}
 
===[[Latex]] generator of the lables===
 
% Gerenator of TaniaPlot.png  <br>
% Save the paragraph below as  TaniaPlot.tex  <br>
% After the latexing and generation TaniaPlot.pdf  <br>
%> convert TaniaPlot.pdf TaniaPlot.png  <br>
% Copyleft 2011 by Dmitrii Kouznetsov  <br>
\documentclass[12pt]{article} % <br>
\usepackage{geometry} % <br>
\usepackage{graphicx} % <br>
\usepackage{rotating} % <br>
\paperwidth 810pt % <br>
\paperheight 426pt % <br>
\topmargin -103pt % <br>
\oddsidemargin -96pt % <br>
\textwidth 1200pt % <br>
\textheight 600pt % <br>
\pagestyle {empty} % <br>
\newcommand \sx {\scalebox} % <br>
\newcommand \rot {\begin{rotate}} % <br>
\newcommand \ero {\end{rotate}} % <br>
\newcommand \ing {\includegraphics} % <br>
\begin{document} % <br>
\sx{1}{ \begin{picture}(808,410) % <br>
\put(1,9){\ing{taniaplot}} % <br>
\put(388,394){\sx{2.8}{$y$}} % <br>
\put(388,303){\sx{2.8}{$3$}} % <br>
\put(388,203){\sx{2.8}{$2$}} % <br>
\put(388,103){\sx{2.8}{$1$}} % <br>
\put( 86,-9){\sx{2.5}{$-3$}} % <br>
\put(186,-9){\sx{2.5}{$-2$}} % <br>
\put(286,-9){\sx{2.5}{$-1$}} % <br>
\put(400,-9){\sx{2.5}{$0$}} % <br>
\put(500,-9){\sx{2.5}{$1$}} % <br>
\put(600,-9){\sx{2.5}{$2$}} % <br>
\put(700,-9){\sx{2.5}{$3$}} % <br>
\put(796,-9){\sx{2.5}{$x$}} % <br>
\put(560,214){\rot{37}\sx{4}{$y=\mathrm{Tania}(x)$}\ero} % <br>
\end{picture} % <br>
} % <br>
\end{document}

Latest revision as of 18:54, 11 March 2022

Summary

Importing file

File history

Click on a date/time to view the file as it appeared at that time.

Date/TimeThumbnailDimensionsUserComment
current18:54, 11 March 2022Thumbnail for version as of 18:54, 11 March 2022807 × 424 (19 KB)Maintenance script (talk | contribs)== Summary == Importing file

The following page uses this file: