Thursday, May 3, 2018

The Second Leg

We knew what problems we faced, and started tackling them one at a time.Our aim was to perfect our project by the end of the semester.

Inclusion of more fonts

We scanned through all the books we had, and started listing all the different fonts used in them. Since we had already converted one font, the process went smoother for the new fonts we discovered. We also used the sorce code from some open-source converters we found online, which helped speed up the process considerably. There were some extremely obscure fonts too, so rare that even their font files weren't available on the internet. Another type of fonts we couldnt't convert were Type I fonts, which were discontinued by Adobe a few years ago. Devlys010 and Walkman Chanakya were two new major fonts that we added to our converter. At the end of this, we were able to convert a lot of the books provided to us. Our mentor also arranged more books from the Rajasthan board, the Chhattisgarh board as well as the CBSE. 

Font Sizing

We moved on to our next problem- the difference in sizes of the fonts. Another issue closely related to this was the difference in the appearance of fonts. These problems were solved in two steps, identifying fonts that closely resembled each other, and then finding an appropriate size conversion for them. Each of these tasks was time consuming, and not something we liked doing, but it had to be done. These conversions were then added to our original script, taking it one step closer to completion.

Headings

Our final task was to tag the text present in the documents according to their position in the hierarchical structure. InDesign supports six levels of headings, h1 through h6, for exporting to various types. These heading tags were important for a visually impaired reader to understand the book structure. We used a tree structure to decide heading levels, with a proper descending structure i.e h2 after h1, h3 after h2, and so on. One assumption we took in this case was that the first heading-type object of the document would be h1. All the remaining text was categorized as paragraph, and the document was ready for exporting.

The Final Deliverable

Our final deliverable that was published online as well as provided to NGOs consisted of two scripts - oe for conversion of fonts with appropriate sizing, and the other for tagging of headings. The only problem we couldnt resolve was the tagging of tables and lists in the document, but these objects were rarely present in the books we converted. The output file generated by exporting the converted InDesign document can be read by any screen reader or document reader which supports Hindi.
The project directory can be found at https://github.com/prakhariitd/COP315-Hindi-fonts-to-Unicode

Our scripts work quite fast, and a 300 page book can be converted in under 2 minutes.
This is how our project works:

Wednesday, May 2, 2018

The Font Conversion

We started working on the problem in December of 2017 under the guidance of Akashdeep sir, our PhD mentor. The first font that we had to convert was Chanakya, which was the original aim of the project.

The deliverable we had to produce was an InDesign Script that ould convert the non-unicode text present in a document. The reason for using InDesign was that our primary goal was to get publishers to use our script, so that they could directly publish the books in Unicode online. InDesign also provides the maximum editing freedom over a document. The procurement of new master files from various school boards was handled by our mentor, while we worked on the conversion.
  

The Dictionary

The first step to convert any font into another is to create a dictionary that maps characters in one font to the corresponding characters in another. We used a software called Font Forge which displays the mapping of a font's characters. Using this, we could map two fonts to each other. But since each font has hundreds of characters, and for non-Unicode fonts, this mapping is unordered, the task of creating a dictionary was extremely tedious and time-consuming. To make things easier, we created a tool in Visual Basic which allowed us to map the characters to their corresponding ones in non-Unicde and create the dictionary easily.

We selected the source non-Unicode font, the target Unicode font, selected a source code for the source font which would correspond to a certain character, and created that character using the unicode Devnagri available to us, therefore creating the dictionary.

The Exceptions
The dictonary alone wasn't suffcient for handling the complete conversion because each font had some exceptional characters that were made by some unique combinations, and coudnt be mapped by the Dictionary tool. these exceptions had to b identified manually by proofreading the converted outputs, and then mapped to their corresponding destinations manually. 

The First Product

At the end of the winters, we had completed a working InDesign script that could convert documents containing Chanakya font to Unicode fonts. However, there were still several problems left - 
  • Most books contained more than just one font, and therefore, we werent able to convert them completely.
  • Since two different fonts rarely have the same character size for the same font size, converting the fonts created an overflow in the pages, which caused some of the text to go beyond the limit of the page, and hence, become invisible. 
  • We also needed proper tagging in the books so that the exported versions could be read by the blind while understanding proper heirarchy in the text.
So, to solve these issues, we decided to expand our project and continue it through the upcoming semester.