Hi Dave,

> On Jan 8, 2024, at 22:08, Dave Collier-Brown via Starlink 
> <starlink@lists.bufferbloat.net> wrote:
> 
> Cool: I got 
> 
> 01-08-2024 21:04:41 UTC Go Responsiveness to mensura.cdn-apple.com:443...
> Results:
> ========
> Download:
>       Throughput: 150.234 Mbps (18.779 MBps), using 8 parallel connections.
>       RPM: 624 (P90)
>       RPM: 1005 (Single-Sided 5% Trimmed Mean)
> ========
> Upload:
>       Throughput: 13.124 Mbps (1.641 MBps), using 8 parallel connections.
>       RPM: 360 (P90)
>       RPM: 1210 (Single-Sided 5% Trimmed Mean)
> ========
> Final RPM: 392 (P90)
> Final RPM: 1124 (Single-Sided 5% Trimmed Mean)
> 
> 
> Now all I have to do is figure out what it means (;-))

RPM is essentially defined as the inverse of latency averaged over:
download saturation: self latency, foreign latency
upload saturation: self latency, foreign latency

self latency is measuring latency from within the load bearing flows, while 
foreign latency measures against flows not (deeply) involved in the saturating 
load.


The actual transformation is 60000/RTT[ms] => RPM or 60000/RPM => RTT[ms].


So your numbers mean:

Download:
        RTT(P90) 60000/624 = 96.15 ms
        RTT(sTR5) 60000/1005 = 59.70 ms
Upload:
        RTT(P90) 60000/360 = 166.67 ms
        RTT(sTR5) 60000/1210 = 49.59 ms
Download:
        RTT(P90) 60000/392 = 153.06 ms
        RTT(sTR5) 60000/1124 = 53.38 ms

As expected the 90 percentile values are considerably lower than the (fancy) 
averages. Without splitting out self and foreign values it is hard to figure 
out whether that is mostly caused by inter- or intra-flow congestion, but there 
is a current branch (final_self_and_foreign_rpms) that helps out there:

bash-3.2$ ./networkQuality --relative-rpm --rpm.parallel --config 
mensura.cdn-apple.com --port 443 --path /api/v1/gm/config --rpm.timeout 120 
--extended-stats --rpm.mnp 32 --logger-filename 
go_networkQuality_20231228_223707 --detailed
01-09-2024 07:20:11 UTC Go Responsiveness to mensura.cdn-apple.com:443...
Baseline RPM:  4786 (P90)
Baseline RPM:  8385 (Single-Sided 5% Trimmed Mean)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Warning: Could not fetch the extended stats for a probe: OOPS: Could not get 
the TCP info for the connection (not a TLS connection)
Results:
========
Download:
        Note: Test did not run to stability, these results are estimates.
        Throughput: 15.364 Mbps (1.920 MBps), using 32 parallel connections.
        Extended Statistics:
                Maximum Segment Size: 1368
                Total Bytes Retransmitted: 2811
                Retransmission Ratio: 0.11%
                Total Bytes Reordered: 333592209
                Average RTT: 192.0625
        RPM Calculation stats:
                Total Self Probes:            4944
                Total Foreign Probes:         14832
                Trimmed Self Probes Count:    247
                Trimmed Foreign Probes Count: 741
                P90 Self RTT:                 6.849031s
                P90 Foreign RTT:              0.601590s
                P90 RTT:                      3.725311s
                Trimmed Mean Self RTT:        1.906785s
                Trimmed Mean Foreign RTT:     0.132828s
                Trimmed Mean RTT:             1.019806s
        RPM: 16 (P90)
        RPM: 59 (Single-Sided 5% Trimmed Mean)
