How to Begin SageMath Development

This is a quick guide for developers who want to contribute to SageMath. It is intended especially for newbie programmers.

First, SageMath's main language is Python. Some parts of SageMath can be written in other languages, especially the components that do the heavy number crunching, but most native functionality is done in Python, including "glue code".

One of the good aspects of Python that Sage inherits is that working code is considered more valuable than just fast code. Sure, fast code is good, but clean, readable code is important, and as anything math-related, inaccurate results are unacceptable. Correctness comes before optimization.

If you don't know Python, you should start there, since it is SageMath's main language. A good place to start is the Python Official Tutorial and other documents available at . Another good place to take a look at is Dive Into Python, which may be pretty helpful in some specific topics like test-driven development.

In the meantime, you can grab your copy of the sage source and get used to git. The pro git book is recommended for those who aren't used to that version control system (and to some extent to those who never used such a system).

Once you are comfortable with Python itself (which is pretty fast for basics) you can start using SageMath. If you want, you can try to learn Python by using SageMath, but that isn't recommended because it's helpful to know what is pure Python and what is SageMath doing its "magic". There are many things that work on one that don't on the other, because SageMath does a lot of type conversions behind the scenes.

Then take a look at the official development guide for SageMath. After that, you can take a look at the trac guidelines which details some aspects of SageMath development and how to get a Trac account. You can also join the sage-devel list at Google Groups and hang around the #sage-devel IRC channel on Freenode. Getting an account in this wiki can be helpful too.

Then, you can choose to grab a ticket from the trac server to solve or you may want to implement some feature you have in mind. If you want to implement something, it's good practice to include a ticket and/or discuss in the group first, so that the gurus can give their opinion (and it's nice to listen to them, since they know SageMath's internals much better and may give some advice). They are pretty open to new ideas, too, like all mathematicians should be :)

Please write Python3-compatible code (see Python3-compatible code)

devel/BeginSageDevelopment (last edited 2016-12-08 21:02:45 by chapoton)