{"id":"https://openalex.org/W4386317173","doi":"https://doi.org/10.1145/3607842","title":"Reflecting on Random Generation","display_name":"Reflecting on Random Generation","publication_year":2023,"publication_date":"2023-08-30","ids":{"openalex":"https://openalex.org/W4386317173","doi":"https://doi.org/10.1145/3607842"},"language":"en","primary_location":{"id":"doi:10.1145/3607842","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3607842","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3607842","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://dl.acm.org/doi/pdf/10.1145/3607842","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5079995663","display_name":"Harrison Goldstein","orcid":"https://orcid.org/0000-0001-9631-1169"},"institutions":[{"id":"https://openalex.org/I36788626","display_name":"California University of Pennsylvania","ror":"https://ror.org/01spssf70","country_code":"US","type":"education","lineage":["https://openalex.org/I36788626"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Harrison Goldstein","raw_affiliation_strings":["University of Pennsylvania, USA"],"affiliations":[{"raw_affiliation_string":"University of Pennsylvania, USA","institution_ids":["https://openalex.org/I36788626"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5002750827","display_name":"Samantha Frohlich","orcid":"https://orcid.org/0000-0002-4423-6918"},"institutions":[{"id":"https://openalex.org/I36234482","display_name":"University of Bristol","ror":"https://ror.org/0524sp257","country_code":"GB","type":"education","lineage":["https://openalex.org/I36234482"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Samantha Frohlich","raw_affiliation_strings":["University of Bristol, UK"],"affiliations":[{"raw_affiliation_string":"University of Bristol, UK","institution_ids":["https://openalex.org/I36234482"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5074307489","display_name":"Meng Wang","orcid":"https://orcid.org/0000-0001-7780-630X"},"institutions":[{"id":"https://openalex.org/I36234482","display_name":"University of Bristol","ror":"https://ror.org/0524sp257","country_code":"GB","type":"education","lineage":["https://openalex.org/I36234482"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Meng Wang","raw_affiliation_strings":["University of Bristol, UK"],"affiliations":[{"raw_affiliation_string":"University of Bristol, UK","institution_ids":["https://openalex.org/I36234482"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5085361253","display_name":"Benjamin C. Pierce","orcid":"https://orcid.org/0000-0001-7839-1636"},"institutions":[{"id":"https://openalex.org/I36788626","display_name":"California University of Pennsylvania","ror":"https://ror.org/01spssf70","country_code":"US","type":"education","lineage":["https://openalex.org/I36788626"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Benjamin C. Pierce","raw_affiliation_strings":["University of Pennsylvania, USA"],"affiliations":[{"raw_affiliation_string":"University of Pennsylvania, USA","institution_ids":["https://openalex.org/I36788626"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5079995663"],"corresponding_institution_ids":["https://openalex.org/I36788626"],"apc_list":null,"apc_paid":null,"fwci":1.9375,"has_fulltext":true,"cited_by_count":9,"citation_normalized_percentile":{"value":0.91097761,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":96,"max":98},"biblio":{"volume":"7","issue":"ICFP","first_page":"322","last_page":"355"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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.9972000122070312,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/python","display_name":"Python (programming language)","score":0.789402425289154},{"id":"https://openalex.org/keywords/generator","display_name":"Generator (circuit theory)","score":0.7362958192825317},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7134920358657837},{"id":"https://openalex.org/keywords/random-testing","display_name":"Random testing","score":0.5524345636367798},{"id":"https://openalex.org/keywords/random-number-generation","display_name":"Random number generation","score":0.5288299918174744},{"id":"https://openalex.org/keywords/trace","display_name":"TRACE (psycholinguistics)","score":0.48202788829803467},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.4501292407512665},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.37619537115097046},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.323943555355072},{"id":"https://openalex.org/keywords/test-case","display_name":"Test case","score":0.3232089877128601},{"id":"https://openalex.org/keywords/machine-learning","display_name":"Machine learning","score":0.20562690496444702},{"id":"https://openalex.org/keywords/power","display_name":"Power (physics)","score":0.08562541007995605}],"concepts":[{"id":"https://openalex.org/C519991488","wikidata":"https://www.wikidata.org/wiki/Q28865","display_name":"Python (programming language)","level":2,"score":0.789402425289154},{"id":"https://openalex.org/C2780992000","wikidata":"https://www.wikidata.org/wiki/Q17016113","display_name":"Generator (circuit theory)","level":3,"score":0.7362958192825317},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7134920358657837},{"id":"https://openalex.org/C106159264","wikidata":"https://www.wikidata.org/wiki/Q17146789","display_name":"Random testing","level":4,"score":0.5524345636367798},{"id":"https://openalex.org/C201866948","wikidata":"https://www.wikidata.org/wiki/Q228206","display_name":"Random number generation","level":2,"score":0.5288299918174744},{"id":"https://openalex.org/C75291252","wikidata":"https://www.wikidata.org/wiki/Q1315756","display_name":"TRACE (psycholinguistics)","level":2,"score":0.48202788829803467},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.4501292407512665},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.37619537115097046},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.323943555355072},{"id":"https://openalex.org/C128942645","wikidata":"https://www.wikidata.org/wiki/Q1568346","display_name":"Test case","level":3,"score":0.3232089877128601},{"id":"https://openalex.org/C119857082","wikidata":"https://www.wikidata.org/wiki/Q2539","display_name":"Machine learning","level":1,"score":0.20562690496444702},{"id":"https://openalex.org/C163258240","wikidata":"https://www.wikidata.org/wiki/Q25342","display_name":"Power (physics)","level":2,"score":0.08562541007995605},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C41895202","wikidata":"https://www.wikidata.org/wiki/Q8162","display_name":"Linguistics","level":1,"score":0.0},{"id":"https://openalex.org/C152877465","wikidata":"https://www.wikidata.org/wiki/Q208042","display_name":"Regression analysis","level":2,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3607842","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3607842","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3607842","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:research-information.bris.ac.uk:openaire_cris_publications/f6739da0-6798-4e43-a8df-87df7c731e59","is_oa":true,"landing_page_url":"https://research-information.bris.ac.uk/en/publications/f6739da0-6798-4e43-a8df-87df7c731e59","pdf_url":null,"source":{"id":"https://openalex.org/S7407055359","display_name":"Explore Bristol Research","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Goldstein, H, Frohlich, S, Wang, M & Pierce, B 2023, 'Reflecting on Random Generation', Proceedings of the ACM on Programming Languages, vol. 7, no. ICFP, 200, pp. 322\u2013355. https://doi.org/10.1145/3607842","raw_type":"info:eu-repo/semantics/publishedVersion"},{"id":"pmh:oai:research-information.bris.ac.uk:publications/f6739da0-6798-4e43-a8df-87df7c731e59","is_oa":true,"landing_page_url":"https://hdl.handle.net/1983/f6739da0-6798-4e43-a8df-87df7c731e59","pdf_url":null,"source":{"id":"https://openalex.org/S4306400895","display_name":"Bristol Research (University of Bristol)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I36234482","host_organization_name":"University of Bristol","host_organization_lineage":["https://openalex.org/I36234482"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Goldstein, H, Frohlich, S, Wang, M & Pierce, B 2023, 'Reflecting on Random Generation', Proceedings of the ACM on Programming Languages, vol. 7, no. ICFP, 200, pp. 322\u2013355. https://doi.org/10.1145/3607842","raw_type":"info:eu-repo/semantics/publishedVersion"}],"best_oa_location":{"id":"doi:10.1145/3607842","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3607842","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3607842","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":[{"id":"https://metadata.un.org/sdg/8","display_name":"Decent work and economic growth","score":0.7200000286102295}],"awards":[{"id":"https://openalex.org/G2090296422","display_name":null,"funder_award_id":"1421243","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G3330119427","display_name":null,"funder_award_id":"EPSRC","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G3892558182","display_name":"EXHIBIT : Expressive High-Level Languages for Bidirectional Transformations","funder_award_id":"EP/T008911/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G6080364906","display_name":null,"funder_award_id":"1521523","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G7583192215","display_name":null,"funder_award_id":"EP/T008911/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G8452545418","display_name":null,"funder_award_id":"unknown","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G848032724","display_name":null,"funder_award_id":"Science","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320309370","display_name":"University of Pennsylvania","ror":"https://ror.org/00b30xv10"},{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4386317173.pdf","grobid_xml":"https://content.openalex.org/works/W4386317173.grobid-xml"},"referenced_works_count":34,"referenced_works":["https://openalex.org/W1489879801","https://openalex.org/W1595372275","https://openalex.org/W1947245809","https://openalex.org/W1965555277","https://openalex.org/W1997143185","https://openalex.org/W2017114730","https://openalex.org/W2054969282","https://openalex.org/W2065948900","https://openalex.org/W2123835026","https://openalex.org/W2125126351","https://openalex.org/W2146950091","https://openalex.org/W2295266283","https://openalex.org/W2519952770","https://openalex.org/W2583649498","https://openalex.org/W2727386241","https://openalex.org/W2886363898","https://openalex.org/W2899781671","https://openalex.org/W2925654996","https://openalex.org/W2963350015","https://openalex.org/W2990912491","https://openalex.org/W3005412812","https://openalex.org/W3005608680","https://openalex.org/W3021104605","https://openalex.org/W3047259347","https://openalex.org/W3109017117","https://openalex.org/W3109272827","https://openalex.org/W3180202404","https://openalex.org/W3185065804","https://openalex.org/W3186138910","https://openalex.org/W4243922950","https://openalex.org/W4244488020","https://openalex.org/W4251631464","https://openalex.org/W4281705085","https://openalex.org/W4307886652"],"related_works":["https://openalex.org/W2147116815","https://openalex.org/W2128688132","https://openalex.org/W4289256071","https://openalex.org/W2096205671","https://openalex.org/W4249105153","https://openalex.org/W2164263318","https://openalex.org/W4313324923","https://openalex.org/W1503711153","https://openalex.org/W1524918397","https://openalex.org/W139286382"],"abstract_inverted_index":{"Expert":[0],"users":[1],"of":[2,31,158,191],"property-based":[3],"testing":[4],"often":[5],"labor":[6,33],"to":[7,23,38,96,106,127,139],"craft":[8],"random":[9,86,99],"generators":[10,48,88,110,118,169],"that":[11,89,101,144],"encode":[12],"detailed":[13],"knowledge":[14],"about":[15],"what":[16],"it":[17],"means":[18],"for":[19,46,63,85,141,154,174],"a":[20,82,156,171],"test":[21,67,192],"input":[22,94],"be":[24,36,125,146,181],"valid":[25],"and":[26,65,71,75,119,129,134,166,177,188],"interesting.":[27],"Fortunately,":[28],"the":[29,42,60,98,131,149,159],"fruits":[30],"this":[32],"can":[34,90,124,145,179],"also":[35,180],"put":[37],"other":[39,189],"uses.":[40],"In":[41],"bidirectional":[43],"programming":[44],"literature,":[45],"example,":[47],"have":[49,103],"been":[50,104],"repurposed":[51],"as":[52,183],"validity":[53],"checkers,":[54,184],"while":[55],"Python's":[56],"Hypothesis":[57],"library":[58],"uses":[59,74],"same":[61],"structures":[62],"shrinking":[64,133,165],"mutating":[66],"inputs.":[68],"To":[69],"unify":[70],"generalize":[72,170],"these":[73],"many":[76],"others,":[77],"we":[78],"propose":[79],"reflective":[80,168],"generators,":[81],"new":[83],"foundation":[84],"data":[87,193],"\"reflect\"":[91],"on":[92],"an":[93],"value":[95,186],"calculate":[97],"choices":[100],"could":[102],"made":[105],"produce":[107],"it.":[108],"Reflective":[109],"combine":[111],"ideas":[112],"from":[113],"two":[114],"existing":[115],"abstractions:":[116],"free":[117],"partial":[120,185],"monadic":[121],"profunctors.":[122],"They":[123],"used":[126,182],"implement":[128],"enhance":[130],"aforementioned":[132],"mutation":[135],"algorithms,":[136],"generalizing":[137],"them":[138],"work":[140],"any":[142],"values":[143],"produced":[147],"by":[148],"generator,":[150],"not":[151],"just":[152],"ones":[153],"which":[155],"trace":[157],"generator's":[160],"execution":[161],"is":[162],"available.":[163],"Beyond":[164],"mutation,":[167],"published":[172],"algorithm":[173],"example-based":[175],"generation,":[176],"they":[178],"completers,":[187],"kinds":[190],"producers.":[194]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3},{"year":2024,"cited_by_count":5}],"updated_date":"2026-04-11T08:14:18.477133","created_date":"2025-10-10T00:00:00"}
