{"id":"https://openalex.org/W4414978574","doi":"https://doi.org/10.1145/3763126","title":"Flix: A Design for Language-Integrated Datalog","display_name":"Flix: A Design for Language-Integrated Datalog","publication_year":2025,"publication_date":"2025-10-09","ids":{"openalex":"https://openalex.org/W4414978574","doi":"https://doi.org/10.1145/3763126"},"language":"en","primary_location":{"id":"doi:10.1145/3763126","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3763126","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://doi.org/10.1145/3763126","any_repository_has_fulltext":null},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5034330109","display_name":"Magnus Madsen","orcid":"https://orcid.org/0000-0002-7510-8724"},"institutions":[{"id":"https://openalex.org/I204337017","display_name":"Aarhus University","ror":"https://ror.org/01aj84f44","country_code":"DK","type":"education","lineage":["https://openalex.org/I204337017"]}],"countries":["DK"],"is_corresponding":true,"raw_author_name":"Magnus Madsen","raw_affiliation_strings":["Aarhus University, Aarhus, Denmark"],"raw_orcid":"https://orcid.org/0000-0002-7510-8724","affiliations":[{"raw_affiliation_string":"Aarhus University, Aarhus, Denmark","institution_ids":["https://openalex.org/I204337017"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5039616179","display_name":"Ond\u0159ej Lhot\u00e1k","orcid":"https://orcid.org/0000-0001-9066-1889"},"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":"Ond\u0159ej Lhot\u00e1k","raw_affiliation_strings":["University of Waterloo, Waterloo, Canada"],"raw_orcid":"https://orcid.org/0000-0001-9066-1889","affiliations":[{"raw_affiliation_string":"University of Waterloo, Waterloo, Canada","institution_ids":["https://openalex.org/I151746483"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5034330109"],"corresponding_institution_ids":["https://openalex.org/I204337017"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":{"value":0.13448222,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"9","issue":"OOPSLA2","first_page":"2115","last_page":"2143"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10215","display_name":"Semantic Web and Ontologies","score":0.9979000091552734,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10215","display_name":"Semantic Web and Ontologies","score":0.9979000091552734,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10317","display_name":"Advanced Database Systems and Queries","score":0.9966999888420105,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.9957000017166138,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/datalog","display_name":"Datalog","score":0.9941999912261963},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.5248000025749207},{"id":"https://openalex.org/keywords/guard","display_name":"Guard (computer science)","score":0.5066999793052673},{"id":"https://openalex.org/keywords/constraint-programming","display_name":"Constraint programming","score":0.43470001220703125},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.43459999561309814},{"id":"https://openalex.org/keywords/declarative-programming","display_name":"Declarative programming","score":0.39989998936653137},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.3937000036239624},{"id":"https://openalex.org/keywords/logic-programming","display_name":"Logic programming","score":0.37560001015663147}],"concepts":[{"id":"https://openalex.org/C148230440","wikidata":"https://www.wikidata.org/wiki/Q1172264","display_name":"Datalog","level":2,"score":0.9941999912261963},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8136000037193298},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7738000154495239},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.5248000025749207},{"id":"https://openalex.org/C141141315","wikidata":"https://www.wikidata.org/wiki/Q2379942","display_name":"Guard (computer science)","level":2,"score":0.5066999793052673},{"id":"https://openalex.org/C173404611","wikidata":"https://www.wikidata.org/wiki/Q528588","display_name":"Constraint programming","level":3,"score":0.43470001220703125},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.43459999561309814},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.40139999985694885},{"id":"https://openalex.org/C146206909","wikidata":"https://www.wikidata.org/wiki/Q531152","display_name":"Declarative programming","level":4,"score":0.39989998936653137},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.3937000036239624},{"id":"https://openalex.org/C128838566","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic programming","level":2,"score":0.37560001015663147},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.3488999903202057},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.3192000091075897},{"id":"https://openalex.org/C117251300","wikidata":"https://www.wikidata.org/wiki/Q1849855","display_name":"Parametric statistics","level":2,"score":0.29339998960494995},{"id":"https://openalex.org/C195818886","wikidata":"https://www.wikidata.org/wiki/Q5421724","display_name":"Expressive power","level":2,"score":0.2824000120162964},{"id":"https://openalex.org/C50033165","wikidata":"https://www.wikidata.org/wiki/Q15712089","display_name":"Inductive programming","level":3,"score":0.2750000059604645},{"id":"https://openalex.org/C96315309","wikidata":"https://www.wikidata.org/wiki/Q5508829","display_name":"Functional logic programming","level":4,"score":0.26499998569488525},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.26269999146461487},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.25609999895095825},{"id":"https://openalex.org/C2777502361","wikidata":"https://www.wikidata.org/wiki/Q1182254","display_name":"Deductive database","level":2,"score":0.251800000667572}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3763126","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3763126","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:pure.atira.dk:openaire/3f448047-0807-4865-8e2b-991fa199965f","is_oa":true,"landing_page_url":"https://pure.au.dk/portal/en/publications/3f448047-0807-4865-8e2b-991fa199965f","pdf_url":null,"source":null,"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Madsen, M & Lhot\u00e1k, O 2025, 'Flix : A Design for Language-Integrated Datalog', Proceedings of the ACM on Programming Languages , vol. 9, no. OOPSLA2, pp. 2115-2143. https://doi.org/10.1145/3763126","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"doi:10.1145/3763126","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3763126","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":68,"referenced_works":["https://openalex.org/W48620657","https://openalex.org/W1768000531","https://openalex.org/W1846157972","https://openalex.org/W1968968780","https://openalex.org/W1971962972","https://openalex.org/W1974695870","https://openalex.org/W1976055110","https://openalex.org/W2008865455","https://openalex.org/W2036157748","https://openalex.org/W2056116767","https://openalex.org/W2080573945","https://openalex.org/W2088675571","https://openalex.org/W2089522440","https://openalex.org/W2091138122","https://openalex.org/W2097366413","https://openalex.org/W2134321625","https://openalex.org/W2139875914","https://openalex.org/W2153329411","https://openalex.org/W2155882070","https://openalex.org/W2158600037","https://openalex.org/W2162621793","https://openalex.org/W2163521620","https://openalex.org/W2167685423","https://openalex.org/W2167845698","https://openalex.org/W2293299776","https://openalex.org/W2295651644","https://openalex.org/W2299299451","https://openalex.org/W2417567569","https://openalex.org/W2433992225","https://openalex.org/W2513927163","https://openalex.org/W2517279098","https://openalex.org/W2867457158","https://openalex.org/W2898152370","https://openalex.org/W2898652177","https://openalex.org/W2899873839","https://openalex.org/W2903272482","https://openalex.org/W2912940102","https://openalex.org/W2916507006","https://openalex.org/W2955447707","https://openalex.org/W2962604136","https://openalex.org/W2996212942","https://openalex.org/W3021830120","https://openalex.org/W3088323786","https://openalex.org/W3101609070","https://openalex.org/W3108199096","https://openalex.org/W3109650547","https://openalex.org/W3174779340","https://openalex.org/W3175660327","https://openalex.org/W3205634919","https://openalex.org/W4211058158","https://openalex.org/W4220851630","https://openalex.org/W4247889999","https://openalex.org/W4251478049","https://openalex.org/W4296313421","https://openalex.org/W4310506229","https://openalex.org/W4318969881","https://openalex.org/W4372046852","https://openalex.org/W4386317475","https://openalex.org/W4386324444","https://openalex.org/W4387667008","https://openalex.org/W4387674013","https://openalex.org/W4387674126","https://openalex.org/W4388481780","https://openalex.org/W4390604895","https://openalex.org/W4412230426","https://openalex.org/W4412230437","https://openalex.org/W6910354045","https://openalex.org/W6949625935"],"related_works":[],"abstract_inverted_index":{"We":[0,14,50,84],"present":[1],"a":[2,125],"comprehensive":[3],"overview":[4],"of":[5,35,62,95,120,137],"the":[6,10,56,68,102,109],"Datalog":[7,23,36,40,63,86,100],"facilities":[8],"in":[9,65,88],"Flix":[11,89],"programming":[12,64,87],"language.":[13],"show":[15],"how":[16,28],"programmers":[17],"can":[18,141],"write":[19],"functions":[20],"implemented":[21],"as":[22],"programs":[24,37],"and":[25,32,47,59,70,75,82,108,111,122,134],"we":[26],"demonstrate":[27],"to":[29,98,128],"build":[30],"modular":[31],"reusable":[33],"families":[34],"using":[38],"first-class":[39],"program":[41,72,116],"values,":[42],"rho":[43],"abstraction,":[44],"parametric":[45],"polymorphism,":[46],"type":[48],"classes.":[49],"describe":[51],"several":[52,91],"features":[53],"that":[54,140],"improve":[55],"ergonomics,":[57],"flexibility,":[58],"expressive":[60],"power":[61],"Flix,":[66],"including":[67,93],"inject":[69],"query":[71],"constructs,":[73],"head":[74],"guard":[76],"expressions,":[77],"functional":[78],"predicates,":[79],"lattice":[80],"semantics,":[81],"more.":[83],"illustrate":[85],"with":[90,144],"applications,":[92],"implementations":[94,119],"Ullman's":[96],"algorithm":[97,104],"stratify":[99],"programs,":[101],"Ford-Fulkerson":[103],"for":[105,114],"maximum":[106],"flow,":[107],"IFDS":[110,121],"IDE":[112,123],"algorithms":[113,139],"context-sensitive":[115],"analysis.":[117],"The":[118],"fulfill":[124],"long-term":[126],"goal:":[127],"have":[129],"fully":[130],"modular,":[131],"polymorphic,":[132],"typed,":[133],"declarative":[135],"formulations":[136],"these":[138],"be":[142],"instantiated":[143],"any":[145],"abstract":[146],"domain.":[147]},"counts_by_year":[],"updated_date":"2026-05-21T06:26:12.895304","created_date":"2025-10-10T00:00:00"}
