Differences between revisions 44 and 45
Revision 44 as of 2010-02-25 15:07:36
Size: 13572
Editor: jason
Comment:
Revision 45 as of 2010-02-25 16:03:47
Size: 15154
Editor: jason
Comment:
Deletions are marked like this. Additions are marked like this.
Line 6: Line 6:
= Sage Tasks Outline =

This is a general outline of targeted areas, including specific tasks, for improving the usability of [[http://www.sagemath.org/ | Sage]]. The sources include the [[devel/SageUsability | Sage Usability Improvements List]] and [[http://sage.math.washington.edu:8100/file/tip/sagenb/todo.txt | sagenb/todo.txt]], but the scope here is wider. Feel free to make changes. To keep items succinct, please make links to group discussions, etc.


############################## GENERAL ##############################
= Sage Projects =

This is a general outline of targeted areas, including specific tasks, for improving the usability of [[http://www.sagemath.org/ | Sage]]. The sources include the [[devel/SageUsability | Sage Usability Improvements List]], but the scope here is wider. Feel free to make changes. To keep items succinct, please make links to group discussions, etc.
Line 14: Line 13:
 * [[http://www.sagenb.org | Sagenb.org]] privacy policy.

 * Y. Aner's [[http://www.gingerlime.com/20090901_securing_sage_notebook.pdf | notebook threat model (PDF)]].

 * [[http://groups.google.com/group/sage-devel/browse_thread/thread/258c07ae672a3617 | SageForge]] - semi-automated repository for contributions to Sage:
 * Make a privacy policy for [[http://www.sagenb.org | Sagenb.org]].

 * Read and make suggestions based on Y. Aner's [[http://www.gingerlime.com/20090901_securing_sage_notebook.pdf | notebook threat model (PDF)]].

 * [[http://groups.google.com/group/sage-devel/browse_thread/thread/258c07ae672a3617 | SageForge]] - establish a semi-automated repository for contributions to Sage. These contributions can include
Line 26: Line 25:
############################## BUILD / TEST ##############################
Line 29: Line 27:
 * Tests:
   * Meaningful statistics / benchmarks, e.g., %timeit for individual doctests.

 * [[http://buildbot.net/ | Buildbot]].

 * Parallel inter/intra-spkg builds.

 * Windows port.

 * Fat binaries (no SSE3, etc.).

 * Notebook functional tests - Extend Selenium tests to other browsers.

 * Notebook load tests - [[http://grinder.sourceforge.net/ | The Grinder]], [[http://funkload.nuxeo.org/ | FunkLoad]], [[http://www.pylot.org/ | Pylot]], [[http://watir.com/ | Watir]], [[http://pypi.python.org/pypi/zope.testbrowser | Zope.testbrowser]] ([[http://trac.sagemath.org/sage_trac/ticket/7468 | now in SageNB]]).


############################## DEVELOPMENT ##############################
 * Make a system for analyzing the performance of doctests. Such a system could be used to do performance regression testing across releases, for example.

 * Make an automated system for building Sage on lots of different platforms.


 * Make progress on the windows port.

 * Enhance the Selenium test suite for the notebook, which tests the notebook code. Extend these tests to other browsers.

 * Make a system for building fat binaries (e.g., no SSE3, etc.)
Line 51: Line 43:
   * Code review tools - [[http://code.google.com/p/rietveld/ | Rietveld]].
   * Automated, continuous builds and testing for new patches.

 * [[http://www.doughellmann.com/articles/CompletelyDifferent-2008-03-linters/index.html | Static Python code analysis]], [[http://pypi.python.org/pypi/pep8/ | pep8]].
   * Make a code review tool for Sage. One possibility is [[http://code.google.com/p/rietveld/ | Rietveld]].
   * Make a system for automatically applying and doctesting every ticket marked "needs review", for example. The system can mark the ticket as "needs work" if the patches don't apply or pass doctests. It would be great if there was an easy way for people to donate computer time to this, say, by running a function that starts the process.

 * Run a static code checker on code (maybe even as part of the automated testing mentioned above). See [[http://www.doughellmann.com/articles/CompletelyDifferent-2008-03-linters/index.html | Static Python code analysis]] or [[http://pypi.python.org/pypi/pep8/ | pep8]].
Line 60: Line 52:
 * Document:

   * Add many more modules to the reference manual.
   * [[http://groups.google.com/group/sage-devel/msg/35e97a1d1cedfdfd | pexpect interface for users]].
   * [[http://groups.google.com/group/sage-devel/browse_thread/thread/6d94c8655e41ba24# | notebook port forwarding]].
   * [[devel/SageNotebook | Notebook server technical overview]].
   * [[http://groups.google.com/group/sage-support/browse_thread/thread/b0d15b82eea3d652 | Run notebook server as daemon]].
 * Add more modules to the reference manual. This involves converting the module to use ReST and adding it to the reference manual file.
 * Document and provide examples of the pexpect interface that users can use to interact with remote Sage servers. See [[http://groups.google.com/group/sage-devel/msg/35e97a1d1cedfdfd]].

 * Notebook
   * Document and provide examples of using ssh port forwarding to access a local Sage notebook server through an SSH tunnel. See [[http://groups.google.com/group/sage-devel/browse_thread/thread/6d94c8655e41ba24# | notebook port forwarding]].
   * Document how the notebook works. See [[devel/SageNotebook | Notebook server technical overview]].
   * Document how to best run the notebook server as a daemon. See [[http://groups.google.com/group/sage-support/browse_thread/thread/b0d15b82eea3d652 | Run notebook server as daemon]].
Line 73: Line 65:
 * Don't list '''all''' users' worksheets.

 * Authentication - abstract interface:
 * Make an abstract interface to authentication modules. Several possibilities for new authentication modules include:
Line 79: Line 69:
 * Dashboard:
   * Real-time and cumulative statistics, aggregate and per user.
   * Backups: complete or selective.
   * Manage user accounts, passwords, groups, privileges.
   * Send email to all registered users.
   * Install new / updated modules and spkgs.

 * More powerful account management tools.
 * Make it possible to accumulate and analyze statistics about notebook use. For example, analyze geographic traffic patterns ([[http://www.clustrmaps.com/ | ClustrMaps]])
 * Make an easy way for an administrator to backup a notebook or selected notebook accounts.
 * Make an option for an administrator to send an email to all registered users.
 * Make an easy way for an administrator to install new spkgs.
Line 90: Line 75:
 * Custom analytics tags, geolocation ([[http://www.clustrmaps.com/ | ClustrMaps]]).


######################### NOTEBOOK: INTROSPECTION #########################
Line 98: Line 79:
 * [[http://groups.google.com/group/sage-devel/browse_thread/thread/e854336b08d436c6/fb8a62d01475e3eb?#fb8a62d01475e3eb | Completions link for mobiles]].

 * Live introspection cells.

 * Introspection cross-links.

 *
[[http://groups.google.com/group/sage-devel/browse_thread/thread/e9d0fc2c75ec6354/2634152df8f85f59?#2634152df8f85f59 | New documentation browser]].  Open worksheet docstrings in this browser.


############################## NOTEBOOK: "MODES" ##############################
 * Enhance Sage for use on a mobile phone, especially using a touch interface. For example, you can't insert a text cell since you can't shift-click. Also, you can't do tab-completion (the Touch has no Tab key). See [[http://groups.google.com/group/sage-devel/browse_thread/thread/e854336b08d436c6/fb8a62d01475e3eb?#fb8a62d01475e3eb]].

 * Make documentation have collapsible headings or other ways of browsing that aren't so overwhelming. See [[http://groups.google.com/group/sage-devel/browse_thread/thread/e9d0fc2c75ec6354/2634152df8f85f59?#2634152df8f85f59 | New documentation browser]].
 

Line 114: Line 91:
 * Slideshow mode - [[http://trac.sagemath.org/sage_trac/ticket/6342 | #6342]].  * Fix the slideshow in the notebook. See [[http://trac.sagemath.org/sage_trac/ticket/6342 | #6342]].
Line 117: Line 94:
   * Auto updates.
Line 119: Line 95:
   * Widget layout - [[http://trac.sagemath.org/sage_trac/ticket/7379 | #7379]].
   * Examples to include with Sage.
   * [[http://groups.google.com/group/sage-devel/browse_thread/thread/8aa6a3a84365f06d/42c7edf1c23ca169?#42c7edf1c23ca169 | Free-form workspace with pipelines]].
   * More widgets: [[http://trac.sagemath.org/sage_trac/ticket/7427 | circular slider ("angle" wheel)]], [[http://trac.sagemath.org/sage_trac/ticket/5305 | date picker ]], vertical sliders, spreadsheets, interactive plots, etc.
   * [[http://github.com/clemesha/jquery-interact | New architecture]].

 * [[http://groups.google.com/group/sage-devel/msg/e86932eeadd88c6a | LaTeX doc mode]].

 * reST mode, with server-side Sphinxify.

 * Chat - [[http://qwebirc.org/ | qwebirc]], [[http://webchat.freenode.net/ | Web IRC]].
   * Make it possible to lay out widgets in a grid or other format - [[http://trac.sagemath.org/sage_trac/ticket/7379 | #7379]].
   * Make a library of good-quality interact examples in Sage.  They'll see more use, and right now, the code in the examples on the wiki gets out of date pretty quickly.
   * Make a worksheet a free-form workspace, where you can just put computations anywhere and link them anyhow. See the discussion on [[http://groups.google.com/group/sage-devel/browse_thread/thread/8aa6a3a84365f06d/42c7edf1c23ca169?#42c7edf1c23ca169 | Free-form workspace with pipelines]].
   * Make more widgets for interacts. These include
      *
[[http://trac.sagemath.org/sage_trac/ticket/7427 | circular slider ("angle" wheel)]]
      *
[[http://trac.sagemath.org/sage_trac/ticket/5305 | date picker ]]
      * vertical sliders
      * spreadsheet-like tables (there is an input_grid control
, but it is pretty primitive)
   * Look the interact architecture here: [[http://github.com/clemesha/jquery-interact | New architecture]].  Can we use any improvements from it?

 * Make a system for converting worksheets to latex documents. See [[http://groups.google.com/group/sage-devel/msg/e86932eeadd88c6a | LaTeX doc mode]].

 * Have a special text cell mode that understands ReST. The server formats it into html for display.

 * Include a chat in the notebook - [[http://qwebirc.org/ | qwebirc]], [[http://webchat.freenode.net/ | Web IRC]].
Line 132: Line 112:
   * Prettier tracebacks for %modes.
   * Python debugger a la [[https://developer.mozilla.org/En/Pylons | Pylons]] - [[http://trac.sagemath.org/sage_trac/ticket/7509 | #7509]].

 * Draw or annotate with [[http://groups.google.com/group/sage-devel/browse_thread/thread/86429406fb3bba17/dd3163cb2a47fa38?#dd3163cb2a47fa38 | vector graphics]] - [[http://trac.sagemath.org/sage_trac/ticket/6973 | #6973]].

 * Code editor - [[https://bespin.mozilla.com/ | BeSpin]], [[http://marijn.haverbeke.nl/codemirror/ | CodeMirror]] ([[http://trac.sagemath.org/sage_trac/ticket/7501 | #7501]]).

 * Browse worksheet directories like a file system.

 *
[[http://groups.google.com/group/sage-devel/browse_thread/thread/da578e3918f08709/da54258f1783b874?#da54258f1783b874 | Math input GUI plug-ins]].


######################### NOTEBOOK: UNDER THE HOOD #########################
   * Make prettier tracebacks for %modes.
   * Include a python debugger a la [[https://developer.mozilla.org/En/Pylons | Pylons]] - [[http://trac.sagemath.org/sage_trac/ticket/7509 | #7509]].

 * Make a way to draw or annotate with [[http://groups.google.com/group/sage-devel/browse_thread/thread/86429406fb3bba17/dd3163cb2a47fa38?#dd3163cb2a47fa38 | vector graphics]] - [[http://trac.sagemath.org/sage_trac/ticket/6973 | #6973]].

 * Include a code editor - [[https://bespin.mozilla.com/ | BeSpin]], [[http://marijn.haverbeke.nl/codemirror/ | CodeMirror]] ([[http://trac.sagemath.org/sage_trac/ticket/7501 | #7501]]).

 * Make a way to input math in a GUI: [[http://groups.google.com/group/sage-devel/browse_thread/thread/da578e3918f08709/da54258f1783b874?#da54258f1783b874 | Math input GUI plug-ins]].
Line 147: Line 124:
 * Manage Jmol applet count / memory use - [[http://groups.google.com/group/sage-notebook/browse_thread/thread/0fd98c858e7d24c5/2ef2c296f1b13c3b?#2ef2c296f1b13c3b | sage-notebook]].

 * Use Python's [[http://docs.python.org/library/logging.html | logging facility]].

 * Cythonize pexpect.

 * Load-balancing.

 * Offload more work to worksheet processes, e.g., docbrowser generation.
 * Make the notebook manage Jmol applet count / memory use to avoid java out-of-memory errors - [[http://groups.google.com/group/sage-notebook/browse_thread/thread/0fd98c858e7d24c5/2ef2c296f1b13c3b?#2ef2c296f1b13c3b | sage-notebook]].

 * Use Python's [[http://docs.python.org/library/logging.html | logging facility]] to log notebook errors.
Line 159: Line 130:
 * Client-server and server-server interaction:
   * Load JS / CSS components on demand - [[http://ajile.net/ | Ajile]].
   * Server-to-server backups, possibly with authentication.

 * Decouple secure transport from sage. Use OpenSSL(?)
 * Make server-to-server sync or backup functionality
 * Load javascript or css components on demand - [[http://ajile.net/ | Ajile]].
Line 251: Line 219:


== Abbreviated items ==

These items were found on this page in the past. They weren't specific enough to understand, though. If someone knows what the item is talking about, please elaborate and put the item back up above.

 * Notebook
    * Don't list '''all''' users' worksheets.
    * Live introspection cells.
    * Introspection cross-links.
    * Auto updates for interacts.
    * Cythonize pexpect.
    * Load-balancing.
    * Offload more work to worksheet processes, e.g., docbrowser generation.
    * Decouple secure transport from sage. Use OpenSSL(?)


    
    
 * Parallel inter/intra-spkg builds.

Sage Projects

This is a general outline of targeted areas, including specific tasks, for improving the usability of Sage. The sources include the Sage Usability Improvements List, but the scope here is wider. Feel free to make changes. To keep items succinct, please make links to group discussions, etc.

1. General

  • Make a privacy policy for Sagenb.org.

  • Read and make suggestions based on Y. Aner's notebook threat model (PDF).

  • SageForge - establish a semi-automated repository for contributions to Sage. These contributions can include

    • Scripts, worksheets, databases, and packages of [nearly] all sizes.
    • Supplementary documentation, including multimedia.
    • Optional reviews and ratings.
    • Live, ulimited cellular paste-bin.
    • RSS feeds.

2. Build / Test

  • Make a system for analyzing the performance of doctests. Such a system could be used to do performance regression testing across releases, for example.
  • Make an automated system for building Sage on lots of different platforms.
  • Make progress on the windows port.
  • Enhance the Selenium test suite for the notebook, which tests the notebook code. Extend these tests to other browsers.
  • Make a system for building fat binaries (e.g., no SSE3, etc.)

3. Development

  • Auto-reload changed modules - paster serve --reload, CherryPy's AutoReload.

  • More convenient development workflow:

    • Make a code review tool for Sage. One possibility is Rietveld.

    • Make a system for automatically applying and doctesting every ticket marked "needs review", for example. The system can mark the ticket as "needs work" if the patches don't apply or pass doctests. It would be great if there was an easy way for people to donate computer time to this, say, by running a function that starts the process.
  • Run a static code checker on code (maybe even as part of the automated testing mentioned above). See Static Python code analysis or pep8.

4. Documentation

5. Notebook

5.1. Admin

  • Make an abstract interface to authentication modules. Several possibilities for new authentication modules include:
    • LDAP.
    • UNIX accounts.
  • Make it possible to accumulate and analyze statistics about notebook use. For example, analyze geographic traffic patterns (ClustrMaps)

  • Make an easy way for an administrator to backup a notebook or selected notebook accounts.
  • Make an option for an administrator to send an email to all registered users.
  • Make an easy way for an administrator to install new spkgs.
  • Allow email address as username.

5.2. Introspection

5.3. "Modes"

  • %timeit.
  • %cython mode, full and outside sage.

  • Fix the slideshow in the notebook. See #6342.

  • interacts:
    • Live published or remote - #6855.

    • Make it possible to lay out widgets in a grid or other format - #7379.

    • Make a library of good-quality interact examples in Sage. They'll see more use, and right now, the code in the examples on the wiki gets out of date pretty quickly.
    • Make a worksheet a free-form workspace, where you can just put computations anywhere and link them anyhow. See the discussion on Free-form workspace with pipelines.

    • Make more widgets for interacts. These include
    • Look the interact architecture here: New architecture. Can we use any improvements from it?

  • Make a system for converting worksheets to latex documents. See LaTeX doc mode.

  • Have a special text cell mode that understands ReST. The server formats it into html for display.
  • Include a chat in the notebook - qwebirc, Web IRC.

  • Debugging:
    • Make prettier tracebacks for %modes.
    • Include a python debugger a la Pylons - #7509.

  • Make a way to draw or annotate with vector graphics - #6973.

  • Include a code editor - BeSpin, CodeMirror (#7501).

  • Make a way to input math in a GUI: Math input GUI plug-ins.

5.4. Under the hood

  • Make the notebook manage Jmol applet count / memory use to avoid java out-of-memory errors - sage-notebook.

  • Use Python's logging facility to log notebook errors.

  • Alternate worksheet process implementations: remote, fork, named pipes, memory-mapped files.

  • Make server-to-server sync or backup functionality
  • Load javascript or css components on demand - Ajile.

  • Remote access Python API - Google Documents List Data API

    • Manipulate, share, up/download, publish worksheets at a given Sage(Forge) server.
  • Storage:
    • Fix worksheet.autosave().

    • Always retrieve worksheet content from disk on open.
    • Use a revision control tool (e.g., Mercurial) for undo, history, snapshots, etc.
    • File size limit - auto-delete and warn above threshold.
    • Access a user's data directory securely via the new storage API.

    • Handle permissions better for directories, history, output, conf files, etc.
  • Migrate to server / framework: Django, Pylons, Pyjamas, Tornado, etc.:

5.5. User Interaction

  • Help:
    • Reorganize help page:
      • Search for commands.
      • Linking to similar and related commands.
    • Easy set up of shipped jsMath fonts - MathJax.

    • Automatic tips for keyboard shortcuts, editing features, etc. Opt out.
  • Customization:
    • Defaults: typeset, implicit multiplication, 3D viewer, rename "Untitled" worksheets.
    • Function to update worksheet titlebar.
    • Easy backups, selective or complete.
  • Keys
    • New shortcuts, e.g., for restart worksheet.
    • Custom shortcuts, e.g., ctrl-bksp to delete previous word, not join cells - #7618.

  • Cells:
    • Right-click menu.
    • Auto-updating cells, e.g., interacts.
    • Unify server and client-side resize algorithms.
    • Always show links for long output cells, regardless of length or interruption.
    • Select, delete, (un)group, move multiple cells.

  • 2D / 3D plots:
  • Worksheets:
    • Export screen with checkboxes for images, data, etc.
    • Use notebook as IDE for running sage instance - #7501.

    • Drag-and-drop file upload.

    • Don't list "Sage Users" when sharing.
    • Page through worksheet list, not all at once - tablesorter.

    • Toolbar with buttons to interrupt running code, save, attach files, etc.
    • Real-time concurrent editing - #7362.

  • Published worksheets:
    • Delete them.
    • RSS feeds.
    • Live cells, e.g, interacts - #6855.

    • Only to selected users or groups.
  • Notebook:
    • Tags / labels.

    • Manage logins:
      • View recent account activity. Add last login to user.py.

      • Invalidate other sessions' cookies.
    • Full-text search: SQLalchemy, Whoosh (codenode-devel).

  • External:

6. Numerical

  • Port some of the ExpoKit routines to Sage/Cython (or if the author agrees to the license, to scipy).

  • Examine the alglib numerical muliprecision linear algebra library and see if we can use it for RealField and ComplexField matrices.

  • See if we have a use for fastfunlib, which implements multiprecision evaluation of special functions in a much faster way than mpfr, at the possible cost of a very minor difference in accuracy.

  • Review http://trac.sagemath.org/sage_trac/ticket/4446 and get MPC into Sage

  • See if CRQ has interesting bits we could use in Sage to do numerical integration. See also http://www.lirmm.fr/arith18/slides/fousse-GLQuad.pdf

  • Investigate CRLib, which provides a correctly-rounded version of libm using MPFR.

  • Implement flexible printing for RR, including making ring-specific flags for defaults which truncate zeros, truncate "extra" digits, give a C printf string, print in scientific notation, etc. When teaching numerical analysis, for example, it's nice to be able to turn truncation off completely. (I'm doing this)
  • Make a class for calculating with minifloat numbers with user-specified precision //and// user-specified exponent size. Currently RealField lets us specify the precision, but it does not let us specify the exponent size. Being able to specify the exponent size would be very useful in teaching (i.e., we could exactly model single or double precision numbers), and would be a very good exercise in understanding in-depth how arithmetic of floating point numbers works.

7. Abbreviated items

These items were found on this page in the past. They weren't specific enough to understand, though. If someone knows what the item is talking about, please elaborate and put the item back up above.

  • Notebook
    • Don't list all users' worksheets.

    • Live introspection cells.
    • Introspection cross-links.
    • Auto updates for interacts.
    • Cythonize pexpect.
    • Load-balancing.
    • Offload more work to worksheet processes, e.g., docbrowser generation.
    • Decouple secure transport from sage. Use OpenSSL(?)
  • Parallel inter/intra-spkg builds.