Changeset 3239 for pjproject/trunk


Ignore:
Timestamp:
Jul 15, 2010 2:45:47 PM (14 years ago)
Author:
nanang
Message:

Re #1103:

  • Added (back) raw jitter statistics into RTCP statistics, with the new name "rx_raw_jitter".
  • Added IPDV statistics into RTCP statistics.
  • Added new compile-time settings to enable/disable raw jitter and IPDV statistics.
  • Updated call dump in pjsua-lib.
Location:
pjproject/trunk
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • pjproject/trunk/pjmedia/include/pjmedia/config.h

    r3067 r3239  
    431431#endif 
    432432 
     433 
     434/** 
     435 * Specify whether RTCP statistics includes raw jitter statistics. 
     436 * Raw jitter is defined as absolute value of network transit time 
     437 * difference of two consecutive packets; refering to "difference D" 
     438 * term in interarrival jitter calculation in RFC 3550 section 6.4.1. 
     439 * 
     440 * Default: 0 (no). 
     441 */ 
     442#ifndef PJMEDIA_RTCP_STAT_HAS_RAW_JITTER 
     443#   define PJMEDIA_RTCP_STAT_HAS_RAW_JITTER     0 
     444#endif 
     445 
     446 
     447/** 
     448 * Specify whether RTCP statistics includes IP Delay Variation statistics. 
     449 * IPDV is defined as network transit time difference of two consecutive 
     450 * packets. The IPDV statistic can be useful to inspect clock skew existance 
     451 * and level, e.g: when the IPDV mean values were stable in positive numbers, 
     452 * then the remote clock (used in sending RTP packets) is faster than local 
     453 * system clock. Ideally, the IPDV mean values are always equal to 0. 
     454 * 
     455 * Default: 0 (no). 
     456 */ 
     457#ifndef PJMEDIA_RTCP_STAT_HAS_IPDV 
     458#   define PJMEDIA_RTCP_STAT_HAS_IPDV           0 
     459#endif 
     460 
     461 
    433462/** 
    434463 * Specify whether RTCP XR support should be built into PJMEDIA. Disabling 
  • pjproject/trunk/pjmedia/include/pjmedia/rtcp.h

    r3237 r3239  
    215215    pj_uint32_t              rtp_tx_last_ts; /**< Last TX RTP timestamp.    */ 
    216216    pj_uint16_t              rtp_tx_last_seq;/**< Last TX RTP sequence.     */ 
     217 
     218#if defined(PJMEDIA_RTCP_STAT_HAS_IPDV) && PJMEDIA_RTCP_STAT_HAS_IPDV!=0 
     219    pj_math_stat             rx_ipdv;/**< Statistics of IP packet delay 
     220                                          variation in receiving direction 
     221                                          (in usec).                        */ 
     222#endif 
     223 
     224#if defined(PJMEDIA_RTCP_STAT_HAS_RAW_JITTER) && PJMEDIA_RTCP_STAT_HAS_RAW_JITTER!=0 
     225    pj_math_stat             rx_raw_jitter;/**< Statistic of raw jitter in 
     226                                                receiving direction  
     227                                                (in usec).                  */ 
     228#endif 
    217229}; 
    218230 
  • pjproject/trunk/pjmedia/src/pjmedia/rtcp.c

    r3237 r3239  
    154154    pj_math_stat_init(&stat->tx.jitter); 
    155155 
     156#if defined(PJMEDIA_RTCP_STAT_HAS_IPDV) && PJMEDIA_RTCP_STAT_HAS_IPDV!=0 
     157    pj_math_stat_init(&stat->rx_ipdv); 
     158#endif 
     159 
     160#if defined(PJMEDIA_RTCP_STAT_HAS_RAW_JITTER) && PJMEDIA_RTCP_STAT_HAS_RAW_JITTER!=0 
     161    pj_math_stat_init(&stat->rx_raw_jitter); 
     162#endif 
     163 
    156164    pj_gettimeofday(&now); 
    157165    stat->start = now; 
     
    361369            pj_int32_t d; 
    362370            pj_uint32_t jitter; 
    363              
     371 
    364372            d = transit - sess->transit; 
    365             sess->transit = transit; 
    366373            if (d < 0)  
    367374                d = -d; 
     
    382389 
    383390 
     391#if defined(PJMEDIA_RTCP_STAT_HAS_RAW_JITTER) && PJMEDIA_RTCP_STAT_HAS_RAW_JITTER!=0 
     392            { 
     393                pj_uint32_t raw_jitter; 
     394 
     395                /* Convert raw jitter unit from samples to usec */ 
     396                if (d < 4294) 
     397                    raw_jitter = d * 1000000 / sess->clock_rate; 
     398                else { 
     399                    raw_jitter = d * 1000 / sess->clock_rate; 
     400                    raw_jitter *= 1000; 
     401                } 
     402                 
     403                /* Update jitter stat */ 
     404                pj_math_stat_update(&sess->stat.rx_raw_jitter, raw_jitter); 
     405            } 
     406#endif 
     407 
     408 
     409#if defined(PJMEDIA_RTCP_STAT_HAS_IPDV) && PJMEDIA_RTCP_STAT_HAS_IPDV!=0 
     410            { 
     411                pj_int32_t ipdv; 
     412 
     413                ipdv = transit - sess->transit; 
     414                /* Convert IPDV unit from samples to usec */ 
     415                if (ipdv > -2147 && ipdv < 2147) 
     416                    ipdv = ipdv * 1000000 / (int)sess->clock_rate; 
     417                else { 
     418                    ipdv = ipdv * 1000 / (int)sess->clock_rate; 
     419                    ipdv *= 1000; 
     420                } 
     421                 
     422                /* Update jitter stat */ 
     423                pj_math_stat_update(&sess->stat.rx_ipdv, ipdv); 
     424            } 
     425#endif 
     426 
    384427#if defined(PJMEDIA_HAS_RTCP_XR) && (PJMEDIA_HAS_RTCP_XR != 0) 
    385428            pjmedia_rtcp_xr_rx_rtp(&sess->xr_session, seq,  
     
    390433                                   -1, 0);                  /* toh     */ 
    391434#endif 
     435 
     436            /* Update session transit */ 
     437            sess->transit = transit; 
    392438        } 
    393439#if defined(PJMEDIA_HAS_RTCP_XR) && (PJMEDIA_HAS_RTCP_XR != 0) 
  • pjproject/trunk/pjsip/src/pjsua-lib/pjsua_call.c

    r3222 r3239  
    22482248               "%s              (msec)    min     avg     max     last    dev\n" 
    22492249               "%s        loss period: %7.3f %7.3f %7.3f %7.3f %7.3f\n" 
    2250                "%s        jitter     : %7.3f %7.3f %7.3f %7.3f %7.3f%s", 
     2250               "%s        jitter     : %7.3f %7.3f %7.3f %7.3f %7.3f" 
     2251#if defined(PJMEDIA_RTCP_STAT_HAS_RAW_JITTER) && PJMEDIA_RTCP_STAT_HAS_RAW_JITTER!=0 
     2252               "\n" 
     2253               "%s        raw jitter : %7.3f %7.3f %7.3f %7.3f %7.3f" 
     2254#endif 
     2255#if defined(PJMEDIA_RTCP_STAT_HAS_IPDV) && PJMEDIA_RTCP_STAT_HAS_IPDV!=0 
     2256               "\n" 
     2257               "%s        IPDV       : %7.3f %7.3f %7.3f %7.3f %7.3f" 
     2258#endif 
     2259               "%s", 
    22512260               indent, info.stream_info[i].fmt.pt, 
    22522261               last_update, 
     
    22782287               stat.rx.jitter.last / 1000.0, 
    22792288               pj_math_stat_get_stddev(&stat.rx.jitter) / 1000.0, 
     2289#if defined(PJMEDIA_RTCP_STAT_HAS_RAW_JITTER) && PJMEDIA_RTCP_STAT_HAS_RAW_JITTER!=0 
     2290               indent, 
     2291               stat.rx_raw_jitter.min / 1000.0, 
     2292               stat.rx_raw_jitter.mean / 1000.0, 
     2293               stat.rx_raw_jitter.max / 1000.0, 
     2294               stat.rx_raw_jitter.last / 1000.0, 
     2295               pj_math_stat_get_stddev(&stat.rx_raw_jitter) / 1000.0, 
     2296#endif 
     2297#if defined(PJMEDIA_RTCP_STAT_HAS_IPDV) && PJMEDIA_RTCP_STAT_HAS_IPDV!=0 
     2298               indent, 
     2299               stat.rx_ipdv.min / 1000.0, 
     2300               stat.rx_ipdv.mean / 1000.0, 
     2301               stat.rx_ipdv.max / 1000.0, 
     2302               stat.rx_ipdv.last / 1000.0, 
     2303               pj_math_stat_get_stddev(&stat.rx_ipdv) / 1000.0, 
     2304#endif 
    22802305               "" 
    22812306               ); 
Note: See TracChangeset for help on using the changeset viewer.