<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic BLACS examples are not working in Intel® oneAPI Math Kernel Library</title>
    <link>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092579#M23327</link>
    <description>&lt;P&gt;hi, i want to use BLACS so i tested&amp;nbsp;HELLO example code in here.&lt;/P&gt;

&lt;P&gt;&lt;A href="http://www.netlib.org/blacs/BLACS/Examples.html#HELLO"&gt;http://www.netlib.org/blacs/BLACS/Examples.html#HELLO&lt;/A&gt;&lt;/P&gt;

&lt;P&gt;&amp;nbsp;it seems to easy, but it&amp;nbsp;was not working. i tried to check why, but it&amp;nbsp;was failed.&lt;/P&gt;

&lt;P&gt;(actually, i tried C++ version together, but it also has same problem.&amp;nbsp;c++ code is this.&lt;/P&gt;

&lt;P&gt;&lt;A href="https://andyspiros.wordpress.com/2011/07/08/an-example-of-blacs-with-c/"&gt;https://andyspiros.wordpress.com/2011/07/08/an-example-of-blacs-with-c/&lt;/A&gt;&amp;nbsp;)&lt;/P&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;&amp;nbsp;my fortran code is this.&lt;/P&gt;

&lt;PRE class="brush:fortran;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PROGRAM HELLO 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; -- BLACS example code --
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Written by Clint Whaley 7/26/94 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Performs a simple check-in type hello world 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. External Functions ..
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER BLACS_PNUM
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; EXTERNAL BLACS_PNUM 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. Variable Declaration ..
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER CONTXT, IAM, NPROCS, NPROW, NPCOL, MYPROW, MYPCOL
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER ICALLER, I, J, HISROW, HISCOL 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Determine my process number and the number of processes in 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; machine 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '!' 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_PINFO(IAM, NPROCS) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If in PVM, create virtual machine if it doesn't exist 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF (NPROCS .LT. 1) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF (IAM .EQ. 0) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*, 1000)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; READ(*, 2000) NPROCS
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_SETUP(IAM, NPROCS)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '@' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Set up process grid that is as close to square as possible 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; NPROW = INT( SQRT( REAL(NPROCS) ) )
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; NPCOL = NPROCS / NPROW 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Get default system context, and define grid

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GET(0, 0, CONTXT)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GRIDINIT(CONTXT, 'Row', NPROW, NPCOL)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GRIDINFO(CONTXT, NPROW, NPCOL, MYPROW, MYPCOL) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '#' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If I'm not in grid, go to end of program 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (MYPROW.GE.NPROW) .OR. (MYPCOL.GE.NPCOL) ) GOTO 30

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Get my process ID from my grid coordinates 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ICALLER = BLACS_PNUM(CONTXT, MYPROW, MYPCOL) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If I am process {0,0}, receive check-in messages from 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; all nodes 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '$' 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (MYPROW.EQ.0) .AND. (MYPCOL.EQ.0) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) ' '

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DO 20 I = 0, NPROW-1
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DO 10 J = 0, NPCOL-1
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (I.NE.0) .OR. (J.NE.0) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL IGERV2D(CONTXT, 1, 1, ICALLER, 1, I, J)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Make sure ICALLER is where we think in process grid

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_PCOORD(CONTXT, ICALLER, HISROW, HISCOL)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (HISROW.NE.I) .OR. (HISCOL.NE.J) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) 'Grid error!&amp;nbsp; Halting . . .'

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; STOP
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*, 3000) I, J, ICALLER


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE 
20&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) ' '
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) 'All processes checked in.&amp;nbsp; Run finished.' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; All processes but {0,0} send process ID as a check-in


*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ELSE

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL IGESD2D(CONTXT, 1, 1, ICALLER, 1, 0, 0)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
30&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_EXIT(0)

1000&amp;nbsp; FORMAT('How many processes in machine?') 
2000&amp;nbsp; FORMAT(I) 
3000&amp;nbsp; FORMAT('Process {',i2,',',i2,'} (node number =',I,
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; $&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ') has checked in.')
&amp;nbsp;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; STOP
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END&lt;/PRE&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;compile command is this.&lt;/P&gt;

&lt;P&gt;$ mpiifort hello.f -mkl -lmkl_scalapack_lp64 -lmkl_blacs_intelmpi_ilp64&lt;/P&gt;

&lt;P&gt;$ mpirun -n 8 ./a.out&lt;/P&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;error is this&lt;/P&gt;

&lt;PRE class="brush:bash;"&gt;[blacs_example]$ mpirun -n 8 ./a.out
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x2e, group=0x7fff39f2d2e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x88c9f740, group=0x7ffe88c9f3e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x259c5904, group=0x7fff259c55e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x3ff, group=0x7ffc216c03e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x0, group=0x7fffdec349e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x18bdf740, group=0x7ffe18bdf3e0) failed
PMPI_Comm_group(133): Invalid communicator
&amp;nbsp;@
&amp;nbsp;@
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x3f, group=0x7ffe09bceae0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x0, group=0x7ffd1e8069e0) failed
PMPI_Comm_group(133): Invalid communicator&lt;/PRE&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;please tell me why these are not working...&lt;/P&gt;

&lt;P&gt;thank you&lt;/P&gt;</description>
    <pubDate>Wed, 26 Apr 2017 13:42:19 GMT</pubDate>
    <dc:creator>Yeongha_L_</dc:creator>
    <dc:date>2017-04-26T13:42:19Z</dc:date>
    <item>
      <title>BLACS examples are not working</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092579#M23327</link>
      <description>&lt;P&gt;hi, i want to use BLACS so i tested&amp;nbsp;HELLO example code in here.&lt;/P&gt;

&lt;P&gt;&lt;A href="http://www.netlib.org/blacs/BLACS/Examples.html#HELLO"&gt;http://www.netlib.org/blacs/BLACS/Examples.html#HELLO&lt;/A&gt;&lt;/P&gt;

&lt;P&gt;&amp;nbsp;it seems to easy, but it&amp;nbsp;was not working. i tried to check why, but it&amp;nbsp;was failed.&lt;/P&gt;

&lt;P&gt;(actually, i tried C++ version together, but it also has same problem.&amp;nbsp;c++ code is this.&lt;/P&gt;

&lt;P&gt;&lt;A href="https://andyspiros.wordpress.com/2011/07/08/an-example-of-blacs-with-c/"&gt;https://andyspiros.wordpress.com/2011/07/08/an-example-of-blacs-with-c/&lt;/A&gt;&amp;nbsp;)&lt;/P&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;&amp;nbsp;my fortran code is this.&lt;/P&gt;

&lt;PRE class="brush:fortran;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PROGRAM HELLO 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; -- BLACS example code --
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Written by Clint Whaley 7/26/94 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Performs a simple check-in type hello world 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. External Functions ..
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER BLACS_PNUM
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; EXTERNAL BLACS_PNUM 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .. Variable Declaration ..
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER CONTXT, IAM, NPROCS, NPROW, NPCOL, MYPROW, MYPCOL
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTEGER ICALLER, I, J, HISROW, HISCOL 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Determine my process number and the number of processes in 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; machine 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '!' 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_PINFO(IAM, NPROCS) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If in PVM, create virtual machine if it doesn't exist 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF (NPROCS .LT. 1) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF (IAM .EQ. 0) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*, 1000)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; READ(*, 2000) NPROCS
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_SETUP(IAM, NPROCS)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '@' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Set up process grid that is as close to square as possible 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; NPROW = INT( SQRT( REAL(NPROCS) ) )
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; NPCOL = NPROCS / NPROW 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Get default system context, and define grid

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GET(0, 0, CONTXT)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GRIDINIT(CONTXT, 'Row', NPROW, NPCOL)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_GRIDINFO(CONTXT, NPROW, NPCOL, MYPROW, MYPCOL) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '#' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If I'm not in grid, go to end of program 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (MYPROW.GE.NPROW) .OR. (MYPCOL.GE.NPCOL) ) GOTO 30

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Get my process ID from my grid coordinates 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ICALLER = BLACS_PNUM(CONTXT, MYPROW, MYPCOL) 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If I am process {0,0}, receive check-in messages from 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; all nodes 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) '$' 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (MYPROW.EQ.0) .AND. (MYPCOL.EQ.0) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) ' '

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DO 20 I = 0, NPROW-1
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DO 10 J = 0, NPCOL-1
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (I.NE.0) .OR. (J.NE.0) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL IGERV2D(CONTXT, 1, 1, ICALLER, 1, I, J)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Make sure ICALLER is where we think in process grid

*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_PCOORD(CONTXT, ICALLER, HISROW, HISCOL)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IF ( (HISROW.NE.I) .OR. (HISCOL.NE.J) ) THEN
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) 'Grid error!&amp;nbsp; Halting . . .'

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; STOP
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*, 3000) I, J, ICALLER


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE 
20&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) ' '
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WRITE(*,*) 'All processes checked in.&amp;nbsp; Run finished.' 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; All processes but {0,0} send process ID as a check-in


*&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ELSE

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL IGESD2D(CONTXT, 1, 1, ICALLER, 1, 0, 0)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END IF

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
30&amp;nbsp;&amp;nbsp;&amp;nbsp; CONTINUE
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CALL BLACS_EXIT(0)

1000&amp;nbsp; FORMAT('How many processes in machine?') 
2000&amp;nbsp; FORMAT(I) 
3000&amp;nbsp; FORMAT('Process {',i2,',',i2,'} (node number =',I,
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; $&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ') has checked in.')
&amp;nbsp;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; STOP
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; END&lt;/PRE&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;compile command is this.&lt;/P&gt;

&lt;P&gt;$ mpiifort hello.f -mkl -lmkl_scalapack_lp64 -lmkl_blacs_intelmpi_ilp64&lt;/P&gt;

&lt;P&gt;$ mpirun -n 8 ./a.out&lt;/P&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;error is this&lt;/P&gt;

&lt;PRE class="brush:bash;"&gt;[blacs_example]$ mpirun -n 8 ./a.out
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;!
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
&amp;nbsp;@
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x2e, group=0x7fff39f2d2e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x88c9f740, group=0x7ffe88c9f3e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x259c5904, group=0x7fff259c55e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x3ff, group=0x7ffc216c03e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x0, group=0x7fffdec349e0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x18bdf740, group=0x7ffe18bdf3e0) failed
PMPI_Comm_group(133): Invalid communicator
&amp;nbsp;@
&amp;nbsp;@
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x3f, group=0x7ffe09bceae0) failed
PMPI_Comm_group(133): Invalid communicator
Fatal error in PMPI_Comm_group: Invalid communicator, error stack:
PMPI_Comm_group(179): MPI_Comm_group(comm=0x0, group=0x7ffd1e8069e0) failed
PMPI_Comm_group(133): Invalid communicator&lt;/PRE&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;

&lt;P&gt;please tell me why these are not working...&lt;/P&gt;

&lt;P&gt;thank you&lt;/P&gt;</description>
      <pubDate>Wed, 26 Apr 2017 13:42:19 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092579#M23327</guid>
      <dc:creator>Yeongha_L_</dc:creator>
      <dc:date>2017-04-26T13:42:19Z</dc:date>
    </item>
    <item>
      <title>you mixed lp64 &amp; ilp64 libs (</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092580#M23328</link>
      <description>&lt;P&gt;you mixed lp64 &amp;amp; ilp64 libs (&amp;nbsp;&lt;SPAN style="font-size: 12px;"&gt;-lmkl_scalapack_&lt;STRONG&gt;lp64&lt;/STRONG&gt; -lmkl_blacs_intelmpi_&lt;STRONG&gt;ilp64 ). &amp;nbsp;How to link - pls have a look at the mkl linker adviser -&amp;nbsp;&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;A href="https://software.intel.com/en-us/articles/intel-mkl-link-line-advisor" target="_blank"&gt;https://software.intel.com/en-us/articles/intel-mkl-link-line-advisor&lt;/A&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 27 Apr 2017 03:22:03 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092580#M23328</guid>
      <dc:creator>Gennady_F_Intel</dc:creator>
      <dc:date>2017-04-27T03:22:03Z</dc:date>
    </item>
    <item>
      <title>Quote:Gennady F. (Intel)</title>
      <link>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092581#M23329</link>
      <description>&lt;P&gt;&lt;/P&gt;&lt;BLOCKQUOTE&gt;Gennady F. (Intel) wrote:&lt;BR /&gt;&lt;P&gt;&lt;/P&gt;

&lt;P&gt;you mixed lp64 &amp;amp; ilp64 libs (&amp;nbsp;-lmkl_scalapack_&lt;STRONG&gt;lp64&lt;/STRONG&gt; -lmkl_blacs_intelmpi_&lt;STRONG&gt;ilp64 ). &amp;nbsp;How to link - pls have a look at the mkl linker adviser -&amp;nbsp;&lt;/STRONG&gt;&lt;A href="https://software.intel.com/en-us/articles/intel-mkl-link-line-advisor"&gt;https://software.intel.com/en-us/articles/intel-mkl-link-line-advisor&lt;/A&gt;&lt;/P&gt;

&lt;P&gt;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;/P&gt;

&lt;P&gt;&amp;nbsp;thank you, now it's working,&amp;nbsp;:)&lt;/P&gt;

&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 27 Apr 2017 05:52:14 GMT</pubDate>
      <guid>https://community.intel.com/t5/Intel-oneAPI-Math-Kernel-Library/BLACS-examples-are-not-working/m-p/1092581#M23329</guid>
      <dc:creator>Yeongha_L_</dc:creator>
      <dc:date>2017-04-27T05:52:14Z</dc:date>
    </item>
  </channel>
</rss>

