<html><head></head><body><div class="ydpbfe5b403yahoo-style-wrap" style="font-family:Helvetica Neue, Helvetica, Arial, sans-serif;font-size:13px;"><div></div>
<div dir="ltr" data-setdir="false">Remember that one important key factor of APRS is _efficiency_! Due to the FCC limits on symbol rates in the various bands (plus the issues in connecting higher baud rate data modems to a radio without a direct discriminator tap), trying to share a channel requires short packets. That was one of the reasons for Mic-E: to have the packet take as few bits as absolutely possible while still complying with AX.25 and still sending something useful. Mic-E actually sends more useful payload data per packet than the JT protocols! That saves air time, and reduces collisions that lower the available bandwidth. If we start using a more verbose protocol, then we have longer packets, and more likelihood of a single bit error that makes the whole thing useless. We could go to FX.25 (or another FEC protocol that gains more efficiency by losing backwards compatibility with AX.25) so we can recover from single bit errors (and possibly two), but that makes our packets even longer with the redundancy, and doesn't make them any more intelligible when a collision occurs.</div><div dir="ltr" data-setdir="false"><br></div><div dir="ltr" data-setdir="false">I'm working on another project actually using PSK1000R and Google Protocol Buffers, and with all the subframe overhead for allowing some subframes to get through in interference, plus station identifications, I can get a maximum payload of useful data of only about 1800 bytes (after compression) in a 30-second superframe (and this was for a protocol design assuming only two stations in handshake for file transfer, like fldigi/flamp, so I didn't have to worry so much about collisions or hidden transmitters). So, don't look at protobufs as a savior. If anything, it will allow the packets to grow rapidly with extra optional fields, so that the channel is clogged faster with longer transmissions and more collisions. And protobufs isn't self-describing at the wire level, any more than APRS or OpenTRAC is. So we'd have to be very stringent about what new fields could be added into each hierarchy level of a protobufs-based protocol (like Scott was with OpenTRAC).<br></div><div dir="ltr" data-setdir="false"><br></div><div dir="ltr" data-setdir="false">So don't go for a potentially fatter protocol unless we can get the bandwidth to use it effectively (like everyone going to 9600 baud). And WB2OSZ already wrote up an excellent whitepaper on why 9600 baud is really only effectively twice as fast as 1200 baud, given our shared channel situation.</div><div dir="ltr" data-setdir="false"><br></div><div dir="ltr" data-setdir="false">Andrew, KA2DDO<br></div><div><br></div>
</div><div id="ydp8ec5ee97yahoo_quoted_5467370875" class="ydp8ec5ee97yahoo_quoted">
<div style="font-family:'Helvetica Neue', Helvetica, Arial, sans-serif;font-size:13px;color:#26282a;">
<div>
On Saturday, February 12, 2022, 12:40:16 PM EST, Scott Howard <showard@nd.edu> wrote:
</div>
<div><br></div>
<div><br></div>
<div><div dir="ltr">On Sat, Feb 12, 2022 at 3:04 AM Heikki Hannikainen <<a shape="rect" href="mailto:hessu@hes.iki.fi" rel="nofollow" target="_blank">hessu@hes.iki.fi</a>> wrote:<br clear="none">><br clear="none">> On Fri, 11 Feb 2022, Weston Bustraan wrote:<br clear="none">><br clear="none">> > I can say that it was not easy to navigate the many exceptions and and<br clear="none">> > oddities in the APRS 1.0.1 spec when implementing a parser, and OpenTRAC<br clear="none">> > seems much more consistent, but the OpenTRAC spec does not seem to be<br clear="none">> > fully complete. For example, I would expect that any new protocol that<br clear="none">> > would supplant APRS would be supporting a UTF-8 character set instead of<br clear="none">> > just ASCII.<br clear="none">><br clear="none">> Yes! Implementing all variations and details of APRS is quite difficult<br clear="none">> indeed, as there are so many completely different position formats, and<br clear="none">> various quirks in which order extension fields should be decoded in, and<br clear="none">> the specifications do not detail all of those. It is unnecessarily complex<br clear="none">> and an awful lot of work.<br clear="none"><br clear="none">protobuffs sounds great, and I think both you and Weston hit on one of<br clear="none">the key points to the future of APRS. I think that whatever protocols<br clear="none">come up next, the priority should be on extensibility so that things<br clear="none">like protobuffs could be used. I think getting away from ASCII towards<br clear="none">binary buffers (UTF-8) would be a way to achieve what Mic-E does<br clear="none">without leaking between protocol layers (allow for more efficient<br clear="none">payloads without hacking DEST), but that would need some kind of<br clear="none">extensible spec. For "official" data types, the schema is published<br clear="none">and well known (maintained in some document somewhere). For<br clear="none">new/experimental extensions, maybe have one packet send out the schema<br clear="none">and the second the payload (kind of like telemetry does). It can use<br clear="none">protobuffs or just our own protobuffs-lite.<br clear="none"><br clear="none">Since much of the new applications of APRS is in embedded systems,<br clear="none">computer modems, and web applications, new protocols can be<br clear="none">implemented and adopted faster than they can be approved by some<br clear="none">centralized body (e.g., if some arduino library compatible with<br clear="none">aprs.fi and direwolf implements something, it'll go live immediately).<br clear="none">I think that would be amazing, and the type of innovation we want to<br clear="none">see. Therefore, some standard as to how that can be done might be<br clear="none">better than trying to formalize every use case or application.<br clear="none"><br clear="none">(Of course, APRS has to support the legacy applications and protocols.)<div class="ydp8ec5ee97yqt8519309952" id="ydp8ec5ee97yqtfd29189"><br clear="none"><br clear="none">_______________________________________________<br clear="none">aprssig mailing list<br clear="none"><a shape="rect" href="mailto:aprssig@lists.tapr.org" rel="nofollow" target="_blank">aprssig@lists.tapr.org</a><br clear="none"><a shape="rect" href="http://lists.tapr.org/mailman/listinfo/aprssig_lists.tapr.org" rel="nofollow" target="_blank">http://lists.tapr.org/mailman/listinfo/aprssig_lists.tapr.org</a><br clear="none"></div></div></div>
</div>
</div></body></html>