Virtual flash cards
Card Game
Anki brings a virtual flash card box to the desktop. Thanks to a useful collection of add-ons, you can adapt Anki to suit your needs, making it one of the most efficient learning tools.
The flash card is still one of the most effective methods for anchoring learning material in long-term memory. But instead of working with a physical index card box and decks of flash cards, today's students use computer programs. Anki [1], considered to be one of the most innovative learning programs for electronic flash cards, goes far beyond everyday needs and even offers a web-based counterpart.
Anki includes several convenient features that you won't get when shuffling through an old-school stack of note cards, such as built-in statistics to chart your progress. The program also lets you rate your success with individual cards, keeping the most difficult at the front of the deck for additional repetitions. The Anki: flashcard system also comes with a large number of add-ons that let you adapt the software to meet a wide range of learning needs. For learning foreign languages, Anki offers the ability to use different character sets, such as Chinese or Russian. Anki uses LaTeX to display formulas, making it ideal for higher mathematics. In addition, Anki can also handle multimedia content; unlike conventional flash cards, Anki can integrate videos, audio files, and images as learning content.
Installation
Anki is available in the repositories of all the common distributions. You can also download a tarball for 64-bit systems from the Anki website, which is recommended if your distribution's repos offer an older Anki version. To set up Anki, unpack the roughly 150MB tarball, which will add about 460MB of data to your hard disk. Then change to the newly created directory and install the package using:
sudo make install
Then start Anki by either selecting the entry in the start menu or entering the anki
command in a terminal window.
If you want to compile Anki manually, the source code is available on the project's GitHub page [2]. You will also find many older versions of the software as TAR.BZ2
archives, which can be useful if the latest version of Anki cannot be installed on older Linux systems due to missing dependencies.
Operation
Upon intial start-up, Anki opens a language-localized window, so you don't have to make any adjustments (Figure 1).
To get started, you need to create a deck of virtual flash cards with the corresponding content on their front and back sides. Click the Create Deck button bottom center. Enter a name for the deck in the window and confirm it.
After clicking on Add below the menubar, you can start entering the contents for each card. The input window consists of two fields for free text input for the front and back of the flash cards; it also allows formatting of the entered data via a small buttonbar above the input fields. You can format the text input, define a background color, link a multimedia file to the index card, or play an audio recording, which is useful for practicing the correct pronunciation of foreign language terms. In addition, the software lets you to enter short fill-in-the blank text. You can also insert chemical or mathematical formulas as needed (Figure 2) using the hamburger menu on the right side of the buttonbar.
The Type selection field lets you specify the form in which the entered terms should be queried. You choose whether Anki queries the cards on both sides or only the front or back side at any given time. Once you have entered the front and back text, click on the Add button to save your card.
After completing the input of a deck of cards, Anki displays the name of the deck with the number of flash cards you entered in the main window. If other decks already exist, only the last one to be activated is shown in the main window. Clicking Decks in the top buttonbar opens the deck display, where all the existing decks are shown, including the decks that need to be reviewed and the new decks to be learned.
Click on a deck to activate it. Next, click Study Now to the right of the deck display to start querying. The program switches to a flash card view where the first term appears. Think about the correct answer and then press the space bar to reveal the answer on the back of the card (Figure 3).
If you want to type in your answer, select Basic (type in the answer) in the Type field in the Add dialog window. When you the type in your answer on a card, Anki will show it with a green background if your answer is correct. Incorrect answers are shown with a red background; Anki then displays the correct answer below.
Structure
Anki lets you manage flash card decks in a hierarchical structure. The top level consists of a main topic, while the lower levels are divided into sub-topics. To do this, you create the individual sub-topics as separate decks and then drag and drop them onto the main deck.
Alternatively, when creating the decks, you can define sub-topics by first specifying the name of the main deck when assigning names followed by two colons (::
) and then the name of the sub-deck. Anki then displays each of the sub-decks indented below the main deck.
You should define your deck structure at the beginning of data input. When creating a hierarchical structure, Anki hides sub-decks entered in the main deck. The sub-decks can only be viewed via Browse in the main window's top buttonbar.
However, after creating a tree structure, new flash cards can still be created in the main deck. To do this, select the desired target deck in the Decks selection field of the Add dialog window. Anki adds the flash card (front and back) when distributing the flash card to multiple sub-decks and then displays the total number of new flash cards in the main deck's overview.
You can also create an extended structure when entering the learning content in the individual decks. Especially for complex topics, it is advisable to use keywords or tags. The Tags field lets you enter several keywords separated by a space. These keywords can also be targeted selection criteria later on when learning the content on the individual cards.
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Wine 10 Includes Plenty to Excite Users
With its latest release, Wine has the usual crop of bug fixes and improvements, along with some exciting new features.
-
Linux Kernel 6.13 Offers Improvements for AMD/Apple Users
The latest Linux kernel is now available, and it includes plenty of improvements, especially for those who use AMD or Apple-based systems.
-
Gnome 48 Debuts New Audio Player
To date, the audio player found within the Gnome desktop has been meh at best, but with the upcoming release that all changes.
-
Plasma 6.3 Ready for Public Beta Testing
Plasma 6.3 will ship with KDE Gear 24.12.1 and KDE Frameworks 6.10, along with some new and exciting features.
-
Budgie 10.10 Scheduled for Q1 2025 with a Surprising Desktop Update
If Budgie is your desktop environment of choice, 2025 is going to be a great year for you.
-
Firefox 134 Offers Improvements for Linux Version
Fans of Linux and Firefox rejoice, as there's a new version available that includes some handy updates.
-
Serpent OS Arrives with a New Alpha Release
After months of silence, Ikey Doherty has released a new alpha for his Serpent OS.
-
HashiCorp Cofounder Unveils Ghostty, a Linux Terminal App
Ghostty is a new Linux terminal app that's fast, feature-rich, and offers a platform-native GUI while remaining cross-platform.
-
Fedora Asahi Remix 41 Available for Apple Silicon
If you have an Apple Silicon Mac and you're hoping to install Fedora, you're in luck because the latest release supports the M1 and M2 chips.
-
Systemd Fixes Bug While Facing New Challenger in GNU Shepherd
The systemd developers have fixed a really nasty bug amid the release of the new GNU Shepherd init system.