Coder Social home page Coder Social logo

project1's Introduction

Contribution

      Please contribute to this repository to help it make better. Any change like new question, 
      code improvement, doc improvement etc. is very welcome. Just send me a pull request and 
      I will review the request and approve it if it looks good.

Project1

"Mobile Phone Tracking System"

we are going to design a data structure that will help us solve a simplified version of the mobile phone tracking problem, i.e., the fundamental problem of cellular networks: When a phone is called, and where it is located so that a connection may be established.

Mobile phone tracking system description

As we know each mobile phone that is switched on is connected to the base station which is nearest. These base stations are popularly called cell phone towers. Although sometimes we may be within range of more than one base station, each phone is registered to exactly one base station at any point of time. When the phone moves from the area of one base station to another, it will be de-registered at its current base station and re-registered at new base station.

Making a phone call.

When a phone call is made from phone p1 registered with base station b1 to a phone p2, the frst thing that the base station b1 has to do is to and the base station with which p2 is registered. For this purpose there is an elaborate technology framework that has been developed over time. You can read more about it on the Web. But, for now, we will assume that b1 sends a query to a central server C which maintains a data structure that can answer the query and return the name of the base station, let's call it b2, with which p2 is registered. C will also send some routing information to b1 so that b1 can initiate a call with b2 and, through the base stations p1 and p2 can talk. It is the data structure at C that we will be implementing in this assignment.

A hierarchical call routing structure.

We will assume that geography is partitioned in a hierarchical way. At the lowest level is the individual base station which de nes an area around it such that all phones in that area are registered with it, e.g., all phones that are currently located in Bharti building, School of IT and IIT Hospital are registered with the base station in Jia Sarai. This base station also serves phone in Jia Sarai and maybe some phones on Outer Ring Road in front of Jia Sarai. Further we assume that base stations are grouped into geographical locations served by an level 1 area exchange. So, for example, the Jia Sarai base station may be served by the Hauz Khas level 1 area exchange. Each level i area exchange is served by a level i+1 area exchange which serves a number of level i area exchanges, e.g., the Hauz Khas level 1 area exchange and the Malviya level 1 area exchange may be both served by a South-Central Delhi level 2 area exchange. A base station can be considered to be a level 0 area exchange in this hierarchical structure. Given a level i exchange f, we say that the level i + 1 exchange that serves it is the parent of f, and denote this parent(f). We will call this hierarchical call routing structure the routing map of the mobile phone network.

Maintaining the location of mobile phones.

Every level i area ex- change, e, maintains a set of mobile phones, Se, as follows. The set Se is called the resident set of e. The level 0 area exchanges (base stations) main- tain the set of mobile phones registered directly with them. A level i+1 area exchange e, maintains the set Se- i.e., the union of the sets of mobile phones maintained by all the level i area exchanges it serves. Clearly, the root of the routing map maintains the set of all currently registered mobile phones.

Tracking a mobile phone.

The routing map along with the resident sets of each area exchange makes up the mobile phone tracking data structure we will be using. This data structure will be stored at the central server C. The process of tracking goes as follows. � When a base station b receives a call for a mobile phone with number m it sends this query to C. � If the root of the routing map is r, we rst check if m 2 Sr. If not then we tell b that the number m is \not reachable." � If m 2 Sr we nd that e such that parent(e) = r and m 2 Se, i.e. we nd the child of r which contains m in its resident set. � Continue like this till we reach all the way down to a leaf of the routing map. This leaf is a base station b0. The central server sends b0 to b along with the path in the routing map from b to b0.

MySet.java

� A java class called Myset that implements sets, with the following methods:

  • public Boolean IsEmpty(): returns true if the set is empty.
  • public Boolean IsMember(Object o): Returns true if o is in the set, false otherwise.
  • public void Insert(Object o): Inserts o into the set.
  • public void Delete(Object o): Deletes o from the set, throws exception if o is not in the set.
  • public Myset Union(Myset a): Returns a set which is the union of the current set with the set a.
  • public Myset Intersection(Myset a): Returns a set which is the intersection of the current set with the set a. You may use a linked list of objects to implement the Myset class. Note that Object is the fundamental class in Java. You can cast it to any class that you want (Integer, Float, Double, etc).

MobilePhone.java

� a java class called MobilePhone, with the following methods:

  • MobilePhone(Int number): constructor to create a mobile phone. Unique identifier for a mobile phone is an integer.
  • public Int number(): returns the id of the mobile phone.
  • public Boolean status(): returns the status of the phone, i.e. switched on or switched o�.
  • public void switchOn(): Changes the status to switched on.
  • public void switchOff(): Changes the status to switched o�.
  • public Exchange location(): returns the base station with which the phone is registered if the phone is switched on and an excep- tion if the phone is o�. The class Exchange will be described next.

MobilePhoneSet.java

� Create a class MobilePhoneSet which stores MobilePhone objects in a Myset. � Create a class ExchangeList which implements a linked list of ex- changes. � Write a java class Exchange that will form the nodes of the routing map structure. The class should have the following methods.

  • Exchange(Int number): constructor to create an exchange. Unique identifier for an exchange is an integer.
  • All usual Node methods for a general tree like public Exchange parent(), public Exchange numChildren() (for number of chil- dren), public Exchange child(int i) (returns the ith child), public Boolean isRoot(), public RoutingMapTree subtree(int i) (returns the ith subtree) and any other tree methods you need. The class de nition RoutingMapTree will be de ned later.
  • public MobilePhoneSet residentSet(): This returns the resi- dent set of mobile phones of the exchange.

RoutingMapTree.java

� Write a java class RoutingMapTree which is a tree class whose nodes are from the Exchange class. The class should contain the following:

  • RoutingMapTree(): constructor method. This should create a RoutingMapTree with one Exchange node, the root node which has an identi er of 0. Create other constructors that you deem necessary.
  • All general tree methods like public Boolean containsNode(Exchange a) but with Exchange as the node class.
  • public void switchOn(MobilePhone a, Exchange b): This method only works on mobile phones that are currently switched o�. It switches the phone a on and registers it with base station b. The entire routing map tree will be updated accordingly.
  • public void switchOff(MobilePhone a): This method only works on mobile phones that are currently switched on. It switches the phone a o�. The entire routing map tree has to be updated ac- cordingly.
  • public String performAction(String actionMessage): This the main stub method that you have to implement. It takes an action as a string. The list of actions, and their format will be described next.

project1's People

Contributors

alokkiitd1729 avatar

Stargazers

 avatar  avatar  avatar  avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.