Skip to content

Latest commit

 

History

History
70 lines (57 loc) · 3.3 KB

README.md

File metadata and controls

70 lines (57 loc) · 3.3 KB

Documentation

Return to the mainpage

This document is the developer documentation for the BrainBrowsR project by NeuroTech Leuven. The project consists of two main parts, a backend and a frontend. These are then connected through WebSockets. The global structure that connects everything can be found in the following diagram.

    flowchart TD;
        subgraph BrainBrowsR
        subgraph Frontend
        subgraph On start
        Start[Start the browser extension]-->pre[Preprocess HTML and insert stimuli]
        pre-->init[set current_post to first post in DOM]
        init-->connect[start WebSocket connection]
        end
        subgraph Parse and wait
        connect--> process[process the current post]
        process-->wait
        wait[wait for message] --no message--> wait
        end
        subgraph WebSocket action
        wait--message received-->decision{Received message}
        decision--next-->next(parse the next post)
        decision--previous-->previous(parse the previous post)
        decision--like-->like(like the post)
        end
        next-->process
        previous-->process
        like -->wait
        end
        subgraph Backend
        subgraph On start
        BrainServR[Create an instance of BrainServR]
        BrainServR-->Headset[Connect with the headset]
        Headset-->Websockets[Starts the WebSockets server]
        Websockets--waiting for connecting -->Websockets
        Websockets--extension connects-->XTConnect

        connect-->XTConnect[Extension Connects]

        end
        subgraph Data-processing
        XTConnect-->SDP[Start data-processing]
        SDP-->Gather[Get data from the headset]
        Gather-->prep[Preprocess the data]
        prep-->classify[Classify the data]
        classify-->thresh{Certainty higher than the threshold?}
        thresh --yes--> send[Send message through websockets]
        send--label/action-->wait
        send--start over-->prep
        thresh--no--> prep

        end
        end
        end

    style Start fill:#26bf24
Loading

Back-end

The backend of BrainBrowR consists of two parts, the WebSockets server and the data processing pipeline. The backend is written in Python and invisible to the application user. It collects the data from the headset, applies data processing, and sends the result to the extension through WebSockets. To learn more about WebSockets, go to the documentation in this document. To learn more about the data processing pipeline, go to the documentation here.

Front-end

The frontend is the extension. The frontend is written in JavaScript with Firefox in mind as the browser. Firefox has created some valuable tools to make the development of the extension easier. However, extending the extension to Chromium-based browsers should be easy.

The extension does three main things. First, it inserts the stimuli in the webpage, the methodology for this is written here. These stimuli will excite the brain, so the data processing pipeline will detect that the user is looking at a specific stimulus. The extension will then respond appropriately by parsing the right post, described here, and then processing this.

Return to the mainpage