Skip to content
@bizres

businessresponsibility.ch

businessresponsibility.ch is a project to strengthen transparency and democratic control over the human rights performance of Swiss companies.

Welcome to the "businessresponsibility.ch" project! 👋

https://en.businessresponsibility.ch/ The businessresponsibility.ch project strengthens transparency and democratic control over the human rights performance of Swiss companies, based on the new non-financial reporting obligation.

Background - Swiss Code of Obligations

By introducing a non-financial reporting obligation, Switzerland is following suit with the law that has already existed in the EU since 2014. However, there is a great lack of transparency with regard to compliance with the reporting obligation: It is unclear which companies are specifically subject to the legal obligation and it is very time-consuming to obtain an overview of which of these companies actually comply with their obligation. This lack of transparency makes it very difficult for civil society to monitor compliance with the law and to hold companies accountable.

Indirect counter-proposal to the popular initiative

«Für verantwortungsvolle Unternehmen – zum Schutz von Mensch und Umwelt»


Wikipedia ©

Project Summary

With businessresponsibility.ch, we are building a digital platform that enables citizens, activists and non-governmental organizations to check whether and how Swiss companies report on sustainability and human rights issues, as required by the new non-financial reporting obligation. The businessresponsibility.ch platform closes the information gap and empowers civil society to demand the information required by the law.

On businessresponsibility.ch, interested parties can quickly and easily see which companies comply with the non-financial reporting obligation. The digital platform identifies, collects, analyzes and publishes non-financial reporting data from hundreds of Swiss companies and makes this information available free of charge.

Based on this data, businessresponsibility.ch enables the analysis of corporate reporting in Switzerland and thus allows civil society, authorities, legislators and last but not least the business community itself to gain a fact-based and always up-to-date insight into the development and progress of non-financial reporting in Switzerland.

    

Architecture

The architectural layout of the businessresponsibility.ch platform can basically be represented in three clearly comprehensible and distinguishable software parts. These parts are internally connected either with system calls such as REST APIs, automated processes or manual user interventions.

The system architecture basically consists of these three distinguishable parts:

  1. Data extraction, processing and workflow management
  2. Natural Language Processing (NLP) and topic classification
  3. Data storage, content management (backend / APIs) and data access (frontend)

system_diagram

Design and implementation decisions

Due to time restrictions and work capacities of the project team members, we decided early on to use proprietary third-party tools to increase our chances to implement and complete a prototype on time.

The aim of the prototype was to build a comprehensible workflow for report topic classification and highlight the potential of our solution with minimal implementation effort. With this approach, we could focus on the report topic classification and frontend development.

We currently use the AirTable as our report context database, screening and approval tool for the sustainability reports. With the Google Search JSON API, we are able to find the concerning reports by certain search terms on the company websites. The Integromat is used to connect the services and automate the workflows.

third_party_integration

Besides the early decision on using proprietary tools, we still laid strategic foundations to replace these tools with Open Source software components and services:

  • AirTable → Strapi (Headless CMS solution)
  • Integromat → Node-RED (a flow-based development tool)
  • Google Search API → Node.js or Python based Crawlers (ie. Scrappy)

1. Data extraction, processing and workflow management

What do we collect and how?

workflow

TBD.

How do we extract the data?

We store the collected data in AirTable, the extracted data in Hidora Jelastic Cloud. The text extraction service is implemented in the report-text-extraction repository using Python as the programming language. This service provides a REST API for extracting the text data from a sustainability report PDF and retrieving the context dependent information to the clients.

To start the Extract process, we provide a trigger via GET http service ‘extract’. Once the trigger is pulled the 202 Accepted response is immediately returned to the client and the Extract process starts in the background on the server.

We pull all the records from the AirTable. The pulled data: ‘airtable record id’, ‘ExtractedID’, and PDF metadata, including link to PDF file. For each record we check if the ‘ExtractedID’ is provided, then we check if the corresponding PDF file is available on the local storage. If available - record is skipped.

If ‘ExtractedID’ is empty - we generate a new unique id. For not skipped records we download the corresponding PDF file and save it locally. After the download, we extract text from PDF with pdfminer.six library and save the TXT file locally as well. After that we prepare and save a JSON file with metadata: ‘air_id = airtable record id’, ‘id = ExtractedID’, and ‘filename = original file name’.

After extraction of every 10 records we send a bulk PATCH request back to airtable to update corresponding records with ‘ExtractedID’ or ‘ExtractedStatus’ if there is an issue with a record. 10 is the AirTable limit. The ‘ExtractedID’ field is needed to decrease/avoid issues when working on multiple servers/dev environments.

The complete extraction of 1158 records takes about 18 hours on dev PC and is about 5.23 GB.

airtable_extraction_tool_data_flow

What are the processes to get useful information from the extracted data?

