Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Scientific Computing in Ruby at Ruby World Conf...
Search
Sameer Deshmukh
November 03, 2016
Programming
1
220
Scientific Computing in Ruby at Ruby World Conference 2016.
Talk on Scientific Computing in Ruby at Ruby World Conference, Matsue City, Shimane, Japan.
Sameer Deshmukh
November 03, 2016
Tweet
Share
More Decks by Sameer Deshmukh
See All by Sameer Deshmukh
XND and rubyplot - typed arrays and visualization in Ruby
v0dro
0
210
Ferrari Driven Development: superfast Ruby with Rubex
v0dro
0
2k
Ruby Kaigi 2017 - C how to supercharge your Ruby with Rubex
v0dro
1
430
Deccan Ruby Conf 2017 Rubex intro
v0dro
0
91
Rubex: A new way of writing C extensions for CRuby
v0dro
1
530
Scientific Computing in Ruby at Ruby World Conference 2016
v0dro
0
120
Data Analysis in RUby with daru
v0dro
3
3.6k
Introduction benchmark-plot at PRUG
v0dro
0
110
Webinar - Scientific Computing and Data Visualization
v0dro
0
96
Other Decks in Programming
See All in Programming
品質ワークショップをやってみた
nealle
0
650
bootcamp2025_バックエンド研修_WebAPIサーバ作成.pdf
geniee_inc
0
140
Leading Effective Engineering Teams in the AI Era
addyosmani
7
660
外接に惑わされない自システムの処理時間SLIをOpenTelemetryで実現した話
kotaro7750
0
110
釣り地図SNSにおける有料機能の実装
nokonoko1203
0
200
開発組織の戦略的な役割と 設計スキル向上の効果
masuda220
PRO
10
1.8k
Vueのバリデーション、結局どれを選べばいい? ― 自作バリデーションの限界と、脱却までの道のり ― / Which Vue Validation Library Should We Really Use? The Limits of Self-Made Validation and How I Finally Moved On
neginasu
2
1.7k
Things You Thought You Didn’t Need To Care About That Have a Big Impact On Your Job
hollycummins
0
260
React Nativeならぬ"Vue Native"が実現するかも?_新世代マルチプラットフォーム開発フレームワークのLynxとLynxのVue.js対応を追ってみよう_Vue Lynx
yut0naga1_fa
2
1.8k
When Dependencies Fail: Building Antifragile Applications in a Fragile World
selcukusta
0
110
オープンソースソフトウェアへの解像度🔬
utam0k
17
3.2k
テーブル定義書の構造化抽出して、生成AIでDWH分析を試してみた / devio2025tokyo
kasacchiful
0
320
Featured
See All Featured
Documentation Writing (for coders)
carmenintech
75
5.1k
4 Signs Your Business is Dying
shpigford
186
22k
What's in a price? How to price your products and services
michaelherold
246
12k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
BBQ
matthewcrist
89
9.9k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.2k
Stop Working from a Prison Cell
hatefulcrawdad
272
21k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.5k
Balancing Empowerment & Direction
lara
5
700
Building a Scalable Design System with Sketch
lauravandoore
463
33k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
48
9.7k
Making the Leap to Tech Lead
cromwellryan
135
9.6k
Transcript
namaste
Incredible India
None
None
None
India must master Western science and yet preserve its Culture
and Heritage. What India Dreams
None
City of Pune. Population: 6 million. Oxford of the East.
Sameer Deshmukh github.com/v0dro @v0dro
None
Dr. Gopal Deshmukh Sameer Desmukh Dr. Hemchandra Deshmukh Dr. Satish
Deshmukh
www.soundcloud.com/catkamikazee Sameer
None
None
Pune Ruby Users Group www.punerb.org @punerb @punerb @deccanrubyconf www.deccanrubyconf.org
Ruby Science Foundation www.sciruby.com @sciruby @sciruby
None
Scientific Computing In Ruby
iruby notebook
Browser based Ruby REPL for interactive computing.
Runs in your browser Input cell – accepts Ruby code
Output cell – can render HTML/CSS/JS
None
nmatrix
ndimensional array object. Interface Ruby with high speed C libraries.
require 'nmatrix' n = NMatrix.new( [2,2], [1,2,3,4], dtype: :float32, stype:
:dense ) n[0,1] # => 2.0
Data Types :int8 :float32 :int16 :float64 :int32 :complex64 :int64 :complex128
Storage types Dense Dense matrix. List Sparse matrix type storing
data as a linked list. Yale Sparse type storing data in the 'New Yale' format.
NMatrix C API
nmatrix nmatrix atlas nmatrix lapacke nmatrix fftw gsl
nyaplot
Interactive plotting tool for Rubyists.
interactive HTML and JavaScript plots that can be displayed in
your browser.
None
Mapnya Nyaplot3D Bionya Map visualizations with inbuilt country charts. Three
Dimensional interactive plots. Biology plots for visualizing relationships of genes.
daru (Data Analysis in RUby)
daru == (Hindi) ददार sake alcohol
library for analysis, cleaning, manipulation and visualization of data.
Read/write many data sources Ephemeral statistics functions Works well with
'wild' data Data indexing
Acts as glue between other SciRuby libraries.
Daru::Vector Heterogenous Array that can be indexed on any Ruby
object. Name Label(0) Label(1) Label(2) ... Label(n-1)
Daru::DataFrame 2D spreadsheet like data structure indexed by rows or
columns. Col0 Label(0) Label(1) Label(2) ... Label(n-1) Col1 Col2 Col(n-1) ....
New Ideas for better Ruby
“Any sufficiently advanced technology is indistinguishable from magic.” Arthur
C. Clarke
Writing C extensions • FFI gem. • Rice. • SWIG.
• Writing C bindings manually.
Rubyist! Write me a C extension!
def factorial n n > 1 ? n*factorial(n-1) : 1
end
unsigned long long int calc_factorial(unsigned long long int n) {
return (n > 1 ? n*calc_factorial(n-1) : 1); } static VALUE cfactorial(VALUE self, VALUE n) { return ULL2FIX( calc_factorial(NUM2ULL(n))); }
void Init_factorial() { VALUE cFact = rb_define_class("Fact", rb_cObject); rb_define_method(cFact, "factorial",
cfactorial, 1); }
a = Fact.new a.factorial(8000)
Big Problems • Difficult and irritating to write. • Time
consuming to debug. • Tough to trace memory leaks. • Change mindset from high level to low level language. • Need to care about small things.™* *Matz – Keynote at Red Dot Ruby Conf 2016, Singapore.
Rubex
Rubex is a Crystalinspired superset of Ruby that compiles to
C.
class Fact def factorial(unsigned long long int n) n >
1 ? n*factorial(n-1) : 1 end end
# Create a C static array and return a Ruby
Array def adder(n) a = StaticArray(i32, n) i32 i = 0 i32 sum = 0 a.each(n) { a[i] = i*5 } for 0 <= i < n do sum += a[i] end sum end
Received the Ruby Association Grant 2016 for development of Rubex
https://github.com/v0dro/rubex
Scientific Computing on JRuby
NMatrix and NArray are a linear algebra libraries for Ruby
similar to numpy.
NMatrix C/C++ core CRuby interpreter Numo::NArray C core CRuby interpreter
JRuby backend for the NMatrix Ruby API – Sci. Computing
on JVM.
Allows interfacing JRuby libraries with jBLAS for performance. Uses Apache
Commons Math library for storage and operations on internal Java arrays.
https://github.com/prasunanand/ nmatrix/tree/jruby_port
Symbolic Computation in Ruby with symengine.rb
(x – y) * (x ** y / z)
require 'symengine' x = SymEngine::Symbol.new("x") y = SymEngine::Symbol.new("y") z =
SymEngine::Symbol.new("z") f = (x – y) * (x ** y / z) f.expand.to_s # x**(1 + y)/z – x**y*y/z f == - (x**y*y/z) + (x**y*x/z) # true
https://github.com/symengine/ symengine.rb
Ruby in Space
NASA SPICE Ruby wrapper spice_rub
require 'spice_rub' k_pool = SpiceRub::KernelPool.instance k_pool.load_folder("spec/data/kernels") epoch = SpiceRub::Time.now moon
= SpiceRub::Body.new(:moon) earth = SpiceRub::Body.now(:earth) earth.position_at(epoch) moon.distance_from(:earth, epoch) # 395791.1464913574 (Km)
https://github.com/gau27/spice_rub
Cool SciRuby Stickers
Thank You Ruby World Conf!
Any questions?