Activities/Abacus
Where to get Abacus
About Abacus
Abacus lets the learner explore different representations of numbers using different mechanical counting systems developed by the ancient Romans and Chinese. There are several different variants available for exploration: a suanpan, the traditional Chinese abacus with 2 beads on top and 5 beads below; a soroban, the traditional Japanese abacus with 1 bead on top and 4 beads below; the schety, the traditional Russian abacus, with 10 beads per column, with the exception of one column with just 4 beads used for counting in fourths; and the nepohualtzintzin, a Mayan abacus, 3 beads on top and 4 beads below (base 20). There is also a binary abacus, a hexadecimal abacus, and several abacuses that lets you calculate with common fractions: 1/2, 1/3, 1/4, 1/5, 1/6, 1/8, 1/9, 1/10, and 1/12. As of Version 9, there is a customization toolbar that lets you design your own abacus.
The toolbars
From left to right:
|
From left to right:
|
From left to right:
|
How to use an abacus
Clear the abacus
Before you start an arithmetic operation, you need to "clear" the abacus. The upper beads should be positioned against the top of the frame and the lower beads should be positioned against the bottom of the frame. This is the default position for the abacus when you launch the activity. (Note that some of the abacuses (e.g., the schety) do not have any upper beads. In such cases, all of the beads should start in the down position.)
Reading the abacus
In each column, the bottom beads represent 1s and the top beads represent 5s. (The exception is the column in the schety with only 4 beads. These are 1/4 each.) So for each bead you raise up from the bottom in a column add 1 and for each bead you lower from the top in the same column, add 5.
The columns themselves represent decimal positions from right to left, e.g., 1s, 10s, 100s, 1000s, etc. (There are two exceptions: (1) the nepohualtzintzin uses base 20, e.g., 1s, 20s, 400s, 8000s, etc.; and (2) on the schety, the beads to the right of the column with just four beads are 0.1s, 0.01s, 0.001s, and 0.0001s.)
The current value is always displayed on the frame. Experiment and you will quickly learn to write and read numbers.
Examples: In the gallery below, several simple examples are shown. In the gallery of images above, the number 54321 is shown on each of the different abaci.
Note: The display always assumes a fixed unit column, but you can override this choice.
Addition
To add, simply move in more beads to represent the number you are adding. There are two rules to follow: (1) whenever you have a total of 5 units or more on the bottom of a column, cancel out the 5 by sliding the beads back down and add a five to to the top; and (2) whenever you have a total of 10 units or more in a column, cancel out the 10 and add one unit to the column immediately to the left. (With the nepohualtzintzin, you work with 20 rather than 10.)
Example: 4+3+5+19+24=55
Subtraction
Subtraction is the inverse of addition. Move out beads that correspond to the number you are subtracting. You can "borrow" from the column immediately to the left: subtracting one unit and adding 10 to the current column.
Example: 26–2–4–6–10=4
Multiplication
There are several strategies for doing multiplication on an abacus. In the method used in the example below, the multiplier is stored on the far left of the abacus and the multiplicand is offset to the left by the number of digits in the multiplier. The red indicator is used to help keep track of where we are in the process.
Division
Simple division (by a single-digit number) is the inverse of multiplication. In the example below, the dividend is put on the left (leaving one column vacant for the quotient) and the divisor on the right.
TODO: Add instructions for long division.
Fractions
The fraction abacus lets you add and subtract common fractions: 1/2, 1/3, 1/4, 1/5, 1/6, 1/8, 1/9, 1/10, and 1/12, The fractional value is determined by the number of black beads on a rod, e.g., to work with thirds, use the rod with three beads, to work with fifths, use the rod with five beads.
The rods with white beads are whole numbers in base 10; from left to right 100000, 10000, 1000, 100, 10, and 1.
Modifying Abacus
Abacus is under GPL license. You are free to use it and learn with it. You are also encouraged to modify it to suit your needs or just for a further opportunity to learn.
Most changes can be confined to three modules: AbacusActivity.py
, abacus.py
and abacus_window.py
. The former define the Sugar and GNOME toolbars; the latter defines what code is executed by each type of abacus.
For instance, to add a menu item such as 'Reset' you would do the following in abacus.py
:
- Add these lines to the menu items list:
menu_items = gtk.MenuItem(_("Reset")) menu.append(menu_items) menu_items.connect("activate", self._reset)
- The _reset() method is trivial:
def _reset(self, event, data=None): """ Reset """ self.abacus.mode.reset_abacus()
Similarly, you can add another button to the Sugar toolbar in AbacusActivity.py
:
- Add these lines to the toolbar block:
# Reset the beads on the abacus to the initial cleared position self.reset_button = ToolButton( "reset" ) self.reset_button.set_tooltip(_('Reset')) self.reset_button.props.sensitive = True self.reset_button.connect('clicked', self._reset_button_cb) toolbar_box.toolbar.insert(self.reset_button, -1) self.reset_button.show()
- The _reset_button_cb() method is trivial:
def _reset_button_cb(self, event, data=None): """ Reset the beads on the abacus to the initial cleared position """ self.abacus.mode.reset_abacus()
- You'll have to create an icon for the button (
reset.svg
) and put it into theicon
subdirectory of the bundle.
This will complete the changes in the abacus.py
. The method reset_abacus()
will have to be defined for each abacus in the abacus_window.py
. This can be done by creating that method in the AbacusGeneric
class used by all the varieties of abacus. The method may have to be overridden in some abacus subclasses for customization reasons. For instance, reset_abacus()
was defined in AbacusGeneric
class and then overridden in Schety
.
If the changes involve modifying the graphics, then other methods may need to be modified as well. For instance, in order to introduce a reset button that can be clicked to reset the bead positions to the beginning, the following methods had to be modified – all in abacus_window.py
:
- in the
class Abacus
, method_button_press_cb()
to activate reset button; - in the
class AbacusGeneric
, methodcreate()
to create the graphics for reset button; - methods
hide()
andshow()
to make the button visible.
Discussion
It would be interesting to discuss various lesson plans for using an abacus here. Also, it would be interesting to explore the use of color. What if, for example, the more recent a bead is moved, the more colorful it is? (implemented in v5). This would perhaps make it more clear what the order of operations is on a calculation. Also, what it we extend the idea of the schety to include more fractional components, e.g., 3rd, 5ths, 6ths, etc. and perhaps have a mode where we can automate the consolidation of the fractional parts (implemented in v6).
Might be good to have some of the above information in Help, eg addition, subtraction, multiplication division. Just the text, no graphics?
It was proposed in IRC last night that a fun collaborative mode might be to have a number randomly generated and each sharer work independently to post it on the abacus of their choice first. There could be a tally of beads awarded for each correct answer. Maybe something to add to v10.
I wonder, should the beads on the fraction abacus vary in size? The halves should be five-bead heights each, for example?
As of v10, the beads are labeled.