This main development repository for spread.gl hosts installation files, input data files, output data files, output examples, and tutorials for several visualisation examples.
- Download & install the latest version of Docker Desktop. Different platforms and chipsets are supported.
- Search for the 'spread.gl.web.page' image (or 'florentlee/spread.gl.web.page') through Docker Desktop. You can choose to either 'Pull' or 'Run' the image (select 'Pull' if you don't want to start working with spread.gl immediately). This should take less than a minute to complete.
- 'Run' the spread.gl image. A pop-up window will appear that allows you to define Optional Settings. Go into these settings and enter '8080' as the host port; there is no need to alter any other settings. Click 'Run' and wait until the Logs window shows 'Compiled successfully', this should take roughly 10 seconds.
- Open a browser and go to http://localhost:8080/ to load the spread.gl page; we advise using the latest version of Firefox, regardless of your operating system. You should see the following page in your browser:
We provide a bioconda package called spreadgltools: https://anaconda.org/bioconda/spreadgltools. If you do not have bioconda installed, you can follow the manual installation steps below:
- Download & install Python v3.11. Download & install the latest version of Git for command-line use, or GitHub Desktop if you prefer a graphical user interface to clone our spread.gl repository (see the next step). In case of any problems in the steps below, check your Python version first; we provide alternative installation steps here using
conda
/mamba
and Python v3.12.4). - Open a terminal on your computer and run the following commands:
git clone https://github.com/GuyBaele/SpreadGL.git
to clone this repository to your local computer; or browse to the spread.gl GitHub repository, click '<> Code â–Ľ' and select 'Open with GitHub Desktop' if you chose to use GitHub Desktop in the previous step;
cd SpreadGL
to enter the cloned 'SpreadGL' directory;
python3.11 -m venv .venv
to create a Python v3.11 virtual environment called '.venv';
source .venv/bin/activate
to activate the created virtual environment on Mac;
.\.venv\Scripts\activate
to activate the created virtual environment on Windows;
cd scripts
to change the working directory to the 'scripts' folder containing the relevant scripts;
pip install .
to install our command-line data processing tools. - You should now be able to process your own data for visualisation in spread.gl (but see the next sections).
- We provide readily made output files (as generated from the data examples below) in the 'outputdata' folder, which you downloaded in the previous step. To test spread.gl, you can - for example - drag & drop the file 'Rabies_virus_RABV_in_the_United_States/RABV_US1_gamma_MCC.tree.output.geojson' into the 'Add Data To Map' window that's currently open in your browser. You should see the following visualisation in your browser (when running in dark mode):
- Play around with the visualisation to explore its features. You can - for example - click the eye symbol to also show the 'end' and the 'start -> end arc' layers, which will show a more phylogeny-like visualisation:
- Set up a filter by clicking on the funnel symbol (but see below for more detailed instructions on how to do so), in order to enable animated visualisations in spread.gl.
- Now that you have tested your spread.gl installation, you can prepare the output files as described in the 'Animation examples in spread.gl' section below to become familiar with the different processing steps within spread.gl. We advise to first carefully go through the two visualisation sections below first though.
As mentioned in the previous section: once you have started spread.gl, you will see a world map in your browser window. To add your own visualisation, click the 'Add Data' button and import a file with extension '.output.geojson' via drag-and-drop (see the sections below for how to generate .geojson files for your own analysis). Having done so, you can follow these steps to create different types of visuals:
- Create a layer to display phylogenetic branches. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Arc' as the layer type in the Basic properties window. When specifying the coordinate fields (latitude and longitude) and coloring the branches, the source and target should correspond to the starting and ending points, respectively. You can adjust other parameters, such as opacity and stroke, to customise the visualisation. Once completed, the phylogenetic tree branches will be rendered on this layer.
- (Discrete phylogeography) Create a layer that reflects the cumulative numbers of phylogenetic nodes at different places. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Cluster' in Basic. Specify the coordinate fields (latitude & longitude) of the ending points. Choose a sequential colour bar and set the colours based on 'Point Count' (by default). The radius parameters can be adjusted to set an appropriate size for the clusters. After that, the clusters that represent the cumulative numbers will be displayed on this layer.
(Continuous phylogeography) Create a contour layer to visually represent uncertainty. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Polygon' in Basic. Then, you will see a lot of tangled polygons. Hide the stroke colour, change the fill colour as you want and lower the opacity to clearly see all the inner polygons. You can make the colour change automatically based on 'ending_time' and set the colour scale to quantize. When playing the animation, contours will gradually appear in chronological order.
(Continuous phylogeography without available HPD data) This type of visualisation is meant for a single tree from a continuous phylogeographic analysis, i.e. not a consensus maximum clade credibility (MCC) tree. Create a layer that enables the differentiation of nodes and tips. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Point' in Basic. Specify the coordinate fields (latitude & longitude) of the ending points. In order to effectively distinguish between the nodes and tips, it is recommended to utilise a qualitative colour bar and set the colours based on the 'type' field. As a result, the internal nodes and external tips will be categorised into distinct colours, allowing for clear and unambiguous observation. - Create an animation for the dispersal over time. You need to add a filter to your map by expanding the panel of 'Filters' in the navigation bar and then doing 'Add Filter' on the spread layer. You should then select a field on which to filter data, in this case, a timestamp called "ending_time". Once this filter is applied to the map, you can see a time bar at the bottom of the screen. Set a moving time window and then click the play button, you will be able to see the animation.
- Create an environmental layer after processing tabular data. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Polygon' in Basic. Fill the colours based on your desired field. You can also set the colour scale as quantize and lower the opacity to increase the contrast between this layer and the base map layer. It is also possible to hide the stroke, change its colour and width.
- Create an environmental layer after processing raster data. Select 'Layers' from the navigation bar, click 'Add Layer' and then choose 'Point' in Basic. Specify the coordinate fields (latitude & longitude) with correct fields. Fill the colours based on your desired field. You can also set the colour scale as quantize and lower the opacity to increase the contrast between this layer and the base map layer. The radius parameters can be adjusted to reach a better effect when zooming in/out.
In the 'inputdata' folder, you can find most of the required input files (excluding environmental data in the YFV example) for our different visualisation examples, which are explained in more detail below. Certain files need to be unzipped before processing. The example output videos we provide below were obtained through screen recording on Mac using Screenshot. The HTML files in the 'html' folder were obtained by exporting the visualisation from within spread.gl by clicking the 'Share' button.
We here visualise one of the discrete phylogeographic analyses from Kaleta et al. (2022) Antibody escape and global spread of SARS-CoV-2 lineage A.27. We here list the steps to follow in spread.gl:
- We first need to process the MCC tree file using the "spread" command, which takes the following arguments:
--tree: Specify the filename (with extension) of your input tree file.
--time: Enter the date of the most recent tip. It can be either a formatted date or a decimal year. In this case, it is "2021-06-01".
--format: This OPTIONAL argument specifies the date format found at the end of phylogenetic tree taxa names. The default format is "YYYY-MM-DD". It also supports "DD-MM-YYYY". In this case, we don't need to specify it explicitly.
--location: Type in the annotation that stores the location information (names or coordinates). In this case, the "region" annotation stores the names of regions and countries.
--list: Only compulsory for discrete space analysis. Use a location list with its filename extension as an input. This file should be in the csv format with a comma (",") separator and comprised of three columns with a specific header of "location,latitude,longitude".
--extension: This OPTIONAL argument specifies the output file extension. The default extension is "geojson". In this case, we should choose "csv" to generate a table. So that the Bayes factors can be easily added later.
When this processing step is done, you will see an output file of the spread layer called 'A.27_worldwide.MCC.tree.output.csv'.
spread --tree A.27_worldwide.MCC.tree --time 2021-06-01 --location region --list A.27_worldwide_location_list.csv --extension csv
- We can now visualise the spread layer in spread.gl using the steps explained above (see Section 'Visualising a (phylo)geographical spread layer in spread.gl').
SARS-CoV-2.lineage.A.27.Worldwide.mp4
- Perform a Bayes factor test.
If you have a BEAST log file with rate indicators as a result of the Bayesian stochastic search variable selection (BSSVS) procedure, you will be able to calculate Bayes factors for the diffusion rates between the discrete locations. This test aims to identify relevant rates that are typically used to interpret the diffusion process. Unzip "A.27_worldwide.BEAST.log.zip" and execute the 'rates.py' script using the following command with different arguments:
--log: Specify as input the BEAST log file (.log).
--location: Type in the annotation that stores the location names in the MCC tree, i.e., "region" in this case.
--burnin: Specify the burn-in ratio to set how many initial sampled values need to be discarded from the analysis. This number should be smaller than "1" but not less than "0", e.g. "0.1" should be sufficient for most analyses (but check your .log file in Tracer). An integer that represents the number of rows is also allowed.
--list: Use the same location list from your discrete analysis as input (.csv).
--layer: OPTIONAL; To combine the spread layer with Bayes factors, use the output from step 1 as input (.csv).
The test result will be saved as 'Bayes.factor.test.result.csv'. If you specify the "layer" argument, a combined output file called 'Bayes.factors.added.A.27_worldwide.MCC.tree.output.csv' will be generated for visualisation.
rates --log A.27_worldwide.BEAST.log --burnin 0.1 --location region --list A.27_worldwide_location_list.csv --layer A.27_worldwide.MCC.tree.output.csv
- Set a filter with Bayes factors in visualisation.
To filter the visualisation in step 2, delete the current dataset in spread.gl and load the output file of step 3. In the Filters panel, add a new filter using the field "bayes_factor". Subsequently, set the left lower limit to "3.0" as a default cut-off value above which the diffusion rates are considered to be well supported. Only phylogenetic branches with a Bayes factor of at least 3 will be shown in the figure below. In addition, the clusters now only indicate cumulative counts of non-local transmissions.
We perform the following steps to visualise one of the continuous phylogeographic analyses from Biek et al. (2007) A high-resolution genetic signature of demographic and spatial expansion in epizootic rabies virus. This is an example for which the MCC tree does not have the HPD information for the ancestral locations.
- Process the MCC tree file using the command below. This step works in a similar way as the A.27 example.
Please take notice of the "--location" argument: As there are two annotations (location1 & location2 in this case) to store coordinates, you need to enter them in the order of latitude and longitude with a comma (",") separator in between.
spread --tree RABV_US1_gamma_MCC.tree --time 2004-7 --location location1,location2
- Follow the previous steps to try different visuals of the spread layer. Please pay attention to the "continuous phylogeography without HPD" part of Section 'Visualising a (phylo)geographical spread layer in spread.gl'. You can set the time window of animation as incremental for better observation of dispersal in continuous space.
Rabies.virus.RABV.in.the.United.States.mp4
- Process the MCC tree file using the following command. This step works in the same way as the A.27 example. You should be able to get an output file of the spread layer, named 'PEDV_China.MCC.tree.output.geojson' and used in step 3.
spread --tree PEDV_China.MCC.tree --time 2019-12-14 --location location --list Involved_provincial_capital_coordinates.csv
- Use tabular environmental data to populate vector data.
In this example, we need to add environmental table data to the GeoJSON map.
The tabular dataset, 'Environmental_variables.csv', can be obtained from the original study conducted by He et al. (2021) Phylogeography Reveals Association between Swine Trade and the Spread of Porcine Epidemic Diarrhea Virus in China and across the World.
The vector dataset, 'China_map.geojson', can be generated via this link: http://datav.aliyun.com/portal/school/atlas/area_selector.
Use the command below to execute the 'regions.py' script with 5 required arguments:
--data: Specify the environmental tabular data you want to visualise (.csv, comma-delimited).
--locationColumn: In the CSV file, find the column that stores the location information.
In the 'Environmental_variables.csv' file, this is the "location" column.
--map: Specify the input boundary map in GeoJSON format (.geojson).
--locationVariable: In the GeoJSON input map, find a property that represents the location variable.
In the 'China_map.geojson' file, each location is stored in a "name" variable (as part of the "properties").
--output: Give a name to the output environmental data layer (.geojson).
You should be able to get an output file of the environmental data layer, named 'Environmental_data_layer.geojson' and used in step 3.
regions --data Environmental_variables.csv --locationColumn location --map China_map.geojson --locationVariable name --output Environmental_data_layer.geojson
Porcine.epidemic.diarrhea.virus.PEDV.in.China.mp4
- Process the single tree file using the command below. This step works in the same way as the RABV example.
As we need tabular data for further data wrangling, do not forget to add the argument of "--extension csv".
spread --tree B.1.1.7_England.single.tree --time 2021-01-12 --location coordinates --extension csv
- Reproject coordinates.
Due to the original tree file using the British National Grid coordinate reference system (CRS), which is not supported in spread.gl, you need to perform an additional step (using the file 'B.1.1.7_England.single.tree.output.csv' created in step 2) to convert it to another CRS (i.e., the World Geodetic System 1984; WGS84).
Use the following command to execute the 'reprojection.py' script with 6 required arguments: input csv file, field names of source latitudes (comma separator in between), field names of source longitudes (comma separator in between), source CRS, target CRS and output csv file. When this step is done, there will be a new file called 'B.1.1.7_England.single.tree.output.reprojected.csv'.
reprojection --input B.1.1.7_England.single.tree.output.csv --lat start_lat,end_lat --lon start_lon,end_lon --source 27700 --target 4326 --output B.1.1.7_England.single.tree.output.reprojected.csv
- Remove geographic outliers.
If you visualise the reprojected output file created in step 3, there will be many points that fall outside Endland. These outliers were caused by missing geographic data. To identify them, it becomes necessary to refer to a dataset file 'TreeTime_270221.csv', which is an analysis result from the original study (Kraemer et al.). This file contains the location information of each point, i.e. "UTLA" (Upper Tier Local Authorities in England). You will need to check if this value is empty or not. If it is "NULL", that point will fall outside of England. Therefore, the corresponding row (branch) has to be removed.
Use the following command to execute the 'trimming.py' script with 6 required arguments: input csv file, foreign key field name of input, reference csv file, foreign field name of reference, queried field(s) of reference (comma separator in between, if needed), and output csv file. When this step is done, there will be a new file called 'B.1.1.7_England.single.tree.output.reprojected.cleaned.csv'.
trimming --referencing B.1.1.7_England.single.tree.output.reprojected.csv --foreignkey end_lat_original --referenced TreeTime_270221.csv --primarykey endLat --null startUTLA,endUTLA --output B.1.1.7_England.single.tree.output.reprojected.cleaned.csv
- Visualise the spatial layers in spread.gl.
Follow the previous steps to get different visuals of the spatial layers (see Section 'Visualising a (phylo)geographical spread layer in spread.gl').
SARS-CoV-2.lineage.B.1.1.7.VOC.Alpha.in.England.mp4
- Process the MCC tree file using the command below. This step works in the same way as the RABV example. Data for the 80% highest posterior density (HPD) regions should be extracted from the tree annotations and stored in the GeoJSON output file.
spread --tree YFV.MCC.tree --time 2019-04-16 --location location1,location2
- Crop raster environmental data using a mask map.
As the environmental data of this example are too large to be hosted on GitHub, you need to download historical monthly weather data (maximum temperature, 2010-2019, 2.5 minutes) from: https://www.worldclim.org/data/monthlywth.html. Only keep the raster files from April 2015 to April 2019 and then save them in a folder called 'wc2.1_2.5m_tmax_2015-2019'. You can find a GeoJSON boundary map in the 'inputdata' folder. This kind of boundary map can also be accessed via: https://www.geoboundaries.org/index.html#getdata.
Use the command below to execute the 'raster.py' script with 5 required arguments:
--data: Enter the folder that contains raster data files (.tif).
--map: Specify the input boundary map (.geojson).
--locationVariable: In the GeoJSON input map, find a property that represents the location variable.
In the 'geoBoundaries-BRA-ADM1.geojson' file, each location/state is stored in a "shapeName" variable (as part of the "properties").
--locationList: Provide a location list of interest (.txt, comma-delimited).
--output: Give a name to the output environmental data layer (.csv).
The average maximum temperatures for all months during the virus outbreak will be calculated automatically. To visualise specific Brazilian provinces instead of the entire world, the raster temperature data will be clipped using a mask made from a GeoJSON boundary map and a list of locations. Finally, a CSV file named 'brazil_region_maxtemp.csv' should be created to serve as the environmental data layer.
raster --data wc2.1_2.5m_tmax_2015-2019 --map geoBoundaries-BRA-ADM1.geojson --locationVariable shapeName --locationList Involved_brazilian_states.txt --output brazil_region_maxtemp.csv
- Follow the previous steps to get different visuals of the spatial and environmental layers. For the spatial layer, you can generate a contour layer. For the environmental layer, you will need to choose 'Point' instead of 'Polygon' as the basic layer type. See Sections 'Visualising a (phylo)geographical spread layer in spread.gl' & 'Visualising an environmental data layer in spread.gl' for more information.