{"id":"https://openalex.org/W2889514531","doi":"https://doi.org/10.1145/3237009.3237026","title":"Specializing ropes for ruby","display_name":"Specializing ropes for ruby","publication_year":2018,"publication_date":"2018-01-01","ids":{"openalex":"https://openalex.org/W2889514531","doi":"https://doi.org/10.1145/3237009.3237026","mag":"2889514531"},"language":"en","primary_location":{"id":"doi:10.1145/3237009.3237026","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3237009.3237026","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 15th International Conference on Managed Languages &amp; Runtimes - ManLang '18","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5001637106","display_name":"Kevin P. Menard","orcid":"https://orcid.org/0009-0005-4551-5555"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Kevin Menard","raw_affiliation_strings":["Oracle Labs"],"affiliations":[{"raw_affiliation_string":"Oracle Labs","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5037104076","display_name":"Chris Seaton","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Chris Seaton","raw_affiliation_strings":["Oracle Labs"],"affiliations":[{"raw_affiliation_string":"Oracle Labs","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5019646899","display_name":"Benoit Daloze","orcid":null},"institutions":[{"id":"https://openalex.org/I121883995","display_name":"Johannes Kepler University of Linz","ror":"https://ror.org/052r2xn60","country_code":"AT","type":"education","lineage":["https://openalex.org/I121883995"]}],"countries":["AT"],"is_corresponding":false,"raw_author_name":"Benoit Daloze","raw_affiliation_strings":["Johannes Kepler University Linz"],"affiliations":[{"raw_affiliation_string":"Johannes Kepler University Linz","institution_ids":["https://openalex.org/I121883995"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5001637106"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.1629,"has_fulltext":false,"cited_by_count":6,"citation_normalized_percentile":{"value":0.58657375,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"1","last_page":"7"},"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.9990000128746033,"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.9990000128746033,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9987999796867371,"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/T10260","display_name":"Software Engineering Research","score":0.9976999759674072,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/concatenation","display_name":"Concatenation (mathematics)","score":0.8661836385726929},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7976523637771606},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6727030277252197},{"id":"https://openalex.org/keywords/byte","display_name":"Byte","score":0.6453995108604431},{"id":"https://openalex.org/keywords/string","display_name":"String (physics)","score":0.63758784532547},{"id":"https://openalex.org/keywords/abstract-syntax-tree","display_name":"Abstract syntax tree","score":0.5147781372070312},{"id":"https://openalex.org/keywords/binary-tree","display_name":"Binary tree","score":0.4547831118106842},{"id":"https://openalex.org/keywords/character","display_name":"Character (mathematics)","score":0.44981318712234497},{"id":"https://openalex.org/keywords/syntax","display_name":"Syntax","score":0.4386499226093292},{"id":"https://openalex.org/keywords/tree","display_name":"Tree (set theory)","score":0.4113249182701111},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3472633957862854},{"id":"https://openalex.org/keywords/parsing","display_name":"Parsing","score":0.26370882987976074},{"id":"https://openalex.org/keywords/arithmetic","display_name":"Arithmetic","score":0.1624639630317688},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.15016835927963257},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.09059163928031921}],"concepts":[{"id":"https://openalex.org/C87619178","wikidata":"https://www.wikidata.org/wiki/Q126002","display_name":"Concatenation (mathematics)","level":2,"score":0.8661836385726929},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7976523637771606},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6727030277252197},{"id":"https://openalex.org/C43364308","wikidata":"https://www.wikidata.org/wiki/Q8799","display_name":"Byte","level":2,"score":0.6453995108604431},{"id":"https://openalex.org/C157486923","wikidata":"https://www.wikidata.org/wiki/Q1376436","display_name":"String (physics)","level":2,"score":0.63758784532547},{"id":"https://openalex.org/C58646249","wikidata":"https://www.wikidata.org/wiki/Q127380","display_name":"Abstract syntax tree","level":3,"score":0.5147781372070312},{"id":"https://openalex.org/C197855036","wikidata":"https://www.wikidata.org/wiki/Q380172","display_name":"Binary tree","level":2,"score":0.4547831118106842},{"id":"https://openalex.org/C2780861071","wikidata":"https://www.wikidata.org/wiki/Q1062934","display_name":"Character (mathematics)","level":2,"score":0.44981318712234497},{"id":"https://openalex.org/C60048249","wikidata":"https://www.wikidata.org/wiki/Q37437","display_name":"Syntax","level":2,"score":0.4386499226093292},{"id":"https://openalex.org/C113174947","wikidata":"https://www.wikidata.org/wiki/Q2859736","display_name":"Tree (set theory)","level":2,"score":0.4113249182701111},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3472633957862854},{"id":"https://openalex.org/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.26370882987976074},{"id":"https://openalex.org/C94375191","wikidata":"https://www.wikidata.org/wiki/Q11205","display_name":"Arithmetic","level":1,"score":0.1624639630317688},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.15016835927963257},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.09059163928031921},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C37914503","wikidata":"https://www.wikidata.org/wiki/Q156495","display_name":"Mathematical physics","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3237009.3237026","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3237009.3237026","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 15th International Conference on Managed Languages &amp; Runtimes - ManLang '18","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":16,"referenced_works":["https://openalex.org/W593998747","https://openalex.org/W1993335798","https://openalex.org/W2058639022","https://openalex.org/W2075675735","https://openalex.org/W2091228796","https://openalex.org/W2094269821","https://openalex.org/W2098522119","https://openalex.org/W2098575713","https://openalex.org/W2141293928","https://openalex.org/W2142947709","https://openalex.org/W2159558457","https://openalex.org/W2316143522","https://openalex.org/W2537964555","https://openalex.org/W2731881248","https://openalex.org/W2810876875","https://openalex.org/W4236519034"],"related_works":["https://openalex.org/W2373577936","https://openalex.org/W4221148444","https://openalex.org/W4387678054","https://openalex.org/W2389596151","https://openalex.org/W3095575180","https://openalex.org/W4306784355","https://openalex.org/W2169308097","https://openalex.org/W4246226292","https://openalex.org/W3091984855","https://openalex.org/W2150768546"],"abstract_inverted_index":{"Ropes":[0,17],"are":[1],"an":[2,46],"immutable":[3],"data":[4],"structure":[5],"for":[6],"representing":[7],"character":[8],"strings":[9,43,106],"via":[10],"a":[11,54],"binary":[12],"tree":[13,58],"of":[14,30,48,88,91,109],"operation-labeled":[15],"nodes.":[16],"were":[18],"designed":[19],"to":[20,40,66,77],"perform":[21,97],"well":[22],"with":[23],"large":[24,31],"strings,":[25],"and":[26,60,74,93],"in":[27,37,44,107],"particular,":[28],"concatenation":[29],"strings.":[32],"We":[33,63],"present":[34],"our":[35,89],"findings":[36],"using":[38,53],"ropes":[39,65,92],"implement":[41],"mutable":[42],"TruffleRuby,":[45],"implementation":[47,90],"the":[49,86],"Ruby":[50,68,81,111],"programming":[51],"language":[52,69],"self-specializing":[55],"abstract":[56],"syntax":[57],"interpreter":[59],"dynamic":[61],"compilation.":[62],"extend":[64],"support":[67,79],"features":[70],"such":[71],"as":[72,101,103],"encodings":[73],"refine":[75],"operations":[76],"better":[78],"typical":[80],"programs.":[82],"Finally,":[83],"we":[84],"evaluate":[85],"performance":[87],"demonstrate":[94],"that":[95],"they":[96],"0.9X":[98],"\u2212":[99],"9.4X":[100],"fast":[102],"byte":[104],"array-based":[105],"benchmarks":[108],"common":[110],"string":[112],"operations.":[113]},"counts_by_year":[{"year":2023,"cited_by_count":5},{"year":2021,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
