{"id":"https://openalex.org/W6949567178","doi":"https://doi.org/10.5281/zenodo.15530618","title":"FastLloyd","display_name":"FastLloyd","publication_year":2025,"publication_date":"2025-05-27","ids":{"openalex":"https://openalex.org/W6949567178","doi":"https://doi.org/10.5281/zenodo.15530618"},"language":"en","primary_location":{"id":"doi:10.5281/zenodo.15530618","is_oa":true,"landing_page_url":"https://doi.org/10.5281/zenodo.15530618","pdf_url":null,"source":{"id":"https://openalex.org/S4306400562","display_name":"Zenodo (CERN European Organization for Nuclear Research)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I67311998","host_organization_name":"European Organization for Nuclear Research","host_organization_lineage":["https://openalex.org/I67311998"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":null,"is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"article"},"type":"other","indexed_in":["datacite"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://doi.org/10.5281/zenodo.15530618","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"Diaa, Abdulrahman","orcid":"https://orcid.org/0009-0000-0377-3680"},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":true,"raw_author_name":"Diaa, Abdulrahman","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Humphries, Thomas","orcid":"https://orcid.org/0000-0003-0844-6771"},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Humphries, Thomas","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"last","author":{"id":null,"display_name":"Kerschbaum, Florian","orcid":"https://orcid.org/0000-0003-4288-2286"},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Kerschbaum, Florian","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I151746483"],"apc_list":null,"apc_paid":null,"fwci":null,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":null,"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":null,"last_page":null},"is_retracted":false,"is_paratext":false,"is_xpac":true,"primary_topic":null,"topics":[],"keywords":[{"id":"https://openalex.org/keywords/cluster-analysis","display_name":"Cluster analysis","score":0.7721999883651733},{"id":"https://openalex.org/keywords/python","display_name":"Python (programming language)","score":0.7250000238418579},{"id":"https://openalex.org/keywords/differential-privacy","display_name":"Differential privacy","score":0.510200023651123},{"id":"https://openalex.org/keywords/protocol","display_name":"Protocol (science)","score":0.445499986410141},{"id":"https://openalex.org/keywords/visualization","display_name":"Visualization","score":0.3905999958515167},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.3490999937057495}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8021000027656555},{"id":"https://openalex.org/C73555534","wikidata":"https://www.wikidata.org/wiki/Q622825","display_name":"Cluster analysis","level":2,"score":0.7721999883651733},{"id":"https://openalex.org/C519991488","wikidata":"https://www.wikidata.org/wiki/Q28865","display_name":"Python (programming language)","level":2,"score":0.7250000238418579},{"id":"https://openalex.org/C23130292","wikidata":"https://www.wikidata.org/wiki/Q5275358","display_name":"Differential privacy","level":2,"score":0.510200023651123},{"id":"https://openalex.org/C2780385302","wikidata":"https://www.wikidata.org/wiki/Q367158","display_name":"Protocol (science)","level":3,"score":0.445499986410141},{"id":"https://openalex.org/C124101348","wikidata":"https://www.wikidata.org/wiki/Q172491","display_name":"Data mining","level":1,"score":0.40720000863075256},{"id":"https://openalex.org/C36464697","wikidata":"https://www.wikidata.org/wiki/Q451553","display_name":"Visualization","level":2,"score":0.3905999958515167},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.39010000228881836},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.3490999937057495},{"id":"https://openalex.org/C2780154274","wikidata":"https://www.wikidata.org/wiki/Q7126717","display_name":"Download","level":2,"score":0.3359000086784363},{"id":"https://openalex.org/C151319957","wikidata":"https://www.wikidata.org/wiki/Q752739","display_name":"Asynchronous communication","level":2,"score":0.31049999594688416},{"id":"https://openalex.org/C81089528","wikidata":"https://www.wikidata.org/wiki/Q5134986","display_name":"clone (Java method)","level":3,"score":0.3012000024318695},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.28940001130104065},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.2865000069141388},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.2777000069618225},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.27239999175071716},{"id":"https://openalex.org/C93226319","wikidata":"https://www.wikidata.org/wiki/Q193137","display_name":"Differential (mechanical device)","level":2,"score":0.2621999979019165}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.5281/zenodo.15530618","is_oa":true,"landing_page_url":"https://doi.org/10.5281/zenodo.15530618","pdf_url":null,"source":{"id":"https://openalex.org/S4306400562","display_name":"Zenodo (CERN European Organization for Nuclear Research)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I67311998","host_organization_name":"European Organization for Nuclear Research","host_organization_lineage":["https://openalex.org/I67311998"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article"}],"best_oa_location":{"id":"doi:10.5281/zenodo.15530618","is_oa":true,"landing_page_url":"https://doi.org/10.5281/zenodo.15530618","pdf_url":null,"source":{"id":"https://openalex.org/S4306400562","display_name":"Zenodo (CERN European Organization for Nuclear Research)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I67311998","host_organization_name":"European Organization for Nuclear Research","host_organization_lineage":["https://openalex.org/I67311998"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":null,"is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":0,"referenced_works":[],"related_works":[],"abstract_inverted_index":{"FastLloyd:":[0],"Federated,":[1,58,548],"Accurate,":[2,59,549],"Secure,":[3,60,550],"and":[4,34,153,185,206,224,293,364,376,403,458,551,560,563],"Tunable":[5,552],"k-Means":[6,62],"Clustering":[7,63,310,554],"with":[8,64,89,197,231,360,411,555],"Differential":[9,65,556],"Privacy":[10],"FastLloyd":[11,51,67,128,338,538],"is":[12],"an":[13],"approach":[14],"to":[15,41,393,438,501,509,518,531],"privacy-preserving":[16,43],"k-means":[17,87],"clustering":[18,44,184,346],"in":[19,54,116,143,423,476,539],"horizontally":[20],"federated":[21,98],"settings.":[22],"It":[23],"offersstate-of-the-art":[24],"utility":[25,318],"while":[26],"providing":[27],"formal":[28],"privacy":[29,186,350],"guarantees":[30],"through":[31,472],"differential":[32],"privacy,":[33,80],"achieves":[35],"orders":[36],"ofmagnitude":[37],"faster":[38],"performance":[39,430,446],"compared":[40],"previous":[42],"methods.":[45],"Overview":[46],"This":[47],"repository":[48,418],"implements":[49],"the":[50,55,69,123,131,155,390,424,470,473,512,544],"protocol":[52,96],"described":[53],"paper":[56],"\"FastLloyd:":[57],"andTunable":[61],"Privacy\".":[66],"addresses":[68],"challenging":[70],"problem":[71],"of":[72,271,366,414,469,499],"collaborativeclustering":[73],"across":[74,348],"multiple":[75,340,395],"data":[76,132,462],"owners":[77],"without":[78],"compromising":[79],"through:":[81],"1.":[82,119,343],"A":[83,92],"novel":[84],"differentially":[85],"private":[86],"algorithm":[88],"radius":[90],"constraints2.":[91],"lightweight":[93],"secure":[94],"aggregation":[95],"for":[97,183,204,241,255,263,282,290,300,432,453,511,527],"settings":[99,351],"Installation":[100],"Requirements":[101],"-":[102,427,496],"Python":[103,113],"3.8":[104],"or":[105],"higher-":[106],"Open":[107],"MPI":[108,194],"(for":[109],"multiparty":[110],"communication)-":[111],"Required":[112],"packages":[114],"listed":[115],"`env.yml`":[117],"Setup":[118],"Clone":[120],"(or":[121],"download)":[122],"repository:":[124],"git":[125],"clone":[126],"https://github.com/D-Diaa/FastLloyd.gitcd":[127],"2.":[129,356],"Download":[130],"from":[133],"Zenodo":[134],"(Also":[135],"referenced":[136],"below),":[137],"then":[138],"mkdir":[139],"-p":[140],"datafor":[141],"f":[142],"*.tar.xz;":[144],"do":[145],"tar":[146],"--extract":[147],"--xz":[148],"--file=\"$f\"":[149],"--directory=datadone":[150],"3.":[151,372],"Create":[152],"activate":[154,163],"conda":[156,158],"environment:":[157],"env":[159],"create":[160],"-f":[161],"env.ymlconda":[162],"fastlloyd":[164],"Repository":[165],"Structure":[166],"\u251c\u2500\u2500":[167,170,188,191,200,215,218,234,237,244,250,258,274,277,286,304,307,320],"configs/":[168],"\u2502":[169,190,217,236,276,306],"defaults.py":[171],"#":[172,180,193,202,211,220,228,239,246,252,260,269,279,288,298,309,316,322,327,332,400,407],"Default":[173],"configuration":[174],"settings,":[175],"dataset":[176,265,361],"definitions\u2502":[177],"\u2514\u2500\u2500":[178,209,226,267,296,314],"params.py":[179],"Parameter":[181],"class":[182],"settings\u2502":[187],"data_io/":[189],"comm.py":[192],"communication":[195,375],"wrapper":[196],"delay":[198],"simulation\u2502":[199],"data_handler.py":[201],"Functions":[203],"loading":[205],"processing":[207],"datasets\u2502":[208,285],"fixed.py":[210],"Fixed-point":[212],"arithmetic":[213],"implementation\u2502":[214],"parties/":[216],"client.py":[219],"Client":[221],"implementations":[222],"(masked":[223],"unmasked)\u2502":[225],"server.py":[227],"Server":[229],"implementation":[230],"DP":[232],"mechanisms\u2502":[233],"plots/":[235],"ablation_plots.py":[238],"Visualization":[240,416],"ablation":[242,454],"studies\u2502":[243],"per_dataset.py":[245],"Dataset-specific":[247],"result":[248],"visualization\u2502":[249],"scale_heatmap.py":[251],"Heatmap":[253],"generation":[254],"scalability":[256,359],"results\u2502":[257,266],"synthetic_bar.py":[259],"Bar":[261],"charts":[262],"synthetic":[264,284,448],"timing_analysis.py":[268],"Analysis":[270],"timing":[272,302,409,461],"experiments\u2502":[273,295,303],"scripts/":[275],"generator.R":[278],"R":[280],"script":[281],"generating":[283],"experiment_runner.sh":[287],"Script":[289,299],"running":[291,301],"accuracy":[292,402],"scale":[294,404],"timing_runner.sh":[297],"utils/":[305],"evaluations.py":[308],"quality":[311,347],"evaluation":[312],"metrics\u2502":[313],"utils.py":[315],"General":[317],"functions\u2502":[319],"experiments.py":[321,353,369,383,479],"Main":[323],"experiment":[324,341,396,500],"runner\u251c\u2500\u2500":[325],"env.yml":[326],"Conda":[328],"environment":[329],"specification\u2514\u2500\u2500":[330],"README.md":[331],"Project":[333],"documentation":[334],"Usage":[335],"Running":[336],"Experiments":[337],"supports":[339],"types:":[342,397],"**Accuracy**:":[344],"Evaluate":[345],"different":[349],"python":[352,368,382,478],"--exp_type":[354,370,384,480],"\"accuracy\"":[355],"**Scale**:":[357],"Analyze":[358],"size,":[362],"dimensions,":[363],"number":[365],"clusters":[367],"\"scale\"":[371],"**Timing**:":[373],"Measure":[374],"computation":[377],"time":[378],"mpirun":[379],"-np":[380],"3":[381],"\"timing\"":[385],"You":[386,464],"can":[387,465],"also":[388],"use":[389,510,537],"provided":[391],"scripts":[392],"run":[394,502],"bash":[398],"scripts/experiment_runner.sh":[399],"For":[401,408],"experimentsbash":[405],"scripts/timing_runner.sh":[406],"experiments":[410,471],"varying":[412],"numbers":[413],"clients":[415],"The":[417],"includes":[419],"several":[420],"visualization":[421],"tools":[422],"`plots`":[425],"directory:":[426],"`per_dataset.py`:":[428],"Creates":[429,442,451],"visualizations":[431],"individual":[433],"datasets-":[434,449],"`scale_heatmap.py`:":[435],"Generates":[436],"heatmaps":[437],"analyze":[439],"scalability-":[440],"`synthetic_bar.py`:":[441],"bar":[443],"plots":[444,452],"comparing":[445],"on":[447],"`ablation_plots.py`:":[450],"studies-":[455],"`timing_analysis.py`:":[456],"Analyzes":[457],"reports":[459],"execution":[460],"Customization":[463],"customize":[466],"various":[467],"aspects":[468],"argument":[474],"parser":[475],"`experiments.py`:":[477],"\"test\"":[481],"--datasets":[482],"\"mnist\"":[483],"\"adult\"":[484],"--method":[485],"\"diagonal_then_frac\"":[486],"--alpha":[487],"0.8":[488],"--post":[489],"\"fold\"":[490],"--results_folder":[491],"\"my_results\"":[492],"Key":[493],"parameters":[494],"include:":[495],"`--exp_type`:":[497],"Type":[498],"(accuracy,":[503],"scale,":[504],"timing,":[505],"test)-":[506],"`--datasets`:":[507],"Datasets":[508],"experiment-":[513],"`--method`:":[514],"Maximum":[515,521],"distance":[516,522],"method":[517,526],"use-":[519],"`--alpha`:":[520],"parameter-":[523],"`--post`:":[524],"Post-processing":[525],"centroids-":[528],"`--results_folder`:":[529],"Folder":[530],"store":[532],"results":[533],"Citation":[534],"If":[535],"you":[536],"your":[540],"research,":[541],"please":[542],"cite":[543],"paper:":[545],"@inproceedings{diaa2025fastlloyd,":[546],"title={FastLloyd:":[547],"$k$-Means":[553],"Privacy},":[557],"author={A.":[558],"Diaa":[559],"T.":[561],"Humphries":[562],"F.":[564],"Kerschbaum},":[565],"eventtitle":[566],"=":[567],"{The":[568],"34th":[569],"{USENIX}":[570],"Security":[571],"Symposium},":[572],"year={2025},}":[573]},"counts_by_year":[],"updated_date":"2025-11-06T06:51:31.235846","created_date":"2025-10-10T00:00:00"}
