{"id":"https://openalex.org/W2784795820","doi":"https://doi.org/10.1145/3183377.3183385","title":"Easing IoT development for novice programmers through code recipes","display_name":"Easing IoT development for novice programmers through code recipes","publication_year":2018,"publication_date":"2018-05-27","ids":{"openalex":"https://openalex.org/W2784795820","doi":"https://doi.org/10.1145/3183377.3183385","mag":"2784795820"},"language":"en","primary_location":{"id":"doi:10.1145/3183377.3183385","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3183377.3183385","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th International Conference on Software Engineering: Software Engineering Education and Training","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://porto.polito.it/2698336/1/recipes.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5060510787","display_name":"Fulvio Corno","orcid":"https://orcid.org/0000-0002-9818-0999"},"institutions":[{"id":"https://openalex.org/I177477856","display_name":"Politecnico di Torino","ror":"https://ror.org/00bgk9508","country_code":"IT","type":"education","lineage":["https://openalex.org/I177477856"]}],"countries":["IT"],"is_corresponding":false,"raw_author_name":"Fulvio Corno","raw_affiliation_strings":["Politecnico di Torino, Turin, Italy"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Politecnico di Torino, Turin, Italy","institution_ids":["https://openalex.org/I177477856"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5023909289","display_name":"Luigi De Russis","orcid":"https://orcid.org/0000-0001-7647-6652"},"institutions":[{"id":"https://openalex.org/I177477856","display_name":"Politecnico di Torino","ror":"https://ror.org/00bgk9508","country_code":"IT","type":"education","lineage":["https://openalex.org/I177477856"]}],"countries":["IT"],"is_corresponding":false,"raw_author_name":"Luigi De Russis","raw_affiliation_strings":["Politecnico di Torino, Turin, Italy"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Politecnico di Torino, Turin, Italy","institution_ids":["https://openalex.org/I177477856"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5059726739","display_name":"Juan Pablo S\u00e1enz","orcid":"https://orcid.org/0000-0003-0928-3089"},"institutions":[{"id":"https://openalex.org/I177477856","display_name":"Politecnico di Torino","ror":"https://ror.org/00bgk9508","country_code":"IT","type":"education","lineage":["https://openalex.org/I177477856"]}],"countries":["IT"],"is_corresponding":false,"raw_author_name":"Juan Pablo S\u00e1enz","raw_affiliation_strings":["Politecnico di Torino, Turin, Italy"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Politecnico di Torino, Turin, Italy","institution_ids":["https://openalex.org/I177477856"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.0566,"has_fulltext":false,"cited_by_count":10,"citation_normalized_percentile":{"value":0.89935389,"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":"13","last_page":"16"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10430","display_name":"Software Engineering Techniques and Practices","score":0.9991999864578247,"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/T10430","display_name":"Software Engineering Techniques and Practices","score":0.9991999864578247,"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/T10260","display_name":"Software Engineering Research","score":0.9984999895095825,"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.9976000189781189,"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.8450379371643066},{"id":"https://openalex.org/keywords/documentation","display_name":"Documentation","score":0.768527626991272},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.6861858367919922},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.5345900058746338},{"id":"https://openalex.org/keywords/asset","display_name":"Asset (computer security)","score":0.5154581665992737},{"id":"https://openalex.org/keywords/internal-documentation","display_name":"Internal documentation","score":0.5066707730293274},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.49520817399024963},{"id":"https://openalex.org/keywords/software-development","display_name":"Software development","score":0.4861859679222107},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.46557849645614624},{"id":"https://openalex.org/keywords/code-review","display_name":"Code review","score":0.42963314056396484},{"id":"https://openalex.org/keywords/world-wide-web","display_name":"World Wide Web","score":0.3773181438446045},{"id":"https://openalex.org/keywords/static-program-analysis","display_name":"Static program analysis","score":0.32383018732070923},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3093522787094116},{"id":"https://openalex.org/keywords/software-construction","display_name":"Software construction","score":0.18244245648384094},{"id":"https://openalex.org/keywords/computer-security","display_name":"Computer security","score":0.11697942018508911}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8450379371643066},{"id":"https://openalex.org/C56666940","wikidata":"https://www.wikidata.org/wiki/Q788790","display_name":"Documentation","level":2,"score":0.768527626991272},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.6861858367919922},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.5345900058746338},{"id":"https://openalex.org/C76178495","wikidata":"https://www.wikidata.org/wiki/Q4808784","display_name":"Asset (computer security)","level":2,"score":0.5154581665992737},{"id":"https://openalex.org/C140396857","wikidata":"https://www.wikidata.org/wiki/Q16934771","display_name":"Internal documentation","level":5,"score":0.5066707730293274},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.49520817399024963},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.4861859679222107},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.46557849645614624},{"id":"https://openalex.org/C150292731","wikidata":"https://www.wikidata.org/wiki/Q1342704","display_name":"Code review","level":5,"score":0.42963314056396484},{"id":"https://openalex.org/C136764020","wikidata":"https://www.wikidata.org/wiki/Q466","display_name":"World Wide Web","level":1,"score":0.3773181438446045},{"id":"https://openalex.org/C137287247","wikidata":"https://www.wikidata.org/wiki/Q1329550","display_name":"Static program analysis","level":4,"score":0.32383018732070923},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3093522787094116},{"id":"https://openalex.org/C186846655","wikidata":"https://www.wikidata.org/wiki/Q3398377","display_name":"Software construction","level":4,"score":0.18244245648384094},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.11697942018508911},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3183377.3183385","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3183377.3183385","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 40th International Conference on Software Engineering: Software Engineering Education and Training","raw_type":"proceedings-article"},{"id":"pmh:oai:porto.polito.it:2698336","is_oa":true,"landing_page_url":"http://porto.polito.it/2698336/1/recipes.pdf","pdf_url":null,"source":{"id":"https://openalex.org/S4306402038","display_name":"PORTO Publications Open Repository TOrino (Politecnico di Torino)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I177477856","host_organization_name":"Politecnico di Torino","host_organization_lineage":["https://openalex.org/I177477856"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"info:eu-repo/semantics/conferenceObject"}],"best_oa_location":{"id":"pmh:oai:porto.polito.it:2698336","is_oa":true,"landing_page_url":"http://porto.polito.it/2698336/1/recipes.pdf","pdf_url":null,"source":{"id":"https://openalex.org/S4306402038","display_name":"PORTO Publications Open Repository TOrino (Politecnico di Torino)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I177477856","host_organization_name":"Politecnico di Torino","host_organization_lineage":["https://openalex.org/I177477856"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"info:eu-repo/semantics/conferenceObject"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":10,"referenced_works":["https://openalex.org/W2124100711","https://openalex.org/W2160694571","https://openalex.org/W2214393799","https://openalex.org/W2558487676","https://openalex.org/W2578412880","https://openalex.org/W2611714150","https://openalex.org/W2731713576","https://openalex.org/W2750225368","https://openalex.org/W2756141981","https://openalex.org/W4236981789"],"related_works":["https://openalex.org/W2112489737","https://openalex.org/W2767775279","https://openalex.org/W2147111361","https://openalex.org/W2587986437","https://openalex.org/W2142991486","https://openalex.org/W1967782643","https://openalex.org/W4310820326","https://openalex.org/W2791928022","https://openalex.org/W2020144937","https://openalex.org/W4214596491"],"abstract_inverted_index":{"The":[0,55],"co-existence":[1],"of":[2,5,14,61,67,77,154],"various":[3],"kinds":[4],"devices,":[6],"protocols,":[7],"architectures,":[8],"and":[9,86,100,156],"programming":[10,162],"languages":[11,163],"make":[12,116],"Internet":[13],"Things":[15],"(IoT)":[16],"systems":[17],"complex":[18],"to":[19,33,74,104,115,199],"develop,":[20],"even":[21,30],"for":[22,98,141],"experienced":[23],"programmers.":[24,37],"Perforce,":[25],"Software":[26],"Engineering":[27],"challenges":[28],"are":[29,195],"more":[31],"difficult":[32],"address":[34],"by":[35,80,120,129,167,179],"novice":[36,48,91,131,143,201],"Previous":[38],"research":[39,122],"focused":[40],"on":[41],"identifying":[42],"the":[43,59,68,75,110,121,126],"most":[44,69],"challenging":[45],"issues":[46],"that":[47,58,182],"programmers":[49,92,132,170,203],"experience":[50],"when":[51],"developing":[52],"IoT":[53,130,202,207],"systems.":[54,208],"results":[56],"suggested":[57],"integration":[60],"heterogeneous":[62],"software":[63],"components":[64],"is":[65],"one":[66],"painful":[70],"issues,":[71],"mainly":[72],"due":[73],"lack":[76],"documentation":[78,99,158],"understandable":[79],"inexperienced":[81],"developers,":[82],"from":[83,161],"both":[84],"conceptual":[85],"technical":[87],"perspectives.":[88],"In":[89],"fact,":[90],"devote":[93],"a":[94,187,196],"significant":[95],"effort":[96],"looking":[97],"code":[101],"samples":[102],"willing":[103],"understand":[105],"them":[106,117],"conceptually,":[107],"or":[108,164],"in":[109,145,204],"worst":[111],"case,":[112,189],"at":[113],"least":[114],"work.":[118],"Driven":[119],"question:":[123],"\"How":[124],"do":[125],"lessons":[127],"learned":[128],"can":[133,171],"be":[134],"captured,":[135],"so":[136],"they":[137],"become":[138,173],"an":[139],"asset":[140],"other":[142,180],"developers?\",":[144],"this":[146],"paper,":[147],"we":[148,190],"introduce":[149],"Code":[150,193],"Recipes.":[151],"They":[152],"consist":[153],"summarized":[155],"well-defined":[157],"modules,":[159],"independent":[160],"run-time":[165],"environments,":[166],"which":[168],"non-expert":[169],"smoothly":[172],"familiar":[174],"with":[175],"source":[176],"code,":[177],"written":[178],"developers":[181],"faced":[183],"similar":[184],"issues.":[185],"Through":[186],"use":[188],"show":[191],"how":[192],"Recipes":[194],"feasible":[197],"mechanism":[198],"support":[200],"building":[205],"their":[206]},"counts_by_year":[{"year":2025,"cited_by_count":2},{"year":2022,"cited_by_count":3},{"year":2021,"cited_by_count":1},{"year":2019,"cited_by_count":4}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
