{"id":"https://openalex.org/W2028229594","doi":"https://doi.org/10.1017/s1471068412000075","title":"Region-based memory management for Mercury programs","display_name":"Region-based memory management for Mercury programs","publication_year":2012,"publication_date":"2012-05-29","ids":{"openalex":"https://openalex.org/W2028229594","doi":"https://doi.org/10.1017/s1471068412000075","mag":"2028229594"},"language":"en","primary_location":{"id":"doi:10.1017/s1471068412000075","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s1471068412000075","pdf_url":null,"source":{"id":"https://openalex.org/S59670734","display_name":"Theory and Practice of Logic Programming","issn_l":"1471-0684","issn":["1471-0684","1475-3081"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Theory and Practice of Logic Programming","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://lirias.kuleuven.be/handle/123456789/316452","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5012278270","display_name":"Quan Phan","orcid":"https://orcid.org/0009-0002-8645-219X"},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":true,"raw_author_name":"QUAN PHAN","raw_affiliation_strings":["Department of Computer Science, Katholieke Universiteit Leuven Celestijnenlaan, 200A, B-3001 Leuven, Belgium (e-mail:","Katholieke Universiteit Leuven, Celestijnenlaan"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, Katholieke Universiteit Leuven Celestijnenlaan, 200A, B-3001 Leuven, Belgium (e-mail:","institution_ids":["https://openalex.org/I99464096"]},{"raw_affiliation_string":"Katholieke Universiteit Leuven, Celestijnenlaan","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5084545304","display_name":"Gerda Janssens","orcid":null},"institutions":[{"id":"https://openalex.org/I99464096","display_name":"KU Leuven","ror":"https://ror.org/05f950310","country_code":"BE","type":"education","lineage":["https://openalex.org/I99464096"]}],"countries":["BE"],"is_corresponding":false,"raw_author_name":"GERDA JANSSENS","raw_affiliation_strings":["Department of Computer Science, Katholieke Universiteit Leuven Celestijnenlaan, 200A, B-3001 Leuven, Belgium (e-mail:","Katholieke Universiteit Leuven, Celestijnenlaan"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science, Katholieke Universiteit Leuven Celestijnenlaan, 200A, B-3001 Leuven, Belgium (e-mail:","institution_ids":["https://openalex.org/I99464096"]},{"raw_affiliation_string":"Katholieke Universiteit Leuven, Celestijnenlaan","institution_ids":["https://openalex.org/I99464096"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5082632656","display_name":"Zolt\u00e1n Somogyi","orcid":"https://orcid.org/0000-0002-3721-6513"},"institutions":[{"id":"https://openalex.org/I42894916","display_name":"Data61","ror":"https://ror.org/03q397159","country_code":"AU","type":"other","lineage":["https://openalex.org/I1292875679","https://openalex.org/I2801453606","https://openalex.org/I42894916","https://openalex.org/I4387156119"]},{"id":"https://openalex.org/I165779595","display_name":"University of Melbourne","ror":"https://ror.org/01ej9dk98","country_code":"AU","type":"education","lineage":["https://openalex.org/I165779595"]}],"countries":["AU"],"is_corresponding":false,"raw_author_name":"ZOLTAN SOMOGYI","raw_affiliation_strings":["National ICT Australia and Department of Computer Science and Software Engineering, The University of Melbourne, Victoria, 3010, Australia (e-mail:","The University of Melbourne,"],"affiliations":[{"raw_affiliation_string":"National ICT Australia and Department of Computer Science and Software Engineering, The University of Melbourne, Victoria, 3010, Australia (e-mail:","institution_ids":["https://openalex.org/I42894916","https://openalex.org/I165779595"]},{"raw_affiliation_string":"The University of Melbourne,","institution_ids":["https://openalex.org/I165779595"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5012278270"],"corresponding_institution_ids":["https://openalex.org/I99464096"],"apc_list":null,"apc_paid":null,"fwci":0.4281,"has_fulltext":false,"cited_by_count":1,"citation_normalized_percentile":{"value":0.71243027,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":"13","issue":"6","first_page":"959","last_page":"1024"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9997000098228455,"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/T10126","display_name":"Logic, programming, and type systems","score":0.9997000098228455,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9995999932289124,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.998199999332428,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8928630352020264},{"id":"https://openalex.org/keywords/mercury","display_name":"Mercury (programming language)","score":0.6141167283058167},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6059757471084595},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.535463273525238},{"id":"https://openalex.org/keywords/backtracking","display_name":"Backtracking","score":0.5322330594062805},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.4871968626976013},{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.44202321767807007},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.4212581515312195}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8928630352020264},{"id":"https://openalex.org/C2777777548","wikidata":"https://www.wikidata.org/wiki/Q206040","display_name":"Mercury (programming language)","level":2,"score":0.6141167283058167},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6059757471084595},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.535463273525238},{"id":"https://openalex.org/C156884757","wikidata":"https://www.wikidata.org/wiki/Q798554","display_name":"Backtracking","level":2,"score":0.5322330594062805},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.4871968626976013},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.44202321767807007},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.4212581515312195}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1017/s1471068412000075","is_oa":false,"landing_page_url":"https://doi.org/10.1017/s1471068412000075","pdf_url":null,"source":{"id":"https://openalex.org/S59670734","display_name":"Theory and Practice of Logic Programming","issn_l":"1471-0684","issn":["1471-0684","1475-3081"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Theory and Practice of Logic Programming","raw_type":"journal-article"},{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/316452","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/316452","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":"Theory and Practice of Logic Programming, vol. 13 (6), Art.No. doi = \"10.1017/S1471068412000075\", (959-1024)","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"pmh:oai:lirias2repo.kuleuven.be:123456789/316452","is_oa":true,"landing_page_url":"https://lirias.kuleuven.be/handle/123456789/316452","pdf_url":null,"source":{"id":"https://openalex.org/S4306401954","display_name":"Lirias (KU Leuven)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I99464096","host_organization_name":"KU Leuven","host_organization_lineage":["https://openalex.org/I99464096"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":"Theory and Practice of Logic Programming, vol. 13 (6), Art.No. doi = \"10.1017/S1471068412000075\", (959-1024)","raw_type":"info:eu-repo/semantics/publishedVersion"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":36,"referenced_works":["https://openalex.org/W132260936","https://openalex.org/W1502058785","https://openalex.org/W1519788915","https://openalex.org/W1553894716","https://openalex.org/W1570130300","https://openalex.org/W1574950491","https://openalex.org/W1710751537","https://openalex.org/W1787265089","https://openalex.org/W1975914482","https://openalex.org/W1981962444","https://openalex.org/W1982243747","https://openalex.org/W1988661738","https://openalex.org/W2005907808","https://openalex.org/W2033540531","https://openalex.org/W2035974062","https://openalex.org/W2040070287","https://openalex.org/W2074003683","https://openalex.org/W2075872176","https://openalex.org/W2087875803","https://openalex.org/W2115308418","https://openalex.org/W2121433585","https://openalex.org/W2130346658","https://openalex.org/W2131135493","https://openalex.org/W2141871141","https://openalex.org/W2152432695","https://openalex.org/W2163365446","https://openalex.org/W2166853865","https://openalex.org/W2521081842","https://openalex.org/W2911672271","https://openalex.org/W2913295241","https://openalex.org/W3111688468","https://openalex.org/W4238128231","https://openalex.org/W4247445868","https://openalex.org/W4250137633","https://openalex.org/W4256185032","https://openalex.org/W4386212917"],"related_works":["https://openalex.org/W2379153735","https://openalex.org/W2760348722","https://openalex.org/W85300993","https://openalex.org/W4252501555","https://openalex.org/W2003848320","https://openalex.org/W2009332552","https://openalex.org/W2066868279","https://openalex.org/W58529227","https://openalex.org/W60573678","https://openalex.org/W1509231339"],"abstract_inverted_index":{"Abstract":[0],"Region-based":[1],"memory":[2,11,166,268,278],"management":[3],"(RBMM)":[4],"is":[5,41,44,85],"a":[6,79,213],"form":[7],"of":[8,17,82,96,107,127,190,199,215,241,261,270],"compile":[9],"time":[10],"management,":[12],"well-known":[13,220],"from":[14],"the":[15,31,105,119,125,144,182,188,246],"world":[16],"functional":[18],"programming.":[19],"In":[20,90,272],"this":[21,91,97],"paper":[22],"we":[23,93,137],"describe":[24,194],"our":[25,128,197,208,230,274],"work":[26],"on":[27,212],"implementing":[28],"RBMM":[29,209],"for":[30,87,181,223,238],"logic":[32],"programming":[33],"language":[34,77],"Mercury.":[35],"One":[36],"interesting":[37],"point":[38],"about":[39],"Mercury":[40,58,113,232,248],"that":[42,84,103,142,170],"it":[43],"designed":[45],"with":[46,60,226,250,256],"strong":[47],"type,":[48],"mode,":[49],"and":[50,70,111,131,163,263],"determinism":[51],"systems.":[52],"These":[53],"systems":[54],"not":[55],"only":[56],"provide":[57],"programmers":[59],"several":[61],"direct":[62],"software":[63],"engineering":[64],"benefits,":[65],"such":[66],"as":[67],"self-documenting":[68],"code":[69],"clear":[71],"program":[72,88,101,129],"logic,":[73],"but":[74],"also":[75],"give":[76],"implementors":[78],"large":[80],"amount":[81],"information":[83,98],"useful":[86],"analyses.":[89],"work,":[92],"make":[94],"use":[95],"to":[99,160,185,187,245],"develop":[100],"analyses":[102,130],"determine":[104],"distribution":[106],"data":[108],"into":[109,117],"regions":[110,155,183],"transform":[112],"programs":[114],"by":[115,149],"inserting":[116],"them":[118],"necessary":[120],"region":[121],"operations.":[122],"We":[123,193,203],"prove":[124],"correctness":[126],"transformation.":[132],"To":[133],"execute":[134],"annotated":[135],"programs,":[136,217],"have":[138],"implemented":[139],"runtime":[140,253,259],"support":[141],"tackles":[143],"two":[145],"main":[146],"challenges":[147],"posed":[148],"backtracking.":[150],"First,":[151],"backtracking":[152],"can":[153],"require":[154],"removed":[156],"during":[157,168],"forward":[158],"execution":[159],"be":[161,176],"\u201cresurrected\u201d;":[162],"second,":[164],"any":[165],"allocated":[167],"computation":[169],"has":[171],"been":[172],"backtracked":[173],"over":[174],"must":[175],"recovered":[177],"promptly":[178],"without":[179],"waiting":[180],"involved":[184],"come":[186],"end":[189],"their":[191],"life.":[192],"in":[195,205,267,280],"detail":[196,206],"solution":[198],"both":[200],"these":[201,227],"problems.":[202],"study":[204],"how":[207],"system":[210,233,249,275],"performs":[211],"selection":[214],"benchmark":[216],"including":[218],"some":[219,281],"difficult":[221,228],"cases":[222],"RBMM.":[224],"Even":[225],"cases,":[229],"RBMM-enabled":[231],"obtains":[234],"clearly":[235],"faster":[236],"runtimes":[237],"15":[239],"out":[240],"18":[242],"benchmarks":[243],"compared":[244],"base":[247],"its":[251],"Boehm":[252],"garbage":[254],"collector,":[255],"an":[257,264],"average":[258,265],"speedup":[260],"24%,":[262],"reduction":[266],"requirements":[269],"95%.":[271],"fact,":[273],"achieves":[276],"optimal":[277],"consumption":[279],"programs.":[282]},"counts_by_year":[{"year":2015,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