We store three distinct pieces of information about the sustainability reports, which are the report in PDF format itself, the extracted text data and the meta-information retrieved from AirTable. These data are extracted and stored permanently in our NFS storage solution during the text extraction process and can be accessed via an API call by submitting an UUID explained in the previous chapter.

report_classification_process

Currently, we use the report extraction API to trigger the extraction process of the reports PDFs and subsequently saving the original PDFs and extracted data permanently in the storage solution. The data can be later retrieved either by the frontend components to display the report PDFs to the visitors or by the NLP services to execute the report classification processes. Especially the NLP services rely on the accessibility of the extracted text data and meta information.

Where do we store the data?

We currently utilize Hidora's Jelastic Cloud services for storing the original, extracted and processed reports data in a Shared Storage Container with NFS client type for data mounting. With this approach, we don’t have to rely on external third-party data storage services such as Google Drive, Dropbox, AWS Storage solutions.

This storage container can be mounted in every service node in the Hidora environment and data can be accessed directly as if it were locally stored. With this approach, we can ease the data protection restrictions in internal usage.

01-shared-storage-container-illustration

How do we ensure that other people access this information?

The sustainability reports must be publicly available and accessible on the Internet by the upcoming Swiss law. Accordingly, there is no urgency to make the internally stored sustainability reports accessible on our platform or via an RESTful API.

However, on the web platform the sustainability report PDFs will be retrieved and displayed from our storage solution, in case the original report is no longer accessible on the company's original report URL. We are currently in discussion with several user groups, NGOs and governmental institutions on the accessibility of the data according to the Open Data deployment scheme.

2. Natural Language Processing (NLP) and topic classification

The goal of this project is to analyze sustainability reports on their promise to report about sustainability and human rights issues as required by the new non-financial reporting obligation. To allow a structured analysis we want to classify each report in five categories. The categories are: Human Rights, Environment, Corruption, Social Concerns and Employee Concerns. For each of these categories we want to be able to tell if the report addresses related issues or not. With this information we can in a next step analyze temporal development, create lists of companies who face up to their responsibilities and those who do not, etc.

To get to this point we did not only have to collect reports and make them machine readable by extracting the text but also assess the topics which are covered by the text. All this should be done with a structured, accessible and reproducible process such that the results of our analyses are robust and explainable.

The following illustration shows schematically our process to arrive at the required results for ruther analysis. After extracting text from the reports, we tag each section of the report with one, none or multiple of the considered categories. If a section is tagged with a category then this means that the section somehow assesses a topic relevant to the category. If a report has enough sections assessing one of the categories then the whole report is considered to report on the topic.

nlp_process

Classifying the reports is a non-trivial task. On one hand the sheer amount of text is too much for a human classifier. On the other hand a manual approach of classifying the reports is neither accessible nor reproducible since different human beings assess text in different ways and afterwards it is not clear why a text was e.g. labeled as addressing social concerns or why not. Our answer to solve this problem was the development of an algorithm which automatically classifies texts. This algorithm can not only do a day’s work of a human in a few seconds but also (and more importantly) be validated and rerun whenever necessary. The validation of the algorithm allows us to assess how stringent and accurate our classifications are and also to show the design and parameters of our model which explains why sections are tagged in a transparent and reproducible way. In the machine learning community this way of processing text is often called Natural Language Processing or NLP for short.

The following illustration shows the process of training our model. First, we select a number of Wikipedia articles which are interpreted as individual topics. We then generate Keywords based on the content of the articles using tf-idf metrics. Lastly, the algorithm searches for keywords in the sustainability reports.

Screenshot 2022-02-24 154202

Topic Detection

The algorithm is built to be adaptable, if in the future we want to use new topics or categories. At the moment we use the following articles to detect topics of five main categories:

Human Rights: Human rights, Right of return, Right of self-defense, Right to be heard, Right to clothing, Right to disconnect, Right to explanation, Right to family life, Right to personal identity, Right to sexuality, Right to truth, Right to social security, Right to food, Right to housing, Right to health, Right to education

Environment: Climate change, Environmental degradation, Environmental health, Environmental issues with energy, Environmental impact of transport, Environmental issues with war, Overpopulation, Mutation breeding, Genetically modified food, Air pollution, Light pollution, Noise pollution, Soil pollution, Water pollution, Resource depletion, Waste

Corruption: Corruption, Cronyism, Insider trading, Nepotism, Police corruption, Securities fraud, Bribery, Embezzlement, Money laundering, Political corruption, Tax evasion

Social Issues: Social stratification, Unemployment, Working poor, Ageism, Social inequality, Educational inequality, wage inequality, gender inequality, racial inequality, Health equity, discrimination, Environmental racism, Abortion debate, literacy, racism, Human trafficking

Employee Concerns: Labor rights, Equal pay for equal work, Overtime, Child labour, Occupational safety and health, Minimum wage, Gender pay gap

If you are interested in the implementation details, please visit our sub repository, specifically our example [Notebook] to gain further insights. For documentation reasons there also exists this deprecated sub repository which contains a supervised approach which was deemed not feasible as we lack resources for extended labeling.

