CatColab (working name) is a collaborative environment for formal, interoperable, conceptual modeling.
Elaborating on these keywords, CatColab aims to be:
- Formal: Models created in the system, be they qualitative or quantitative, are well-defined mathematical objects that can be critiqued with clarity.
- Interoperable: Models, and the logics in which they are expressed, can be flexibly interoperated with each other, without privileging any viewpoint as primary.
- Conceptual: Each domain-specific logic in the system is well adapted to the concepts used by practitioners in that domain.
- Modeling: Constructing a model is a collaborative, ongoing process that does not required participants to have specialized technical expertise.
An early demo is available at https://catcolab.org. For more about where the project is going, try this blog post.
Warning
CatColab is pre-alpha software under active development. You are welcome to experiment but you should not store any important or sensitive data in the system.
The staging deployment, synced to the main
branch, is available at
https://next.catcolab.org. Documentation for developers is browsable at
https://next.catcolab.org/dev/.
CatColab is written in a mix of Rust and TypeScript. To start developing, install install Rust (say by using rustup) and install pnpm, or use the dev container (see below).
To develop the frontend locally, clone the repository and run
pnpm install
pnpm run build
pnpm run dev --mode staging
Then navigate your browser to the URL provided by Vite.
Note that the flag --mode staging
uses the staging deployment of the backend.
When this flag is omitted, the command pnpm run dev
uses a local backend.
To maintain a clean and consistent codebase, we follow strict conventions on code formatting and style. To format and lint the frontend code, run these commands:
cd packages/frontend
pnpm run format
pnpm run lint
To format and lint the Rust code, run these commands:
cargo fmt
cargo clippy
Try to remember to run these commands before making a PR. (If you forget, the CI will remind you.)
CatColab has experimental support for development using a dev container, which simplifies the setup process by providing a pre-configured environment via a Dockerfile. This is most useful for developers using Visual Studio Code or other editors that support the dev containers standard.
To use the dev container:
- Ensure you have a container runtime installed and running on your machine. You can refer to the Open Container Initiative for more information on container standards and runtimes. For practical guidance, you might consider starting with Docker's Get Started Guide.
- Open the CatColab repository in VS Code.
- Open the VS Code command pallet by pressing
Cmd+Shift+P
on macOS orCtrl+Shift+P
on Linux - Issue the command "Dev Containers: Reopen in Container".
- Once the container is running, the necessary setup commands will be executed automatically.
- VS Code will prompt "Your application running on port 5173 is available. See all forwarded ports". Click the link to open the application in your browser.
As the name suggests, CatColab is based on mathematical ideas from category theory. It is a specific design goal that the system be usable without any knowledge of such ideas. Still, for those curious about the underlying mathematics, here are a few pointers for further reading.
CatColab is an editor for categorical structures and their morphisms and higher morphisms. The meta-logical framework organizing these categorical structures is based on double category theory. More precisely, the domain-specific logics in CatColab are defined by double theories, and the models in CatColab are models of double theories.
The library of domain-specific logics in CatColab, available now and to grow over time, is inspired by a wide body of research in applied category theory and beyond. Incomplete bibliographies are in the dev docs and the core docs.