Re: [MMUSIC] Simplifying draft-westerlund-avtcore-rtp-simulcast

Paul Kyzivat <pkyzivat@alum.mit.edu> Tue, 03 December 2013 17:55 UTC

Return-Path: <pkyzivat@alum.mit.edu>
X-Original-To: mmusic@ietfa.amsl.com
Delivered-To: mmusic@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 8FC131AE15F for <mmusic@ietfa.amsl.com>; Tue, 3 Dec 2013 09:55:22 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: 2.365
X-Spam-Level: **
X-Spam-Status: No, score=2.365 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, J_CHICKENPOX_12=0.6, J_CHICKENPOX_14=0.6, J_CHICKENPOX_15=0.6, J_CHICKENPOX_16=0.6, J_CHICKENPOX_18=0.6, J_CHICKENPOX_19=0.6, SPF_SOFTFAIL=0.665] autolearn=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id UZJ48fw_7jlb for <mmusic@ietfa.amsl.com>; Tue, 3 Dec 2013 09:55:20 -0800 (PST)
Received: from qmta04.westchester.pa.mail.comcast.net (qmta04.westchester.pa.mail.comcast.net [IPv6:2001:558:fe14:43:76:96:62:40]) by ietfa.amsl.com (Postfix) with ESMTP id 014161AE120 for <mmusic@ietf.org>; Tue, 3 Dec 2013 09:55:19 -0800 (PST)
Received: from omta07.westchester.pa.mail.comcast.net ([76.96.62.59]) by qmta04.westchester.pa.mail.comcast.net with comcast id x15C1m0031GhbT8545vH0D; Tue, 03 Dec 2013 17:55:17 +0000
Received: from Paul-Kyzivats-MacBook-Pro.local ([50.138.229.164]) by omta07.westchester.pa.mail.comcast.net with comcast id x5vH1m0043ZTu2S3T5vHFE; Tue, 03 Dec 2013 17:55:17 +0000
Message-ID: <529E1B04.5030702@alum.mit.edu>
Date: Tue, 03 Dec 2013 12:55:16 -0500
From: Paul Kyzivat <pkyzivat@alum.mit.edu>
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.7; rv:24.0) Gecko/20100101 Thunderbird/24.1.1
MIME-Version: 1.0
To: mmusic@ietf.org
References: <BLU169-W11468829F05B411E43D51E693EE0@phx.gbl>, , <867vuen3mevy8h0fwtss4hta.1385800798144@email.android.com>, <BLU169-W119ED7AA7ACE6A2FC53A4CE93E80@phx.gbl>, <BBE9739C2C302046BD34B42713A1E2A22E061AB2@ESESSMB105.ericsson.se> <BLU169-W1237C68C1A3C558FB55021D93D50@phx.gbl>
In-Reply-To: <BLU169-W1237C68C1A3C558FB55021D93D50@phx.gbl>
Content-Type: text/plain; charset="windows-1252"; format="flowed"
Content-Transfer-Encoding: 8bit
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=comcast.net; s=q20121106; t=1386093317; bh=YvYt6y+i2A8kHNMVvaidygNOla63iqgXTdvXOCWLigk=; h=Received:Received:Message-ID:Date:From:MIME-Version:To:Subject: Content-Type; b=SGP/5lXou4Wx/ObMBPfORKFOwY/fozUa/HXaIUvtFqOFtuuHSyMMykgJ2yhmAOaVt G6De4S2cVBVhAP7Ul4WA91fNBzRGH7WRDImhPvT61lsdComnPrHkLTpczxXrfbNwkJ sthTrW2HjTyKX5oqHWKcqmp95p+KApuXy5rIZqFurmmMShQ9bT98l6e3yZKpKEDBX3 FBKqk5XHAxkat5eGvI/u3qNtLzhu7pVq+Ny5Ywzby6CJUvRChq91N4Zub9W8hah/yu RRy9GfDOo3z1o+++isCAstdJhBWlEUsmMjDUvbGVHAjhJklSxcGcLXaC16KHTmzJJq UkwZu4uYeBU6g==
Subject: Re: [MMUSIC] Simplifying draft-westerlund-avtcore-rtp-simulcast
X-BeenThere: mmusic@ietf.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: Multiparty Multimedia Session Control Working Group <mmusic.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/mmusic>, <mailto:mmusic-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/mmusic/>
List-Post: <mailto:mmusic@ietf.org>
List-Help: <mailto:mmusic-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/mmusic>, <mailto:mmusic-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 03 Dec 2013 17:55:22 -0000

ISTM there are major asymmetries here. Whether something can be 
simulcast can only be determined by the sender.

- A sender, when making an offer, can include multiple sendonly streams 
marked as simulcasts of each other.

- A receiver, when presented with an offer containing simulcast, can 
decide which of the simulcast streams it wants to receive and describe 
them as recvonly.

- A receiver making an offer could indicate that it is interested in 
receiving simulcast versions of the same source, but only in special 
cases would it know that it makes sense to send such an offer. Using 
grouping, there could be an ambiguity whether the goal is simply to 
receive *one* of the alternative formats, or if the goal is to receive 
multiple simulcast streams. (Maybe treating them as alternatives can be 
banned because other techniques should be used to indicate that.)

