The foundation of self-developing blob machines for spatial computing

The current trend in electronics is to integrate more and more transistors on a chip and produce massive hardware resources. As a consequence, traditional computing models, which mainly compute in the temporal domain, do not work well anymore since it becomes increasingly difficult to orchestrate th...

Ausführliche Beschreibung

Gespeichert in:
Bibliographische Detailangaben
Veröffentlicht in:Physica. D 2008-07, Vol.237 (9), p.1282-1301
Hauptverfasser: Gruau, Frédéric, Eisenbeis, Christine, Maignan, Luidnel
Format: Artikel
Sprache:eng
Schlagworte:
Online-Zugang:Volltext
Tags: Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
container_end_page 1301
container_issue 9
container_start_page 1282
container_title Physica. D
container_volume 237
creator Gruau, Frédéric
Eisenbeis, Christine
Maignan, Luidnel
description The current trend in electronics is to integrate more and more transistors on a chip and produce massive hardware resources. As a consequence, traditional computing models, which mainly compute in the temporal domain, do not work well anymore since it becomes increasingly difficult to orchestrate these massive-scale hardware resources in a centralized way. Spatial computing is a unifying term that embodies many unconventional computing models and means computing on a relatively homogeneous physical medium made of hardware components, where the communication time is dependent on the Euclidean distance between the components (locality constraint). This constraint makes the programming for high performance significantly more complex compared to classical non-spatial hardware because performance now depends on where computation happens in space (mapping problem). Blob computing is a new approach that addresses this parallel computing challenge in a radically new and unconventional way: it decouples the mapping of computations onto the hardware from the software programming while still elegantly exploiting the space of the underlying hardware. Hardware mapping of computations is done by a physical force-based approach that simulates forces between threads of computation (automata). Attractive forces are used to keep automata that need to communicate with each other closer while repulsive forces are used for load balancing. The advantage of these primitives is that they are simple enough to be implemented on an arbitrary computing medium. They form the basis of a runtime system (RTS) that transforms an arbitrary computing medium into an easier-to-program virtual machine called the blob machine. The basic objects of the blob machine are those automata, and the instructions let automata create new automata in specific ways so as to maintain a hierarchical organization (which facilitates both the mapping and the programming). We detail the basic instructions of the blob machine and demonstrate their confluence. Programming a spatial medium to perform a given algorithm then boils down to programming the blob machine, provided the RTS is implemented on it. The advantage of this approach is the hardware independency, meaning that the same program can be used on different media. By means of several examples programmed using a high-level language description, we further show that we can efficiently implement most current parallel computing models, such as Single Instruc
doi_str_mv 10.1016/j.physd.2008.03.046
format Article
fullrecord <record><control><sourceid>elsevier_hal_p</sourceid><recordid>TN_cdi_hal_primary_oai_HAL_lirmm_00402195v1</recordid><sourceformat>XML</sourceformat><sourcesystem>PC</sourcesystem><els_id>S0167278908001255</els_id><sourcerecordid>S0167278908001255</sourcerecordid><originalsourceid>FETCH-LOGICAL-c414t-8ea8aca31e4d27e56696ae8c7b6eaaed328776dec39e6db4395140793c3246d43</originalsourceid><addsrcrecordid>eNp90D1PwzAQBmALgUQp_AKWLEwowV-1nYGhqgpFqsRSZsu1L9RVEkd2W6n_Hpeijky3PO-d7kXokeCKYCJettWwOSZXUYxVhVmFubhCI6IkLRWm9BqNspIllaq-RXcpbTHGRDI5QvPVBoom7Htndj70RWiKBG1TOjhAGwbffxfrNqyLztiN7yFlG4s0ZGzawoZu2O-yuUc3jWkTPPzNMfp6m69mi3L5-f4xmy5LywnflQqMMtYwAtxRCRMhamFAWbkWYAw4RpWUwoFlNQi35qyeEI5lzSyjXDjOxuj5vHdjWj1E35l41MF4vZgudetj12mMOaaknhxI1uysbQwpRWguEYL1qTe91b-96VNvGjOde8upp3NqMMmatommtz5dojQbqtgku9ezg_zwwUPUyXroLTgfwe60C_7fOz-ptoSO</addsrcrecordid><sourcetype>Open Access Repository</sourcetype><iscdi>true</iscdi><recordtype>article</recordtype></control><display><type>article</type><title>The foundation of self-developing blob machines for spatial computing</title><source>Elsevier ScienceDirect Journals Complete</source><creator>Gruau, Frédéric ; Eisenbeis, Christine ; Maignan, Luidnel</creator><creatorcontrib>Gruau, Frédéric ; Eisenbeis, Christine ; Maignan, Luidnel</creatorcontrib><description>The current trend in electronics is to integrate more and more transistors on a chip and produce massive hardware resources. As a consequence, traditional computing models, which mainly compute in the temporal domain, do not work well anymore since it becomes increasingly difficult to orchestrate these massive-scale hardware resources in a centralized way. Spatial computing is a unifying term that embodies many unconventional computing models and means computing on a relatively homogeneous physical medium made of hardware components, where the communication time is dependent on the Euclidean distance between the components (locality constraint). This constraint makes the programming for high performance significantly more complex compared to classical non-spatial hardware because performance now depends on where computation happens in space (mapping problem). Blob computing is a new approach that addresses this parallel computing challenge in a radically new and unconventional way: it decouples the mapping of computations onto the hardware from the software programming while still elegantly exploiting the space of the underlying hardware. Hardware mapping of computations is done by a physical force-based approach that simulates forces between threads of computation (automata). Attractive forces are used to keep automata that need to communicate with each other closer while repulsive forces are used for load balancing. The advantage of these primitives is that they are simple enough to be implemented on an arbitrary computing medium. They form the basis of a runtime system (RTS) that transforms an arbitrary computing medium into an easier-to-program virtual machine called the blob machine. The basic objects of the blob machine are those automata, and the instructions let automata create new automata in specific ways so as to maintain a hierarchical organization (which facilitates both the mapping and the programming). We detail the basic instructions of the blob machine and demonstrate their confluence. Programming a spatial medium to perform a given algorithm then boils down to programming the blob machine, provided the RTS is implemented on it. The advantage of this approach is the hardware independency, meaning that the same program can be used on different media. By means of several examples programmed using a high-level language description, we further show that we can efficiently implement most current parallel computing models, such as Single Instruction Multiple Data (SIMD), data parallelism, “divide-and-conquer” parallelism and pipelining which demonstrates parallel expressiveness. On sorting and matrix multiplication algorithms, we also show that our approach scales up optimally with the number of basic hardware components.</description><identifier>ISSN: 0167-2789</identifier><identifier>EISSN: 1872-8022</identifier><identifier>DOI: 10.1016/j.physd.2008.03.046</identifier><identifier>CODEN: PDNPDT</identifier><language>eng</language><publisher>Amsterdam: Elsevier B.V</publisher><subject>Computer architecture ; Computer language ; Computer Science ; Distributed algorithm ; Distributed, Parallel, and Cluster Computing ; Exact sciences and technology ; Physics ; Self-developing network ; Spatial computing</subject><ispartof>Physica. D, 2008-07, Vol.237 (9), p.1282-1301</ispartof><rights>2008 Elsevier B.V.</rights><rights>2008 INIST-CNRS</rights><rights>Distributed under a Creative Commons Attribution 4.0 International License</rights><lds50>peer_reviewed</lds50><oa>free_for_read</oa><woscitedreferencessubscribed>false</woscitedreferencessubscribed><citedby>FETCH-LOGICAL-c414t-8ea8aca31e4d27e56696ae8c7b6eaaed328776dec39e6db4395140793c3246d43</citedby><cites>FETCH-LOGICAL-c414t-8ea8aca31e4d27e56696ae8c7b6eaaed328776dec39e6db4395140793c3246d43</cites></display><links><openurl>$$Topenurl_article</openurl><openurlfulltext>$$Topenurlfull_article</openurlfulltext><thumbnail>$$Tsyndetics_thumb_exl</thumbnail><linktohtml>$$Uhttps://dx.doi.org/10.1016/j.physd.2008.03.046$$EHTML$$P50$$Gelsevier$$H</linktohtml><link.rule.ids>230,309,310,314,780,784,789,790,885,3550,23930,23931,25140,27924,27925,45995</link.rule.ids><backlink>$$Uhttp://pascal-francis.inist.fr/vibad/index.php?action=getRecordDetail&amp;idt=20462835$$DView record in Pascal Francis$$Hfree_for_read</backlink><backlink>$$Uhttps://hal-lirmm.ccsd.cnrs.fr/lirmm-00402195$$DView record in HAL$$Hfree_for_read</backlink></links><search><creatorcontrib>Gruau, Frédéric</creatorcontrib><creatorcontrib>Eisenbeis, Christine</creatorcontrib><creatorcontrib>Maignan, Luidnel</creatorcontrib><title>The foundation of self-developing blob machines for spatial computing</title><title>Physica. D</title><description>The current trend in electronics is to integrate more and more transistors on a chip and produce massive hardware resources. As a consequence, traditional computing models, which mainly compute in the temporal domain, do not work well anymore since it becomes increasingly difficult to orchestrate these massive-scale hardware resources in a centralized way. Spatial computing is a unifying term that embodies many unconventional computing models and means computing on a relatively homogeneous physical medium made of hardware components, where the communication time is dependent on the Euclidean distance between the components (locality constraint). This constraint makes the programming for high performance significantly more complex compared to classical non-spatial hardware because performance now depends on where computation happens in space (mapping problem). Blob computing is a new approach that addresses this parallel computing challenge in a radically new and unconventional way: it decouples the mapping of computations onto the hardware from the software programming while still elegantly exploiting the space of the underlying hardware. Hardware mapping of computations is done by a physical force-based approach that simulates forces between threads of computation (automata). Attractive forces are used to keep automata that need to communicate with each other closer while repulsive forces are used for load balancing. The advantage of these primitives is that they are simple enough to be implemented on an arbitrary computing medium. They form the basis of a runtime system (RTS) that transforms an arbitrary computing medium into an easier-to-program virtual machine called the blob machine. The basic objects of the blob machine are those automata, and the instructions let automata create new automata in specific ways so as to maintain a hierarchical organization (which facilitates both the mapping and the programming). We detail the basic instructions of the blob machine and demonstrate their confluence. Programming a spatial medium to perform a given algorithm then boils down to programming the blob machine, provided the RTS is implemented on it. The advantage of this approach is the hardware independency, meaning that the same program can be used on different media. By means of several examples programmed using a high-level language description, we further show that we can efficiently implement most current parallel computing models, such as Single Instruction Multiple Data (SIMD), data parallelism, “divide-and-conquer” parallelism and pipelining which demonstrates parallel expressiveness. On sorting and matrix multiplication algorithms, we also show that our approach scales up optimally with the number of basic hardware components.</description><subject>Computer architecture</subject><subject>Computer language</subject><subject>Computer Science</subject><subject>Distributed algorithm</subject><subject>Distributed, Parallel, and Cluster Computing</subject><subject>Exact sciences and technology</subject><subject>Physics</subject><subject>Self-developing network</subject><subject>Spatial computing</subject><issn>0167-2789</issn><issn>1872-8022</issn><fulltext>true</fulltext><rsrctype>article</rsrctype><creationdate>2008</creationdate><recordtype>article</recordtype><recordid>eNp90D1PwzAQBmALgUQp_AKWLEwowV-1nYGhqgpFqsRSZsu1L9RVEkd2W6n_Hpeijky3PO-d7kXokeCKYCJettWwOSZXUYxVhVmFubhCI6IkLRWm9BqNspIllaq-RXcpbTHGRDI5QvPVBoom7Htndj70RWiKBG1TOjhAGwbffxfrNqyLztiN7yFlG4s0ZGzawoZu2O-yuUc3jWkTPPzNMfp6m69mi3L5-f4xmy5LywnflQqMMtYwAtxRCRMhamFAWbkWYAw4RpWUwoFlNQi35qyeEI5lzSyjXDjOxuj5vHdjWj1E35l41MF4vZgudetj12mMOaaknhxI1uysbQwpRWguEYL1qTe91b-96VNvGjOde8upp3NqMMmatommtz5dojQbqtgku9ezg_zwwUPUyXroLTgfwe60C_7fOz-ptoSO</recordid><startdate>20080701</startdate><enddate>20080701</enddate><creator>Gruau, Frédéric</creator><creator>Eisenbeis, Christine</creator><creator>Maignan, Luidnel</creator><general>Elsevier B.V</general><general>Elsevier</general><scope>IQODW</scope><scope>AAYXX</scope><scope>CITATION</scope><scope>1XC</scope><scope>VOOES</scope></search><sort><creationdate>20080701</creationdate><title>The foundation of self-developing blob machines for spatial computing</title><author>Gruau, Frédéric ; Eisenbeis, Christine ; Maignan, Luidnel</author></sort><facets><frbrtype>5</frbrtype><frbrgroupid>cdi_FETCH-LOGICAL-c414t-8ea8aca31e4d27e56696ae8c7b6eaaed328776dec39e6db4395140793c3246d43</frbrgroupid><rsrctype>articles</rsrctype><prefilter>articles</prefilter><language>eng</language><creationdate>2008</creationdate><topic>Computer architecture</topic><topic>Computer language</topic><topic>Computer Science</topic><topic>Distributed algorithm</topic><topic>Distributed, Parallel, and Cluster Computing</topic><topic>Exact sciences and technology</topic><topic>Physics</topic><topic>Self-developing network</topic><topic>Spatial computing</topic><toplevel>peer_reviewed</toplevel><toplevel>online_resources</toplevel><creatorcontrib>Gruau, Frédéric</creatorcontrib><creatorcontrib>Eisenbeis, Christine</creatorcontrib><creatorcontrib>Maignan, Luidnel</creatorcontrib><collection>Pascal-Francis</collection><collection>CrossRef</collection><collection>Hyper Article en Ligne (HAL)</collection><collection>Hyper Article en Ligne (HAL) (Open Access)</collection><jtitle>Physica. D</jtitle></facets><delivery><delcategory>Remote Search Resource</delcategory><fulltext>fulltext</fulltext></delivery><addata><au>Gruau, Frédéric</au><au>Eisenbeis, Christine</au><au>Maignan, Luidnel</au><format>journal</format><genre>article</genre><ristype>JOUR</ristype><atitle>The foundation of self-developing blob machines for spatial computing</atitle><jtitle>Physica. D</jtitle><date>2008-07-01</date><risdate>2008</risdate><volume>237</volume><issue>9</issue><spage>1282</spage><epage>1301</epage><pages>1282-1301</pages><issn>0167-2789</issn><eissn>1872-8022</eissn><coden>PDNPDT</coden><abstract>The current trend in electronics is to integrate more and more transistors on a chip and produce massive hardware resources. As a consequence, traditional computing models, which mainly compute in the temporal domain, do not work well anymore since it becomes increasingly difficult to orchestrate these massive-scale hardware resources in a centralized way. Spatial computing is a unifying term that embodies many unconventional computing models and means computing on a relatively homogeneous physical medium made of hardware components, where the communication time is dependent on the Euclidean distance between the components (locality constraint). This constraint makes the programming for high performance significantly more complex compared to classical non-spatial hardware because performance now depends on where computation happens in space (mapping problem). Blob computing is a new approach that addresses this parallel computing challenge in a radically new and unconventional way: it decouples the mapping of computations onto the hardware from the software programming while still elegantly exploiting the space of the underlying hardware. Hardware mapping of computations is done by a physical force-based approach that simulates forces between threads of computation (automata). Attractive forces are used to keep automata that need to communicate with each other closer while repulsive forces are used for load balancing. The advantage of these primitives is that they are simple enough to be implemented on an arbitrary computing medium. They form the basis of a runtime system (RTS) that transforms an arbitrary computing medium into an easier-to-program virtual machine called the blob machine. The basic objects of the blob machine are those automata, and the instructions let automata create new automata in specific ways so as to maintain a hierarchical organization (which facilitates both the mapping and the programming). We detail the basic instructions of the blob machine and demonstrate their confluence. Programming a spatial medium to perform a given algorithm then boils down to programming the blob machine, provided the RTS is implemented on it. The advantage of this approach is the hardware independency, meaning that the same program can be used on different media. By means of several examples programmed using a high-level language description, we further show that we can efficiently implement most current parallel computing models, such as Single Instruction Multiple Data (SIMD), data parallelism, “divide-and-conquer” parallelism and pipelining which demonstrates parallel expressiveness. On sorting and matrix multiplication algorithms, we also show that our approach scales up optimally with the number of basic hardware components.</abstract><cop>Amsterdam</cop><pub>Elsevier B.V</pub><doi>10.1016/j.physd.2008.03.046</doi><tpages>20</tpages><oa>free_for_read</oa></addata></record>
fulltext fulltext
identifier ISSN: 0167-2789
ispartof Physica. D, 2008-07, Vol.237 (9), p.1282-1301
issn 0167-2789
1872-8022
language eng
recordid cdi_hal_primary_oai_HAL_lirmm_00402195v1
source Elsevier ScienceDirect Journals Complete
subjects Computer architecture
Computer language
Computer Science
Distributed algorithm
Distributed, Parallel, and Cluster Computing
Exact sciences and technology
Physics
Self-developing network
Spatial computing
title The foundation of self-developing blob machines for spatial computing
url https://sfx.bib-bvb.de/sfx_tum?ctx_ver=Z39.88-2004&ctx_enc=info:ofi/enc:UTF-8&ctx_tim=2025-01-07T18%3A32%3A34IST&url_ver=Z39.88-2004&url_ctx_fmt=infofi/fmt:kev:mtx:ctx&rfr_id=info:sid/primo.exlibrisgroup.com:primo3-Article-elsevier_hal_p&rft_val_fmt=info:ofi/fmt:kev:mtx:journal&rft.genre=article&rft.atitle=The%20foundation%20of%20self-developing%20blob%20machines%20for%20spatial%20computing&rft.jtitle=Physica.%20D&rft.au=Gruau,%20Fr%C3%A9d%C3%A9ric&rft.date=2008-07-01&rft.volume=237&rft.issue=9&rft.spage=1282&rft.epage=1301&rft.pages=1282-1301&rft.issn=0167-2789&rft.eissn=1872-8022&rft.coden=PDNPDT&rft_id=info:doi/10.1016/j.physd.2008.03.046&rft_dat=%3Celsevier_hal_p%3ES0167278908001255%3C/elsevier_hal_p%3E%3Curl%3E%3C/url%3E&disable_directlink=true&sfx.directlink=off&sfx.report_link=0&rft_id=info:oai/&rft_id=info:pmid/&rft_els_id=S0167278908001255&rfr_iscdi=true