Warning: this is an htmlized version!
The original is here, and the conversion rules are here. |
####### # # E-scripts on programs to typeset deduction trees. # # Note 1: use the eev command (defined in eev.el) and the # ee alias (in my .zshrc) to execute parts of this file. # Executing this file as a whole makes no sense. # An introduction to eev can be found here: # # (find-eev-quick-intro) # http://angg.twu.net/eev-intros/find-eev-quick-intro.html # # Note 2: be VERY careful and make sure you understand what # you're doing. # # Note 3: If you use a shell other than zsh things like |& # and the for loops may not work. # # Note 4: I always run as root. # # Note 5: some parts are too old and don't work anymore. Some # never worked. # # Note 6: the definitions for the find-xxxfile commands are on my # .emacs. # # Note 7: if you see a strange command check my .zshrc -- it may # be defined there as a function or an alias. # # Note 8: the sections without dates are always older than the # sections with dates. # # This file is at <http://angg.twu.net/e/dednat.e> # or at <http://angg.twu.net/e/dednat.e.html>. # See also <http://angg.twu.net/emacs.html>, # <http://angg.twu.net/.emacs[.html]>, # <http://angg.twu.net/.zshrc[.html]>, # <http://angg.twu.net/escripts.html>, # and <http://angg.twu.net/>. # ####### # «.dednat.lua» (to "dednat.lua") # «.dednat.icn» (to "dednat.icn") # «.dednat4-tgz-tests» (to "dednat4-tgz-tests") # «.thereplusxy» (to "thereplusxy") # «.splitdist» (to "splitdist") # «.phantom-nodes» (to "phantom-nodes") # «.tex-src-tgz» (to "tex-src-tgz") # «.eepitch-dednat4» (to "eepitch-dednat4") # «.dednat4-test» (to "dednat4-test") # «.dednat41-test» (to "dednat41-test") # «.dednat4-demo1» (to "dednat4-demo1") # «.dednat41-demo1» (to "dednat41-demo1") # «.tgz:make-demo1» (to "tgz:make-demo1") # «.visible-phantoms» (to "visible-phantoms") # «.dednat4.el» (to "dednat4.el") # «.symlinks» (to "symlinks") # «.dednat4-log» (to "dednat4-log") # «.2008filterp-texsrc» (to "2008filterp-texsrc") # «.lpeg» (to "lpeg") # «.bitlib» (to "bitlib") # «.loop» (to "loop") # «.demo-loop-and-place» (to "demo-loop-and-place") # «.ticked-arrowheads» (to "ticked-arrowheads") # «.enddefdiag» (to "enddefdiag") # «.dednat5» (to "dednat5") # «.idarct» (to "idarct") # «.idarct2017» (to "idarct2017") # «.GA-material-pack» (to "GA-material-pack") # «.hyperboles» (to "hyperboles") # «.dednat6-luarepl» (to "dednat6-luarepl") # «.luarepl» (to "luarepl") # «.thislinetag» (to "thislinetag") # «.processbigstr» (to "processbigstr") # «.hyperlinks» (to "hyperlinks") # «.BOX-dednat6» (to "BOX-dednat6") # «.curve» (to "curve") # «.dednat6.zip-2018» (to "dednat6.zip-2018") # «.dednat6.zip-test» (to "dednat6.zip-test") # «.dednat6.zip-2019» (to "dednat6.zip-2019") # «.contours-new» (to "contours-new") # «.sub-ZHA» (to "sub-ZHA") # «.LPicture-add-pict2e» (to "LPicture-add-pict2e") # «.V.walk» (to "V.walk") # «.LPicture.addrect» (to "LPicture.addrect") # «.TCG.addrect» (to "TCG.addrect") # «.TCGDims» (to "TCGDims") # «.defzha-and-deftcg» (to "defzha-and-deftcg") # «.defub» (to "defub") # «.qmarks-to-cuts» (to "qmarks-to-cuts") # «.dednat6-dnt-from-lua» (to "dednat6-dnt-from-lua") # «.output_dnt» (to "output_dnt") # «.output-no-tex» (to "output-no-tex") # «.hyperlinks-in-LPicture» (to "hyperlinks-in-LPicture") # «.stackexchange» (to "stackexchange") # «.git-repo» (to "git-repo") # «.git-repo-test» (to "git-repo-test") # «.git-repo-update» (to "git-repo-update") # «.makefile» (to "makefile") # «.ctan-guidelines» (to "ctan-guidelines") # «.arxiv-yoneda» (to "arxiv-yoneda") # «.tf:push» (to "tf:push") # «.diaxydoc-and-barrdoc» (to "diaxydoc-and-barrdoc") # «.lua-files-in-ctan-pkgs» (to "lua-files-in-ctan-pkgs") # «.quirks-2019-jul» (to "quirks-2019-jul") # «.colored-arrows» (to "colored-arrows") # «.write_single_tex_file» (to "write_single_tex_file") # «.deletecomments» (to "deletecomments") # «.deletecomments-2021» (to "deletecomments-2021") # «.LR.fromtcgspec-5.3» (to "LR.fromtcgspec-5.3") # «.dednat6-xyoption-2cell» (to "dednat6-xyoption-2cell") # «.ph1-doc» (to "ph1-doc") # «.harrownode» (to "harrownode") # «.extra-modules» (to "extra-modules") # «.converting-TCG-to-TCGQ» (to "converting-TCG-to-TCGQ") # «.dednat4-pdfs-downloading» (to "dednat4-pdfs-downloading") # «.dednat4-texs-converting» (to "dednat4-texs-converting") # «.tikzdiagram» (to "tikzdiagram") # «.plabel-error-handling» (to "plabel-error-handling") # «.bussproofs» (to "bussproofs") # «.at:» (to "at:") # «.texstudio» (to "texstudio") # «.repl-pict» (to "repl-pict") # «.lawvere-tierney» (to "lawvere-tierney") # «.lawvere-tierney-mpunder» (to "lawvere-tierney-mpunder") # «.V3» (to "V3") # «.drawing-polys» (to "drawing-polys") # «.numerozinhos» (to "numerozinhos") # «.error-2021-04-21» (to "error-2021-04-21") # «.color-non-open» (to "color-non-open") # «.pictreplace» (to "pictreplace") # «.burghardt» (to "burghardt") # «.lean-nng» (to "lean-nng") # «.fitch» (to "fitch") # «.ftch» (to "ftch") # «.slides-to-pngs» (to "slides-to-pngs") # «.dednat7-dednat7» (to "dednat7-dednat7") # «.dednat7-leonan-2024» (to "dednat7-leonan-2024") # (find-blogme3 "sandwiches-defs.lua" "code-pdf-page-tests") # (code-pdf-page "dn6slides" "~/dednat6/tug-slides.pdf") # (code-pdf-text "dn6slides" "~/dednat6/tug-slides.pdf") # (code-pdf-page "dn6article" "~/dednat6/tugboat-rev2.pdf") # (code-pdf-text "dn6article" "~/dednat6/tugboat-rev2.pdf") ##### # # dednat.lua (obsolete) # 2001may15 # ##### # «dednat.lua» (to ".dednat.lua") # (find-angg "LUA/dednat.lua") # (find-angg "LATEX/Makefile") # (find-angg "LATEX/Makefile" "dednat.lua") # (find-angg "LATEX/Makefile" "dn_to_dnt") #* # (find-angg "LATEX/tese2.sty") # (find-angg "LATEX/proof.edrx.sty") cd ~/LATEX/ rm -v tmp.dn tmp.dnt cat > tmp.tex <<'%%%' % \input tese2.sty \documentclass{book} \usepackage{proof.edrx} \def\ded#1{\csname ded-#1\endcsname} \def\defded#1#2{\expandafter\def\csname ded-#1\endcsname{#2}} \input tmp.dnt \begin{document} % %:*->*\to * %: %: a [a->b]^1 %: ----------- %: b %: ---------1 %: (a->b)->b %: %: ^dedtest %: $$\ded{dedtest}$$ % \end{document} %%% make tmp.dvi rexdvi tmp.dvi #* ##### # # dednat.icn (obsolete) # 2001may15 # ##### # «dednat.icn» (to ".dednat.icn") # (find-angg "LATEX/dednat.icn") ##### # # dednat4: tgz and tests # 2008may26 # ##### # «dednat4-tgz-tests» (to ".dednat4-tgz-tests") # (find-es "xypic") # (find-es "xypic" "dednat41-test") # (find-es "xypic" "dednat41-demo1") # (find-es "xypic" "eepitch-dednat4") # (find-angg ".emacs" "eepitch-dednat4") # (find-angg ".emacs" "dednat4") # (find-angg ".emacs" "eedn4a") # (find-dn4 "") # (find-dn4 "Makefile") # The README is crap: # (find-dn4file "README") # This is ok - copy to the dednat4/ dir: # (find-THLw3m "dednat4.html") # (find-TH "dednat4") # (find-sh "grep IMG ~/TH/dednat4.blogme") # It needs a hacker's guide, though... get logs from: # (find-es "xypic" "eepitch-dednat4") # Add: at: x y tag # .xy+= x y # there+: x y tag # (find-anggfile "IMAGES/Atimes-dnt.png") # (find-anggfile "IMAGES/Atimes.png") # (find-anggfile "IMAGES/TfromFtoG.png") # (find-anggfile "IMAGES/eqfib-trans.png") # (find-anggfile "IMAGES/lccc-bcc.png") # (find-anggfile "IMAGES/lccc-frob.png") # (find-anggfile "IMAGES/preslim.png") # (find-zsh " cd ~/IMAGES/ A=( Atimes-dnt.png Atimes.png TfromFtoG.png eqfib-trans.png lccc-bcc.png lccc-frob.png preslim.png ) laf $A ") ##### # # there+xy: # 2008jun01 # ##### # «thereplusxy» (to ".thereplusxy") # (find-LATEXfile "2008sheaves.tex" "thereplusxy =") ##### # # understand harrownodes and varrownodes # 2008jun02 # ##### # «splitdist» (to ".splitdist") # (find-dn4 "dednat41.lua") # (find-dn4 "experimental.lua") Suppose that we want to draw a diagram like this one: A |-----> FA | - | |-> | v v B |-----> FB * (eepitch-dednat4) * (eepitch-kill) * (eepitch-dednat4) require "experimental" = splitdist(100, 200, nil, 20, nil) --> 140 160 ##### # # Documentation about phantom nodes # 2008jun24 # ##### # «phantom-nodes» (to ".phantom-nodes") # Moved to: (find-dn4 "README.phantoms") ##### # # LaTeX source tarballs for my .texs # 2008jun08 # ##### # «tex-src-tgz» (to ".tex-src-tgz") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/te/ mkdir /tmp/te/ cd /tmp/te/ # (find-fline "~/LATEX/2008bcc.tex") F=$HOME/LATEX/2008bcc.tex cp -av $F . cp -av ~/dednat4/examples/edrx08.sty . cp -av ~/dednat4/examples/edrxdnt.tex . cp -av ~/dednat4/examples/edrxdefs.tex . cp -av ~/dednat4/examples/edrxheadfoot.tex . ~/dednat4/dednat41 $(basename $F) cp -av $S/http/www.ctan.org/tex-archive/macros/latex/contrib/lkproof/proof.sty . unzip -o $S/ftp/ftp.math.mcgill.ca/pub/barr/diagxy.zip diagxy.tex latex $(basename $F) # (find-fline "/tmp/te/") # (find-dn4exfile "") # (find-dn4file "Makefile") # (find-dn4file "Makefile" "TATPROOFSFILE =") # (find-dn4file "Makefile" "DIAGXYFILE") # Add this? # (find-dn4file "dednat41.lua") # Generated by dednat41.lua ##### # # eepitch-dednat4 # 2008may11 # ##### # «eepitch-dednat4» (to ".eepitch-dednat4") # (find-angg ".emacs" "eepitch-dednat4") # (find-angg "LUA/lua50init.lua" "load_dednat4") # (find-dn4 "dednat41.lua") # (find-dn4 "dednat41.lua" "tree-lib" "dolinenumbers") * (eepitch-dednat4) * (eepitch-kill) * (eepitch-dednat4) PP(abbrevs) process "/home/edrx/dednat4/examples/edrx08.sty" PP(abbrevs) PP(heads) * (eepitch-dednat4) * (eepitch-kill) * (eepitch-dednat4) dolinenumbers = nil diagram "miniadj" dxy2Dx " 100 140 " dxy2D " 140 a^L <= a " dxy2D " - - " dxy2D " | | " dxy2D " v v " dxy2D " 100 b => b^R " PP("nodes =", nodes) pushtag "a^L"; pushtag "a"; dof "<=" pushtag "a^L"; pushtag "b"; dof "|->" pushtag "a"; pushtag "b^R"; dof "|->" pushtag "b"; pushtag "b^R"; dof "=>" PP("arrows =", arrows) enddiagram() * (eepitch-dednat4) * (eepitch-kill) * (eepitch-dednat4) dolinenumbers = nil mytostringk = mytostringk2 dofs "diagram miniadj2" dofs "2Dx 100 140 " dofs "2D 140 a^L <= a " dofs "2D - - " dofs "2D | | " dofs "2D v v " dofs "2D 100 b => b^R " dofs "(( a^L a <= a^L b |-> a b^R |->" printf("xs = %s\n", mytostring(xs)) for i=1,#nodes do printf("nodes[%d] = %s\n", i, mytostring(nodes[i])) end for i=1,#arrows do printf("arrows[%d] = %s\n", i, mytostring(arrows[i])) end for i=1,#ds do printf("ds[%d] = %s\n", i, mytostring(ds[i])) end for i=1,#depths do printf("depths[%d] = %s\n", i, mytostring(depths[i])) end PP(keys(nodes)) dofs " b b^R => ))" dofs "enddiagram" Note: due to a bad design decision the elements of ds are "in the wrong order" - to push a new element we move the old elements from the positions 1..n to 2..n+1, and then we set ds[1] to the new element... this simplifies accessing the elements at the top of the stack, but complicates all the rest - especially "@" and operations with the array "depths". One possible fix (dirty trick): use a metatable with a "__call" entry for the table "ds"; make ds(2) return ds[-2] for any value of 2. Notes (obsolete): %L at = function (index) return ds[#ds - depths[1] - index] end %L PP("@ 0 =", at(0)) %L PP("@ 1 =", at(1)) %L PP("@ 2 =", at(2)) %L PP(ds[#ds]) %L PP(ds[#ds - 1]) %L PP(#ds) %L PP(ds) %L mytostringk = mytostringk2 %L printf("xs = %s\n", mytostring(xs)) %L for i=1,#nodes do printf("nodes[%d] = %s\n", i, mytostring(nodes[i])) end %L for i=1,#arrows do printf("arrows[%d] = %s\n", i, mytostring(arrows[i])) end %L for i=1,#ds do printf("ds[%d] = %s\n", i, mytostring(ds[i])) end %L for i=1,#depths do printf("depths[%d] = %s\n", i, mytostring(depths[i])) end %L PP(keys(nodes)) % (find-sh "cd ~/LATEX/ && lua51 ~/dednat4/dednat41.lua tmp.tex") % (find-angg "LUA/lua50init.lua") ##### # # Testing dednat41 # 2008may19 # ##### # «dednat4-test» (to ".dednat4-test") # «dednat41-test» (to ".dednat41-test") # (find-dn4 "Makefile") # (find-node "(kpathsea)File lookup") # (find-dn4exfile "dednat4.el") # (find-eevtmpfile "") # (find-eevtmpfile "ee.sh") # (find-LATEXfile "" "tmp.tex") # (find-LATEXfile "tmp.tex") # (find-LATEXfile "ee.tex") # (find-angg ".emacs") # (find-angg ".emacs" "dednat4") # (find-es "xypic" "eepitch-dednat4") # (find-angg ".emacs" "eedn4a") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/dntest/ mkdir /tmp/dntest/ cd /tmp/dntest/ cd ~/dednat4/ make S=$S TEXDIR=/tmp/dntest texfiles cd /tmp/dntest/ DN4EXDIR=$HOME/dednat4/examples/ cp -v $DN4EXDIR/edrxmain41a.tex tmp.tex cp -v $DN4EXDIR/eedemo1.tex ee.tex cp -v $DN4EXDIR/edrx08.sty edrx08.sty ~/dednat4/dednat41 tmp.tex TEXINPUTS=$DN4EXDIR: latex tmp.tex # (find-fline "/tmp/dntest/") # (find-fline "/tmp/dntest/tmp.tex") # (find-dvipage "/tmp/dntest/tmp.dvi") # «dednat4-demo1» (to ".dednat4-demo1") # «dednat41-demo1» (to ".dednat41-demo1") # (find-dn4 "Makefile" "demo1") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/dednat4/ rm -Rv demos/ mkdir demos/ make demo1 # (find-dn4 "demos/") # (find-man "unzip") ##### # # dednat4: "make demo1" (from the tarball) # 2008jun25 # ##### # «tgz:make-demo1» (to ".tgz:make-demo1") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/dn4t/ mkdir /tmp/dn4t/ cd /tmp/dn4t/ tar -xvzf ~/dednat4/dednat4.tgz make S=$S demo1 |& tee om # (find-fline "/tmp/dn4t/") ##### # # visible phantoms # 2008jun27 # ##### # «visible-phantoms» (to ".visible-phantoms") # (find-fline "~/tmp/phantom-nodes.png") %* % (eedn4a-bounded) %L phantomnode = "\\myphantom{O}" \def\myphantom{\phantom} %D diagram harrowdemo %D 2Dx 100 +30 %D 2D 100 A |-----> FA %D 2D | - %D 2D f | |-> | Ff %D 2D v v %D 2D +30 B |-----> FB %D 2D %D (( A FA |-> %D A B -> .plabel= l f %D FA FB -> .plabel= r Ff %D B FB |-> %D A FB harrownodes nil 20 nil |-> %D )) %D enddiagram %D $$\diag{harrowdemo} \qquad {\def\myphantom{\red} \diag{harrowdemo} } $$ %* ##### # # dednat4.el # 2008jun27 # ##### # «dednat4.el» (to ".dednat4.el") # (find-dn4 "dednat4.el") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/dednat4/ lua51 -e 'dofile"dednat41.lua"' -i require "experimental" ##### # # symlinks: tmp.tex -> edrxmain41.tex and ee.tex -> eedemo1.tex # 2008jun27 # ##### # «symlinks» (to ".symlinks") # (find-dn4file "Makefile") # Removed from the makefile: # Ooops - here I am symlinking tmp.tex -> edrxmain41a.tex... What # happens if I copy something to tmp.tex later? Does it cease to be a # symlink, or does it overwrite edrxmain41a.tex? # # Possible solution: do not symlink - edrxmain41a.tex has a header # that explains from where it comes. #demo1-old: dednat41 texfiles # mkdir -p $(DEMODIR) # ln -sf $(DN4EXDIR)/edrxmain41a.tex $(DEMODIR)/tmp.tex # ln -sf $(DN4EXDIR)/edrx08.sty $(DEMODIR)/edrx08.sty # ln -sf $(DN4EXDIR)/eedemo1.tex $(DEMODIR)/ee.tex # cd $(DEMODIR) && $(PWD)/dednat41 tmp.tex # cd $(DEMODIR) && TEXINPUTS=$(TEXDIR): latex tmp.tex # cd $(DEMODIR) && ln -sf edrxmain41a.tex tmp.tex # cd $(DEMODIR) && ln -sf eedemo1.tex ee.tex ##### # # dednat4-log.html # 2008jul12 # ##### # «dednat4-log» (to ".dednat4-log") # (find-THgrep "grep -niH -e traffic *") # (find-blogme3grep "grep -niH -e traffic *") # (find-blogme3 "anggdefs.lua" "TRAFFIC") # (find-TH "dednat4") # (find-TH "dednat4-log") # (find-es "blogme" "traffic-lights-glyphs") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd rm -Rv mkdir /tmp/dn4/ cd ~/dednat4/ make tarball mkdir /tmp/dn4/ cd /tmp/dn4/ wget http://angg.twu.net/dednat4/dednat4.tgz tar -xvzf dednat4.tgz make make dednat4 make texfiles make demo2 ##### # # 2008filterp-texsrc.tar.gz # 2008jul12 # ##### # «2008filterp-texsrc» (to ".2008filterp-texsrc") # http://angg.twu.net/math/ # (find-twusfile "") # (find-twusfile "math/") # (find-twusfile "LATEX/") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/fi/ mkdir /tmp/fi/ cd ~/LATEX/ cp -aiv 2008filterp.{tex,dnt} filters.bib /tmp/fi/ cd /tmp/fi/ ~/dednat4/.files.sh eval "{ texedrx ; texother; } | prepends" cp -aiv $(~/dednat4/.files.sh eval "{ texedrx ; texother; } | prepends") . rm -v edrxmain*.tex tar -cvzf /tmp/2008filterp-texsrc.tar.gz * laf /tmp/2008filterp-texsrc.tar.gz laf ~/dednat4/dednat4 2008filterp.tex latex 2008filterp.tex bibtex 2008filterp latex 2008filterp.tex latex 2008filterp.tex # (ee-cp "/tmp/2008filterp-texsrc.tar.gz" (ee-twusfile "LATEX/2008filterp-texsrc.tar.gz") 'over) ##### # # The "lpeg" and "bitlib" targets in the Makefile # 2008jul21 # ##### # «lpeg» (to ".lpeg") # «bitlib» (to ".bitlib") # (find-dn4 "Makefile" "lpeg") # (find-dn4 "Makefile" "bitlib") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/dednat4/ && make tmpdir cd /tmp/dn4/ tar -xvzf /tmp/dulua.tgz make S=$S luabuild tar -cvzf /tmp/dulua.tgz usrc/lua-5.1.3/ make S=$S lpegbuild make S=$S bitlibbuild ./lua51 require "lpeg" PP(lpeg) assert(package.loadlib("./lbitlib.so", "luaopen_bit"))() print(bit.bxor(6,3)) os.exit() ##### # # \Loop # 2008aug01 # ##### # «loop» (to ".loop") # (find-diagxypage 29 "\\Loop") # (find-diagxytext "\\Loop") # (find-dn4 "experimental.lua") # (find-dn4 "experimental.lua" "loop") %* % (eedn4a-bounded) %D diagram ?? %D 2Dx 100 +30 +30 %D 2D 100 a --> b %D 2D v %D 2D +20 c d %D 2D %D (( a b -> b c -> %D a loop (ul,dl)_{aa} %D b loop (u,r) %D c loop (dl,dr) %D d place %D )) %D enddiagram %D $$\diag{??}$$ %* % (eedn4a-bounded) $$\bfig \morphism[A`B;f] \Loop(0,0)A(ur,ul)_g \Loop(0,0)A(ur,ul)^a \Loop(500,0)B(dl,dr)_h \Loop(1000,0)CC(dl,dr) % \Loop(1500,0)DD \efig $$ %* ##### # # demo-loop-and-place # 2022feb08 # ##### # «demo-loop-and-place» (to ".demo-loop-and-place") %D diagram demo-loop-and-place %D 2Dx 100 +15 +15 %D 2D 100 NW N NE %D 2D +15 W C E %D 2D +15 SW S SE %D 2D %D (( NW loop (l,u) N loop (ul,ur) NE loop (u,r) %D W loop (dl,ul) C place E loop (ur,dr)^{abc} %D SW loop (d,l) S loop (dr,dl) SE loop (r,d) %D )) %D enddiagram %D $$\pu \diag{demo-loop-and-place} $$ -- (find-dn6 "diagforth.lua" "arrows") -- (find-dn6 "diagforth.lua" "arrows" "loop") -- (find-dn6 "diagtex.lua" "DxyLoop") ##### # # ticked arrowheads # 2009feb26 # ##### # «ticked-arrowheads» (to ".ticked-arrowheads") from Michael Barr <barr@math.mcgill.ca> to Categories list <categories@mta.ca> date Wed, Feb 25, 2009 at 10:08 PM subject categories: ticked arrowheads in xy-pic and diagxy A month or two ago, Micah McCurdy wrote to ask me if it was possible to make an arrow with a tick in the middle (that is ----+---->) and I said I didn't know how to do that and suggested he ask Ross Moore. Ross told him that xy-pic didn't have that capacity. Well, Micah discovered that it did. Here are some samples, using diagxy, but that is just a front end to xy-pic. %* % (eedn4a-bounded) $$\bfig \node a(0,0)[A] \node b(300,400)[B] \arrow/@{>}|-*@{>}/[a`b;f] \efig$$ $$\bfig \ptriangle/>`>`@{>}|-@{|}/[A`B`C;f`g`h] \efig$$ $$\bfig \morphism/@{>}|-@{+}/<700,0>[ABCDE`F;h] \efig$$ $$\bfig \morphism/@{>}|-*@{|}/<700,0>[ABCDE`F;h] \efig$$ %* As far as I can tell, the * between the - and the @ has no effect. The one limitation is that what goes inside the -@{ } must be a \dir. This is a limitation for me, since I cannot figure out the syntax of \newdir. For this to work, it clearly has to be something that tex can rotate. Michael from Michael Barr <barr@math.mcgill.ca> to Categories list <categories@mta.ca> date Sat, Feb 28, 2009 at 1:55 PM subject categories: More arrow decorations By playing with Micah's discovery (which is actually documented on page 39, third line from the bottom of Fig. 13), I have come up with the following potentially useful decorations: %* % (eedn4a-bounded) $$\bfig \morphism/@{>}|-@{|}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{x}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{o}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{*}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{||}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{)}/<500,500>[A`B;f] \efig$$ $$\bfig \morphism/@{>}|-@{(}/<500,500>[A`B;f] \efig$$ %* The same ideas also work in native xy-pic and, for all I know, in the matrix version as well. ##### # # enddefdiag # 2009aug11 # ##### # «enddefdiag» (to ".enddefdiag") # (find-dn4 "experimental.lua" "def") %* % (eedn4a-bounded) % (find-sh0 "cd ~/LATEX/ && dvips -D 300 -P pk -o tmp.ps tmp.dvi") % (find-sh0 "cd ~/LATEX/ && dvired -D 300 -P pk -o tmp.ps tmp.dvi") % (find-pspage "~/LATEX/tmp.ps") %D diagram pmetauniv %D 2Dx 100 +20 %D 2D 100 #1 %D 2D - %D 2D #4| %D 2D v %D 2D +20 #2 ==> #3 %D 2D %D (( #1 #3 |-> .plabel= l #4 %D #2 #3 => %D )) %D enddefpdiagram 4 $$\pmetauniv abcd$$ %* ##### # # dednat5 # 2010apr20 # ##### # «dednat5» (to ".dednat5") # (find-dn4 "dednat4.lua") # (find-dn4 "dednat5.lua") # (find-dn4 "dednat5-shadow.lua") # (find-tkdiff "~/dednat4/dednat4.lua" "~/dednat4/dednat5.lua") # (find-dn5 "") ##### # # How to build "idarct-preprint.pdf" # 2015sep30 / 2017mai01 # ##### # «idarct» (to ".idarct") # (find-angg ".emacs" "idarct") # https://mail.google.com/mail/ca/u/0/#search/idarct/13f82428ec76b6e3 <- tgz # # http://angg.twu.net/math-b.html#idarct # file:///home/edrx/TH/L/math-b.html#idarct # (find-TH "math-b" "internal-diags-in-ct") # (find-TH "math-b" "internal-diags-in-ct" "idarct-preprint.pdf") # (find-idarct0file "") # (find-idarct0file "Makefile") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) laf -d ~/LATEX/idarct/ laf ~/LATEX/idarct/ rm -Rv ~/LATEX/idarct/ mkdir ~/LATEX/idarct/ tar -C ~/LATEX/idarct/ -xvzf ~/LATEX/idarct.tgz cd ~/LATEX/idarct/ make idarct-preprint.dvi make idarct-preprint.pdf * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/dednat6/tests/ cp -v proof.sty ~/LATEX/idarct/ cd ~/LATEX/idarct/ make idarct-preprint.dvi dvipdf idarct-preprint.dvi cd ~/LATEX/idarct/ cp -v idarct-preprint.dvi ~/LATEX/ cp -v idarct-preprint.pdf ~/LATEX/ cp -v frob-sketch.eps ~/LATEX/ cp -v diagxy.tex ~/LATEX/idarct/ ##### # # 2017idarct.tex: an attempt to port idarct to dednat6 # 2019apr22 # ##### # «idarct2017» (to ".idarct2017") # (find-LATEX "2017idarct.tex") ##### # # 2015-2-GA-material: pack into a zip file # 2016feb15 # ##### # «GA-material-pack» (to ".GA-material-pack") # Superseded by: (find-angg "LUA/flsfiles.lua") # (find-angg "LATEX/2015-2-GA-material.tex") # (find-xpdfpage "~/LATEX/2015-2-GA-material.pdf") # Preparation: # (find-dn6 "dednat6.lua" "run-tests-in-test-dir") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/ga/ mkdir /tmp/ga/ cd ~/LATEX/ A=( 2015-2-GA-material.tex diagxy.tex edrx15.sty edrx15defs.tex edrxaccents.tex edrxdnt.tex edrxheadfoot.tex edrxtikz.lua istanbuldefs.tex ) cp -v $A /tmp/ga/ mkdir /tmp/ga/dednat6/ unzip -d /tmp/ga/dednat6/ /tmp/dednat6.zip zip -r /tmp/ga.zip * lualatex 2015-2-GA-material.tex # (find-fline "/tmp/ga.zip") # (find-man "zip") cd /tmp/ga/ lualatex -recorder 2015-2-GA-material.tex # (find-fline "/tmp/ga/2015-2-GA-material.fls") # (find-sh "sort /tmp/ga/2015-2-GA-material.fls") # (find-sh "sort /tmp/ga/2015-2-GA-material.fls | grep -v /usr/") ##### # # Hyperboles # 2016jul17 # ##### # «hyperboles» (to ".hyperboles") # (find-LATEX "2016-1-GA-material.tex") = v(3,4) = v(3,4):norm() * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() chdir "~/LATEX/" dofile "edrxtikz.lua" -- (find-LATEX "edrxtikz.lua") -- (find-LATEX "edrxtikz.lua" "Hyperbole") PP(V) ##### # # dednat6/luarepl # 2016oct07 / 2019jan06 # ##### # «dednat6-luarepl» (to ".dednat6-luarepl") # «luarepl» (to ".luarepl") # (find-LATEX "2018dednat6-repl.tex") # (find-LATEX "2018tug-dednat6.tex" "repls-2") # Old: # (find-es "lua5" "lua-repl-2016") ##### # # thislinetag # 2017ago09 # ##### # «thislinetag» (to ".thislinetag") # (find-es "luatex" "thislinetag") # (find-LATEX "2017cwm.tex" "thislinetag") ##### # # processbigstr (for interactive tests) # 2017dez30 # ##### # «processbigstr» (to ".processbigstr") # (find-dn6 "texfile.lua" "processbigstr") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() processbigstr [[ %D diagram foo %D 2Dx 100 +30 %D 2D 100 a <-| b %D 2D | | %D 2D v v %D 2D +20 c ==> d %D 2D %D (( a b <-| a c -> b d -> c d => %D )) %D enddiagram ]] ##### # # Hyperlinks to source # 2017dez31 # ##### # «hyperlinks» (to ".hyperlinks") # (find-dn6 "texfile.lua" "TexFile" "hyperlink =") # (find-dn6 "diagforth.lua" "enddiagram") # (find-dn6 "diagforth.lua" "enddiagram" "no hyperlink yet") # (find-dn6 "diagforth.lua" "enddiagram" "tf:hyperlink()") # (find-dn6file "treetex.lua" "tf:hyperlink()") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() bigstr = [[ %: a b %: ----? %: c %: %: ^foo %: %D diagram bar %D 2Dx 100 +30 %D 2D 100 a <-| b %D (( a b <-| %D )) %D enddiagram ]] processbigstr(bigstr) hyperlinkfmt = '(find-es "dednat" "hyperlinks" (+ 9 %s))' processbigstr(bigstr) no hyperlink yet = format("foo", 10) = format('(find-fline "foo" %d)', 10) ##### # # Porting BOX to dednat6 # 2017dez29 # ##### # «BOX-dednat6» (to ".BOX-dednat6") # (find-dn6 "diagforth.lua" "BOX") # # (find-dn4 "experimental.lua" "BOX") # (find-dn4 "examples/edrx08.sty" "savebox") # (find-dn4 "examples/edrx08.sty" "diagprep") # (find-idarct0file "2010diags-body.tex") # (find-idarct0file "2010diags-body.tex" "dnc .tex=" "BOX") # (find-idarct0file "2010diags.dnt") # (find-idarct0file "2010diags.dnt" "\\savebox{\\myboxa}{$\\fcded{dict-1-dnc}$}") # (find-dn6 "preamble6.lua" "preamble1") # (find-dn6 "diagforth.lua" "enddiagram") # (find-dn6 "diagtex.lua" "arrows_to_defdiag") # (find-dn6grep "grep -nH -e arrows_to_defdiag *") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() bigstr = [[ %: a b d e %: ----? ----! %: c f %: %: ^foo ^bar %: %D diagram plic %D 2Dx 100 +30 %D 2D 100 foo -> bar %D %D (( foo .tex= \fcded{foo} BOX %D bar .tex= \fcded{bar} BOX %D foo bar -> %D )) %D enddiagram ]] processbigstr(bigstr) ##### # # .curve= # 2018dec22 # ##### # «curve» (to ".curve") # (find-dn6grep "grep --color -nH -e curve *.lua") # (find-dn6 "diagtex.lua" "arrow_to_TeX-test") # (find-dn6 "diagtex.lua" "arrow_to_TeX" "curve =") # (find-dn6 "diagforth.lua" ".curve=") # (find-es "diagxy" "moving-labels") # (find-es "diagxy" "shape") # Old: # (find-dn4grep "grep --color -nH -e curve *") # (find-LATEXgrep "grep --color -nH -e '.curve=' *.tex") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() require "diagtex" test = function (A) print(arrow_to_TeX(A)) end storenode {TeX="a", tag="a", x=100, y=100} storenode {TeX="b", tag="b", x=140, y=100} test {from="a", to="b", shape="|->"} test {from="a", to="b", shape="|->", label="up", placement="a"} test {from="a", to="b", shape="|->", label="up", placement="a", slide="5pt"} test {from="a", to="b", shape="|->", label="up", lplacement="_(0.42)"} -- err? ##### # # dednat6.zip: 2018 version (just after the TUGBoat article) # 2018dec23 # ##### # «dednat6.zip-2018» (to ".dednat6.zip-2018") # (find-latex-upload-links "2018dednat6-extras") # (find-angg ".zshrc" "flsfiles") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/LATEX/ cat ~/LATEX/2018tugboat-rev1.fls \ ~/LATEX/2018tug-dednat6.fls \ ~/LATEX/2018dednat6-extras.fls \ ~/LATEX/2018dednat6-minimal.fls \ ~/LATEX/2018dednat6-repl.fls \ ~/LATEX/2018dednat6-no-lua.fls \ > /tmp/o.fls flsfiles /tmp/o.fls | tee /tmp/o2.fls (TZ=GMT date; date) > VERSION rm dednat6.zip zip dednat6.zip $(cat /tmp/o2.fls) \ 2018tugboat-rev1.pdf \ 2018tug-dednat6.pdf \ 2018dednat6-extras.pdf \ 2018dednat6-minimal.pdf \ 2018dednat6-no-lua.pdf \ VERSION laf dednat6.zip # (find-sh "unzip -lv ~/LATEX/dednat6.zip") cd ~/LATEX/ Scp-np -v dednat6.zip edrx@angg.twu.net:/home/edrx/slow_html/ Scp-np -v dednat6.zip edrx@angg.twu.net:/home/edrx/public_html/ # «dednat6.zip-test» (to ".dednat6.zip-test") # (find-LATEX "2018dednat6-extras.tex" "dednat6.zip-test") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/dn6-test/ mkdir /tmp/dn6-test/ cd /tmp/dn6-test/ wget http://angg.twu.net/dednat6.zip # cp -v ~/LATEX/dednat6.zip . unzip dednat6.zip rm -v *.pdf lualatex 2018tugboat-rev1.tex lualatex 2018tugboat-rev1.tex lualatex 2018tug-dednat6.tex lualatex 2018tug-dednat6.tex lualatex 2018dednat6-extras.tex lualatex 2018dednat6-extras.tex lualatex 2018dednat6-minimal.tex lualatex 2018dednat6-no-lua.tex mkdir no-lua/ cd no-lua/ cp -v ../2018dednat6-no-lua.tex ../2018dednat6-no-lua.dnt . pdflatex 2018dednat6-no-lua.tex * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/dn6-test-min/ mkdir /tmp/dn6-test-min/ cd /tmp/dn6-test-min/ # wget http://angg.twu.net/dednat6.zip cp -v ~/LATEX/dednat6.zip . unzip dednat6.zip "dednat6/**" dednat6load.lua 2018dednat6-minimal.tex lualatex 2018dednat6-minimal.tex xpdf 2018dednat6-minimal.pdf * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/dn6-test-no-lua/ mkdir /tmp/dn6-test-no-lua/ cd /tmp/dn6-test-no-lua/ # wget http://angg.twu.net/dednat6.zip cp -v ~/LATEX/dednat6.zip . unzip dednat6.zip "dednat6/**" dednat6load.lua 2018dednat6-no-lua.tex lualatex 2018dednat6-no-lua.tex mkdir no-lua/ cd no-lua/ cp -v ../2018dednat6-no-lua.tex ../2018dednat6-no-lua.dnt . pdflatex 2018dednat6-no-lua.tex xpdf 2018dednat6-no-lua.pdf # (find-fline "/tmp/dn6-test/") # (find-fline "/tmp/dn6-test-min/") ##### # # dednat6.zip: version of may 2019 # 2019may15 # ##### # «dednat6.zip-2019» (to ".dednat6.zip-2019") # (find-TH "dednat6" "testing:script") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/LATEX/ cat ~/LATEX/2018tugboat-rev1.fls \ ~/LATEX/2018tug-dednat6.fls \ ~/LATEX/2018dednat6-extras.fls \ ~/LATEX/2018dednat6-minimal.fls \ ~/LATEX/2018dednat6-repl.fls \ ~/LATEX/2018dednat6-no-lua.fls \ > /tmp/o.fls flsfiles /tmp/o.fls | tee /tmp/o2.fls (TZ=GMT date; date) > VERSION rm dednat6.zip zip dednat6.zip $(cat /tmp/o2.fls) \ 2018dednat6-preproc.tex \ 2018tugboat-rev1.pdf \ 2018tug-dednat6.pdf \ 2018dednat6-extras.pdf \ 2018dednat6-minimal.pdf \ VERSION laf dednat6.zip # (find-sh "unzip -lv ~/LATEX/dednat6.zip") cd ~/LATEX/ Scp-np -v dednat6.zip edrx@angg.twu.net:/home/edrx/slow_html/ Scp-np -v dednat6.zip edrx@angg.twu.net:/home/edrx/public_html/ # (find-TH "dednat6" "testing:script") # (find-twusfile "") ##### # # New code for contours # 2018dec30 # ##### # «contours-new» (to ".contours-new") # (find-dn6 "zhas.lua" "ZHA-walls") # (find-dn6 "zhas.lua" "Cuts-tests") # (find-dn6file "zhas.lua" "addcuts =") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() z = ZHA.fromspec("123432343234321") = z z:PP() PP(z:leftwallgenerators()) contourstr = function (z) local str = "00s" local store = function (s) str = str.."-"..s end for _,P in ipairs(z:leftwallgenerators()) do local l1,r1 = P:to_l_r() local l0 = l1-1 local r0 = z.minr[l0] store(l0..r0.."w-"..l1..r1.."s") end store(z.topl..z.minr[z.topl].."w") store(z.topl..z.topr.."n") store(z.minl[z.topr]..z.topr.."e") rwgens = z:rightwallgenerators() for i=#rwgens,1,-1 do local P = rwgens[i] local l1,r1 = P:to_l_r() local r0 = r1-1 local l0 = z.minl[r0] store(l1..r1.."s-"..l0..r0.."e") end return str end = contourstr(z) = z A implementação atual é meio tosca. O ideal seria que eu adicionasse na classe V, e na função v, o suporte a sufixos como s, n, e, w... ##### # # Using a sub-ZHA (as in PHA3) # 2018dec30 # ##### # «sub-ZHA» (to ".sub-ZHA") # (find-LATEX "2017planar-has-3.tex" "classifier") # (find-dn6grep "grep --color -nH -e addcuts *.lua") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() z = ZHA.fromtcgspec("4, 5; 32, 14 25"):print() mp = MixedPicture.new({}, z):addlrs():addcutssub("34", "c"):print() mp = MixedPicture.new({}, z):addlrs():addcuts("2/1"):print() mp = MixedPicture.new({}, z):addlrs():addcuts("4/3"):print() mp = MixedPicture.new({}, z):addlrs():addcuts("5/4"):print() mp = MixedPicture.new({}, z):addlrs():addcuts("2|3"):print() z:PP() -- (find-dn6 "zhas.lua" "MixedPicture-zha") -- (find-dn6 "zhas.lua" "MixedPicture-zhalrf-tests") myspec = "1R2R3212RL1" mycuts = "c 4321/0 0123|45|6" mytop = v"35" myf = "lr -> lr:below(mytop) and lr:lr() or '..'" mp = mpnew({}, myspec):addcutssub(mytop, mycuts):addlrs():print() mp = mpnew({}, myspec):addcutssub(mytop, mycuts):adddots():print() mp = mpnew({}, myspec):addcutssub(mytop, mycuts):zhalrf0(myf):print() mytop = v"34" mp = mpnew({}, myspec):addcutssub(mytop, mycuts):zhalrf0(myf):print() mp:print() * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() myspec = "1232RL1" mycuts = "c 32/10 012|3" mytop = v"35" myf = "lr -> lr:below(mytop) and lr:lr() or '..'" foo = function (top, opts) mytop = v(top) mpnew(opts, myspec):addcutssub(mytop, mycuts):zhalrf0(myf):print() end foo("33", {}) foo("32", {}) foo("20", {}) foo("10", {}) -- (find-LATEX "2017planar-has-1.tex" "topologies-as-HAs") -- (find-LATEX "2017planar-has-1.tex" "topologies-on-2CGs") -- (ph1 "topologies-on-2CGs") -- (ph1 "topologies-on-2CGs" ":addgens()") -- (ph1p 27 "topologies-on-2CGs") -- (ph1p 30) -- (find-dn6file "zhas.lua" "addgens =") ##### # # Adding arbitrary pict2e code to an LPicture object # 2019apr27 # ##### # «LPicture-add-pict2e» (to ".LPicture-add-pict2e") # (find-dn6 "picture.lua" "LPicture") # (find-dn6 "picture.lua" "LPicture" "addtex =") # (find-dn6 "picture.lua" "LPicture" "addtex =" "addt") # (find-dn6 "zhas.lua" "MixedPicture") # (find-dn6 "zhas.lua" "MixedPicture-zhalrf-tests") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() mp = mpnew({}, "123454321") mp = mpnew({}, "123454321"):addlrs() mp = mpnew({}, "123454321"):addlrs():addcontour() mp:print() mp:lprint() mp.lp:print() mp.lp:addtex("HELLO"):print() mp.lp:addtex("HELLO"):print() mp.lp:addt("\\polygon%s%s%s%s", 2, 3, 4, 5):print() PPV(LPicture.__index) PPV(MixedPicture.__index) mp = mpnew({}, "123454321") ##### # # Adding a V.walk method and support for things like "23e" # 2019apr28 # ##### # «V.walk» (to ".V.walk") # (find-dn6 "picture.lua" "V") # (find-dn6 "picture.lua" "V" "v = V.fromab") # (find-dn6 "picture.lua" "V" "walk =") # (find-dn6 "picture.lua" "V" "fromab =") # (find-dn6 "picture.lua" "V" "fromab =" "ensw") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() = v"22" = v"22":w() PPV(V.__index) = v"22" = v"22":walk"e" = v"22e" # TODO: simplify this: # (find-dn6 "zhas.lua" "Cuts") # (find-dn6 "zhas.lua" "Cuts" "addcuts =") # (find-dn6 "zhas.lua" "Cuts" "addcuts =" "local f =") ##### # # LPicture.addrect # 2019apr28 # ##### # «LPicture.addrect» (to ".LPicture.addrect") # (find-dn6 "picture.lua" "LPicture") # (find-dn6 "picture.lua" "LPicture" "addtex =") # (find-dn6 "picture.lua" "LPicture" "addtex =" "addt") # (find-dn6 "picture.lua" "LPicture" "addrect4 =") # (find-dn6 "zhas.lua" "MixedPicture") # (find-dn6 "zhas.lua" "MixedPicture-zhalrf-tests") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() mp = mpnew({}, "123454321") mp = mpnew({}, "123454321"):addlrs() mp = mpnew({def="foo"}, "123454321"):addlrs() LPicture.__index.addrect4 = function (lp, x0, y0, x1, y1) return lp:addt("\\polygon(%s,%s)(%s,%s)(%s,%s)(%s,%s)", x0,y0, x1,y0, x1,y1, x0,y1) end LPicture.__index.addrect2 = function (lp, x0y0, x1y1) local x0,y0 = x0y0:to_x_y() local x1,y1 = x1y1:to_x_y() return lp:addt("\\polygon(%s,%s)(%s,%s)(%s,%s)(%s,%s)", x0,y0, x1,y0, x1,y1, x0,y1) end mp.lp:addrect2(v"00", v"23") mp.lp:print() ##### # # Adding rectangles to TCG to debug dimensions # 2019apr28 # ##### # «TCG.addrect» (to ".TCG.addrect") # (find-LATEX "edrxpict.lua" "TCG") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) chdir "~/LATEX/" require "edrxpict" ##### # # TCGDims # 2019apr28 # ##### # «TCGDims» (to ".TCGDims") # (find-LATEX "edrxpict.lua" "TCGDims") # (find-dn6 "picture.lua" "LPicture") # (find-dn6 "picture.lua" "LPicture" "addtex =") # (find-dn6 "picture.lua" "LPicture" "addtex =" "addt") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) chdir "~/LATEX/" require "edrxpict" lp = LPicture.new({meta="p b", def="foo"}) lp:addpoint(v(1,1)) lp:addpoint(v(4,8)) lp:addrect2(v(2,1), v(3,2)) = lp LPicture.__index.addarrow = function (lp, A, B, t0, t1) lp:addtex(Line.newAB(A, B, t0, t1):pictv()) end -- (find-LATEX "edrxpict.lua" "TCGDims") lp = LPicture.new({meta="p b", def="foo"}) td = TCGDims {h=6, v=3, q=2, crh=2, crv=1, qrh=1} lp:addpoint(td:lowerleft()) lp:addpoint(td:upperright(4)) lp:addrectr(td:L(0), td:cellradius()) lp:addrectr(td:L(1), td:cellradius()) lp:addrectr(td:L(2), td:cellradius()) lp:addrectr(td:R(0), td:cellradius()) lp:addrectr(td:R(1), td:cellradius()) lp:addrectr(td:R(2), td:cellradius()) lp:addrectr(td:R(3), td:cellradius()) lp:addrectr(td:R(4), td:cellradius()) lp:addarrow(td:larrowparams(2, 1)) lp:addarrow(td:lrarrowparams(2, 1)) lp:addarrow(td:lrarrowparams(2, 0)) = lp ##### # # \defzha and \deftcg # 2019apr29 # ##### # «defzha-and-deftcg» (to ".defzha-and-deftcg") # (find-LATEX "2017planar-has-defs.tex" "defzha-and-deftcg") # (find-dn6 "picture.lua" "makepicture") # (find-dn6 "picture.lua" "makepicture" "options.tdef") # (find-dn6 "picture.lua" "makepicture" "options.zdef") \def\defzha#1#2{\expandafter\def\csname zha-#1\endcsname{#2}} \def\ifzhaundefined#1{\expandafter\ifx\csname zha-#1\endcsname\relax} \def\zha#1{\ifzhaundefined{#1} \errmessage{UNDEFINED ZHA: #1} \else \csname zha-#1\endcsname \fi } \def\deftcg#1#2{\expandafter\def\csname tcg-#1\endcsname{#2}} \def\iftcgundefined#1{\expandafter\ifx\csname tcg-#1\endcsname\relax} \def\tcg#1{\iftcgundefined{#1} \errmessage{UNDEFINED TCG: #1} \else \csname tcg-#1\endcsname \fi } ##### # # defub # 2021jul17 # ##### # «defub» (to ".defub") # Example: (find-LATEX "2017planar-has-1.tex" "prop-calc-ZHA") # (find-LATEX "2017planar-has-1.tex" "prop-calc-ZHA" "defub") # (find-LATEXgrep "grep --color=auto -nH --null -e 'defub' *.tex") # (find-LATEXgrep "grep --color=auto -nH --null -e '%L defub' *.tex") ##### # # A way to convert question marks to cuts # 2019apr29 # ##### # «qmarks-to-cuts» (to ".qmarks-to-cuts") # (find-dn6 "zhas.lua" "MixedPicture-J-tests") # (find-dn6 "zhas.lua" "MixedPicture-J-tests" "Imp") # (find-dn6 "zhas.lua" "mpnewJ") # (find-dn6 "zhas.lua" "mpnewJ" ":zhaJcuts()") # (find-dn6 "zhas.lua" "MixedPicture-zha") # (find-dn6 "zhas.lua" "MixedPicture-zha" "zhaJcuts =") # (find-dn6 "zhas.lua" "ZHA-getcuts") # (find-dn6 "zhas.lua" "ZHA-getcuts" "getcuts =") # (find-dn6 "tcgs.lua" "qmarks-cuts") # (find-dn6 "zhas.lua" "Cuts-tests") # (find-dn6 "zhas.lua" "Cuts-tests" "c:addcuts(") # (find-dn6 "zhas.lua" "Cuts") # (find-dn6 "zhas.lua" "Cuts" "addcuts =") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() require "tcgs" mp = mpnewJ({}, "1234RR321", "P -> z:Imp(v'12', P)") = mp = mp.zha:getcuts(mp.J) = mp:addlrs() PP(qmarkstocuts(".??", "..???")) PP(cutstoqmarks "321/0 0|1|2345") -- _5 ? -- _4 ? -- ? 3_ _3 ? -- ? 2_ _2 -- 1_ _1 ##### # # How to run dednat6 from a Lua without TeX and generate a .dnt # 2019apr29 # ##### # «dednat6-dnt-from-lua» (to ".dednat6-dnt-from-lua") # (find-LATEXfile "2018dednat6-no-lua.tex" "write_dnt_file()") # (find-dn6 "output.lua" "write_dnt_file") # (find-LATEX "dednat6load.lua") # (find-dn6file "preamble6.lua" "\\def\\pu{\\directlua{pu()}}") # (find-dn6 "block.lua" "texfile0") # (find-dn6 "block.lua" "texfile0" "pu =") # (find-dn6 "output.lua" "output") # (find-dn6 "output.lua" "output" "output_verbose =") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) chdir "~/LATEX/" -- (find-LATEX "dednat6load.lua") dednat6dir = "dednat6/" -- (find-dn6 "") dofile(dednat6dir.."dednat6.lua") -- (find-dn6 "dednat6.lua") dofile(dednat6dir.."block.lua") -- (find-dn6 "block.lua") texfile0("2018dednat6-minimal.tex") tex = {print = function () end} -- pu(tf.j) tf:processuntil(tf.j) print(dnt_log) ##### # # Changing output_dnt to add debug code # 2019may02 # ##### # «output_dnt» (to ".output_dnt") # (find-dn6 "output.lua" "output_dnt") %L output_dnt = function (str) %L dnt_log = dnt_log..str.."\n" %L end %L output_dnt = function (str) %L dnt_n = dnt_n or 1 %L local dbg = "% "..dnt_n.."\n" %L if dnt_n == 15 then dbg = dbg..debug.traceback().."\n" end %L dnt_log = dnt_log..dbg..str.."\n" %L dnt_n = dnt_n + 1 %L end ##### # # Changing output() to make it run well outside latex # 2019dec15 # ##### # «output-no-tex» (to ".output-no-tex") # (find-dn6 "output.lua" "output_dnt") output = function (str) print(str) end ##### # # Add things like "% %L-block in lines 42-99" to the latex of LPictures # 2019apr30 # ##### # «hyperlinks-in-LPicture» (to ".hyperlinks-in-LPicture") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/LATEX/ ./dednat6load.lua -t 2019logicday.tex # (find-LATEXsh "./dednat6load.lua -t 2019logicday.tex") # (find-LATEXsh "./dednat6load.lua -t 2019logicday.tex" "\\def\\Kmini") # Better line numbers in the output: # (find-dn6 "treetex.lua" "TreeNode") # (find-dn6 "treetex.lua" "TreeNode" "TeX_deftree = ") # (find-dn6grep "grep --color -nH -e TeX_deftree *.lua") # (find-dn6file "block.lua" "hyperlink =") # (find-dn6grep "grep --color -nH -e hyperlink *.lua") # (find-dn6grep "grep --color -nH -e 'tf:hyperlink()' *.lua") # (find-dn6 "block.lua" "Block") # (find-dn6 "block.lua" "Block" "hyperlink =") # (find-dn6 "treetex.lua" "TeX_deftree_tatsuta") # (find-dn6 "treetex.lua" "TeX_deftree_tatsuta" "tf:hyperlink()") # (find-dn6 "diagtex.lua" "arrows_to_defdiag") # (find-dn6grep "grep --color -nHw -e Line *.lua") # (find-dn6 "texfile.lua" "TexFile") # (find-dn6 "texfile.lua" "TexFile" "Line %s") # (find-dn6 "picture.lua" "LPicture") # (find-dn6 "picture.lua" "LPicture" "output =") ##### # # Dednat6 at stackexchange # 2019may17 # ##### # «stackexchange» (to ".stackexchange") # https://tex.stackexchange.com/questions/468/what-is-the-best-package-out-there-to-typeset-proof-trees/491248#491248 ##### # # A git repository for dednat6 - creating it (obsolete) # 2019may17 # ##### # «git-repo» (to ".git-repo") # (find-eev2-links) # (find-es "dednat" "dednat6.zip-2019") # (find-LATEXfile "" " dednat6.zip") # https://github.com/edrx/dednat6 # https://github.com/edrx/dednat6/archive/master.zip * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) dednat6files () { unzip -Z1 ~/LATEX/dednat6.zip; } dednat6files () {( cd /tmp/dednat6/ && git ls-files; )} mkdir -p ~/dednat6/dednat6/lua-repl/repl/ cd ~/dednat6/ # (...) dednat6files | my-cmp-tkdiff "~/LATEX/" "~/dednat6/" # (find-eevfile "README.md") # (find-fline "~/dednat6/README.md") git add README.md git commit -m "first commit" git remote add origin https://github.com/edrx/dednat6.git git push -u origin master ##### # # Downloading and testing dednat6 from git # 2019may21 # ##### # «git-repo-test» (to ".git-repo-test") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/dednat6/ cd /tmp/ git clone https://github.com/edrx/dednat6 cd /tmp/dednat6/ make make clean laf # (find-gitk "/tmp/dednat6/") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/master.zip rm -Rfv /tmp/dednat6-master/ mkdir /tmp/dednat6-master/ cd /tmp/ wget https://github.com/edrx/dednat6/archive/master.zip unzip master.zip cd /tmp/dednat6-master/ make make clean laf ##### # # Uploading recent updates to the git repository # 2019jul19 # ##### # «git-repo-update» (to ".git-repo-update") # (find-angg ".emacs" "find-dednat6-links") # (find-dednat6-links) # (find-eev2-links) # (find-angg "dednat6/") # https://github.com/edrx/dednat6 * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) dednat6files () {( cd /tmp/dednat6/ && git ls-files; )} dednat6pdffiles () {( cd /tmp/dednat6/ && ls *.pdf | cat; )} dednat6pdffiles () {( cd ~/dednat6/ && ls *.pdf | cat; )} (TZ=GMT date; date) > ~/dednat6/VERSION rm -Rfv /tmp/dednat6 cd /tmp/ git clone https://github.com/edrx/dednat6 cd /tmp/dednat6/ PAGER=cat git log --oneline --graph --all -20 # (find-fline "/tmp/") # (find-fline "/tmp/dednat6/") # (find-gitk "/tmp/dednat6/") # First step: make sure that ~/LATEX/dednat6/ # and ~/dednat6/ are in sync. # cd /tmp/dednat6/ dednat6files | grep lua | my-cmp-tkdiff "~/LATEX/" "~/dednat6/" dednat6files | my-cmp-tkdiff "~/dednat6/" /tmp/dednat6/ # cp -iv ~/LATEX/dednat6/diagtikz.lua dednat6/ # git add dednat6/diagtikz.lua # cp -iv ~/dednat6/demo-tikz.tex . # git add demo-tikz.tex MSG="Make deletecomments_2021 the default." MSG="Added the DeleteComments class in output.lua." MSG="Now '%L' blocks ignore the first space after the '%L'." MSG="Added 'newnode:' and 'at:'." MSG="Rewrote lualoader.lua to make it handle a bug in TeXLive 2020." MSG="Added the classes ProofSty and BussProofs to treetex.lua." MSG="Added diagtikz.lua and demo-tikz.tex." MSG="Rewrote demo-tikz.tex." MSG="Added more comments to diagtex.lua." MSG="Added 'xy+='." echo "$MSG" # (magit-status "/tmp/dednat6/") git commit -a -m "$MSG" # (find-eevsh0 "PAGER=cat git log -1 --pretty=tformat:%s") # git commit -a --amend -m "$MSG" # (find-gitk ee-eevdir) # (find-eevsh0 "gitk &") git push # edrx Fa cd /tmp/dednat6/ cd ~/dednat6/ make veryclean make make clean ls laf dednat6pdffiles rm -v /tmp/dednat6.zip zip /tmp/dednat6.zip $(dednat6files) $(dednat6pdffiles) laf /tmp/dednat6.zip unzip -l /tmp/dednat6.zip cp -v /tmp/dednat6.zip ~/LATEX/ cd /tmp/ Scp-np dednat6.zip edrx@angg.twu.net:/home/edrx/slow_html/ Scp-np dednat6.zip edrx@angg.twu.net:/home/edrx/public_html/ Scp-np -v dednat6.zip edrx@angg.twu.net:/home/edrx/public_html/ # (find-dednat6 "Makefile") # (find-fline "/tmp/dednat6/Makefile") ##### # # A Makefile for the dednat6/ directory # 2019may19 # ##### # «makefile» (to ".makefile") # (find-dednat6 "Makefile") # (find-dednat6 "") # (find-dednat6sh "ls *.tex; ls *.lua; ls *.png") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/dednat6/ make veryclean make -n make all # (find-es "git" "git-ls-files") git ls-files make tugboat-rev2.pdf git rm ltugboat.cls git add Makefile git commit -a -m 'Added a makefile' git commit -a -m 'Small doc fixes.' git push make clean laf make all laf make clean laf make demo-minimal.pdf make demo-preproc.pdf make demo-preproc.subdirpdf make demo-write-dnt.pdf make demo-write-dnt.subdirpdf make tugboat-rev2.pdf ##### # # Guidelines for preparing Dednat6 for submission to CTAN # 2019may21 # ##### # «ctan-guidelines» (to ".ctan-guidelines") # https://tex.stackexchange.com/questions/25116/what-is-good-practice-when-preparing-a-package-for-ctan ##### # # Submitting my notes on Yoneda to Arxiv # 2019jun01 # ##### # «arxiv-yoneda» (to ".arxiv-yoneda") # http://angg.twu.net/LATEX/2019notes-yoneda.pdf # https://arxiv.org/user/ # https://arxiv.org/submit/2713866/preview # https://arxiv.org/submit/2713866/view # (nyo) * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) cd ~/LATEX/ lualatex 2019notes-yoneda.tex pdflatex -record 2019notes-yoneda.tex flsfiles-zip 2019notes-yoneda.fls 2019notes-yoneda.zip rm -rfv /tmp/edrx-latex/ mkdir /tmp/edrx-latex/ unzip -d /tmp/edrx-latex/ ~/LATEX/2019notes-yoneda.zip cd /tmp/edrx-latex/ pdflatex 2019notes-yoneda.tex latex 2019notes-yoneda.tex # (find-man "unzip") # (find-fline "/tmp/edrx-latex/") # (find-fline "~/LATEX/2019notes-yoneda.zip") # (find-sh "cp -v ~/LATEX/2019notes-yoneda.zip /tmp/") # (find-xpdfpage "/tmp/edrx-latex/2019notes-yoneda.pdf") # ! LaTeX Error: Option clash for package hyperref. # https://www.quora.com/Should-I-post-my-paper-to-the-arXiv-before-I-get-a-decision-from-a-conference-journal # https://veronikach.com/phd-advice/my-thoughts-on-preprints/ # https://tex.stackexchange.com/questions/329461/arxiv-option-clash-for-package-hyperref-when-there-are-no-options # https://arxiv.org/help/submit_tex # https://arxiv.org/help/faq/mistakes # https://arxiv.org/help/hypertex A diagram for the Yoneda Lemma (in which each node and arrow can be interpreted precisely as a ``term'', and most of the interpretations are ``obvious''; plus dictionaries!!!) The full title of these slides is: ``A diagram for the Yoneda Lemma (In which each node and arrow can be interpreted precisely as a `term', and most of the interpretations are `obvious'; plus dictionaries!!!)'' This is a set of slides showing how to represent the Yoneda Lemma --- or, rather, three ``Yoneda Lemmas'' --- as diagrams, in a way that le This is a set of slides showing how to represent the Yoneda Lemma --- or, rather, three ``Yoneda Lemmas'' --- as diagrams, in a way in which eacy node and arrow can be interpreted precisely as a term in a type system or in Agda, Most of the details that do not appear in these 6-node diagrams that are needed for the translation to Agda can This is a set of slides showing how to interpret the three ``Yoneda Lemmas'' as diagrams with five or six nodes each, in a way in which each node and arrow can be interpreted precisely as a term in a type system or in Agda. These 5- or 6-node diagrams do not have all the details needed for the translation into terms, but we show how to infer the missing details using the technique of ``internal diagrams''. ##### # # tf:push and tf:pop # 2019jul02 # ##### # «tf:push» (to ".tf:push") # (find-dn6 "stacks.lua") # (find-dn6 "block.lua") # (find-dn6 "block.lua" "TexLines") # (find-dn6 "block.lua" "texfile0") # (find-dn6 "block.lua" "tf_push_and_tf_pop") ##### # # diaxydoc.pdf and barrdoc.pdf # 2019jul16 # ##### # «diaxydoc-and-barrdoc» (to ".diaxydoc-and-barrdoc") # (find-angg ".emacs" "diaxydoc-and-barrdoc") # https://ctan.org/pkg/diagxy # http://tug.ctan.org/tex-archive/macros/generic/diagrams/diagxy/diaxydoc.pdf # http://tug.ctan.org/tex-archive/macros/latex/contrib/xypic/doc/barrdoc.pdf # (find-tlsh "find * | sort | grep diaxydoc") # (find-tlsh "find * | sort | grep barrdoc") # (find-fline "/usr/local/texlive/2018/texmf-dist/doc/generic/barr/" "diaxydoc.pdf") # (find-fline "/usr/local/texlive/2018/texmf-dist/doc/generic/xypic/" "barrdoc.pdf") ;; (find-diaxydocpage) ;; (find-diaxydoctext) ;; (find-barrdocpage) ;; (find-barrdoctext) ;; (find-barrdocpage 2 "\\usepackage[barr,pdf]{xy}") ;; (find-barrdoctext 2 "\\usepackage[barr,pdf]{xy}") ;; (find-barrdocpage 24 "5.3 Empty placement and moving labels") ;; (find-barrdoctext 24 "5.3 Empty placement and moving labels") ;; (find-barrdocpage 33 "5.9 A few samples") ;; (find-barrdoctext 33 "5.9 A few samples") ;; (find-diaxydocpage 34 "4.9 A few samples") ;; (find-diaxydoctext 34 "4.9 A few samples") ##### # # Lua files in CTAN packages # 2019jul18 # ##### # «lua-files-in-ctan-pkgs» (to ".lua-files-in-ctan-pkgs") # https://tug.org/pipermail/tex-live/2019-July/043918.html # https://tug.org/pipermail/tex-live/2019-July/043922.html invitation * e-mail to texlive: Packages that only have Lua files https://tug.org/pipermail/tex-live/2019-July/043931.html https://mail.google.com/mail/ca/u/0/#sent/QgrcJHsHpDWxZJHjjFnVDPsgGhwhCsfctBG Packages that only have Lua files Hi List, Are there any examples on CTAN of packages that are made of Lua files only, except for documentation? I have this package here, that I would like to submit to CTAN soon - i.e., in a few months - that is like that... http://angg.twu.net/dednat6.html In order to use it, in, say, foo.tex, one has to copy to the same directory of foo.tex the file "dednat6load.lua" and the directory "dednat6/" - that only contains Lua files. Thanks in advance!!! Eduardo Ochs http://angg.twu.net/dednat6.html http://angg.twu.net/math-b.html http://angg.twu.net/#eev # https://tug.org/pipermail/tex-live/2019-July/043935.html xindex # https://ctan.org/pkg/xindex # (find-tlsh "find * | sort | grep xindex") # https://tug.org/pipermail/tex-live/2019-July/043937.html .sty # https://tug.org/pipermail/tex-live/2019-July/043938.html lualibs, luaotfload ##### # # Mapping the quirks that don't let me create a .sty for dednat6 # 2019jul20 # ##### # «quirks-2019-jul» (to ".quirks-2019-jul") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/quirks/ mkdir /tmp/quirks/ cd ~/dednat6/ cp -av demo-minimal.tex dednat6load.lua dednat6/ /tmp/quirks/ cd /tmp/quirks/ lualatex demo-minimal.tex cp -iv demo-minimal.tex demo-BCD.tex cp -iv demo-minimal.tex demo-BDC.tex cp -iv demo-minimal.tex demo-BD.tex cp -iv demo-minimal.tex demo-CDB.tex cp -iv demo-minimal.tex demo-DCB.tex # (find-fline "/tmp/quirks/demo-minimal.tex" 56) # (find-fline "/tmp/quirks/demo-BCD.tex" 56) # (find-fline "/tmp/quirks/demo-BDC.tex" 56) # (find-fline "/tmp/quirks/demo-BD.tex" 56) # (find-fline "/tmp/quirks/demo-CDB.tex" 56) # (find-fline "/tmp/quirks/demo-DCB.tex" 56) lualatex demo-BCD.tex lualatex demo-BDC.tex lualatex demo-BD.tex lualatex demo-CDB.tex lualatex demo-DCB.tex # (find-fline "/tmp/quirks/a.tex") # (find-fline "/tmp/quirks/") # (find-pdf-page "/tmp/quirks/demo-BCD.pdf") # (find-pdf-page "/tmp/quirks/demo-BDC.pdf") # (find-pdf-page "/tmp/quirks/demo-BD.pdf") # (find-pdf-page "/tmp/quirks/demo-CDB.pdf") # (find-pdf-page "/tmp/quirks/demo-DCB.pdf") # BCD: default, good # BCD: some omegas # BD: many omegas # DCB: LaTeX Error: Missing \begin{document}. \catcode`\^^J=10 % (find-es "luatex" "spurious-omega") \directlua{dofile "dednat6load.lua"} % (find-dednat6 "dednat6load.lua") % %\catcode`\^^J=10 % \directlua{dofile "dednat6load.lua"} % -> many omegas % \begin{document} % \catcode`\^^J=10 % (find-es "luatex" "spurious-omega") % \directlua{dofile "dednat6load.lua"} % (find-dednat6 "dednat6load.lua") % -> everything works ##### # # colored-arrows # 2019aug03 # ##### # «colored-arrows» (to ".colored-arrows") \def\ca#1{{\color {Red}#1}} \def\cb#1{{\color{Yellow}#1}} \def\cc#1{{\color {Blue}#1}} \def\cd#1{{\color {Green}#1}} \ca{1}\cb{2}\cc{3}\cd{4} %D diagram ?? %D 2Dx 100 +30 %D 2D 100 A B %D 2D %D 2D +20 %D 2D %D (( A .tex= \ca{A} %D B .tex= \cb{B} %D A B |-> .plabel= a \cc{C} %D %D )) %D enddiagram %D $$\pu \diag{??} $$ \defdiag{??}{ % In the "%D"-block in lines 65--77 \morphism(0,0)|a|/|->/<450,0>[{\ca{A}}`{\cb{B}};{\cc{C}}] } \defdiag{??}{ % In the "%D"-block in lines 65--77 \morphism(0,0)|a|/|->/<450,0>[{\ca{A}}`{\cb{B}};{\cc{C}}] \color{Green} \morphism(0,200)|a|/|->/<450,0>[{\ca{A}}`{\cb{B}};{\cc{C}}] \color{Black} \morphism(0,400)|a|/|->/<450,0>[{\ca{A}}`{\cb{B}};{\cc{C}}] } $$ \diag{??} $$ ##### # # write_single_tex_file # 2019aug03 # ##### # «write_single_tex_file» (to ".write_single_tex_file") # (find-dednat6file "demo-write-dnt.tex") # (find-dednat6file "demo-write-single.tex") # (find-dn6 "output.lua" "write_dnt_file") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) chdir "~/dednat6/" ##### # # deletecomments (I need a better version of this) # 2019aug16 # ##### # «deletecomments» (to ".deletecomments") # (find-dn6 "output.lua" "deletecomments") # (find-LATEXgrep "grep --color -nH -e deletecomments *.tex") %L deletecomments = function (str) %L return (str:gsub("%%[^\n]*\n[ \t]*", "")) %L end ##### # # deletecomments: a better version # 2021may14 # ##### # «deletecomments-2021» (to ".deletecomments-2021") # (find-dn6 "output.lua" "deletecomments") # (find-dn6 "output.lua" "DeleteComments-class") # (find-dn6 "output.lua" "DeleteComments-tests") # (find-es "tex" "comments") # (find-lua51manual "#pdf-string.reverse") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() bigstr = [[ foo%12 bar\plic%34 qoo%56 blep bletch % woo ]] DeleteComments = Class { type = "DeleteComments", split = function (bigstr) local A = {} for _,li in ipairs(splitlines(bigstr)) do local a,b = li:match("^([^%%]*)(.*)") table.insert(A, {a, b, "\n"}) end return DeleteComments(A) end, __tostring = function (dc) return mytabletostring(dc) end, __index = { hascomment = function (dc, k) return dc[k][2] ~= "" end, endswithcmd = function (dc, k) return dc[k][1]:reverse():match("^[A-Za-z]+\\") end, addspaceaftercmd = function (dc, k) dc[k][1] = dc[k][1].." " end, valid = function (dc, k) return 1 <= k and k <= #dc end, ltrim = function (dc, k) dc[k][1] = dc[k][1]:match("^[ \t]*(.*)") end, delcomment = function (dc, k) if dc:endswithcmd(k) then dc:addspaceaftercmd(k) end dc[k][2] = "" -- delete the "%..." dc[k][3] = "" -- delete the newline if dc:valid(k+1) then dc:ltrim(k+1) end end, delcomments = function (dc) for k=1,#dc do if dc:hascomment(k) then dc:delcomment(k) end end return dc end, concat = function (dc) bigstr = "" for k=1,#dc-1 do bigstr = bigstr..dc[k][1]..dc[k][2]..dc[k][3] end if #dc > 0 then bigstr = bigstr..dc[#dc][1]..dc[#dc][2] end return bigstr end, }, } dc = DeleteComments.split(bigstr) = dc = dc:delcomments() = dc:concat() delcomments = deletecomments1 = function (line) local left,right = line:match("^([^%%]*)(.*)") if right == "" then end deletecomments = function (bigstr) local lines = splitlines(bigstr) for i=1,#lines do local line = lines[i] local left,right = line:match("^([^%%]*)(.*)") local newright = right if right:match"^%%" then if left:match"^[ \t]*$" then lines[i] = "" if left:rev():match("[A-Za-z]+\\") then newright = "\n" else newright = end PP(left, right) end end = deletecomments(bigstr) ##### # # Coercion problems in LR.fromtcgspec in Lua 5.3 # 2019aug12 # ##### # «LR.fromtcgspec-5.3» (to ".LR.fromtcgspec-5.3") # (find-es "lua5" "coercions-5.3") # (find-dn6 "tcgs.lua" "TCGSpec") # (find-dn6 "tcgs.lua" "TCGSpec" "mp =") # (find-dn6 "tcgs.lua" "TCGSpec" "zhaspec =") # (find-dn6 "tcgs.lua" "TCGSpec" "zha =") # (find-dn6 "zhaspecs.lua" "LR") # (find-dn6 "zhaspecs.lua" "LR" "fromspec =") # (find-dn6 "zhaspecs.lua" "LR" "fromtcgspec =") # (find-dn6 "zhaspecs.lua" "LR" "fromtwocolgraph =") # (find-dn6 "zhaspecs.lua" "LR" "zha =") # (find-dn6file "zhaspecs.lua" " spec =") # (find-dn6 "zhas.lua") # (find-dn6 "zhas.lua" "ZHA") # (find-dn6 "zhas.lua" "ZHA" "fromspec0 =") # (find-dn6 "zhas.lua" "ZHA" "specwidths =") # (find-dn6 "picture.lua" "V") # (find-dn6 "picture.lua" "V" "to_l_r =") [string "2019elephant-poster-z.tex:%R:860-873"]:14 # (find-LATEXfile "2019elephant-poster-z.tex" 860 14) # (find-dn6 "zhas.lua" "MixedPicture") # (find-dn6 "zhas.lua" "MixedPicture" "zfunction =") # (find-dn6 "zhas.lua" "asciirectpoints-tests") -- (find-LATEXfile "2019elephant-poster-z.tex" "house =") * (eepitch-lua53) * (eepitch-kill) * (eepitch-lua53) loaddednat6() output = print * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() output = print str = ".1.|2.3|4.5" opts = {def="dagHouse", scale="4pt", meta="p b s"} mp = MixedPicture.new(opts):zfunction(str) = mp = mp:tolatex() * (eepitch-lua53) * (eepitch-kill) * (eepitch-lua53) loaddednat6() output = print str = ".1.|2.3|4.5" opts = {def="dagHouse", scale="4pt", meta="p b s"} mp = MixedPicture.new(opts):zfunction(str) = mp = mp:tolatex() kite = ".1.|2.3|.4.|.5." house = ".1.|2.3|4.5" W = "1.2.3|.4.5." guill = ".1.2|3.4.|.5.6" hex = ".1.2.|3.4.5|.6.7." mp = MixedPicture.new({def="dagKite", meta="s", scale="5pt"}, z):zfunction(kite):output() mp = MixedPicture.new({def="dagKite", meta="t", scale="4pt"}, z):zfunction(kite):output() mp = MixedPicture.new({def="dagHouse", meta="s", scale="5pt"}, z):zfunction(house):output() mp = MixedPicture.new({def="dagW", meta="s", scale="4pt"}, z):zfunction(W):output() mp = MixedPicture.new({def="dagGuill", meta="s", scale="4pt"}, z):zfunction(guill):output() mp = MixedPicture.new({def="dagHex", meta="s", scale="4pt"}, z):zfunction(hex):output() kite = ".1.|2.3|.4.|.5." house = ".1.|2.3|4.5" W = "1.2.3|.4.5." guill = ".1.2|3.4.|.5.6" hex = ".1.2.|3.4.5|.6.7." o = MixedPicture.new({def="dagKite", meta="s", scale="5pt"}, z) o = MixedPicture.new({def="dagKite", meta="s", scale="5pt"}, z):zfunction(kite) PPV(o) mp = MixedPicture.new({def="dagKite", meta="s", scale="5pt"}, z):zfunction(kite):output() mp = MixedPicture.new({def="dagKite", meta="t", scale="4pt"}, z):zfunction(kite) mp = MixedPicture.new({def="dagHouse", meta="s", scale="5pt"}, z):zfunction(house) mp = MixedPicture.new({def="dagW", meta="s", scale="4pt"}, z):zfunction(W) mp = MixedPicture.new({def="dagGuill", meta="s", scale="4pt"}, z):zfunction(guill) mp = MixedPicture.new({def="dagHex", meta="s", scale="4pt"}, z):zfunction(hex) -- (find-dn6file "luarects.lua" "tozmp =") -- (find-dn6 "luarects.lua" "ZHAFromPoints") ##### # # dednat6-xyoption-2cell # 2019aug18 # ##### # «dednat6-xyoption-2cell» (to ".dednat6-xyoption-2cell") # (find-fline "~/LATEX/xy-problem-1.tex") \documentclass{article} %\usepackage{proof} % For derivation trees ("%:" lines) \input diagxy % For 2D diagrams ("%D" lines) \xyoption{curve} % For the ".curve=" feature in 2D diagrams \xyoption{all} \xyoption{2cell} %\usepackage[all,2cell]{xy} \usepackage{mathrsfs,amssymb,stmaryrd,bbm,mathtools, mathabx, enumitem, upgreek} \usepackage{chngcntr} \usepackage{ifluatex} \begin{document} ##### # # Explaining the notations in PH1 # 2019sep18 # ##### # «ph1-doc» (to ".ph1-doc") # (ph1p 5 "positional") # (ph1 "positional") # (find-LATEX "2017planar-has-defs.tex" "picturedots") # (find-LATEX "edrxpict.lua" "pictdots")g * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() ##### # # harrownode # 2019oct07 # ##### # «harrownode» (to ".harrownode") % (find-angg ".emacs.papers" "symbols") % (find-symbolspage 108 "extarrows") % (find-symbolstext 108 "extarrows") % (find-dn6 "diagforth.lua" "place") % \usepackage{extarrows} %L forths["harrownode"] = function (x0, y0, x2, y2, dx0, dx2) %L local node0, node2 = ds:pick(1), ds:pick(0) %L local dx0, dx2, tex = getwordasluaexpr(), getwordasluaexpr() %L local tex = getword() or werror() %L local x0, y0, x2, y2 = node0.x, node0.y, node2.x, node2.y %L local x1a, x1b = splitdist(x0, x2, dx0, 0, dx2) -- x1a=x1b %L local x1, y1 = x1a, (y0 + y2)/2 %L PP(x1, y1, tex) %L ds:push(storenode{x=x1, y=y1, TeX=tex}) %L ds:push(storearrow(DxyPlace {ds:pick(0)})) %L end \def\catA{\mathbf{A}} \def\catB{\mathbf{B}} $\xLongrightarrow[foo]{bar}$ %D diagram adj %D 2Dx 100 +25 +25 +25 %D 2D 100 LA <--| A %D 2D | | %D 2D | <-> | %D 2D v v %D 2D +25 B |--> RB C --> D %D 2D %D 2D +15 \catB \catA %D 2D %D (( LA A <-| %D LA B -> A RB -> %D B RB |-> %D # LA RB harrownodes nil 20 nil <-> %D LA RB harrownode nil nil \xLongrightarrow[foo]{bar} %D \catB \catA <- sl^ .plabel= a L %D \catB \catA -> sl_ .plabel= b R %D %D C D -> .curve= ^10pt .plabel= a a %D C D -> .curve= _10pt .plabel= b b %D )) %D enddiagram %D $$\pu \diag{adj} $$ ##### # # extra-modules.tex: a discussion of the modules for ZHAs in dednat6 # 2019dec13 # ##### # «extra-modules» (to ".extra-modules") # (find-angg "dednat6/extra-modules.tex") # (dnz) # (find-dednat6 "dednat6/zhas.lua" "ZHA-tests") # (find-dednat6 "dednat6/zhas.lua" "MixedPicture") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() z = ZHA.fromspec("12L1RRR2RL1"):PP():print() z = ZHA.fromspec("123LLR432L1"):PP():print() z = ZHA.fromspec("123RRL432R1"):PP():print() = z = z:tolatex() * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() output = function (str) print(str) end -- (jopp 3 "basic-definitions") -- (jos "basic-definitions") tdims = TCGDims {qrh=5, q=15, crh=12, h=60, v=25, crv=7} -- with v arrows tspec_PA = TCGSpec.new("46; 11 22 34 45, 25") tspec_PAQ = TCGSpec.new("46; 11 22 34 45, 25", ".???", "???.?.") oap = tspec_PA :mp ({zdef="O_A(P)"}) :addlrs() oapj = tspec_PAQ:mp ({zdef="O_A(P),J"}):addlrs() pa = tspec_PA :tcgq({tdef="(P,A)", meta="1pt p"}, "lr q h v ap") paq = tspec_PAQ:tcgq({tdef="(P,A),Q", meta="1pt p"}, "lr q h v ap") = tdims = tspec_PA = tspec_PAQ = oap = oapj -- (find-dednat6 "dednat6/eoo.lua" "otype") = otype(oap) PP(keys(oap)) = VerticalTable(sorted(keys(oap))) = PP(getmetatable(oap)) = PP(getmetatable(oap).__index) = PP(sorted(keys(getmetatable(oap).__index))) ofields = function (o) return VerticalTable(sorted(keys(oap))) end omethods = function (o) return VerticalTable(sorted(keys(getmetatable(oap).__index))) end = otype(oap) = ofields(oap) = omethods(oap) = oap.cuts -- error = oap.lp = PP(oap.lp) PPV(oap) ##### # # Converting code that uses the old TCG class to code that uses TCGQ # 2019dec24 # ##### # «converting-TCG-to-TCGQ» (to ".converting-TCG-to-TCGQ") # Old: (find-LATEXgrep "grep --color -nH --null -e TCG.new *") # (find-LATEX "edrxpict.lua" "TCG") # (find-LATEX "edrxpict.lua" "TCG-tests") # New: (find-LATEXgrep "grep --color -nH --null -e TCGDims *") # (find-LATEXgrep "grep --color -nH --null -e TCGSpec *") # (find-LATEX "dednat6/tcgs.lua") # # Meaning of the (new) parameters: # (find-dednat6 "extra-modules.tex") # (find-dednat6 "extra-modules.tex" "TCGs") # (find-pdf-page "~/dednat6/extra-modules.pdf" 3) * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) -- -- An example of code using the old TCG class, from: -- (find-LATEX "2017planar-has-1.tex" "2CGs") -- (find-LATEX "2017planar-has-1.tex" "2CGs" "TCG.new") -- loaddednat6() chdir "~/LATEX/" dofile "edrxtikz.lua" -- (find-LATEX "edrxtikz.lua") dofile "edrxpict.lua" -- (find-LATEX "edrxpict.lua" "TCG") output = function (str) print(str) end -- (find-es "dednat" "output-no-tex") tcg_big = {scale="14pt", meta="p", dv=2, dh=2.75, ev=0.32, eh=0.275} tcg_Big = {scale="14pt", meta="p", dv=2, dh=3.5, ev=0.32, eh=0.200} tcg_medium = {scale= "9pt", meta="p s", dv=1, dh=2.2, ev=0.32, eh=0.275} tcgnew = function (opts, def, str) return TCG.new(opts, def, unpack(split(str, "[ %d]+"))) end tcgbig = function (def, spec) return tcgnew(tcg_big, def, spec or tcg_spec) end tcgBig = function (def, spec) return tcgnew(tcg_Big, def, spec or tcg_spec) end tcgmed = function (def, spec) return tcgnew(tcg_medium, def, spec or tcg_spec) end tcg = TCG.new(tcg_big, "foo", 3, 4, "34 23", "22 12"):lrs():vs():hs():output() -- (find-LATEXfile "2019planar-has-1-body.tex" "TCG.new") -- (find-LATEX "dednat6/tcgs.lua" "TCGSpec-test") ##### # # Downloading the PDFs of my .texs that require dednat4 # 2020jan27 # ##### # «dednat4-pdfs-downloading» (to ".dednat4-pdfs-downloading") # (find-twusfile "LATEX/") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) # (find-fline "/tmp/latexold/") rm -Rv /tmp/latexold/ mkdir /tmp/latexold/ cd /tmp/latexold/ A=( 2007dnc-sets.pdf 2008bcc.pdf 2008comprcat.pdf 2008dnc-sets.pdf 2008filterp-abs.pdf 2008filterp.pdf 2008filterp-slides.pdf 2008gf.pdf 2008graphs.pdf 2008hyp.pdf 2008induction.pdf 2008modallogic.pdf 2008monads.pdf 2008natded.pdf 2008notations.pdf 2008projeto.pdf 2008sdg.pdf 2008sheaves-abs1.pdf 2008sheaves.pdf 2008topos-str.pdf 2009dnc-in-coq.pdf 2009dnc-monads.pdf 2009jul02-C2-exercicios.pdf 2009jun05.pdf 2009-planodetrabalho.pdf 2009unilog-abs1.pdf 2009unilog-diags.pdf 2009unilog-dnc.pdf 2010diags.pdf 2010kockdiff-new.pdf 2010kockdiff.pdf 2010reducao.pdf 2010unilog-2010jun21.pdf 2010unilog-current.pdf 2011ebl-abs.pdf 2011ebl-booklet-abs.pdf 2011ebl-slides.pdf 2012minicats.pdf 2013idct-changes.pdf 2013-montreal.pdf 2014istanbul-a.pdf 2014sfc-abstract.pdf 2014sfc-slides2h.pdf 2014sfc-slides2.pdf 2014sfc-slides.pdf 2015children.pdf 2015planar-has.pdf ) for i in $A; do wget -nc http://angg.twu.net/LATEX/$i; done ##### # # dednat4-texs-converting # 2020jan27 # ##### # «dednat4-texs-converting» (to ".dednat4-texs-converting") # (find-angg "LUA/texcatcodes.lua") ##### # # tikzdiagram and endtikzdiagram # 2020feb16 # ##### # «tikzdiagram» (to ".tikzdiagram") # (find-dednat6 "dednat6/diagforth.lua" "high-level-tests") # (find-dednat6 "dednat6/diagforth.lua" "diagram") # (find-dednat6 "dednat6/diagforth.lua" "enddiagram") # (find-dednat6 "dednat6/diagtikz.lua") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() forths["tikzdiagram"] = function () diagramname = getword() or derror("No diagram name") xys = {} nodes = VerticalTable {} arrows = VerticalTable {} lasty = nil end forths["endtikzdiagram"] = function () -- output(arrows_to_defdiag(diagramname, tf:hyperlink())) print(arrows) end dxyrun [[ tikzdiagram ?? ]] dxyrun [[ 2Dx 100 +40 ]] dxyrun [[ 2D 100 A --> B ]] dxyrun [[ 2D | ]] dxyrun [[ 2D +30 C ]] dxyrun [[ 2D ]] dxyrun [[ (( A B -> .plabel= a foo ]] dxyrun [[ B C => .plabel= r bar ]] dxyrun [[ A C |-> .plabel= m plic ]] dxyrun [[ ]] dxyrun [[ )) ]] dxyrun [[ endtikzdiagram ]] -- (find-dednat6 "dednat6/diagtex.lua" "arrows_to_defdiag") -- (find-dednat6 "dednat6/diagtex.lua" "arrow_to_TeX") print(arrows) PP(arrows[1]) PP(arrows[1].from) PP(arrows[1].to) PP(nodes[arrows[1].from]) PP(nodes[arrows[1].to]) ##### # # plabel-error-handling # 2020jul25 # ##### # «plabel-error-handling» (to ".plabel-error-handling") # (find-dednat6 "dednat6/diagforth.lua" "high-level-tests") # (find-dednat6 "dednat6/diagforth.lua" "diagram") # (find-dednat6 "dednat6/diagforth.lua" "enddiagram") # (find-dednat6 "dednat6/diagtikz.lua") # (find-dednat6 "dednat6/diagforth.lua" "diag-head" "dxyrun =") # (find-dednat6 "dednat6/parse.lua" "getword") # (find-LATEX "2020dn6-error-handling.lua") # (dne) * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() getword1 = function (errmsg) return getword() or error(errmsg) end forths[".plabel="] = function () local p = getword1("In '.plabel=': missing first argument (placement)") local label = getword1("In '.plabel=': missing second argument (label)") arrow.placement, arrow.label = p, label end dxyrun [[ diagram ?? ]] dxyrun [[ 2Dx 100 +40 ]] dxyrun [[ 2D 100 A --> B ]] dxyrun [[ 2D | ]] dxyrun [[ 2D +30 C ]] dxyrun [[ 2D ]] dxyrun [[ (( A B -> .plabel= aafoo ]] dxyrun [[ A W -> .plabel= aafoo ]] dxyrun [[ )) ]] dxyrun [[ # enddiagram ]] ##### # # bussproofs # 2020aug22 # ##### # «bussproofs» (to ".bussproofs") # (find-es "tex" "bussproofs-victor") # (find-angg "LUA/lua50init.lua" "loaddednat6") # (find-LATEX "dednat6load.lua") # (find-LATEX "dednat6/heads6.lua" "tree-head") # (find-LATEX "dednat6/block.lua" "TexLines") # (find-LATEX "dednat6/treesegs.lua" "allsegments-tests") # (find-LATEX "dednat6/treetex.lua" "TreeNode") # (find-LATEX "dednat6/treetex.lua" "TreeNode" "TeX_deftree =") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() require "block" bigstr = [[ %: H %: ... %: A B C E F \Pi %: =======r ::::\phi ... %: D G I %: ------------------- %: J %: %: ^bars %: ]] output = print output("foo") texlines = TexLines.new("test", bigstr) tf = texlines:toblock() PP(headblocks) tf:processuntil(texlines:nlines()) PP(headblocks) = allsegments[9] seg = allsegments[9][1] name = "bars" output(seg:rootnode():totreenode():TeX_deftree(name)) = seg:rootnode() = seg:rootnode():totreenode() tree = seg:rootnode():totreenode() = tree = tree[1] = tree[3] = tree[3][1] = tree[3][1][1] PPV(tree) PPV(tree[3][1][1]) -- (find-bussguidepage 6 "\\QuaternaryInfC{form}") -- (find-bussguidetext 6 "\\QuaternaryInfC{form}") -- (find-bussguidepage 8 "\\RightLabel{text}") -- (find-bussguidetext 8 "\\RightLabel{text}") -- (find-bussguidepage 9 "\\doubleLine") -- (find-bussguidetext 9 "\\doubleLine") BussProofs = Class { type = "BussProofs", new = function () return BussProofs {} end, __index = { unabbrev = function (bp, str) return unabbrev(str) end, tolatex = function (bp, tn, i) local i_,i__ = i.." ", i.." " if not tn:hasbar() then local r_ = tn:TeX_root() return i.."\\AxiomC{$"..bp:unabbrev(r_).."$}" else local r_ = tn:TeX_root() local b_ = tn:barchar() local l_ = tn:TeX_label() local h_ = tn:hypslist() local r = "\\mathstrut "..bp:unabbrev(r_) local s = function (indent, str) return str and (indent..str.."\n") or "" end local Lines = {["-"]=nil, ["="]="\\doubleLine", ["."]="\\noLine"} local Line = Lines[b_] local Label = l_ and format("\\RightLabel{$%s$}", l_) local Infs = {"\\UnaryInfC", "\\BinaryInfC", "\\TrinaryInfC", "\\QuaternaryInfC", "\\QuinaryInfC"} local Inf = format("%s{$%s$}", Infs[#h_], bp:unabbrev(r_)) local f = function (tn) return bp:tolatex(tn, i__) end local Hyps = mapconcat(f, h_, i__.."\n") return Hyps.."\n"..s(i_,Line)..s(i_,Label)..i..Inf end end, todefded = function (bp, tn, name, link) local comment = " % "..(link or tf:hyperlink()) return "\\defdedbuss{"..name.."}{"..comment.."\n".. bp:tolatex(tn, " ").."\n }" end, }, } bp = BussProofs.new() = bp:tolatex(tree, "") = bp:tolatex(tree, " ") = bp:todefded(tree, "NAME") ee_dofile "~/LATEX/2020dn6-error-handling.lua" bp = BussProofs.new() = bp:todefded(tree, "NAME") ##### # # The word "at:" and the new syntax for calculating with "v"s # 2020dec04 # ##### # «at:» (to ".at:") # (find-LATEX "2020ats.tex") # (find-dn6 "dednat6.lua") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() Node = Class { type = "Node", __tostring = function (node) return mytostring(node) end, __index = { v = function (node) return v(node.x,node.y) end, setv = function (node,v) node.x=v[1]; node.y=v[2]; return node end, }, } storenode = function (node) node = Node(node) table.insert(nodes, node) node.noden = #nodes -- nodes[node.noden] == node if node.tag then -- was: "and not nodes[node.tag]"... nodes[node.tag] = node -- nodes[node.tag] == node end return node end dxyrun [[ diagram ?? ]] dxyrun [[ 2Dx 100 +40 ]] dxyrun [[ 2D 100 A0 -------------> A1 ]] dxyrun [[ 2D | ----- B4 B5 | ]] dxyrun [[ 2D | \ B3\ | ]] dxyrun [[ 2D | \B2 v | ]] dxyrun [[ 2D v B0 B1 ----> v ]] dxyrun [[ 2D +40 A2 -------------> A3 ]] dxyrun [[ 2D ]] dxyrun [[ # (( A B -> .plabel= aafoo ]] dxyrun [[ # A W -> .plabel= aafoo ]] dxyrun [[ # )) ]] dxyrun [[ # enddiagram ]] = nodes = v(10,20) = v(10,20) + v(3,4) = 10 * v(10,20) + v(3,4) = tow tow = function (vv, ww, a, b) local diff = ww-vv local diffrot90 = v(diff[2], -diff[1]) return vv + (a or 0.5)*diff + (b or 0)*diffrot90 end ats_to_vs = function (str) return (str:gsub("@(%w+)", "nodes[\"%1\"]:v()")) end forths["newnode:"] = function () local tag = getword() ds:push(storenode({tag=tag, TeX=phantomnode})) end forths["at:"] = function () local node = ds:pick(0) local vexpr = getword() node:setv(expr(ats_to_vs(vexpr))) end dxyrun [[ (( newnode: B0 at: tow(@A0,@A2,0.75,0.25) ]] dxyrun [[ newnode: B1 at: @B0+v(10,0) ]] dxyrun [[ )) ]] = nodes = tow(v(100,200), v(110,200)) = tow(v(100,200), v(110,200), 0.1) = tow(v(100,200), v(110,200), 0.1, 1) = nodes[1] = otype(nodes[1]) = otype(nodes) = nodes[1]:v() = nodes[1][1], nodes[1][2] = v(nodes[1][1],nodes[1][2]) = ats_to_vs("@A0 + @A1") = expr(ats_to_vs("@A0 + @A1")) = expr(ats_to_vs("tow(@A0,@A1)")) -- (find-angg "LUA/lua50init.lua" "VerticalTable") -- (find-dn6 "diagstacks.lua" "nodes") -- (find-dn6 "diagforth.lua" "relplace") -- (find-dn6grep "grep --color -nH --null -e storenode *.lua") -- (find-dn6grep "grep --color -nH --null -e phantom *.lua") ##### # # Instructions to use Dednat6 in TeXStudio # 2021jan20 # ##### # «texstudio» (to ".texstudio") # (find-es "tex" "texstudio") # http://angg.twu.net/dednat6.html#essential-files * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) # (find-fline "/tmp/ts/") rm -Rv /tmp/ts/ mkdir /tmp/ts/ cd /tmp/ts/ cd ~/dednat6/ cp -aiv demo-minimal.tex dednat6load.lua dednat6/ /tmp/ts/ cd /tmp/ts/ texstudio demo-minimal.tex # Configurations: # Options -> Configure TeXstudio -> Build -> Default compiler -> LuaLaTeX # Options -> Configure TeXstudio -> Show advanced options [turn on] # Options -> Configure TeXstudio -> Build -> Build Options -> Show stdout -> Always # On why we (sometimes) need stdout: # (find-dn6articlepage 3 "The preprocessor outputs this on stdout:") # (find-dn6articletext 3 "The preprocessor outputs this on stdout:") # (find-dn6articlepage 3 "3 Semi-preprocessors") # (find-dn6articletext 3 "3 Semi-preprocessors") # (find-dn6slidespage 14 "output" "\\defdiag") # (find-dn6slidestext 14 "output" "\\defdiag") ##### # # repl-pict: create pict2e code from a REPL # 2021feb08 # ##### # «repl-pict» (to ".repl-pict") # (find-LATEX "2021repl-pict.tex") # (find-LATEX "edrxtikz.lua") # (find-LATEX "edrxpict.lua") # (find-LATEX "2017planar-has-defs.tex" "picturedotsdef") # (find-LATEX "edrxpict.lua" "defpictdots") # (find-LATEXfile "dednat6/zhas.lua") # (find-dn6 "tcgs.lua") # (find-dn6 "tcgs.lua" "TCGQ") # (find-dn6 "picture.lua" "BoundingBox") # (find-dn6 "picture.lua" "BoundingBox" "addpoint =") # (find-dn6 "picture.lua" "LPicture") # (find-dn6 "picture.lua" "LPicture-tests") # (find-dn6 "picture.lua" "metaopts") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() -- require "picture.lua" lp = LPicture.new {cellfont="\\scriptsize"} lp = LPicture.new {cellfont="\\scriptsize", meta="b"} for l=0,2 do for r=0,3 do local pos=lr(l, r) lp:put(pos, pos:xy()) end end = lp = lp:tolatex() ee_writefile("~/LATEX/o.tex", "$"..lp:tolatex().."$") -- (find-angg "LUA/lua50init.lua" "repltexthis") repltexthis(lp:tolatex()) ##### # # Drawing Lawvere-Tierney topologies (with cuts on each \Omega(u)) # 2021apr03 # ##### # «lawvere-tierney» (to ".lawvere-tierney") # (find-dn6 "tcgs.lua" "TCGSpec") # (find-dn6 "tcgs.lua" "TCGSpec" "mp =") # (find-dn6 "tcgs.lua" "TCGSpec" "mpunder =") # (find-dn6 "zhas.lua" "MixedPicture-cuts") # (find-dn6 "zhas.lua" "MixedPicture-cuts" "addcutssub =") # (find-dn6 "zhas.lua" "MixedPicture-zha") # (find-dn6 "zhas.lua" "MixedPicture-zha" "zhalr =") # (find-dn6 "zhas.lua" "MixedPicture-zha" "zhalrf0 =") # (find-dn6 "zhas.lua" "ZHA-shrinktop") # (find-dn6 "zhas.lua" "ZHA-test-shrinktop") # (find-es "dednat" "sub-ZHA") # (cltp 28 "SetT-classifier-defs") # (clt "SetT-classifier-defs") # (cltp 38 "def-j-example") # (clt "def-j-example") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() ts = TCGSpec.new("33; 32, ", ".??",".??") = ts:zhaspec() = ts:zha() = ts:zha():shrinktop(v"32") = ts:zha():shrinktop(v"32").spec = ts:hasqmarks() = ts:cuts() = "c "..ts:cuts() utop = "32" zhaspec = ts:zhaspec() zha = ts:zha() uzha = ts:zha():shrinktop(v(utop)) ucuts = "c "..ts:cuts() ulrf = "lr -> lr:below(v'"..utop.."') and lr:lr() or '..'" mp = ts:mp({zdef="?", scale="12pt", meta=""}) mp = mpnew({zdef="?", scale="12pt", meta=""}, zhaspec) mp:zhalrf0(ulrf) = mp mp.cuts:addcuts(uzha, ucuts) = mp -- «lawvere-tierney-mpunder» (to ".lawvere-tierney-mpunder") -- (find-dn6 "tcgs.lua" "TCGSpec" "mp =") -- (find-dn6 "tcgs.lua" "TCGSpec" "mpunder =") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() output = print ts = TCGSpec.new("33; 32, ") ts = TCGSpec.new("33; 32, ", ".??",".??") mp = ts:mpunder("32", {zdef="A:j:3_", scale="12pt", meta=""}):print() mp = ts:mpunder("20", {zdef="A:j:2_", scale="12pt", meta=""}):print() mp = ts:mpunder("10", {zdef="A:j:1_", scale="12pt", meta=""}):print() mp = ts:mpunder("03", {zdef="A:j:_3", scale="12pt", meta=""}):print() mp = ts:mpunder("02", {zdef="A:j:_2", scale="12pt", meta=""}):print() mp = ts:mpunder("01", {zdef="A:j:_1", scale="12pt", meta=""}):print() ##### # # V3: a variant of the class V for 3D vectors # 2021apr19 # ##### # «V3» (to ".V3") # (find-dn6 "picture.lua" "V") # (find-angg "LATEX/2020-2-C3-plano-tang.lua") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() V3 = Class { type = "V3", __tostring = function (v) return v:tostring() end, __add = function (v, w) return V3{v[1]+w[1], v[2]+w[2], v[3]+w[3]} end, __sub = function (v, w) return V3{v[1]-w[1], v[2]-w[2], v[3]-w[3]} end, __unm = function (v) return v*-1 end, __mul = function (v, w) local ktimesv = function (k, v) return V3{k*v[1], k*v[2], k*v[3]} end local innerprod = function (v, w) return v[1]*w[1] + v[2]*w[2] + v[3]*w[3] end if type(v) == "number" and type(w) == "table" then return ktimesv(v, w) elseif type(v) == "table" and type(w) == "number" then return ktimesv(w, v) elseif type(v) == "table" and type(w) == "table" then return innerprod(v, w) else error("Can't multiply "..tostring(v).."*"..tostring(w)) end end, __index = { tostring = function (v) return v:v3string() end, v3string = function (v) return pformat("(%s,%s,%s)", v[1], v[2], v[3]) end, v2string = function (v) return tostring(v:tov2()) end, tov2 = function (v) return v[1]*v.p1 + v[2]*v.p2 + v[3]*v.p3 end, p1 = V{2,-1}, p2 = V{2,1}, p3 = V{0,2}, }, } v3 = function (x,y,z) return V3{x,y,z} end = v3(2,3,4) = v3(2,3,4)*10 = v3(2,3,4):v2string() V3.__index.tostring = function (v) return v:v3string() end V3.__index.tostring = function (v) return v:v2string() end = expr("v3(2,3,4)") foo = function (str) local f = function (s) return tostring(expr(s)) end return (str:gsub("<([^<>]+)>", f)) end -- (find-dn6 "heads6.lua" "lua-head") = Pict = foo "ab<1+2>cd<v3(2,3,4)>" return string.gsub(str, "%$([%a_][%w_]*)", function (e) return getenv(e) or "" end) ##### # # Functions to draw multiplication and division of polynomials # 2021apr25 # ##### # «drawing-polys» (to ".drawing-polys") # (find-LATEXfile "2020-2-C2-ids-trigs.lua") # (c2m202itp 2 "div-polis") # (c2m202it "div-polis") ##### # # Diagramas de numerozinhos - low-level approach # 2021apr29 # ##### # «numerozinhos» (to ".numerozinhos") # (find-LATEX "2020-2-C3-P1.tex" "numerozinhos") # (mpgp 24 "Fxy") # (mpg "Fxy") # (find-LATEX "material-para-GA.tex" "pictureFxy") # (find-LATEX "edrxpict.lua" "pictFxy") # (find-LATEX "edrxpict.lua" "pictFxy" "tcell") # (find-LATEX "2020-2-C2-ids-trigs.lua") # (find-LATEX "2020-2-C2-ids-trigs.lua" "CCells") # (find-LATEX "2020-2-C2-ids-trigs.lua" "CCells" "addlatexto =") # (find-dn6 "zhas.lua" "MixedPicture") # (find-dn6 "picture.lua" "AsciiPicture") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() f = function (x,y) return min(x,y) end mp = MixedPicture.new({zdef="demo", scale="10pt", meta=""}) mp.ap.s = " " mp.lp:addt("\\Line(-3,0)(3,0)") mp.lp:addt("\\Line(0,3)(0,-3)") for y=2,-2,-1 do for x=-2,2 do mp:put(v(x,y), tostring(f(x,y))) end end = mp = mp:tolatex() * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() MixedPicture.__index.addnumerosaxes = function (mp, xmin, xmax, ymin, ymax) mp.lp:addt("\\Line(%s,0)(%s,0)", xmin-0.5, xmax+0.5) mp.lp:addt("\\Line(0,%s)(0,%s)", ymin-0.5, ymax+0.5) return mp end MixedPicture.__index.addnumerozinhos = function (mp, xmin, xmax, ymin, ymax, f) for y=ymin,ymax do for x=xmin,xmax do mp:put(v(x,y), tostring(f(x,y))) end end return mp end mp = MixedPicture.new({zdef="demo", scale="10pt", meta=""}) mp.ap.s = " " f = function (x,y) return min(x,y) end mp:addnumerosaxes (-2,4, -2,4) mp:addnumerozinhos(-2,4, -2,4, f) = mp ##### # # error-2021-04-21 # 2021apr21 # ##### # «error-2021-04-21» (to ".error-2021-04-21") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rfv /tmp/dednat6/ mkdir /tmp/dednat6/ cd /tmp/dednat6/ wget http://angg.twu.net/dednat6.zip unzip dednat6.zip export PATH=/usr/local/texlive/2021/bin/x86_64-linux:$PATH lualatex demo-minimal.tex ##### # # Show non-open sets using color # 2021may08 # ##### # «color-non-open» (to ".color-non-open") # (find-LATEX "2021groth-tops-children.lua" "zha-colors") # (find-dn6 "picture.lua" "V") # (find-dn6 "picture.lua" "AsciiPicture") # (find-dn6 "picture.lua" "AsciiPicture" "put =") # (find-dn6 "picture.lua" "AsciiPicture-tests") # (find-dn6 "zhas.lua" "MixedPicture") # (find-dn6 "zhas.lua" "MixedPicture" " celltotex =") # (find-dn6 "zhas.lua" "MixedPicture" " put =") # (find-dn6 "zhas.lua" "MixedPicture" " addcells =") # (find-dn6 "zhas.lua" "MixedPicture-tests") # (find-LATEX "2021groth-tops-defs.tex" "ArtDecoNQ") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() = v"20" = v"20":And(v"11") = v"20":And(v"11"):lr() = v"20":Or (v"11"):lr() V.__index.minmaxlr = function (A, B) local minl,minr = A:And(B):to_l_r() local maxl,maxr = A:Or (B):to_l_r() return minl,maxl,minr,maxr end = v"46":minmaxlr(v"53") betweens = function (A, B) A, B = v(A), v(B) local minl,minr = A:And(B):to_l_r() local maxl,maxr = A:Or (B):to_l_r() return cow(function () for l=minl,maxl do for r=minr,maxr do coy(l, r) end end end) end for l,r in betweens("46", "53") do print(l, r) end MixedPicture.__index.putcolor = function (mp, A, str) A = v(A) str = str:gsub("~", A:lr()) mp.ap:put(A, str) return mp end MixedPicture.__index.putcolors = function (mp, A, B, str) for l,r in betweens(A, B) do mp:putcolor(v(l, r):lrtoxy(), str) end return mp end MixedPicture.__index.putleftgen = function (mp, l, r, green, red, orange, yellow) local lr = function (l, r) return v(l, r):lrtoxy() end mp:putcolor (lr(l, r), green or "\\G~") mp:putcolors(lr(l, r-1), thisleft, yellow or "\\Y~") mp:putcolor (lr(l, r-1), red or "\\R~") mp:putcolor (lr(l, r-2), orange or "\\O~") mp:putcolor (lr(l+1, r-1), orange or "\\O~") return mp end MixedPicture.__index.putrightgen = function (mp, l, r, green, red, orange, yellow) local lr = function (l, r) return v(l, r):lrtoxy() end mp:putcolor (lr(l, r), green or "\\G~") mp:putcolors(lr(l-1, r), thisright, yellow or "\\Y~") mp:putcolor (lr(l-1, r), red or "\\R~") mp:putcolor (lr(l-2, r), orange or "\\O~") mp:putcolor (lr(l-1, r+1), orange or "\\O~") return mp end MixedPicture.__index.transfercolors = function (mp) for l,r in betweens("00", thistop) do local str = bitrim(mp.ap:get(lr(l, r))) if str ~= "" then mp.lp:put(lr(l, r), str) end end return mp end = lr = lr(2,0) -- (jonp 3 "basic-definitions") -- (jos "basic-definitions") -- (jonp 16 "valuations") -- (jov "valuations") thistop = v"46" thisleft = v"40" thisright = v"06" Foo_ts = TCGSpec.new("43; , ") Foo_mp = Foo_ts:mp({zdef="H_zha", scale="11pt", meta=nil}) Foo_mp.ap.s = " " Foo_mp:putcolors("00", "46", "~") Foo_mp:putleftgen(2, 2) Foo_mp:putrightgen(2, 5) = Foo_mp Foo_mp:putleftgen(2, 2, nil, "", "", "") Foo_mp:putrightgen(2, 5, nil, "", "", "") = Foo_mp Foo_mp:transfercolors() = Foo_mp:tolatex() ##### # # The "pictreplace" head for "%P" lines # 2021aug09 # ##### # «pictreplace» (to ".pictreplace") # (find-LATEX "2020-2-C3-plano-tang.lua" "pictreplace") # (find-LATEX "2020-2-C3-plano-tang.lua" "pictreplace-tests") # (find-dednat6 "tugboat-rev2.tex" "creating-new-heads") # (find-pdf-page "~/dednat6/tugboat-rev2.pdf" 5) # Used in: # (find-LATEXgrep "grep --color=auto -nH --null -e '%P' 202*.tex") # (c3m202planotangp 27 "3D-fig") # (c3m202planotanga "3D-fig") # (c3m211cnp 15 "figura-piramide") # (c3m211cna "figura-piramide") # (c3m211dpp 11 "3D-fig") # (c3m211dpa "3D-fig") # (c3m211nfp 18 "quadraticas-exemplos") # (c3m211nfa "quadraticas-exemplos") # (c3m211nfa "quadraticas-exemplos" "%P") ##### # # Convert the tree in 2021burghardt.tex to an UndTree # 2021sep29 # ##### # «burghardt» (to ".burghardt") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() require "block" -- (find-dn6 "block.lua") = Path.prepend("path", "~/LUA/?.lua") require "Rect" -- (find-angg "LUA/Rect.lua" "undtolatex-tests") -- (find-LATEX "2021burghardt.tex" "tree") texfile0("~/LATEX/2021burghardt.tex") = tf output = print tf:processuntil(tf.j) = tf = allsegments = allsegments[79] = allsegments[79][1] caretsegs = {} for n,segments in pairs(allsegments) do local seg = segments[1] if seg and seg.t:match("^^") then print(seg); caretsegs[seg.t] = seg end end PPV(caretsegs) caretseg = caretsegs["^Bur-tree"] = caretseg = caretseg:rootnode() = caretseg:rootnode():totreenode() tree = caretseg:rootnode():totreenode() = tree PPV(tree) = undtolatex(tree) defbody = undtolatex(tree) deffull = "\\def\BurUnd{\n"..defbody.."\n}" = deffull output(deffull) caretsegs = {} for n,segments in pairs(allsegments) do local seg = segments[1] if seg and seg.t:match("^^") then print(seg); caretsegs[seg.t] = seg end end caretseg = caretsegs["^Bur-tree"] tree = caretseg:rootnode():totreenode() defbody = undtolatex(tree) deffull = "\\def\BurUnd{\n"..defbody.."\n}" output(deffull) -- (find-dn6 "treetex.lua" "ProofSty-test") -- (find-dn6 "treesegs.lua") -- (find-dn6 "heads6.lua" "tree-head") ##### # # lean-nng # 2021oct13 # ##### # «lean-nng» (to ".lean-nng") # (find-dn6 "treesegs.lua" "Segments") # (find-LATEXfile "2021lean-nng.tex") * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() output = print require "block" -- (find-dn6 "block.lua") -- (find-LATEX "2021lean-nng.tex" "tree") texfile0("~/LATEX/2021lean-nng.tex") = tf tf:processuntil(tf.j) = tf = Path.prependtopath "~/LUA/?.lua" require "Rect" -- (find-angg "LUA/Rect.lua") require "Re" -- (find-angg "LUA/Re.lua") lean_gram = [=[ stuff <- {~ ( wordsf / special / . ) * ~} wordsf <- {~ ("" -> "\textsf{") word ("" -> "}")~} word <- {~ ([A-Za-z0-9]+ / ('_' -> '\_')) + ~} special <- ( '[' / ']' / '.' ) -> specials ]=] lean_specials = { ["["] = "<<", ["]"] = ">>", ["."] = "\\,", } lean_rt0 = Re { grammar = lean_gram, defs = {specials = lean_specials} } lean_rtp = Re { grammar = lean_gram, defs = {specials = lean_specials}, print = PP } lean_rtp:c 'top <- word' 'foo_bar0plic bletch' lean_rtp:c 'top <- wordsf' 'foo_bar0plic bletch' lean_rtp:c 'top <- stuff' 'foo_bar0plic bletch' lean_rtp:c 'top <- stuff' 'foo_bar0plic.[bletch]' lean_rt0:c 'top <- stuff' 'foo_bar0plic.[bletch]' lean_rtranslate = lean_rt0:c 'top <- stuff' PP(lean_rtranslate 'foo_bar0plic.[bletch]') proofsty = ProofSty.new() proofsty.unabbrev = function (ps, str) return lean_rtranslate(str) end TreeNode.__index.TeX_deftree = function (tn, name, link) return proofsty:todefded(tn, name, link) end texfile0("~/LATEX/2021lean-nng.tex") tf:processuntil(tf.j) # Old: * (eepitch-lua51) * (eepitch-kill) * (eepitch-lua51) loaddednat6() = Path.prependtopath "~/LUA/?.lua" require "block" -- (find-dn6 "block.lua") require "Rect" -- (find-angg "LUA/Rect.lua") -- (find-LATEX "2021lean-nng.tex" "tree") texfile0("~/LATEX/2021lean-nng.tex") = tf output = print tf:processuntil(tf.j) = tf PPPV(allsegments) = allsegments = allsegments:last(1000) = allsegments:last(1000):totreenode() ##### # # fitch # 2021oct20 # ##### # «fitch» (to ".fitch") # «ftch» (to ".ftch") # (find-angg ".emacs" "dednat6-ftch") # (find-es "tex" "kluwer-fitch") # (find-LATEX "2021fitch.tex" "defftch") # (find-LATEX "2021fitch.lua") ##### # # slides-to-pngs # 2022oct22 # ##### # «slides-to-pngs» (to ".slides-to-pngs") # (find-fline "~/IMAGES/") # (find-fline "~/IMAGES/" "dednat6") # (find-pdf-page "~/dednat6/tug-slides.pdf") # (find-man "pdftoppm") # (find-TH "dednat6" "introduction") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/pdf-jpg-pdf/ mkdir /tmp/pdf-jpg-pdf/ cd /tmp/pdf-jpg-pdf/ # pdftoppm -jpeg -jpegopt quality=80 -r 150 ~/dednat6/tug-slides.pdf b # pdftoppm -jpeg -jpegopt quality=80 -r 60 ~/dednat6/tug-slides.pdf b pdftoppm -png -r 100 ~/dednat6/tug-slides.pdf dednat6-slides pdftoppm -png -r 125 ~/dednat6/tug-slides.pdf dednat6-slides # (find-fline "/tmp/pdf-jpg-pdf/") # (find-fline "/tmp/pdf-jpg-pdf/dednat6-slides-07.png") # (find-fline "/tmp/pdf-jpg-pdf/dednat6-slides-09.png") # (find-fline "/tmp/pdf-jpg-pdf/dednat6-slides-10.png") cd /tmp/pdf-jpg-pdf/ cp -v dednat6-slides-07.png ~/IMAGES/ cp -v dednat6-slides-09.png ~/IMAGES/ cp -v dednat6-slides-10.png ~/IMAGES/ makeL; makeR ##### # # Copying the files of Dednat7 to ~/dednat7/ # 2024sep12 # ##### # «dednat7-dednat7» (to ".dednat7-dednat7") # (find-angg "dednat7/dednat7.sh") # (find-angg "LUA/dednat7load.lua") # (find-fline "~/LATEX/" "dednat7-test1.tex") # (find-fline "~/LATEX/dednat7-test1.tex") # (find-angg "LUA/lua50init.lua" "DednatRequire" "loadfile =") # (find-dn6 "treetex.lua") # (find-dn6 "diagforth.lua") * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) . ~/dednat7/dednat7.sh prep1 # rm -v /tmp/dn7test/dednat6/errors.lua lualatex dednat7-test1.tex xpdf dednat7-test1.pdf * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) . ~/dednat7/dednat7.sh prep1 tar -cvzf dednat7.tgz * laf dednat7.tgz cd /tmp/dn7test/ scp dednat7.tgz $LINP/tmp/ * (eepitch-shell) * (eepitch-kill) * (eepitch-shell) rm -Rv /tmp/dn7test/ mkdir /tmp/dn7test/ cd /tmp/dn7test/ wget http://anggtwu.net/tmp/dednat7.tgz tar -xvzf dednat7.tgz # (find-fline "/tmp/dn7test/") # (find-fline "/tmp/dn7test/dednat7-test1.tex") lualatex dednat7-test1.tex xpdf dednat7-test1.pdf # (find-fline "/tmp/dn7test/" "dednat7.tgz") # (find-cp-angg-links "dednat7.tgz" "/tmp/dn7test/" "tmp/") ##### # # Leonan testou o Dednat7 em 2024nov28 # 2024dec01 # ##### # «dednat7-leonan-2024» (to ".dednat7-leonan-2024") # (find-telegachat "-1002074960141#877" "Leonan dednat7") # Local Variables: # coding: utf-8-unix # End: