The contribution of “Open-Source Archaeology” for exchanging data and ideas between researchers and archaeologists.

Within the domain of archaeological research, and particularly in informatics archaeology, the relevant costs associated with software licences might present a concrete obstacle, particularly in situations where research funds are scarce. Furthermore, beyond their proprietary nature, numerous prevalent software applications in archaeology lack explicit design and development for archaeological purposes, thereby falling short of meeting the specific requirements of the discipline. Additionally, certain archaeology-specific software programs are no longer receiving support. As Benjamin Ducke noted:

One possible solution to this problem lies in embedding software development and research within larger, open-source projects that are not confined to the scope and lifetime of a single research project. This provides a two-fold advantage. On the one hand, paying programmers to implement functionality in open-source software delivers a solid return on investment. On the other hand, it offers countless opportunities for the sharing of investments and resources, reducing the burden on the individual stakeholders. (Ducke 2012, 574)

Open-source software is distributed as readable program source code written in a (usually high-level) programming language (Wilson and Edwards 2015, 1). The availability of source code allows the end user not only to run the software but also to manipulate, change, redevelop and understand how it works.

We use different software tools for our academic research which are often not interoperable with each other. Nowadays, an important objective is finding a meeting point to allow groups and people with different backgrounds to quickly consult the archaeological data, thus increasing the exchange of resources and ideas. Our brief contribution provides an attempt to integrate some of these tools, pyArchinit and BraDypUS to allow for accessible software communication.

The software used

Initiated in 2005, the project “pyArchInit - python for archaeology” was designed to facilitate the management of data derived from archaeological contexts within the well-known and widely used QGIS platform (Cocca and Mandolesi 2013). The overarching goal of the developers was to establish a novel application for archaeologists, seamlessly adaptable to both field and laboratory settings. The envisioned application aimed for user-friendliness and seamless integration with management systems utilised by public administrations. Luca Mandolesi spearheaded the development of Pyarchinit, and Enzo Cocca further implemented it (Mandolesi and Cocca in 2022). The development is based on the commitment to maximum system portability, ensuring ease and immediacy of use, leveraging open-source software for development, creating modules for comprehensive archaeological data management, integrating existing and robust data management systems, and maintaining flexibility for the accommodation of alphanumeric, cartographic, and multimedia data.

BraDypUS stands as an application dedicated to the creation and management of archaeological databases online (Bogdani 2021). Originating from Julian Bogdani’s initiatives in 2008 to develop bespoke web-based software solutions for the management of archaeological data, has since expanded its scope, managing, and providing services for significant Italian and international cultural heritage projects. Within the realm of digital humanities, BraDypUS emerges as a valuable tool, particularly in the field of archaeology. The software expedites the processes, methods, surveys, and documentation involved in excavations, often constrained by site-specific requirements. The WebGIS solutions integrated into BraDypUS offer practical assistance in inventorying, understanding, and networking cultural heritage within a given area (Bogdani 2019).

(P.R.)

From BraDypUS to PyArchInit and vice versa

