The present disclosure relates to scheduling meeting rooms, and more specifically, anticipating the need for a meeting room and scheduling a meeting room that is best suited for the participants of a meeting.
Scheduling or calendaring services are utilized by many users to schedule meetings, conferences, and gatherings between participants. One of the features of a scheduling service is to schedule a meeting room in which the meeting will take place if the meeting requires the use of a meeting room. Many office buildings have multiple meeting or conference rooms available for employees to use for meetings or conferences with other participants. These meeting rooms may differ in their characteristics, such as the size of the room, location of the room in relation to the scheduled participants, availability of Wi-Fi® wireless connectivity in the room, availability of video conferencing capabilities in the room, etc. Meeting rooms may also be virtual meeting rooms, that is, a meeting hosted by a web-based meeting service.
Despite scheduling services aiding participants in scheduling meeting rooms for meetings, the current scheduling services contain flaws. Scheduling services only present the meeting rooms that are available for specific dates and times to the participants when scheduling a meeting. Thus, especially in environments where meetings are frequent, or environments with a lack of adequate available meeting rooms, in order to acquire a desired room for a meeting, participants are required to schedule the meeting rooms well in advanced to avoid the desired meeting room not being available. In addition, participants scheduling the meeting typically need knowledge of the characteristics of all of the meeting rooms in order to determine which room is best suited for the meeting. For example, if knowledge of the characteristics of the meeting rooms are not known, and video conferencing is needed for a meeting but video conferencing is not available in the scheduled meeting room, the participants may not discover that the scheduled meeting room does not have the necessary video conferencing capabilities until the participants arrive at the meeting room for their scheduled meeting. This could result in the meeting not being able to take place.
Moreover, current scheduling services only track whether or not a meeting room is scheduled for a specific date and time. The scheduling services do not take into account the current occupancy of the room when scheduling meeting rooms, specifically when scheduling last minute meetings. For example, while meeting rooms are often scheduled in advanced, these meeting rooms are sometimes never used for the scheduled meeting, either because the meeting has been canceled without un-scheduling the meeting room via the scheduling service, or the location of the meeting has been changed without making these changes via the scheduling service. In addition, scheduled meetings often run short of their projected time span, leaving the meeting room scheduled but unused for the remainder of the scheduled time slot. Thus, it is not uncommon for a meeting room to be scheduled for a first set of participants, but the meeting room is not being used by the first set of participants. Meanwhile, a second set of participants looking to schedule a last minute meeting cannot use the scheduled but unused meeting room, and are unaware that the scheduled and unused meeting room is unoccupied.
Furthermore, participants often fail to utilize scheduling services to schedule meeting rooms. Instead, these participants host impromptu meetings in any meeting room that they discover is unused. Thus, when scheduling a last minute meeting in a meeting room via a scheduling service, participants may find that other participants are conducting a meeting in the meeting room scheduled via the scheduling service. This requires the participants who scheduled the meeting room to then either quickly find another room for the meeting or to confront the group of participants already in the meeting room to request that those participants leave.
Techniques are presented for scheduling meeting rooms for participants by a server in communication with user devices that are utilized by the participants. The server receives a meeting trigger that signifies a necessity for, or a scheduling of, a meeting in which a first user is a participant. The server then determines that a meeting room is needed for the meeting. Upon determining that a meeting room is needed for the meeting, the server queries the data associated with a plurality of meeting rooms located within a predetermined proximity of the first user for characteristics of the plurality of meeting rooms. Once the meeting rooms within a proximity of the user devices are identified and the characteristics of each of these rooms are determined, the server then filters a subset of the plurality of meeting rooms based on a set of constraints for the meeting. Thus, any rooms whose characteristics do not meet the constraints needed for the meeting room is filtered out of the plurality of meeting rooms. The subset of the plurality of meeting rooms are then sorted based on the status of the subset of the plurality of meeting rooms in terms of the rooms being scheduled and the rooms being occupied. The server then reserves one of the meeting rooms from the subset of the plurality of meeting rooms for the meeting between the participants.
The anticipatory meeting scheduling system and method presented herein enable users to schedule meeting rooms based on energy data and meeting needs for the participants of the meeting. In addition, the anticipatory meeting scheduling system may anticipate the need for a meeting room prior to a user attempting to schedule a meeting room, and schedule a meeting room based on energy data and meeting needs for the participants of the meeting. The anticipatory meeting scheduling system analyzes data sets relating to location, wireless network usage in the rooms, energy usage in the rooms, current scheduling data for the meeting rooms, etc., in order to schedule the appropriate room for the participants of the meeting. The anticipatory meeting scheduling system may determine if a meeting room is available even if an online directory says the meeting room is not available. Furthermore, the system may provide suggestions to a participant or the participants of the room availability.
An example embodiment of an anticipatory meeting scheduling system 10 is depicted in
The sensor data storage 30 stores the data acquired by the sensors 42, 52 from each of the rooms 40, 50. The anticipatory meeting scheduling system 10 is configured to analyze activity associated with each user device 60, 62, 64 to determine if a meeting room is necessary for a meeting, identify the meeting rooms 40, 50 within a proximity of the user devices 60, 62, 64, determine whether these meeting rooms 40, 50 are occupied via data collected by the sensors 42, 52, to provide the user devices 60, 62, 64 with the most suitable meeting room for the meeting. The system 10 may also provide directions for each user to a meeting room from the current location of the user devices 60, 62, 64.
The anticipatory meeting server 20 of the anticipatory meeting scheduling system 10 is configured to host and support the exchange of data between user devices 60, 62, 64, meeting rooms 40, 50, and the sensor data storage 30. Some examples of user devices 60, 62, 64 includes any type of computing device including, without limitation, personal computer (PC) devices, such as stationary (e.g., desktop) computers, laptop computers, or any other type of mobile computing device such as cellular (smart) mobile phones (e.g., cell phones, also referred to as mobile phones), note pads, tablets, personal data assistant (PDA) devices, and other portable media devices. The user devices 60, 62, 64, the anticipatory meeting server 20, and other devices of the anticipatory meeting scheduling system 10 can utilize any suitable operating system to facilitate the sharing of location data and meeting room sensor data between the various meeting rooms 40, 50, the sensor data storage 30, and the user devices 60, 62, 64 with the anticipatory meeting server 20. In addition, the techniques described herein for anticipating and scheduling meeting rooms via the anticipatory meeting scheduling system 10 can be integrated with any suitable type of commercial software products and scheduling or calendaring services, which may be provided by the scheduling server 70, the instant messaging server 72, and the email server 74.
The anticipatory meeting scheduling system 10 facilitates the exchange of data between meeting rooms 40, 50, user devices 60, 62, 64, and/or one or more servers 20, 70, 72, 74 via any one or more suitable networks 80 including, without limitation, any one or more of local or wide area networks, Internet Protocol (IP) networks such as intranet or internet networks, telephone networks (e.g., public switched telephone networks), wireless or mobile phone or cellular networks, and any suitable combinations thereof. The number of user devices 60, 62, 64, meeting rooms 40, 50, and server 30 depicted in
As previously explained, the meeting rooms 40, 50 of the anticipatory meeting scheduling system 10 may include sensors 42, 52. The sensors 42, 52 may include, but are not limited to, a motion sensor, a sensor for detecting the wireless network (e.g., Wi-Fi) usage in the meeting room 40, 50, a sensor for detecting the energy usage in a meeting room 40, 50, a sensor for detecting whether or not the phone is being used in a meeting room 40, 50, a sensor for detecting whether or not the video conferencing equipment is being used in a meeting room 40, 50, etc. Each of the rooms 40, 50 may include any number of such sensors 42, 52, or no sensors 42, 52 at all. The sensors 42, 52 of the meeting rooms 40, 50 may collect data related their respective rooms. Thus, the sensors 42 installed in meeting room 40 collect data regarding meeting room 40, while the sensors 52 installed in meeting room 50 collect data regarding meeting room 50. Furthermore, the collected data from the sensors may be sent to the sensor data storage 30. As illustrated in
The sensor data storage 30 stores data from each of the sensors 42, 52. The sensor data storage 30 may be any type of tangible storage device that can retain and store sensor data for use by the anticipatory meeting server 20 and any other device of the anticipatory meeting scheduling system 10. The sensor data storage 30 may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the sensor data storage 30 includes: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device. The sensor data storage 30 is configured to store any files or data recorded by the sensors 42, 52. Thus, the sensor data storage 30 may store real-time sensor data values that represent the perceived conditions of a meeting room 40, 50 by the sensors 42, 52 in real-time. The sensor data storage 30 may also store historical data of the conditions of a meeting room 40, 50 that were detected by the sensors 42, 52. The sensor data storage 30 may record the conditions present in a meeting room 40, 50 at all times, including when the rooms 40, 50 are occupied and when the rooms 40, 50 are unoccupied. This historical sensor data of the meeting rooms 40, 50 may enable the anticipatory meeting server 20 of the anticipatory meeting scheduling system 10 to compare real-time sensor data with the historical data to determine if the meeting rooms 40, 50 are currently occupied.
Furthermore, as previously explained, each of the meeting rooms 40, 50 may or may not include an AP 44, 54. AP 44, 54 may be any device that routes wireless data between the devices and the network 80 of the system 10 or to another network. AP 44, 54 may include an antenna, a processor, and a memory. In one example, an AP is able to support Wi-Fi in general, and the 802.11a, 802.11b, 802.11g, 802.11n, and/or 802.11ac wireless networking standards in particular. The APs 44, 54 may be configured to relay the data detected by the sensors 42, 52 of a meeting room 40, 50 to the network 80, and ultimately to the sensor data storage 30. The APs 44, 54 may also be configured to relay location data to the server 20 of both the user devices 60, 62, 64 and the meeting rooms 40, 50 in relation to the user devices 60, 62, 64 and vice versa. The anticipatory meeting server 20 may utilize location-based services supported by the APs 44, 54 to track the physical location of user devices 60, 62, 64. Additionally, the APs 44, 54 may be configured to provide wireless network access to the user devices 60, 62, 64 once located within and/or around a meeting room 40, 50.
Illustrated in
The processor(s) 24 may be embodied by one or more microprocessors or microcontrollers, and executes software instructions stored in memory 26 for anticipatory meeting scheduler software 28 in accordance with the techniques presented herein in connection with
Memory 26 may include one or more computer readable storage media that may comprise read only memory (ROM), random access memory (RAM), magnetic disk storage media devices, optical storage media devices, flash memory devices, electrical, optical, or other physical/tangible memory storage devices.
Thus, in general, the memory 26 may comprise one or more tangible (e.g., non-transitory) computer readable storage media (e.g., a memory device) encoded with software comprising computer executable instructions, and when the software is executed by the processor(s) 24, the processor(s) 24 is operable to perform the operations described herein in connection with the anticipatory meeting scheduler software 28. In other approaches, anticipatory meeting scheduler software 28 is stored remotely, external to the anticipatory meeting server 20, but accessible by the processor(s) 24.
The functions of the processor(s) 24 may be implemented by logic encoded in one or more tangible computer readable storage media or devices (e.g., storage devices compact discs, digital video discs, flash memory drives, etc. and embedded logic such as an ASIC, digital signal processor instructions, software that is executed by a processor, etc.).
While
Illustrated in
The occupancy of each meeting room 40, 50 may be determined from a number of sensors 42, 52 that provide information and/or data to the sensor data storage 30 via network 80. The information and/or data may be accessed on the sensor data storage 30 by the anticipatory meeting server 20. For example, one of the sensors 42, 52 in the meeting rooms 40, 50 may be a motion sensor, which is capable of detecting movement within the meeting room 40, 50 in which the motion sensor is installed. The meeting rooms 40, 50 may be equipped with another sensor that enables the anticipatory meeting server 20 to monitor the wireless network (e.g., Wi-Fi) usage in the meeting room. In addition, each meeting room 40, 50 may be equipped with a sensor 42, 52 that enables the anticipatory meeting server 20 to monitor and/or control the power consumption in the meeting room 40, 50. Each meeting room 40, 50 may also be equipped with a sensor or sensors 42, 52 that enables the anticipatory meeting server 20 to monitor whether or not the phone and/or the video conferencing equipment is being used in a meeting room 40, 50. Occupancy of a meeting room 40, 50 may be determined by analyzing data obtained by one of the sensors 42, 52, or by combining the data from multiple ones of the sensors 42, 52 with each sensor 42, 52, based on weighting mechanism. For example, the anticipatory meeting server 20 may apply a weighting mechanism according to the equation, Occupancy =E (Motion_Sensor +Average(Wi-Fi_Use_in_Room/Max_Wi-Fi; Energy_Use_in_Room/Max_Energy; phone_use? 1:0; video_use? 1:0)), where the average determines or represents the average number of people in the meeting room.
Turning now to
At step 150, the anticipatory meeting server 20 then sorts the remaining meeting rooms based on the meeting room usage state priority, as described previously in connection with
However, if a meeting room does not have a usage state of unscheduled and unoccupied 460, at step 164 the anticipatory meeting server 20 will then determine if there are any meeting rooms that have a usage state of unscheduled and occupied 450. As previously stated, the anticipatory meeting server 20 may access sensor data that is stored on the sensor data storage 30, or may access the sensors to determine if the meeting rooms are occupied. The anticipatory meeting server 20 may additionally access information stored on the anticipatory meeting server 20 to determine if the meeting rooms have been scheduled via the scheduling service. If a meeting room has a usage state of unscheduled and occupied 450, the anticipatory meeting server 20 then, at step 166, schedules the meeting room. If multiple meeting rooms have a usage state of unscheduled and occupied 450, then the anticipatory meeting server 20 will schedule the meeting room that has a location that is most suitable for the majority of the participants of the meeting, as explained previously. The anticipatory meeting server 20 may also take into consideration the number of people currently in the meeting rooms when determining which meeting room to reserve. At step 180, the anticipatory meeting server 20 then sends directions to the scheduled meeting room 40, 50 to the user devices 60, 62, 64 of each of the participants.
In the event that the anticipatory meeting server 20 determines that none of the remaining meeting rooms have a usage state of unscheduled and occupied 450, then at step 168, the anticipatory meeting server 20 determines if any of the remaining meeting rooms have a usage state of scheduled and unoccupied 440. If a meeting room has a usage state of scheduled and unoccupied 440, at step 170 the anticipatory meeting server 20 determines if there is a preemptive mechanism that may be used to schedule a meeting room that already is scheduled for another meeting. A preemptive mechanism is a mechanism or rule that allows the anticipatory meeting server 20 to reserve a meeting room that is already scheduled for another meeting. Thus, the preemptive mechanism allows the anticipatory meeting server 20 to un-schedule a previously scheduled meeting for a meeting room so that the same meeting room may be scheduled for the meeting to be scheduled. The preemptive mechanism may be based on the priority rating of each meeting, where one factor for determining the priority rating of the meeting may be the participants of the meeting and their role in the company. For example, a meeting between three lower level employees of a company will have a first priority rating, while the meeting between the chief executive officer (CEO) of the company and board of directors of the company will have a second priority rating, where the second priority rating is higher than the first priority rating because the CEO and the board of directors have a more important and higher role in the company than the lower level employees. In this example, the higher priority rating will provide the anticipatory meeting server 20 with a preemptive mechanism for scheduling a meeting room for the CEO and the board of directors over the previously scheduled meeting by the lower level employees. Other factors for determining the priority rating of the meeting may include, but are not limited to, the number of the participants of the meeting, the subject matter of the meeting, impeding deadlines for the participants of the meeting, etc. The priority rating of the meetings may be determined by the scheduling service, or by the anticipatory meeting server 20. If the meeting to be scheduled has a higher priority rating, then the anticipatory meeting server 20 may have a preemptive mechanism for rescheduling the currently scheduled meeting room to allow the use of the meeting room for meeting to be scheduled. Thus, a step 172, if a preemptive mechanism exists for scheduling the meeting to be scheduled over a meeting already scheduled for a meeting room, then the anticipatory meeting server 20 may use the preemptive mechanism for scheduling the meeting room. At step 180, the server may then send directions to the scheduled meeting room to the user devices 60, 62, 64 of each of the participants.
However, in the event that the meeting rooms do not have a unscheduled and unoccupied usage state 460, an unscheduled and occupied usage state 450, or a scheduled and unoccupied usage state 440, then the meeting rooms have a usage state of scheduled and occupied 430, and thus, at step 174, the meeting to be scheduled cannot be scheduled in any of the meeting rooms. In addition, if the anticipatory meeting server 20 determines that there are meeting rooms 40, 50 that have a usage state of scheduled and unoccupied 440, but the anticipatory meeting server 20 determines that there is no preemptive mechanism to use to schedule the meeting to be scheduled, then, at step 174, the meeting to be scheduled cannot be scheduled in any of the meeting rooms.
Turning to
However, if the anticipatory meeting server 20, at step 220, determines that the meeting does not require a physical meeting between the participants, or determines that a physical meeting is not possible, the anticipatory meeting server 20, at step 240, then determines that this is a virtual meeting. At step 250, the anticipatory meeting server 20 may then determine if the virtual meeting requires a virtual meeting room. If the server determines that a virtual meeting room is required, then, at step 252, the anticipatory meeting server 20 may then use the find room method, as described previously in connection with
Turning to
As illustrated in
However, if the anticipatory meeting server 20 determines that a meeting room is needed at step 320, then, at step 340, the anticipatory meeting server 20 then uses the find room method, as explained previously in connection with
An example embodiment of a high-level process 500 performed by the anticipatory meeting server 20 for scheduling meeting rooms 40, 50 is depicted in the flowchart of
Once all of the meeting rooms have been queried for their characteristics, the anticipatory meeting server 20, at step 540, filters the plurality of meeting rooms into a subset of the plurality of meeting rooms based on a set of constraints for the meeting. The meeting trigger may include information or data about the constraints or requirements for the meeting, such as, but not limited to, a requirement for video conferencing, a requirement for telephone conferencing, a requirement for wireless network connectivity (e.g., Wi-Fi) and/or the ability to connect to the network 80, the number of chairs needed in the room, the number of tables needed in the room, the proximity of the room in relation to the participants, etc. At step 550, the anticipatory meeting server 20 then sorts the subset of the meeting rooms by the meeting room usage state priority, where meeting rooms may have a usage state of unscheduled and unoccupied 460, unscheduled and occupied 450, scheduled and unoccupied 440, and scheduled and occupied 430. As previously explained, the meeting room usage state, in order of most preferred to least preferred, is unscheduled and unoccupied 460, unscheduled and occupied 450, scheduled and unoccupied 440, and scheduled and occupied 430. Finally, at step 560, the anticipatory meeting server 20 reserves one of the meeting rooms from the subset of the plurality of meeting rooms for the meeting, where the selected meeting room is the meeting room that is most preferred and contains the characteristics that fit the constraints of the meeting. Thus, the scheduled meeting room is the meeting room that is most suitable for the participants of the meeting.
When the anticipatory meeting server 20 sorts the subset of the plurality of meeting rooms based on a usage state (e.g., usage states 430, 440, 450, and 460) of the subset of the plurality of meeting rooms, the anticipatory meeting server 20 determines which meeting rooms of the subset of the plurality of meeting rooms are currently scheduled via a scheduling service, and which meeting rooms of the subset of the plurality of meeting rooms are currently occupied. When the anticipatory meeting server 20 determines which of the meeting rooms are currently occupied, the anticipatory meeting server 20 analyzes data that is output from the sensors located in or proximate the meeting rooms or capable or obtaining information about occupancy of the meeting rooms even if the sensors (such as power usage sensors) are remote from the meeting room. For example, the anticipatory meeting server 20 may analyze the output of a motion sensor in a meeting room , the wireless local area network activity in a meeting room, energy usage in a meeting room, phone usage in a meeting room, the video usage in a meeting room, etc. Once a meeting room 40, 50 has been booked by the anticipatory meeting server 20, the anticipatory meeting server 20 may then send a message to the user devices 60, 62, 64, where the message may contain directions to the scheduled meeting room.
As explained above, meetings are often scheduled, and meeting rooms are often reserved using scheduling or calendaring services. However, meeting rooms are often scheduled or reserved and then never used. Moreover, groups of people often use a meeting room without ever going through the proper procedures for reserving the meeting room, causing confusion and conflicts between groups of people who actually scheduled the meeting room via the scheduling or calendaring services.
The techniques presented herein provide a computer-implemented method of monitoring a user's messaging services to determine when the user will need a meeting room for a meeting with other users, and then reserving the best suited meeting room for the meeting without the user ever requesting that the meeting room be reserved. As described herein, the server not only monitors a user's devices, but also monitors the meeting rooms themselves, along with the locations of the participants in relation to the meeting rooms and each other. The server is able to determine which meeting rooms are currently scheduled, which meeting rooms are currently occupied, the technological capabilities of each of the meeting rooms, and which meeting rooms are in a certain proximity to the indicated participants of the meeting. The server is able to determine, based on the characteristics of each of the meeting rooms, the scheduling status of the meeting rooms, the occupancy status of the meeting rooms, and the proximity of the meeting rooms to the indicated participants to filter the plurality of meeting rooms, and then sort the meeting rooms into an order of most preferred to least preferred meeting rooms. The server can then reserve the best suited meeting room for the indicated participants and the constraints of the meeting, where the server then provides each of the participants with directions to the reserved meeting room.
The techniques presented herein may be used by a server of an anticipatory meeting scheduling system to reduce both the confusion of scheduling meeting rooms and the time required to determine which meeting room is best suited for the meeting. The anticipatory meeting scheduling system prevents situations where one group of participants is holding a meeting in a meeting room that has been scheduled for another group of participants. Moreover, the anticipatory meeting scheduling system prevents users from scheduling meeting rooms and monopolizing meeting rooms, when those participants do not need the meeting room. In addition, the anticipatory meeting scheduling system prevents participants from scheduling meeting rooms that are best suited for that participant, but is an inconvenience for the other participants of the meeting.
The above description is intended by way of example only. Various modifications and structural changes may be made therein without departing from the scope of the concepts described herein and within the scope and range of equivalents of the claims.