[Proj] PROJ.4 and OpenMP
    Even Rouault 
    even.rouault at spatialys.com
       
    Thu Jul  2 08:34:11 PDT 2015
    
    
  
Le jeudi 02 juillet 2015 16:25:50, José Luis García Pallero a écrit :
> Hello:
> 
> Since version 4.8.0, PROJ.4 has some thread safety facilities
> (https://trac.osgeo.org/proj/wiki/ThreadSafety) and also the source
> code contains an example program in which Posix Threads are used. But
> I'm a bit confused about how to use this thread safety with OpenMP.
> Could someone, please, upload a code example of using PROJ with
> OpenMP? Such example could be also added to the distributed source
> code
José,
I don't have a working example to propose nor I am an OpenMP expert, but based 
on https://en.wikipedia.org/wiki/OpenMP, I guess you must use a thread-private 
identifier to select projPJ objects specific to each thread.
The global workflow could be :
- initialization :
projCtxt* tabProjCtx;
projPJ* tabProjSrc;
projPJ* tabProjDst;
int nThreads;
#pragma omp parallel
{
    #pragma omp single
    nThreads =  omp_get_num_threads()
    /* TODO: allocate tabProjCtx, tabProjSrc and tabProjDst to be nThreads 
large */
    /* TODO: loop over nThreads and initialize each tabProjCtx[i], 
tabProjSrc[i] and tabProjDst[i] */
}
- and then use something like :
int th_id;
#pragma omp parallel for private(th_id)
for(i=0;i<...;i++)
{
     th_id = omp_get_thread_num();
     pj_transform(tabProjSrc[th_id], tabProjDst[th_id], ...)
}
Completely untested of course...
If you manage to get a working example, please contribute it.
Even
-- 
Spatialys - Geospatial professional services
http://www.spatialys.com
    
    
More information about the Proj
mailing list