Communication devices, such as cellular telephones, smartphones, computers, or the like, may receive information from other communication devices via a network. The information may be transmitted via evolved multimedia broadcast multicast services (“eMBMS”) to the communication devices.
The following detailed description of example implementations refers to the accompanying drawings. The same reference numbers in different drawings may identify the same or similar elements.
A user of a user device (e.g., a cellular phone, a smartphone, a computing device, etc.) may communicate with other users of other user devices as members of a group (e.g., a social network, a professional network, etc.). The user devices may communicate via a multicast network by use of evolved multimedia broadcast multicast services (“eMBMS”). Use of an eMBMS network may allow for a message sent from one user device to be broadcast to other user devices associated with the group (e.g., via a multicast broadcast). Additionally, use of an eMBMS network may allow for reduced latency associated with a message sent between the user devices, as a network may use eMBMS to deliver the message to members of the group without having to send the message to a server device. However, the users may wish to determine the groups (e.g., what user devices are associated with the group), to join the group, and may wish to log into the group and/or log out of the group. Implementations described herein may allow a provisioning device to create a private wireless network of user devices whereby the user devices may log in to a group, and may receive multicast messages from other members of the group.
As shown in
Based on the association between the group and the set of user devices, the provisioning device may provision a private wireless network for the group. The private wireless network may include a multicast network that allows a message sent from a first user device (e.g., user device A) to be broadcast to the other active user devices associated with the group (e.g., user device B and user device D). The provisioning device may provision the private wireless network so that an inactive member of the group does not receive the message (e.g., user device C). In this manner, the provisioning device may determine a private wireless network of user devices that may be always active (e.g., similar to a push to talk network), and that may be scaled as group membership increases.
Provisioning device 210 may include a device capable of provisioning a multicast group. For example, provisioning device 210 may include a computing device (e.g., a desktop computer, a laptop computer, a tablet computer, a handheld computer, etc.), a network device (e.g., a gateway, a base station, etc.), a server, or a similar device. Provisioning device 210 may receive information from and/or transmit information to user device 240 and/or storage device 250.
Network 220 may include one or more wired and/or wireless networks. For example, network 220 may include a cellular network, a long term evolution (“LTE”) network, a public land mobile network (“PLMN”), a local area network (“LAN”), a wide area network (“WAN”), a metropolitan area network (“MAN”), a telephone network (e.g., the Public Switched Telephone Network (“PSTN”)), an ad hoc network, an intranet, the Internet, a fiber optic-based network, and/or a combination of these or other types of networks.
Private wireless network 230 may include one or more wireless networks. For example, private wireless network may include a cellular network a long term evolution (“LTE”) network, a multimedia broadcast multicast services (“MBMS”) network, an evolved multimedia broadcast multicast services (“eMBMS”) network, and/or a combination of these or other types of wireless networks. In some implementations, private wireless network 230 may be a subset of and/or share resources with network 220.
User device 240 may include a device capable of receiving and/or transmitting information, such as information associated with voice calls, video calls, emails, SMS text messages, or the like. For example, user device 210 may include a mobile telephone (e.g., a smartphone, a radiotelephone, etc.), a computing device (e.g., a desktop computer, a laptop computer, a tablet computer, a handheld computer, etc.), or a similar device. User device 240 may receive information from and/or transmit information to provisioning device 210 and/or storage device 250.
Storage device 250 may include one or more devices capable of receiving, storing, processing, and/or transmitting information, such as information transmitted between user devices 240. For example, storage device 250 may include a computing device, such as a server, a desktop computer, a laptop computer, a tablet computer, a handheld computer, or a similar device. Storage device 250 may receive information from and/or transmit information to provisioning device 210 and/or user device 240.
The number of devices and networks shown in
Bus 310 may include a path that permits communication among the components of device 300. Processor 320 may include a processor (e.g., a central processing unit, a graphics processing unit, an accelerated processing unit), a microprocessor, and/or any processing component (e.g., a field-programmable gate array (“FPGA”), an application-specific integrated circuit (“ASIC”), etc.) that interprets and/or executes instructions. Memory 330 may include a random access memory (“RAM”), a read only memory (“ROM”), and/or another type of dynamic or static storage device (e.g., a flash, magnetic, or optical memory) that stores information and/or instructions for use by processor 320.
Input component 340 may include a component that permits a user to input information to device 300 (e.g., a touch screen display, a keyboard, a keypad, a mouse, a button, a switch, etc.). Output component 350 may include a component that outputs information from device 300 (e.g., a display, a speaker, one or more light-emitting diodes (“LEDs”), etc.).
Communication interface 360 may include a transceiver-like component, such as a transceiver and/or a separate receiver and transmitter, that enables device 300 to communicate with other devices, such as via a wired connection, a wireless connection, or a combination of wired and wireless connections. For example, communication interface 360 may include an Ethernet interface, an optical interface, a coaxial interface, an infrared interface, a radio frequency (“RF”) interface, a universal serial bus (“USB”) interface, or the like.
Device 300 may perform various operations described herein. Device 300 may perform these operations in response to processor 320 executing software instructions included in a computer-readable medium, such as memory 330. A computer-readable medium may be defined as a non-transitory memory device. A memory device may include memory space within a single physical storage device or memory space spread across multiple physical storage devices.
Software instructions may be read into memory 330 from another computer-readable medium or from another device via communication interface 360. When executed, software instructions stored in memory 330 may cause processor 320 to perform one or more processes described herein. Additionally, or alternatively, hardwired circuitry may be used in place of or in combination with software instructions to perform one or more processes described herein. Thus, implementations described herein are not limited to any specific combination of hardware circuitry and software.
The number of components shown in
As shown in
In some implementations, the registration information may include information associated with user device 240. For example, the registration information may include information that identifies user device 240, such as a serial number, an identification number (“ID”), a phone number, an internet protocol (“IP”) address, or the like. Additionally, or alternatively, the registration information may include a device type (e.g., whether user device 240 is a smartphone, a computing device, a tablet device, etc.), a device model, a location of user device 240, or the like.
In some implementations, the registration information may include user information associated with a user of user device 240. For example, the registration information may include a name of the user, an address of the user, a phone number associated with the user, or the like. In some implementations, the registration information may include demographic information associated with the user (e.g., an age of the user, a gender of the user, etc.). Additionally, or alternatively, the registration information may include information for logging into an account associated with user device 240 (e.g., a username, a password, a personal identification number, etc.).
In some implementations, the registration information may include user preference information. For example, the registration information may include information that identifies a group that user device 240 and/or the user is to be associated with, one or more other group members (e.g., other user devices 240, other users of user devices 240, etc.), or the like. Additionally, or alternatively, the registration information may include information that describes the group, such as a group name, a group ID, a group description, or the like.
In some implementations, the registration information may designate user device 250 and/or the user as a member of a preexisting group (e.g., a group previously created by another user device 240). Additionally, or alternatively, the registration information may include information for creating a new group associated with user device 240 and/or the user.
In some implementations, provisioning device 210 may receive the registration information from user device 240. For example, user device 240 may receive the registration information from a user of user device 240 (e.g., via user input), and may provide the registration information to provisioning device 210. Additionally, or alternatively, provisioning device 210 may receive the registration information from another device, such as an account server associated with a service provider associated with user device 240 (e.g., a home subscriber server), storage device 250, or the like.
As further shown in
In some implementations, the group may include an association of one or more user devices 240 and/or one or more users of user devices 240. For example, the group may include user devices 240 associated as members of a wireless network (e.g., private wireless network 230). In some implementations, provisioning device 210 may determine group information (e.g., information that describes the group), and may store the group information in a data structure associated with provisioning device 210. Additionally, or alternatively, provisioning device 210 may provide the group information to another device, such as user device 240, and/or storage device 250.
In some implementations, provisioning device 210 may determine the group based on the registration information provided by user device 240. For example, provisioning device 210 may determine which user devices 240 to include as members of the group based on a preference of a user of user device 240 (e.g., a preference to be a part of the group, a preference to be grouped with other user devices 240 and/or other users of user devices 240, etc.). Additionally, or alternatively, provisioning device 210 may determine the group based on a location of user device 240, a device type of user device 240, a business rule, or the like.
In some implementations, provisioning device 210 may determine that storage device 250 is to be a member of the group. For example, provisioning device 210 may determine that storage device 250 is to be a member of the group so as to receive a message sent from user devices 240. In some implementations, storage device 250 may store the messages in a data structure associated with storage device 250 to maintain a record of the messages.
In some implementations, provisioning device 210 may determine a group identifier associated with the group. For example, the group identifier may include a group name, a group number, a group ID (e.g., a unique set of characters), or the like. Additionally, or alternatively, provisioning device 210 may determine a member identifier associated with a member of the group (e.g., user device 240, a user of user device 240, etc.). For example, the member identifier may include a set of characters (e.g., numbers, letters, symbols, etc.) that identify the user, such as a name, an ID number, a username, or the like. Additionally, or alternatively, the member identifier may include a set of characters that identify user device 240, such as a serial number, a device name, an IP address associated with user device 240, or the like.
In some implementations, provisioning device 240 may automatically determine group information associated with the group. For example, provisioning device 210 may determine and/or assign a group ID, a group name, a group number, an IP address, or the like. Additionally, or alternatively, provisioning device 240 may determine the group information based on the registration information (e.g., based on the preferences of a user of user device 240).
In some implementations, a set of provisioning devices 210 may store information associated with user devices 240 (e.g., group information, registration information, etc.). For example, a first provisioning device 210-1 may be associated with a first set of user devices 240, and may store information associated with the first set of user devices 240 (e.g., groups associated with the first set of user devices 240, device information associated with the first set of user devices 240, user information associated with users of the first set of user devices 240, etc.). A second provisioning device 210-2 may be associated with a second set of user devices 240, and may store information associated with the second set of user devices 240 (e.g., groups associated with the second set of user devices 240, device information associated with the second set of user devices 240, user information associated with users of the second set of user devices 240, etc.). First provisioning device 210-1 may receive a request from a user device 240 of the second set of user devices 240 (a request to log into an account, a request to register as a member of a group, etc.). Based on the request, first provisioning device 210-1 may receive information from and/or transmit information to second provisioning device 210-2. For example, first provisioning device 210-1 may provide registration information, received from user device 240, to second provisioning device 210-2 to allow user device 240 to join a group associated with provisioning device 210-2.
In some implementations, provisioning device 210 may be associated with a geographic region, and may send queries from user devices 240 outside of the geographic region to another provisioning device 210 (e.g., associated with another geographic region). In some implementations, a set of provisioning devices 210 may be associated with a virtual IP address (e.g., an IP address associated with multiple provisioning devices 240). For example, a centralized provisioning device 210 may forward requests (e.g., sent from user devices 240 to the virtual IP address) to an appropriate provisioning device 210, of the set of provisioning devices 210. In this manner, centralized provisioning device 210 may act as a load balancer.
As further shown in
In some implementations, provisioning device 210 may determine active user devices based on user input. For example, a user of user device 240 may be a member of a group. The user may provide user input (e.g., via user device 240) indicating that the user is active (e.g., that the user would like to send information to other members of the group and/or receive information from the other members of the group). In some implementations, provisioning device 210 may receive login information from user device 240 (e.g., a username, a password, etc.). Based on the login information (e.g., based on the user logging into the group), provisioning device 210 may determine that user device 240 is an active user device 240.
In some implementations, provisioning device 210 may determine active user devices 240 based on one or more attributes of user device 240. For example, provisioning device 210 may determine that user device 240 is an active user device 240 based on a location of user device 240, a status of user device 240 (e.g., that user device 240 is powered on, that user device 240 is connected to a network, etc.), a type of user device 240, or the like.
In some implementations, provisioning device 210 may determine a set of IP addresses associated with active user devices 240. For example, provisioning device 210 may determine an IP address associated with user device 240 when a user of user device 240 logs into the group.
In some implementations, provisioning device 210 may determine that storage device 250 is an active member of the group. Additionally, or alternatively, provisioning device 210 may determine an IP address associated with storage device 250, an identifier associated with storage device 250, or the like.
In some implementations, provisioning device 210 may store information associated with active user devices 240 in a data structure associated with provisioning device 210 (e.g., a list of active user devices 240, a set of IP addresses associated with active user devices 240, a storage device 250 that is an active member of the group, etc.). Additionally, or alternatively, provisioning device 210 may provide the information to another device, such as another provisioning device 210, user device 240 and/or storage device 250.
As further shown in
In some implementations, the multicast identifier may include an identifier that allows a message to be sent from a first use device 240-1 to other user devices 240 (e.g., actively associated with the group). The message may include information sent and/or received by user device 240, such as a voice call, a video call, an email, a video, a file, a short message service (“SMS”) text message, or the like.
In some implementations, the multicast identifier may include a multicast address. The multicast address may allow one or more network devices (e.g., a router, an eNB, a switch, a gateway, etc.) to deliver the message to active user devices 240 via a wireless network (e.g., private wireless network 230). In some implementations, the multicast address may allow the message to be delivered by use of multimedia broadcast multicast services (“MBMS”), evolved multimedia broadcast multicast services (“eMBMS”), or the like.
In some implementations, provisioning device 210 may generate a socket, associated with user device 240 and/or private wireless network 230, for user device 240 to receive and/or send messages. For example, the socket may include a communication endpoint in a network (e.g., network 220, private wireless network 230, etc.). In some implementations, the socket may be associated with a socket address. For example, the socket address may include a combination of an IP address and a port number. In some implementations, provisioning device 210 may generate the socket by use of an application programming interface (“API”) associated with user device 240 (e.g., a socket API).
As further shown in
In some implementations, provisioning device 210 may store an association between a multicast address association with the group and a set of IP addresses associated with active user devices 240. For example, provisioning device 210 may determine an active member of the group (e.g., a member of the group who is logged into an account associated with the group). Provisioning device 210 may determine an active user device 240, of a set of user devices 240, associated with the active member. Provisioning device 210 may determine an IP address associated with active user device 240, and may store an association between the IP address and the multicast address.
In some implementations, provisioning device 210 may determine an association between a first multicast identifier (e.g., associated with a first group) and a second multicast identifier (e.g., associated with a second group). Provisioning device 210 may store the association (e.g., in a data structure) to allow the first and second groups to be associated. For example, provisioning device 210 may associate the first and second groups to permit the first group to merge with the second group, to permit the first group to become a subgroup of the second group, to scale the first and second groups (e.g., to generate a larger group), or the like.
As further shown in
In some implementations, provisioning device 210 may provide the association information to a network device (e.g., a router, an eNB, a switch, a gateway, etc.) to cause the network device to deliver a message, sent from a first active user device 240-1, to a remaining set of active user devices 240 (e.g., other active user devices 240, besides first active user device 240, associated with the group). Additionally, or alternatively, provisioning device 210 may provide the association to another provisioning device (e.g., a regional provisioning device 210, a centralized provisioning device 210, etc.).
In some implementations, provisioning device 210 may provide the association information periodically. For example, provisioning device 210 may provide the association information when user device 240 has joined the group (e.g., become associated with the group), when user device 240 has left the group (e.g., become disassociated with the group), when user device 240 has become active (e.g., logged into an account), when active user device 240 has become inactive (e.g., logged out of the account), or the like.
In some implementations, the network device may deliver the message by use of a routing protocol. For example, the network device may deliver the message via a distance-vector routing protocol (DVRP), a link-state routing protocol, or the like. Additionally, or alternatively, the network device may deliver the message by use of a protocol-independent multicast (“PIM”) protocol, such as PIM sparse mode (“PIM-SM”), PIM dense mode (“PIM-DM”), bidirectional PIM, PIM source-specific multicast (PIM-SSM”), or the like.
In some implementations, the network device may deliver the message to storage device 250. For example, storage device 250 may be a member of a group. The network device may deliver messages sent from members of the group (e.g., active user devices 240) to storage device 250. In some implementations, storage device 250 may store the messages as a history of messages (e.g., in a data structure associated with storage device 250). Additionally, or alternatively, storage device 250 may provide the history of messages to another device, such as provisioning device 210 and/or user device 240.
Although
As shown in
Group ID field 535 may store information that identifies a group of users and/or a group of user devices 240. In some implementations, user devices 240 may be associated with a wireless network (e.g., private wireless network 230). In some implementations, the group ID may be expressed as a set of characters, including numbers, letters, and/or symbols. Provisioning device 210 may determine the group ID based on registration information received from user device 240 (e.g., when a user of user device 240 registered). Additionally, or alternatively, provisioning device 210 may determine the group ID automatically. For example, provisioning device 210 may determine the group ID based on a chronology of groups (e.g., based on which group, of a set of groups, was first created), based on a business rule, or the like.
Group name field 540 may store information that identifies and/or describes a name of the group identified in group ID field 535. In some implementations, the group name may be expressed as a set of characters, including numbers, letters, and/or symbols. Additionally, or alternatively, the group name may include an identifier to be used by members of the group (e.g., a colloquial name, a colloquial description, etc.). In some implementations, a member of the group (e.g., a user of user device 240) may determine the group name, and may provide the group name to provisioning device 210 (e.g., as part of the registration information). Additionally, or alternatively, provisioning device 210 may determine the group name automatically.
Group members field 545 may store information that identifies members of the group identified in group ID field 535. Group members field 545 may include one or more member identifiers that include one or more characters (e.g., numbers, letters, symbols, etc.) that identify the set of members associated with the group (e.g., the set of users, the set of user devices 240, etc.). In some implementations, the member identifier may include a user name, a user ID, a device name, a device ID, a device type, or the like. Provisioning device 210 may determine the members associated with the group based on registration information. For example, a user of user device 240 may select a group identified in group ID field 535 and/or group name field 540, and provisioning device may add the user to the group by adding an identifier to group members field 545.
Information associated with a single group ID may be conceptually represented as a row in data structure 500. For example, the first row in data structure 500 may correspond to a particular group identified with group ID of “001.” Provisioning device 210 may determine the group ID chronologically (e.g., based on the group being the first group created by provisioning device 210). Additionally, or alternatively, provisioning device 210 may determine the group ID based on a user preference, a business rule, or the like. The group ID may correspond to a group of taxicab drivers, which are identified by a group name of “Baltimore Taxi Cabs.” Provisioning device 210 may determine the group name based on a user preference (e.g., based on the registration information provided by a user). The group of taxicab drivers may include members of the group, identified by member IDs “Taxi-328,” “Taxi-106,” “Taxi-839,” and “Taxi-390.” A member ID may include an identifier associated with a particular taxi cab and/or taxi cab driver (e.g., a particular user).
The second row in data structure 500 of
As shown in
Member ID field 550 may store information that identifies a member of a group (e.g., a group identified in group ID field 535 (
Member name field 555 may store information that identifies a name of a member associated with the group ID. The member name may include a full name, a partial name (e.g., a first name, a last name, an initial, etc.), a nickname, or the like. Provisioning device 210 may determine the member name based on registration information provided by the member (e.g., a user of user device 240).
IP address field 560 may store information that identifies an IP address associated with a user device 240 associated with a member identified by the member ID and/or the member name. In some implementations, the IP address may include a numerical label assigned to a device (e.g., user device 240) to allow the device to receive and/or transmit information via a network (e.g., network 220, private wireless network 230, etc.). Provisioning device 210 may determine the IP address based on registration information. Additionally, or alternatively, provisioning device 210 may determine the IP address when a user (e.g., via user device 240) logs into an account associated with the group.
Information associated with a single member of a group may be conceptually represented as row in data structure 510. For example, the first row in data structure 510 may correspond to a first taxi cab driver associated with a group of Baltimore taxi cab drivers (e.g., identified as group ID “001” in
The second row of data structure 510 may correspond to a second taxi cab driver associated with the group. The second taxi cab driver may be identified by a member ID of “Taxi-106,” a member name of “Cynthia Thomas,” and may be associated with a particular user device 240 identified by an IP address of “41.32.8.457.” Likewise, the third row of data structure 510 may correspond to a third taxi cab driver (e.g., with member ID “Taxi-839,” member name “Gustav Roman,” and IP address “95.14.2.852”), and the fourth row of data structure 510 may correspond to a fourth taxi cab driver (e.g., with member ID “Taxi-390,” member name “Traci Dunn,” and IP address “72.74.6.276.”
As shown in
Group ID field 565 may store information that identifies a group of users and/or a group of user devices 240. Provisioning device 210 may determine group ID field 565 based on group ID field 535 (e.g.,
Multicast address field 575 may store information that identifies an identifier that allows one or more network devices (e.g., a router, an eNB, a gateway device, etc.) to deliver a message to user devices 240 via a wireless network (e.g., private network 230). The multicast address may include a unique set of numbers, letters, and/or symbols. Provisioning device 210 may determine the multicast address, and may assign the multicast address to the group identified by the group ID.
Active group members field 580 may store information that identifies which members of the group identified by group ID field 565 are currently active (e.g., logged into the group). The active group members may include one or more member IDs of the set of member IDs identified in group members field 545 (e.g.,
Information associated with a group may be conceptually represented as a row in data structure 520. For example, a first row in data structure 520 may correspond to group ID “001.” The group ID may identify a group of taxi cab drivers, with a group name of “Baltimore Taxi Cabs.” Provisioning device 210 may assign a unique multicast address, “478.2.945,” to the group, and may determine which members of the group are active group members (e.g., which members of the group are logged in to the group). The active group members may be identified by the member IDs “Taxi-328,” “Taxi-839,” and “Taxi-390.” In some implementations, active group members field 580 may not include members of the group that are not active. For example, a group member (e.g., “Taxi-106”) identified in group members field 545 (e.g.,
The second row in data structure 520 may correspond to group ID “002.” The group ID may identify a social group of painters, with a group name of “Gerald's Painting Group.” Provisioning device 210 may assign a unique multicast address, “532.2.741,” to the group, and may determine that a single group member, with member ID “K. Hitchens,” is currently active (e.g., currently logged on to the group).
In some implementations, provisioning device 210 may determine an association between active user devices 240 and the group by associating the multicast address (e.g., identified in multicast address field 575) with the set of IP addresses (e.g., identified in IP address field 560 of
Data structure 500, data structure 510, and data structure 520 include fields 535-580 for explanatory purposes. In practice, data structure 500, data structure 510, and/or data structure 520 may include additional fields, fewer fields, different fields, or differently arranged fields than those illustrated in
As shown by reference number 610, provisioning device 210 may receive registration information from a first user device 240-1. First user device 240-1 may be associated with a first police officer (e.g., “Police Officer 1”). The registration information may include information for creating a group of first responders in a city. The first police officer may specify, in the registration information, a group name (e.g., “S.F. First Responders”), a member ID (e.g., “O-121”), account information (e.g., a username, a password, etc.), or the like. Provisioning device 210 may create the group based on the registration information.
As shown in
As shown by reference number 630, provisioning device 210 may store information about the group (e.g., in a data structure associated with provisioning device 210). Provisioning device 210 may store the group name (e.g., “S.F. First Responders”), a group ID determined by provisioning device 210 (e.g., “G5432”), and a list of group members associated with the group (e.g., “O-121,” “O-214,” “F-11,” “AD-7,” and “Storage Device 3”).
As shown in
As shown by reference number 660, provisioning device 210 may provide the information about the active group members (e.g., an association between the multicast address and the set of IP addresses associated with the group) to a network device (e.g., associated with private wireless network 230). As shown by reference number 670, the association may allow a message sent from fourth user device 240-4 to be delivered to the active members of the group (e.g., first user device 240-1 and third user device 230-3). The association may also allow the message to be delivered to storage device 250, as shown by reference number 680. Storage device 250 may store a history of messages sent from active user devices 240 (e.g., in a data structure associated with storage device 250).
As indicated above,
As shown by reference number 710, user device 240 may provide login information to first provisioning device 210-1. First provisioning device 210-1 may act as a centralized provisioning device 210, and may store information that identifies which provisioning device 210, of the set of provisioning devices 210, stores information associated with a group to which user device 240 belongs. Based on determining an appropriate provisioning device 210, first provisioning device 210-1 may provide the login information to fourth provisioning device 210-4, as shown by reference number 720.
As shown by reference number 730, fourth provisioning device 210-4 may receive the login information from first provisioning device 210-1. Fourth provisioning device 210-4 may update group information associated with user device 240 based on the login information (e.g., may list user device 240 among a list of active user devices 240, may update an IP address associated with user device 240, or the like). Fourth provisioning device 210-4 may provide the group information to a network device associated with a wireless network (e.g., private wireless network 230) so that messages sent in the wireless network can be broadcast multicast to active user devices 240.
As indicated above,
Implementations described herein may allow a provisioning device to create a private, scalable wireless network of user devices that permit the user devices to receive multicast messages from other members of the group.
The foregoing disclosure provides illustration and description, but is not intended to be exhaustive or to limit the implementations to the precise form disclosed. Modifications and variations are possible in light of the above disclosure or may be acquired from practice of the implementations.
As used herein, the term component is intended to be broadly construed as hardware, firmware, or a combination of hardware and software.
It will be apparent that systems and/or methods, as described herein, may be implemented in many different forms of software, firmware, and hardware in the implementations illustrated in the figures. The actual software code or specialized control hardware used to implement these systems and/or methods is not limiting of the implementations. Thus, the operation and behavior of the systems and/or methods were described without reference to the specific software code—it being understood that software and hardware can be designed to implement the systems and/or methods based on the description herein.
Even though particular combinations of features are recited in the claims and/or disclosed in the specification, these combinations are not intended to limit the disclosure of possible implementations. In fact, many of these features may be combined in ways not specifically recited in the claims and/or disclosed in the specification. Although each dependent claim listed below may directly depend on only one claim, the disclosure of possible implementations includes each dependent claim in combination with every other claim in the claim set.
To the extent the aforementioned implementations collect, store, or employ personal information provided by individuals, it should be understood that such information shall be used in accordance with all applicable laws concerning protection of personal information. Additionally, the collection, storage, and use of such information may be subject to consent of the individual to such activity, for example, through “opt-in” or “opt-out” processes as may be appropriate for the situation and type of information. Storage and use of personal information may be in an appropriately secure manner reflective of the type of information, for example, through various encryption and anonymization techniques for particularly sensitive information.
No element, act, or instruction used herein should be construed as critical or essential unless explicitly described as such. Also, as used herein, the articles “a” and “an” are intended to include one or more items, and may be used interchangeably with “one or more.” Where only one item is intended, the term “one” or similar language is used. Further, the phrase “based on” is intended to mean “based, at least in part, on” unless explicitly stated otherwise.
Number | Name | Date | Kind |
---|---|---|---|
6529882 | Park | Mar 2003 | B1 |
7075904 | Manish | Jul 2006 | B1 |
7162241 | Kim | Jan 2007 | B2 |
7170863 | Denman | Jan 2007 | B1 |
7549160 | Podar et al. | Jun 2009 | B1 |
7970425 | Balachandran | Jun 2011 | B2 |
8196051 | Zaner | Jun 2012 | B2 |
8249068 | Bijwaard et al. | Aug 2012 | B2 |
8428237 | Denman | Apr 2013 | B1 |
9246763 | Forssell | Jan 2016 | B2 |
9432820 | Anchan | Aug 2016 | B2 |
9736705 | Yun | Aug 2017 | B2 |
10182330 | Pazos | Jan 2019 | B2 |
20020037736 | Kawaguchi | Mar 2002 | A1 |
20030017836 | Vishwanathan | Jan 2003 | A1 |
20030083046 | Mathis | May 2003 | A1 |
20030086423 | Hsu | May 2003 | A1 |
20030119540 | Mathis | Jun 2003 | A1 |
20030126137 | McFadden | Jul 2003 | A1 |
20030153340 | Crockett | Aug 2003 | A1 |
20030231629 | Banerjee | Dec 2003 | A1 |
20040082351 | Westman | Apr 2004 | A1 |
20040137882 | Forsyth | Jul 2004 | A1 |
20040185856 | McKenna | Sep 2004 | A1 |
20040230664 | Bowers | Nov 2004 | A1 |
20040233907 | Hundscheidt | Nov 2004 | A1 |
20040246984 | Hundscheidt | Dec 2004 | A1 |
20050007969 | Hundscheidt | Jan 2005 | A1 |
20050076369 | Cai | Apr 2005 | A1 |
20050111474 | Kobayashi | May 2005 | A1 |
20050143135 | Brems | Jun 2005 | A1 |
20050170842 | Chen | Aug 2005 | A1 |
20050181815 | Shostak | Aug 2005 | A1 |
20050243721 | Cai | Nov 2005 | A1 |
20050281264 | Hsu | Dec 2005 | A1 |
20050281265 | Sakamoto | Dec 2005 | A1 |
20060003784 | Chion | Jan 2006 | A1 |
20060030347 | Biswaas | Feb 2006 | A1 |
20060040689 | Yoon | Feb 2006 | A1 |
20060077897 | Kotzin | Apr 2006 | A1 |
20060088031 | Nalawade | Apr 2006 | A1 |
20060168087 | Lescuyer | Jul 2006 | A1 |
20060184683 | Bosscha et al. | Aug 2006 | A1 |
20060235981 | Westman | Oct 2006 | A1 |
20060246933 | Na | Nov 2006 | A1 |
20070019616 | Rantapuska | Jan 2007 | A1 |
20070049314 | Balachandran | Mar 2007 | A1 |
20070058653 | Harris | Mar 2007 | A1 |
20070177593 | Kompella | Aug 2007 | A1 |
20070233802 | Kulkarni | Oct 2007 | A1 |
20070286106 | Yang | Dec 2007 | A1 |
20080084837 | Watanabe | Apr 2008 | A1 |
20080125158 | Shostak | May 2008 | A1 |
20080132181 | Shen | Jun 2008 | A1 |
20080253322 | So | Oct 2008 | A1 |
20080288589 | Ala-Pietila | Nov 2008 | A1 |
20080310408 | Thompson | Dec 2008 | A1 |
20090054097 | Kim | Feb 2009 | A1 |
20090190587 | Zhao | Jul 2009 | A1 |
20090252084 | Fodor | Oct 2009 | A1 |
20090320102 | Ou | Dec 2009 | A1 |
20100083318 | Weare | Apr 2010 | A1 |
20100261488 | Little | Oct 2010 | A1 |
20100262924 | Kalu | Oct 2010 | A1 |
20100287215 | Lasensky | Nov 2010 | A1 |
20100306320 | Leppanen | Dec 2010 | A1 |
20100329169 | de Bruin | Dec 2010 | A1 |
20110069652 | Kakani | Mar 2011 | A1 |
20110161319 | Chunilal | Jun 2011 | A1 |
20120151561 | Kreiner | Jun 2012 | A1 |
20120202428 | Mirbaha | Aug 2012 | A1 |
20120232943 | Myr | Sep 2012 | A1 |
20130046841 | Park | Feb 2013 | A1 |
20130066984 | Shin | Mar 2013 | A1 |
20130109425 | Kerger | May 2013 | A1 |
20130136049 | Song | May 2013 | A1 |
20130229969 | Quan | Sep 2013 | A1 |
20130246631 | Gonzales | Sep 2013 | A1 |
20130272186 | Mohanty | Oct 2013 | A1 |
20140067826 | Jackson | Mar 2014 | A1 |
20140112251 | Kim | Apr 2014 | A1 |
20140120973 | Agulnik | May 2014 | A1 |
20140126452 | Agulnik | May 2014 | A1 |
20140192697 | Anchan | Jul 2014 | A1 |
20140194100 | Anchan | Jul 2014 | A1 |
20140219157 | Sukumar | Aug 2014 | A1 |
20140282095 | Walters | Sep 2014 | A1 |
20140286222 | Yu | Sep 2014 | A1 |
20140304357 | Bestler | Oct 2014 | A1 |
20140355508 | Anchan | Dec 2014 | A1 |
20140357226 | Charugundla | Dec 2014 | A1 |
20140358997 | Boulkenafed | Dec 2014 | A1 |
20150063186 | Kakadia | Mar 2015 | A1 |
20150223028 | Wang | Aug 2015 | A1 |
20150223030 | Gu | Aug 2015 | A1 |
20150229677 | Gu | Aug 2015 | A1 |
20150230063 | Chandramouli | Aug 2015 | A1 |
20150236865 | Field | Aug 2015 | A1 |
20150244656 | Choi | Aug 2015 | A1 |
20150317583 | Huang | Nov 2015 | A1 |
20160036962 | Rand | Feb 2016 | A1 |
20160165413 | Bhalla | Jun 2016 | A1 |
Entry |
---|
Wikipedia, “Multicast Address”, http://en.wikipedia.org/w/index.php?title=Multicast_address&oldid=569517613, Aug. 21, 2013, 6 pages. |
Wikipedia, “Multimedia Broadcast Multicast Service”, http://en.wikipedia.org/w/index.php?title=Multimedia_Broadcast_Mulicast_Service&oldid=56433570, Jul. 15, 2013, 4 pages. |
Number | Date | Country | |
---|---|---|---|
20150063186 A1 | Mar 2015 | US |