reduce.jl: Symbolic parser generator for Julia language expressions using REDUCE algebra term re-writer, automatically mirrored from https://github.com/chakravala/Reduce.jl https://github.com/chakravala/Reduce.jl
Michael Reed 5ca423f0ce disabled osbit for windows | 6 éve | |
---|---|---|
deps | 6 éve | |
docs | 6 éve | |
src | 6 éve | |
test | 6 éve | |
.codecov.yml | 7 éve | |
.gitignore | 7 éve | |
.travis.yml | 6 éve | |
LICENSE.md | 7 éve | |
README.md | 6 éve | |
REQUIRE | 6 éve | |
appveyor.yml | 6 éve | |
license | 7 éve |
Symbolic parser generator for Julia language expressions using REDUCE algebra term rewrite system
REDUCE is a system for general algebraic computations of interest to mathematicians, scientists and engineers:
Interface for applying symbolic manipulation on Julia expressions using REDUCE's term rewrite system:
RExpr
objects that can parse
into julia Expr
objects and vice versa;rcall
method;reduce>
REPL within the Julia terminal window activated by }
key;+
,-
,*
,^
,/
,//
compute on Symbol
and Expr
types;Additional packages that depend on Reduce.jl are maintained at JuliaReducePkg.
The upstream REDUCE software created by Anthony C. Hearn is maintained by collaborators on SourceForge.
The Reduce
package currently provides the base functionality to work with Julia and Reduce expressions, provided that you have redpsl
in your path. On GNU/Linux/OSX/Windows, Pkg.build("Reduce")
will automatically download a precompiled binary for you. If you are running a different Unix operating system, the build script will download the source and attempt to compile redpsl
for you, success depends on the build tools installed. Automatic download on Windows is supported, although any appveyor build tests for Windows will fail due to absent software distribution infrastructure. However, the automated testing for Travis CI using Linux and OSX are fully operational using Reduce
.
julia> Pkg.add("Reduce"); Pkg.build("Reduce")
julia> using Reduce
Reduce (Free PSL version, revision 4015), 5-May-2017 ...
In order to support Unicode / UTF8 characters, the CSL version of reduce is required. The automated build script currently only fetches the PSL version. However, if you have redcsl
installed on your system it can be used by Reduce.jl by setting the environment variable ENV["REDUCE"] = "redcsl -w"
in julia.
For users who wish to experiment with precomplation, it is possible to enable extra precompilation scripts by setting the environment variable ENV["REDPRE"] = "1"
in julia (only effective when Reduce
is being compiled).
View the documentation stable / latest for more features and examples.
The extended algebraic symbolic expression mode of Reduce.jl is activated with ForceImport.jl by
@force using Reduce.Algebra
This locally extends native Julia functions to Symbol
and Expr
types in the current module without extending global methods. Alternatively, the methods it provides can be accesed by prefixing Algebra.
in front of the method.
Reduce expressions encapsulated into RExpr
objects can be manipulated within julia using the standard syntax. Create an expression object either using the RExpr("expression")
string constructor or R"expression"
. Additionally, arbitrary julia expressions can also be parsed directly using the RExpr(expr)
constructor. Internally RExpr
objects are represented as an array that can be accessed by calling *.str[n]
on the object.
When Reduce
is used in Julia, standard arithmetic operations are now extended to also work on Symbol
and Expr
types.
julia> 1-1/:n
:((n - 1) // n)
julia> ans^-:n
:(1 // ((n - 1) // n) ^ n)
julia> limit(ans,:n,Inf)
e = 2.7182818284590...
Julia abstract syntax trees are automatically converted into sequences of reduce statements (using RExpr
constructor) that are in return parsed into julia quote
blocks usig parse
.
The rcall
method is used to evaluate any type of expression.
julia> :(int(sin(im*x+pi)^2-1,x)) |> rcall
:((1 - (e ^ (4x) + 4 * e ^ (2x) * x)) // (8 * e ^ (2x)))
However, there are often multiple equivalent ways of achieving the same result:
julia> int(sin(im*:x+π)^2-1,:x)
:((1 - (e ^ (4x) + 4 * e ^ (2x) * x)) // (8 * e ^ (2x)))
The output of rcall
will be the same as its input type.
julia> "int(sin(y)^2, y)" |> rcall
"( - cos(y)*sin(y) + y)/2"
Use rcall(expr,switches...)
to evaluate expr
using REDUCE mode switches
like :expand
, :factor
, and :latex
.
julia> :((x+im+π)^2; int(1/(1+x^3),x)) |> RExpr
^(+(x,i,pi),2);
int(/(1,+(1,^(x,3))),x);
julia> rcall(ans,:horner) |> parse
quote
((π + 2x) * π + 2 * (π + x) * im + x ^ 2) - 1
((2 * sqrt(3) * atan((2x - 1) // sqrt(3)) - log((x ^ 2 - x) + 1)) + 2 * log(x + 1)) // 6
end
Call split(::RExpr)
to create a new RExpr
object with all expressions internally split into separate array elements.
Mathematical operators and REDUCE modes can be applied directly to Expr
and RExpr
objects.
julia> Expr(:function,:(fun(a,b)),:(return a^3+3*a^2*b+3*a*b^2+b^3)) |> factor
:(function fun(a, b)
return (a + b) ^ 3
end)
Although not all language features have been implemented yet, it is possible to directly execute a variety of REDUCE style input programs using a synergy of julia syntax.
julia> Expr(:for,:(i=2:34),:(product(i))) |> rcall
:(@big_str "295232799039604140847618609643520000000")
The squash
function provides a way to reduce full program blocks into simplified functions,
julia> Expr(:function,:(example(a,b)),quote
z = 3
target = z * :a * :b
z -= 1
target += z*(1-:a)*(1-:b)
end) |> squash |> factor
:(function example(a, b)
(5b - 2) * a - 2 * (b - 1)
end)
Various output modes are supported. While in the REPL, the default nat
output mode will be displayed for RExpr
objects.
julia> :(sin(x*im) + cos(y*φ)) |> RExpr
(sqrt(5) + 1)*y
cos(-----------------) + sinh(x)*i
2
This same output can also be printed to the screen by calling print(nat(r))
method.
It is possible to direclty convert a julia expression object to LaTeX code using the latex
method.
julia> print(@latex sin(x) + cos(y*φ))
\begin{displaymath}
\cos \left(\left(\left(\sqrt {5}+1\right) y\right)/2\right)+\sin \,x
\end{displaymath}
Internally, this command essentially expands to rcall(:(sin(x) + cos(y*φ)),:latex) |> print
, which is equivalent.
In IJulia
the display output of RExpr
objects will be rendered LaTeX with the rlfi
REDUCE package in latex
mode.
Similar to ? help and ; shell modes in Julia, Reduce
provides a reduce>
REPL mode by pressing shift+] as the first character in the julia terminal prompt. The output is in nat
mode.
reduce> df(atan(golden_ratio*x),x);
2 2
sqrt(5)*x + sqrt(5) - x + 1
-------------------------------
4 2
2*(x + 3*x + 1)
The Reduce
package currently provides a robust interface to directly use the PSL version of REDUCE within the Julia language and the REPL. This is achieved by interfacing the abstract syntax tree of Expr
objects with the parser generator for RExpr
objects and then using an IOBuffer
to communicate with redpsl
.
REDUCE is a system for doing scalar, vector and matrix algebra by computer, which also supports arbitrary precision numerical approximation and interfaces to gnuplot to provide graphics. It can be used interactively for simple calculations but also provides a full programming language, with a syntax similar to other modern programming languages. REDUCE has a long and distinguished place in the history of computer algebra systems. Other systems that address some of the same issues but sometimes with rather different emphasis are Axiom, Macsyma (Maxima), Maple and Mathematica. REDUCE is implemented in Lisp (as are Axiom and Macsyma), but this is completely hidden from the casual user. REDUCE primarily runs on either Portable Standard Lisp (PSL) or Codemist Standard Lisp (CSL), both of which are included in the SourceForge distribution. PSL is long-established and compiles to machine code, whereas CSL is newer and compiles to byte code. Hence, PSL may be faster but CSL may be available on a wider range of platforms.
Releases of Reduce.jl
enable the general application of various REDUCE functionality and packages to manipulate the Julia language to simplify and compute new program expressions at run-time. Intended for uses where a symbolic pre-computation is required for numerical algorithm code generation.
Julia is a high-level, high-performance dynamic programming language for numerical computing. It provides a sophisticated compiler, distributed parallel execution, numerical accuracy, and an extensive mathematical function library. Julia’s Base library, largely written in Julia itself, also integrates mature, best-of-breed open source C and Fortran libraries for linear algebra, random number generation, signal processing, and string processing. The strongest legacy of Lisp in the Julia language is its metaprogramming support. Like Lisp, Julia represents its own code as a data structure of the language itself. Since code is represented by objects that can be created and manipulated from within the language, it is possible for a program to transform and generate its own code. This allows sophisticated code generation without extra build steps, and also allows true Lisp-style macros operating at the level of abstract syntax trees.
If the reduce>
REPL is not appearing when }
is pressed or the Reduce.PSL
pipe is broken, the session can be restored by simply calling Reduce.Reset()
, without requiring a restart of julia
or reloading the package. This kills the currently running redpsl
session and then re-initializes it for new use.
Otherwise, questions can be asked on gitter/discourse or submit your issue or pull-request if you require additional features or noticed some unusual edge-case behavior.
Reduce.jl is compatible with the OhMyREPL.jl package.
Place using Reduce
as first package to load in the ~/.juliarc.jl
startup file to ensure the REPL loads properly (when also using OhMyREPL
). Otherwise, if you are loading this package when Julia has already been started, load it after OhMyREPL
.