Opera Regeolocation in Venice (1660-1760): Difference between revisions

From FDHwiki
Jump to navigation Jump to search
Line 148: Line 148:
Due to lack of time or experience, the methods used in this project presented some flaws. They will now be discussed.
Due to lack of time or experience, the methods used in this project presented some flaws. They will now be discussed.


=== OCR detection ===
=== OCR inaccuracies ===


[[File:Niccolò Jommelli.jpg|200 px|thumb|Niccolò Jommelli, whose name was consistently inaccurately scanned.]]
[[File:Niccolò Jommelli.jpg|200 px|thumb|Niccolò Jommelli, whose name was consistently inaccurately scanned.]]
Line 156: Line 156:
Another problem that might have arisen due to OCR errors regards entry separation. The different opera entries were split thanks to an instance of pattern matching: as all entries end with a line that starts with "Listed as", this was used as the separation rule. However, there might be cases where OCR wrongfully detected different characters in this line; were that the case, the following entry would have been entirely omitted from the extraction. This could also be corrected with a complete examination of the original source, which would detect
Another problem that might have arisen due to OCR errors regards entry separation. The different opera entries were split thanks to an instance of pattern matching: as all entries end with a line that starts with "Listed as", this was used as the separation rule. However, there might be cases where OCR wrongfully detected different characters in this line; were that the case, the following entry would have been entirely omitted from the extraction. This could also be corrected with a complete examination of the original source, which would detect


=== NER issues ===
=== NER limitations===
The NER scan presented two main issues. The first one is due to  
The NER scan presented two main issues. The first one is due to  


Line 164: Line 164:
* Footnote entities often associated with the wrong entry because of entry separation
* Footnote entities often associated with the wrong entry because of entry separation
* Context sentences often aren't delimited correctly
* Context sentences often aren't delimited correctly
=== Interface ===
=== Interface bugs ===
* Bugs with comparison mode
* Bugs with comparison mode
* Search bar filters the operas on the map, not the theater/composer/librettist lists
* Search bar filters the operas on the map, not the theater/composer/librettist lists

Revision as of 16:05, 12 December 2025

This project is defended by Christophe Bitar and Eliott Bell, master students at the EPFL, in the frame of the course DH-405 Foundations of Digital Humanities, given by Prof. Kaplan, Collège des Humanités, EPFL.

Introduction

[Eliott & Christophe]

GitHub repository (data extraction)

GitHub repository (Website)

Website

Motivation

[Christophe]

Mind map

Research questions

Biography via data

State of the art and litterature

CORAGO + books

Project plan

Here is the plan for our project. The core idea is to represent on an interface the information about operas given in Venise between 1660 and 1760, according to the book of Eleanor Selfridge-Field (Standford 2007). We collect data about composers, writters, dates, opera houses.

After the midterm presentation of the project, we divide the work in two. Christophe works on the interface implementation while Eliott works on the last elements of the database.

The planning is made by modules : if we manage to achieve one part, we can continue and enrich the data. This model guarantees to achieve the Minimal Viable Project, consisting in showing the opera through time and space. The NER extraction, possibly more difficult, would arise only if we have time. We ensure also to have sufficient time to debug the interface and analyze the results.

Planning
Week Eliott Bell Christophe Bitar
Week 7 Scan & OCR Litterature finding
Week 8 Pattern matching State of the art
Week 9 Midterm presentation
Week 10 Matching and cleaning data Working on the interface
Week 11 NER of entities Working on the interface
Week 12 Implement full database - Cleaning data
Week 13 Debugging, feedback, analysis
Week 14 Final report

Methodology

From a book to a database

OCR

The first concrete step of the project was to extract as much relevant information from A History of Venetian Opera and Related Genres as possible in order to create an extensive historical dataset. To that effect, after a digitised copy of the book was found, an optical character recognition (OCR) scan was performed on the PDF file to retrieve the text content. This was done using the python-tesseract library.

Once this was done, some superficial data cleanup was performed in order to remove any non-standard characters that wouldn't be handled correctly by the next few functions.

Pattern matching

An illustration of the pattern matching workflow: pattern detection, then regular expresssion writing. This regex in particular extracts the librettist for a given opera entry.

Two different methods were used to extract the desired data. For the basic, systematic information about each opera (i.e. its title, writer(s), librettist(s), venue and sorting date), the decision was taken to use pattern matching, as said data was well-structured and lacked context. The procedure was to identify the pattern used by the author of the book, write the regular expression corresponding to that pattern, then match the entries and patterns to retrieve the desired data in an automated procedure.

To make data extraction more consistent, a few adjustments had to be made to the regexes in order to make them more flexible, as certain entries contained some inconsistencies and additional information. After the adjustments, the few errors that remained were corrected by hand in the final dataset in order to keep regexes reasonably short.

Once the dataset was consistent, it was exported into a JSON file. In addition to the data, a unique ID was added to each opera entry in order to easily cross-reference the database with the following elements.

NER

In addition to the systematic data on each opera, most entries in the book feature a text paragraph disclosing information about the context the opera was released in. To retrieve some of that information, a named entity recognition (NER) scan was done with the Python spaCy library. For each opera production, a list of named entities, including locations and people, was extracted. The decision was then taken to select the 100 most frequently mentioned entities, along with the entries and specific sentences in which they appear. Some entities were discarded from the set for different reasons, such as lack of interesting information (the most frequent entity was “Venice”), being too vague (e.g. surnames that could refer to multiple people), being inaccurate, etc.

The resulting JSON file features the same UID system as the original database to link them in a consistent manner. Alongside the named entities, the spaCy library allows for extraction of the sentence an entity appears in, which is stored as the ent.sent.text object. In order to provide more information on the context in which these entities appear, these sentences were included in the dataset as well.

Enriching the data

Finding coordinates

[Christophe]

Sources, Wikidata, etc.

Interface design

[Christophe]

Slider, filters, maps, modes, credits, etc. Google AI : trial and errors

Results

Technical Assesment

[Eliott]

What did we/the machine manage to do?

Interface Usability

Comparison mode

The Comparison Mode, here displaying works by Antonio Vivaldi and Marc'Antonio Ziani. The histogram at the bottom allows us to quickly see that Ziani precedes Vivaldi.

In order to allow comparative data analysis, a "Comparison Mode" was implemented into the interface. It enables users to apply two search filters in parallel.

Entities research

Alongside the standard method of filtering operas based on theater, composer or librettist, an option to quickly browse through entities mentioned in the entries was implemented. By selecting a certain entity, the map filters operas that mention it and the sidebar shows a list of said operas as well as the sentence the entity appears in, allowing many opportunities for deeper research.

Data exportation

When filtering entries by any criteria, users can export the list of all corresponding operas in a CSV file.

On top of that, an option to easily export and download visual data from the map of Venice was added next to the histogram. This allows users to seamlessly take screenshots of the desired data, or even create GIFs showing its evolution through time and space.

Historical results

[Christophe]

Opera house as an incubator

Composers journeys

Pallarolo

Links between cities

Trends in Music in Venise

Between opera houses

Discussion and limitations

Technical issues and potential improvements

[Eliott]

Due to lack of time or experience, the methods used in this project presented some flaws. They will now be discussed.

OCR inaccuracies

Niccolò Jommelli, whose name was consistently inaccurately scanned.

A frequent issue with the OCR scan occurred due to the language model used: since the pytesseract library uses a very basic English character set for its detection, some characters weren't recognised properly. This is particularly true for the "ò" character, which often became "d" or "e"; thus, for example, the composer Niccolò Jommelli often became Niccold or Niccole. Such errors had to be corrected by hand upon being noticed, though some may remain in the dataset due to lack of a thorough human examination.

Another problem that might have arisen due to OCR errors regards entry separation. The different opera entries were split thanks to an instance of pattern matching: as all entries end with a line that starts with "Listed as", this was used as the separation rule. However, there might be cases where OCR wrongfully detected different characters in this line; were that the case, the following entry would have been entirely omitted from the extraction. This could also be corrected with a complete examination of the original source, which would detect

NER limitations

The NER scan presented two main issues. The first one is due to



  • Footnote entities often associated with the wrong entry because of entry separation
  • Context sentences often aren't delimited correctly

Interface bugs

  • Bugs with comparison mode
  • Search bar filters the operas on the map, not the theater/composer/librettist lists

Data extraction

  • No genre extraction, could provide interesting information about the zeitgeist (see what I did there?)

Historical limitations of the method

[Christophe]

Domino effect, not sufficient to grasp the daily life

What we learnt