Tidier.jl
StaticCompiler.jl
Tidier.jl | StaticCompiler.jl | |
---|---|---|
5 | 16 | |
493 | 475 | |
4.9% | - | |
8.5 | 6.9 | |
11 days ago | 9 days ago | |
Julia | Julia | |
MIT License | GNU General Public License v3.0 or later |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Tidier.jl
- Tidier.jl: Meta-package for data analysis in Julia, modeled after R tidyverse
-
Julia 1.10 Released
btw, there has been a pretty nice effort of reimplementing the tidyverse in julia with https://github.com/TidierOrg/Tidier.jl and it seems to be quite nice to work with, if you were missing that from R at least
-
Pandas vs. Julia – cheat sheet and comparison
Indeed DataFrames.jl isn't and won't be the fastest way to do many things. It makes a lot of trade offs in performance for flexibility. The columns of the dataframe can be any indexable array, so while most examples use 64-bit floating point numbers, strings, and categorical arrays, the nice thing about DataFrames.jl is that using arbitrary precision floats, pointers to binaries, etc. are all fine inside of a DataFrame without any modification. This is compared to things like the Pandas allowed datatypes (https://pbpython.com/pandas_dtypes.html). I'm quite impressed by the DataFrames.jl developers given how they've kept it dynamic yet seem to have achieved pretty good performance. Most of it is smart use of function barriers to avoid the dynamism in the core algorithms. But from that knowledge it's very clear that systems should be able to exist that outperform it even with the same algorithms, in some cases just by tens of nanoseconds but in theory that bump is always there.
In the Julia world the one which optimizes to be fully non-dynamic is TypedTables (https://github.com/JuliaData/TypedTables.jl) where all column types are known at compile time, removing the dynamic dispatch overhead. But in Julia the minor performance gain of using TypedTables vs the major flexibility loss is the reason why you pretty much never hear about it. Probably not even worth mentioning but it's a fun tidbit.
> For what it's worth, data.table is my favourite to use and I believe it has the nicest ergonomics of the three I spoke about.
I would be interested to hear what about the ergonomics of data.table you find useful. if there are some ideas that would be helpful for DataFrames.jl to learn from data.table directly I'd be happy to share it with the devs. Generally when I hear about R people talk about tidyverse. Tidier (https://github.com/TidierOrg/Tidier.jl) is making some big strides in bringing a tidy syntax to Julia and I hear that it has had some rapid adoption and happy users, so there are some ongoing efforts to use the learnings of R API's but I'm not sure if someone is looking directly at the data.table parts.
-
Tidyverse 2.0.0
“Tidier.jl is a 100% Julia implementation of the R tidyverse mini-language in Julia.”
https://github.com/TidierOrg/Tidier.jl
-
What's Julia's biggest weakness?
A recent package, Tidier.jl, is coming from a R package developer: https://github.com/kdpsingh/Tidier.jl
StaticCompiler.jl
-
Potential of the Julia programming language for high energy physics computing
Yes, julia can be called from other languages rather easily, Julia functions can be exposed and called with a C-like ABI [1], and then there's also various packages for languages like Python [2] or R [3] to call Julia code.
With PackageCompiler.jl [4] you can even make AOT compiled standalone binaries, though these are rather large. They've shrunk a fair amount in recent releases, but they're still a lot of low hanging fruit to make the compiled binaries smaller, and some manual work you can do like removing LLVM and filtering stdlibs when they're not needed.
Work is also happening on a more stable / mature system that acts like StaticCompiler.jl [5] except provided by the base language and people who are more experienced in the compiler (i.e. not a janky prototype)
[1] https://docs.julialang.org/en/v1/manual/embedding/
[2] https://pypi.org/project/juliacall/
[3] https://www.rdocumentation.org/packages/JuliaCall/
[4] https://github.com/JuliaLang/PackageCompiler.jl
[5] https://github.com/tshort/StaticCompiler.jl
-
Julia App Deployment
PackageCompiler, but it' s a fat runtime and not cross compile. A thin runtime is currently not possible without sacrifices for feature as https://github.com/tshort/StaticCompiler.jl.
-
JuLox: What I Learned Building a Lox Interpreter in Julia
https://github.com/tshort/StaticCompiler.jl/issues/59 Would working on this feasible?
- Making Python 100x faster with less than 100 lines of Rust
- What's Julia's biggest weakness?
-
Size of a "hello world" application
I just read the project's documentation at https://github.com/tshort/StaticCompiler.jl. It does produce a "hello world" application that is only 8.4k in size 👍. I do like that it can work on Mac OS. Hopefully Windows support will come soon.
-
Why Julia 2.0 isn’t coming anytime soon (and why that is a good thing)
See https://github.com/tshort/StaticCompiler.jl
- My Experiences with Julia
-
Julia for health physics/radiation detection
You're probably dancing around the edges of what [PackageCompiler.jl](https://github.com/JuliaLang/PackageCompiler.jl) is capable of targeting. There are a few new capabilities coming online, namely [separating codegen from runtime](https://github.com/JuliaLang/julia/pull/41936) and [compiling small static binaries](https://github.com/tshort/StaticCompiler.jl), but you're likely to hit some snags on the bleeding edge.
-
We Use Julia, 10 Years Later
using StaticCompiler # `] add https://github.com/tshort/StaticCompiler.jl` to get latest master
What are some alternatives?
Julia-DataFrames-Tutorial - A tutorial on Julia DataFrames package
julia - The Julia Programming Language
tidytable - Tidy interface to 'data.table'
PackageCompiler.jl - Compile your Julia Package
py-shiny - Shiny for Python
acados - Fast and embedded solvers for nonlinear optimal control
DataFramesMeta.jl - Metaprogramming tools for DataFrames
GPUCompiler.jl - Reusable compiler infrastructure for Julia GPU backends.
oneAPI.jl - Julia support for the oneAPI programming toolkit.
db-benchmark - reproducible benchmark of database-like ops
LoopVectorization.jl - Macro(s) for vectorizing loops.