US20180295623A1 - Communications between connected devices - Google Patents
Communications between connected devices Download PDFInfo
- Publication number
- US20180295623A1 US20180295623A1 US15/925,181 US201815925181A US2018295623A1 US 20180295623 A1 US20180295623 A1 US 20180295623A1 US 201815925181 A US201815925181 A US 201815925181A US 2018295623 A1 US2018295623 A1 US 2018295623A1
- Authority
- US
- United States
- Prior art keywords
- channels
- channel
- nodes
- individual node
- processor
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000004891 communication Methods 0.000 title claims abstract description 23
- 238000000034 method Methods 0.000 claims abstract description 27
- 230000005540 biological transmission Effects 0.000 claims abstract description 23
- 230000015654 memory Effects 0.000 claims description 23
- 230000008859 change Effects 0.000 claims description 6
- 230000008569 process Effects 0.000 claims description 5
- 238000005259 measurement Methods 0.000 claims description 3
- 238000001228 spectrum Methods 0.000 description 11
- 230000006870 function Effects 0.000 description 8
- 238000005516 engineering process Methods 0.000 description 6
- 101100172132 Mus musculus Eif3a gene Proteins 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- 238000012545 processing Methods 0.000 description 3
- 230000001174 ascending effect Effects 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 238000001514 detection method Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000036541 health Effects 0.000 description 2
- 230000033001 locomotion Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000004134 energy conservation Methods 0.000 description 1
- 230000007613 environmental effect Effects 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 239000004557 technical material Substances 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W72/00—Local resource management
- H04W72/04—Wireless resource allocation
- H04W72/044—Wireless resource allocation based on the type of the allocated resource
- H04W72/0453—Resources in frequency domain, e.g. a carrier in FDMA
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W84/00—Network topologies
- H04W84/18—Self-organising networks, e.g. ad-hoc networks or sensor networks
Definitions
- Embodiments relate generally to multi-channel communications between sensor nodes for wireless sensor networks. More specifically, disclosed is system and methods that enable wireless communications between devices using different wireless transmission protocols.
- the future of devices e.g., computing devices such as computers, cameras, appliances, etc.
- devices e.g., computing devices such as computers, cameras, appliances, etc.
- the Internet of Things is the idea where devices in environments such as home automation, health care, emergency response, intelligent shopping, smart product management, environmental sensing, smart meters, waste management, urban planning can communicate with other devices and the World Wide Web.
- the devices in these environments communicate using protocols that can enable many devices to connect to a network and communicate in an efficient and reliable way.
- One challenge is to add connections within one contention region (where wireless devices' are physically close enough that their transmission may interfere with each other) when the available network spectrum is limited.
- devices to connect they usually need to use a portion of the spectrum (e.g., wireless band) to send messages to an appropriate receiver.
- a portion of the spectrum e.g., wireless band
- These issues and similar issues can be worse when devices use popular wireless bands such as the Industrial, Scientific and Medical Radio Band of 2.4 GHz which is also used by other standards based on different channel definition within the band.
- IEEE 802.11 and IEEE 802.15.4 share the spectrum and avoid collisions by switching channels in such a way that there is no overlap among the utilized channels around neighboring devices. This feature is called “frequency agility” and is defined in ZigBee RF4CE Specification Version 1.01.
- devices that use the same standard are usually required to stay on the same channel. This means contention will not be controlled among nodes using 802.15.4 standard.
- aspects of the exemplary embodiments may include a transceiver radio for a wireless hub including an RF front end receiver that can capture, demodulate and decode a pre-defined band entirely as well as medium access algorithms for managing channel access when multiple users try to access the band; as well as a transceiver radio for a sensor device including updated medium access control algorithm that can communicate with the aforementioned hub in order to efficiently access the spectrum while reducing contention.
- the RF front end radio at the hub can capture messages sent over the pre-defined band when messages are sent over non-overlapping channels and each channel is occupying a different part of the spectrum. Using this Radio, the need to implement multiple RF front ends is eliminated. Utilizing the offered communication system for Home Automation, health care, emergency response, intelligent shopping etc. results in larger network density (more number of nodes within the same geographical area), reduced transmission delay, and energy conservation.
- the present technology includes a computer-implemented method comprising the following steps. First, receiving, at a hub in communication with at a plurality of computing nodes, a first plurality of available communication channel lists, each one of the available communication channel list being generated by one of the plurality of computing nodes. Secondly, determining one or more channels unavailable for the hub determining, based at least in part on the one or more channels unavailable for the hub, a second plurality of available communication lists, each one of the available channel lists associated with one of the plurality of computing nodes. Thirdly, sorting, according to numeric values of the second plurality of available communication lists, the plurality of computing nodes to form a sorted plurality of computing nodes in an ascending order. Lastly, selecting a communication channel for each of the plurality of computing nodes based on the sorted plurality of computing nodes in the ascending order.
- FIG. 1 illustrates channel definition for 802.15.4 on the top and 802.11 at the bottom for 2.4 GHz band in accordance with an embodiment
- FIG. 2 is a diagram illustrating an example of the network topology in accordance with an embodiment
- FIG. 3 is an example flow diagram illustrating an example of the proposed algorithm in accordance with various embodiments
- FIG. 4 illustrates an exemplary network device in accordance with an embodiment
- FIG. 5 illustrates an exemplary system in accordance with various embodiments.
- the present technology enables a coordinator or a centralized hub that can connect to and communicate with numerous devices.
- the hub is connected to the web and control devices such as smart phones or smart tablets.
- the control devices can directly communicate with the hub and coordinate the connected devices via applications.
- one present problem is that many of the popular standards designed and reserved for a platform (exp. IEEE 802.11 and IEEE 802.15.4) share wireless bands.
- the wireless band is usually divided into multiple channels. For each standard, different channel definitions are introduced.
- the available band/spectrum is shared among all neighbors when their radio use a wireless standard based on that spectrum.
- only one channel can be used by each node for any popular IoT standards. Therefore, multiple nodes using the same standard have to compete for the same channel or similar channels; while other nodes based other standard compete for their designated channels.
- Contention is the main limitation when it comes to increasing network density by number of nodes and reducing transmission delay.
- Transmission delay is the transmission time for a message from entering a node's transmission queue to being received by the receiver's radio.
- the present technology utilizes the available band efficiently so that computing nodes can use different parts of the available band concurrently to reduce contention. As a result, more nodes can be added to the network without causing much transmission delays.
- the present technology solves the problem that coordinators and hubs can only capture and receive a single transmission over a single channel for IoT standards, and the nodes need to share this single channel via Carrier Sense Multiple Access with Collision Avoidance (CSMA/CA).
- CSMA/CA Carrier Sense Multiple Access with Collision Avoidance
- the average throughput (i.e., the number of successfully received bits) per node decreases as number of neighboring nodes (i.e., density) increases to the point that it will reach to zero as density approaches its maximum possible value.
- aspects of the exemplary embodiments may include a transceiver radio including an RF front end receiver that can capture, demodulate and decode a pre-defined band entirely as well as medium access algorithms for managing channel access when multiple users try to access the band.
- the RF front end radio can capture messages sent over the pre-defined band concurrently when messages are sent over non-overlapping channels and each channel is occupying a different part of the spectrum. Using this Radio, the need to implement multiple RF front ends is eliminated (which is limited in terms of number of possible radios and difficult to attain).
- the network of nodes is clustered to groups. In each group there is one root and some children. The children in each cluster produce data and send their information to the root of that cluster.
- the roots can also create clusters among themselves and create a hierarchy of clusters in order to eventually send the gathered data back to the coordinator which acts as the sink for all the gathered data.
- the invention includes a channel assignment algorithm.
- the network can be clustered depending on the transmission range of the nodes and the channel assignment algorithm is implemented at the root of each cluster.
- the root collects messages from its children and re-sends them to the further away root if the transmission range of the original senders is shorter than their distance to the coordinator/top root. Also children can use less power to transmit data to the closer root compared to the further away coordinator even if the transmission range can support the geographical distance.
- the coordinator can connect the clustered network to the internet and the end user.
- one of the major standards used in Internet of Things is 802.15.4.
- the new algorithm enables implementation of new hubs that allow multiple 802.15.4 devices to use different unoccupied 802.15.4 channels at the same time.
- the hub can receive and demodulate messages sent over these non-overlapping channels concurrently.
- the devices that use non-overlapping channels do not need to wait for their turn to send messages to the hub if they are assigned a unique non-overlapping channel for their transmission. This brings about less transmitter active time, faster channel access, and ultimately less power consumption.
- the channel assignment algorithm can detect and find channels that are available and free to be used by its children, meaning that no other user around that specific child is using the channel for data transmission. According to some embodiments, the channel assignment algorithm can assign free channels to the children and keep channel usage among them as evenly distributed as possible. This means that the algorithm should not assign one channel to too many children while assign another channel to too few children. The goal is to keep contention at a minimum level.
- FIG. 2 illustrates an example 200 of the network topology when there are multiple nodes that collect information and need to send it back to the coordinator.
- coordinator may or may not be within the transmission range of the nodes.
- relaying hubs roots
- the hubs are special devices equipped with the similar transceiver as the coordinator.
- the channel allocation algorithm will be applied at both the coordinator and the hubs. Each will run the algorithm independently to choose channels for future transmissions to/from its own children.
- specific terms such as relaying hubs, roots and coordinators are interchangeable, and specific terms such as children and child nodes are interchangeable.
- a coordinator or hub 202 can apply algorithm to select channels (e.g. 232 , 234 , 236 , 238 and 240 ) for multiple child nodes (e.g. 204 , 206 , 208 , 210 and 212 ).
- child nodes can also serve as relay hubs (e.g. 208 , 210 and 212 ) that can further communicate with one or more child nodes.
- child node or replay hub 212 can run algorithm to select channels (e.g. 241 , 244 and 246 ) for multiple child nodes (e.g. 226 , 228 and 230 ).
- child node or relay hub 208 can communicate with multiple child nodes (e.g. 214 , 216 and 218 ); child node or relay hub 210 can communicate with multiple child nodes (e.g. 220 , 222 and 224 ).
- each coordinator or hub can individually and independently apply algorithm to select available channels for the associated child nodes.
- coordinator or hub 202 can apply algorithm to select one non-overlapping channel 232 , 234 , 236 , 238 and 240 and assign each of the channels to each of the associated child nodes 204 , 206 , 208 , 210 and 222 . Because these channels are non-overlapping to each other, all child nodes 204 , 206 , 208 , 210 and 212 can concurrently transmit data to coordinator or hub 202 .
- the coordinator or hub can further reduce the contention issue by evenly distributing available channels among all the child nodes. For example, coordinator or hub 202 can avoid assigning one channel to too many or too few child nodes.
- FIG. 3 illustrates an example 300 of the proposed algorithm applied by each root to allocate a channel to each of its children for their future communications with the root.
- the channel selection algorithm starts at 302 when the root starts collecting channel status information from each child one by one. All children use a pre-defined control channel (set by the network designer) and CSMA/CA medium access protocol to send their channel status information to the root. Root needs to collect this information about all channels from all its children.
- the channel status information collected from each child shows two possible answers for each of the available channels: “Busy_status” or “Free_status”.
- Busy_status means that the channel might be used by other neighbors of the sensing child and at the sensing child, the noise level at this specific channel is very high, so it's “Busy”.
- the root checks the status of channels around itself, meaning that it will sense the noise level around itself at each channel and give each channel a Busy or Free flag based on its own measurements. If a channel is Busy around the root, it will be eliminated from the channel assignment algorithm 306 , since children cannot transmit on a channel that is already sensed with a high noise level at the receiver (root).
- the root lists the channel with free status for each child (“Free channel list”) and for each channel with a free status, it counts how many children include that channel in their list as a free channel.
- This counter can be called “ch_selection” counter and can be from 0 to the total number of channels.
- each channel has a “ch_counter” associated with it.
- the root checks the free channel list for each child, and if a child has more than one free channel in its list, one of them should be chosen since only one channel will be assigned to each child. At this step, the root chooses that channel that has the smallest “ch_selection” counter (which means that it has been listed less than the other channel). This ensures uniform selection of channels for children. After each change to the list, the root updates the ch_selection counter for the channels.
- the root sorts all channels based on their ch_selection counter ascendingly meaning that channels with smallest ch_counter will be first and channels with the largest ch_selection counter will be last.
- 320 is a checkpoint to see if all children have one channel in their list. If yes, 314 is the finishing step of the algorithm and if not, the algorithm moves to step 316 .
- the root sorts all the children that have no channels in their list based on their ID (ascendingly or descendingly.) then at 318 , it will assign the first channel from the channel list to the first child from the children list. Then ch_selection counter is updated and at 319 the algorithm moves to step 312 where it will sort channels again and goes to the check point 320 to check for the finishing step of the algorithm.
- the shared channel among the chosen children can be accessed via the CSMA/CA protocol that is well known in the art.
- the root can broadcast its selection table to the children on a pre-defined control channel. This channel is assigned during installation. The message will be acknowledged by the root children to make sure they all have successfully received the information regarding g the chosen channel and they can send info on the assigned channel for the future communication.
- the call for channel selection at the root can be applied at one or more of the following situations:
- FIG. 4 illustrates example 400 of an exemplary network device 410 suitable for implementing the present invention.
- Network device 410 includes a master central processing unit (CPU) 462 , interfaces 468 , and a bus 415 (e.g., a PCI bus).
- CPU 462 When acting under the control of appropriate software or firmware, the CPU 462 is responsible numerous tasks, at least some of which relate to network management. It preferably accomplishes all these functions under the control of software including an operating system and any appropriate applications software.
- CPU 462 may include one or more processors 463 such as a processor from the Motorola family of microprocessors or the MIPS family of microprocessors. In an alternative embodiment, processor 463 is specially designed hardware for controlling the operations of router 410 .
- a memory 461 (such as non-volatile RAM and/or ROM) also forms part of CPU 462 . However, there are many different ways in which memory could be coupled to the system.
- the interfaces 468 are typically provided as interface cards (sometimes referred to as “line cards”). Generally, they control the sending and receiving of data packets over the network and sometimes support other peripherals used with the router 410 .
- the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like.
- various very high-speed interfaces may be provided such as fast token ring interfaces, wireless interfaces, Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces and the like.
- these interfaces may include ports appropriate for communication with the appropriate media. In some cases, they may also include an independent processor and, in some instances, volatile RAM.
- the independent processors may control such communications intensive tasks as packet switching, media control and management. By providing separate processors for the communications intensive tasks, these interfaces allow the master microprocessor 462 to efficiently perform routing computations, network diagnostics, security functions, etc.
- FIG. 4 is one specific network device of the present invention, it is by no means the only network device architecture on which the present invention can be implemented.
- an architecture having a single processor that handles communications as well as routing computations, etc. is often used.
- other types of interfaces and media could also be used with the router.
- the network device may employ one or more memories or memory modules (including memory 461 ) configured to store program instructions for the general-purpose network operations and mechanisms for roaming, route optimization and routing functions described herein.
- the program instructions may control the operation of an operating system and/or one or more applications, for example.
- the memory or memories may also be configured to store tables such as mobility binding, registration, and association tables, etc.
- FIG. 5 illustrates example 500 of exemplary possible system embodiments, such a system making up network device 410 .
- the more appropriate embodiment will be apparent to those of ordinary skill in the art when practicing the present technology. Persons of ordinary skill in the art will also readily appreciate that other system embodiments are possible.
- FIG. 5 illustrates a conventional system bus computing system architecture 502 wherein the components of the system are in electrical communication with each other using a bus 505 .
- Exemplary system 500 includes a processing unit (CPU or processor) 510 and a system bus 505 that couples various system components including the system memory 515 , such as read only memory (ROM) 520 and random access memory (RAM) 525 , to the processor 510 .
- system memory 515 such as read only memory (ROM) 520 and random access memory (RAM) 525
- the system 500 can include a cache of high-speed memory connected directly with, in close proximity to, or integrated as part of the processor 510 .
- the system 500 can copy data from the memory 515 and/or the storage device 530 to the cache 512 for quick access by the processor 510 . In this way, the cache can provide a performance boost that avoids processor 510 delays while waiting for data.
- These and other modules can control or be configured to control the processor 510 to perform various actions.
- Other system memory 515 may be available for use as well.
- the memory 515 can include multiple different types of memory with different performance characteristics.
- the processor 510 can include any general purpose processor and a hardware module or software module, such as module 1 532 , module 2 534 , and module 3 536 stored in storage device 530 , configured to control the processor 510 as well as a special-purpose processor where software instructions are incorporated into the actual processor design.
- the processor 510 may essentially be a completely self-contained computing system, containing multiple cores or processors, a bus, memory controller, cache, etc.
- a multi-core processor may be symmetric or asymmetric.
- the communications interface 540 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
- Storage device 530 is a non-volatile memory and can be a hard disk or other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 525 , read only memory (ROM) 520 , and hybrids thereof.
- RAMs random access memories
- ROM read only memory
- the storage device 530 can include software modules 532 , 534 , 536 for controlling the processor 510 . Other hardware or software modules are contemplated.
- the storage device 530 can be connected to the system bus 505 .
- a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as the processor 510 , bus 505 , display 535 , and so forth, to carry out the function.
- the present technology may be presented as including individual functional blocks including functional blocks comprising devices, device components, steps or routines in a method embodied in software, or combinations of hardware and software.
- the computer-readable storage devices, mediums, and memories can include a cable or wireless signal containing a bit stream and the like.
- non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
- Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network.
- the computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that may be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on.
- Devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example.
- the instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
Description
- This application is a continuation of U.S. patent application Ser. No. 14/586,492, entitled “COMMUNICATIONS BETWEEN CONNECTED DEVICES” filed Dec. 30, 2014, which is now issued as U.S. Pat. No. 9,924,514, and which is incorporated in entirety herein by reference for all purposes.
- A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
- Embodiments relate generally to multi-channel communications between sensor nodes for wireless sensor networks. More specifically, disclosed is system and methods that enable wireless communications between devices using different wireless transmission protocols.
- The future of devices (e.g., computing devices such as computers, cameras, appliances, etc.) or other objects will change by the ability to communicate with other devices and the World Wide Web. For example, the Internet of Things (IoT) is the idea where devices in environments such as home automation, health care, emergency response, intelligent shopping, smart product management, environmental sensing, smart meters, waste management, urban planning can communicate with other devices and the World Wide Web. The devices in these environments communicate using protocols that can enable many devices to connect to a network and communicate in an efficient and reliable way. One challenge is to add connections within one contention region (where wireless devices' are physically close enough that their transmission may interfere with each other) when the available network spectrum is limited.
- For example, for devices to connect, they usually need to use a portion of the spectrum (e.g., wireless band) to send messages to an appropriate receiver. However, when other devices within the same contention region also attempt to access the spectrum, there will be increasing collisions and access delay as the number of devices increase. As more devices attempt to access the same spectrum, the more contention is created and, as a result, connection attempts can fail. These issues and similar issues can be worse when devices use popular wireless bands such as the Industrial, Scientific and Medical Radio Band of 2.4 GHz which is also used by other standards based on different channel definition within the band. For this band, IEEE 802.11 and IEEE 802.15.4 share the spectrum and avoid collisions by switching channels in such a way that there is no overlap among the utilized channels around neighboring devices. This feature is called “frequency agility” and is defined in ZigBee RF4CE Specification Version 1.01. However, devices that use the same standard are usually required to stay on the same channel. This means contention will not be controlled among nodes using 802.15.4 standard.
- Thus, there is a need to manage better use of spectrum when multiple channels are available within a single standard (or various standards) and can be distributed among devices to reduce contention among neighboring nodes.
- Aspects of the exemplary embodiments may include a transceiver radio for a wireless hub including an RF front end receiver that can capture, demodulate and decode a pre-defined band entirely as well as medium access algorithms for managing channel access when multiple users try to access the band; as well as a transceiver radio for a sensor device including updated medium access control algorithm that can communicate with the aforementioned hub in order to efficiently access the spectrum while reducing contention.
- The RF front end radio at the hub can capture messages sent over the pre-defined band when messages are sent over non-overlapping channels and each channel is occupying a different part of the spectrum. Using this Radio, the need to implement multiple RF front ends is eliminated. Utilizing the offered communication system for Home Automation, health care, emergency response, intelligent shopping etc. results in larger network density (more number of nodes within the same geographical area), reduced transmission delay, and energy conservation.
- According to some embodiments, the present technology includes a computer-implemented method comprising the following steps. First, receiving, at a hub in communication with at a plurality of computing nodes, a first plurality of available communication channel lists, each one of the available communication channel list being generated by one of the plurality of computing nodes. Secondly, determining one or more channels unavailable for the hub determining, based at least in part on the one or more channels unavailable for the hub, a second plurality of available communication lists, each one of the available channel lists associated with one of the plurality of computing nodes. Thirdly, sorting, according to numeric values of the second plurality of available communication lists, the plurality of computing nodes to form a sorted plurality of computing nodes in an ascending order. Lastly, selecting a communication channel for each of the plurality of computing nodes based on the sorted plurality of computing nodes in the ascending order.
- Various embodiments or examples of the invention are disclosed in the following detailed description and the accompanying drawings:
-
FIG. 1 illustrates channel definition for 802.15.4 on the top and 802.11 at the bottom for 2.4 GHz band in accordance with an embodiment; -
FIG. 2 is a diagram illustrating an example of the network topology in accordance with an embodiment; -
FIG. 3 is an example flow diagram illustrating an example of the proposed algorithm in accordance with various embodiments; -
FIG. 4 illustrates an exemplary network device in accordance with an embodiment; and -
FIG. 5 illustrates an exemplary system in accordance with various embodiments. - Various embodiments or examples may be implemented in numerous ways, including as a system, a process, an apparatus, a user interface, or a series of program instructions on a computer readable medium such as a computer readable storage medium or a computer network where the program instructions are sent over optical, electronic, or wireless communication links. In general, operations of disclosed processes may be performed in an arbitrary order, unless otherwise provided in the claims.
- A detailed description of one or more examples is provided below along with accompanying figures. The detailed description is provided in connection with such examples, but is not limited to any particular example. The scope is limited only by the claims and numerous alternatives, modifications, and equivalents are encompassed. Numerous specific details are set forth in the following description in order to provide a thorough understanding. These details are provided for the purpose of example and the described techniques may be practiced according to the claims without some or all of these specific details. For clarity, technical material that is known in the technical fields related to the examples has not been described in detail to avoid unnecessarily obscuring the description.
- The future of the objects in the world will change by the ability to communicate to other objects and the World Wide Web. In this way, most devices (e.g., TVs, appliances, lightings, etc.) will have sensors, actuators, and transceivers and have the ability to communicate with each other. For various applications such as home automation devices can make decisions based on information they receive from other devices without the involvement of the network owner. For instance, the coffee maker can start making coffee when the motion sensor detects movement near the kitchen in the morning time, or the hallway lights turn on before the front door is open. All the “things” we deal with daily can become smart and make our lives easier. To achieve this, these devices need to communicate wirelessly with each other.
- The present technology enables a coordinator or a centralized hub that can connect to and communicate with numerous devices. The hub is connected to the web and control devices such as smart phones or smart tablets. The control devices can directly communicate with the hub and coordinate the connected devices via applications.
- As shown in
FIG. 1 , one present problem is that many of the popular standards designed and reserved for a platform (exp. IEEE 802.11 and IEEE 802.15.4) share wireless bands. The wireless band is usually divided into multiple channels. For each standard, different channel definitions are introduced. For network nodes, the available band/spectrum is shared among all neighbors when their radio use a wireless standard based on that spectrum. Typically, only one channel can be used by each node for any popular IoT standards. Therefore, multiple nodes using the same standard have to compete for the same channel or similar channels; while other nodes based other standard compete for their designated channels. - To avoid interference, these competing nodes from different standards should avoid using the same channels. Meanwhile, sharing only one channel by nodes that utilize the same standard means that there will be contention. Contention is the main limitation when it comes to increasing network density by number of nodes and reducing transmission delay. Transmission delay is the transmission time for a message from entering a node's transmission queue to being received by the receiver's radio.
- The present technology utilizes the available band efficiently so that computing nodes can use different parts of the available band concurrently to reduce contention. As a result, more nodes can be added to the network without causing much transmission delays. The present technology solves the problem that coordinators and hubs can only capture and receive a single transmission over a single channel for IoT standards, and the nodes need to share this single channel via Carrier Sense Multiple Access with Collision Avoidance (CSMA/CA). In accordance with various embodiments, when CSMA/CA is used as the medium access technique, the average throughput (i.e., the number of successfully received bits) per node decreases as number of neighboring nodes (i.e., density) increases to the point that it will reach to zero as density approaches its maximum possible value.
- Aspects of the exemplary embodiments may include a transceiver radio including an RF front end receiver that can capture, demodulate and decode a pre-defined band entirely as well as medium access algorithms for managing channel access when multiple users try to access the band. The RF front end radio can capture messages sent over the pre-defined band concurrently when messages are sent over non-overlapping channels and each channel is occupying a different part of the spectrum. Using this Radio, the need to implement multiple RF front ends is eliminated (which is limited in terms of number of possible radios and difficult to attain).
- The network of nodes is clustered to groups. In each group there is one root and some children. The children in each cluster produce data and send their information to the root of that cluster. The roots can also create clusters among themselves and create a hierarchy of clusters in order to eventually send the gathered data back to the coordinator which acts as the sink for all the gathered data.
- The invention includes a channel assignment algorithm. The network can be clustered depending on the transmission range of the nodes and the channel assignment algorithm is implemented at the root of each cluster. The root collects messages from its children and re-sends them to the further away root if the transmission range of the original senders is shorter than their distance to the coordinator/top root. Also children can use less power to transmit data to the closer root compared to the further away coordinator even if the transmission range can support the geographical distance. The coordinator can connect the clustered network to the internet and the end user.
- For example, one of the major standards used in Internet of Things is 802.15.4. The new algorithm enables implementation of new hubs that allow multiple 802.15.4 devices to use different unoccupied 802.15.4 channels at the same time. The hub can receive and demodulate messages sent over these non-overlapping channels concurrently. The devices that use non-overlapping channels do not need to wait for their turn to send messages to the hub if they are assigned a unique non-overlapping channel for their transmission. This brings about less transmitter active time, faster channel access, and ultimately less power consumption.
- According to some embodiment, the channel assignment algorithm can detect and find channels that are available and free to be used by its children, meaning that no other user around that specific child is using the channel for data transmission. According to some embodiments, the channel assignment algorithm can assign free channels to the children and keep channel usage among them as evenly distributed as possible. This means that the algorithm should not assign one channel to too many children while assign another channel to too few children. The goal is to keep contention at a minimum level.
-
FIG. 2 illustrates an example 200 of the network topology when there are multiple nodes that collect information and need to send it back to the coordinator. Generally depending on the distribution of the nodes, coordinator may or may not be within the transmission range of the nodes. In such cases, relaying hubs (roots) need to be deployed to pass the messages to the coordinator. The hubs are special devices equipped with the similar transceiver as the coordinator. The channel allocation algorithm will be applied at both the coordinator and the hubs. Each will run the algorithm independently to choose channels for future transmissions to/from its own children. In the present specification, specific terms such as relaying hubs, roots and coordinators are interchangeable, and specific terms such as children and child nodes are interchangeable. - In
FIG. 2 , a coordinator orhub 202 can apply algorithm to select channels (e.g. 232, 234, 236, 238 and 240) for multiple child nodes (e.g. 204, 206, 208, 210 and 212). According to some embodiments, child nodes can also serve as relay hubs (e.g. 208, 210 and 212) that can further communicate with one or more child nodes. As shown inFIG. 2 , child node orreplay hub 212 can run algorithm to select channels (e.g. 241, 244 and 246) for multiple child nodes (e.g. 226, 228 and 230). Additionally, child node orrelay hub 208 can communicate with multiple child nodes (e.g. 214, 216 and 218); child node orrelay hub 210 can communicate with multiple child nodes (e.g. 220, 222 and 224). - According to some embodiments, each coordinator or hub can individually and independently apply algorithm to select available channels for the associated child nodes. For example, coordinator or
hub 202 can apply algorithm to select onenon-overlapping channel child nodes child nodes hub 202. - According to some embodiments, the coordinator or hub can further reduce the contention issue by evenly distributing available channels among all the child nodes. For example, coordinator or
hub 202 can avoid assigning one channel to too many or too few child nodes. -
FIG. 3 illustrates an example 300 of the proposed algorithm applied by each root to allocate a channel to each of its children for their future communications with the root. According to some embodiments, the channel selection algorithm starts at 302 when the root starts collecting channel status information from each child one by one. All children use a pre-defined control channel (set by the network designer) and CSMA/CA medium access protocol to send their channel status information to the root. Root needs to collect this information about all channels from all its children. The channel status information collected from each child (it can be collected multiple times to ensure better accuracy) shows two possible answers for each of the available channels: “Busy_status” or “Free_status”. Busy_status means that the channel might be used by other neighbors of the sensing child and at the sensing child, the noise level at this specific channel is very high, so it's “Busy”. - At
step 304, after collecting channel status information from its children, the root checks the status of channels around itself, meaning that it will sense the noise level around itself at each channel and give each channel a Busy or Free flag based on its own measurements. If a channel is Busy around the root, it will be eliminated from thechannel assignment algorithm 306, since children cannot transmit on a channel that is already sensed with a high noise level at the receiver (root). - At
step 308, the root lists the channel with free status for each child (“Free channel list”) and for each channel with a free status, it counts how many children include that channel in their list as a free channel. This counter can be called “ch_selection” counter and can be from 0 to the total number of channels. At the end of this step, each channel has a “ch_counter” associated with it. - At
step 310, the root checks the free channel list for each child, and if a child has more than one free channel in its list, one of them should be chosen since only one channel will be assigned to each child. At this step, the root chooses that channel that has the smallest “ch_selection” counter (which means that it has been listed less than the other channel). This ensures uniform selection of channels for children. After each change to the list, the root updates the ch_selection counter for the channels. - At
step 312, the root sorts all channels based on their ch_selection counter ascendingly meaning that channels with smallest ch_counter will be first and channels with the largest ch_selection counter will be last. 320 is a checkpoint to see if all children have one channel in their list. If yes, 314 is the finishing step of the algorithm and if not, the algorithm moves to step 316. At this point, the root sorts all the children that have no channels in their list based on their ID (ascendingly or descendingly.) then at 318, it will assign the first channel from the channel list to the first child from the children list. Then ch_selection counter is updated and at 319 the algorithm moves to step 312 where it will sort channels again and goes to thecheck point 320 to check for the finishing step of the algorithm. - After the root has selected one channel for each child, some children might end up sharing a common channel especially if the number of children is more than the available channels; or if more channels are busy around the root or its children and therefore cannot be used. In this case, the shared channel among the chosen children can be accessed via the CSMA/CA protocol that is well known in the art.
- After channel selection algorithm is finished, the root can broadcast its selection table to the children on a pre-defined control channel. This channel is assigned during installation. The message will be acknowledged by the root children to make sure they all have successfully received the information regarding g the chosen channel and they can send info on the assigned channel for the future communication.
- For example, the call for channel selection at the root can be applied at one or more of the following situations:
-
- 1. At the beginning of network set up;
- 2. At change of network topology by adding new nodes or extracting nodes; and
- 3. At error detection algorithm deciding that too many packets are dropped and as a result channel selection should be re-done. The error detection algorithm is run at the transport layer to detect the success rate of packet arrivals at the intended destination.
-
FIG. 4 illustrates example 400 of anexemplary network device 410 suitable for implementing the present invention.Network device 410 includes a master central processing unit (CPU) 462,interfaces 468, and a bus 415 (e.g., a PCI bus). When acting under the control of appropriate software or firmware, theCPU 462 is responsible numerous tasks, at least some of which relate to network management. It preferably accomplishes all these functions under the control of software including an operating system and any appropriate applications software.CPU 462 may include one ormore processors 463 such as a processor from the Motorola family of microprocessors or the MIPS family of microprocessors. In an alternative embodiment,processor 463 is specially designed hardware for controlling the operations ofrouter 410. In a specific embodiment, a memory 461 (such as non-volatile RAM and/or ROM) also forms part ofCPU 462. However, there are many different ways in which memory could be coupled to the system. - The
interfaces 468 are typically provided as interface cards (sometimes referred to as “line cards”). Generally, they control the sending and receiving of data packets over the network and sometimes support other peripherals used with therouter 410. Among the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like. In addition, various very high-speed interfaces may be provided such as fast token ring interfaces, wireless interfaces, Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces and the like. Generally, these interfaces may include ports appropriate for communication with the appropriate media. In some cases, they may also include an independent processor and, in some instances, volatile RAM. The independent processors may control such communications intensive tasks as packet switching, media control and management. By providing separate processors for the communications intensive tasks, these interfaces allow themaster microprocessor 462 to efficiently perform routing computations, network diagnostics, security functions, etc. - Although the system shown in
FIG. 4 is one specific network device of the present invention, it is by no means the only network device architecture on which the present invention can be implemented. For example, an architecture having a single processor that handles communications as well as routing computations, etc. is often used. Further, other types of interfaces and media could also be used with the router. - Regardless of the network device's configuration, it may employ one or more memories or memory modules (including memory 461) configured to store program instructions for the general-purpose network operations and mechanisms for roaming, route optimization and routing functions described herein. The program instructions may control the operation of an operating system and/or one or more applications, for example. The memory or memories may also be configured to store tables such as mobility binding, registration, and association tables, etc.
-
FIG. 5 illustrates example 500 of exemplary possible system embodiments, such a system making upnetwork device 410. The more appropriate embodiment will be apparent to those of ordinary skill in the art when practicing the present technology. Persons of ordinary skill in the art will also readily appreciate that other system embodiments are possible.FIG. 5 illustrates a conventional system buscomputing system architecture 502 wherein the components of the system are in electrical communication with each other using abus 505.Exemplary system 500 includes a processing unit (CPU or processor) 510 and asystem bus 505 that couples various system components including thesystem memory 515, such as read only memory (ROM) 520 and random access memory (RAM) 525, to theprocessor 510. Thesystem 500 can include a cache of high-speed memory connected directly with, in close proximity to, or integrated as part of theprocessor 510. Thesystem 500 can copy data from thememory 515 and/or thestorage device 530 to thecache 512 for quick access by theprocessor 510. In this way, the cache can provide a performance boost that avoidsprocessor 510 delays while waiting for data. These and other modules can control or be configured to control theprocessor 510 to perform various actions.Other system memory 515 may be available for use as well. Thememory 515 can include multiple different types of memory with different performance characteristics. Theprocessor 510 can include any general purpose processor and a hardware module or software module, such asmodule 1 532,module 2 534, andmodule 3 536 stored instorage device 530, configured to control theprocessor 510 as well as a special-purpose processor where software instructions are incorporated into the actual processor design. Theprocessor 510 may essentially be a completely self-contained computing system, containing multiple cores or processors, a bus, memory controller, cache, etc. A multi-core processor may be symmetric or asymmetric. - The
communications interface 540 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed. -
Storage device 530 is a non-volatile memory and can be a hard disk or other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 525, read only memory (ROM) 520, and hybrids thereof. - The
storage device 530 can includesoftware modules processor 510. Other hardware or software modules are contemplated. Thestorage device 530 can be connected to thesystem bus 505. In one aspect, a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as theprocessor 510,bus 505, display 535, and so forth, to carry out the function. - For clarity of explanation, in some instances the present technology may be presented as including individual functional blocks including functional blocks comprising devices, device components, steps or routines in a method embodied in software, or combinations of hardware and software.
- In some embodiments the computer-readable storage devices, mediums, and memories can include a cable or wireless signal containing a bit stream and the like. However, when mentioned, non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
- Methods according to the above-described examples can be implemented using computer-executable instructions that are stored or otherwise available from computer readable media. Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that may be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on.
- Devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example.
- The instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures.
- Although a variety of examples and other information was used to explain aspects within the scope of the appended claims, no limitation of the claims should be implied based on particular features or arrangements in such examples, as one of ordinary skill would be able to use these examples to derive a wide variety of implementations. Further and although some subject matter may have been described in language specific to examples of structural features and/or method steps, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to these described features or acts. For example, such functionality can be distributed differently or performed in components other than those identified herein. Rather, the described features and steps are disclosed as examples of components of systems and methods within the scope of the appended claims.
Claims (21)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/925,181 US10334602B2 (en) | 2014-12-30 | 2018-03-19 | Communications between connected devices |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/586,492 US9924514B2 (en) | 2014-12-30 | 2014-12-30 | Channel selection for concurrent communications between wireless devices |
US15/925,181 US10334602B2 (en) | 2014-12-30 | 2018-03-19 | Communications between connected devices |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/586,492 Continuation US9924514B2 (en) | 2014-12-30 | 2014-12-30 | Channel selection for concurrent communications between wireless devices |
Publications (2)
Publication Number | Publication Date |
---|---|
US20180295623A1 true US20180295623A1 (en) | 2018-10-11 |
US10334602B2 US10334602B2 (en) | 2019-06-25 |
Family
ID=56166012
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/586,492 Active 2035-01-22 US9924514B2 (en) | 2014-12-30 | 2014-12-30 | Channel selection for concurrent communications between wireless devices |
US15/925,181 Active US10334602B2 (en) | 2014-12-30 | 2018-03-19 | Communications between connected devices |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/586,492 Active 2035-01-22 US9924514B2 (en) | 2014-12-30 | 2014-12-30 | Channel selection for concurrent communications between wireless devices |
Country Status (1)
Country | Link |
---|---|
US (2) | US9924514B2 (en) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9924514B2 (en) * | 2014-12-30 | 2018-03-20 | SiTune Corporation | Channel selection for concurrent communications between wireless devices |
EP3310085A1 (en) * | 2016-10-11 | 2018-04-18 | Abb Ab | System and method for reducing interferences between multiple wireless protocols of a wireless building automation network |
US11418619B1 (en) * | 2017-09-25 | 2022-08-16 | Amazon Technologies, Inc. | Scheduling data communication for devices |
CN108834219B (en) * | 2018-07-20 | 2021-05-25 | 东北电力大学 | Wireless sensor network S-MAC protocol optimization method based on flow self-adaption |
CN113517735A (en) * | 2021-05-19 | 2021-10-19 | 广东工业大学 | Multi-device intelligent wireless charging method |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100526185B1 (en) * | 2003-08-14 | 2005-11-03 | 삼성전자주식회사 | Method And Apparatus for Enhancing Transfer Rate Using DLP And Multi-Channel In Wireless Lan Using PCF And DCF |
US20080214238A1 (en) * | 2007-03-01 | 2008-09-04 | Motorola, Inc. | Devices and methods for facilitating hands-free mode with fm transmitter |
US20110152970A1 (en) * | 2009-12-23 | 2011-06-23 | Medtronic Minimed, Inc. | Location-based ranking and switching of wireless channels in a body area network of medical devices |
CN102823293B (en) * | 2010-04-06 | 2015-12-09 | 皇家飞利浦电子股份有限公司 | Dynamic channel for medical body area network is selected |
US9326153B2 (en) * | 2010-07-06 | 2016-04-26 | Qualcomm Incorporated | Network setup in wide channel wireless local area networks (WLANs) |
SG11201508051SA (en) * | 2013-03-28 | 2015-10-29 | Agency Science Tech & Res | Spectrum coordination devices, radio communication devices, spectrum coordination methods, and methods for controlling a radio communication device |
US9924514B2 (en) * | 2014-12-30 | 2018-03-20 | SiTune Corporation | Channel selection for concurrent communications between wireless devices |
-
2014
- 2014-12-30 US US14/586,492 patent/US9924514B2/en active Active
-
2018
- 2018-03-19 US US15/925,181 patent/US10334602B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
US10334602B2 (en) | 2019-06-25 |
US9924514B2 (en) | 2018-03-20 |
US20160192364A1 (en) | 2016-06-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10334602B2 (en) | Communications between connected devices | |
CN104869526B (en) | A kind of communication of device-to-device and its resource allocation methods, equipment | |
CN104025691B (en) | Dynamic channel reuse in multi-access communication systems | |
US9059869B2 (en) | Interface selection in a hybrid communication device | |
CN107484254A (en) | Available resources determine methods, devices and systems | |
US10420101B2 (en) | Traffic-aware slot assignment | |
CN104105194A (en) | Method, apparatus, and computer program product for synchronization packet transmitter selection in a wireless network | |
CN104737609A (en) | System and method for radio access virtualization | |
RU2011101387A (en) | INTERFERENCE SETTING CHART AND ITS APPLICATION FOR THE PURPOSE OF NETWORK RESOURCES | |
US20150326492A1 (en) | Distributed scheduling method and apparatus for resource allocation for device-to-device communication | |
EP3266244B1 (en) | Resource allocation method and control entity using the same | |
CN107005984A (en) | A kind of method and UE for reducing resource contention | |
TWI633804B (en) | Communication control device, communication control method, and information processing device | |
Liu et al. | Resource management in LTE-U systems: Past, present, and future | |
Dang et al. | A hybrid multi-channel MAC protocol for wireless ad hoc networks | |
US9854592B2 (en) | Methods of channel allocation for devices using different communication protocols | |
WO2017151060A1 (en) | Method of controlling data transmission in a wireless mesh network and node thereof | |
Chowdhury | Matching theory for cognitive radio networks: An overview | |
Kauer et al. | Reliable wireless multi-hop networks with decentralized slot management: An analysis of IEEE 802.15. 4 DSME | |
CN104349462B (en) | Communication pattern system of selection and user equipment | |
CN103237323A (en) | Multichannel-based parallel node accepting method | |
CN104640177A (en) | Energy-efficiency-based cell selection method for multilevel heterogeneous network | |
CN103889005A (en) | Coordinated multi-point transmission scheduling method and device | |
CN105516966A (en) | Apparatus and method in wireless communication system | |
CN104509133A (en) | Method, base station and user terminal of transmitting signal in device-to-device approach service |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO SMALL (ORIGINAL EVENT CODE: SMAL); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
FEPP | Fee payment procedure |
Free format text: SURCHARGE FOR LATE PAYMENT, SMALL ENTITY (ORIGINAL EVENT CODE: M2554); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 4 |
|
AS | Assignment |
Owner name: ARCTIC SEMICONDUCTOR CORPORATION, CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:SITUNE CORPORATION;REEL/FRAME:065878/0242 Effective date: 20231212 |