Ask Question, Ask an Expert

+61-413 786 465

info@mywordsolution.com

Ask Computer Engineering Expert

You are a computational neuroscientist working on simulations of neural networks. You have data representing a very large feed-forward network and wish to create a computer simulation for further study.

The network can be model led as a graph with vertices representing neurons and directed edges representing connections between them.

In order to calculate the output of a neuron, you need to first calculate the output of all neurons that connect to it (note: this particular feed-forward network has no cycles). So a topological sort will give a possible evaluation order for the network.

Assignment Specification - Part A

For this part of the assignment, you will be given a network and a starting state. Your program will then calculate the subsequent state of the network. For neurons that have no inputs, the new state will be the same as the current state. For other neurons, a very simple neuron model will be used:

for each neuron v: input = 0

for each edge uv:
input += weight(uv)*state(u)

if input>0: state(v)= 1
else:
state(v)= 0

You must use the following data structures to represent the graph as an adjacency list:

typedef struct edge{

int toVertex;

int weight;
} Edge;

typedef struct edgeNode{

Edge edge;
struct edgeNode *next;

} *EdgeList;

typedef struct graph{ int V;

int *state;

EdgeList *edges;
} Graph;

For testing purposes you will input the graph data from the keyboard and/or using input redirection (as for assignment 1). The input format is as follows:

- The first line will contain the number of vertices ( neurons) in the graph
- Then for each vertex:
   o The first line contains the initial state of that vertex
   o The second line contains the number of edges from that vertex
   o The third line contains a list of toVertex, weight pairs separated by spaces (if there are no edges, this line is omitted)

For example, the following text would define a 7 vertex graph:

7
1
2
6,1 3,-2
0
1
4,4
1
3
4,-2 3,1 0,3
1
0
1
1
3,2
0
4
6,2 3,-4 2,1 0,-3
1
3
5,2 4,-1 3,4

The edge weights will be in the range -100 to +100; states will be either 0 or 1.

Your program should use the queue based topological sort method based on in-degrees to determine an evaluation order for the graph. Then working through the vertices in this topologically sorted order to calculate the next state of each neuron. The output should be the new state of all neurons after this calculation (on a single line). So the initial state of the vertex above would be printed as:

1011101

Assignment Specification - Part B

You find that the topological sort can take a long time for some graphs, and you would also like to be able to detect cycles. So you decide to test whether a depth first search based topological sort gives better performance.

