内容简介:Optimath is an experimental const generics based linear algebra library that works without any allocations in no_std and utilizes simd. So now you can do fancy maths on embedded.This library is based around one type,A
Optimath is an experimental const generics based linear algebra library that works without any allocations in no_std and utilizes simd. So now you can do fancy maths on embedded.
Intro
This library is based around one type, Vector that passes on element-wise operations (+-*/) to its contained elements. Vectors have a size that is known at compile time thanks to const generics.
// Vectors can be initalized from an rng, let a: Vector<i32, 2000> = rng.gen(); // from iterators let b: Vector<i32, 2000> = (0..2000).collect(); // with an initalizer function let c: Vector<i32, 2000> = Vector::build_with_fn(|i| i as i32); // or using Default let d: Vector<i32, 2000> = Default::default(); let e = &a + &b; let f = &c + &d; let h = &e + &f;
A Matrix is therefore just a Vector<Vector<T>>, but has specific methods, namely transpose and matrix_multiply implemented on it.
use optimath::Matrix; let a: Matrix<f32, 2, 3> = Default::default(); let b: Matrix<f32, 3, 4> = Default::default(); // matrix size is checked at compile time! let c: Matrix<f32, 2, 4> = a.matrix_multiply(&b); // transpositions are just views on matrices. // can be materialized on demand let c2 = c.transpose().materialize().transpose().materialize(); assert_eq!(c, c2);
You can find a lot of further information in the README .
I have been mostly concerned with library design, if you need any specific operation please feel free to open an issue (or a pull request of course).
Specialization
Optimath not only uses const generics, but also specialization, for the full type adventure experience.
There has been an issue that stopped you from calculating array sizes at compile time. A lot of this crates further development has been blocked on that. This issue has luckily been resolved by now, but the docs of version 0.3.0 still refer to it. You will therefore need quite a recent nightly to compile version 0.4.0 and onwards.
Specialization is then used to override the generic pass-trough operations (+-*/) for specific types, like Vector<f32>. On those instead of doing element-wise addition SIMD can be used. Or at least that is how I initially did it. Checking the assembly (shoutout to cargo-asm ) I noticed that rustc/llvm already did perfect SIMD, especially with the help of explicit alignment. Doing some benchmarks showed no gain from manually re-implementing that.
They still need to pack/unpack &[f32; 4] into one simd-register though. The next step is therefore to just always store the types in an SIMD compatible way. That had been blocked on the aforementioned issue. Some experimentation can be found in the (disabled) layout module .
Purpose
I started this library because there was no no_std capable linear algebra library available and I wanted to move movedumbnet away from GenericArray now that const generics are available in rust. So the initial purpose of optimath was to fit my personal usecase.
One possible direction is to make this the base of a rust BLAS library, there is a detailed planned changelog in the README .
Its also intended as a playground and an exploration on how a const generics may be adapted in a linalg crate. I would be perfectly happy to merge this with for example ndarray at some point.
Additionally it might be a motivating example for the rust devs working on const generics and specialization, showing off some real usecases. And finding compiler bugs, ofc :).
For both of those groups there is some takeaways in the insights module .
no_std notice
no_std users will have to comment out the dev-dependencies cause they seem to be polluting the real ones. i do not know how to turn that off sadly. With them commented out
cargo build --target=armebv7r-none-eabihf --release
builds without errors. If anyone knows how to fix that don't hesitate to contact me!
You can also join the discussion on reddit !
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
统计思维:程序员数学之概率统计
Allen B.Downey / 张建锋、陈钢 / 人民邮电出版社 / 2013-5 / 29.00元
代码跑出来的概率统计问题; 程序员的概率统计开心辞典; 开放数据集,全代码攻略。 现实工作中,人们常被要求用数据说话。可是,数据自己是不能说话的,只有对它进行可靠分析和深入挖掘才能找到有价值的信息。概率统计是数据分析的通用语言,是大数据时代预测未来的根基。 站在时代浪尖上的程序员只有具备统计思维才能掌握数据分析的必杀技。本书正是一本概率统计方面的入门图书,但视角极为独特,折......一起来看看 《统计思维:程序员数学之概率统计》 这本书的介绍吧!