2023-11-26 23:36:18 +08:00
|
|
|
/// \file
|
|
|
|
///
|
|
|
|
/// This file is part of RakNet Copyright 2003 Kevin Jenkins.
|
|
|
|
///
|
|
|
|
/// Usage of RakNet is subject to the appropriate license agreement.
|
|
|
|
/// Creative Commons Licensees are subject to the
|
|
|
|
/// license found at
|
|
|
|
/// http://creativecommons.org/licenses/by-nc/2.5/
|
|
|
|
/// Single application licensees are subject to the license found at
|
|
|
|
/// http://www.rakkarsoft.com/SingleApplicationLicense.html
|
|
|
|
/// Custom license users are subject to the terms therein.
|
|
|
|
/// GPL license users are subject to the GNU General Public
|
|
|
|
/// License as published by the Free
|
|
|
|
/// Software Foundation; either version 2 of the License, or (at your
|
|
|
|
/// option) any later version.
|
|
|
|
|
|
|
|
#include "RakNetStatistics.h"
|
|
|
|
#include <stdio.h> // sprintf
|
2023-12-07 23:19:46 +08:00
|
|
|
#include "BitStream.h" // BITS_TO_BYTES
|
2023-11-26 23:36:18 +08:00
|
|
|
#include "GetTime.h"
|
|
|
|
|
|
|
|
RakNetTime connectionStartTimeSaved=0;
|
|
|
|
uint64_t totalBitsSentSaved=0;
|
|
|
|
uint64_t bitsReceivedSaved=0;
|
|
|
|
|
|
|
|
// Verbosity level currently supports 0 (low), 1 (medium), 2 (high)
|
|
|
|
// Buffer must be hold enough to hold the output string. See the source to get an idea of how many bytes will be output
|
|
|
|
void StatisticsToString( RakNetStatisticsStruct *s, char *buffer, int verbosityLevel )
|
|
|
|
{
|
|
|
|
if ( s == 0 )
|
|
|
|
{
|
|
|
|
sprintf( buffer, "stats is a NULL pointer in statsToString\n" );
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ( verbosityLevel )
|
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
{
|
|
|
|
RakNetTime time = RakNet::GetTime();
|
|
|
|
double elapsedTime;
|
|
|
|
double bpsSent;
|
|
|
|
double bpsReceived;
|
|
|
|
|
|
|
|
if ( connectionStartTimeSaved == 0 )
|
|
|
|
connectionStartTimeSaved = s->connectionStartTime;
|
|
|
|
|
|
|
|
elapsedTime = (time-connectionStartTimeSaved) / 1000.0f;
|
|
|
|
bpsSent = (double) ((unsigned)s->totalBitsSent-totalBitsSentSaved) / elapsedTime;
|
|
|
|
bpsReceived = (double) ((unsigned)s->bitsReceived-bitsReceivedSaved) / elapsedTime;
|
|
|
|
|
|
|
|
totalBitsSentSaved = s->totalBitsSent;
|
|
|
|
bitsReceivedSaved = s->bitsReceived;
|
|
|
|
connectionStartTimeSaved = RakNet::GetTime();
|
|
|
|
|
|
|
|
// Verbosity level 1
|
|
|
|
sprintf( buffer,
|
|
|
|
"Messages in Send buffer: %u\n"
|
|
|
|
"Messages sent: %u\n"
|
|
|
|
"Bytes sent: %u\n"
|
|
|
|
"Acks sent: %u\n"
|
|
|
|
"Acks in send buffer: %u\n"
|
|
|
|
"Messages waiting for ack: %u\n"
|
|
|
|
"Messages resent: %u\n"
|
|
|
|
"Bytes resent: %u\n"
|
|
|
|
"Packetloss: %.1f%%\n"
|
|
|
|
"Messages received: %u\n"
|
|
|
|
"Bytes received: %u\n"
|
|
|
|
"Acks received: %u\n"
|
|
|
|
"Duplicate acks received: %u\n"
|
|
|
|
"Inst. KBits per second: %.1f\n"
|
|
|
|
"KBits per second sent: %.1f\n"
|
|
|
|
"KBits per second received: %.1f\n",
|
|
|
|
s->messageSendBuffer[ SYSTEM_PRIORITY ] + s->messageSendBuffer[ HIGH_PRIORITY ] + s->messageSendBuffer[ MEDIUM_PRIORITY ] + s->messageSendBuffer[ LOW_PRIORITY ],
|
|
|
|
s->messagesSent[ SYSTEM_PRIORITY ] + s->messagesSent[ HIGH_PRIORITY ] + s->messagesSent[ MEDIUM_PRIORITY ] + s->messagesSent[ LOW_PRIORITY ],
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->totalBitsSent ),
|
|
|
|
s->acknowlegementsSent,
|
|
|
|
s->acknowlegementsPending,
|
|
|
|
s->messagesOnResendQueue,
|
|
|
|
s->messageResends,
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->messagesTotalBitsResent ),
|
|
|
|
100.0f * ( float ) s->messagesTotalBitsResent / ( float ) s->totalBitsSent,
|
|
|
|
s->duplicateMessagesReceived + s->invalidMessagesReceived + s->messagesReceived,
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->bitsReceived + s->bitsWithBadCRCReceived ),
|
|
|
|
s->acknowlegementsReceived,
|
|
|
|
s->duplicateAcknowlegementsReceived,
|
|
|
|
s->bitsPerSecond / 1000.0,
|
|
|
|
bpsSent / 1000.0,
|
|
|
|
bpsReceived / 1000.0);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
{
|
|
|
|
RakNetTime time = RakNet::GetTime();
|
|
|
|
double elapsedTime;
|
|
|
|
double bpsSent;
|
|
|
|
double bpsReceived;
|
|
|
|
elapsedTime = (time-s->connectionStartTime) / 1000.0f;
|
|
|
|
bpsSent = (double) s->totalBitsSent / elapsedTime;
|
|
|
|
bpsReceived= (double) s->bitsReceived / elapsedTime;
|
|
|
|
|
|
|
|
// Verbosity level 2.
|
|
|
|
sprintf( buffer,
|
|
|
|
"Bytes sent:\t\t\t\t%u\n"
|
|
|
|
"Messages in send buffer:\t\tSP:%u HP:%u MP:%u LP:%u\n"
|
|
|
|
"Messages sent:\t\t\t\tSP:%u HP:%u MP:%u LP:%u\n"
|
|
|
|
"Message data bytes sent:\t\tSP:%u HP:%u MP:%u LP:%u\n"
|
|
|
|
"Message header bytes sent:\t\tSP:%u HP:%u MP:%u LP:%u\n"
|
|
|
|
"Message total bytes sent:\t\tSP:%u HP:%u MP:%u LP:%u\n"
|
|
|
|
"Bytes received:\t\t\t\tTtl:%u Good:%u Bad:%u\n"
|
|
|
|
"Packets received:\t\t\tTtl:%u Good:%u Bad:%u\n"
|
|
|
|
"Acks received:\t\t\t\tTtl:%u Good:%u Dup:%u\n"
|
|
|
|
"Messages received:\t\t\tTotal:%u Valid:%u Invalid:%u Dup:%u\n"
|
|
|
|
"Packetloss:\t\t\t\t%.1f%%\n"
|
|
|
|
"Packets sent:\t\t\t\t%u\n"
|
|
|
|
"Acks sent:\t\t\t\t%u\n"
|
|
|
|
"Acks in send buffer:\t\t\t%u\n"
|
|
|
|
"Messages waiting for ack:\t\t%u\n"
|
|
|
|
"Ack bytes sent:\t\t\t\t%u\n"
|
|
|
|
"Sent packets containing only acks:\t%u\n"
|
|
|
|
"Sent packets w/only acks and resends:\t%u\n"
|
|
|
|
"Reliable messages resent:\t\t%u\n"
|
|
|
|
"Reliable message data bytes resent:\t%u\n"
|
|
|
|
"Reliable message header bytes resent:\t%u\n"
|
|
|
|
"Reliable message total bytes resent:\t%u\n"
|
|
|
|
"Number of messages split:\t\t%u\n"
|
|
|
|
"Number of messages unsplit:\t\t%u\n"
|
|
|
|
"Message splits performed:\t\t%u\n"
|
|
|
|
"Additional encryption bytes:\t\t%u\n"
|
|
|
|
"Sequenced messages out of order:\t%u\n"
|
|
|
|
"Sequenced messages in order:\t\t%u\n"
|
|
|
|
"Ordered messages out of order:\t\t%u\n"
|
|
|
|
"Ordered messages in of order:\t\t%u\n"
|
|
|
|
"Split messages waiting for reassembly:\t%u\n"
|
|
|
|
"Messages in internal output queue:\t%u\n"
|
|
|
|
"Inst KBits per second:\t\t\t%.1f\n"
|
|
|
|
"Elapsed time (sec):\t\t\t%.1f\n"
|
|
|
|
"KBits per second sent:\t\t\t%.1f\n"
|
|
|
|
"KBits per second received:\t\t%.1f\n",
|
|
|
|
BITS_TO_BYTES( s->totalBitsSent ),
|
|
|
|
s->messageSendBuffer[ SYSTEM_PRIORITY ], s->messageSendBuffer[ HIGH_PRIORITY ], s->messageSendBuffer[ MEDIUM_PRIORITY ], s->messageSendBuffer[ LOW_PRIORITY ],
|
|
|
|
s->messagesSent[ SYSTEM_PRIORITY ], s->messagesSent[ HIGH_PRIORITY ], s->messagesSent[ MEDIUM_PRIORITY ], s->messagesSent[ LOW_PRIORITY ],
|
|
|
|
BITS_TO_BYTES( s->messageDataBitsSent[ SYSTEM_PRIORITY ] ), BITS_TO_BYTES( s->messageDataBitsSent[ HIGH_PRIORITY ] ), BITS_TO_BYTES( s->messageDataBitsSent[ MEDIUM_PRIORITY ] ), BITS_TO_BYTES( s->messageDataBitsSent[ LOW_PRIORITY ] ),
|
|
|
|
BITS_TO_BYTES( s->messageTotalBitsSent[ SYSTEM_PRIORITY ] - s->messageDataBitsSent[ SYSTEM_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ HIGH_PRIORITY ] - s->messageDataBitsSent[ HIGH_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ MEDIUM_PRIORITY ] - s->messageDataBitsSent[ MEDIUM_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ LOW_PRIORITY ] - s->messageDataBitsSent[ LOW_PRIORITY ] ),
|
|
|
|
BITS_TO_BYTES( s->messageTotalBitsSent[ SYSTEM_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ HIGH_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ MEDIUM_PRIORITY ] ), BITS_TO_BYTES( s->messageTotalBitsSent[ LOW_PRIORITY ] ),
|
|
|
|
BITS_TO_BYTES( s->bitsReceived + s->bitsWithBadCRCReceived ), BITS_TO_BYTES( s->bitsReceived ), BITS_TO_BYTES( s->bitsWithBadCRCReceived ),
|
|
|
|
s->packetsReceived + s->packetsWithBadCRCReceived, s->packetsReceived, s->packetsWithBadCRCReceived,
|
|
|
|
s->acknowlegementsReceived + s->duplicateAcknowlegementsReceived, s->acknowlegementsReceived, s->duplicateAcknowlegementsReceived,
|
|
|
|
s->messagesReceived + s->invalidMessagesReceived + s->duplicateMessagesReceived, s->messagesReceived, s->invalidMessagesReceived, s->duplicateMessagesReceived,
|
|
|
|
100.0f * ( float ) s->messagesTotalBitsResent / ( float ) s->totalBitsSent,
|
|
|
|
s->packetsSent,
|
|
|
|
s->acknowlegementsSent,
|
|
|
|
s->acknowlegementsPending,
|
|
|
|
s->messagesOnResendQueue,
|
|
|
|
BITS_TO_BYTES( s->acknowlegementBitsSent ),
|
|
|
|
s->packetsContainingOnlyAcknowlegements,
|
|
|
|
s->packetsContainingOnlyAcknowlegementsAndResends,
|
|
|
|
s->messageResends,
|
|
|
|
BITS_TO_BYTES( s->messageDataBitsResent ),
|
|
|
|
BITS_TO_BYTES( s->messagesTotalBitsResent - s->messageDataBitsResent ),
|
|
|
|
BITS_TO_BYTES( s->messagesTotalBitsResent ),
|
|
|
|
s->numberOfSplitMessages,
|
|
|
|
s->numberOfUnsplitMessages,
|
|
|
|
s->totalSplits,
|
|
|
|
BITS_TO_BYTES( s->encryptionBitsSent ),
|
|
|
|
s->sequencedMessagesOutOfOrder,
|
|
|
|
s->sequencedMessagesInOrder,
|
|
|
|
s->orderedMessagesOutOfOrder,
|
|
|
|
s->orderedMessagesInOrder,
|
|
|
|
s->messagesWaitingForReassembly,
|
|
|
|
s->internalOutputQueueSize,
|
|
|
|
s->bitsPerSecond/1000.0,
|
|
|
|
elapsedTime,
|
|
|
|
bpsSent / 1000.0,
|
|
|
|
bpsReceived / 1000.0
|
|
|
|
);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case 4:
|
|
|
|
{
|
|
|
|
sprintf( buffer,
|
|
|
|
"Messages in Send buffer: %u\n"
|
|
|
|
"Messages sent: %u\n"
|
|
|
|
"Bytes sent: %u\n"
|
|
|
|
"Acks sent: %u\n"
|
|
|
|
"Acks in send buffer: %u\n"
|
|
|
|
"Messages waiting for ack: %u\n"
|
|
|
|
"Messages resent: %u\n"
|
|
|
|
"Bytes resent: %u\n"
|
|
|
|
"Packetloss: %.1f%%\n"
|
|
|
|
"Messages received: %u\n"
|
|
|
|
"Bytes received: %u\n"
|
|
|
|
"Acks received: %u\n"
|
|
|
|
"Duplicate acks received: %u\n",
|
|
|
|
s->messageSendBuffer[ SYSTEM_PRIORITY ] + s->messageSendBuffer[ HIGH_PRIORITY ] + s->messageSendBuffer[ MEDIUM_PRIORITY ] + s->messageSendBuffer[ LOW_PRIORITY ],
|
|
|
|
s->messagesSent[ SYSTEM_PRIORITY ] + s->messagesSent[ HIGH_PRIORITY ] + s->messagesSent[ MEDIUM_PRIORITY ] + s->messagesSent[ LOW_PRIORITY ],
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->totalBitsSent ),
|
|
|
|
s->acknowlegementsSent,
|
|
|
|
s->acknowlegementsPending,
|
|
|
|
s->messagesOnResendQueue,
|
|
|
|
s->messageResends,
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->messagesTotalBitsResent ),
|
|
|
|
100.0f * ( float ) s->messagesTotalBitsResent / ( float ) s->totalBitsSent,
|
|
|
|
s->duplicateMessagesReceived + s->invalidMessagesReceived + s->messagesReceived,
|
|
|
|
( unsigned ) BITS_TO_BYTES( s->bitsReceived + s->bitsWithBadCRCReceived ),
|
|
|
|
s->acknowlegementsReceived,
|
|
|
|
s->duplicateAcknowlegementsReceived);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|