{"status":"ok","message-type":"work","message-version":"1.0.0","message":{"indexed":{"date-parts":[[2025,3,26]],"date-time":"2025-03-26T18:06:17Z","timestamp":1743012377002,"version":"3.40.3"},"publisher-location":"Cham","reference-count":20,"publisher":"Springer International Publishing","isbn-type":[{"type":"print","value":"9783319589428"},{"type":"electronic","value":"9783319589435"}],"license":[{"start":{"date-parts":[[2017,1,1]],"date-time":"2017-01-01T00:00:00Z","timestamp":1483228800000},"content-version":"tdm","delay-in-days":0,"URL":"https:\/\/www.springer.com\/tdm"},{"start":{"date-parts":[[2017,1,1]],"date-time":"2017-01-01T00:00:00Z","timestamp":1483228800000},"content-version":"vor","delay-in-days":0,"URL":"https:\/\/www.springer.com\/tdm"}],"content-domain":{"domain":["link.springer.com"],"crossmark-restriction":false},"short-container-title":[],"published-print":{"date-parts":[[2017]]},"DOI":"10.1007\/978-3-319-58943-5_8","type":"book-chapter","created":{"date-parts":[[2017,5,27]],"date-time":"2017-05-27T08:42:07Z","timestamp":1495874527000},"page":"96-107","update-policy":"https:\/\/doi.org\/10.1007\/springer_crossmark_policy","source":"Crossref","is-referenced-by-count":0,"title":["Automatic Generation of OpenCL Code for ARM Architectures"],"prefix":"10.1007","author":[{"given":"Sergio","family":"Afonso","sequence":"first","affiliation":[],"role":[{"role":"author","vocabulary":"crossref"}]},{"given":"Alejandro","family":"Acosta","sequence":"additional","affiliation":[],"role":[{"role":"author","vocabulary":"crossref"}]},{"given":"Francisco","family":"Almeida","sequence":"additional","affiliation":[],"role":[{"role":"author","vocabulary":"crossref"}]}],"member":"297","published-online":{"date-parts":[[2017,5,28]]},"reference":[{"key":"8_CR1","doi-asserted-by":"publisher","first-page":"25","DOI":"10.1016\/j.parco.2016.04.003","volume":"57","author":"A Acosta","year":"2016","unstructured":"Acosta, A., Afonso, S., Almeida, F.: Extending paralldroid with object oriented annotations. Parallel Comput. 57, 25\u201336 (2016). http:\/\/www.sciencedirect.com\/science\/article\/pii\/S0167819116300126","journal-title":"Parallel Comput."},{"key":"8_CR2","unstructured":"Acosta, A., Almeida, F.: Towards a unified heterogeneous development model in android. In: 11th International Workshop HeteroPar 2013: Algorithms, Models and Tools for Parallel Computing on Heterogeneous Platforms (2013)"},{"key":"8_CR3","series-title":"Lecture Notes in Computer Science","doi-asserted-by":"publisher","first-page":"387","DOI":"10.1007\/978-3-319-14313-2_33","volume-title":"Euro-Par 2014: Parallel Processing Workshops","author":"A Acosta","year":"2014","unstructured":"Acosta, A., Almeida, F.: Paralldroid: performance analysis of GPU executions. In: Lopes, L., et al. (eds.) Euro-Par 2014. LNCS, vol. 8806, pp. 387\u2013399. Springer, Cham (2014). doi:10.1007\/978-3-319-14313-2_33"},{"key":"8_CR4","doi-asserted-by":"crossref","unstructured":"Acosta, A., Almeida, F.: Performance analysis of paralldroid generated programs. In: 2014 22nd Euromicro International Conference on Parallel, Distributed, and Network-Based Processing, pp. 60\u201367 (2014)","DOI":"10.1109\/PDP.2014.14"},{"key":"8_CR5","unstructured":"Anandtech: AMD Outlines HSA Roadmap: Unified Memory for CPU\/GPU in 2013, HSA GPUs in 2014. http:\/\/www.anandtech.com\/show\/5493\/"},{"key":"8_CR6","unstructured":"AOSP: Android Open Source Project. http:\/\/source.android.com\/"},{"key":"8_CR7","unstructured":"Apple: iOS: Apple mobile operating system. http:\/\/www.apple.com\/ios"},{"issue":"6","key":"8_CR8","doi-asserted-by":"publisher","first-page":"1","DOI":"10.1145\/2345156.2254066","volume":"47","author":"C Dubach","year":"2012","unstructured":"Dubach, C., Cheng, P., Rabbah, R., Bacon, D.F., Fink, S.J.: Compiling a high-level language for GPUs: (via language support for architectures and compilers). SIGPLAN Not. 47(6), 1\u201312 (2012)","journal-title":"SIGPLAN Not."},{"key":"8_CR9","unstructured":"Google: Android mobile platform. http:\/\/www.android.com"},{"key":"8_CR10","unstructured":"Khronos Group: The open standard for parallel programming of heterogeneous systems. https:\/\/www.khronos.org\/opencl\/"},{"key":"8_CR11","doi-asserted-by":"crossref","unstructured":"Membarth, R., Reiche, O., Hannig, F., Teich, J.: Code generation for embedded heterogeneous architectures on android. In: DATE, pp. 1\u20136 (2014)","DOI":"10.7873\/DATE.2014.099"},{"key":"8_CR12","unstructured":"Systems, M.: Algorithmic Memory \u2122Technology. http:\/\/www.memoir-systems.com\/"},{"key":"8_CR13","unstructured":"Microsoft: Windows Phone: Microsoft mobile operating system. http:\/\/www.microsoft.com\/windowsphone"},{"key":"8_CR14","unstructured":"NVIDIA: GPUDirect Technology. http:\/\/developer.nvidia.com\/gpudirect"},{"key":"8_CR15","unstructured":"NVIDIA: Tegra mobile processors: Tegra 2, Tegra 3 and Tegra 4. http:\/\/www.nvidia.com\/object\/tegra-superchip.html"},{"key":"8_CR16","unstructured":"Qualcomm: Snapdragon mobile processors. http:\/\/www.qualcomm.com\/snapdragon"},{"key":"8_CR17","unstructured":"Samsung: Exynos mobile processors. http:\/\/www.samsung.com\/global\/business\/semiconductor\/minisite\/Exynos\/"},{"key":"8_CR18","unstructured":"Valentin, C., Christian, S., Pierre, K., Fran\u00e7ois, K.P., Jean-Fran\u00e7ois, R.: Parallel object programming with Java. http:\/\/gridgroup.hefr.ch\/popj\/doku.php"},{"key":"8_CR19","unstructured":"Viry, P.: Ateji PX for Java-parallel programming made simple. Ateji White Paper (2010)"},{"key":"8_CR20","unstructured":"Qian, X., Guangyu Zhu, X.F.L.: Comparison and analysis of the three programming models in Google android. In: 1st Asia-Pacific Programming Languages and Compilers Workshop (APPLC), June 2012"}],"container-title":["Lecture Notes in Computer Science","Euro-Par 2016: Parallel Processing Workshops"],"original-title":[],"language":"en","link":[{"URL":"https:\/\/link.springer.com\/content\/pdf\/10.1007\/978-3-319-58943-5_8","content-type":"unspecified","content-version":"vor","intended-application":"similarity-checking"}],"deposited":{"date-parts":[[2021,5,28]],"date-time":"2021-05-28T00:24:04Z","timestamp":1622161444000},"score":1,"resource":{"primary":{"URL":"https:\/\/link.springer.com\/10.1007\/978-3-319-58943-5_8"}},"subtitle":[],"short-title":[],"issued":{"date-parts":[[2017]]},"ISBN":["9783319589428","9783319589435"],"references-count":20,"URL":"https:\/\/doi.org\/10.1007\/978-3-319-58943-5_8","relation":{},"ISSN":["0302-9743","1611-3349"],"issn-type":[{"type":"print","value":"0302-9743"},{"type":"electronic","value":"1611-3349"}],"subject":[],"published":{"date-parts":[[2017]]},"assertion":[{"value":"28 May 2017","order":1,"name":"first_online","label":"First Online","group":{"name":"ChapterHistory","label":"Chapter History"}},{"value":"Euro-Par","order":1,"name":"conference_acronym","label":"Conference Acronym","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"European Conference on Parallel Processing","order":2,"name":"conference_name","label":"Conference Name","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"Grenoble","order":3,"name":"conference_city","label":"Conference City","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"France","order":4,"name":"conference_country","label":"Conference Country","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"2016","order":5,"name":"conference_year","label":"Conference Year","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"24 August 2016","order":7,"name":"conference_start_date","label":"Conference Start Date","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"26 August 2016","order":8,"name":"conference_end_date","label":"Conference End Date","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"22","order":9,"name":"conference_number","label":"Conference Number","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"europar2016","order":10,"name":"conference_id","label":"Conference ID","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"https:\/\/europar2016.inria.fr\/","order":11,"name":"conference_url","label":"Conference URL","group":{"name":"ConferenceInfo","label":"Conference Information"}},{"value":"This content has been made available to all.","name":"free","label":"Free to read"}]}}