In an increasingly networked world, more and more traffic, such as data, voice, and video, is transmitted over public and proprietary networks. The public and proprietary networks provide a variety of services, such as voice communications, electronic mail, instant messaging, Internet-based services, security, etc. Applications, hosted by network devices within the networks, may provide a service associated with personnel attendance tracking and/or management. The applications may store, manage, and/or analyze information corresponding to personnel (e.g., personnel records, attendance records, vacation usage, etc.) associated with organizations that use the applications.
Information may be entered into an application by the personnel when entering and/or exiting a facility (e.g., when the personnel clock in and/or clock out, etc.) and/or by system administrators (e.g., when attendance is taken, when roll is called, when information associated personnel records is entered, etc.). The system may use the entered information to track attendance and/or manage the information associated with the personnel. Tracking the attendance and/or updating the information corresponding to the personnel throughout the day (e.g., between clocking in and/or clocking out) may be performed when the personnel frequently clock in and/or clock out when entering, moving about, and/or exiting the facility, when administrators frequently take attendance, etc. Unfortunately, the frequent clocking in and/or clocking out and/or taking attendance throughout the day may be cumbersome and/or time consuming for personnel and/or administrators.
The following detailed description refers to the accompanying drawings. The same reference numbers in different drawings may identify the same or similar elements. Also, the following detailed description does not limit the embodiments described herein.
Systems and/or methods, described herein, may enable an automatic attendance tracking application (hereinafter referred to as “attendance application”) to automatically determine whether a user, associated with a user device, is present or absent based on location information associated with the user device. As described herein, the attendance application may use information associated with whether a user device is present, tardy, or absent relative to a particular location (e.g., a school, a work place, a class room, a bus, etc.) to generate and/or update information associated with the user (e.g., attendance records, class rosters, personnel records, payroll records, etc.). The attendance application may determine whether a potential event, associated with the user, exists by determining whether the user device is missing, is excused from being absent, is excused from being late, etc. The attendance application may perform an operation to locate the user device in the event of an unexcused absence and/or when a potential event is detected. The attendance application may send notifications to the user device, another user device (e.g., associated with a parent, a physician, a guardian, etc. of the user), a client device (e.g., associated with a teacher, an administrator, a supervisor, etc. of the user), and/or governmental authorities (e.g., first responders and/or local, state, and/or federal officials, truant officers, etc.). The notifications may identify a status of the user device (e.g., on time, tardy, absent, etc.), a presence of the user device (e.g., present or not present), whether a late or absent status is excused, and/or whether a potential event has been detected. The notifications may identify a location of the user device (e.g., for use by first responders, truant officers, etc.), whether the user device is within a particular distance of an assigned location, whether the user device within a boundary specified by a parent of the user, etc. The attendance application may generate reports, such as personnel listings, class room rosters, attendance reports (e.g., a quantity of incidences of tardiness, absence, etc.), curriculum reports, etc.
The attendance application may enable less time to be spent managing attendance of personnel, which may permit more time to be spent performing other duties. The attendance application may permit the amount of time and/or funds associated with performing attendance data retrieval, attendance audits, record keeping, and/or reporting to be reduced. The attendance application may enable parents and/or supervisors to be kept informed as to the location and/or attendance status of children and/or employees, respectively.
Also, in some implementations, one or more of the devices of environment 100 may perform one or more functions described as being performed by another one or more of the devices of environment 100. Devices of environment 100 may interconnect via wired connections, wireless connections, or a combination of wired and wireless connections.
User device 110 may include any computation or communication device that is capable of communicating with network 160. For example, user device 110 may include a radiotelephone, a personal communications system (PCS) terminal (e.g., that may combine a cellular radiotelephone with data processing and data communications capabilities), a personal digital assistant (PDA) (e.g., that can include a radiotelephone, a smart phone, a pager, Internet/intranet access, etc.), a landline telephone, a laptop computer, a tablet computer, a personal computer, a set top box (STB), a radio frequency identification (RFID) device, a television, a camera, a personal gaming system, or another type of computation or communication device. The description to follow will generally refer to user device 110 as a wireless mobile device. The description is not limited, however, to a wireless mobile device and may equally apply to other types of user devices.
In an example implementation, user device 110 may include a location component that enables geographic location information, associated with user device 110, to be transmitted to SGW server 140 via network 160. The location information may be transmitted automatically, upon the occurrence of some event, periodically (e.g., every 30 seconds, 5 minutes, at particular times, etc.), and/or in response to a request from SGW server 140. For example, the location component may include a global positioning satellite (GPS) transponder that communicates with a GPS satellite constellation in order to obtain and/or generate location information associated with user device 110. In another example, user device 110 may transmit a signal (e.g., by transmitting Bluetooth® signal, by beaming a point-to-point infrared signal, etc.) to SGW server 140 (e.g., via a WIFI hot spot, an infrared sensor, and/or a wireless local area network (WLAN) that is hosted by, interconnected to, and/or controlled by SGW server 140) indicating that user device 110 is present and/or located at a particular location within or at a facility (e.g., a class room, gymnasium, a laboratory, etc.) and/or campus with which SGW server 140 is associated.
When communicating with SGW server 140, user device 110 may send the location information and/or the indication that user device 110 is present in a manner that includes information associated with user device 110. The information associated with user device 110 may include a device identifier (e.g., a mobile directory number (MDN), a subscriber identity module (SIM) universal resource identifier (URI), an international mobile subscriber identity (IMSI), an international mobile equipment identity (IMEI), a CODEC, etc.). Additionally, or alternatively, the information associated with user device 110 may include an address associated with user device 110 (e.g., a media access control (MAC) address, an IP address, a uniform resource locator (URL), etc.), information associated with a user of user device 110 (e.g., a username, password, personal identification number (PIN), biometric information, etc.), and/or information associated with an application hosted by user device 110 (e.g., an application identifier).
Client device 120 may include one or more server devices, or other types of computation or communication devices, that gather, process, search, store, and/or provide information in a manner similar to that described herein. Client device 120 may send, to SGW server 140 via network 160, information associated with a status of user device 110 and/or personnel information associated with a user of user device 110. For example, an operator of client device 120 (e.g., an administrator, a foreman, a teacher, etc.) may send an indication regarding whether a user, of user device 110, is present, absent, tardy, excused, etc. Client device 120 may store personnel information associated with the user (e.g., grades, attendance information, personal information, class schedules, curriculum information, job assignments, etc.) in a data structure stored in a memory associated with client device 120 and/or may send the personnel information and/or updates to the personnel information to SGW server 140. In an example implementation, client device 120 may receive a signal from user device 110 indicating that user device 110 is present and/or within a particular distance and/or range of client device 120 (e.g., within a classroom, facility, grounds, etc.) and client device 120 may send a status indication to SGW server 140 based on the signal received from user device 110. Client device 120 may permit an operator, of client device 120, to send an event notification that indicates that a potential emergency (e.g., a medical emergency, a fire, an act of violence, etc.) is about to occur, is in the process of occurring, or has occurred.
Client device 120 may receive notifications from SGW server 140 associated with user device 110. For example, client device 120 may receive an indication that an absence, associated with user device 110, is excused. In another example, client device 120 may receive a notification that a user, of user device 110, is to take particular medication at a prescribed time, is to report to a particular location, etc. Client device 120 may determine that a quantity of user devices 110 are present and/or that another quantity of user devices 110 are not present and may send information associated with the quantity of user devices 110 that are present and/or the other quantity of user devices 110 that are not present to SGW server 140. Client device 120 may provide recommendations to an operator based on information associated with the quantity of user devices that are present and the other quantity of user devices 110 that are not present. In one example, client device 120 may perform an operation to adjust a curriculum based on individual curricula associated with users, of user devices 110, that are present. In another example, client device 120 may adjust work schedules and/or tasks based on an expertise, skill, training, etc. associated with users of user devices 110 that are present.
Public server 130 may include one or more server devices, or other types of computation or communication devices, that gather, process, search, store, and/or provide information in a manner similar to that described herein. In an example implementation, public server 130 may be associated with government authorities at the federal, state, and/or local levels and/or may be associated with first responders in the event of an emergency and/or some other event (e.g., fire and rescue personnel, police, medical personnel, etc.).
Public server 130 may communicate with SGW server 140 via network 160. For example, public server 130 may send an event notification to SGW server 140 indicating that an event has occurred in close proximity to a facility at which SGW server 140 and/or user device 110 are located (e.g., a natural and/or man-made disaster, an accident, etc.). The notification may include instructions associated with the event notification (e.g., delay releasing students from school, instructions associated with alternative routes to avoid an accident, etc.). Public server 130 may receive an event notification from SGW server 140 indicating that a potential event has occurred at or near a facility at which SGW server 140, client device 120, and/or user device 110 are located. Public server 130 may receive the event notification and may alert authorities, first responders, and/or the public (e.g., an Amber alert, etc.) that the potential event has occurred based on the event notification. In another example, the event notification may include information associated with a location of user device 110 that first responders or other governmental authorities may use to location user device 110.
SGW server 140 may include one or more server devices, or other types of computation or communication devices, that gather, process, search, store, and/or provide information in a manner similar to that described herein. In an example implementation, SGW server 140 may act as a proxy and/or gateway device with respect to application server 150. When acting as the proxy and/or gateway device, SGW server 140 may manage communications, service provisioning, authentication operations, etc. on behalf of application server 150 when performing automated attendance tracking and/or event notification operations and/or other operations. SGW server 140 may, for example, communicate with user device 110 to obtain location information associated with user device 110. SGW server 140 may communicate with user device 110 to identify a position, within a facility and/or an area (e.g., such as a building, a room within the building, a grounds and/or campus on which the building is located, etc.), associated with user device 110. SGW server 140 may send the location information and/or the identified position, associated with user device 110, to application server 140. SGW server 140 may communicate with a variety of types of user devices 110 and/or client devices 120 using a variety of protocols, data formats, etc.
SGW server 140 may communicate with client device 120 to receive status information associated with user device 110 (e.g., absent, tardy, present, excused, etc.). SGW server 140 may receive the status information and may send the status information to application server 150. SGW server 140 may receive personnel information associated with the user (e.g., grades, attendance information, personal information, class schedules, curriculum information, job assignments, etc.) and may store the personnel information in a memory associated with SGW server 140 and/or may send the personnel information to application server 150.
SGW server 140 may receive notifications from application server 150 and may send the notifications to client device 120. For example, SGW server 140 may receive a notification that user device 110 will be absent on a particular day (e.g., due to a medical appointment of the user of user device 110) and may send the notification to client device 120 (e.g., to notify a foreman, teacher, etc. in advance of the absence, etc.).
Application server 150 may include one or more server devices, or other types of computation or communication devices, that gather, process, search, store, and/or provide information in a manner similar to that described herein. In an example implementation, application server 150 may host logic and/or software associated with an attendance application that enables application server 150 to perform automated attendance and/or event notification operations. Application server 150 may receive, from SGW server 140, location information associated with user device 110 and may determine a state associated with user device 110 based on the location information, a current time, and/or personnel information associated with a user of user device 110.
For example, application server 150 may receive the location information and may retrieve, from a memory associated with application server 150, personnel information associated with the user. The personnel information may include information that identifies a location and/or area within which user device 110 is to be located at a particular point in time. In one example, the personnel information may include a class schedule that includes starting and/or ending times, periods that correspond to the starting and/or ending times, classroom numbers that correspond to the periods, etc. The attendance application may, based on the location information, determine whether user device 110 is located at a location and/or within an area (e.g., within a facility, school building, etc.) that corresponds to a particular classroom within which user device 110 is to be located, at the current time, based on the personnel information.
If, for example, the attendance application identifies that user device 110 is located in the particular classroom, then the attendance application may determine that the user, of user device 110, is present. If the attendance application determines that user device 110 is not located in the particular classroom, then the attendance application may determine that user device 110 is not present. The attendance application may identify, at a later point in time (e.g., after a particular period starts and before the particular period ends), that user device 110 is located within the particular classroom, and may determine that the user is present, but is tardy. The attendance application may identify, at another later point in time (e.g., after the particular period ends), that user device 110 is not located within the particular classroom, and may determine that the user is not present and is absent.
In another example, the attendance application may, based on the location information, determine whether user device 110 is located within an authorized geographic area (e.g., corresponding to a bus route between home and a school with which user device 110 is associated, etc.). The geographic area may be specified, by the parent of a user of user device 110, as a set of boundaries outside which user device 110 is not authorized to be located. In yet another example, the attendance application may, based on the location information, determine a rate at which user device 110 changes location (e.g., speed, velocity, acceleration, etc.). Attendance application may, for example, determine whether user device 110 is adhering to posted speed limits (e.g., whether a speed, associated with user device 110, is greater than a threshold, such as when the user is commuting to or from a school, work place, etc.) and/or whether user device 110 was involved in an accident (e.g., when a rate at which a speed, corresponding to user device 110 changes, such as during a deceleration or acceleration, exceeds a threshold).
Based on the determination that the user is tardy and/or absent, the attendance application may determine, from the personnel information, whether the tardiness and/or absence was excused. The tardiness and/or absence may be excused based on information stored in the personnel information that indicates that the tardiness and/or absence is excused. The information may be stored in the personnel information based on, for example, a notification received from another user device 110 (e.g., with which a parent and/or doctor of the user is associated) and/or when the information is stored in the personnel information by an operator of client device 120 (e.g., when the absence is approved by a teacher, supervisor, etc.). In an example where the absence is not excused, the attendance application may send a notification to user device 110 and/or to the other user device 110 (e.g., with which the parent is associated) identifying that user device 110 is absent and is not excused. In another example, the attendance application may send the notification to the other user device 110 and may receive a response from the other user device 110 indicating that the absence was not authorized. Based on the indication that the absence was not authorized, the attendance application may perform an operation to locate user device 110. In one example, the attendance application may send an absence notification, associated with user device 110, to client device 120 (e.g., with which a truant officer, police officer, etc. is associated) that indicates that the whereabouts of user device 110 are to be determined. In another example, the attendance application may send a query to SGW server 140 to obtain location information associated with user device 110. If the location of user device 110 cannot be determined and/or is determined to be at an unauthorized location (e.g., a location that corresponds to another county, another state, outside an authorized boundary, a distance from a school that is greater than a threshold, etc.), then the attendance application may send an event notification to public server 130 (e.g., associated with local, state, and/or federal authorities and/or first responders) indicating that user device 110 (e.g., the user of user device) is missing and/or is at an unauthorized location. The event notification may include the location information that enables a parent and/or the first responders and/or or other governmental authorities to locate user device 110 based on the location information.
The attendance application may store and/or update a status of user device 110 in the personnel information. For example, the attendance application may store a present status of user device 110 in the personnel information. The attendance application may update the personnel information associated with a period of time (e.g., a quantity of yearly absences, a quantity of times that user device 110 was tardy, etc.). The attendance application may update classroom rosters based on a quantity of present and/or absent user devices 110 and may send recommended curriculum changes and/or tasking to client device 120 (e.g., with which a teacher and/or supervisor, respectively, are associated).
The attendance application may perform operations in response to the occurrence of some event and/or that are tailored to the demographics of a particular day and/or time. For example, the attendance application may send notifications to user devices 110 and/or client devices 120 alerting users of user devices 110 and/or operators of client devices 120 of the occurrence of some event (e.g., an unplanned office and/or school closing due to inclement weather, etc.). The attendance application may identify whether particular operators of client device 120 are present to determine whether a quorum exists in order to schedule a meeting. Based on a determination regarding whether the quorum exists, the attendance application may send a notification that the meeting is going to be held (e.g., when the quorum is determined to exist) or that the meeting is not going to be held (e.g., when the quorum is determined not to exist). The attendance application may determine a quantity of user devices 110 that are present and/or absent and may recommend adjustments to a curriculum, reassignment of tasks, changes to a schedule based on which users, of user devices 110, are present.
Network 160 may include one or more wired and/or wireless networks. For example, network 160 may include a cellular network, the public land mobile network (PLMN), a second generation (2G) network, a third generation (3G) network, a fourth generation (4G) network (e.g., a long term evolution (LTE) network), a fifth generation (5G) network, and/or another network. Additionally, or alternatively, network 160 may include a wide area network (WAN), a metropolitan area network (MAN), a telephone network (e.g., the Public Switched Telephone Network (PSTN)), an ad hoc network, an intranet, the Internet, a fiber optic-based network (e.g., a FiOS network), and/or a combination of these or other types of networks.
Device 200 may include a bus 210, a processor 220, a memory 230, an input component 240, an output component 250, and a communication interface 260. Although
Bus 210 may include a path that permits communication among the components of device 200. Processor 220 may include a processor, microprocessor, or processing logic that may interpret and execute instructions. Memory 230 may include any type of dynamic storage device that may store information and instructions, for execution by processor 220, and/or any type of non-volatile storage device that may store information for use by processor 220.
Input component 240 may include a mechanism that permits a user to input information to device 200, such as a keyboard, a keypad, a button, a switch, a microphone, a camera, a fingerprint reader, etc. Output component 250 may include a mechanism that outputs information to the user, such as a display, a speaker, one or more light emitting diodes (LEDs), a haptics-based device, etc. Communication interface 260 may include any transceiver-like mechanism that enables device 200 to communicate with other devices and/or systems via wireless communications (e.g., radio frequency, infrared, and/or visual optics, etc.), wired communications (e.g., conductive wire, twisted pair cable, coaxial cable, transmission line, fiber optic cable, and/or waveguide, etc.), or a combination of wireless and wired communications. For example, communication interface 260 may include mechanisms for communicating with another device or system via a network, such as network 160.
As will be described in detail below, device 200 may perform certain operations relating to automated attendance tracking and/or event notification operations. Device 200 may perform these operations in response to processor 220 executing software instructions contained in a computer-readable medium, such as memory 230. A computer-readable medium may be defined as a non-transitory memory device. A memory device may include space within a single physical memory device or spread across multiple physical memory devices. The software instructions may be read into memory 230 from another computer-readable medium or from another device. The software instructions contained in memory 230 may cause processor 220 to perform processes described herein. Alternatively, hardwired circuitry may be used in place of or in combination with software instructions to implement processes described herein. Thus, implementations described herein are not limited to any specific combination of hardware circuitry and software.
User ID field 302 may store a name, a student ID number, etc. associated with a user of a particular user device 110. User info field 304 may store information associated with the user. For example, the attendance application may store, in user info field 304, an age, a grade level, a sex, physical characteristics (e.g., hair color, eye color, height, weight, race, etc.) associated with the user. User device info field 305 may store information associated with the particular user device 110 with which the user is associated. For example, the attendance application may store, in user device info field 305, the information associated with the particular user device 110, which may include a device identifier (e.g., MDN, SIM URI, etc.), an address (e.g., an IP address, a MAC address, etc.), a type of device (e.g., a cellular telephone, a PDA, etc.).
Morning trans field 306 may store information associated with a mode of transportation used by the user of the particular user device 110 when commuting to school. For example, the attendance application may store, in morning trans field 306, information associated with a bus number, a bus schedule, a bus route, a bus stop, a period of time during which the particular user device 110 is scheduled to be commuting, an indication that the particular user device 110 is driven to school, information associated with a vehicle via which the particular user device 110 is driven to school, etc. Period fields 308-1 through 308-P may store information associated with a location at which the particular user device 110 is to be located during each period (e.g., period 1-period P) identified by period fields 308-1 through 308-P. For example, the attendance application may store, in period fields 308-1 through 308-P, a room number, a location (e.g., coordinates, latitude/longitude, etc.), a position within a facility, an address, etc. for each of the periods that the particular user device 110 is scheduled to be located.
Afternoon trans field 310 may store information associated with a mode of transportation used by the particular user device 110 when commuting from school to home or some other location. Special needs field 312 may store information associated with special needs of the user. For example, the attendance application may store, in special needs field 312, information regarding an illness, condition, allergy, and/or handicap associated with the user. The information associated with special needs may be used by a doctor in the event of a medical emergency or by a law enforcement officer, a teacher, etc. when performing an operation to locate, communicate and/or treat the user. Medication field 314 may identify a medication that the user is authorized to take.
Authorized pick up field 316 may store information that identifies persons that are authorized, by parents of the user, to pick up the user from school. Parent information fields 318-1 and 318-2 may store information associated with the parent of the user. For example, the attendance application may store, in parent information fields 318, information associated with one or more parents associated with the user (e.g., a username, password, PIN, a street address, a telephone number, etc.), information associated with another user device 110 via which the parent communicates with application server 150, etc.
Application server 150 may receive a request, from the particular user device 110 and/or the other user device 110 (e.g., with which the parent is associated) to set up an account associated with a student (e.g., the user of the particular user device 110). The attendance application may, in response to the request, send information associated with a set up user interface (UI) that permits the user, or parent of the user, to enter personnel information, associated with the user, via the set up UI. The user, or parent of the user, may enter the personnel information into the set up UI, which may enable the personnel information to be sent to application server 150. Application server 150 may receive the personnel information and may store the personnel information in a set up data structure (e.g., set up data structure 300).
For example, the stored personnel information may include a name and/or student ID associated with the user (e.g., Chuck Brown and/or 1234, respectively), information associated with the user (e.g., age 6, male, 1st grade, and any physical traits associated with the user), and/or information associated with the particular user device 110 (e.g., MDN1) (e.g., as shown by ellipse 320). The stored personnel information may also include information associated with a mode of transportation via which the user commutes to school (e.g., bus ID: 113, a duration of the commute “07:15-07:55”), information associated with locations at which the particular user device 110 is to be during each period of the day (e.g., period 1-Rm1; period 2-Rm3; period 3-gym, etc.) and/or information associated with a mode of transportation via which the user commutes from school (e.g., bus ID: 121, a duration of the commute “15:15-15:50”) (e.g., as shown by ellipse 320). In one example implementation, the information associated with the mode of transportation via which the user commutes to and/or from school and/or the information associated with the locations at which the particular user device 110 is to be located during each period of the day may be retrieved from a memory associated with application server 150 (e.g., in response to the request to set up the account) and may be sent to user device 110 for display (e.g., pre-populated) via the set up UI.
The stored personnel information may further include information associated with special needs of the user (e.g., condition A, allergy B, etc.), information associated with a medication to be taken (e.g., medication A at 1:00 pm), and/or information associated with persons that are authorized, by the parent, to pick up the user (e.g., Mr. or Mrs. Michael Brady) (e.g., as shown by ellipse 320). The stored personnel information may still further include information associated with a parent of the user (e.g., a username, password, PIN, address, telephone number, etc.) and/or information associated with another user device 110 via which the parent communicates with the attendance application (e.g., MDN2) (e.g., as shown by ellipse 320).
As shown in
As also shown in
In an example implementation, the attendance application may send, to client device 120 (e.g., with which a school administrator is associated), a request for a class schedule and/or bus information associated with the user of user device 110. The information associated with the class schedule and/or bus information may correspond to the information associated with the mode of transportation via which the user commutes to and/or from school and/or the information associated with the locations at which the particular user device 110 is to be located during each period of the day (e.g., fields 306-310 of
As further shown in
The attendance application may send a notification to user device 110 requesting that a parent and/or guardian of the user of user device 110 authorize the collection and/or use of location information, associated with the user device 110, when performing automated attendance tracking and/or event notification operations. The request may be accompanied with information describing the information, associated with user device 110, that is to be collected (e.g., information associated with the location of user device 110, changes in the location of user device 110 as a function of time, set up information as described above, etc.) and/or a manner in which the collected information is to be used and/or disseminated.
User ID field 502 may store a name and/or a student ID number that corresponds to a user of user device 110. User info field 504 may store information associated with the user. For example, the attendance application may store, in user info field 504, an age, a grade level, a sex, physical characteristics (e.g., hair color, eye color, height, weight, race, etc.) associated with the user. User device info field 506 may store information associated with user device 110 with which the user is associated. For example, the attendance application may store, in device info field 506, information associated with user device 110, which may include a device identifier (e.g., MDN, SIM URI, etc.), an address (e.g., an IP address, a MAC address, etc.), a type of device (e.g., laptop computer, a cellular telephone, a PDA, etc.).
Current period indicator field 508 may store information associated with a period (e.g., a school period) at a current point in time. Assigned location field 510 may store information associated with a location at which the user is assigned during a current period identified in current period indicator field 508. Presence indicator field 512 may store an indicator of whether the user is located at the assigned location. For example, if the user is located at the assigned location, then the attendance application may store an indication that the user is present. If the user is not located at the assigned location, then the attendance application may store an indication that the user is not present. Location indicator field 514 may store an indicator that corresponds to an actual location of user device 110. For example, if user device 110 is located at a location that corresponds to the assigned location, then the attendance application may store a location indicator that matches the assigned location indicator. If user device 110 is not located at a location that corresponds to the assigned location, then the attendance application may store a location indicator that does not match the assigned location indicator.
Time in field 516 may store a time at which user device 110 entered the assigned location. For example, the attendance application may use location information, obtained from SGW server 140, to identify a time at which the location information matched the assigned location. In another example implementation, user device 110 may send a signal to application server 150 indicating that user device 110 is located at the assigned location. For example, the user device 110 may send a signal (e.g., a Bluetooth signal, a beamed infrared signal) to client device 120 and/or to application server 150 when user device 110 is located at the assigned location (e.g., when user device 110 enters a room that corresponds to the assigned location). In yet another example implementation, the user may cause user device 110 to scan a device (e.g., an RFID device) located at the assigned location and which includes a unique code associated with the assigned location. User device 110 may send a signal (e.g., that includes the unique code) to application server 150 indicating that user device 110 is at the assigned location.
Time out field 518 may store a time at which user device 110 exits the assigned location. For example, the attendance application may use location information, obtained from SGW server 140, to identify another time at which the location information does not match the assigned location. In another example implementation, user device 110 may send a signal to application server 150 indicating that user device 110 is not located at the assigned location. For example, the user device 110 may cease sending a signal (e.g., a Bluetooth signal, a beamed infrared signal) to client device 120 and/or to application server 150 when user device 110 is not located at the assigned location (e.g., when user device 110 leaves the room that corresponds to the assigned location). In another example, user device 110 may send another signal to another client device 120 and/or to application server 150 when the user is located at another location that does not match the assigned location. In yet another example implementation, the user may cause user device 110 to scan a device (e.g., an RFID device) located at the assigned location and which includes a unique code associated with the assigned location. User device 110 may send a signal (e.g., that includes the unique code) to application server 150 indicating that user device 110 is leaving the assigned location. In another example, the user may cause user device 110 to scan another device (e.g., another RFID device) located at another location which indicates that user device 110 is not located at the assigned location.
Status field 520 may store an indication of whether user device 110 is associated with a normal state, a late state, and/or an absent state. For example, the attendance application may store a normal indication when user device 110 is present at the assigned location and/or arrived at the assigned location on time (e.g., prior to a time at which the current period begins). In another example, the attendance application may store a late indication when user device 110 is present at the assigned location and/or arrived at the assigned location late (e.g., after the time at which the current period begins). In yet another example, the attendance application may store an absent indication when user device 110 is not present at the assigned location.
Notification field 522 may store an indication that a notification is to be sent based on a state associated with user device 110. For example, the attendance application may store an indication that an absent notification is to be sent when user device 110 is absent and the absence is not excused. In another example, the attendance application may store an indication that a tardy notification is to be sent when user device 110 is determined to be late and the lateness is not excused.
Application server 150 may receive location information associated with user device 110 and the attendance application may identify a state associated with user device 110. For example, the attendance application may retrieve information from a set up data structure (e.g., set up data structure 300 of
Application server 150 may receive location information associated with other user devices 110 and the attendance application may identify a state associated with each of the other user devices 110. For example, the attendance application may retrieve information from a set up data structure (e.g., set up data structure 300 of
In yet another example, the attendance application may determine that a location (e.g., LOC1) associated with a further user device 110 does not match the assigned location (e.g., RM3) (e.g., as shown by ellipse 528). The attendance application may store a presence indicator (e.g., not present) based on the determination that the location of the other user device 110 does not match the assigned location (e.g., as shown by ellipse 528). The attendance application may store a status (e.g., absent) associated with the further user device 110 and may store an indication (e.g., absent) that an absent notification, associated with the further user device 110, is to be sent (e.g., as shown by ellipse 528).
In still another example, the attendance application may determine a status (e.g., absent) associated with another user device 110 (e.g., as shown by ellipse 530). The attendance application may determine that the absence is excused based on a notification received from client device 120 (e.g., when an operator, such as a teacher, authorized an early departure from an assigned location). Based on the determination that the absence is excused, the attendance application may store an indication (e.g., excused) that an absence excused notification, associated with the other user device 110, is to be sent (e.g., as shown by ellipse 530).
Roster identifier field 552 may store information associated with an operator of client device 120 to which roster data structure 550 corresponds. For example, the information associated with the operator (e.g., Ms. Beasley, 3rd Grade, RM 3) may be associated with roster data structure 550. Curriculum information field 554 may store information associated with a curriculum that corresponds to a user of user device 110. Presence total field 562 may store a quantity of users of user device 110 that are identified as present (e.g., by presence indicator 512). Attendance summary field 564 may store a summary of status indicators stored in status field 520. Notification summary field 566 may store a summary of notification indicators stored in notification field 522. Curriculum summary field 568 may store a summary of curriculum information stored in curriculum information field 554.
The attendance application may generate one or more roster data structures 550 for all or a portion of the operators associated with client devices 120. Roster data structure 550 may, in a manner similar to that described above (e.g., with respect to personnel data structure 500 of
The attendance application may determine a total quantity of user devices 110 that are present at the assigned location (e.g., based on indicators stored in presence indicator field 512) and may store the total quantity in data structure 550 (e.g., shown as 17 present in presence total field 562). The attendance application may identify an attendance summary (e.g., based on the status indicators stored in status field 520) and may store the summary in roster data structure 550 (e.g., shown as 15 on time, 2 late, and 1 absent in attendance summary field 564). The attendance application may identify a notification summary (e.g., based on the notification indicators stored in notification field 522) and may store the notification summary in roster data structure 550 (e.g., shown as 1 tardy and 1 absent in notification summary field 566).
The attendance application may identify a curriculum summary (e.g., based on the curriculum information, that corresponds to user devices 110, stored in curriculum info field 554) and may store the curriculum summary in roster data structure 550 (e.g., shown as 14 math 1, 0 math 2, 12 reading 1, and 5 reading 2 in curriculum summary field 568). An operator may use the information stored in roster data structure 550 to tailor curricula based on the quantity of user devices 110 that are present and/or the curriculums associated with the user devices 110 that are present. For example, an operator of client device 120 may tailor a math curriculum based on a determination that no user devices 110 associated with the math 2 curricula are present. In another example, the attendance application may, over a period of time, determine whether absenteeism and/or tardiness (e.g., based on notification summary field 566), associated with a class with which roster data structure 550 is associated, is excessive (e.g., based on a threshold) and may send a notification if excessive absenteeism and/or tardiness is detected.
As shown in
As also shown in
As further shown in
As yet further shown in
As still further shown in
As shown in
As also shown in
In an example implementation, the attendance application may retrieve, from the personnel data structure, information associated with a quantity of times that user device 110 was identified as being tardy over a time period (e.g., a school year, a quarter, a semester, etc.). The attendance application may compare the quantity of times that user device 110 was identified as being tardy to a threshold to determine whether a tardy condition (e.g., corresponding to excessive tardiness), associated with user device 110, exists. Based on a determination that the quantity of times that user device 110 was identified as being tardy, is greater than the threshold, the attendance application may send a notification to user device 110 and/or the other user device 110 and/or may store, in the personnel data structure, information associated with the tardiness condition with which user device 110 is associated.
As further shown in
As yet further shown in
In another example implementation, the attendance application may retrieve information from the personnel data structure that identifies a quantity of user devices 110 that have been determined to be absent during a particular period of time or on a particular day. Based on the identification of the quantity of user devices 110 that have been determined to be absent, the attendance application may determine whether to schedule or cancel a meeting. In one example, the attendance application may determine that a meeting, that was scheduled for the particular period of time and/or at a particular assigned location, is to be attended by a set of user devices of which one or more of the set of user devices have been identified as being absent. The attendance application may cancel the meeting based on a determination that the quantity of user devices 110, that are scheduled to attend the meeting and which are not absent, is less than a threshold (e.g., a quorum cannot be establish). In another example, the attendance application may schedule a meeting (e.g., an ad hoc meeting) based on a determination that particular user devices 110 are identified as not being absent.
In yet another example implementation, the attendance application may retrieve information from a roster data structure, which identifies a quantity of user devices 110 that have been determined to be absent from a group that is associated with the particular client device 120 and/or that corresponds the particular assigned location during a particular period of time. Based on the identification of the quantity of user devices 110 that have been determined to be absent, the attendance application may determine that all or a portion of a curriculum, work plans, task assignments, etc. associated with the particular period of time were associated with the quantity of user devices 110 that have been determined to be absent. Based on the determination that all or the portion of the curriculum, work plans, task assignments, etc. were associated with the quantity of user devices 110 that have been determined to be absent, the attendance application may send a notification to the particular client device 120 and/or may recommend modified curriculum, work plans, task assignments, etc. that is tailored to user devices 110 that are identified as not being absent.
As also shown in
In another example implementation, the other user device 110 and/or client device 120 may send a notification, to application server 150, indicating that user device 110 will be located outside a geographic area within which user device 110 is authorized to be located and/or at a distance that is greater than a particular distance beyond which user device 110 is not authorized to be located. The notification may indicate that user device 110, when located outside the authorized geographic location and/or beyond the particular distance, is to be excused. Application server 150 may receive the notification and may store, in the roster and/or personnel data structure, information indicating that user device 110 is to be excused when located outside the authorized geographic location and/or beyond the particular distance.
As further shown in
In another example implementation, the attendance application may retrieve, from the personnel data structure, information associated with a quantity of times that user device 110 was associated with an unexcused absence over a time period (e.g., a school year, a quarter, a semester, etc.). The attendance application may compare the quantity of times that user device 110 was associated with the unexcused absence to a threshold to determine whether an absence condition (e.g., corresponding to excessive absenteeism), associated with user device 110, exists. Based on a determination that the quantity of times that user device 110 was associated with the unexcused absence, is greater than the threshold, the attendance application may send a notification to user device 110 and/or the other user device 110, and/or may store, in the personnel data structure, information associated with the absence condition with which user device 110 is associated.
The attendance application may perform an operation to determine whether a potential safety event, associated with user device 110, exists based on the determination that the absence is not excused. In one example, the attendance application may instruct SGW server 140 to identify a location associated with user device 110 to determine whether user device 110 is located in and/or within a close proximity (e.g., based on a threshold) to the assigned location and/or a facility within which the assigned location is located. The attendance application may cause an instruction to be sent to another client device 120 (e.g., associated with a truant officer, a security officer, etc.) to initiate an investigation associated with user device 110.
In another example, the attendance application may send an instruction to user device 110 indicating that a user, of user device 110, is to report to the assigned location or some other location. Additionally, or alternatively, the attendance application may cause a call to be placed to user device 110 that may enable an administrator and/or operator, associated with application server 150 (e.g., a school official, a supervisor, etc.) to converse and/or communicate with the user of user device 110 in order to determine whether a potential safety event has occurred.
In still another example, the attendance application may cause a call to be placed to the other user device 110 that enables an administrator and/or operator, associated with application server 150, to converse and/or communicate with a user of the other user device 110 (e.g., a spouse, a parent, a guardian, etc.) to determine whether the potential safety event exists.
As yet further shown in
As still further shown in
Systems and/or methods, described herein, may enable an attendance application to automatically determine whether a user, associated with a user device, is present or absent based on location information associated with the user device. The systems and/or methods may use information associated with whether a user device is present, tardy, or absent relative to a particular location (e.g., a school, a work place, a class room, a bus, etc.) to generate and/or update information associated with the user (e.g., attendance records, class rosters, personnel records, payroll records, etc.). The systems and/or methods may determine whether a potential event, associated with the user, exists by determining whether the user device is missing, is excused from being absent, is excused from being late, etc. The systems and/or methods may perform an operation to locate the user device in the event of an unexcused absence and/or when a potential event is detected. The systems and/or methods may send notifications to the user device, another user device (e.g., associated with a parent, a physician, a guardian, spouse, etc. of the user), a client device (e.g., associated with a teacher, an administrator, a supervisor, etc. of the user), and/or governmental authorities (e.g., first responders and/or local, state, and/or federal officials, etc.). The notifications may identify a status of the user device (e.g., on time, tardy, absent, etc.), a presence of the user device (e.g., present or not present), whether a late or absent status is excused, and/or whether a potential event has been detected. The systems and/or methods may generate reports, such as personnel listings, class room rosters, attendance reports (e.g., a quantity of incidences of tardiness, absence, etc.), curriculum reports, etc.
The systems and/or methods may enable less time to be spent managing attendance of personnel, which may permit more time to be spent performing other duties. The systems and/or methods may permit the amount of time and/or funds associated with performing attendance data retrieval, attendance audits, record keeping, and/or reporting to be reduced. The attendance application may enable parents and/or supervisors to be kept informed as to the location and/or attendance status of children and/or employees, respectively.
The foregoing description provides illustration and description, but is not intended to be exhaustive or to limit the implementations to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of the embodiments.
While series of blocks have been described with regard to
It will be apparent that systems and methods, as described above, may be implemented in many different forms of software, firmware, and hardware in the implementations illustrated in the figures. The actual software code or specialized control hardware used to implement these systems and methods is not limiting of the implementations. Thus, the operation and behavior of the systems and methods were described without reference to the specific software code—it being understood that software and control hardware can be designed to implement the systems and methods based on the description herein.
Further, certain portions, described above, may be implemented as a component or logic that performs one or more functions. A component or logic, as used herein, may include hardware, such as a processor, an ASIC, or a FPGA, or a combination of hardware and software (e.g., a processor executing software).
It should be emphasized that the terms “comprises” and/or “comprising,” when used in this specification, are taken to specify the presence of stated features, integers, steps or components but does not preclude the presence or addition of one or more other features, integers, steps, components or groups thereof
Even though particular combinations of features are recited in the claims and/or disclosed in the specification, these combinations are not intended to limit the disclosure of the embodiments. In fact, many of these features may be combined in ways not specifically recited in the claims and/or disclosed in the specification. Although each dependent claim listed below may directly depend on only one other claim, the disclosure of the embodiments includes each dependent claim in combination with every other claim in the claim set.
No element, act, or instruction used in the present application should be construed as critical or essential to the embodiments unless explicitly described as such. Also, as used herein, the article “a” is intended to include one or more items. Where only one item is intended, the term “one” or similar language is used. Further, the phrase “based on” is intended to mean “based, at least in part, on” unless explicitly stated otherwise.