We propose a Reader-aware Congruence Assistant (RaCA), which supports writers to create texts that are adapted to target readers. Similar to user-centered design which is based on user profiles, RaCA features reader-centered writing through reader profiles(RP) that are dynamically computed from information discovered through academic search engines. Our assistant then leverages large language models to measure the congruence of a written text with a given reader profile, and provides feedback to the writer. We demonstrate our approach with an implemented prototype that illustrates how RaCA exploits information available on the Web to construct reader profiles, assesses writer-reader congruence and offers writers color-coded visual feedback accordingly.
👀 demo: here
Before setting up the project, ensure you have the following installed:
- Python 3.x
- Flask
- Flask-CORS
- OpenAI Python package
Also, you'll need an OpenAI API key to use the text analysis features.
-
Clone the project repository.
-
Navigate to the project directory and create a virtual environment:
python -m venv venv source venv/bin/activate # Unix/macOS venv\Scripts\activate.bat # Windows
-
Install the required Python packages:
pip install Flask Flask-CORS OpenAI
Before running the application, configure your OpenAI API key in app.py
by replacing OPENAI_API_KEY
with your actual key.
app.py
: The entry point to the application, responsible for initializing the Flask app and integrating server and client components.app.server.py
: Contains server-side logic, including routes for fetching reader profiles, performing coherence analysis, and calculating scores.app.client.py
: Manages client-side interactions, serving HTML templates and handling form submissions.arc/
: A directory housing the Flask app declaration, metrics computation modules, and templates of UI.__init__.py
metrics/
: Contains modules for computing coherence scores or related measurements.static/
: Contains JavaScript files for client-side functionality.template/
: Stores HTML templates that define the UI of the coherence analysis system.
Defines Flask routes for:
- Fetching data based on
personal_id
. - Performing coherence analysis between user text and abstracts.
- Calculating co-occurrence scores.
Handles:
- Serving HTML templates for user interaction.
- Capturing and submitting user inputs for analysis.
To run the application:
- Start the Flask server by executing
app.py
:python app.py
- Access the web application via your browser at
http://localhost:5000
.
Users can interact with the system through the web interface provided by the app.client.py
routes. This includes submitting texts for analysis, choosing reader profiles, and viewing suggestions and scores for text coherence.
We welcome contributions to TLCA. Feel free to fork the repository, make improvements, and submit pull requests. For bugs and feature requests, please use the issue tracker.
This project is licensed under GPL-3.0 license.
For support or collaboration, please contact ge.li2@studio.unibo.it.