Software ideas

From OLPC
Jump to navigation Jump to search
  english | 日本語 HowTo [ID# 96741]  +/-  
Projects and proposals    +/-
Content ideas Content projects
Hardware ideas Hardware projects
Software ideas Software projects

See also Category:Software ideas

This page is a brainstorming space for ideas which may eventually become Software projects. Keep in mind that the projects here are merely proposals or ideas. If you would like to add a new project idea, try to be reasonably thorough in your description.

When brainstorming, try to let your mind run free. When reading and looking for a project to start, keep in mind that we are looking for projects that encourage Playful Learning instead of Edutainment.

This section discusses whole application-classes that might be useful to have available on the OLPC laptops. That is, these are "requirements"-focussed ideas for what type of thing we want to provide. For many of the application classes there are existing PyGTK-based applications available that could be ported to Sugar (Sugarised).

Also, think about frameworks rather than just individual applications. Don't build MySpace. Instead, build a toolkit that could be used to build MySpace-like applications.

If you want to work on one of these ideas, add a section to the Software projects page describing your project (or just add your name below with contact information so that other interested people can contact you to organise into a project, or create a link to a Wiki page with more description about what you figure needs to be done):

Mathematics

  • Simple Calculations
  • Data Analysis and Visualization (as opposed to statistics)
  • Fractran interpretor in C from ADA graph language
  • Basic Calculators (e.g. GCalculator)
  • Spreadsheet software ( see request:Ban_Samkha )
    • Financial tools
    • Budgeting
    • Loan calculators
    • Accounting software
  • Higher mathematics
  • Financial Literacy
    • Cash vs. Credit
    • Banking
    • Interest and Borrowing
    • Basic Accounting
    • International Monies
  • Applied Mathematics
    • Digital Signal Processing (filters, echo, etc. in Electronic Music, voice-changer game, etc.)
    • Motion simulation (rocketry, planetary-motion)
    • Estimation through sampling (e.g. the total height of all the children, based on a sample)

Language

Science

  • Starfield explorers (e.g. nightsky)
  • Chemical simulators
  • Physics simulators (Newtonian)
  • Biological simulators (population simulators)
  • Genealogy software (e.g. Gramps)
  • Dynamic system simulators (e.g. ecological simulators, economic simulators)
  • Geography (mapping) software, coordinates, maps, data-overlays, GIS operations
  • Data collection tools
  • Unit conversion tools (e.g. GConvert)
  • Time-lapse photography tool
  • Photogrammetric Astronavigation (i.e. analyzing pictures of the night sky to determine the child's location)

Physical Education and Training

Art and Expression

moovl An on-line program using Java that combines art with physics.

  • Raster graphic creation (painting, sketching)
  • Collage operations (eToys?)
  • Programmatic creation (Logo or the like)
  • Video creation
    • Animation
    • Stop-motion
  • Art History Studies
  • Performance broadcast (school plays and the like)
  • Panoramic photography (i.e. basic multi-photo stitching, to produce wide-angle/360-degree images - depending on the hardware specs, may also be used to produce higher pixel-count images than with the onboard camera itself)

Music

  • Voice/Ear training (e.g. Solfege)
  • Score display and creation (TamTam?)
  • Instrument tuning (e.g. guitar)
  • Viral OLPC Startup Sounds - edit short jingles and share them them with network neighbours. They could also "mutate" with each copy
  • minimalist keyboard -> audio keyboard program like tinypiano
  • track based editor like audacity
  • simple vst-based sound processor like VST Processor, or, possibly more in the spirit of olpc, a more mathematical/visual sound processing environment like Max/MSP.

Communications

  • VoIP phone
  • Conferencing system, virtual classroom, shared presentations
  • Email client (gmail-for-children?)
  • Voice-mail (voice email and standard voicemail)
  • Web-page editor (wikidpad?)
  • Televised video (streaming video viewer)
  • Blog Tool

For more school-to-school and internet-school communication, see the Internet and Radio and broadcast pages for a whole list of internet and non-internet communication methods, some of which would make good software-projects. This includes things like Sneakernet (moving files between schools and to an internet-computer on CD/DVD/Flash Drive, aided by routing software), one-way file broadcasting, etc.

Educational

  • Role-playing systems
  • Mind-mapping systems (outliners, free-form note-taking tools, e.g. Labyrinth, Gjots, )
    • Integrate these into the bulletin board layer?
  • A learning management system and collaborative work environment, for school servers. Moodle or similar.
  • A groupware for project development and management, for school servers. Egrouware or similar
  • A repository system for multimedia content in school servers
  • A wiki engine for school servers
  • Drill and test software (Yes, even on a constructivist machine - follow the link for discussion)
  • Software for supporting teachers' use of rubrics
  • Software to enable simple anonymous group voting for a multiple choice questions. The class answers are then collated and displayed as a 4 element bar graph. Using the wireless mesh to enable the whole class to vote on a simple A,B,C,D multi choice question removes the social pressure to always provide the correct answer in frount of the group. In addition to quiz sessions it would also teach democratic behavoir and encourage voting amoung the young. ( think who wants to be a millionare ask the audience ! )

Games (see also Games)

  • Game framework: Multi-player, multi-team game architecture, so kids can make up their own games.
  • Game console emulators (needs content)
  • Strategy Games
    • Turn-based
      • Go, Reversi
      • Chess (e.g. PyChess)
      • Checkers/Chinese Checkers
      • Oware
      • Pictionary
    • Real-time Strategy
    • Simulation Games
      • SimCities micropolis
      • Pioneer / Oregon Trail
      • SimBusiness - (Lemonade Tycoon, Theme Park Tycoon, etc.)
      • Open Transport Tycoon Deluxe openTTD
      • CodeInvader CodeInvader
  • eToys Games
  • Puzzle Games
    • Crosswords
    • Jigsaw Puzzles
    • Word Searches
    • Word Jumbles
    • Hangman
    • Mazes
    • Sodoku (e.g. Python Sodoku)
    • Rube Goldberg-like puzzles (e.g., The Incredible Machine)
  • Card Games
  • Tournament framework: Allow kids to easily set up and manage a tournament
  • Text-driven Adventure Games for 2nd language learning - Multi-user with pictures or 3D rooms.
  • Massively Multiplayer Online Games for 2nd language learning - involving native speakers via the internet.

Play (like games, without winners and losers)

  • Peek-a-boom
  • ESP
  • There is a literature of this kind of social team-building play. For instance, adapt ideas from No Contest by Alfie Kohn.

Technology

  • Microcontroller programmers/compilers (e.g. for irrigation systems, art installations and general automation)
  • CAD/CAM applications (e.g. PythonCAD)
  • BuddyBrowser - a safe, fun hybrid web browser/search engine/protal made especially for kids 4-10 allowing kids to surf all of their favorite kid-appropriate sites, without accidentally running in to inapporporiate material. Download at www.buddybrowser.com
  • Source-code editor with transparent native-language display.
  • Sharable interactive disassembler for Linux ELF x86, FLASH ActionScript bytecode, wireless firmware, Python *.pyc files, 8051 firmware, and other things found on the laptop. It can be the ultimate fall-back "show source" operation. Interactive disassembly is particularly well-suited to being a shared activity; as each person defines things (code or data, function name, data structures, etc.) the shared understanding becomes clearer.
  • Distributed WEP key cracking over the mesh, allowing a group of XO users to share the work of obtaining an internet connection.
  • Map making software, allowing kids to make decent maps from poor-quality measurements. For example, measuring some distances or angles around a garden or playground should allow the creation of a map. (angles alone gives you no scale of course) The software could treat the distances as springs, then try to find the least-stress deformation that allows all the numbers to work out.

PIM

  • Clock
  • Contacts
  • Scheduling
  • To-do lists
  • Personal Wiki (eg TiddlyWiki)
  • juwo (please see http://juwo.com. I shall need help porting it to Linux)

Teaching Software

eXe - an XHTML-Editor for creating E-Learnings. (You do not need any programming knowledge, an pretty easy tool: http://exelearning.org/)

Scratch - I think the OLPC team should consider the idea of including a version of Scratch in the OLPC machines. Created by the MIT, it's free, and it's an excellent and graphical way to create animations and games, to learn logic and how to program machines (specially for kids !), with no need of complicated instruction code : you make all by mouse clicks, and with a pretty interface. Try it, and you'll like it !

Indeed. The Scratch folks are porting it to OLPC. I've just now created a stub Scratch page. Good thought. :) MitchellNCharity 17:02, 4 August 2007 (EDT)

I draw your attention to vpython.org, where VPython = Python + numpy + Visual + OpenGL.

The Visual module lets even novice programmers create mouse-navigable 3D animations, by making 3D graphics a side effect of Python calculations. This can be a highly enabling environment for kids. At an upper level, currently several thousand college students are writing VPython programs every semester in an introductory physics course at various institutions that include NCSU, Purdue, and Georgia Tech (see physics course).

This is free open-source multiplatform software and runs on Linux, Windows, and Mac.

There currently is a production version based on gtk1 and numeric and a beta version based on gtk2 and numpy. Most of the user base is on Windows and Mac, so the beta version hasn't gotten a lot of testing on Linux but seems to work fine (the Windows version is buggy, which is why the beta version hasn't been promoted to being the production version). The beta version adds the capabilities of transparency, surface textures, and sophisticated lighting (spotlights, specular highlights).

Here is a complete runnable VPython program that displays a yellow brick beside a red sphere (pos is 3D position):

from visual import *

box(pos=(2,0,0), size=(2,6,1), color=color.yellow)

sphere(pos=(-2,0,0), radius=1.5, color=color.red)

Holding down the right mouse button, you can rotate the "camera" around the scene. Holding down both buttons you can zoom in and out.

The beta version being based on gtk2 and Pango does provide some internationalization, but the Python program statements currently have to be written in English. For example, the object names "box" and "sphere" and their attributes are all English words. Obviously one could recompile the C++ code to change these names.

I'm the gatekeeper for this open-source project and have contributed to its development. Bruce Sherwood 12:15, 30 September 2007 (EDT)

Classroom tools

The idea of activity sharing supports several important forms of classroom interaction, and can be stretched to accommodate many more. However the focus on constructionism means there's a lack of support for teacher-centric interactions, even ones which are useful in constructionist learning.

Raising hands

The fundamental model that's missing is the idea of questions or assignments, posed by the teacher and answered separately by each student or team of students. It is possible to accomplish this 'manually', but the technical shuffling makes it impractical to do so in a real-time, classroom situation, especially if it is desirable to keep data for later.

For instance, I as a teacher want to be able to pose a question and have each student individually type a response. I could see, and record for later, who responded what and who didn't respond. After giving a brief interval, I could 'call on' a student either by my choice or randomly, and continue the discussion based on their answer. There are several obvious variations on this pattern - for instance, instead of typing a complete answer they could just indicate whether they have an answer, ie, 'raise their hands'; teams could present shared answers; etc. The software would help the teacher to keep track of each student's participation and to 'call on' students in a systematic manner.

This type of interaction is so fundamental that it would be great to have it available independent of the currently shared activity. The obvious place to put it, therefore, would be in the bulletin board. This means the bulletin board would have to have some support for active logic. There are 3 ways to do this that I can see: somehow using AJAX for the bulletin board (advantages: highly flexible, tools exist; disadvantages: memory and processor hog, needs some server technology on the teacher's side); hard-coding this one case into the bulletin board (advantage: can be optimized better; disadvantage: inflexible); or somehow making a plugin system for the bulletin board (advantage: flexible; disadvantage: security issues, the world doesn't need yet another plugin architecture)

Homunq 08:12, 14 January 2008 (EST)

Classroom management

Motivation and interest are the best ways to achieve engagement, but social pressure and good examples are also a part of the picture, and these are impossible without transparency. If there is no easy way for teachers (or, for that matter, other students) to tell the difference between a student who is working on the laptop, and one who is playing DOOM, bad things happen.

Intel/Microsoft's "Classmate" competitor is rumored to have tools for the teacher to freeze or take over the student's laptop, "to guide them through the interface". Regardless of whether this is a desirable relationship, it would be hard to accomplish within the security model and memory constraints of the XO.

However, it would be good to have tools for all members of a shared activity to see the current state and recent history of all other current members. This protects privacy (after all, you can just quit the shared activity for privacy) while creating transparency. For it to be useful, it has to be simple and fast. Useful things to see are which activities have been used, and whether out-of-band communication has happened, over the last minute.

Homunq 08:12, 14 January 2008 (EST)

System Software

Cultural

  • Recipe-managing (allowing kids and parents to create and share recipes with friends and world. eg Gourmet Recipe Manager)
  • Cultural Song Lyrics - search, share, contribute
  • Cultural/Historical Stories - search, share, contribute

Social and collaborative

  • Multi-person simulations of markets, agriculture, government.
  • Yahoo Answers
  • IM, chat, Skype
  • Multi-person simulations of physics, biology, population,
  • Wiki-like group drawing tools
  • Wiki-like group music tools.
  • Social Networking to connect young people worldwide

Porting Existing Software

This section explores existing applications that could be ported to the laptop in order to provide the functionality for the children. The List of PyGTK Applications is a good place to start. If you are porting an application, you'll want to contact the author and add an entry to the Software projects page describing the porting effort (and providing contact information for it).


Not knowing much about python, I wonder about the feasibility of emulation on the OLPC, specifically for Apple II software. It seems there is a project - ApplePy - in the works. There are a large number of great educational apple II titles, many of which have no more recent ports or versions. Though the graphics are limited, making these availible in the short term might be a good start. As a long term project, it would be great to port/reversion/internationalize some classics like Odell Lake, Number Munchers, and Robot Odyssey. Dialectric 19:22, 26 November 2007 (EST)


Emulating or porting Sugar into a website that could become a web portal for users of any platform with any machine. It could become a social networking site demonstrating the Sugar user interface and sharing the Sugar perspective of human and machine interaction.

Mathematics

  • Calc for more basic tasks, BC for more difficult ones, and SC or a GUI based spreadsheet, perhaps.
  • LaTeX, this is free and powerful typesetting system creating beautiful documents
  • Mathematica for children, for modeling and calculating

Updates

  • An update/software manager to handle updates and new software that come out after the laptop is given to the child

Software for scheduling activities

Teachers sometimes find it hard to supervise mixed-ability groups, since each child learns at a different rate. There is a commercial program called Supermemo (an abbreviation of Super-Memorization), which demonstrates a Spaced repetition technique that might be used to schedule the learning-activities for each child. An open-source program similar to this might be found/written. It could be used, for example, to remind children to review and update mind-maps to stop knowledge fading from memory, which was acquired originally through constructionist activities.

(Further discussion of this concept, and why it does not necessarily clash with constructivism, moved to Drill and test software)

Mindstorms robot simulations

Seymour Papert, the father of constructionism and a leading-light of OLPC, wrote the book 'Mindstorms: Children, Computers, and Powerful Ideas'. The 'Mindstorms' name was licensed to Lego for their range of Lego Mindstorms NXT robots, programming software, motors, controllers, etc.

It would be good to see whether the OLPC could have some software simulation of Mindstorm-type activites (building and programming robots and sensors, production-lines, light/sound-detectors, etc). Since it might infringe some Lego intellectual property rights, the OLPC project could negotiate with them to see if any part of the Mindstorms ideas can be used for free, perhaps in exchange for some more advice on advances in constructionist education and activities. It shouldn't undermine their sales much, since children in Europe and North America prefer the physical toys to on-screen simulations.


Keyboarding/Typing Tutor

  • Anything lightweight enough to reside on local XO laptop as a tutorial program or game

External links

Audio/Video edition of NGO-in-a-Box A set of Free Open-Source Video and Audio editing software-tools, documentation and tutorials for Non-Governmental Organizations and other groups for social change. They are available on CD or by download. Keyboarding Possibilities Could Tux Typing be a good addition? http://tuxtype.sourceforge.net/ It is developed and released under the General Public License (GPL). It is part of the Tux4Kids project (Tux Paint and Tux Math), which is a Schoolforge member. I just don't know if it can run on Linux. Those of you who understand the prgram spec's might want to email: tuxmath-devel@lists.sourceforge.net .

System Software Enhancements

These are lower-level projects that would enhance the entire system's performance or usability.

  • compiler optimization: if you are a compiler wizard, we understand that the Geode lacks a specific back end code scheduler, which limits performance, particularly FP performance. We'd love to see work go on in this area which would help everyone.
  • tickless operation: there are patches out of tree about to be integrated into Linux that allows Linux to function without periodic ticks; we've been experimenting, and while our tick rate is probably the lowest yet observed on a Linux system, it can and should go further. Nothing in the system should poll!
  • power management desktop interaction: applications need to be better aware of their power usage and requirements, and communicate this better to the system.
  • The OOM (out of memory) killer is naive, to say the least.
  • Sugar optimization: While the Sugar environment will get substantially faster as soon as we deploy a rebuilt Python 2.5, further work, particularly on Python startup, is in order.
  • Sugarizing applications: There are many applications that with minimal work can be made to work well in the Sugar environment for young children. We encourage you to pick one and help out.
  • Remote display: we have begun work on a low-cost projector. Making it easy to run remote applications is well worthwhile. There are a number of ways (and difficulties) of doing this, so there are immediate techniques available, along with much more sophisticated ways of advancing the "state of the X Window System art", depending on your inclinations and abilities.
  • Educational applications of all sorts.
  • Server-based tools for schools and support of the laptops.
  • memory usage: many applications and toolkits waste and/or leak memory. Fixing these will help everyone and most easily done on conventional systems.
  • performance optimization: fixing memory usage will usually result in faster code.
  • toolkit adaptation: the display's effective resolution will change from grayscale to color mode and back. Toolkits and applications need to be able to adapt, and themes that work well in both modes verified.
  • UI: most of the user interface work can be done today on conventional Linux desktops. But our system will also have an e-book mode, with dual 4-direction keys and enter. Key applications will need updating to work well in this environment (e.g. evince, web browser). Testing application's behavior under grayscale conditions and making whatever changes are needed would be helpful.
  • Applications: goes without saying. The "Sugar" environment under development can be run on conventional desktops, and many applications should be simplified and optimized for our systems. Our primary audience are younger children, rather than the middle and high school students that have been the primary child users of computers.
  • IPv6 support, and service discovery, which are very important to us.
  • Security: Bitfrost is a way to protect against Day 0 attacks; as a large ecosystem of similar machines, it is something worth seriously worrying about.

See also: