Skip to content

Commit

Permalink
Merge pull request #313 from garethsb/signal-ancestry
Browse files Browse the repository at this point in the history
Add a selection of parents to sources and flows
  • Loading branch information
lo-simon authored Dec 3, 2022
2 parents b10eee9 + fd0e32d commit 0fb6b51
Showing 1 changed file with 22 additions and 0 deletions.
22 changes: 22 additions & 0 deletions Development/nmos-cpp-node/node_implementation.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,9 @@ namespace impl
// generate a repeatable source-specific multicast address for each leg of a sender
utility::string_t make_source_specific_multicast_address_v4(const nmos::id& id, int leg = 0);

// add a selection of parents to a source or flow
void insert_parents(nmos::resource& resource, const nmos::id& seed_id, const port& port, int index);

// add a helpful suffix to the label of a sub-resource for the example node
void set_label_description(nmos::resource& resource, const port& port, int index);

Expand Down Expand Up @@ -369,6 +372,7 @@ void node_implementation_init(nmos::node_model& model, slog::base_gate& gate)
{
source = nmos::make_mux_source(source_id, device_id, nmos::clock_names::clk0, frame_rate, model.settings);
}
impl::insert_parents(source, seed_id, port, index);
impl::set_label_description(source, port, index);

nmos::resource flow;
Expand Down Expand Up @@ -426,6 +430,7 @@ void node_implementation_init(nmos::node_model& model, slog::base_gate& gate)
// add optional grain_rate
flow.data[nmos::fields::grain_rate] = nmos::make_rational(frame_rate);
}
impl::insert_parents(flow, seed_id, port, index);
impl::set_label_description(flow, port, index);

// set_transportfile needs to find the matching source and flow for the sender, so insert these first
Expand Down Expand Up @@ -1343,6 +1348,23 @@ namespace impl
return utility::s2us(boost::asio::ip::address_v4(a).to_string());
}

// add a selection of parents to a source or flow
void insert_parents(nmos::resource& resource, const nmos::id& seed_id, const port& port, int index)
{
// algorithm to produce signal ancestry with a range of depths and breadths
// see https://github.com/sony/nmos-cpp/issues/312#issuecomment-1335641637
int b = 0;
while (index & (1 << b)) ++b;
if (!b) return;
index &= ~(1 << (b - 1));
do
{
index &= ~(1 << b);
web::json::push_back(resource.data[nmos::fields::parents], impl::make_id(seed_id, resource.type, port, index));
++b;
} while (index & (1 << b));
}

// add a helpful suffix to the label of a sub-resource for the example node
void set_label_description(nmos::resource& resource, const impl::port& port, int index)
{
Expand Down

0 comments on commit 0fb6b51

Please sign in to comment.