{# bokeh #} {% for f in bokehres.js_files -%} {%- endfor %} {% for f in bokehres.css_files -%} {%- endfor %}
This is work in progress and contributions are welcome. Head over to GitHub to see where you can help.
Other languages using the Arabic alphabet (regional dialects, Urdu, Persian) are explicitly not supported.
xmodmap ar-lulua.xmodmap
28 letters make up the Arabic alphabet and quite a few extra symbols are required for proper text input, like the hamza in its different shapes أ إ آ ء ئ ؤ, ta marbutah ة, alif maqsurah ى and various diacritics for vowelized texts. Since the performance of a keyboard layout depends on the text entered it is necessary to study its mono-, di- and trigraph frequencies first. The novel corpus built for the following analysis consists of
Source | Words | Characters | |
---|---|---|---|
{{ c.source.name }} | {% set count = c.get ('count') %} {% if count %} {# use new style formatting, for some reason %7,d does not work #}{{ '{:7,d}'.format(count[0])|numspace }} {{ count[1] }} | {% else %}{% endif %} {% set stats = c.get ('stats') %} {% for k in ('words', 'characters') %} {% set i = stats[k]|approx %} | {{ '%5.1f'|format(i[0])|numspace }} {{ i[1] }} | {% endfor %}
Total | {% for k in ('words', 'characters') %} {% set i = corpustotal[k]|approx %} | {{ '%5.1f'|format(i[0])|numspace }} {{ i[1] }} | {% endfor %}
The plot below shows ا ل ي م و ن can be considered the most frequently used letters in the Arabic language. Together they account for more than 55% of all letters in the corpus.
Throughout this evaluation color coding is used to identify fingers:
Asymmetry is defined as the difference between left and right hand usage.
The layout proposed uses four layers and assumes a 102/105 key ISO keyboard common in Europe to accomodate the shift keys necessary. These are in order: Shift on the left and right, caps lock on the left and the rightmost key in the middle row, the key right of the left shift key and the key labeled Alt Gr to the right of the spacebar. Symbols are assigned to the four layers by their function: characters, punctuation, diacritics, other.
The first layer was optimized using an extended reimplementation of carpalx. From several runs with 100.000 iterations each the layout which had good scores and looked reasonable to the human eye was picked. Optimal arrengement of layers two and up are still under investigation.
The most frequent letters have all been assigned to the home row, which makes them easily accessible. ا and ل are typed with different hands, balancing the load on hands almost evenly. The index and middle finger of both hands share the majority of the typing load, but naturally the left middle finger is used more frequently due to its assignment to the letter alif.