Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Readability metrics #712

Open
Tracked by #1269
jyhelle opened this issue Mar 17, 2021 · 12 comments
Open
Tracked by #1269

Readability metrics #712

jyhelle opened this issue Mar 17, 2021 · 12 comments
Assignees
Labels
build tool Component: Exports or the build tool enhancement Request: New feature or improvement

Comments

@jyhelle
Copy link
Contributor

jyhelle commented Mar 17, 2021

I know the subject is a matter of discussion, and many people (including myself) give little importance to the Flesh, Gunning, SMOG or similar methods of readability assessment.
However, there are publishers, especially in the children and teens literature, who are very attached to this kind of tool and expect to get the figures with the manuscript. (I have seen a target readability index specified in several translation contracts)
The computation can be done manually, counting sentences and words and syllables, but it is very tedious while the computer could do it in seconds, so that might be a good point to envision including something into a future version of nW.

@jyhelle jyhelle added the enhancement Request: New feature or improvement label Mar 17, 2021
@vkbo
Copy link
Owner

vkbo commented Mar 17, 2021

I already have code for this that I wrote a couple of years ago. It is for English only, as counting syllables is not a trivial matter and has to be tailored for each language. I arrived at an algorithm that counts syllables fairly accurately without having to look up each word, which is the only really accurate method. My code calculates the Flesch–Kincaid Readability Score.

The code was once in one of the utility files of nW, but I took it out since it wasn't used. I've considered putting it back in again as well. Thanks for the reminder!

@vkbo vkbo self-assigned this Mar 17, 2021
@jyhelle
Copy link
Contributor Author

jyhelle commented Mar 17, 2021

My level of confidence in that sort of "metrics" is such that I would say as long as it count syllables in English it would probably be OK for French as well. These are statistical-empirical tools, and measuring different parts of an homogeneous text gives (similar but) different results, so a good approximation might be sufficient

Any promoter or advocate to speak up ?

@vkbo
Copy link
Owner

vkbo commented Mar 17, 2021

The English function I wrote does not work for Norwegian for instance. I tested it when I wrote it just to see.

A decent first approach is to count diphthongs and single vowels. The challenge in English is that the letter y is a consonant or vowel depending on context. There are also silent vowels in endings that need to be accounted for.

The second issue is of course that the grading metric is designed for English specifically, and unless you want to just extract the fairly esoteric score, you need a grading scale for other languages too. They can of course easily be added if they exist.

I'm wondering how much work it would be to make a simple machine learning training set for this problem and then train it on a full dictionary using supervised learning.

@johnblommers
Copy link

Every time I run a readability tool over my writing, for example Hemingway I'm reminded that:

  1. Hemingway has no Linux version
  2. I dislike uploading my work to untrusted servers
  3. My writing is too wordy

So a readability score displayed next to the word counter would be a welcome addition to novelWriter.

It would by nice if novelWriter had a switch that would color sentences that are hard to read, suffer from passive voice, which is what the Hemingway app does. I'm afraid that might be a huge distraction from novelWriter's main reason for existing.

@vkbo
Copy link
Owner

vkbo commented Mar 18, 2021

Those are pretty advanced language analysis features, and probably also too heavy to run with Python. I am not a fan of tools like Hemingway anyway. While they help with grammar, which is useful, they also have a feel of over-teching writing to the point of generating uniformity and conformity. That's not a good thing in my book.

The readability score is a more neutral metric because it gives you a number without any judgement on whether it is good or bad. The readability score only needs to match the target audience's reading level.

My main concern about adding it is that it adds a tool that is language-specific. I want nW to be less English-oriented. English is not my own first language either. If we can collaborate to make it a bit more language-independent, then I'm all for adding a field next to the word counter that lists the values and the total.

The Flesch–Kincaid score is based on average syllables per word and words per sentence, so keeping track of those two values throughout the project isn't too hard. I can add this to the indexer. Syllables is still the trickier one to generalise.

@vkbo
Copy link
Owner

vkbo commented Mar 18, 2021

Just for reference, this is how to programmatically count syllables in English:

  • Count the number of vowels (A, E, I, O, U) in the word.
    • Add 1 every time the letter 'y' makes the sound of a vowel (A, E, I, O, U).
    • Subtract 1 for each silent vowel (like the silent 'e' at the end of a word).
  • Subtract 1 for each diphthong or triphthong in the word.
    • Diphthong: when 2 vowels make only 1 sound (au, oy, oo)
    • Triphthong: when 3 vowels make only 1 sound (iou)
  • Does the word end with "le" or "les?" Add 1 only if the letter before the "le" is a consonant.
  • The number you get is the number of syllables in your word.

