Demonstrate the shared memory model of programming in Parallel Processing

#include<stdio.h>
#include "shmlib.h"

int main(){
in final_sum, *sum0, sum1, id, id1, id2;
sum0 = (int*)shared(sizeof(int),&id1);
sum1 = (int*)shared(sizeof(int),&id2);
id = create_process(1);
if(id == 0){
*sum0 = 10+15;
printf("\n Sum0 : %d",*sum0);
}
if(id == 1){
*sum1 = 6 + 7;
printf("\n Sum1 : %d", *sum1);
}
join_process(2,id);
final_sum = *sum + *sum1;
printf("\n Final Result : %d",final_sum);
printf("\n");
free_shm(id1);
free_shm(id2);
return 0;
}

0 comments:

Demonstrate the concept of Mutual Exclusion in Parallel Processing

For this program you must have some knowledge of mutual exclusion and pointers

#include<stdio.h>
#include "shmlib.h"

main(){
int *lock1,id, sid1, sid2, *i, j;

//this allocates memory of int size and this is a shared memory which is accessed from sd1
lock1 = (int*)shared(sizeof(int),&sid1);

//initializing lock
init_lock(lock1);

//this allocates memory of int size and this is a shared memory which is accessed from sd2
i=(int*)shared(sizeof(int),&sid2);

*i=110;
j=110;

printf("before fork : %d %d\n",*i,j);
id=create_process(2);
lock(lock1);

*i=id;
j=id*2;

printf("After Fork : %d %d\n", i*,j);

//lock released
unlock(lock1);

join_process(3,id);
printf("After Join : %d %d\n",*i,j);

//memory released
free_shm(sid1);
free_shm(sid2);
}

0 comments:

Creation and Destruction of Process In Unix

#include<stdio.h>
#include "shmlib.h"


main(){

int id, n;
//id is used for numbering each process, n is used for user to enter total number of processes

printf("This program creates user entered number minus one child processes,");
printf("\n Assign Task to each child process and once the the processing is complete, all child process are killed");
printf("\n Enter the nmber of processes : ");
// here user enter number of processes

scanf("%d",&n);
// creates process
id = create_process(n);

//conditions to check parallel execution by child if the id is greater than 0
id(id > 0){
printf("\n Parallel Execution");
printf("\n O/P from child %d My Id is : %d \n",id,id);
}
//condition to check for parent process
else if(id == 0){
printf("\n O/P from Parent Process : My id = %d",id);
}
join_process(n,id)
printf("\n Sequential Execution");
printf("Finished");
}

0 comments:

Crossover

Write a program in Lisp to demonstrate the crossover genetic operator.

 (Enter population of binary strings. Perform crossover based on a random crossing site value. Consider fitness value as the number of repetitions of specified bit in the string. Perform the evolution for a specified number generation).


CODE:

