Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add doc for neuroglancer, and visualizing structure tensor #32

Merged
merged 5 commits into from
Jan 3, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
81 changes: 81 additions & 0 deletions docs/neuroglancer.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
# Using Neuroglancer to Visualize Orientation Vector in Zarr Format

## 1. Ensure the vector dimension is in a single chunk

Neuroglancer requires that the dimension along the channels (where your vector data resides) must be within a single chunk. Specifically, the chunk size along the channel dimension must be **3**.

## 2. Load the Zarr data into Neuroglancer

Once you have your data chunked correctly, you can load the Zarr dataset into Neuroglancer. Typically, you will:

## 2.1 Start Local Neuroglancer Server
1. Start Neuroglancer.
2. Open Neuroglancer in a browser.
3. Load Zarr if it presents locally `load zarr:///example.path.zarr`

## 2.2 Start Neuroglancer on lincbrain
1. Find the dataset you want to visualize
2. Under `Open With` button, select Neuroglancer

## 3. Rename the channel dimension from `c'` to `c^`

Neuroglancer may label your dimension as `c'` or something else automatically.

Renaming this dimension helps Neuroglancer interpret the data as a vector field (dimension of 3).


## 4. Apply a custom shader for visualization

To actually see your vector data meaningfully rendered, you need a custom shader. Neuroglancer supports a small GLSL-like language for defining how each voxel is colored.

### 4.1 If the vectors already have unit norm

If you know that each voxel’s vector is already normalized (i.e., \(\|\mathbf{v}\| = 1\)), you can use the following simple shader to visualize the absolute value of each component (as RGB channels):

```glsl
void main() {
vec3 color;
color.r = abs(getDataValue(0));
color.g = abs(getDataValue(1));
color.b = abs(getDataValue(2));
emitRGB(color);
}
```

### 4.2 If the vectors do not have unit norm

If your vectors do not have unit norm, and the magnitude of each vector encodes additional information (like reliability of the measurement), you can normalize the color in the shader and use the magnitude as alpha:

```glsl
void main() {
vec4 color;
color.r = abs(getDataValue(0));
color.g = abs(getDataValue(1));
color.b = abs(getDataValue(2));

// Compute the norm (magnitude) of the vector
color.a = sqrt(color.r * color.r + color.g * color.g + color.b * color.b);

// Normalize the color by the magnitude
color.r = color.r / color.a;
color.g = color.g / color.a;
color.b = color.b / color.a;

// Scale alpha by some maximum norm if desired. If you have a known maximum,
// replace MAX_NORM with that value; otherwise you can leave the alpha
// as-is or adjust as needed.
float MAX_NORM = 1.0; // modify this as appropriate
color.a = color.a / MAX_NORM;

emitRGBA(color);
}
```

In Neuroglancer, you can paste this shader code in the layer’s Shader Editor (usually found under the “Layer” panel).


## 5. Example

An example dataset can be found at [here](https://lincbrain.org/dandiset/000010/draft/files?location=sourcedata%2Fderivatives&page=2). The file `sample18_st_filtered.ome.zarr`. Once we change the dimension name to `c^` and apply the shader. We can see the result as following.
![](img/neuroglancer_orientation_vector_example.jpeg)

1 change: 1 addition & 0 deletions mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ theme:
nav:
- Welcome: "index.md"
- Upload data: "upload.md"
- Visualize data in Neuroglancer: "neuroglancer.md"
- Webknossos:
- Add Webknossos dataset: "webknossos-add-dataset.md"
- Deployment: https://github.com/lincbrain/webknossos/blob/ak-dev/LINC_DEPLOYMENT.md
Expand Down
Loading