It is accurate enough that the mistakes it makes don't affect the final score. One issue is to determine exactly when 'y' makes a vowel sound.

We'd need a similar set of rules for each supported language, and I have no idea how well any of this would work for a non-European language.

@jyhelle
Copy link
Contributor Author

jyhelle commented Mar 18, 2021

there was a tool some years ago that used the OpenOffice hyphenation dictionaries to overcome the multi-lingual problem...

Edit: it still exists and even evolved, now using LibreOffice dicts... have a look at PyHyphen on Pypi
It is primarily an hyphenation tool that I used to format verses in poetry booklets, but it can return syllables

@vkbo
Copy link
Owner

vkbo commented Mar 18, 2021

Yeah, this is what I was referring to when I mentioned that the only accurate method is to look up words (although hyphenation dictionaries don't always produce the correct syllable count). I researched this back when I wrote that code. I'm reluctant to depend on such external tools hosted on PyPi as such packages aren't always very dependable. I've had enough problems with pyenchant that I use for spell checking.

Perhaps the hyphenation package can be used to train a machine learning implementation though. It's an interesting topic in general.

Edit: Another alternative is to write a small module to parse the LibreOffice hyphenation dictionaries directly, like Pyphen does.

@jyhelle
Copy link
Contributor Author

jyhelle commented Mar 18, 2021

Yes, I just wanted to show it as a mean to bridge that multiple languages issue, and my idea was along the lines of the last alternative you added.
We don't need an hyphenation package, and the syllables command of PyHyphen gives the individual syllables where we only need their number. So the idea was to look over the code of PyHyphen, or maybe other similar tools, and understand how we could get what we need from those dictionaries. But I have strictly no idea about the programming complexity it entails.

@vkbo
Copy link
Owner

vkbo commented Mar 18, 2021

A benefit of that approach is that the hyphenation dictionaries are available for download, so nW could automatically download the ones the user wants.

Looking at the Pyphen package, the parsing isn't that complicated. Since Pyphen is written in pure Python, it's also a good option to just include it in a lib folder in nW instead of depending on an external package.

@vkbo
Copy link
Owner

vkbo commented Mar 24, 2021

As for the suggestion by @johnblommers on integration with grammar tools like Hemingway, there's a feature issue #515 on this where the discussion is to integrate with LanguageTool, which is open source. Since you can run a local language server for free, or optionally connect to a hosted one, this may be a good fit for novelWriter. Especially since it supports multiple languages.

As for the metrics part, I will have a look at adding the syllable algorithm for English to the indexer. Perhaps if I add a proper class for syllables calculations we could try out multiple approaches. However, the very idea of counting syllables to determine complexity doesn't translate well outside of European languages, and not necessarily to Germanic languages either where multiple words are often joined into long words where one in English would keep the spaces or insert hyphens. These words aren't necessarily more complex or hard to read just because they contain many syllables. This practice is very common in Norwegian and of course infamous in German.

@vkbo
Copy link
Owner

vkbo commented Feb 8, 2022

I'm planning to redesign the Build Tool for the next release cycle. I've been thinking of adding an extra feature to the build tool for analysing the structure of the manuscript. Checking the complexity of the text could be one option. It requires a fair bit of processing, so it isn't well suited for the text editor.

If I add it, I'd like to give a breakdown so that the user has some idea of the various stats that go into these various metrics. It would probably make it more useful than just stating a score based on English alone.

It would also allow the user to select a way to estimate syllables. My own algorithm for English provides a good estimate, but it really is tuned to English. Letting the user select the algorithm is probably a good solution. Adding a module of such algorithms would also make it possible for other users to contribute some for other languages. It would be a nice area to accept contributions actually.

@vkbo vkbo added the build tool Component: Exports or the build tool label Feb 8, 2022
@vkbo vkbo added this to the Release 1.7 Beta 1 milestone Feb 8, 2022
@vkbo vkbo mentioned this issue Nov 29, 2022
28 tasks
@vkbo vkbo modified the milestones: Release 2.1 Beta 1, Build Tool Rewrite Apr 24, 2023
@vkbo vkbo modified the milestones: Build Tool Rewrite, Future Release Jan 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
build tool Component: Exports or the build tool enhancement Request: New feature or improvement
Projects
None yet
Development

No branches or pull requests

3 participants