========
Upload:
        Throughput: 32.503 Mbps (4.063 MBps), using 29 parallel connections.
        Extended Statistics:
                Maximum Segment Size: 1368
                Total Bytes Retransmitted: 1024727
                Retransmission Ratio: 0.24%
                Total Bytes Reordered: 461083
                Average RTT: 176.17241379310346
        RPM Calculation stats:
                Total Self Probes:            7063
                Total Foreign Probes:         21189
                Trimmed Self Probes Count:    353
                Trimmed Foreign Probes Count: 1059
                P90 Self RTT:                 0.770294s
                P90 Foreign RTT:              0.667592s
                P90 RTT:                      0.718943s
                Trimmed Mean Self RTT:        0.112447s
                Trimmed Mean Foreign RTT:     0.120068s
                Trimmed Mean RTT:             0.116258s
        RPM: 83 (P90)
        RPM: 516 (Single-Sided 5% Trimmed Mean)
========
Final RPM Calculation stats:
        Total Self Probes:            12007
        Total Foreign Probes:         36021
        Trimmed Self Probes Count:    600
        Trimmed Foreign Probes Count: 1801
        P90 Self RTT:                 5.504198s
        P90 Foreign RTT:              0.635901s
        P90 RTT:                      3.070049s
        Trimmed Mean Self RTT:        0.119163s
        Trimmed Mean Foreign RTT:     0.123304s
        Trimmed Mean RTT:             0.121233s

Final RPM: 20 (P90) RTT: 3.070049s
Final RPM: 495 (Single-Sided 5% Trimmed Mean) RTT: 0.121233s
Final RPM (Self Only): 11 (P90) RTT: 5.504198s
Final RPM (Self Only): 504 (Single-Sided 5% Trimmed Mean) RTT: 0.119163s
Final RPM (Foreign Only): 94 (P90) RTT: 0.635901s
Final RPM (Foreign Only): 487 (Single-Sided 5% Trimmed Mean) RTT: 0.123304s
Working Conditions RPM Effect:   198% (P90)
Working Conditions RPM Effect:   178% (Single-Sided 5% Trimmed Mean)