Both pyArchInit (https://github.com/pyarchinit/pyarchinit) and BraDypUS (https://github.com/lab-archeologia-digitale/BraDypUS) are specifically tailored for archaeological applications. PyArchInit is predominantly developed in Python and relies on a predetermined database schema primarily designed for spatial data management. BraDypUS employs various web languages such as PHP, Javascript, and CSS, and boasts extensive versatility, offering complete customization for relational databases. The installation of BraDypUS is typically conducted on a web server and is accessible from any device running a modern web browser, while pyArchInit runs on a local machine and requires QGIS. In addressing the challenge of different structures, a resolution was achieved by establishing a connection between the two systems through the utilisation of a Spatial Relational Database Management System (RDBMS). Both applications are capable of interfacing with PostgreSQL and PostGIS, providing a collaborative solution for multiple individuals to concurrently engage in a shared project. Given the rigid database schema inherent in PyArchInit, the process necessitated constructing the database using PyArchInit’s dedicated tools.

PyArchInit requires many tables to be created, each specifically designed to adhere to the stringent standards set by the Central Italian Institute for Cataloguing and Documentation (ICCD).

Given that both software packages were originally designed for distinct purposes and implemented using different programming languages, encountering incompatible components is inevitable. One prominent challenge lies in certain database conventions that hinder a straightforward and immediate connection between the systems. For instance:

-BraDypUS needs two mandatory fields (named “id” defined as the primary key, and “creator”) to be added to every PyArchInit table to properly work;

-BraDypUS requires each table name to have a unique prefix separated by a double underscore;

-Yet, pyArchInit is very restrictive on the table naming system, and names such as ‘site_table’and ‘US_table’ cannot be changed

To enable a connection between the two platforms, sharing a common database, we recommend the following procedural steps. As a premise, a PostgreSQL/PostGIS, PHP and Apache web server must be available; we will not cover here in detail the setup of a proper environment, since the BraDypUS official guide offers some support for this1 .

In QGIS, the pyArchInit plugin must be used to create and initialize the PostgreSQL database to strictly adhere to the required schema. Subsequently, the QGIS built-in function named DB Manager or an external tool (such as PgAdmin4) can be used to access the database generated by pyArchInit and add to each table the two columns required by BraDypUS, namely ‘id’ and ‘creator’. Both columns should be configured as type INTEGER2 . This is a critical step to align the PyArchInit database to BraDypUS. After these first steps, a new BraDypUS application can be created by pointing to the already-created database by selecting “pgsql” as the database type and entering the same connection credential used during the creation of the PostgreSQL database in pyArchInit3 . Consistency between BraDypUS and pyArchInit data is crucial for establishing a reliable connection and ensuring seamless interoperability.

To ensure easy access and manipulation of data within the BraDypUS environment, it is essential to meticulously create the configuration for each of the pyArchInit tables. BraDypUS integrates a graphical user interface (GUI) for this, which is simple and safe to use.4 that will be stored in the “Project” folder of BraDypUS. To facilitate this process, we have made available a first draft of the configuration files required to run BraDypUS on a pyArchInit database schema.5

As a result, some aspects remain unsolved, the main one being the issue related to the primary key of each table. BraDypUS mandatory requires a field named “id” to act as a primary key, a rather diffused practice in relational databases. On the other hand, PyArchInit uses a proper, uncommon, way of naming the primary key, by prefixing “id_” to the name of the table (e.g., us.id_us, sito.id_sito, tafonomia.id_tafonomia, and so on).

pyArchInit and BraDypUS use also different methods for representing stratigraphic relationships. PyArchInit files all related contexts as an array in a single field, while BraDypUS employs related tables by taking full advantage of the relational model. In the first case, heavy application logic is required to grant data consistency and avoid recursive relationship, something that is solved in the second case by few database constraints that prevent, for example, do define twice a relationship between two contexts.

These are only few preliminary notes that we wanted to share with a broader public of users and developers, in the attempt to facilitate further integration between software solutions that are spreading rapidly in the Italian context, at least.

Finally, the database behind pyArchInit and BraDypUS seamlessly integrates with QField, a GIS software for mobile devices, facilitating the direct storage of archaeological data gathered during fieldwork (Bernasocchi 2022a, 2022b). QField empowers users to visualise and manage GIS projects on smartphones or tablets, leveraging QGIS project themes, labels, and styles, and is currently becoming a rather common practice in the archaeological domain (Montagnetti and Guarino 2021, Montagnetti and Rosati 2019).

(G.G.)

References


1

2

More information is available at: https://docs.bdus.cloud/conventions(accessed 20/12/2023)

3

Further details and thorough instructions are available at the official BraDypUS documentation site: https://docs.bdus.cloud/create_app (accessed 20/12/2023).

4

https://docs.bdus.cloud/setup/

5

https://github.com/Heryx/cfg_from_pyarchinit_to_ bradypus (accessed 20/12/2023).