Escali 4.4 Using the scanalyze, Commrank recv from fromworldFromcommonFields, Analysing all2all

Page 55

Section: 4.4 Using the scanalyze

"Receive lines" has the following fields:

<Comm><rank> recv from <from>(<worldFrom>):<commonFields>

where

 

<Comm>

is the communicator being used

<rank>

is the rank within <Comm>

<from>

is the rank within <Comm>

<worldFrom>

is the rank within MPI_COMM_WORLD

"Send-lines" has the following fields:

<Comm><rank> send to <to>(<worldTo>):<commonFields> where

<Comm>

is the communicator being used

<rank>

is the rank within <Comm>

<to>

is the rank within <Comm>

<worldTo>

is the rank within MPI_COMM_WORLD

The <commonFields> are as follows:

!<count>!<avrLen>!<zroLen>!<inline>!<eager>!<transporter>! where

<count>

is the number of sends/receives

<avrLen>

is the average length of messages in bytes

<zroLen>

is the number of messages sent/received using the zero-bytes

 

mechanism

<inline>

is the number of messages sent/received using the inline

 

mechanism

<eager>

is the number of messages sent/received using the eagerbuffer

 

mechanism

<transporter>

is the number of messages sent/received using the transporter

 

mechanism

More details on the different mechanisms can be found in “Description of Scali MPI Connect” on page 11.

4.4 Using the scanalyze

Tracing and timing the image processing example above produced little data, and interpreting the data posed little problem. However, most applications run for longer time, with correspondingly larger logs as a result; output from tracing and timing with Scali MPI Connect easily amounts to megabytes of data.

In order to extract information from the huge amount of data, Scali has developed a simple analysis tool called scanalyze. This analysis tool accept output from SMC applications run with certain predefined trace and timing variables set.

4.4.1 Analysing all2all

The all2all program in /opt/scali/examples/bin is a simple communication benchmark, but tracing and timing it produces massive log files. For example running

user% SCAMPI_TRACE=”-f arg;timing” mpimon ./all2all -- r1 r2

on a particular system produced a 2354159 byte log file, while running

Scali MPI Connect Release 4.4 Users Guide

43

Image 55
Contents Scali MPI ConnectTM Users Guide Copyright 1999-2005 Scali AS. All rights reserved AcknowledgementScali Bronze Software Certificate II Software License Terms Commencement MaintenanceGrant of License Export Requirements SupportLicense Manager Sub-license and distributionLICENSEE’s Obligations SCALI’s ObligationsTransfer Title to Intellectual Property RightsCompliance with Licenses Warranty of Title and Substantial PerformanceScali MPI Connect Release 4.4 Users Guide Vii Limitation on Remedies and LiabilitiesMiscellaneous Proprietary InformationGoverning Law Scali MPI Connect Release 4.4 Users Guide Table of contents Profiling with Scali MPI Connect Appendix a Example MPI code Scali MPI Connect Release 4.4 Users Guide Scali MPI Connect product context ChapterPlatforms supported Scali mailing lists SMC FAQ SMC release documentsProblem reports SupportFeedback How to read this guideAcronyms and abbreviations LicensingNIC Typographic conventions Terms and conventionsGUI style font Typographic conventions Scali MPI Connect components Description of Scali MPI ConnectSMC network devices Ethernet Devices Direct Access Transport DATNetwork devices Shared Memory DeviceUsing detstat Using detctl3.2 DET 5.1 IB MyrinetInfiniband 4.1 GM6 SCI Communication protocols on DAT-devicesChannel buffer Eagerbuffering protocol Inlining protocolTransporter protocol Support for other interconnects MPI-2 FeaturesZerocopy protocol Scali MPI Connect Release 4.4 Users Guide MPI-2 Features Running Setting up a Scali MPI Connect environmentCompiling and linking Scali MPI Connect environment variablesLinker flags Compiler supportNaming conventions Running Scali MPI Connect programsBasic usage Mpimon monitor programIdentity of parallel processes Program spec Controlling options to mpimonStandard input Standard outputNetwork options How to provide options to mpimonMpirun usage Mpirun wrapper scriptPart part Running with tcp error detection TfdrSuspending and resuming jobs Running with dynamic interconnect failover capabilitiesDebugging with a sequential debugger Debugging and profilingDebugging with Etnus Totalview Using built-in segment protect violation handlerBuilt-in-tools for debugging Assistance for external profilingCommunication resources on DAT-devices Controlling communication resourcesChannelinlinethreshold size to set threshold for inlining Matching MPIRecv with MPIProbe Using MPIIsend, MPIIrecvUsing MPIBsend Good programming practice with SMCUnsafe MPI programs Error and warning messagesUser interface errors and warnings Fatal errorsMpimon options Prefix Giving numeric values to mpimonPostfix Scali MPI Connect Release 4.4 Users Guide Example Profiling with Scali MPI ConnectTracing Using Scali MPI Connect built-in trace+relSecs S eTime where AbsRank MPIcallcommNamerankcall-dependant-parameters whereExample FeaturesTiming Using Scali MPI Connect built-in timingMPIcallDcallsDtimeDfreq TcallsTtimeTfreq Count!avrLen!zroLen!inline!eager!transporter! where Using the scanalyzeCommrank recv from fromworldFromcommonFields Commrank send to toworldTocommonFields whereFor timing This produces the following report Using SMCs built-in CPU-usage functionalityScali MPI Connect Release 4.4 Users Guide Automatic buffer management Tuning communication resourcesFirst iteration is very slow How to optimize MPI performanceBenchmarking Caching the application program on the nodesMemory consumption increase after warm-up Collective operationsFinding the best algorithm Programs in the ScaMPItst package Appendix aImage contrast enhancement Scali MPI Connect Release 4.4 Users Guide Original File formatWhy does not my program start to run? When things do not work troubleshootingAppendix B Why does my program terminate abnormally? Why can I not start mpid?General problems Appendix C Per node installation of Scali MPI ConnectExample Install Scali MPI Connect for TCP/IPInstall Scali MPI Connect for Direct Ethernet Install Scali MPI Connect for MyrinetLicense options Install Scali MPI Connect for InfinibandInstall Scali MPI Connect for SCI Install and configure SCI management softwareTroubleshooting Network providers Uninstalling SMCScali kernel drivers Troubleshooting the GM provider Troubleshooting 3rdparty DAT providersScali MPI Connect Release 4.4 Users Guide Bracket expansion Appendix D Bracket expansion and groupingGrouping Scali MPI Connect Release 4.4 Users Guide Related documentation Appendix EScali MPI Connect Release 4.4 Users Guide List of figures Scali MPI Connect Release 4.4 Users Guide Transporter protocol IndexSSP