{"id":22131813,"url":"https://github.com/distributedcomponents/verdi-aggregation","last_synced_at":"2025-09-07T17:33:52.140Z","repository":{"id":77119579,"uuid":"74302347","full_name":"DistributedComponents/verdi-aggregation","owner":"DistributedComponents","description":"An implementation of a distributed aggregation protocol, verified in Coq using the Verdi framework","archived":false,"fork":false,"pushed_at":"2017-08-05T04:48:07.000Z","size":3168,"stargazers_count":2,"open_issues_count":1,"forks_count":0,"subscribers_count":4,"default_branch":"master","last_synced_at":"2025-01-29T14:50:06.882Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Coq","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-2-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/DistributedComponents.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2016-11-20T21:02:52.000Z","updated_at":"2020-04-14T13:00:33.000Z","dependencies_parsed_at":"2023-03-22T02:03:21.957Z","dependency_job_id":null,"html_url":"https://github.com/DistributedComponents/verdi-aggregation","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DistributedComponents%2Fverdi-aggregation","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DistributedComponents%2Fverdi-aggregation/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DistributedComponents%2Fverdi-aggregation/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/DistributedComponents%2Fverdi-aggregation/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/DistributedComponents","download_url":"https://codeload.github.com/DistributedComponents/verdi-aggregation/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245240979,"owners_count":20583138,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-12-01T18:37:45.179Z","updated_at":"2025-03-24T09:22:49.968Z","avatar_url":"https://github.com/DistributedComponents.png","language":"Coq","funding_links":[],"categories":[],"sub_categories":[],"readme":"Verdi Aggregation\n=================\n\n[![Build Status](https://api.travis-ci.org/DistributedComponents/verdi-aggregation.svg?branch=master)](https://travis-ci.org/DistributedComponents/verdi-aggregation)\n\nAn implementation of a distributed aggregation protocol, verified in Coq using the Verdi framework.\n\nRequirements\n------------\n\nDefinitions and proofs:\n\n- [`Coq 8.6`](https://coq.inria.fr/coq-86)\n- [`Verdi`](https://github.com/uwplse/verdi)\n- [`math-comp`](https://math-comp.github.io/math-comp/) (`ssreflect`, `fingroup`, `algebra`)\n- [`StructTact`](https://github.com/uwplse/StructTact)\n- [`InfSeqExt`](https://github.com/DistributedComponents/InfSeqExt)\n- [`AAC_tactics`](https://github.com/coq-contribs/aac-tactics)\n- [`Cheerios`](https://github.com/uwplse/cheerios)\n- [`verdi-cheerios`](https://github.com/DistributedComponents/verdi-cheerios)\n\nExecutable code:\n\n- [`OCaml 4.02.3`](https://ocaml.org) (or later)\n- [`OCamlbuild`](https://github.com/ocaml/ocamlbuild)\n- [`ocamlfind`](http://projects.camlcity.org/projects/findlib.html)\n- [`verdi-runtime`](https://github.com/DistributedComponents/verdi-runtime)\n- [`Uuidm`](http://erratique.ch/software/uuidm)\n- [`PortAudio`](http://www.portaudio.com)\n- [`ocaml-portaudio`](https://github.com/savonet/ocaml-portaudio)\n\nIntegration testing of executable code:\n\n- [`Python 2.7`](https://www.python.org/download/releases/2.7/)\n\nUnit testing of unverified code:\n\n- [`OUnit 2.0.0`](http://ounit.forge.ocamlcore.org)\n\nBuilding\n--------\n\nFirst, make sure the PortAudio library is installed on the system; on Ubuntu and Debian systems, the package is called `portaudio19-dev`.\n\nThe recommended way to install the OCaml and Coq dependencies of Verdi Aggregation is via [OPAM](https://coq.inria.fr/opam/www/using.html):\n\n```\nopam repo add coq-released https://coq.inria.fr/opam/released\nopam repo add distributedcomponents-dev http://opam-dev.distributedcomponents.net\nopam install coq-mathcomp-ssreflect coq-mathcomp-fingroup coq-mathcomp-algebra coq-aac-tactics \\\n verdi StructTact InfSeqExt cheerios verdi-cheerios verdi-runtime uuidm portaudio\n```\n\nThen, run `./configure` in the root directory.  This will check for the appropriate version of Coq and ensure all necessary dependencies can be located.\n\nBy default, the script assumes that `Verdi`, `StructTact`, `InfSeqExt`, `Cheerios`, and `VerdiCheerios` are installed in Coq's `user-contrib` directory, but this can be overridden by setting the `Verdi_PATH`, `StructTact_PATH`, `InfSeqExt_PATH`, `Cheerios_PATH`, and `VerdiCheerios_PATH` environment variables.\n\nFinally, run `make` in the root directory.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdistributedcomponents%2Fverdi-aggregation","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdistributedcomponents%2Fverdi-aggregation","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdistributedcomponents%2Fverdi-aggregation/lists"}