For this part of the assignment, you will implement DFS for the input graph, and use the post- order numbering of the DFS spanning tree to determine if there are any cycles. [Note: you don't have to actually build a separate DFS spanning tree to calculated the post-order numbering] If there are no cycles, you should then use the post-order numbering to calculate a topological sort and calculate and print the new state of the graph as for part A. Otherwise, the program should print an error message: "this graph contains at least one cycle".

There is however, a slight complication. The procedure for DFS described in lectures assumes a single known starting vertex. That is not the case for this data, where in general we will have many "input" neurons. In this situation, we usually build a DFS forest by repeated application of the algorithm.

For this assignment, two solutions to this problem will be allowed:

1. Implement an algorithm that builds a DFS spanning forest. You will find examples of this approach online.

2. Use the previously calculated in-degrees to identify "input" neurons (the ones with in-degree 0). Then (conceptually) add a new vertex to the graph with edges to each of these inputs. Make this new vertex the starting point for your DFS. [Note: you don't have to actually add the vertex to the graph, just proceed as though it does exist]

The first approach has the advantage that it is the standard way to deal with this problem, so you will find more help online. The second approach has the advantage that it matches what was discuss in lectures more closely and may be a little simpler to understand.

The assessment criteria for this task are:

1. Implement code to create a graph using the correct input format

2. Implement topological sort using the queue-based in-degree method

3. Implement the network update step

4. Implement the DFS-based topological sort

Unit learning outcomes

You will be an ICT professional with the abilities and skills to:

1. adapt and apply algorithms and data structures for storing, managing and analysing data, information and knowledge;

2. select and effectively apply algorithms and data structures to develop ICTproducts and services;

3. analyse algorithms and code to determine the runtime(and space) complexity, and evaluate strengths and weaknesses of potential algorithms; and

4. use algorithm design techniques to develop new algorithms for a given problem.
You will acquire attitudes needed by an ICT professional to:

5. take initiative and work independently;

6. communicate effectively using appropriate terminology;

7. use abstraction and computational, creative and critical thinking to problem solve;

8. continue lifelong learning;

9. act in accordance with best practice and industry standards.

Computer Engineering, Engineering

  • Category:- Computer Engineering
  • Reference No.:- M91790340
  • Price:- $65

Guranteed 36 Hours Delivery, In Price:- $65

Have any Question?


Related Questions in Computer Engineering

Suppose that we reconsider our student example and the only

Suppose that we reconsider our STUDENT example and the only attributes of STUDENT are student number and name. Let us suppose that we have another entity called HIGH SCHOOL, that is going to be the high school from which ...

Assignment from chapter 10 page 302 web-based case read and

Assignment: From Chapter 10, page 302, Web-Based Case. Read and answer the questions. KNOWLEDGE MANAGEMENT SYSTEMS AND CRM In answer to the challenges Nelnet faces in servicing a growing volume of student loans, the comp ...

Please help me find out how to calculate stock pricewhat is

Please help me find out how to calculate stock price. "What is the price of Company A's stock.We know company A pay dividend twice a year. And its beta=1.5 Government bond's Coupon is 8.8 and Yield is 5%(which one you sh ...

Use the management studio to create a new database called

Use the Management Studio to create a new database called Membership2 using the default settings. (If the database already exists, use the Management Studio to delete it and than recreate it)

Restaurant management database project the restaurant

Restaurant Management Database Project : The restaurant maintains the catalog for the list of food and beverage items that it provides. Apart from providing food facility at their own premises, the restaurant takes order ...

Research the history of specification languages and write a

Research the history of specification languages, and write a report on the successes or failures of some of these languages. Include 5 languages which are successful and 5 which have failed. All work should be typed writ ...

What are some examples of when a data compression utility

What are some examples of when a data compression utility can be used for information stored on a computer's hard drive?

A company that supplies batteries for watches guarantees

A company that supplies batteries for watches guarantees that 95% of the batteries it ships will be free from defects. You test a sample of 50 batteries you received. You find that fewer than 10 have defects. Does this l ...

How is international trade regulated what is involved in

How is international trade regulated? What is involved in "trade agreements"?

Systems analysis and design projectpersonal trainer inc

Systems Analysis and design project Personal Trainer, Inc. owns and operates fitness centers in a dozen Midwestern cities. The centers have done well, and the company is planning an international expansion by opening a n ...

  • 4,153,160 Questions Asked
  • 13,132 Experts
  • 2,558,936 Questions Answered

Ask Experts for help!!

Looking for Assignment Help?

Start excelling in your Courses, Get help with Assignment

Write us your full requirement for evaluation and you will receive response within 20 minutes turnaround time.

Ask Now Help with Problems, Get a Best Answer

Why might a bank avoid the use of interest rate swaps even

Why might a bank avoid the use of interest rate swaps, even when the institution is exposed to significant interest rate

Describe the difference between zero coupon bonds and

Describe the difference between zero coupon bonds and coupon bonds. Under what conditions will a coupon bond sell at a p

Compute the present value of an annuity of 880 per year

Compute the present value of an annuity of $ 880 per year for 16 years, given a discount rate of 6 percent per annum. As

Compute the present value of an 1150 payment made in ten

Compute the present value of an $1,150 payment made in ten years when the discount rate is 12 percent. (Do not round int

Compute the present value of an annuity of 699 per year

Compute the present value of an annuity of $ 699 per year for 19 years, given a discount rate of 6 percent per annum. As