Obsah:
- Krok 1: Vytvořte matici NxN jednotných čtverců
- Krok 2: Randomizace sítě
- Krok 3: Získejte nové vzdálenosti
- Krok 4: Vyberte bod a porovnejte vzdálenost od tohoto bodu k ostatním
- Krok 5: Přesuňte se do nového bodu
- Krok 6: Síla = vzdálenost K*
- Krok 7: Změňte pohyb v síti kvůli přesunutému bodu
- Krok 8: Hotový kód
2025 Autor: John Day | [email protected]. Naposledy změněno: 2025-01-23 14:38
Buňky jsou schopné interagovat se svou okolní extracelulární matricí (ECM) a mohou jak působit, tak reagovat na síly vyvíjené ECM. Pro náš projekt simulujeme propojenou síť vláken, která by fungovala jako ECM, a sledujeme, jak se síť mění v reakci na pohyb jednoho z bodů. ECM je modelován jako propojený systém pružin, které jsou zpočátku v rovnováze s čistou silou nula. Jak síla působí na síť v reakci na pohyb bodu, snažíme se přimět spojené body, aby reagovaly na sílu takovým způsobem, že se pokusí vrátit do rovnováhy. Síla je monitorována rovnicí F = k*x, kde k je pružinová konstanta a x je změna délky vlákna. Tato simulace může poskytnout obecné porozumění šíření síly ve vláknitých sítích, které lze nakonec použít k simulaci mechanotransdukce.
Krok 1: Vytvořte matici NxN jednotných čtverců
Chcete -li začít s kódem, zvolíme N, který určí rozměry naší sítě (NxN). Hodnotu N lze podle potřeby ručně změnit a změnit tak rozměry sítě. V tomto případě N = 8, takže máme síť bodů 8x8. Poté, co vygenerujeme matici, spojíme všechny body v matici, které mají délku 1 jednotku, pomocí vzorce vzdálenosti, vzdálenost = sqrt ((x2-x1)^2+(y2-y1)^2). Tím získáme sítě čtverců, které jsou rovnoměrně rozloženy o 1 jednotku. To lze vidět na obrázku 101.
Krok 2: Randomizace sítě
V tomto kroku chceme randomizovat všechna umístění bodů kromě vnějších bodů, které budou tvořit naši hranici. K tomu nejprve najdeme všechny maticové souřadnice, které se rovnají 0 nebo N. Tyto body jsou těmi, které tvoří hranici. U neohraničných bodů je umístění randomizováno přidáním jiné náhodné hodnoty od -5 do 0,5 do obou poloh x a y. Vynesený náhodný obrázek lze vidět na obrázku 1.
Krok 3: Získejte nové vzdálenosti
Jakmile je vytvořena naše randomizovaná síť, znovu najdeme vzdálenost mezi spojenými body pomocí vzorce vzdálenosti.
Krok 4: Vyberte bod a porovnejte vzdálenost od tohoto bodu k ostatním
V tomto kroku můžeme pomocí kurzoru vybrat bod zájmu, jak ukazuje obrázek 2. Kurzor nemusíte přesouvat přesně na bod, protože kód jej upraví na nejbližší bod připojení. Za tímto účelem nejprve vypočítáme vzdálenost mezi všemi spojenými body a bodem, který jsme právě vybrali. Poté, co jsou vypočítány všechny vzdálenosti, vybereme bod s nejmenší vzdáleností od vybraného bodu, aby se stal skutečným vybraným bodem.
Krok 5: Přesuňte se do nového bodu
V tomto kroku pomocí bodu, který byl vybrán v předchozím kroku, přesuneme bod na nové místo. Tento pohyb se provádí výběrem nové pozice kurzorem, který nahradí předchozí pozici. Tento pohyb bude použit k simulaci vyvíjené síly v důsledku změny délky pružiny. Na modrém obrázku je vybráno nové umístění. Na dalším obrázku lze pohyb zobrazit pomocí oranžových spojení, což jsou nová umístění, na rozdíl od modrých spojení, která byla stará umístění.
Krok 6: Síla = vzdálenost K*
V tomto kroku použijeme sílu rovnice = k*vzdálenost, kde k je pro kolagenová vlákna konstanta 10. Protože vláknová síť začíná ve svém rovnovážném stavu, je čistá síla 0. Vytvoříme nulový vektor o délce matice, kterou jsme vygenerovali dříve, abychom reprezentovali tuto rovnováhu.
Krok 7: Změňte pohyb v síti kvůli přesunutému bodu
V tomto kroku simulujeme pohyb sítě v reakci na pohyb bodu, abychom se vrátili do rovnovážného stavu. Začneme tím, že najdeme nové vzdálenosti mezi dvěma body. Díky tomu můžeme najít změnu délky vlákna pohledem na rozdíl mezi starou a novou vzdáleností. Můžeme také vidět, které body se přesunuly, a také body, se kterými jsou spojeny, porovnáním nového a starého umístění bodu. To nám umožňuje vidět, které body by se měly pohybovat v reakci na vyvíjenou sílu. Směr pohybu lze rozdělit na jeho složky x a y, což dává 2D směrový vektor. Pomocí hodnoty k, změny vzdálenosti a vektoru směru můžeme vypočítat vektor síly, který lze použít k pohybu našich bodů směrem k rovnováze. Tuto část kódu spustíme 100krát, pokaždé se pohybujeme v přírůstcích Force*.1. Spuštění kódu 100krát nám umožňuje nakonec dosáhnout opět rovnováhy a dodržováním okrajových podmínek vidíme změnu v síti namísto jednoduše celou směnu. Pohyb sítě je vidět na obrázku 3, přičemž žlutá je přesunutá pozice a modrá předchozí.
Krok 8: Hotový kód
V této části je připojena kopie našeho kódu. Nebojte se jej upravit tak, aby vyhovoval vašim potřebám, pomocí modelování různých sítí!
Doporučuje:
Měření času (hodiny na měření pásky): 5 kroků (s obrázky)
Time Measure (Tape Measure Clock): Pro tento projekt jsme (Alex Fiel & Anna Lynton) vzali každodenní měřicí nástroj a udělali z něj hodiny! Původní plán byl motorizovat stávající svinovací metr. Při tom jsme se rozhodli, že bude snazší vytvořit si vlastní shell, do kterého
Ultrazvukový senzor pro zachycení pozičních změn objektů: 3 kroky
Ultrazvukový senzor pro zachycení pozičních změn objektů: Je důležité mít své cenné věci v bezpečí, bylo by chromé, kdybyste celý den střežili svůj hrad. Pomocí kamery Raspberry Pi můžete zachytit snímky ve správný okamžik. Tato příručka vám pomůže natočit video nebo pořídit
Přemístění Vintage interkomu: 7 kroků (s obrázky)
Re-Purposing Vintage Intercom: Koupil jsem krásný starý interkom v místním prodeji zavazadlového prostoru auta a řekl jsem si, že by bylo dobré jej použít jako dveřní interkom pro naše " schodiště " (jak se viktoriánským bytovým domům v Edinburghu říká). Je to GEC K7867 a vypadá
Surfboardy generované daty: 11 kroků (s obrázky)
Surfboardy generované daty: Toto je převzato z mé vedoucí práce z průmyslového designu zhruba před rokem, takže se omlouvám, pokud jsou v něm nějaké díry, moje paměť může být trochu mimo. Je to experimentální projekt a existuje tolik věcí, které by mohly být provedeny jinak
Alibre Design a vnější vlákna (metoda 1): 6 kroků
Alibre Design a externí vlákna (metoda 1): Tento návod ukáže, jak vytvořit externí vlákno v Alibre Design. V tomto příkladu vytvoříme 50mm čep s 20 mm závitem (M6x1). Tento pokyn předpokládá, že uživatel: 1) může vytvářet primitiva, jako jsou kostky a