Skip to content
mohawkjohn edited this page Jan 6, 2011 · 25 revisions

== The Manifesto ==

Ruby has no equivalent to the beautifully constructed numpy, scipy, and matplotlib libraries for Python. We believe that the time for a Ruby science and visualization package has come and gone. Sometimes when a solution of sugar and water becomes super-saturated, from it precipitates a pure, delicious, and diabetes-inducing crystal of sweetness, induced by no more than the tap of a finger. So it is, we believe, with the need for numeric and visualization libraries in Ruby.

We are not [http://codeforpeople.com/ the first] with this idea, but we want to bring it to life.

As a further note, we believe that Ruby scripts are no different from the methods used in a mechanical experiment (e.g., the wetlab), and must be published along with any ''published'' derivative experimental results. The license for SciRuby shall likely reflect this, ultimately.

=== Who We Are === We are [http://www.ruby-lang.org/ Rubyists], lovers of [http://mislav.uniqpath.com/poignant-guide/ chunky bacon], and [http://en.wikipedia.org/wiki/Science scientists]. Driven mad by the glee of our [http://www.scipy.org/ Python-loving colleagues], we came together [http://kids.niehs.nih.gov/lyrics/peopsing.htm humming Les Mis].

You should join us! [https://spreadsheets.google.com/viewform?formkey=dG80STQzNjBwbHotTjBDUTNIUUVzOWc6MQ Sign up by filling out this form].

Currently, we are:

  • [http://www.chem.byu.edu/users/jtprince John T. Prince], Department of Chemistry & Biochemistry, Brigham Young University
  • [https://github.com/mohawkjohn John O. Woods], Marcotte Lab, The University of Texas at Austin

=== Why Ruby? === First and least, Ruby is a language with a sense of humor.

But more importantly, numerical computation and visualization can be done much better in Ruby, for a number of reasons:

''Everything returns a value.'' Ruby's better object model means better of chaining of computation.

''Iterators'' are way better than ''for'' loops.

''Readability.'' Ruby is incredibly readable, which makes it uber-maintainable.

''Metaprogramming.'' Sometimes the simplest solution is to write a [https://github.com/wycats/thor code generator]. Sometimes, [http://banisterfiend.wordpress.com/2008/10/06/metaprogramming-in-the-ruby-c-api-part-two-dynamic-methods/ eigenclasses] are the cleanest.

''Integration into Rails.'' The influence of Rails on Ruby is undeniable. Web-based visualization for scientific projects is the future.

''R is nice but clunky.'' The learning curve is enormous. It does some things very well, and others not very well at all.

=== Alternatives and Sources of Inspiration ===

  • [https://github.com/alexgutteridge/rsruby rsruby], [http://rinruby.ddahl.org/ rinruby], [https://github.com/jtprince/simpler simpler]: gems which connect Ruby to R
  • [https://github.com/xdotcommer/flotomatic flotomatic]: Rails gem for the Flot Javascript library, for web data visualization.
  • [http://narray.rubyforge.org/ NArray]: Numerical Ruby NArray and Ruby/PGPLOT.
  • [http://rb-gsl.rubyforge.org/ Ruby GSL]: Ruby interface for the GNU Scientific Library

== Directives ==

=== Prime Directive ===

All published results obtained using our libraries must include online publication of any and all source code using our libraries.

=== Numeric Array and Matrix Library ===

For what it is worth, the broad success of python is due, in large part, to its numerical computing core, [http://numpy.scipy.org/ numpy]. A few examples: [http://code.google.com/p/h5py/ h5py], [http://www.pymol.org/ pymol], [http://code.google.com/p/mdanalysis/ mdanalysis],...

Goals: Stable, robust, fast, extremely well-documented core numerical library.

  • FFI (C) or Rice (C++ with Boost) ** Allow for custom C functions with FFI or Rice.
  • Good at casting
  • Consider [http://docs.scipy.org/doc/numpy/reference/ufuncs.html#broadcasting broadcasting]
  • Thoroughly documented, on par with [http://www.yaml.org/YAML_for_ruby.html Yaml Cookbook]
  • Convenience wrappers for GSL, perhaps in a separate module.
  • Eventual inclusion in Ruby core.

NArray is a fantastic library that has served the community for many years. Can it be extended and better documented, or is it better to start from scratch (borrowing conceptually from NArray where we can) using an FFI or Rice interface?

=== Visualization and Plotting Library ===

Goals: High-quality, ''interactive'', dynamic visualizations of the sort seen in [http://processing.org/ Processing] and [http://vis.stanford.edu/protovis/ Protovis].

Currently, the plan is to build a Ruby DSL for creating Protovis plots. This will allow us to produce a variety of image formats, including SVGs, and make visualization fully realizable on the Web.

Clone this wiki locally