Based on the “-out_assignments” of tck2connectome, I created the tracks files belong to pairs of ALL regions. As I checked the track between Precentral_L and Precentral_R, there were still some tracks distributed in other areas of brain, as you can see in below picture:
Hi,
you could use the Volume Render option and show the tractogram. Then press ‘M’ to hide the main image to only display the tractogram. It will maybe give you a clue.
Is this a normal result or is there any error in my scripts?
It’s hard to know for sure. But bear in mind that tck2connectome by default only considers the endpoints of each streamline when assigning to the parcellation. So streamlines can go anywhere they like in the brain, but as long as the endpoints make it back to the two regions of interest, it will be included in that edge of the connectome, and will be extracted by connectome2tck along with the other streamlines corresponding to that edge. The reason why extracting & visualising the endpoints was suggested was in order to determine whether the streamlines you highlighted in fact still terminate in the two regions of interest (even if they don’t follow the expected trajectory), or whether those streamlines were erroneously attributed to that edge.
My suspicion is that there is in fact an issue, and it will be caused by this:
This combined registration & transformation step will be interpolating values when it generates the output image. This means that a voxel in between parcels 1 and 3 may obtain a value of 2, and therefore streamlines terminating there may be assigned to parcel 2, even though parcel 2 is elsewhere in the brain. See documentation here.
Besides, I wonder if the mrview could show the tracks in a 3D way like dsistudio?
In addition to use of the volume render mode, you may need to uncheck the “Crop to slab” option in the Tractography tool.
You are right about the interpolating, after I used the nearest neighbor interpolating, the endpoint were right in the AAL atlas.
I was constructing a fiber connectivity matrix, using the number of fibers connected from region i to region j(from the connectome.csv) as Matrix(i,j),was this number equal to streamlines whose endpoints assigned to the parcellation?
While, if I want to define the connectivity strength of two regions, should I consider streamlines only ended in the two regions, or also consider streamlines passing through the two regions but ended in other regions? If the latter is right, how to calculate it by MRtrix?
While, if I want to define the connectivity strength of two regions, should I consider streamlines only ended in the two regions, or also consider streamlines passing through the two regions but ended in other regions? If the latter is right, how to calculate it by MRtrix?
If you really want the connectome construction to behave in the latter way, you can use the -assignment_all_voxels option for the tck2connectome command. Instead of assigning each of the two streamline endpoints to a parcel, and those two parcels determining the connectome edge to which the streamline contributes, this mechanism instead builds a list of all parcels that the streamline intersects, and if this list contains more than two regions, the streamline then contributes multiple times to the connectivity matrix, based on all possible pairs of parcels within this list.
This is however not something that is advocated. It is there principally to demonstrate the issues associated with assigning streamlines to parcels in this way. It is also true that if one were to explicitly loop over all pairs of parcels, and for every pair count the number of streamlines that intersect both parcels, the result one would obtain would be the same as using this mechanism; the implementation in tck2connectome is however much faster. The looping-over-ROI-pairs approach is something that was done historically prior to my tck2connectome implementation, and I still see described in this fashion sometimes in the literature, though it can be difficult to tell whether or not such descriptions are in fact faithful to the actual computations that were done.
My concern is, though one streamline passing through region a and region b (ended between other two regions,say region c and region d), could this streamline deliver messages from region a to b?
I think this is a conflation between streamlines and biological white matter connections. The reason we by default only consider the two endpoints of each streamline is because axons are known to not synapse within white matter, and therefore only form connections at either end of the cell; as such, a streamline being assigned to more than two regions is vastly more likely to be an artifact of the reconstruction methodology than it is reflective of biology.
This is not to say that a “streamline” could not “deliver messages” between more than two regions within some kind of tailored simulation, if you chose to allow them to. But such a decision would be contrary to the biology that streamlines tractography is intended to represent. There’s no enforcement of what a streamline “could” do, since it’s an entirely fictitious entity. But I personally don’t think that having one digitally reconstructed “connection” mediating communication between more than two nodes in a network makes a whole lot of sense.