(defun Cross(List1 List2)
(setq Cnt 0)
(setq newList1 '())
(setq newList2 '())
(setq cp (random (length List1)))
(print "CrossOver Point")
(prin1 cp)
(loop
                                (when (equal (first List1) nil)(return))
                                (if (<= cp Cnt)
                                                (block blkOne
                                                                (setq newList1 (cons (first List2) newList1))
                                                                (setq newList2 (cons (first List1) newList2))
                                                )
                                                (block blkTwo
                                                                (setq newList1 (cons (first List1) newList1))
                                                                (setq newList2 (cons (first List2) newList2))
                                                )
                                )
                                (incf Cnt)
                                (setq List1 (rest List1))
                                (setq List2 (rest List2))
                )
                (setq List1 (append newList1 newList2))
)
(defun mainCross (listOne listTwo Gen)

(setq genCntr 0)
(setq tempList '())
                (loop
                                (when(equal genCntr Gen)(return))
                    (setq posCntr 0)(setq tempList '())
                                (setq tempList (Cross listOne listTwo))
                    (setq lenTempList (length templist))
                                (setq listOne '())
                    (setq listTwo '())
    (loop
                                  (when (equal (first tempList) nil)(return))
               
                                                (if (< posCntr (/ lenTempList 2))
                                                                (setq listOne (cons (first tempList) listOne))
                                        (setq listTwo (cons (first tempList) listTwo))
                                                )
                                                (incf posCntr)
                                                (setq tempList (rest tempList))
    )
    (incf genCntr)
    (print "Result of Crossing")   
    (print listOne)
    (print listTwo)  ))

(mainCross '(1 2 3 4) '(5 6 7 8) 3)
OUTPUT:

"CrossOver Point" 0
"Result of Crossing"
(5 6 7 8)
(1 2 3 4)
"CrossOver Point" 0
"Result of Crossing"
(1 2 3 4)
(5 6 7 8)
"CrossOver Point" 3
"Result of Crossing"
(1 2 3 8)
(5 6 7 4)
NIL

0 comments:

Mutation

Write a program in Lisp to demonstrate the genetic operator mutation.

(Enter a population of binary strings. Perform mutation based on a random mutation point. Consider fitness value as the number of repetitions of a specified bit (say 1) in the string. Perform the evolution for a specified number generation.)


CODE:

(defun Muta(List)
(setq Cnt 0)
(setq newList '())
(setq mp (random (length List)))

(print "Mutation Point")
(prin1 mp)

                (loop
                                (when (equal (first List) nil) (return))
                                (if (equal mp Cnt)
                                                (if(equal (first List) 0)
                                                                (setq newList (cons '1 newList))
                                                                (setq newList (cons '0 newList))
                                                )
                               
                                                (setq newList (cons (first List) newList))
                                )
                               
                                (incf Cnt)
                                (setq List (rest List))
                )
               
                (setq List (reverse newList))
        (setq newList '())
                (print List)
)

(defun mainMuta (List1 List2 Gen)
(setq FVList1 0)
(setq FVList2 0)
(setq GenCntList1 0)
(setq GenCntList2 0)
(setq dplList '())

                (loop
                                (when (equal GenCntList1 Gen) (return))
                                (when (equal GenCntList2 Gen) (return))
                               
                                (setq FVList1 0)
                                (setq dplList List1)
                                (loop
                                                (when (equal (first List1) nil) (return))
                                                (if(equal (first List1) 1)(incf FVList1))
                                                (setq List1 (rest List1))
                                )
                                (setq List1 dplList)
                               
                                (setq FVList2 0)
                                (setq dplList List2)
                                (loop
                                                (when (equal (first List2) nil) (return))
                                                (if(equal (first List2) 1) (incf FVList2))
                                                (setq List2 (rest List2))
                                )
                                (setq List2 dplList)

                                (if (> FVList1 FVList2)
                                                (block blkOne
                                                                (incf GenCntList1)
                                                                (setq dplList List1)
                                                                (setq List1 (Muta List1))
                                                                (print "List1:-")
                                                                (prin1 List1)
                                                                (prin1 "List1 Generation Count:-")
                                                                (prin1 GenCntList1)
                                                )
                                                (block blkTwo
                                                                (incf GenCntList2)
                                                                (setq dplList List2)
                                                                (setq List2 (muta List2))
                                                                (print "List2:-")
                                                                (prin1 List2)
                                                                (prin1 "List2 Generation Count:-")
                                                                (prin1 GenCntList2)
                                                )
                                )
                )
)


(mainMuta '(1 2 3 4) '(5 6 7 8) 3)

OUTPUT:

"Mutation Point" 0
(0 2 3 4)
"List1:-" (0 2 3 4)"List1 Generation Count:-"1
"Mutation Point" 3
(5 6 7 0)
"List2:-" (5 6 7 0)"List2 Generation Count:-"1
"Mutation Point" 1
(5 0 7 0)
"List2:-" (5 0 7 0)"List2 Generation Count:-"2
"Mutation Point" 1
(5 1 7 0)
"List2:-" (5 1 7 0)"List2 Generation Count:-"3
NIL

0 comments:

Roulette Wheel

Write a program in Lisp to perform roulette wheel selection. (Enter a population of binary strings. Consider fitness value as the number of repetitions of a specified bit (say 1) in the string.)


CODE:

(defun strStg (strWord)
(setq stgCnt 0)
(setq lenCnt 0)
                (loop
                                (when (equal lenCnt (length strWord)) (return stgCnt))
                                (if (equal (char "1" 0) (char strWord lenCnt)) (incf stgCnt))
                                (incf lenCnt)
                )
)

(strStg "10001")

(defun RW (strOne strTwo strThree strFour strFive)
(setq Cnt 0)
(setq stgList '())

                (setq strOneStg (strStg strOne))
                (setq strTwoStg (strStg strTwo))
                (setq strThreeStg (strStg strThree))
                (setq strFourStg (strStg strFour))
                (setq strFiveStg (strStg strFive))

                (setq stgList (push strOneStg stgList))
                (setq stgList (push (+ strOneStg strTwoStg) stgList))       
                (setq stgList (push (+ strOneStg strTwoStg strThreeStg) stgList))
                (setq stgList (push (+ strOneStg strTwoStg strThreeStg strFourStg) stgList))
                (setq stgList (push (+ strOneStg strTwoStg strThreeStg strFourStg strFiveStg) stgList))

                (setq strSel (Mod (random 1000) (first stgList)))
                (print strSel)

                (loop
                                (when (equal (first stgList) nil) (return))
                                (if (>= strSel (first stgList))
                                                (block blkIf
                                                                (if(equal Cnt 0)(return strOne))
                                                                (if(equal Cnt 1)(return strTwo))
                                                                (if(equal Cnt 2)(return strThree))
                                                                (if(equal Cnt 3)(return strFour))
                                                                (if(equal Cnt 4)(return strFive))
                                                )
                                )
                                (setq stgList (rest stgList))
                                (incf Cnt)
                )
)

(RW "100110" "100101" "001010" "010101" "100001")

OUTPUT:
---- Done ----

1

---- Done ----

7
"010101"

0 comments:

A fuzzy system is a structured Numerical estimator in LISP example Inverted Pendulum

Write a program in Lisp to demonstrate that a fuzzy system is a structured
Numerical estimator-using example of controlling an inverted pendulum.
(Enter two strings for angle of pendulum θ and angular velocity Δθ.

Convert them into strings of fuzzy using five fuzzy set values NM(Negative medium), NS (Negative Small), ZE(Zero), PS (Positive Small) and PM ( Positive Medium). Apply FAM rules to find the output values v,the current to the motor control of the pendulum to each input set of (θ,Δθ). Create a string of fuzzy output values of the current.)

(defun FAM (angPen anguVel)
                (cond
                                ((equal angPen "NM")
                                                                (cond
                                                                                ((equal anguVel "NM") nil)
                                                                                ((equal anguVel "NS") nil)
                                                                                ((equal anguVel "ZE") (print "PM"))
                                                                                ((equal anguVel "PS") nil)
                                                                                ((equal anguVel "PM") nil)
                                                                )
                                )
                                ((equal angPen "NS")
                                                                (cond
                                                                                ((equal anguVel "NM") nil)
                                                                                ((equal anguVel "NS") nil)
                                                                                ((equal anguVel "ZE") (print "PS"))
                                                                                ((equal anguVel "PS") nil)
                                                                                ((equal anguVel "PM") nil)
                                                                )
                                )
                                ((equal angPen "ZE")
                                                                (cond
                                                                                ((equal anguVel "NM") (print "PM"))
                                                                                ((equal anguVel "NS") (print "PS"))
                                                                                ((equal anguVel "ZE") (print "ZE"))
                                                                                ((equal anguVel "PS") (print "NS"))
                                                                                ((equal anguVel "PM") (print "NM"))
                                                                )
                                )
                                ((equal angPen "PS")
                                                                (cond
                                                                                ((equal anguVel "NM") nil)
                                                                                ((equal anguVel "NS") nil)
                                                                                ((equal anguVel "ZE") (print "NS"))
                                                                                ((equal anguVel "PS") nil)
                                                                                ((equal anguVel "PM") nil)
                                                                )
                                )
                                ((equal angPen "PM")
                                                                (cond
                                                                                ((equal anguVel "NM") nil)
                                                                                ((equal anguVel "NS") nil)
                                                                                ((equal anguVel "ZE") (print "NM"))
                                                                                ((equal anguVel "PS") nil)
                                                                                ((equal anguVel "PM") nil)
                                                                )
                                )
                )
)

(FAM "NM" "ZE")

OUTPUT:
---- Done ----
FAM
---- Done ----
"PM"


0 comments:

logistic, threshold, hyperbolic-tangent, linear, exponential, sigmoid functions

Write a program in Lisp to demonstrate working of an artificial neuron.

(Enter an input vector X and weight vector W. Calculate weighted sum  XW. Transform this using signal or activation functions like logistic,threshold, hyperbolic-tangent, linear, exponential, sigmoid etc and display the output.)


(defun nnFunctions (actSignList wghtList c n)
(setq wghtSum 0)
(setq resFunc 0)
            (loop
                        (when (equal (first actSignList) nil) (return))
                        (setq wghtSum (+ wghtSum (* (first actSignList) (first wghtList))))
                        (print wghtSum )
                        (setq actSignList (rest actSignList))
                        (setq wghtList (rest  wghtList))
            )
            (print "Logistical Signal Function")
            (print (/ 1 (+ 1 (exp (- 0 (* c wghtSum))))))

            (print "Hyperbolic tangent Signal Function")
            (print (tan (* 10 wghtSum)))
           
            (print "Threshold Linear Signal Function")
                        (if (<= 1 (* c wghtSum)) (print 1) (print 0))
           
            (print "Linear Signal Function")
            (print (* c wghtSum))

            (print "Threshold Exponential Signal Function")
            (print (min 1 (exp (* c wghtSum))))

            (print "Threshold Distribution Signal Function")
            (print (max 0 (- 1 (exp (- 0 (* c wghtSum))))))

            (print "Ratio Polynomial Signal Function")
            (print (max 0 (/ (expt wghtSum n) (+ c (expt wghtSum n)))))
)

(nnFunctions '(1 2 3) '(2 3 4) 5 4 )

OUTPUT:
---- Done ----
0
---- Done ----
2
8
20
"Logistical Signal Function"
1.0
"Hyperbolic tangent Signal Function"
-1.7925274837903817
"Threshold Linear Signal Function"
1         
"Linear Signal Function"
100
"Threshold Exponential Signal Function"
1
"Threshold Distribution Signal Function"
1.0
"Ratio Polynomial Signal Function"
32000/32001
32000/32001

0 comments:

Count the number of repetitions of each element in the list in LISP

Write a program in Lisp to enter a number n and create a list of length n of repeated elements. Count the number of repetitions of each element in the list. Display the count value of each element in character.

( Eg (1 2 1 1 3) should give the output “element 1: three times”).


(defun Num()
(print "Enter a Number:")
(setq a(read))
(loop for i from 0 to a collect(random 3)
)
)
NUM

(defun occurence()
(setf b(Num))
(format t "Elements are : ~S ~%" b)
(setq m(count 0 b))
(format t "Element : ~R ~R times ~%" 0 m)
(setq c(count 1 b))
(format t "Element : ~R ~R times ~%" 1 c)
(setq d(count 2 b))
(format t "Element : ~R ~R times ~%" 2 d)
(setq e(count 3 b))
(format t "Element : ~R ~R times ~%" 3 d)
)
OCCURENCE



0 comments: