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

Information and Network Architectures #903

Open
wants to merge 173 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 161 commits
Commits
Show all changes
173 commits
Select commit Hold shift + click to select a range
ef5e909
test
orosoman-dstl Jan 9, 2023
e448647
building blocks
orosoman-dstl Jan 9, 2023
fa1d881
add architecture density and test for density function
spike-dstl Jan 10, 2023
54e1468
Change structure, expand Architecture class
orosoman-dstl Jan 10, 2023
c30fa92
add progress on plot function in architecture class
spike-dstl Jan 13, 2023
506c1ab
Create basic functionality for Architecture.plot method
orosoman-dstl Jan 19, 2023
c6eb678
Add shape colour functionality
spike-dstl Jan 30, 2023
82db2bd
Node title font size and kind of working node labelling system
spike-dstl Jan 30, 2023
4c11c41
Architecture.plot expansion. Allows specification of position, node s…
orosoman-dstl Jan 30, 2023
cebf0dd
Improvement to plot function
spike-dstl Jan 31, 2023
d567c40
Add SensorSuite function
spike-dstl Feb 2, 2023
c84aa39
Beginning of data measurement and propagation for architectures.
orosoman-dstl Feb 6, 2023
50d4701
Fixes to code
spike-dstl Feb 7, 2023
8f31038
Rough propogation for network architectures.
orosoman-dstl Feb 20, 2023
cb6ddf0
bug fixes/neatening for Node.update
orosoman-dstl Feb 21, 2023
727a2c6
making architectures gooder
orosoman-dstl Feb 24, 2023
fb63b3b
bug/fixes for Node.process(). Made SingleProbabilityHypothesis hashable
orosoman-dstl Mar 7, 2023
f5c7e47
Quick fix to architecture _set_dict() method
orosoman-dstl Mar 8, 2023
9324470
add message class
spike-dstl Mar 8, 2023
f1f9d31
Add send_message and open_message functions
spike-dstl Mar 14, 2023
176f91f
Add latency, Edge, Edges
orosoman-dstl Mar 14, 2023
05d2027
Adjustments to send_message and update_message functions to account f…
spike-dstl Mar 15, 2023
4aa0e1b
Further changes to Message and Edge classes.
orosoman-dstl Mar 17, 2023
4a318e1
added fixture to test_architecture
orosoman-dstl Mar 20, 2023
3b74502
halfway to fixing architecture propagation
orosoman-dstl Mar 27, 2023
60d85be
minor test changes and dictionary key change
spike-dstl Mar 23, 2023
66e1231
small changes
orosoman-dstl Mar 28, 2023
a2484b9
bug fixing towards correct measurement
orosoman-dstl Mar 28, 2023
e6fb87b
bug fixing towards correct measurement again
orosoman-dstl Apr 5, 2023
6ccd89c
bug fixin
orosoman-dstl Apr 17, 2023
8630329
propagation now works fully without latency
orosoman-dstl Apr 17, 2023
a07cf0f
bug fixin
orosoman-dstl May 2, 2023
b412716
data is passed only along direct edges
orosoman-dstl May 2, 2023
0e95ad2
MultiTargetFusionTracker started
orosoman-dstl May 2, 2023
99c879c
Debugging with latency successful
orosoman-dstl May 4, 2023
79bdc7a
Move into new architecture sub-module. Begin implementation of threading
orosoman-dstl May 12, 2023
846ba16
Changes to improve plot aesthetics
spike-dstl May 15, 2023
ccb6689
Bug fix to base.py to allow circular imports
spike-dstl May 19, 2023
ebfe7b1
Progress on fusion algorithm
spike-dstl May 25, 2023
d91d2cb
more tracker progress
spike-dstl May 30, 2023
1259fcc
Notes and minor tweaks on fusion tracker
orosoman-dstl Jun 20, 2023
98f576c
Notes and minor tweaks on fusion tracker 2
orosoman-dstl Jun 28, 2023
37afe45
Fusion Tracker updates
spike-dstl Jul 6, 2023
6768800
More work on tracker, still not working
spike-dstl Jul 6, 2023
dba51f5
Add automated hierarchical node positioning for fusion architectures …
spike-dstl Aug 21, 2023
c66d70a
sketch changes to tracker
orosoman-dstl Jul 26, 2023
f20967b
sketch of fusion tracker
orosoman-dstl Jul 28, 2023
2809e5d
Convert stonesoup.architectures from a directory to a Python Package.…
spike-dstl Aug 21, 2023
8007d40
Add tests for architecture.py, small fixes to other architecture file…
spike-dstl Aug 22, 2023
6e8eaec
Delete stonesoup.architecture directory file after replacement with p…
spike-dstl Aug 22, 2023
033426f
neatening of architectures
orosoman-dstl Aug 22, 2023
6594649
Add thread for tracker for FusionNode
sdhiscocks Aug 22, 2023
d22f2fb
Add plot_style parameter to Architecture plot function to allow hiera…
spike-dstl Aug 23, 2023
d0e3cf9
Add more tests for architecture.py
spike-dstl Aug 23, 2023
1bfb83a
renaming to sender/recipient terminology in architectures module
orosoman-dstl Aug 23, 2023
f3d7583
Change logic of InformationArchitecture.is_centralised() to use corre…
spike-dstl Aug 23, 2023
26cc798
beginning tests for node and edge class including conftest file
orosoman-dstl Aug 23, 2023
3bc9ddf
Various modifications for track to track fusion
sdhiscocks Aug 23, 2023
7f4fc10
completion of test_edge_init, additions to architectures conftests
orosoman-dstl Aug 23, 2023
a1be94d
Tests for all plotting and helper functions in stonesoup.architecture…
spike-dstl Aug 23, 2023
063a4bc
Fix issue with duplicating tracks in architectures
sdhiscocks Aug 23, 2023
b8720f4
add to architectures test_edge
orosoman-dstl Aug 24, 2023
bfaae80
minor test_edge changes
orosoman-dstl Aug 24, 2023
7f7cdb8
Move test_architecture.py fixtures to conftest.py and reconfigure tes…
spike-dstl Aug 24, 2023
d375fc4
Allow monitoring of queue consumption for fuse node queues
sdhiscocks Aug 24, 2023
3559ab7
Add a WIP wrapper for switching between two updaters
sdhiscocks Aug 24, 2023
fea112b
Add docstrings to architecture.__init__.py
spike-dstl Aug 24, 2023
b47a61e
test_edge mostly finished
orosoman-dstl Aug 24, 2023
822baf9
Make interface for FusionQueue clearer
sdhiscocks Aug 24, 2023
c22a10f
Allow architecture latency to be any type of number
sdhiscocks Aug 24, 2023
42a50e4
Fix logic with FusionNode in architectures
sdhiscocks Aug 24, 2023
46dc20e
finished test_edge in architectures
orosoman-dstl Aug 24, 2023
6e07082
Added fixtures for fusion network to conftest.py and further tests to…
spike-dstl Aug 24, 2023
f9d05da
finished test_edge in architectures
orosoman-dstl Aug 24, 2023
0204992
Remove timeout constraint on FuseNode in architectures
sdhiscocks Aug 24, 2023
daf46c9
Tests for architecture.__init__.py except for .propagate()
spike-dstl Aug 24, 2023
bf42cc7
finished test_functions
orosoman-dstl Aug 24, 2023
abbee37
Add tests for propagate function, test fails currently
spike-dstl Aug 25, 2023
4125148
Fix propagate tests, Flake8 errors
spike-dstl Aug 25, 2023
3529f9a
finished test_node
orosoman-dstl Aug 25, 2023
6d9c4b7
add networkx and graphviz to requirements
orosoman-dstl Aug 25, 2023
876b34a
Change to how DOT code is written in plot() function
spike-dstl Sep 4, 2023
8288bf3
Version 1 of architecture tutorial. Fixes to allow nodes to be plotted.
spike-dstl Sep 4, 2023
958a2a3
Add pydot to requirements. Updates to architecture plot() and relevan…
spike-dstl Sep 5, 2023
31c4238
Progress on NetworkArchitecture
spike-dstl Oct 16, 2023
f208d5a
NetworkArchitecture propagate() added functionality for nodes that do…
spike-dstl Oct 16, 2023
d8c7ee4
Additional functionality to NetworkArchitecture to enable passing of …
spike-dstl Oct 19, 2023
1439679
Fixes to NetworkArchitecture() to consider edge cases, added tests fo…
spike-dstl Oct 24, 2023
c02db32
Added architecture tutorials: Introduction to Architectures in Stone …
spike-dstl Nov 6, 2023
42df16f
Add use_arival_time property to Achitecture class to allow simulation…
spike-dstl Nov 30, 2023
b5596fe
Add metric table generator for comparing two tracks to a truth
spike-dstl Dec 4, 2023
a390776
Deepcopy datapieces to allow fusion node to recieve both induvidually…
spike-dstl Dec 4, 2023
33d2f72
Minor changes to docs prose
orosoman-dstl Dec 5, 2023
04396d5
Fix image loading in architecture tutorial 3
spike-dstl Dec 5, 2023
9c0e7ee
Fix grammar for architecture documentation
orosoman-dstl Dec 11, 2023
7958015
minor additional spelling and grammar fixes
orosoman-dstl Dec 11, 2023
b5a7c15
Update CircleCI build to include architectures dependencies
jswright-dstl Dec 12, 2023
f0db7b3
Clean up comments and documentation. Get rid of an unnecessary function
orosoman-dstl Dec 15, 2023
7ecbe2a
Fix minor bug in typing
orosoman-dstl Dec 15, 2023
f88368d
Fix failing test by changing method of adjusting data timestamps when…
spike-dstl Dec 21, 2023
d79dfbb
Fix short underlines causing bug in architectures tutorials
spike-dstl Dec 21, 2023
6bcf76f
Change Edge.unsent_data() method to consider edges rather than recipi…
spike-dstl Dec 21, 2023
6aa9a4b
Filter for duplicate data on fusion queue, update network arch propag…
spike-dstl Dec 21, 2023
0317589
Simplify some architecture plotting and enable display in docs
sdhiscocks Jan 22, 2024
09491da
Install graphviz on CircleCI to render architecture diagrams
sdhiscocks Jan 22, 2024
de6a516
Use node labels when plotting in info./net. architecture example
sdhiscocks Jan 26, 2024
6eb99e6
Fix architecture tutorial thumbnail images and remove old images
sdhiscocks Feb 9, 2024
277ba18
Fix architecture tutorial doc build warnings
sdhiscocks Feb 9, 2024
4f380ac
Add InformationArchitectureGenerator and NetworkArchitectureGenerator…
spike-dstl Feb 22, 2024
127aed2
Simplify node label generation and avoid duplicate node names
sdhiscocks Feb 26, 2024
3a200fd
Fixes to generator to produce more realistic decentralised graphs
spike-dstl Feb 28, 2024
af4be32
Progress on MultiArchitectureGenerators
spike-dstl Mar 19, 2024
5f31187
Functionality added to ArchitectureGenerator classes to allow creatio…
spike-dstl Apr 3, 2024
780bcc5
Bug fixes for ArchitectureGenerator classes
spike-dstl Apr 4, 2024
8c8e11d
Add tests for architecture generators
spike-dstl Apr 5, 2024
1eaf361
Add node labels to nodes generated by ArchitectureGenerator classes
spike-dstl Apr 10, 2024
583f215
Add detail to architecture tutorials
spike-dstl Apr 15, 2024
08a13a0
progress towards architecture generator bugs
spike-dstl Apr 15, 2024
bef7265
Fix bug in Architecture.propagate causing unintended lag/OOSM
spike-dstl Apr 17, 2024
378e755
Rework to ArchitectureGenerator logic to produce more feasible archit…
spike-dstl Apr 18, 2024
a8993f6
Merge branch 'architecture_generator' into architecture_repr
spike-dstl Apr 23, 2024
7d92bd2
Apply easier to address suggestions from #903 code review
orosoman-dstl Apr 23, 2024
c539359
Change to SiapDiffTableGenerator to allow more than 2 sets of metrics
spike-dstl Apr 24, 2024
fed2f5a
Merge branch 'architecture_repr' of https://github.com/dstl/Stone-Sou…
spike-dstl Apr 24, 2024
c79c2a5
Update Architecture tutorials to newer versions
spike-dstl May 2, 2024
19f08fa
Minor title change
Aug 22, 2024
d3f9f97
Remove commented cell from architecture tutorial 3
spike-dstl Aug 27, 2024
c175a64
Merge branch 'main' into architecture_repr
spike-dstl Aug 27, 2024
10d96e0
Update architecture branch to use new radar sensor resolution parameter.
spike-dstl Aug 27, 2024
babf8d4
Update stonesoup/architecture/__init__.py
orosoman-dstl Aug 28, 2024
2d6dba4
Update stonesoup/architecture/__init__.py
orosoman-dstl Aug 28, 2024
2707f9c
Update stonesoup/architecture/__init__.py
orosoman-dstl Aug 28, 2024
498b051
Update stonesoup/architecture/__init__.py
orosoman-dstl Aug 28, 2024
6f837f6
fix indent bug
orosoman-dstl Aug 28, 2024
019979a
flake-8 fixes
orosoman-dstl Aug 28, 2024
e993ad9
"Address review comments. Remove unnecessary code"
orosoman-dstl Aug 30, 2024
b3ba8cf
remove tests for fusion tracker
orosoman-dstl Aug 30, 2024
1fae468
Use timedelta to add to a datetime
orosoman-dstl Aug 30, 2024
df8ba83
Slicing GroundTruthPath converts back to StateMutableSequence - corre…
orosoman-dstl Aug 30, 2024
2a95fd0
cleanup and mopve towards tests passing
orosoman-dstl Aug 30, 2024
7166770
minor changes
orosoman-dstl Aug 30, 2024
95319c0
Fix bug caused by timedelta rounding to zero, Update fully propagated…
spike-dstl Sep 2, 2024
b26a993
Fix bug with Edge.unsent_data not accepting RepeaterNodes
spike-dstl Sep 2, 2024
f64d0ea
Fix flake-8 errors on Architecture module after bug fixes
spike-dstl Sep 2, 2024
a03822d
Add docstrings to architecture.__init__.py
spike-dstl Sep 5, 2024
0da6703
Improved coverage on arhitecture tests
spike-dstl Sep 5, 2024
8c794b5
improve coverage
orosoman-dstl Sep 6, 2024
b511737
fix error in test_edge.py
orosoman-dstl Sep 6, 2024
ffd7fc1
Fix to test_message_destinations. Add test_update_messages() to test …
spike-dstl Sep 9, 2024
35e814c
Improve coverage of architecture.node.
spike-dstl Sep 9, 2024
bd622b8
remove unnecessary RuntimeError check in FusionQueue
orosoman-dstl Sep 9, 2024
c334831
Fix architecture tests
sdhiscocks Sep 16, 2024
a4e16d3
fix flake8 and tutorial prose
orosoman-dstl Sep 16, 2024
6ac1984
flake8
orosoman-dstl Sep 16, 2024
ae5f690
bullet point fix
orosoman-dstl Sep 16, 2024
0d33ffd
bullet points...
orosoman-dstl Sep 16, 2024
4d55517
bullet points...
orosoman-dstl Sep 16, 2024
96ab028
bullet points...
orosoman-dstl Sep 16, 2024
6ab5d3b
Add description to architecture tutorial 3
spike-dstl Sep 17, 2024
9bec8ba
minor grammar fixes
orosoman-dstl Sep 17, 2024
01e00d8
backslash needed
orosoman-dstl Sep 17, 2024
f597e16
Arch Tutorial 3: Replace Siap metrics with covariance based metric.
spike-dstl Sep 20, 2024
2888d30
refine architecture tutorial 3
orosoman-dstl Sep 22, 2024
7077bee
fix bullet points againnn
orosoman-dstl Sep 23, 2024
62dd910
fix bullet points againnnnn
orosoman-dstl Sep 23, 2024
f9fabc1
fix list
orosoman-dstl Sep 23, 2024
3e651ae
fix list
orosoman-dstl Sep 23, 2024
f142cd1
bug fix
orosoman-dstl Sep 24, 2024
56ba870
match propogates architecture
orosoman-dstl Sep 25, 2024
494de0b
flake8
orosoman-dstl Sep 25, 2024
7c661aa
the
orosoman-dstl Sep 25, 2024
74808f9
fix list formatting
orosoman-dstl Sep 27, 2024
49dd925
formatting
orosoman-dstl Sep 30, 2024
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
10 changes: 8 additions & 2 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,8 @@ jobs:
python -m venv venv
. venv/bin/activate
pip install --upgrade pip
pip install -e .[dev,orbital] opencv-python-headless pyehm
pip install -e .[dev,orbital,architectures] opencv-python-headless pyehm

- save_cache:
paths:
- ./venv
Expand Down Expand Up @@ -98,14 +99,19 @@ jobs:
- checkout
- restore_cache:
key: dependencies-doc-{{ .Environment.CACHE_VERSION }}-{{ checksum "/home/circleci/.pyenv/version" }}-{{ checksum "setup.cfg" }}
- run:
name: Install OS Dependencies
command: |
sudo apt-get update
sudo apt-get install -y graphviz
- run:
name: Install Dependencies
command: |
python -m venv venv
. venv/bin/activate
pip install --upgrade pip
pip install -r docs/ci-requirements.txt
pip install -e .[dev,orbital] opencv-python-headless
pip install -e .[dev,orbital,architectures] opencv-python-headless
- save_cache:
paths:
- ./venv
Expand Down
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this or the other two pngs still being used?

Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
125 changes: 125 additions & 0 deletions docs/tutorials/architecture/01_Introduction_to_Architectures.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
#!/usr/bin/env python
# coding: utf-8

"""
===============================================
1 - Introduction to Architectures in Stone Soup
===============================================
"""

# %%
# Introduction
# ------------
#
# The architecture package in Stone Soup provides functionality to build information and network
# architectures, enabling the user to simulate sensing, propagation and fusion of data.
# Architectures are modelled by defining the nodes in the architecture, and edges that represent
# connections between nodes.
#
# Nodes
# -----
#
# Nodes represent points in the architecture that collect, process (fuse), or simply forward on
# data. Before advancing, a few definitions are required:
#
# - Relationships between nodes are defined as parent-child. In a directed graph, an edge from
# node A to node B means that data is passed from the child node, A, to the parent node, B.
#
# - The children of node A, denoted :math:`children(A)`, is defined as the set of nodes B, where
# there exists a direct edge from node B to node A (set of nodes that A receives data from).
#
# - The parents of node A, denoted :math:`parents(A)`, is defined as the set of nodes B, where
# there exists a direct edge from node A to node B (set of nodes that A passes data to).
#
# Different types of node can provide different functionality in the architecture. The following
# are available in Stone Soup:
#
# - :class:`.~SensorNode`: makes detections of targets and propagates data onwards through the
# architecture.
#
# - :class:`.~FusionNode`: receives data from child nodes, and fuses to achieve a fused result.
# The fused result can be propagated onwards.
#
# - :class:`.~SensorFusionNode`: has the functionality of both a SensorNode and a FusionNode.
#
# - :class:`.~RepeaterNode`: does not create or fuse data, but only propagates it onwards.
# It is only used in network architectures.
#
# Set up and Node Properties
# ^^^^^^^^^^^^^^^^^^^^^^^^^^

from stonesoup.architecture.node import Node

node_A = Node(label='Node A')
node_B = Node(label='Node B')
node_C = Node(label='Node C')

# %%
# The :class:`.~Node` base class contains several properties. The `latency` property gives
# functionality to simulate processing latency at the node. The rest of the properties (`label`,
# `position`, `colour`, `shape`, `font_size`, `node_dim`), are used for graph plotting.

node_A.colour = '#006494'

node_A.shape = 'hexagon'

# %%
# :class:`~.SensorNode` and :class:`~.FusionNode` objects have additional properties that must be
# defined. A :class:`~.SensorNode` must be given an additional `sensor` property - this must be a
# :class:`~.Sensor`. A :class:`~.FusionNode` has two additional properties: `tracker` and
# `fusion_queue`.`tracker` must both be :class:`~.Tracker`\s - the main tracker manages the
# fusion at the node, while the `fusion_queue` property is a :class:`~.FusionQueue` by default -
# this manages the inflow of data from child nodes.
#
# Edges
# -----
# An edge represents a link between two nodes in an architecture. An :class:`~.Edge` contains a
# property `nodes`: a tuple of :class:`~.Node` objects where the first entry in the tuple is
# the child node and the second is the parent. Edges in Stone Soup are directional (data can
# flow only in one direction), with data flowing from child to parent. Edge objects also
# contain a `latency` property to enable simulation of latency caused by sending a message,
# separately to node latency.

from stonesoup.architecture.edge import Edge

edge1 = Edge(nodes=(node_B, node_A))
edge2 = Edge(nodes=(node_C, node_A))

# %%
# :class:`~.Edges` is a container class for :class:`~.Edge` objects. :class:`~.Edges` has an
# `edges` property - a list of :class:`~.Edge` objects. An :class:`~.Edges` object is required
# to pass into an :class:`~.Architecture`.

from stonesoup.architecture.edge import Edges

edges = Edges(edges=[edge1, edge2])


# %%
# Architecture
# ------------
# Architecture classes manage the simulation of data propagation across a network. Two
# architecture classes are available in Stone Soup: :class:`~.InformationArchitecture` and
# :class:`~.NetworkArchitecture`. Information architecture simulates how
# information is shared across the network, only considering nodes that create or modify
# information. Network architecture simulates how data is actually
# propagated through a network. All nodes are considered including nodes that don't open or modify
# any data.
#
# A good analogy for the two is receiving a parcel via post. The "information architecture" is
# from sender to receiver, the former who creates the parcel, and the latter who opens it.
# However, between these are many unseen but crucial steps which form the "network architecture".
# In this analogy, the postman never does anything with the parcel besides deliver it, so functions
# like a Stone Soup :class:`~.RepeaterNode`.
#
#
# Architecture classes contain an `edges` property - this must be an :class:`~.Edges` object.
# The `current_time` property of an Architecture instance maintains the current time within the
# simulation. By default, this begins at the current time of the operating system.

# sphinx_gallery_thumbnail_path = '_static/sphinx_gallery/ArchTutorial_1.png'

from stonesoup.architecture import InformationArchitecture

arch = InformationArchitecture(edges=edges)
arch
Loading