Showing posts with label Divide and rule example in java. Show all posts
Showing posts with label Divide and rule example in java. Show all posts

Friday 16 August 2013

Top Most DIVIDE AND RULE IN JAVA 7 CONCURRENCY FOR FIBONACCI SERIES



1) I used here java 6 so for forkjoin api i used here jsr166 library that give you API of java 7 concurrency . alternatively you can use java 7 directly and change the import package accordingly.

2) observe the results by getting the Fibonacci series from 1-10, 1-100, 1-1000, 1-10000,1-100000.



package com.myapp.test;

import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.util.Scanner;

import org.perf4j.StopWatch;

import jsr166y.forkjoin.ForkJoinPool;
import jsr166y.forkjoin.RecursiveTask;

public class ForkAndJoinExample {
class FibonacciProblem {

public long n;
OutputStream out=null;
public FibonacciProblem(long n) {
 this.n = n;
}

public long solve() {
 return fibonacci(n);
}

private long fibonacci(long n) {
 //System.out.println("Thread: " +  Thread.currentThread().getName() + " calculates " + n);
 long f1, f2=0, f3=1;
for(int i=1;i<=n;i++){
System.out.print(" "+f3+" ");
f1 = f2;
f2 = f3;
f3 = f1 + f2;
}
return f3;
}
}

//create class by extending RecursiveTask class of jsr166 to use the parallelism feature
class FibonacciTask extends RecursiveTask<Long> {


private static final long THRESHOLD=100000;

private FibonacciProblem problem;
public long result;

public FibonacciTask(FibonacciProblem problem) {
 this.problem = problem;
}

@Override
public Long compute() {
 if (problem.n <= THRESHOLD) { // easy problem, don't bother with parallelism
  result = problem.solve();
 }
 else {
  FibonacciTask worker1 = new FibonacciTask(new FibonacciProblem(problem.n-1));//here i have defined here two worker thread by deviding the probelm in two part
  FibonacciTask worker2 = new FibonacciTask(new FibonacciProblem(problem.n-2));
  worker1.fork();
  result = worker2.compute() + worker1.join();//now i join the result of both of the worker to get the exact result

 }
 return result;
}

}
public static void main(String[] args) throws IOException {
//taking input from user like 100 or 1000
Scanner scan = new Scanner(System.in);
//writing the result to a file in windows c:\\ drive, file name is result.txt
BufferedWriter out=null;
try {
out=new BufferedWriter(new OutputStreamWriter(new FileOutputStream("c://result.txt")));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

int input = scan.nextInt();
output("solution1 output", out);
solution1(input,out);
out.newLine();
output("solution2 output", out);
solution2(input,out);
out.flush();
out.close();


}
public static void output(String str,BufferedWriter out)throws IOException{
out.write(str);
out.newLine();
}

private static void solution1(long n,BufferedWriter out)throws IOException{
StopWatch stopWatch = new StopWatch();
ForkAndJoinExample example=new ForkAndJoinExample();
ForkAndJoinExample.FibonacciProblem problem=example.new FibonacciProblem(n);
double result = problem.solve();  
stopWatch.stop();

String str=  "Computing Fib number: " + n + "\n";
output(str, out);
str="Computed Result: " + result+ "\n";;

output(str, out);
str="Elapsed Time: " + stopWatch.getElapsedTime()+ "\n";;
output(str, out);
}
private static void solution2(long n,BufferedWriter out)throws IOException{
// Check the number of available processors
 int processors = Runtime.getRuntime().availableProcessors();
 String str="No of processors: " + processors+ "\n";;
 output(str, out);

 StopWatch stopWatch = new StopWatch();  
 ForkAndJoinExample example=new ForkAndJoinExample();

 ForkAndJoinExample.FibonacciProblem problem=example.new FibonacciProblem(n);
 ForkAndJoinExample.FibonacciTask task = example.new FibonacciTask(problem);
 ForkJoinPool pool = new ForkJoinPool(processors);//using processor to solve the problem
 pool.invoke(task);

 double result = task.result;
 str="Computed Result: " + result+ "\n";;
 output(str, out);

 stopWatch.stop();

 str="Elapsed Time: " + stopWatch.getElapsedTime()+ "\n";;
 output(str, out);

}
}


LinkWithin

Related Posts Plugin for WordPress, Blogger...

Labels

Core Java programming core java interview question Core Java Faq's Servlets coding database jsp-servlet spring Java linux unix interview questions java investment bank Web Services Interview investment bank mysql Senior java developer interviews best practices java collection tutorial RMI SQL Eclipse FIX protocol tutorial tibco J2EE groovy java questions SCJP grails java 5 tutorial jdbc beginner error and exception Design Patterns Java Programming Tutorials fundamentals general object oriented programming xml Java Programs Hibernate Examples Flex JAMon Java xml tutorial logging Jsp Struts 2.0 Sybase and SQL Server debugging java interviews performance FIX Protocol interview questions JUnit testing WebSphere date and time tutorial experienced java IO tutorial java concurrency thread Ejb Freshers Papers IT Management Java Exapmle Java Script SQL and database tutorial examples Scwcd ant tutorials concurrency example and tutorial future state homework java changes java threading tricky Agile Business of IT Development JSTL Java JSON tutorial Java multithreading Tutorials PM Scrum data structure and algorithm java puzzles java tips testing tips windows 8 5 way to create Singleton Object Architect Interview Questions and Answers Architecture Architecure Bluetooth server as swing application that searches bluetooth device in 10 meter circle and show all devices. You can send file to any bluetooth device. C Programming CIO Callable Statement in Java Circular dependency of Objects in Java Comparable Example in Collection Custom annotation in Java Developer Interview Divide and rule example in java Drupal Example of Singleton Pattern FIX protocol ForkJoin Example in Java 7 Get data from dynamic table with Java Script Git HTML and JavaScript Health Hello World TCP Client Server Networking Program Hibernate Basics Hibernate Interview Question Answer J2EE Interview Question And Answers J2ME GUI Program JEE Interview QA JMS interview question Java J2EE Hibernate Spring Struts Interview Question Java System Property Java Threads Manager Portlets Provident Fund Read data from any file in same location and give the required result. Reading Properties File in Java Redpoint Rest WebService Client Rest Webservice Test SAL join with ven diagram SCP UNIX COMMAND SSL Singleton Pattern in Java Spring Bean Initialization methods and their order Spring Interview Questions Struts Struts 2.0 Basics Struts 2.0 Design Pattern Submit Html Form With Java Script On The Fly Unix executable For Java Program XOM DOM SAX XP books computers core java; core java; object oriented programming data structure; java investment bank; design pattern dtd duplicate rows in table get browser name with jquery grails podcast inner class java beginners tutorial java cache java networking tutorial java spring java util; java collections; java questions java.java1.5 linked list mailto function with all browser oracle database oracle duplicate rows orm schema social spring mvc questions struts transaction tricks tweet windows xslt