All Downloads are FREE. Search and download functionalities are using the official Maven repository.

oms3.util.Threads Maven / Gradle / Ivy

There is a newer version: 0.10.8
Show newest version
/*
 * $Id$
 * 
 * This software is provided 'as-is', without any express or implied
 * warranty. In no event will the authors be held liable for any damages
 * arising from the use of this software.
 * 
 * Permission is granted to anyone to use this software for any purpose,
 * including commercial applications, and to alter it and redistribute it
 * freely, subject to the following restrictions:
 * 
 *  1. The origin of this software must not be misrepresented; you must not
 *     claim that you wrote the original software. If you use this software
 *     in a product, an acknowledgment in the product documentation would be
 *     appreciated but is not required.
 * 
 *  2. Altered source versions must be plainly marked as such, and must not be
 *     misrepresented as being the original software.
 * 
 *  3. This notice may not be removed or altered from any source
 *     distribution.
 */
package oms3.util;

import java.util.ArrayList;
import java.util.Iterator;
import oms3.Compound;
import java.util.List;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import oms3.ComponentAccess;
import oms3.annotations.Finalize;
import oms3.annotations.Initialize;

/**
 * Compound Execution utilities.
 * 
 * @author Olaf David
 * @version $Id$ 
 */
public class Threads {

    public static abstract class CompList implements Iterable {

        List list;
        public List p;

        public CompList(List list) {
            this.list = list;
        }

        public abstract Compound create(T src);

        List list() {
            if (p == null) {
                p = new ArrayList();
                for (T el : list) {
                    p.add(create(el));
                }
            }
            return p;
        }

        @Override
        public Iterator iterator() {
            return list().iterator();
        }
    }

    public static void seq_e(CompList t) {
        for (Compound c : t) {
            c.execute();
        }
    }

    public static void seq_ief(CompList t) throws Exception {
         for (Compound c : t) {
            ComponentAccess.callAnnotated(c, Initialize.class, true);
            c.execute();
            ComponentAccess.callAnnotated(c, Finalize.class, true);
        }
    }
  
    public static void par_ief(CompList t) throws Exception {
        par_ief(t, Runtime.getRuntime().availableProcessors() + 1);
    }

    public static ExecutorService e = Executors.newFixedThreadPool(
            Runtime.getRuntime().availableProcessors() + 1);

    /**
     * Runs a set of Compounds in parallel. there are always numproc + 1 threads active. 
     * @param comp
     * @param numproc
     * @throws java.lang.Exception
     */
     private static void par_ief(CompList t, int numproc) throws Exception {
        if (numproc < 1) {
            throw new IllegalArgumentException("numproc");
        }
        final CountDownLatch latch = new CountDownLatch(t.list().size());
//        final ExecutorService e = Executors.newFixedThreadPool(numproc);
        for (final Compound c : t) {
            e.submit(new Runnable() {

                @Override
                public void run() {
                    try {
                        ComponentAccess.callAnnotated(c, Initialize.class, true);
                        c.execute();
                        ComponentAccess.callAnnotated(c, Finalize.class, true);
                    } catch (Throwable E) {
                        e.shutdownNow();
                    }
                    latch.countDown();
                }
            });
        }
        latch.await();
//        e.shutdown();
    }

    public static void par_e(CompList t) throws Exception {
        par_e(t, Runtime.getRuntime().availableProcessors() + 1);
    }
    
    public static void par_e(CompList t, int numproc) throws Exception {
        if (numproc < 1) {
            throw new IllegalArgumentException("numproc");
        }
        final CountDownLatch latch = new CountDownLatch(t.list().size());
//        final ExecutorService e = Executors.newFixedThreadPool(numproc);
        for (final Compound c : t) {
            e.execute(new Runnable() {

                @Override
                public void run() {
                    try {
                        c.execute();
                    } catch (Throwable E) {
                        e.shutdownNow();
                    }
                    latch.countDown();
                }
            });
        }
        latch.await();
//        e.shutdown();
    }

//    public static final Iterable it(final Iterator i) {
//        return new Iterable() {
//
//            @Override
//            public Iterator iterator() {
//                return i;
//            }
//        };
//    }
    
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy