-
Notifications
You must be signed in to change notification settings - Fork 43
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
158 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
.. include:: ../sources/multi/docs/specification.rst | ||
|
||
This returns the following: | ||
|
||
.. include:: ../build/docs-work/multi_source_schema.json | ||
:literal: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,136 @@ | ||
Multi Source Schema | ||
=================== | ||
|
||
A multi-source tile source is used to composite multiple other sources into a | ||
single conceptual tile source. It is specified by a yaml or json file that | ||
conforms to the appropriate schema. | ||
|
||
Examples | ||
-------- | ||
|
||
All of the examples presented here are in yaml; json works just as well. | ||
|
||
Multi Z-position | ||
~~~~~~~~~~~~~~~~ | ||
|
||
For example, if you have a set of individual files that you wish to treat as | ||
multiple z slices in a single file, you can do something like: | ||
|
||
:: | ||
|
||
--- | ||
sources: | ||
- path: ./test_orient1.tif | ||
z: 0 | ||
- path: ./test_orient2.tif | ||
z: 1 | ||
- path: ./test_orient3.tif | ||
z: 2 | ||
- path: ./test_orient4.tif | ||
z: 3 | ||
- path: ./test_orient5.tif | ||
z: 4 | ||
- path: ./test_orient6.tif | ||
z: 5 | ||
- path: ./test_orient7.tif | ||
z: 6 | ||
- path: ./test_orient8.tif | ||
z: 7 | ||
|
||
Here, each of the files is explicitly listed with a specific ``z`` value. | ||
Since these files are ordered, this could equivalently be done in a simpler | ||
manner using a ``pathPattern``, which is a regular expression that can match | ||
multiple files. | ||
|
||
:: | ||
|
||
--- | ||
sources: | ||
- path: . | ||
pathPattern: 'test_orient[1-8]\.tif' | ||
zStep: 1 | ||
|
||
Since the ``z`` value will default to 0, this works. The files are sorted in | ||
C-sort order (lexically using the ASCII or UTF code points). This sorting will | ||
break down if you have files with variable length numbers (e.g., ``file10.tif`` | ||
will appear before ``file9.tiff``. You can instead assign values from the | ||
file name using named expressions: | ||
|
||
:: | ||
|
||
--- | ||
sources: | ||
- path: . | ||
pathPattern: 'test_orient(?P<z1>[1-8])\.tif' | ||
|
||
Note that the name in the expression (``z1`` in this example) is the name of | ||
the value in the schema. If a ``1`` is added, then it is assumed to be 1-based | ||
indexed. Without the ``1``, it is assumed to be zero-indexed. | ||
|
||
Composite To A Single Frame | ||
~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
Multiple sources can be made to appear as a single frame. For instance: | ||
|
||
:: | ||
|
||
--- | ||
width: 360 | ||
height: 360 | ||
sources: | ||
- path: ./test_orient1.tif | ||
position: | ||
x: 0 | ||
y: 0 | ||
- path: ./test_orient2.tif | ||
position: | ||
x: 180 | ||
y: 0 | ||
- path: ./test_orient3.tif | ||
position: | ||
x: 0 | ||
y: 180 | ||
- path: ./test_orient4.tif | ||
position: | ||
x: 180 | ||
y: 180 | ||
|
||
Here, the total width and height of the final image is specified, along with | ||
the upper-left position of each image in the frame. | ||
|
||
Composite With Scaling | ||
~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
Transforms can be applied to scale the individual sources: | ||
|
||
:: | ||
|
||
--- | ||
width: 720 | ||
height: 720 | ||
sources: | ||
- path: ./test_orient1.tif | ||
position: | ||
scale: 2 | ||
- path: ./test_orient2.tif | ||
position: | ||
scale: 2 | ||
x: 360 | ||
- path: ./test_orient3.tif | ||
position: | ||
scale: 2 | ||
y: 360 | ||
- path: ./test_orient4.tif | ||
position: | ||
scale: 360 | ||
x: 180 | ||
y: 180 | ||
|
||
Note that the zero values from the previous example have been omitted as they | ||
are unnecessary. | ||
|
||
Full Schema | ||
----------- | ||
|
||
The full schema (jsonschema Draft6 standard) can be obtained by referencing the | ||
Python at ``large_image_source_multi.MultiSourceSchema``. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters