{"id":"https://openalex.org/W2789864968","doi":"https://doi.org/10.1145/3196321.3196349","title":"Identifying software components from object-oriented APIs based on dynamic analysis","display_name":"Identifying software components from object-oriented APIs based on dynamic analysis","publication_year":2018,"publication_date":"2018-05-28","ids":{"openalex":"https://openalex.org/W2789864968","doi":"https://doi.org/10.1145/3196321.3196349","mag":"2789864968"},"language":"en","primary_location":{"id":"doi:10.1145/3196321.3196349","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3196321.3196349","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 26th Conference on Program Comprehension","raw_type":"proceedings-article"},"type":"article","indexed_in":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://arxiv.org/pdf/1803.06235","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"Anas Shatnawi","orcid":null},"institutions":[{"id":"https://openalex.org/I66752286","display_name":"University of Milano-Bicocca","ror":"https://ror.org/01ynf4891","country_code":"IT","type":"education","lineage":["https://openalex.org/I66752286"]}],"countries":["IT"],"is_corresponding":true,"raw_author_name":"Anas Shatnawi","raw_affiliation_strings":["University of Milan-Bicocca, Milan, Italy"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Milan-Bicocca, Milan, Italy","institution_ids":["https://openalex.org/I66752286"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Hudhaifa Shatnawi","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Hudhaifa Shatnawi","raw_affiliation_strings":["Maharishi University of Management"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Maharishi University of Management","institution_ids":[]}]},{"author_position":"middle","author":{"id":null,"display_name":"Mohamed Aymen Saied","orcid":null},"institutions":[{"id":"https://openalex.org/I60158472","display_name":"Concordia University","ror":"https://ror.org/0420zvk78","country_code":"CA","type":"education","lineage":["https://openalex.org/I60158472"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Mohamed Aymen Saied","raw_affiliation_strings":["Concordia University, Montreal, Quebec, Canada"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Concordia University, Montreal, Quebec, Canada","institution_ids":["https://openalex.org/I60158472"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Zakarea Al Shara","orcid":null},"institutions":[{"id":"https://openalex.org/I19894307","display_name":"Universit\u00e9 de Montpellier","ror":"https://ror.org/051escj72","country_code":"FR","type":"education","lineage":["https://openalex.org/I19894307"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Zakarea Al Shara","raw_affiliation_strings":["University of Montpellier, Montpellier, France"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Montpellier, Montpellier, France","institution_ids":["https://openalex.org/I19894307"]}]},{"author_position":"middle","author":{"id":null,"display_name":"Houari Sahraoui","orcid":null},"institutions":[{"id":"https://openalex.org/I70931966","display_name":"Universit\u00e9 de Montr\u00e9al","ror":"https://ror.org/0161xgx34","country_code":"CA","type":"education","lineage":["https://openalex.org/I70931966"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Houari Sahraoui","raw_affiliation_strings":["University of Montreal, Montreal, Quebec, Canada"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Montreal, Montreal, Quebec, Canada","institution_ids":["https://openalex.org/I70931966"]}]},{"author_position":"last","author":{"id":null,"display_name":"Abdelhak Seriai","orcid":null},"institutions":[{"id":"https://openalex.org/I19894307","display_name":"Universit\u00e9 de Montpellier","ror":"https://ror.org/051escj72","country_code":"FR","type":"education","lineage":["https://openalex.org/I19894307"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Abdelhak Seriai","raw_affiliation_strings":["University of Montpellier, Montpellier, France"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Montpellier, Montpellier, France","institution_ids":["https://openalex.org/I19894307"]}]}],"institutions":[],"countries_distinct_count":3,"institutions_distinct_count":6,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I66752286"],"apc_list":null,"apc_paid":null,"fwci":3.2885,"has_fulltext":false,"cited_by_count":14,"citation_normalized_percentile":{"value":0.9343131,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"189","last_page":"199"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9994000196456909,"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"}},"topics":[{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9994000196456909,"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"}},{"id":"https://openalex.org/T12127","display_name":"Software System Performance and Reliability","score":0.9918000102043152,"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/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9890999794006348,"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/component","display_name":"Component (thermodynamics)","score":0.7235000133514404},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.7038999795913696},{"id":"https://openalex.org/keywords/granularity","display_name":"Granularity","score":0.588100016117096},{"id":"https://openalex.org/keywords/identification","display_name":"Identification (biology)","score":0.5874999761581421},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.5730999708175659},{"id":"https://openalex.org/keywords/component-based-software-engineering","display_name":"Component-based software engineering","score":0.5472999811172485},{"id":"https://openalex.org/keywords/class","display_name":"Class (philosophy)","score":0.5361999869346619},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.5095999836921692}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8407999873161316},{"id":"https://openalex.org/C168167062","wikidata":"https://www.wikidata.org/wiki/Q1117970","display_name":"Component (thermodynamics)","level":2,"score":0.7235000133514404},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.7038999795913696},{"id":"https://openalex.org/C177774035","wikidata":"https://www.wikidata.org/wiki/Q1246948","display_name":"Granularity","level":2,"score":0.588100016117096},{"id":"https://openalex.org/C116834253","wikidata":"https://www.wikidata.org/wiki/Q2039217","display_name":"Identification (biology)","level":2,"score":0.5874999761581421},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.5730999708175659},{"id":"https://openalex.org/C174683762","wikidata":"https://www.wikidata.org/wiki/Q609588","display_name":"Component-based software engineering","level":4,"score":0.5472999811172485},{"id":"https://openalex.org/C2777212361","wikidata":"https://www.wikidata.org/wiki/Q5127848","display_name":"Class (philosophy)","level":2,"score":0.5361999869346619},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.5095999836921692},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.4885999858379364},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.4496999979019165},{"id":"https://openalex.org/C124101348","wikidata":"https://www.wikidata.org/wiki/Q172491","display_name":"Data mining","level":1,"score":0.4287000000476837},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.3887999951839447},{"id":"https://openalex.org/C76518257","wikidata":"https://www.wikidata.org/wiki/Q271680","display_name":"Software framework","level":5,"score":0.32350000739097595},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.32019999623298645},{"id":"https://openalex.org/C149091818","wikidata":"https://www.wikidata.org/wiki/Q2429814","display_name":"Software system","level":3,"score":0.31940001249313354},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3165000081062317},{"id":"https://openalex.org/C113843644","wikidata":"https://www.wikidata.org/wiki/Q901882","display_name":"Interface (matter)","level":4,"score":0.31349998712539673},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.30379998683929443},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.30079999566078186},{"id":"https://openalex.org/C1009929","wikidata":"https://www.wikidata.org/wiki/Q179550","display_name":"Software bug","level":3,"score":0.29120001196861267},{"id":"https://openalex.org/C99613125","wikidata":"https://www.wikidata.org/wiki/Q165194","display_name":"Application programming interface","level":2,"score":0.28839999437332153},{"id":"https://openalex.org/C2984968299","wikidata":"https://www.wikidata.org/wiki/Q1077784","display_name":"Software tool","level":3,"score":0.2786000072956085},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.2702000141143799},{"id":"https://openalex.org/C101317890","wikidata":"https://www.wikidata.org/wiki/Q940053","display_name":"Software maintenance","level":4,"score":0.2583000063896179}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3196321.3196349","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3196321.3196349","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 26th Conference on Program Comprehension","raw_type":"proceedings-article"},{"id":"pmh:oai:arXiv.org:1803.06235","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1803.06235","pdf_url":"https://arxiv.org/pdf/1803.06235","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},{"id":"pmh:oai:HAL:lirmm-01932804v1","is_oa":false,"landing_page_url":"https://hal-lirmm.ccsd.cnrs.fr/lirmm-01932804","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"https://conf.researchr.org/home/icpc-2018","raw_type":"Conference papers"}],"best_oa_location":{"id":"pmh:oai:arXiv.org:1803.06235","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1803.06235","pdf_url":"https://arxiv.org/pdf/1803.06235","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":32,"referenced_works":["https://openalex.org/W63474583","https://openalex.org/W302904365","https://openalex.org/W1743635611","https://openalex.org/W1986223934","https://openalex.org/W1986839693","https://openalex.org/W1991613282","https://openalex.org/W2003876621","https://openalex.org/W2043791485","https://openalex.org/W2044527216","https://openalex.org/W2046835698","https://openalex.org/W2046867620","https://openalex.org/W2048668881","https://openalex.org/W2052657693","https://openalex.org/W2064113309","https://openalex.org/W2064909362","https://openalex.org/W2101345573","https://openalex.org/W2102830428","https://openalex.org/W2115513993","https://openalex.org/W2121066518","https://openalex.org/W2125172975","https://openalex.org/W2151181659","https://openalex.org/W2166091242","https://openalex.org/W2398208853","https://openalex.org/W2469414321","https://openalex.org/W2501770979","https://openalex.org/W2546599611","https://openalex.org/W2604655775","https://openalex.org/W2614718149","https://openalex.org/W2727421303","https://openalex.org/W2736559386","https://openalex.org/W3003801367","https://openalex.org/W4246180958"],"related_works":[],"abstract_inverted_index":{"The":[0,206],"reuse":[1,63],"at":[2,13,30],"the":[3,11,14,22,36,58,79,87,129,135,146,154,167,195],"component":[4,68,89,211],"level":[5,24,33],"is":[6,19],"generally":[7],"more":[8],"effective":[9],"than":[10],"one":[12],"object-oriented":[15,38,81,125],"class":[16,177],"level.":[17],"This":[18],"due":[20],"to":[21,35,62,74,100,107,119,151,186],"granularity":[23],"where":[25],"components":[26,41,76,123],"expose":[27],"their":[28,44,47],"functionalities":[29],"an":[31,53,117],"abstract":[32],"compared":[34],"fine-grained":[37],"classes.":[39],"Moreover,":[40],"clearly":[42],"define":[43],"dependencies":[45,96],"through":[46],"provided":[48],"and":[49,134,176],"required":[50],"interfaces":[51],"in":[52,124],"explicit":[54],"way":[55],"that":[56,103,209],"facilitates":[57],"understanding":[59],"of":[60,86,156,169,202],"how":[61],"these":[64],"components.":[65],"Therefore,":[66],"several":[67],"identification":[69,90,212],"approaches":[70,91],"have":[71],"been":[72],"proposed":[73],"identify":[75,101,120],"based":[77,127],"on":[78,128],"analysis":[80,149,162],"software":[82,122],"applications.":[83],"Nevertheless,":[84],"most":[85],"existing":[88],"did":[92],"not":[93],"consider":[94],"co-usage":[95],"between":[97,131],"API":[98,157],"classes":[99],"classes/methods":[102],"can":[104],"be":[105],"reused":[106],"implement":[108],"a":[109,200,215],"specific":[110],"scenario.":[111],"In":[112],"this":[113],"paper,":[114],"we":[115,139],"propose":[116],"approach":[118,182,213],"reusable":[121],"APIs,":[126],"interactions":[130],"client":[132,192],"applications":[133,193],"targeted":[136],"API.":[137],"As":[138],"are":[140,163],"dealing":[141],"with":[142,190],"actual":[143],"clients":[144],"using":[145,160],"API,":[147],"dynamic":[148,171],"allows":[150],"better":[152],"capture":[153],"instances":[155],"usage.":[158],"Approaches":[159],"static":[161],"usually":[164],"limited":[165],"by":[166,183],"difficulty":[168],"handling":[170],"features":[172],"such":[173],"as":[174],"polymorphism":[175],"loading.":[178],"We":[179],"evaluate":[180],"our":[181,210],"applying":[184],"it":[185],"three":[187],"Java":[188],"APIs":[189],"eight":[191],"from":[194],"DaCapo":[196,198],"benchmark.":[197],"provides":[199],"set":[201],"pre-defined":[203],"usage":[204],"scenarios.":[205],"results":[207],"show":[208],"has":[214],"very":[216],"high":[217],"precision.":[218]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":5},{"year":2021,"cited_by_count":2},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":4},{"year":2018,"cited_by_count":1}],"updated_date":"2026-05-07T13:39:58.223016","created_date":"2018-03-29T00:00:00"}