> 
> --dave
> 
> On 2024-01-08 14:45, Dave Taht via Starlink wrote:
>> ---------- Forwarded message ---------
>> From: Sebastian Moeller via Bloat 
>> <bl...@lists.bufferbloat.net>
>> 
>> Date: Mon, Jan 8, 2024 at 2:41 PM
>> Subject: [Bloat] goresponsiveness learned a few tricks...
>> To: Dave Taht via Bloat 
>> <bl...@lists.bufferbloat.net>
>> 
>> 
>> 
>> Just a quick shoutout to Will Hawkins goresponsiveness effort
>> (h++ps://github.com/network-quality/goresponsiveness: open source go
>> implementation along the lines of the RPM IETF responsiveness draft
>> (h++ps://github.com/network-quality/draft-ietf-ippm-responsiveness).
>> 
>> The goal I think is a quick latency under working conditions/latency
>> under load for the rest of us. I think the draft likely will get a
>> last call soon, so whoever wants to add something to the spec or just
>> wants to comment, now would be a good time:
>> 
>> goresponsiveness is currently acquiring a few nice features, like the
>> ability to compare the latency between idle and working conditions,
>> run both saturating loads concurrently, and to report the sub results
>> for the "self" probes (measuring latency within the load generating
>> connection/flow) and the "foreign" probes (measuring latency outside
>> of the load generating flows)
>> 
>> bash-3.2$ ./networkQuality --relative-rpm --rpm.parallel --config
>> mensura.cdn-apple.com --port 443 --path /api/v1/gm/config
>> --rpm.timeout 120 --extended-stats --rpm.mnp 32 --logger-filename
>> go_networkQuality_20231228_223707 --detailed
>> 01-08-2024 19:37:07 UTC Go Responsiveness to mensura.cdn-apple.com:443...
>> Baseline RPM:  2813 (P90)
>> Baseline RPM:  3888 (Single-Sided 5% Trimmed Mean)
>> Results:
>> ========
>> Download:
>>         Throughput: 80.367 Mbps (10.046 MBps), using 13 parallel connections.
>>         Extended Statistics:
>>                 Maximum Segment Size: 1208
>>                 Total Bytes Retransmitted: 2860
>>                 Retransmission Ratio: 0.25%
>>                 Total Bytes Reordered: 140968234
>>                 Average RTT: 34.30769230769231
>>         RPM: 264 (P90)
>>         RPM: 509 (Single-Sided 5% Trimmed Mean)
>> ========
>> Upload:
>>         Throughput: 30.124 Mbps (3.766 MBps), using 9 parallel connections.
>>         Extended Statistics:
>>                 Maximum Segment Size: 1208
>>                 Total Bytes Retransmitted: 466855
>>                 Retransmission Ratio: 0.95%
>>                 Total Bytes Reordered: 700
>>                 Average RTT: 37
>>         RPM: 676 (P90)
>>         RPM: 2536 (Single-Sided 5% Trimmed Mean)
>> ========
>> Final RPM Calculation stats:
>>         Total Self Probes:            933
>>         Total Foreign Probes:         2799
>>         Trimmed Self Probes Count:    46
>>         Trimmed Foreign Probes Count: 139
>>         P90 Self RTT:                 0.379444841
>>         P90 Foreign RTT:              0.031294024999999996
>>         Trimmed Mean Self RTT:        0.035124
>>         Trimmed Mean Foreign RTT:     0.017979
>> 
>> Final RPM: 292 (P90)
>> Final RPM: 2260 (Single-Sided 5% Trimmed Mean)
>> Final RPM (Self Only): 158 (P90)
>> Final RPM (Self Only): 1708 (Single-Sided 5% Trimmed Mean)
>> Final RPM (Foreign Only): 1917 (P90)
>> Final RPM (Foreign Only): 3337 (Single-Sided 5% Trimmed Mean)
>> Working Conditions RPM Effect:   162% (P90)
>> Working Conditions RPM Effect:    53% (Single-Sided 5% Trimmed Mean)
>> 
>> 
>> The beauty of the self and foreign reports is that here we can see
>> that my cake'd upstream does a decent job to preserve foreign
>> responsiveness while in the self responsiveness we see how TCP
>> self-congests like there is no tomorrow... Please ignore the download
>> direction, this is over a 100 Mbps USB ethernet dongle and my true
>> download shaper is set to 105 Mbps, so this is mostly the bad USB
>> dongle in action...
>> 
>> 
>> 
>> _______________________________________________
>> Bloat mailing list
>> 
>> bl...@lists.bufferbloat.net
>> https://lists.bufferbloat.net/listinfo/bloat
>> 
>> 
>> 
>> 
> -- 
> David Collier-Brown,         | Always do right. This will gratify
> System Programmer and Author | some people and astonish the rest
> 
> dave.collier-br...@indexexchange.com |              -- Mark Twain
> 
> CONFIDENTIALITY NOTICE AND DISCLAIMER : This telecommunication, including any 
> and all attachments, contains confidential information intended only for the 
> person(s) to whom it is addressed. Any dissemination, distribution, copying 
> or disclosure is strictly prohibited and is not a waiver of confidentiality. 
> If you have received this telecommunication in error, please notify the 
> sender immediately by return electronic mail and delete the message from your 
> inbox and deleted items folders. This telecommunication does not constitute 
> an express or implied agreement to conduct transactions by electronic means, 
> nor does it constitute a contract offer, a contract amendment or an 
> acceptance of a contract offer. Contract terms contained in this 
> telecommunication are subject to legal review and the completion of formal 
> documentation and are not binding until same is confirmed in writing and has 
> been signed by an authorized signatory.
> 
> _______________________________________________
> Starlink mailing list
> Starlink@lists.bufferbloat.net
> https://lists.bufferbloat.net/listinfo/starlink

_______________________________________________
Starlink mailing list
Starlink@lists.bufferbloat.net
https://lists.bufferbloat.net/listinfo/starlink

Reply via email to