- A sender, when presented with an offer containing simulcast recvonly 
streams can decide if it is capable of satisfying more than one of those.

I *think* the sendrecv case can be treated as just a combination with no 
new semantics. The answerer would analyze the offer once as a simulcast 
receiver and once as a simulcast sender. This could result in arbitrary 
combinations of sendrecv, sendonly, and recvonly in the answer for the 
m-lines in the simulcast group.

	Thanks,
	Paul

On 12/2/13 7:15 PM, Bernard Aboba wrote:
> Bo Burman said:
>
> "Should a simulcast-capable endpoint be restricted to be a
> simulcast-sender-only or a simulcast-receiver-only, or do we envision
> endpoints that are capable of both sending and receiving simulcast? One
> example would be if simulcast streams are to be forwarded between
> different SFU (using Bernard’s terminology below)."
>
> If so and assuming that we define a new 5888-type simulcast grouping, do
> we need separate groupings for send direction simulcast and receive
> direction simulcast, or is a=sendonly and a=recvonly information for
> simulcast-grouped media blocks fully sufficient?
>
> Also, I think the way to use this approach for simulcast in combination
> with multiple separate media sources (like multiple cameras) or media
> sinks (like multiple displays) would be pretty straightforward; just add
> one simulcast grouping per media source/sink."
>
> [BA] In the case where parallel simulcast streams are being both sent
> and received (e.g. between SFUs), there wouldn't be a need for
> a=sendonly or a=recvonly lines;  each m=line would apply to both sending
> and receiving.  So it seems like a single simulcast group would
> suffice.   If you have multiple sources or sinks, then yes, I believe
> you would have one simulcast grouping per media source/sink.
>
> A simple SFU1-SFU2 exchange would look like this:
>
> Offer:
>
> v=0
> o=SFU12362969037 2362969040 IN IP4 192.0.2.156
> s=Simulcast Enabled SFU1
>
> t=0 0
> c=IN IP4 192.0.2.156
> b=AS:665
>
> a=group:SCS1 S2
> m=video 49300 RTP/AVP 97
> b=AS:520
> a=rtpmap:97 H264/90000
>
> a=fmtp:97 profile-level-id=42c01e
> a=imageattr:97 send [x=640,y=360]
>
> a=mid:S1
> m=video 49302 RTP/AVP 98
> a=rtpmap:98 H264/90000
> a=fmtp:98 profile-level-id=42c01e
> a=imageattr:98 send [x=320,y=180]
>
> a=mid:S2
>
> Answer:
>
> v=0
> o=SFU2 823479283 1209384938 IN IP4 192.0.2.2
> s=Answer to Simulcast Enabled SFU1
>
> t=0 0
> c=IN IP4 192.0.2.43
>
> b=AS:665
>
> a=group:SCS1 S2
> m=video 48000 RTP/AVP 97
> b=AS:520
>
> a=rtpmap:97 H264/90000
>
> a=fmtp:97 profile-level-id=42c01e
> a=imageattr:97 recv[x=640,y=360]
>
> a=mid:S1
>
> m=video 48002 RTP/AVP 98
> a=rtpmap:98 H264/90000
>
> a=fmtp:98 profile-level-id=42c01e
> a=imageattr:98 recv[x=320,y=180]
>
> a=mid:S2
>
> *From:*mmusic [mailto:mmusic-bounces@ietf.org] *On Behalf Of *Bernard Aboba
> *Sent:* den 30 november 2013 20:31
> *To:* Christer Holmberg; mmusic@ietf.org
> *Subject:* Re: [MMUSIC] Simplifying draft-westerlund-avtcore-rtp-simulcast
>
> Christer asked:
>
> "In your example, how does the answerer know that the offered m- lines are for simulcast? As far as O/A is concerned, it could just be a number of completely separate (different content etc) uni-directional streams."
>
> [BA] The most obvious way would be grouping.  Looking at RFC 5888/5583, it doesn't appear that either FID or DDP grouping would apply to simulcast.   So perhaps a new group type would be needed.
>
>
>
>
>
> Bernard Aboba <bernard_aboba@hotmail.com  <mailto:bernard_aboba@hotmail.com>> wrote:
>
>
>
> At IETF 88, a number of  participants (including myself) expressed the
> view that draft-westerlund-avtcore-rtp-simulcast was too
> complicated.  Below, I will attempt to explain how simulcast might
> be negotiated in a simplified Offer/Answer exchange based on the
> principles of Unified Plan.
>
> Typically in simulcast we have an endpoint sending multiple streams in
> parallel to the Selective Forwarding Unit (SFU), while receiving one
> among a set of potential streams from the SFU, with the SFU being able
> to switch between the streams that it is sending to the endpoint without
> signaling.  RFC 3264 describes how to handle each of these situations.
>
> With respect to sending multiple streams in parallel, RFC 3264 Section
> 5.1 states the following:
>
> If the offerer wishes to only send media on a stream to its peer,
> it MUST mark the stream as sendonly with the "a=sendonly" attribute.
> We  refer to a stream as being marked with a certain direction if
> a direction attribute was present as either a media stream attribute or
> a session attribute. For sendonly RTP streams, the payload type numbers
> indicate the value of the payload type field in RTP packet the offerer
> is planning to send for that codec...  In all cases, the formats in the
> "m=" line MUST be listed in order of preference, with the first format
> listed being preferred.  In this case, preferred means that the
> recipient of the offer SHOULD use the format with the highest preference
> that is acceptable to it. If multiple media streams of different types
> are present, it means that the offerer wishes to use those streams at
> the same time.  A typical case is an audio and a video stream as part of
> a videoconference.
>
> If multiple media streams of the same type are present in an offer,  it
> means that the offerer wishes to send (and/or receive) multiple streams
> of that type at the same time...  Each stream MAY use different encodings.
>
>
> With respect to receiving one among a set of potential streams, here is
> what RFC 3264 Section 5.1 says:
>
> If the offerer wishes to only receive media from its peer, it MUST mark
> the stream as recvonly... If multiple formats are listed, it means that
> the offerer is capable of making use of any of those formats during the
> session.  In other words, the answerer MAY change formats in the middle
> of the session, making use of any of the formats listed, without sending
> a new offer.  For a sendonly stream, the offer SHOULD indicate those
> formats the offerer is willing to send for this stream.  For a recvonly
> stream,  the offer SHOULD indicate those formats the offerer is willing
> to receive for this stream....
>
> For recvonly RTP streams, the payload type numbers indicate the value of
> the payload type field in RTP packets the offerer is expecting to
> receive for that codec.
>
>
> Based on the above:
>
> 1. An offer from an endpoint to an SFU would include an m=line for each
> potential simulcast stream to be sent, each including an a=sendonly
> line.  The offer would also include a single m=line (with a=recvonly)
> describing the streams that the endpoint is prepared to receive, each
> with their own payload type.
>
> 2. An answer from an SFU to an endpoint would accept or reject each of
> the simulcast streams that the endpoint is proposing to send (with an
> a=recvonly line).  In addition, the answer would include a single m=line
> (with a=sendonly) indicating the streams from among those proposed by
> the endpoint that the SFU is prepared to send.  The SFU can then switch
> between those streams without having to signal the endpoint.
>
> Since it is possible for the Answerer to accept/reject each of the
> proposed streams the Offerer is proposing to send, an Answerer can
> indicate how many streams it is prepared to receive (might only be one
> if simulcast isn't supported).   Similarly, an Answerer can select those
> simulcast streams it is prepared to send (might only be one if simulcast
> isn't supported).
>
> Example Offer (leaving out BUNDLE, rtp/rtcp multiplexing, and audio):
>
>     v=0
>     o=alice 2362969037 2362969040 IN IP4 192.0.2.156
>     s=Simulcast Enabled Unified Plan Client
>     t=0 0
>     c=IN IP4 192.0.2.156
>     b=AS:665
>     m=video 49300 RTP/AVP 97
>     a=sendonly
>     b=AS:520
>     a=rtpmap:97 H264/90000
>     a=fmtp:97 profile-level-id=42c01e
>     a=imageattr:97 send [x=640,y=360]
>     m=video 49302 RTP/AVP 98
>     a=sendonly
>     a=rtpmap:98 H264/90000
>     a=fmtp:98 profile-level-id=42c01e
>     a=imageattr:98 send [x=320,y=180]
>     m=video 49304 RTP/AVP 100 99
>     a=recvonly
>     a=rtpmap:100 H264/90000
>     a=fmtp:100 profile-level-id=42c01e
>     a=imageattr:100 recv [x=640,y=360]
>     a=rtpmap:99 H264/90000
>     a=fmtp:99 profile-level-id=42c01e
>     a=imageattr:99 recv [x=320,y=180]
>
>
> Example Answer:
>
>     v=0
>     o=server 823479283 1209384938 IN IP4 192.0.2.2
>     s=Answer to Simulcast Enabled Unified Plan Client
>     t=0 0
>     c=IN IP4 192.0.2.43
>     b=AS:665
>     m=video 48000 RTP/AVP 97
>     a=recvonly
>     b=AS:520
>     a=rtpmap:97 H264/90000
>     a=fmtp:97 profile-level-id=42c01e
>     a=imageattr:97 recv [x=640,y=360]
>     m=video 48002 RTP/AVP 98
>     a=recvonly
>     a=rtpmap:98 H264/90000
>     a=fmtp:98 profile-level-id=42c01e
>     a=imageattr:98 recv [x=320,y=180]
>     m=video 48004 RTP/AVP 100 99
>     a=sendonly
>     a=rtpmap:100 H264/90000
>     a=fmtp:100 profile-level-id=42c01e
>     a=imageattr:100 send [x=640,y=360]
>     a=rtpmap:99 H264/90000
>     a=fmtp:99 profile-level-id=42c01e
>     a=imageattr:100 send [x=320,y=180]
>
>
>
> _______________________________________________
> mmusic mailing list
> mmusic@ietf.org
> https://www.ietf.org/mailman/listinfo/mmusic
>