Reoport classification

One the topics are detected, we have to classify the reports as a whole. For our Prototype Fund project we used the following rules:

  • For each topic, we generate at most 10 key expressions which contain two words (e.g.. "air pollution" or "lung cancer").
  • If a section of a report contains at least one key expression of a topic it is considered to report about the topic
  • If a report contains at least 600 characters (i.e. "half a page") of sections about subtopics of a category, the report is considered to report about the category

Those rules are designed such that our categorization have rather "broad catchment area". However, for further analysis and different projects the selection of topics and the classification rules of reports will very likely look different, depending on the kind of analysis and project.

Technologies

Following technologies are currently selected:

  • Third-Party tools: AirTable, Integromat, Google Search API - used for Rapid Prototyping purposes
  • Jelastic Cloud environment: Hidora.io (https://hidora.io)
  • Loadbalancer: Nginx
  • Backend: Node.js with Strapi (https://strapi.io)
  • Frontend: Node.js with Next.js / React (https://nextjs.org/)
  • Database: PostgreSQL
  • Machine Learning and NLP: Python, fastText
  • Development and Production Environment with Docker

Project roadmap

Contributing to the project

We aim to be a community driven project, which embraces the broad range of opinions, people with cultures and different mind-sets, and technological backgrounds. We are sure that a close collaboration with the Open Source communities and Institutions is essential for the success of this project. Therefore, we encourage and welcome everybody, who wants to participate and make a contribution to this project.

You can reach us either on our website businessresponsibility.ch or GitHub project page or with our official E-Mail address info@businessresponsibility.ch.

Team

We are an interdisciplinary team of political scientists, economists, environmental activists and software developers that support the businessresponsibility.ch project. This is a non-profit startup project that aims to strengthen transparency and democratic oversight of the human rights performance of Swiss companies.

We are building a digital platform to monitor company performance vis a vis non-financial reporting obligations. We are currently funded by the Prototype Fund, which supports innovative open source projects that strengthen democratic participation in Switzerland through digital solutions.

  • David Weiss (Project Lead)
  • Dina Pomeranz (Strategic Advisor)
  • Deborah Kistler (Project Manager)
  • Kobbina Awuah (Business Manager)
  • Cahit Atilgan (Tech Lead)
  • Nickolay Golomysov (Tech Developer)
  • Johannes Hool (Tech Developer)
  • Miguel Vazquez Vazquez (Tech Developer)
  • Schahin Bajka (Report Analysis Support)

Feedback

We welcome any feedback concerning our project! Please send us a message to our official E-Mail address info@businessresponsibility or reach out for specific questions our team members:

  • Project specific questions and feedback: David Weiss and Dina Pomeranz
  • Technology specific questions:
    • System architecture / GitHub / Development: Cahit Atilgan
    • Machine Learning / Natural Language Processing: Nickolay Golomysov or Johannes Hool

License

This project is currently using the 3-Clause BSD license, which allows almost unlimited freedom with the software as long as the BSD copyright and license notice are included

Acknowledgments

Pinned Loading

  1. businessresponsibility businessresponsibility Public

    businessresponsibility.ch is a project to strengthen transparency and democratic control over the human rights performance of Swiss companies.

    TypeScript 5

  2. report-topic-classification report-topic-classification Public

    A natural language processing module for the sustainability report topic classification

    Python 1

  3. report-text-extraction report-text-extraction Public

    Python 1

Repositories

Showing 7 of 7 repositories
  • bizres/report-topic-classification-supervised’s past year of commit activity
    Python 0 BSD-3-Clause 0 0 0 Updated Jun 21, 2022
  • bizres/report-topic-classification-unsupervised’s past year of commit activity
    Jupyter Notebook 0 0 0 0 Updated Jun 21, 2022
  • .github Public

    Adds a README.md to your organization's GitHub profile.

    bizres/.github’s past year of commit activity
    0 BSD-3-Clause 0 0 0 Updated Jun 21, 2022
  • report-topic-classification Public

    A natural language processing module for the sustainability report topic classification

    bizres/report-topic-classification’s past year of commit activity
    Python 1 0 0 0 Updated Feb 24, 2022
  • businessresponsibility Public

    businessresponsibility.ch is a project to strengthen transparency and democratic control over the human rights performance of Swiss companies.

    bizres/businessresponsibility’s past year of commit activity
    TypeScript 5 0 0 0 Updated Feb 21, 2022
  • core-team Public

    businessresponsibility.ch is a project to strengthen transparency and democratic control over the human rights performance of Swiss companies.

    bizres/core-team’s past year of commit activity
    2 MIT 0 22 0 Updated Feb 5, 2022
  • bizres/report-text-extraction’s past year of commit activity
    Python 0 BSD-3-Clause 1 1 0 Updated Feb 5, 2022

Most used topics

Loading…