Wolfram Language has very detailed built-in data about Anatomical Structure. Here is an example of usage building an interactive models of brain. First we would need some data. Because anatomical parts constitute of smaller parts and so forth, we can visualize anatomical structures as trees, for instance:
data:image/s3,"s3://crabby-images/70d9c/70d9cc60cb8989527c34ea8e2da39fa0b8a14d35" alt="enter image description here"
To get that I need to build a data crawler:
crawler[root_, depth_] :=
Flatten[Rest[NestList[DeleteCases[Union[Flatten[
Thread[# -> DeleteMissing[EntityValue[#, EntityProperty["AnatomicalStructure",
"RegionalParts"]]]] & /@ Last /@ #]], HoldPattern[_ -> Sequence[]]] &, {"" -> root}, depth]]];
start from brain and get down 3 levels of anatomical structure:
edge = crawler[Entity["AnatomicalStructure", "Brain"], 3]
data:image/s3,"s3://crabby-images/2b050/2b0509d5d7ad75904053f418d3bade96425a56f9" alt="enter image description here"
Get edges, vertices, and labels as images of anatomical parts:
g = Graph[edge];
vert = VertexList[g];
lblsT = Rasterize /@ vert;
The image at the top is build with ContextualizedHighlightedImage
:
lblsI = Module[{tmp},
tmp = EntityValue[#, EntityProperty["AnatomicalStructure", "ContextualizedHighlightedImage"]];
If[ImageQ[tmp], ImageCrop[tmp], "N/A"]] & /@ vert
data:image/s3,"s3://crabby-images/cf491/cf491a292b6316a32a04c37bdc2df58089983bd4" alt="enter image description here"
we can also try just with Image
:
lblsI = Module[{tmp},
tmp = EntityValue[#, EntityProperty["AnatomicalStructure", "Image"]];
If[ImageQ[tmp], ImageCrop[tmp], "N/A"]] & /@ vert
data:image/s3,"s3://crabby-images/a05f2/a05f2c3f68f88a31c6367e137e3b614a96e7a6fe" alt="enter image description here"
A quick way to get a non-interactive tree like plot:
GraphPlot[edge, VertexLabeling -> True]
data:image/s3,"s3://crabby-images/ed500/ed5007cf78b1b3a79b4fa0e174e570a2cb36bfe7" alt="enter image description here"
But for fancy interactivity and to preserve Graph data-structure we write a short code and get the top nice image in this post:
tltps = Tooltip @@@ Transpose[{lblsT, lblsI}];
TreeGraph[vert, edge, VertexLabels -> Thread[vert -> (Placed[#, Center] & /@ tltps)],
ImageSize -> 700, GraphStyle -> "ThickEdge", GraphLayout -> "RadialEmbedding"]
data:image/s3,"s3://crabby-images/7d393/7d3934ac338dc1cfdb9d38161f6c61a4294d9e43" alt="enter image description here"
That was a good programming exercise and now we can appreciate how recent function NestGraph can make things much easier:
NestGraph[Cases[EntityValue[#, EntityProperty["AnatomicalStructure", "RegionalParts"]], _Entity] &,
Entity["AnatomicalStructure", "Brain"], 4, ImageSize -> 700, GraphStyle -> "SmallNetwork",
GraphLayout -> "RadialEmbedding", VertexLabels -> Placed["Name", Tooltip]]
data:image/s3,"s3://crabby-images/d6632/d66322c9c3f4787f29233b8c037ff12ac80b25f1" alt="enter image description here"
We can also build a 3D interactive model app. For example, choose specific brain parts
bParts = {
Entity["AnatomicalStructure", "ParietalLobe"],
Entity["AnatomicalStructure", "Cerebellum"],
Entity["AnatomicalStructure", "PituitaryGland"],
Entity["AnatomicalStructure", "OpticChiasm"],
Entity["AnatomicalStructure", "Hypothalamus"],
Entity["AnatomicalStructure", "ChoroidPlexusOfCerebralHemisphere"],
Entity["AnatomicalStructure", "HippocampalFormation"]}
data:image/s3,"s3://crabby-images/ca16c/ca16cc0c4499ef0851ae1fd5f3f1039a4b6dc915" alt="enter image description here"
and get their 3D models:
bParts3D = EntityValue[bParts, EntityProperty["AnatomicalStructure", "Graphics3D"]];
And then we can build an app with just few lines of code:
Manipulate[
Show[Graphics3D[], x, ImageSize -> {400, 400},
SphericalRegion -> True, Boxed -> False, ViewAngle -> .27],
{{x, bParts3D[[1]], ""}, Thread[bParts3D -> bParts],
CheckboxBar, Appearance -> "Vertical"}]
data:image/s3,"s3://crabby-images/2e7b2/2e7b24f5e9baa898a67694627dd45c6f5ff5b88b" alt="enter image description here"
You can also get MeshRegion
data:image/s3,"s3://crabby-images/f38ae/f38ae0f30bd55a9766b924daedcb85c97e2c69dc" alt="enter image description here"
to do some computational geometry, for example:
RegionMeasure[%]
1482.164538484
Of course you can check for any anatomical part and also its properties:
EntityProperties["AnatomicalStructure"]
data:image/s3,"s3://crabby-images/a5cda/a5cda2db4ba1d1c180ab5afffeda5b96602a36ed" alt="enter image description here"