{"id":"https://openalex.org/W3151202736","doi":"https://doi.org/10.1007/978-3-030-72016-2_9","title":"FOREST: An Interactive Multi-tree Synthesizer for Regular Expressions","display_name":"FOREST: An Interactive Multi-tree Synthesizer for Regular Expressions","publication_year":2021,"publication_date":"2021-01-01","ids":{"openalex":"https://openalex.org/W3151202736","doi":"https://doi.org/10.1007/978-3-030-72016-2_9","mag":"3151202736"},"language":"en","primary_location":{"id":"doi:10.1007/978-3-030-72016-2_9","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-030-72016-2_9","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-030-72016-2_9.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"},"type":"book-chapter","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://link.springer.com/content/pdf/10.1007/978-3-030-72016-2_9.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5105003367","display_name":"Margarida A. Ferreira","orcid":"https://orcid.org/0000-0001-8773-5242"},"institutions":[{"id":"https://openalex.org/I121345201","display_name":"Instituto de Engenharia de Sistemas e Computadores Investiga\u00e7\u00e3o e Desenvolvimento","ror":"https://ror.org/04mqy3p58","country_code":"PT","type":"nonprofit","lineage":["https://openalex.org/I121345201","https://openalex.org/I4210125590"]},{"id":"https://openalex.org/I141596103","display_name":"University of Lisbon","ror":"https://ror.org/01c27hj86","country_code":"PT","type":"education","lineage":["https://openalex.org/I141596103"]}],"countries":["PT"],"is_corresponding":true,"raw_author_name":"Margarida Ferreira","raw_affiliation_strings":["INESC-ID,Instituto Superior T\u00e9cnico, Universidade de Lisboa, Lisbon, Portugal","OutSystems, Linda-a-Velha, Portugal"],"affiliations":[{"raw_affiliation_string":"INESC-ID,Instituto Superior T\u00e9cnico, Universidade de Lisboa, Lisbon, Portugal","institution_ids":["https://openalex.org/I121345201","https://openalex.org/I141596103"]},{"raw_affiliation_string":"OutSystems, Linda-a-Velha, Portugal","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5018333103","display_name":"Miguel Terra-Neves","orcid":"https://orcid.org/0000-0003-4089-7206"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Miguel Terra-Neves","raw_affiliation_strings":["OutSystems, Linda-a-Velha, Portugal"],"affiliations":[{"raw_affiliation_string":"OutSystems, Linda-a-Velha, Portugal","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5065074033","display_name":"Miguel Ventura","orcid":"https://orcid.org/0000-0002-4233-1348"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Miguel Ventura","raw_affiliation_strings":["OutSystems, Linda-a-Velha, Portugal"],"affiliations":[{"raw_affiliation_string":"OutSystems, Linda-a-Velha, Portugal","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5058622165","display_name":"In\u00eas Lynce","orcid":"https://orcid.org/0000-0003-4868-415X"},"institutions":[{"id":"https://openalex.org/I121345201","display_name":"Instituto de Engenharia de Sistemas e Computadores Investiga\u00e7\u00e3o e Desenvolvimento","ror":"https://ror.org/04mqy3p58","country_code":"PT","type":"nonprofit","lineage":["https://openalex.org/I121345201","https://openalex.org/I4210125590"]},{"id":"https://openalex.org/I141596103","display_name":"University of Lisbon","ror":"https://ror.org/01c27hj86","country_code":"PT","type":"education","lineage":["https://openalex.org/I141596103"]}],"countries":["PT"],"is_corresponding":false,"raw_author_name":"In\u00eas Lynce","raw_affiliation_strings":["INESC-ID,Instituto Superior T\u00e9cnico, Universidade de Lisboa, Lisbon, Portugal"],"affiliations":[{"raw_affiliation_string":"INESC-ID,Instituto Superior T\u00e9cnico, Universidade de Lisboa, Lisbon, Portugal","institution_ids":["https://openalex.org/I121345201","https://openalex.org/I141596103"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5101995804","display_name":"Ruben Martins","orcid":"https://orcid.org/0000-0003-1525-1382"},"institutions":[{"id":"https://openalex.org/I74973139","display_name":"Carnegie Mellon University","ror":"https://ror.org/05x2bcf33","country_code":"US","type":"education","lineage":["https://openalex.org/I74973139"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ruben Martins","raw_affiliation_strings":["Carnegie Mellon University, Pittsburgh, USA"],"affiliations":[{"raw_affiliation_string":"Carnegie Mellon University, Pittsburgh, USA","institution_ids":["https://openalex.org/I74973139"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5105003367"],"corresponding_institution_ids":["https://openalex.org/I121345201","https://openalex.org/I141596103"],"apc_list":{"value":5000,"currency":"EUR","value_usd":5392},"apc_paid":{"value":5000,"currency":"EUR","value_usd":5392},"fwci":2.0733,"has_fulltext":true,"cited_by_count":6,"citation_normalized_percentile":{"value":0.85580774,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"152","last_page":"169"},"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.9997000098228455,"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.9997000098228455,"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/T10181","display_name":"Natural Language Processing Techniques","score":0.9973999857902527,"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/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.9970999956130981,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/regular-expression","display_name":"Regular expression","score":0.7350343465805054},{"id":"https://openalex.org/keywords/satisfiability-modulo-theories","display_name":"Satisfiability modulo theories","score":0.6745809316635132},{"id":"https://openalex.org/keywords/modulo","display_name":"Modulo","score":0.6646223664283752},{"id":"https://openalex.org/keywords/expression","display_name":"Expression (computer science)","score":0.6637744903564453},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.6422410011291504},{"id":"https://openalex.org/keywords/tree","display_name":"Tree (set theory)","score":0.5793885588645935},{"id":"https://openalex.org/keywords/representation","display_name":"Representation (politics)","score":0.5787609219551086},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.5404092073440552},{"id":"https://openalex.org/keywords/integer","display_name":"Integer (computer science)","score":0.475027859210968},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.44352322816848755},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.3941369652748108},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.23515847325325012},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.20759710669517517},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.10688695311546326},{"id":"https://openalex.org/keywords/combinatorics","display_name":"Combinatorics","score":0.06136766076087952}],"concepts":[{"id":"https://openalex.org/C121329065","wikidata":"https://www.wikidata.org/wiki/Q185612","display_name":"Regular expression","level":2,"score":0.7350343465805054},{"id":"https://openalex.org/C164155591","wikidata":"https://www.wikidata.org/wiki/Q2067766","display_name":"Satisfiability modulo theories","level":2,"score":0.6745809316635132},{"id":"https://openalex.org/C54732982","wikidata":"https://www.wikidata.org/wiki/Q1415345","display_name":"Modulo","level":2,"score":0.6646223664283752},{"id":"https://openalex.org/C90559484","wikidata":"https://www.wikidata.org/wiki/Q778379","display_name":"Expression (computer science)","level":2,"score":0.6637744903564453},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.6422410011291504},{"id":"https://openalex.org/C113174947","wikidata":"https://www.wikidata.org/wiki/Q2859736","display_name":"Tree (set theory)","level":2,"score":0.5793885588645935},{"id":"https://openalex.org/C2776359362","wikidata":"https://www.wikidata.org/wiki/Q2145286","display_name":"Representation (politics)","level":3,"score":0.5787609219551086},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.5404092073440552},{"id":"https://openalex.org/C97137487","wikidata":"https://www.wikidata.org/wiki/Q729138","display_name":"Integer (computer science)","level":2,"score":0.475027859210968},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.44352322816848755},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3941369652748108},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.23515847325325012},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.20759710669517517},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.10688695311546326},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.06136766076087952},{"id":"https://openalex.org/C199539241","wikidata":"https://www.wikidata.org/wiki/Q7748","display_name":"Law","level":1,"score":0.0},{"id":"https://openalex.org/C17744445","wikidata":"https://www.wikidata.org/wiki/Q36442","display_name":"Political science","level":0,"score":0.0},{"id":"https://openalex.org/C94625758","wikidata":"https://www.wikidata.org/wiki/Q7163","display_name":"Politics","level":2,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1007/978-3-030-72016-2_9","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-030-72016-2_9","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-030-72016-2_9.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"},{"id":"pmh:oai:pubmedcentral.nih.gov:7979175","is_oa":true,"landing_page_url":"https://www.ncbi.nlm.nih.gov/pmc/articles/7979175","pdf_url":null,"source":{"id":"https://openalex.org/S2764455111","display_name":"PubMed Central","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1299303238","host_organization_name":"National Institutes of Health","host_organization_lineage":["https://openalex.org/I1299303238"],"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":"Tools and Algorithms for the Construction and Analysis of Systems","raw_type":"Text"}],"best_oa_location":{"id":"doi:10.1007/978-3-030-72016-2_9","is_oa":true,"landing_page_url":"https://doi.org/10.1007/978-3-030-72016-2_9","pdf_url":"https://link.springer.com/content/pdf/10.1007/978-3-030-72016-2_9.pdf","source":{"id":"https://openalex.org/S106296714","display_name":"Lecture notes in computer science","issn_l":"0302-9743","issn":["0302-9743","1611-3349"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"book series"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Lecture Notes in Computer Science","raw_type":"book-chapter"},"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/15","score":0.7200000286102295,"display_name":"Life in Land"}],"awards":[{"id":"https://openalex.org/G1886981331","display_name":null,"funder_award_id":"project UID","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G2441341484","display_name":null,"funder_award_id":"UIDB/50021/2020","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G3272457656","display_name":null,"funder_award_id":"UIDB/","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G5348594205","display_name":null,"funder_award_id":"FEDER","funder_id":"https://openalex.org/F4320334779","funder_display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia"},{"id":"https://openalex.org/G7858740741","display_name":"SHF: Medium: Collaborative Research: Computer-Aided Programming for Data Science","funder_award_id":"1762363","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/F4320334779","display_name":"Funda\u00e7\u00e3o para a Ci\u00eancia e a Tecnologia","ror":"https://ror.org/00snfqn58"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W3151202736.pdf","grobid_xml":"https://content.openalex.org/works/W3151202736.grobid-xml"},"referenced_works_count":31,"referenced_works":["https://openalex.org/W1480909796","https://openalex.org/W1791762382","https://openalex.org/W2132525863","https://openalex.org/W2175619924","https://openalex.org/W2275996142","https://openalex.org/W2288434693","https://openalex.org/W2531982678","https://openalex.org/W2536870052","https://openalex.org/W2550471858","https://openalex.org/W2587580284","https://openalex.org/W2612337100","https://openalex.org/W2626990892","https://openalex.org/W2768510408","https://openalex.org/W2890260889","https://openalex.org/W2953054522","https://openalex.org/W2956992268","https://openalex.org/W2964240296","https://openalex.org/W2964284687","https://openalex.org/W2968700020","https://openalex.org/W2971324190","https://openalex.org/W2973690622","https://openalex.org/W2974467477","https://openalex.org/W3011649674","https://openalex.org/W3033889389","https://openalex.org/W3046767532","https://openalex.org/W3048452377","https://openalex.org/W3082233550","https://openalex.org/W3084910657","https://openalex.org/W3173665653","https://openalex.org/W3192343331","https://openalex.org/W4255584681"],"related_works":["https://openalex.org/W2070252991","https://openalex.org/W2807449856","https://openalex.org/W238211858","https://openalex.org/W2941201715","https://openalex.org/W2196131019","https://openalex.org/W2112041331","https://openalex.org/W2810367355","https://openalex.org/W2131919998","https://openalex.org/W4287547960","https://openalex.org/W3151202736"],"abstract_inverted_index":{"Abstract":[0],"Form":[1],"validators":[2,26],"based":[3,82,156],"on":[4,10,83,157,163],"regular":[5,39,49,107,142,150,168,179,192],"expressions":[6,108],"are":[7],"often":[8],"used":[9],"digital":[11,43],"forms":[12],"to":[13,31,94,120,135],"prevent":[14],"users":[15],"from":[16],"inserting":[17],"data":[18],"in":[19,75,114,147,181],"the":[20,53,57,70,76,98,115,122,148,177,184],"wrong":[21],"format.":[22],"However,":[23],"writing":[24],"these":[25],"can":[27],"pose":[28],"a":[29,38,48,61,88,103,125,131,140,190],"challenge":[30],"some":[32],"users.":[33],"We":[34,101,128,160],"present":[35,130],"Forest":[36,46,162,174],",":[37,189],"expression":[40,50,180,193],"synthesizer":[41],"for":[42,56,106,139],"form":[44],"validations.":[45],"produces":[47],"that":[51,68,173],"matches":[52],"desired":[54,178],"pattern":[55],"input":[58],"values":[59,74],"and":[60,86,96,117,186],"set":[62],"of":[63,72,183],"conditions":[64,138],"over":[65],"capturing":[66],"groups":[67],"ensure":[69],"validity":[71],"integer":[73],"input.":[77],"Our":[78],"synthesis":[79],"procedure":[80],"is":[81],"enumerative":[84],"search":[85,99],"uses":[87,118],"Satisfiability":[89],"Modulo":[90],"Theories":[91],"(SMT)":[92],"solver":[93],"explore":[95],"prune":[97],"space.":[100],"propose":[102],"novel":[104],"representation":[105],"synthesis,":[109],"multi-tree,":[110],"which":[111],"induces":[112],"patterns":[113],"examples":[116],"them":[119],"split":[121],"problem":[123],"through":[124],"divide-and-conquer":[126],"approach.":[127],"also":[129],"new":[132],"SMT":[133],"encoding":[134],"synthesize":[136],"capture":[137],"given":[141],"expression.":[143],"To":[144],"increase":[145],"confidence":[146],"synthesized":[149],"expression,":[151],"we":[152],"implement":[153],"user":[154],"interaction":[155],"distinguishing":[158],"inputs.":[159],"evaluated":[161],"real-world":[164],"form-validation":[165],"instances":[166,185],"using":[167],"expressions.":[169],"Experimental":[170],"results":[171],"show":[172],"successfully":[175],"returns":[176],"70%":[182],"outperforms":[187],"Regel":[188],"state-of-the-art":[191],"synthesizer.":[194]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1}],"updated_date":"2026-03-20T23:20:44.827607","created_date":"2025-10-10T00:00:00"}
