US11550863B2 - Spatially dynamic document retrieval - Google Patents
Spatially dynamic document retrieval Download PDFInfo
- Publication number
- US11550863B2 US11550863B2 US16/723,126 US201916723126A US11550863B2 US 11550863 B2 US11550863 B2 US 11550863B2 US 201916723126 A US201916723126 A US 201916723126A US 11550863 B2 US11550863 B2 US 11550863B2
- Authority
- US
- United States
- Prior art keywords
- document
- spatial
- user profile
- current
- objects
- 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.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/953—Querying, e.g. by the use of web search engines
- G06F16/9537—Spatial or temporal dependent retrieval, e.g. spatiotemporal queries
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/17—Details of further file system functions
- G06F16/176—Support for shared access to files; File sharing support
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/904—Browsing; Visualisation therefor
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/907—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
- G06F16/909—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using geographical or spatial information, e.g. location
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/93—Document management systems
Definitions
- embodiments of the present invention provide methods, apparatuses, systems, computing devices, and/or the like that are configured to enable document retrieval in document collaboration systems.
- certain embodiments of the present invention provide methods, apparatuses, systems, computing devices, and/or the like that are configured to enable document retrieval in document collaboration systems using at least one of spatial-temporal states, contextual labels, spatial labels, spatial-temporal relevance scores, and spatially dynamic document prediction interfaces.
- a method comprises: determining a current spatial-temporal state for a mobile device associated with a target user profile; accessing a document object repository comprising a plurality of document objects, wherein each document object of the plurality of document objects comprises one or more contextual labels and one or more spatial labels; for each document object of the plurality of document objects, determining a spatial-temporal relevance score for the document object with respect to the target user profile based on the one or more contextual labels for the document object, the one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile; and generating a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- a computer program product may comprise at least one computer-readable storage medium having computer-readable program code portions stored therein, the computer-readable program code portions comprising executable portions configured to: determine a current spatial-temporal state for a mobile device associated with a target user profile; access a document object repository comprising a plurality of document objects, wherein each document object of the plurality of document objects comprises one or more contextual labels and one or more spatial labels; for each document object of the plurality of document objects, determine a spatial-temporal relevance score for the document object with respect to the target user profile based on the one or more contextual labels for the document object, the one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile; and generate a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- an apparatus comprising at least one processor and at least one memory including computer program code.
- the at least one memory and the computer program code may be configured to, with the processor, cause the apparatus to: determine a current spatial-temporal state for a mobile device associated with a target user profile; access a document object repository comprising a plurality of document objects, wherein each document object of the plurality of document objects comprises one or more contextual labels and one or more spatial labels; for each document object of the plurality of document objects, determine a spatial-temporal relevance score for the document object with respect to the target user profile based on the one or more contextual labels for the document object, the one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile; and generate a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- FIG. 1 is a block diagram of an example document collaboration system and network architecture within which at least some embodiments of the present invention may operate.
- FIG. 2 is a block diagram of an example document collaboration server configured in accordance with at least some embodiments of the present invention.
- FIG. 3 is a block diagram of an example client device configured in accordance with at least some embodiments of the present invention.
- FIG. 4 is a flowchart diagram of an example process for spatially dynamic document presentation by a specially configured document collaboration system in accordance with at least some embodiments of the present invention.
- FIG. 5 is a flowchart diagram of an example process for determining a current spatial-temporal state for a client device using predictive mobility adjustment in accordance with at least some embodiments of the present invention.
- FIG. 6 provides an operational example of a document collaboration space creation user interface in accordance with at least some embodiments of the present invention.
- FIG. 7 provides an operational example of a document collaboration space selection user interface in accordance with at least some embodiments of the present invention.
- FIG. 8 provides an operational example of a document prediction task bar user interface in accordance with at least some embodiments of the present invention.
- FIG. 9 provides an operational example of a document prediction push notification user interface in accordance with at least some embodiments of the present invention.
- FIG. 10 provides an operational example of a spatial-temporal state data object in accordance with at least some embodiments of the present invention.
- FIG. 11 provides an operational example of a geolocation designation interface in accordance with at least some embodiments of the present invention.
- FIGS. 12 A- 12 D provide operational examples of spatially dynamic document prediction interfaces in accordance with at least some embodiments of the present invention.
- a large-scale document collaboration system may involve managing tens of thousands or millions of document objects.
- a document collaboration server of the document collaboration system needs to find the desired document object in its large document object repository and transmit the desired document object to a client device associated with a user profile associated with the user.
- the noted processes can be computationally expensive and plagued by inefficiencies that implicate data storage requirements and document retrieval and rendering latencies.
- a document collaboration server determines a current spatial-temporal state for a mobile device associated with a target user profile; determines a spatial-temporal relevance score for each document object with respect to the target user profile based on one or more contextual labels for the document object, one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile; and generates a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- various embodiments of the present invention incorporate predictive signals that indicate a predicted relevance of document objects to user profiles given contextual environments and activity patterns of document-requesting user profiles.
- the noted embodiments of the present invention can limit the number of document objects that a document collaboration server needs to query in order to process document retrieval requests.
- the described embodiments of the present invention enhance computational and data storage efficiency of document detection and document retrieval in large-scale document collaboration systems. Accordingly, various embodiments of the present invention improve computational and data storage efficiency of document detection and document retrieval in large-scale document collaboration systems.
- data As used herein, the terms “data,” “content,” “digital content,” “digital content object,” “information,” and similar terms may be used interchangeably to refer to data capable of being transmitted, received, and/or stored in accordance with embodiments of the present invention. Thus, use of any such terms should not be taken to limit the spirit and scope of embodiments of the present invention.
- a computing device is described herein to receive data from another computing device
- the data may be received directly from another computing device or may be received indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, hosts, and/or the like, sometimes referred to herein as a “network.”
- intermediary computing devices such as, for example, one or more servers, relays, routers, network access points, base stations, hosts, and/or the like, sometimes referred to herein as a “network.”
- the data may be sent directly to another computing device or may be sent indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, hosts, and/or the like.
- computer-readable storage medium refers to a non-transitory, physical or tangible storage medium (e.g., volatile or non-volatile memory), which may be differentiated from a “computer-readable transmission medium,” which refers to an electromagnetic signal.
- client device refers to computer hardware and/or software that is configured to access a service made available by a server.
- the server is often (but not always) on another computer system, in which case the client accesses the service by way of a network.
- Client devices may include, without limitation, smart phones, tablet computers, laptop computers, wearables, personal computers, enterprise computers, and the like.
- current spatial-temporal state is a data object that indicates a prediction about a geographic association of a client device during a particular time interval (e.g., a current point in time, a time interval that includes the current point in time as well as a period of time before and after the current point in time, etc.).
- the prediction about the geographic association of the client device may be based on a current geolocation designation for the client device (e.g., a current geolocation designation based on GPS coordinates of the client device), a current mobility designation for the client device (e.g., a current mobility designation based on comparing current geolocation designations for the client device over a period of time), a geolocation correlation between the current geolocation designation for the client device and the geolocation coordinates of one or more predefined spatial labels (e.g., a geolocation correlation between the current geolocation of a mobile device and geolocation coordinates of a particular office location to determine whether the mobile device is at the particular office location), etc.
- a current geolocation designation for the client device e.g., a current geolocation designation based on GPS coordinates of the client device
- a current mobility designation for the client device e.g., a current mobility designation based on comparing current geolocation designations for the client device over a period of time
- a current spatial-temporal state for a client device may indicate that the client device is at an office location.
- a current spatial-temporal state for a client may indicate that the client device is traveling between an office location and a residential location.
- a current spatial-temporal state for a client may indicate that the client device is traveling from a first meeting room of an office location to a second meeting room of an office location.
- current geolocation designation refers to a data object that indicates a location of a client device at a particular point in time (e.g., GPS coordinates of the client device at a particular point in time).
- a document collaboration server determines the current geolocation designation for the client device based on a geolocation identifying data object for the client device.
- the geolocation identifying data object for the client device is generated based on at least one of the following: (i) sensor output data from a geolocation reporting sensor (e.g., a GPS sensor) of the client device, (ii) an interaction between the mobile device and a machine-readable optical label (e.g., a Quick Response (QR) code label or a barcode label), (iii) a connection between the client device and a geolocation-registered communication network (e.g., a home WiFi network or an office WiFi network), and (iv) a short-range communication interaction (e.g., a Bluetooth communication interaction) between the client device and a geolocation-registered computing device.
- a geolocation reporting sensor e.g., a GPS sensor
- an interaction between the mobile device and a machine-readable optical label e.g., a Quick Response (QR) code label or a barcode label
- QR Quick Response
- a geolocation-registered communication network e.g.,
- the term “current mobility designation” refers to a data object that indicates a magnitude and a direction of velocity of a client device at a particular point in time.
- the current mobility designation for the client device may be determined based on comparing current geolocation designations for the client device over a temporally continuous period of time (e.g., the system may calculate a velocity for a client device by comparing a GPS position at time t 1 to a second position at time t 2 ).
- the current mobility designation for the client device may be determined based on output data from a velocity reporting sensor of the client device.
- the current mobility designation for the client device may be determined based on output data from a gyroscopic reporting sensor of the client device.
- determining the predicted travel trajectory for a client device includes determining the predicted travel trajectory based on estimating a path that starts at the current geolocation designation and traverses in a direction that is substantially aligned with the direction information included in the current mobility designation. In some embodiments, determining the predicted travel trajectory for a client device is further performed based on the magnitude information in the current mobility designation, such as for example by determining a shorter estimated path and/or an empty estimated path if the magnitude information indicate a below-threshold velocity magnitude. In still other embodiments, determining the predicted travel trajectory for a client device includes merging client device GPS location data with map data such as that made available from Google® Maps API. In other embodiments, local map data may be used such as proprietary maps of buildings, rooms, or campuses.
- contextual label refers to a data object that indicates an estimated relevance of a document object to an inferred environmental context of devices seeking to access the document object and/or an activity patterns of user profiles associated with the devices that seek to access the document object.
- Examples of contextual labels include mobility designations, topic labels, etc.
- Examples of contextual labels include absolute contextual labels and weighted contextual labels.
- An absolute contextual label may be a data object that, when used to associate a document object with an environment context and/or activity pattern, indicates that the document object is estimated to be relevant to the environment context and/or activity pattern.
- a weighted contextual label may be a data object that, when used to associate a document object with an environment context and/or activity pattern, indicates a degree of relevance of the document object to the environment context and/or activity pattern (e.g., a discrete degree of relevance or a continuous degree of relevance).
- An example of an absolute contextual label is a contextual label that indicates that a document is related to finance matters, administrative matters, etc.
- An example of a weighed contextual label is a contextual label that indicates that a document is 20% related to finance matters, 40% related to administrative matters, etc.
- At least some of the contextual labels of a document object are determined based on one or more machine learning models, e.g., a machine learning models trained using natural language features of the document objects as input data and past user usage of the natural language documents by one or more users as target output data.
- machine learning models e.g., a machine learning models trained using natural language features of the document objects as input data and past user usage of the natural language documents by one or more users as target output data.
- spatial label refers to a data object that indicates an estimated relevance of the document object to a spatial-temporal state.
- Examples of spatial labels include absolute spatial labels and weighted spatial labels.
- An absolute spatial label may be a data object that, when used to associate a document object with a current spatial-temporal state, indicates that the document object is estimated to be relevant to the current spatial-temporal state.
- a weighted spatial label may be a data object that, when used to associate a document object with a current spatial-temporal state, indicates a degree of relevance of the document object to the current spatial-temporal state (e.g., a discrete degree of relevance or a continuous degree of relevance).
- an absolute spatial label is a spatial label that indicates that a document is related to an office location, a home location, etc.
- An example of a weighed spatial label is a spatial label that indicates that a document is 20% related to an office location, 40% a home location, etc.
- at least some of the spatial labels of a document object are determined based on one or more machine learning models, e.g., a machine learning models trained using natural language features of the document objects as input data and past user usage of the natural language documents by one or more users as target output data.
- document collaboration space refers to a data object associated with one or more enrolled user profiles that enables giving defined access privileges to each related user profile associated with the document collaboration space with respect to a particular document object by associating the particular document object with the document collaboration space.
- Examples of document collaboration spaces include personal document collaboration spaces and collective document collaboration spaces.
- a personal document collaboration space may be a space that is statically (i.e., immutably) associated with a single enrolled user profile, while a collective document collaboration space may be a space that is dynamically (i.e., in a modifiable manner) associated with one or more enrolled user profiles.
- collective document collaboration spaces include team document collaboration spaces associated with one or more team member user profiles, project document collaboration spaces associated with one or more project participant user profiles, site document collaboration spaces associated with one or more site user profiles, etc.
- spatial-temporal relevance score refers to a data object that indicates an estimated relevance of a document object to a user profile given a current spatial-temporal state of the user profile.
- a document collaboration server to generate a spatial-temporal relevance score for a document object with respect to a user profile, a document collaboration server generates a relevance score vector that includes a relevance score for the document object with respect to each of a set of potential spatial-temporal states and selects, from the relevance score vector, the relevance score associated with the current spatial-temporal state of the user profile.
- the document collaboration server to generate a spatial-temporal relevance score for a document object with respect to a user profile, the document collaboration server generates a relevance score for each contextual label or each spatial label of the document object with respect to the current spatial temporal state of the user profile and aggregates (e.g., averages) each generated relevance score to generate the spatial-temporal relevance score.
- spatially dynamic document prediction interface refers to a user interface configured to present indications of a group of document objects based on spatial-temporal relevance scores associated with the document objects.
- a spatially dynamic document prediction interface includes indications of a preconfigured number of document objects having the highest spatial-temporal relevance score.
- a spatially dynamic document prediction interface includes indications of any document objects whose respective spatial-temporal relevance scores exceed a document presentation threshold.
- a spatially dynamic document prediction interface is accessible using a sidebar icon in a user interface associated with a document collaboration application.
- the term “document object repository” refers to a combination of one or more storage devices that are configured to store one or more document objects along with contextual labels and spatial labels for each document object.
- the document object repository may include a group of distributed storage devices. For example, one storage device may store document objects while another storage device may store metadata information about document objects such as contextual label data and spatial label data for the document objects.
- the document object repository is implemented as a software-as-a-service platform using a cloud-based web services service.
- the document object repository stores redundant copies of document object data and/or document object metadata in distributed storage platforms in order to decrease probability of data unavailability due to system failures and/or data loss scenarios.
- geolocation identifying data object refers to a data object received from a computing device that indicates a geolocation of the computing device at a time interval indicated in the geolocation identifying data object and/or at a time interval deemed to be sufficiently close to a time of dispatch and/or a time of receipt of the geolocation identifying data object.
- geolocation identifying data objects include data objects that indicate GPS coordinates of a data object at a particular time.
- geolocation reporting sensor device refers to any electronic device configured to generate an indication of at least one property of a physical environment of the electronic device.
- Examples of geolocation reporting sensor devices include image sensor devices (e.g., cameras), location-reporting sensor devices, temperature-identifying sensor devices, velocity-reporting sensor devices, pressure-reporting sensor devices, orientation-reporting sensor devices, etc.
- sensor output data refers to any data object generated by a geolocation reporting sensor device.
- sensor output data include image data objects recorded by an image sensor (e.g., a camera), temperature data objects recorded by a thermometer, proximity data objects recorded by a proximity sensor, acceleration data objects record by an accelerometer, pressure data objects recorded by a pressure sensor, position data objects recorded by a position sensor, etc.
- short-range communication interaction refers to any exchange of data objects, where the exchange of data objects is performed using a short-range communication channel between two or more communication devices.
- Examples of short-range communication channels include Bluetooth communication channels, Near-Field Communication (NFC) communication channels, Near-Field Communication-Contactless (NFC/CTLS) communication channels, etc.
- tention prediction refers to a data object that describes one or more user activities of a particular user profile based on at least one of a current geolocation designation of a mobile device associated with the particular user profile one or more activity planning data objects (e.g., confirmed calendar entries) associated with the user profile.
- the intention prediction is determined using an intention prediction machine learning model trained to determine user activity designations based on current geolocation designation data and activity planning data, where the intention prediction machine learning model is trained using past document search history data associated with the user profile.
- Methods, apparatuses, and computer program products of the present invention may be embodied by any of a variety of devices.
- the method, apparatus, and computer program product of an example embodiment may be embodied by a networked device (e.g., an enterprise platform), such as a server or other network entity, configured to communicate with one or more devices, such as one or more query-initiating computing devices.
- the computing device may include fixed computing devices, such as a personal computer or a computer workstation.
- example embodiments may be embodied by any of a variety of mobile devices, such as a portable digital assistant (PDA), mobile telephone, smartphone, laptop computer, tablet computer, wearable, or any combination of the aforementioned devices.
- PDA portable digital assistant
- FIG. 1 illustrates an example system architecture 100 within which embodiments of the present invention may operate.
- the architecture 100 includes a document collaboration system 105 configured to interact with one or more client devices 102 A-C, such as client device 102 A, client device B 102 B, and client device C 103 .
- the document collaboration system 105 may be configured to receive document retrieval requests from the client devices 102 A-C, process the document retrieval requests to generate user interfaces that include data associated with requested documents, and provide rendering data associated with the user interfaces to the client devices 102 A-C.
- the document collaboration system 105 may be configured to detect current spatial-temporal states of client devices 102 A-C and provide data associated with document objects deemed relevant to the current spatial-temporal states of client devices 102 A-C to those client devices 102 A-C.
- the document collaboration system 105 may communicate with the client devices 102 A-C using a network 104 .
- the network 104 may include any wired or wireless communication network including, for example, a wired or wireless local area network (LAN), personal area network (PAN), metropolitan area network (MAN), wide area network (WAN), or the like, as well as any hardware, software and/or firmware required to implement it (such as, e.g., network routers, etc.).
- the network 104 may include a cellular telephone, an 802.11, 802.16, 802.20, and/or WiMax network.
- the network 104 may include a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to Transmission Control Protocol/Internet Protocol (TCP/IP) based networking protocols.
- TCP/IP Transmission Control Protocol/Internet Protocol
- the networking protocol may be customized to suit the needs of the group-based communication system.
- the protocol is a custom protocol of JavaScript Object Notation (JSON) objects sent via a Websocket channel.
- JSON JavaScript Object Notation
- the protocol is JSON over RPC, JSON over REST/HTTP, and the like.
- the document collaboration system 105 may include a document collaboration server 106 and a document object repository 107 .
- the document collaboration server 106 may be configured to detect spatial-temporal states for client devices, determine spatial-temporal relevance scores for document objects given the detected spatial-temporal states for client devices, and generate spatially dynamic document prediction interface based on the spatial-temporal relevance scores.
- the document collaboration server 106 may be configured to generate push notification user interfaces for document objects whose spatial-temporal relevance score exceeds a critical relevance threshold.
- the document object repository 107 may store data associated with one or more document objects associated with the document collaboration system 105 .
- the document object repository 107 may include one or more storage units, such as multiple distributed storage units that are connected through a computer network. Each storage unit in the document object repository 107 may store at least one of one or more data assets and/or one or more data about the computed properties of one or more data assets.
- each storage unit in the document object repository 107 may include one or more non-volatile storage or memory media including but not limited to hard disks, ROM, PROM, EPROM, EEPROM, flash memory, MMCs, SD memory cards, Memory Sticks, CBRAM, PRAM, FeRAM, NVRAM, MRAM, RRAM, SONOS, FJG RAM, Millipede memory, racetrack memory, and/or the like.
- the document collaboration server 106 may be embodied by one or more computing systems, such as apparatus 200 shown in FIG. 2 .
- the apparatus 200 may include processor 202 , memory 204 , input/output circuitry 206 , communications circuitry 208 , context determination circuitry 210 , and document retrieval circuitry 212 .
- the apparatus 200 may be configured to execute the operations described herein.
- these components 202 - 212 are described with respect to functional limitations, it should be understood that the particular implementations necessarily include the use of particular hardware. It should also be understood that certain of these components 202 - 212 may include similar or common hardware. For example, two sets of circuitries may both leverage use of the same processor, network interface, storage medium, or the like to perform their associated functions, such that duplicate hardware is not required for each set of circuitries.
- the processor 202 (and/or co-processor or any other processing circuitry assisting or otherwise associated with the processor) may be in communication with the memory 204 via a bus for passing information among components of the apparatus.
- the memory 204 is non-transitory and may include, for example, one or more volatile and/or non-volatile memories.
- the memory 204 may be an electronic storage device (e.g., a computer-readable storage medium).
- the memory 204 may be configured to store information, data, content, applications, instructions, or the like for enabling the apparatus to carry out various functions in accordance with example embodiments of the present invention.
- the processor 202 may be embodied in a number of different ways and may, for example, include one or more processing devices configured to perform independently.
- the processor 202 may include one or more processors configured in tandem via a bus to enable independent execution of instructions, pipelining, and/or multithreading.
- processing circuitry may be understood to include a single core processor, a multi-core processor, multiple processors internal to the apparatus, and/or remote or “cloud” processors.
- the processor 202 may be configured to execute instructions stored in the memory 204 or otherwise accessible to the processor 202 .
- the processor 202 may be configured to execute hard-coded functionalities.
- the processor 202 may represent an entity (e.g., physically embodied in circuitry) capable of performing operations according to an embodiment of the present invention while configured accordingly.
- the instructions may specifically configure the processor 202 to perform the algorithms and/or operations described herein when the instructions are executed.
- the apparatus 200 may include input/output circuitry 206 that may, in turn, be in communication with processor 202 to provide output to the user and, in some embodiments, to receive an indication of a user input.
- the input/output circuitry 206 may comprise a user interface and may include a display, and may comprise a web user interface, a mobile application, a query-initiating computing device, a kiosk, or the like.
- the input/output circuitry 206 may also include a keyboard, a mouse, a joystick, a touch screen, touch areas, soft keys, a microphone, a speaker, or other input/output mechanisms.
- the processor and/or user interface circuitry comprising the processor may be configured to control one or more functions of one or more user interface elements through computer program instructions (e.g., software and/or firmware) stored on a memory accessible to the processor (e.g., memory 204 , and/or the like).
- computer program instructions e.g., software and/or firmware
- the communications circuitry 208 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to receive and/or transmit data from/to a network and/or any other device, circuitry, or module in communication with the apparatus 200 .
- the communications circuitry 208 may include, for example, a network interface for enabling communications with a wired or wireless communication network.
- the communications circuitry 208 may include one or more network interface cards, antennae, buses, switches, routers, modems, and supporting hardware and/or software, or any other device suitable for enabling communications via a network.
- the communications circuitry 208 may include the circuitry for interacting with the antenna/antennae to cause transmission of signals via the antenna/antennae or to handle receipt of signals received via the antenna/antennae.
- the context determination circuitry 210 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to identify a current spatial-temporal state of a user profile associated with a client device 102 A-C.
- the context determination circuitry 210 may be configured to determine current spatial-temporal states for particular client devices based on data received from one or more sensory devices operating on the client devices.
- the context determination circuitry 210 utilizes the communications circuitry 208 to transmit application programming interface (API) calls to one or more API servers associated with the noted client devices.
- API application programming interface
- the document retrieval circuitry 212 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to generate spatial-temporal relevance scores for document objects stored in the document object repository 107 based on the spatial-temporal state states determined by the context determination circuitry 210 .
- the document retrieval circuitry 212 may be further configured to retrieve document objects from the document object repository 107 based on the generated spatial-temporal relevance scores.
- the document retrieval circuitry 212 may be further configured to generate user interfaces that include data associated with the retrieved document objects.
- all or some of the information discussed herein can be based on data that is received, generated and/or maintained by one or more components of apparatus 200 .
- one or more external systems such as a remote cloud computing and/or data storage system may also be leveraged to provide at least some of the functionality discussed herein.
- the client device 102 A-C may be embodied by one or more computing systems, such as apparatus 300 shown in FIG. 3 .
- the apparatus 300 may include processor 302 , memory 304 , input/output circuitry 306 , communications circuitry 308 , and geolocation circuitry 310 .
- these components 302 - 310 are described with respect to functional limitations, it should be understood that the particular implementations necessarily include the use of particular hardware. It should also be understood that certain of these components 302 - 310 may include similar or common hardware. For example, two sets of circuitries may both leverage use of the same processor, network interface, storage medium, or the like to perform their associated functions, such that duplicate hardware is not required for each set of circuitries.
- the processor 302 (and/or co-processor or any other processing circuitry assisting or otherwise associated with the processor) may be in communication with the memory 304 via a bus for passing information among components of the apparatus.
- the memory 304 is non-transitory and may include, for example, one or more volatile and/or non-volatile memories.
- the memory 304 may be an electronic storage device (e.g., a computer-readable storage medium).
- the memory 304 may include one or more databases.
- the memory 304 may be configured to store information, data, content, applications, instructions, or the like for enabling the apparatus 300 to carry out various functions in accordance with example embodiments of the present invention.
- the processor 302 may be embodied in a number of different ways and may, for example, include one or more processing devices configured to perform independently.
- the processor 302 may include one or more processors configured in tandem via a bus to enable independent execution of instructions, pipelining, and/or multithreading.
- processing circuitry may be understood to include a single core processor, a multi-core processor, multiple processors internal to the apparatus, and/or remote or “cloud” processors.
- the processor 302 may be configured to execute instructions stored in the memory 304 or otherwise accessible to the processor 302 .
- the processor 302 may be configured to execute hard-coded functionalities.
- the processor 302 may represent an entity (e.g., physically embodied in circuitry) capable of performing operations according to an embodiment of the present invention while configured accordingly.
- the processor 302 when the processor 302 is embodied as an executor of software instructions (e.g., computer program instructions), the instructions may specifically configure the processor 302 to perform the algorithms and/or operations described herein when the instructions are executed.
- the apparatus 300 may include input/output circuitry 306 that may, in turn, be in communication with processor 302 to provide output to the user and, in some embodiments, to receive an indication of a user input.
- the input/output circuitry 306 may comprise a user interface and may include a display, and may comprise a web user interface, a mobile application, a query-initiating computing device, a kiosk, or the like.
- the input/output circuitry 306 may also include a keyboard (e.g., also referred to herein as keypad), a mouse, a joystick, a touch screen, touch areas, soft keys, a microphone, a speaker, or other input/output mechanisms.
- the processor and/or user interface circuitry comprising the processor may be configured to control one or more functions of one or more user interface elements through computer program instructions (e.g., software and/or firmware) stored on a memory accessible to the processor (e.g., memory 304 , and/or the like).
- computer program instructions e.g., software and/or firmware
- the communications circuitry 308 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to receive and/or transmit data from/to a network and/or any other device, circuitry, or module in communication with the apparatus 300 .
- the communications circuitry 308 may include, for example, a network interface for enabling communications with a wired or wireless communication network.
- the communications circuitry 308 may include one or more network interface cards, antennae, buses, switches, routers, modems, and supporting hardware and/or software, or any other device suitable for enabling communications via a network.
- the communications circuitry 308 may include the circuitry for interacting with the antenna/antennae to cause transmission of signals via the antenna/antennae or to handle receipt of signals received via the antenna/antennae.
- the geolocation circuitry 310 may be any means such as a device or circuitry embodied in either hardware or a combination of hardware and software that is configured to report a current geolocation of the apparatus 300 .
- the geolocation circuitry 310 may be configured to communicate with a satellite-based radio-navigation system such as the GPS system.
- the geolocation circuitry 310 may be configured to infer an indoor geolocation and/or a sub-structure geolocation of the apparatus 300 using signal acquisition and tracking and navigation data decoding, where the signal acquisition and tracking and the navigation data decoding is performed using GPS signals and/or GPS-like signals.
- Example techniques for performing indoor geolocation and/or sub-structure geolocations is presented in Xu et al., A New Indoor Positioning System Architecture Using GPS Signals, 15(5) Sensors 10074-10087 (2015), available at https://doi.org/10.3390/s150510074.
- Other examples of geolocation determination include Wi-Fi triangulation and ultra-wideband radio technology.
- all or some of the information discussed herein can be based on data that is received, generated and/or maintained by one or more components of apparatus 300 .
- one or more external systems such as a remote cloud computing and/or data storage system may also be leveraged to provide at least some of the functionality discussed herein.
- a document collaboration server determines a current spatial-temporal state for a mobile device associated with a target user profile; determines a spatial-temporal relevance score for each document object with respect to the target user profile based on one or more contextual labels for the document object, one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile; and generates a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- various embodiments of the present invention incorporate predictive signals that indicate predicted relevance of document objects to user profiles given contextual environments and activity patterns of document-requesting user profiles.
- the noted embodiments of the present invention can limit the number of document objects that a document collaboration server needs to explore in order to process document retrieval requests.
- the described embodiments of the present invention enhance computational and storage-wise efficiency of document detection and document retrieval in large-scale document collaboration system. Accordingly, various embodiments of the present invention improve computational and storage-wise efficiency of document detection and document retrieval in large-scale document collaboration system and make important technical contributions to enhancing computational and storage-wise efficiency of document detection and document retrieval in large-scale document collaboration system.
- FIG. 4 is a flowchart diagram of an example process 400 for spatially dynamic document presentation in a document collaboration system 105 .
- the document collaboration server 106 of the document collaboration system 105 can enhance efficiency and effectiveness of collaborative document retrieval and collaborative document presentation by integrating contextual and spatial considerations in determining whether and how to present document objects to end users.
- the process 400 begins at operation 401 when the document collaboration server 106 determines a current spatial-temporal state for a client device 102 A-C (e.g., a mobile device) associated with a target user profile.
- the current spatial-temporal state for a client device is a prediction about a geographic association of the client device during a particular time interval (e.g., a current point in time, a time interval that includes the current point in time as well as a period of time before and after the current point in time, etc.).
- the prediction about the geographic association of the client device may be based on a current geolocation designation for the client device (e.g., a current geolocation designation based on GPS coordinates of the client device), a current mobility designation for the client device (e.g., a current mobility designation based on comparing current geolocation designations for the client device over a period of time), a geolocation correlation between the current geolocation designation for the client device and the geolocation coordinates of one or more predefined spatial labels (e.g., a geolocation correlation between the current geolocation of a mobile device and geolocation coordinates of a particular office location to determine whether the mobile device is at the particular office location), etc.
- a current geolocation designation for the client device e.g., a current geolocation designation based on GPS coordinates of the client device
- a current mobility designation for the client device e.g., a current mobility designation based on comparing current geolocation designations for the client device over a period of time
- a current spatial-temporal state for a client device may indicate that the client device is at an office location.
- a current spatial-temporal state for a client may indicate that the client device is traveling between an office location and a residential location.
- a current spatial-temporal state for a client may indicate that the client device is traveling from a first meeting room of an office location to a second meeting room of an office location.
- the document collaboration server 106 may determine the current spatial-temporal state of a client device based on document browsing activity of a user profile associated with the client device. For example, if the user profile is browsing workplace-related documents, the document collaboration server 106 may determine that the client device is likely at the workplace even without using any geolocation designation data transmitted by the client device.
- the current spatial-temporal state 1000 indicates a location field 1001 which indicates a GPS coordinate, a mobility status field 1002 , and a location tag field 1003 .
- the location field 1001 indicates a GPS coordinate for a current location of a target user profile.
- the mobility status field 1002 indicates a non-mobile status for the target user profile.
- the location tag field 1003 indicates a descriptor for the GPS coordinated indicated by the location field 1001 , i.e., an “office” descriptor for the GPS coordinated indicated by the location field 1001 .
- operation 401 may be performed in accordance with the operations depicted in FIG. 5 , which is a flowchart diagram of an example process 500 for determining a current spatial-temporal state for a client device using predictive mobility adjustment.
- the process 500 begins at operation 501 when the document collaboration server 106 identifies a current geolocation designation for the client device.
- a current geolocation designation for the client device is any indication of a location of the client device at a particular point in time (e.g., GPS coordinates of the client device at a particular point in time).
- the document collaboration server 106 determines the current geolocation designation for the client device based on a geolocation identifying data object for the client device.
- the geolocation identifying data object for the client device is generated based on at least one of the following: (i) sensor output data from a geolocation reporting sensor device (e.g., a GPS sensor device) of the client device, (ii) an interaction between the mobile device and a machine-readable optical label (e.g., a QR code label or a barcode label), (iii) a connection between the client device and a geolocation-registered communication network (e.g., a home WiFi network or an office WiFi network), and (iv) a short-range communication interaction (e.g., a Bluetooth communication interaction) between the client device and a geolocation-registered computing device.
- a geolocation reporting sensor device e.g., a GPS sensor device
- an interaction between the mobile device and a machine-readable optical label e.g., a QR code label or a barcode label
- a connection between the client device and a geolocation-registered communication network e.g., a home WiFi network
- the document collaboration server 106 identifies a current mobility designation for the client device.
- the current mobility designation for the client device is any indication of a magnitude and a direction of velocity of the client device at a particular point in time.
- the current mobility designation for the client device may be determined based on comparing current geolocation designations for the client device over a temporally continuous period of time.
- the current mobility designation for the client device may be determined based on output data from a velocity reporting sensor of the client device.
- the current mobility designation for the client device may be determined based on output data from a gyroscopic reporting sensor of the client device.
- the document collaboration server 106 generates a predicted travel trajectory for the client device based on the current geolocation designation of the client device and the current mobility designation of the client device.
- the predicted travel trajectory for the client device is an indication of an estimated path along which the client device is moving given its current geolocation designation and current mobility designation.
- determining the predicted travel trajectory for a client device includes determining the predicted travel trajectory based on estimating a path that starts at the current geolocation designation and traverses in a direction that is substantially aligned with the direction information included in the current mobility designation.
- determining the predicted travel trajectory for a client device is further performed based on the magnitude information in the current mobility designation, such as for example by determining a shorter estimated path and/or an empty estimated path if the magnitude information indicate a below-threshold velocity magnitude.
- the document collaboration server 106 generates the current spatial-temporal state for the client device based on the predicted travel trajectory for the client device.
- the document collaboration server 106 first identifies a starting geolocation designation and an ending geolocation designation for the predicted travel trajectory. Then, the document collaboration server 106 correlates (e.g., using a triangulation algorithm) the starting geolocation designation and the ending geolocation designation with a set of labeled geographic designations (e.g., an office geographic designation, a home geographic designation, etc.) to come up with a starting geographic designation and an ending geographic designation for the predicted travel trajectory.
- a set of labeled geographic designations e.g., an office geographic designation, a home geographic designation, etc.
- the document collaboration server 106 indicates as the current spatial-temporal state for the client device that the client device is at the starting geographic designation. However, if the starting geographic designation and the ending geographic designation for the predicted travel trajectory are not the same, the document collaboration server 106 indicates as the current spatial-temporal state for the client device that the client device is traveling from the starting geographic designation to the ending geographic designation.
- the document collaboration server 106 accesses a document object repository 107 comprising a plurality of document objects, wherein each document object of the plurality of document objects is associated with (e.g., includes) one or more contextual labels and one or more spatial labels.
- a contextual label for a document object is a data object that indicates an estimated relevance of the document object to an inferred environmental context of devices seeking to access the document object and/or an activity patterns of user profiles associated with the devices seeking to access the document object. Examples of contextual labels include mobility designations, topic labels, etc.
- a spatial label for a document object is a data object that indicates an estimated relevance of the document object to a spatial-temporal state.
- contextual labels include absolute contextual labels and weighted contextual labels.
- An absolute contextual label may be a data object that, when used to associate a document object with an environment context and/or activity pattern, indicates that the document object is estimated to be relevant to the environment context and/or activity pattern.
- an absolute contextual label for a particular document object may indicate that the particular document object relates to an “at_meetingA” activity pattern.
- a weighted contextual label may be a data object that, when used to associate a document object with an environment context and/or activity pattern, indicates a degree of relevance of the document object to the environment context and/or activity pattern (e.g., a discrete degree of relevance or a continuous degree of relevance).
- a weighted contextual label for a particular document object may indicate that the particular document object relates to an “at_meetingA” activity pattern with a degree of relevance that indicates strong relevance of the particular document object with the “at_meetingA” activity pattern.
- An absolute spatial label may be a data object that, when used to associate a document object with a current spatial-temporal state, indicates that the document object is estimated to be relevant to the current spatial-temporal state.
- an absolute spatial label for a particular document object may indicate that the particular document object relates to an “at_locationA” current spatial-temporal state.
- a weighted spatial label may be a data object that, when used to associate a document object with a current spatial-temporal state, indicates a degree of relevance of the document object to the current spatial-temporal state (e.g., a discrete degree of relevance or a continuous degree of relevance).
- a weighted spatial label for a particular document object may indicate that the particular document object relates to an “at_meetingA” current spatial-temporal state with a degree of relevance that indicates strong relevance of the particular document object with the “at_meetingA” current spatial-temporal state.
- the plurality of document objects include one or more document objects associated with the target user profile.
- the document collaboration system 105 may define one or more association relationships between user profiles of the document collaboration system 105 and the document objects stored in the document object repository 107 of the document collaboration system 105 .
- a particular document collaboration system 105 may deem a particular user profile and a particular document object to have an association relationship if one or more of the following conditions are met with respect to the particular user profile and the particular document object: (i) the particular user profile is a creator of the particular document object, and (ii) another user profile having an association relationship with the particular document object has given sufficient access privileges (e.g., read or write access privileges, write-only access privileges, etc.) to the particular user profile with respect to the particular document object.
- sufficient access privileges e.g., read or write access privileges, write-only access privileges, etc.
- a particular document collaboration system 105 may deem a particular user profile and a particular document object to have an association relationship if one or more of the following conditions are met with respect to the particular user profile and the particular document object: (i) if the particular document object is in a personal document collaboration space of the particular user profile, (ii) if another user profile having the particular document object in its personal document collaboration space has given sufficient access privileges (e.g., read or write access privileges, write-only access privileges, etc.) to the particular user profile with respect to the particular document object, and (iii) if the particular document object is in a collective document collaboration space associated with the particular user profile.
- access privileges e.g., read or write access privileges, write-only access privileges, etc.
- a document collaboration space is a data object associated with one or more enrolled user profiles that enables giving defined access privileges to each related user profile associated with the document collaboration space with respect to a particular document object by associating the particular document object with the document collaboration space.
- Examples of document collaboration spaces include personal document collaboration spaces and collective document collaboration spaces.
- a personal document collaboration space may be a space that is statically (i.e., immutably) associated with a single enrolled user profile, while a collective document collaboration space may be a space that is dynamically (i.e., in a modifiable manner) associated with one or more enrolled user profiles.
- Examples of collective document collaboration spaces include team document collaboration spaces associated with one or more team member user profiles, project document collaboration spaces associated with one or more project participant user profiles, site document collaboration spaces associated with one or more site user profiles, etc.
- collective document collaboration spaces associated with a document collaboration system 105 may be divided into various categories based on at least one of an expected subject matter of content associated with each collective document collaboration space category, access privilege parameters of each collective document collaboration space category, etc.
- the document space categories 602 - 605 include a documentation space category 602 for collective document collaboration spaces that contain documentation information, a knowledgebase space category 603 for collective document collaboration spaces that contain knowledgebase information, a software project space category 604 for collective document collaboration spaces that contain software project documents (e.g., source code documents, executable files, etc.), and a team space 605 for collective document collaboration spaces that contain documents of relevance to a particular team.
- a documentation space category 602 for collective document collaboration spaces that contain documentation information
- a knowledgebase space category 603 for collective document collaboration spaces that contain knowledgebase information
- a software project space category 604 for collective document collaboration spaces that contain software project documents (e.g., source code documents, executable files, etc.)
- team space 605 for collective document collaboration spaces that contain documents of relevance to a particular team.
- identifying the one or more document objects associated with a target user profile of the document collaboration system is performed based on a current document collaboration space associated with the target user profile.
- the document collaboration system 105 may enable the target user profile to select a document collaboration space of the various spaces associated with the target user profile to work in.
- the document collaboration server 106 may automatically select a current document collaboration space for the target user profile based on at least one of a location of the target user profile, a current activity of the target user profile, a spatial-temporal state of the target user profile, etc.
- the document collaboration server 106 may include document objects associated with the current document collaboration space in the identified one or more document objects associated with the target user profile and exclude document objects that are not associated with the current document collaboration space from the identified one or more document objects associated with the target user profile even if those document objects are associated with one or more other document collaboration spaces that are associated with the target user profile.
- the document collaboration server 106 determines, for each document object of the plurality of document objects, a spatial-temporal relevance score for the document object with respect to the target user profile based on the one or more contextual labels for the document object, the one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile.
- a spatial-temporal relevance score for a document object with respect to a user profile is a data object that indicates an estimated relevance of the document to the user profile given a current spatial-temporal state of the user profile.
- the document collaboration server 106 to generate a spatial-temporal relevance score for a document object with respect to a user profile, the document collaboration server 106 generates a relevance score vector that includes a relevance score for the document object with respect to each of a set of potential spatial-temporal states and selects, from the relevance score vector, the relevance score associated with the current spatial-temporal state of the user profile. In some embodiments, to generate a spatial-temporal relevance score for a document object with respect to a user profile, the document collaboration server 106 generates a relevance score for each contextual label or each spatial label of the document object with respect to the current spatial temporal state of the user profile and aggregates (e.g., averages) each generated relevance score to generate the spatial-temporal relevance score.
- the one or more contextual labels for a document object of the plurality of document objects comprise one or more topical labels
- the spatial-temporal relevance score for a document object of the plurality of document objects is determined further based on a correlation score between the one or more topical labels for the document object and an intention prediction for the target user profile
- the intention prediction for the target user profile is determined based on the current spatial-temporal state of the target user profile.
- the one or more contextual labels for a document object of the plurality of document objects comprise one or more mobility association labels
- the spatial-temporal relevance score for a document object of the plurality of document objects is determined further based on a correlation score between the one or more mobility association labels for the document object and a mobility designation for the target user profile
- the mobility designations for the target user profile is determined based on the current spatial-temporal state of the target user profile.
- the document collaboration server 106 utilizes a machine learning model.
- the document collaboration server 106 may supply the one or more contextual labels for the document object, the one or more spatial labels for the document object, and the current spatial-temporal state of the target user profile as inputs to a trained supervised machine learning model (e.g., a trained neural network model) configured to generate the spatial-temporal relevance score for the document object with respect to the target user profile based on the supplied inputs.
- a trained supervised machine learning model e.g., a trained neural network model
- the trained supervised machine learning model may be trained using training data generated based on past user activity data associated with the target user profile and/or with user profiles determined to be similar demographically and/or in terms of activity metrics to the target user profile.
- the document collaboration server 106 may use the one or more contextual labels for the document object and the one or more spatial labels for the document object to map a current activity session in a multi-dimensional space that also includes mappings of other activity sessions associated with the current spatial-temporal state, where the other activity sessions have preconfigured spatial-temporal relevance scores. The document collaboration server 106 may then identify (e.g., using a clustering algorithm) based on a portion of the preconfigured spatial-temporal relevance scores associated with a portion of the other activity sessions associated with the current activity session.
- the document collaboration server 106 generates a spatially dynamic document prediction interface based on the spatial-temporal relevance score for each document object of the plurality of document objects.
- a spatially dynamic document prediction interface is a user interface configured to present indications of a group of document objects based on spatial-temporal relevance scores associated with the document objects.
- a spatially dynamic document prediction interface includes indications of a preconfigured number of document objects having the highest spatial-temporal relevance score.
- a spatially dynamic document prediction interface includes indications of any document objects whose respective spatial-temporal relevance scores exceed a document presentation threshold.
- a spatially dynamic document prediction interface is accessible using a sidebar icon, e.g., the sidebar icon 801 in the sidebar user interface 800 of FIG. 8 .
- generating the spatially dynamic document prediction interface comprises identifying a reduced set of the plurality of document objects satisfying a predetermined spatial-temporal relevance score criterion (e.g., having a highest spatial-temporal relevance score), and generating the spatially dynamic document prediction interface to comprise reduced indications of each of the reduced set of the plurality of document objects.
- a predetermined spatial-temporal relevance score criterion e.g., having a highest spatial-temporal relevance score
- the document collaboration server 106 determines whether a reduced set of the plurality of document objects whose respective spatial-temporal relevance scores satisfy a critical relevance threshold criterion (e.g., exceed a critical relevance threshold) is non-empty; and in response to determining that subset of the plurality of document objects is non-empty, generates a push notification user interface (e.g., the push notification user interface 900 of FIG. 9 ) that comprise reduced indications of each of the reduced set of the plurality of document objects.
- the document collaboration server 106 utilizes spatial-temporal relevance scores to organize presentation of document objects in response to document search requests and/or document listing requests.
- an end-user may be configured to generate geolocation designations for various geographic areas in a geographic region using a geolocation designation interface, such as the geolocation designation interface 1100 of FIG. 11 .
- the geolocation designation interface 1100 contains a map user interface element 1110 .
- an end-user can designate geographic locations and thus generate geolocation designations.
- the map user interface element 1110 depicted in FIG. 11 includes a “Home” geographic designation 1101 , a “Work” geographic designation 1102 , a “Gym” geographic designation 1103 , and a “Supermarket” geographic designation 1104 .
- Defining a geographic designation may enable the end-user to retrieve document objects deemed related to the geographic designation when the end-user is determined to be at an area sufficiently proximate to the geographic designation and/or when the end-user is determined to be in a predicted travel category whose destination designation is the geographic designation.
- interaction with the side-bar interface element 1210 causes a display of indications of home-related document objects.
- interaction with the side-bar interface element 1210 causes a display of indications of work-related document objects.
- interaction with the side-bar interface element 1210 causes a display of indications of gym-related document objects.
- interaction with the side-bar interface element 1210 causes a display of indications of supermarket-related document objects.
- Embodiments of the subject matter and the operations described herein can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them.
- Embodiments of the subject matter described herein can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on computer-readable storage medium for execution by, or to control the operation of, information/data processing apparatus.
- the program instructions can be encoded on an artificially-generated propagated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, which is generated to encode information/data for transmission to suitable receiver apparatus for execution by an information/data processing apparatus.
- a computer-readable storage medium can be, or be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them. Moreover, while a computer-readable storage medium is not a propagated signal, a computer-readable storage medium can be a source or destination of computer program instructions encoded in an artificially-generated propagated signal. The computer-readable storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices).
- the operations described herein can be implemented as operations performed by an information/data processing apparatus on information/data stored on one or more computer-readable storage devices or received from other sources.
- the term “data processing apparatus” encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing.
- the apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (Application Specific Integrated Circuit).
- the apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them.
- the apparatus and execution environment can realize various different computing model infrastructures, such as web services, distributed computing and grid computing infrastructures.
- a computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment.
- a computer program may, but need not, correspond to a file in a file system.
- a program can be stored in a portion of a file that holds other programs or information/data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code).
- a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
- processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
- a processor will receive instructions and information/data from a read-only memory, a random access memory, or both.
- the essential elements of a computer are a processor for performing actions in accordance with instructions and one or more memory devices for storing instructions and data.
- a computer will also include, or be operatively coupled to receive information/data from or transfer information/data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
- mass storage devices for storing data
- a computer need not have such devices.
- Devices suitable for storing computer program instructions and information/data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
- the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
- embodiments of the subject matter described herein can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information/data to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer.
- a display device e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor
- a keyboard and a pointing device e.g., a mouse or a trackball
- Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
- a computer can interact with a user by sending documents to and receiving documents from a device that is used by the user; for example, by sending web pages to a web browser on a user's query-initiating computing device in response to requests received from the web browser.
- Embodiments of the subject matter described herein can be implemented in a computing system that includes a back-end component, e.g., as an information/data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a query-initiating computing device having a graphical user interface or a web browser through which a user can interact with an implementation of the subject matter described herein, or any combination of one or more such back-end, middleware, or front-end components.
- the components of the system can be interconnected by any form or medium of digital information/data communication, e.g., a communication network.
- Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), an inter-network (e.g., the Internet), and peer-to-peer networks (e.g., ad hoc peer-to-peer networks).
- LAN local area network
- WAN wide area network
- inter-network e.g., the Internet
- peer-to-peer networks e.g., ad hoc peer-to-peer networks.
- the computing system can include clients and servers.
- a client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
- a server transmits information/data (e.g., a Hypertext Markup Language (HTML) page) to a query-initiating computing device (e.g., for purposes of displaying information/data to and receiving user input from a user interacting with the query-initiating computing device).
- Information/data generated at the query-initiating computing device e.g., a result of the user interaction
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Library & Information Science (AREA)
- Information Transfer Between Computers (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
Description
Claims (19)
Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US16/723,126 US11550863B2 (en) | 2019-12-20 | 2019-12-20 | Spatially dynamic document retrieval |
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US16/723,126 US11550863B2 (en) | 2019-12-20 | 2019-12-20 | Spatially dynamic document retrieval |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| US20210192002A1 US20210192002A1 (en) | 2021-06-24 |
| US11550863B2 true US11550863B2 (en) | 2023-01-10 |
Family
ID=76438445
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US16/723,126 Active US11550863B2 (en) | 2019-12-20 | 2019-12-20 | Spatially dynamic document retrieval |
Country Status (1)
| Country | Link |
|---|---|
| US (1) | US11550863B2 (en) |
Families Citing this family (4)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20210192361A1 (en) * | 2019-12-23 | 2021-06-24 | Marriott International, Inc. | Intelligent data object generation and assignment using artificial intelligence techniques |
| US11496908B2 (en) * | 2020-06-16 | 2022-11-08 | At&T Intellectual Property I, L.P. | Apparatuses and methods for enhancing network coverage in accordance with predictions |
| US12341832B2 (en) * | 2022-12-29 | 2025-06-24 | Atlassian Pty, Ltd. | Automatic adaptive digital content generation for collaborative documents using machine-learning-based digital content processing techniques |
| CN120029772B (en) * | 2025-01-24 | 2025-11-11 | 中航信移动科技股份有限公司 | A search task processing method, electronic device and storage medium |
Citations (21)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20020069312A1 (en) * | 2000-07-10 | 2002-06-06 | Jones Gad Quentin | System and method for the storage, management and sharing of spatial-temporal based information |
| US20080208847A1 (en) * | 2007-02-26 | 2008-08-28 | Fabian Moerchen | Relevance ranking for document retrieval |
| US20090325602A1 (en) * | 2008-06-27 | 2009-12-31 | Yahoo! Inc. | System and method for presentation of media related to a context |
| US20110184636A1 (en) * | 2010-01-27 | 2011-07-28 | Daniel Rolf | Method of Operating a Navigation System to Provide Geographic Location Information |
| US20120166432A1 (en) * | 2010-12-22 | 2012-06-28 | Erick Tseng | Providing Context Relevant Search for a User Based on Location and Social Information |
| US20130006974A1 (en) * | 2011-04-18 | 2013-01-03 | International Business Machines Corporation | File searching on mobile devices |
| US20130166188A1 (en) * | 2011-12-21 | 2013-06-27 | Microsoft Corporation | Determine Spatiotemporal Causal Interactions In Data |
| US20130325856A1 (en) * | 2012-06-04 | 2013-12-05 | Apple Inc. | App recommendation using crowd-sourced localized app usage data |
| US20140207730A1 (en) * | 2004-09-03 | 2014-07-24 | Open Text S.A. | Systems and methods for providing a collaboration place interface including data that is persistent after a client is longer in the collaboration place among a plurality of clients |
| US20140280103A1 (en) * | 2013-03-15 | 2014-09-18 | Geofeedr, Inc. | System and method for predicting a geographic origin of content and accuracy of geotags related to content obtained from social media and other content providers |
| US20140274122A1 (en) * | 2013-03-15 | 2014-09-18 | Erick Tseng | Multi-Factor Location Verification |
| US20140298207A1 (en) * | 2013-03-29 | 2014-10-02 | Intertrust Technologies Corporation | Systems and Methods for Managing Documents and Other Electronic Content |
| US20150019520A1 (en) * | 2013-07-15 | 2015-01-15 | Az.Mo.Sh Ltd. | System and method for conducting spatio-temporal search using real time crowd sourcing |
| US20150112963A1 (en) * | 2013-10-23 | 2015-04-23 | Tilofy, Inc. | Time and location based information search and discovery |
| US20150128020A1 (en) * | 2013-11-03 | 2015-05-07 | Oscar Garcia Chávez | System and method for collaboration based on geographical location |
| US20150149430A1 (en) * | 2006-06-28 | 2015-05-28 | Microsoft Corporation | Search Guided By Location And Context |
| US20150356183A1 (en) * | 2014-06-04 | 2015-12-10 | Facebook, Inc. | Recommending Objects To A User Of A Social Networking System Based On The Location Of The User |
| US20170091202A1 (en) * | 2015-09-25 | 2017-03-30 | Yahoo! Inc. | Region of search based on context |
| US20170091203A1 (en) * | 2015-09-28 | 2017-03-30 | Yahoo! Inc. | Predicting locations for web pages and related techniques |
| US20170249956A1 (en) * | 2016-02-29 | 2017-08-31 | International Business Machines Corporation | Inferring User Intentions Based on User Conversation Data and Spatio-Temporal Data |
| US20200075153A1 (en) * | 2018-08-31 | 2020-03-05 | Nutristyle Inc. | Geofenced equivalence recommendations for meal plan menu |
-
2019
- 2019-12-20 US US16/723,126 patent/US11550863B2/en active Active
Patent Citations (22)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20020069312A1 (en) * | 2000-07-10 | 2002-06-06 | Jones Gad Quentin | System and method for the storage, management and sharing of spatial-temporal based information |
| US20140207730A1 (en) * | 2004-09-03 | 2014-07-24 | Open Text S.A. | Systems and methods for providing a collaboration place interface including data that is persistent after a client is longer in the collaboration place among a plurality of clients |
| US20150149430A1 (en) * | 2006-06-28 | 2015-05-28 | Microsoft Corporation | Search Guided By Location And Context |
| US20080208847A1 (en) * | 2007-02-26 | 2008-08-28 | Fabian Moerchen | Relevance ranking for document retrieval |
| US20090325602A1 (en) * | 2008-06-27 | 2009-12-31 | Yahoo! Inc. | System and method for presentation of media related to a context |
| US20110184636A1 (en) * | 2010-01-27 | 2011-07-28 | Daniel Rolf | Method of Operating a Navigation System to Provide Geographic Location Information |
| US20120166432A1 (en) * | 2010-12-22 | 2012-06-28 | Erick Tseng | Providing Context Relevant Search for a User Based on Location and Social Information |
| US20130006974A1 (en) * | 2011-04-18 | 2013-01-03 | International Business Machines Corporation | File searching on mobile devices |
| US20130166188A1 (en) * | 2011-12-21 | 2013-06-27 | Microsoft Corporation | Determine Spatiotemporal Causal Interactions In Data |
| US20130325856A1 (en) * | 2012-06-04 | 2013-12-05 | Apple Inc. | App recommendation using crowd-sourced localized app usage data |
| US20130339345A1 (en) * | 2012-06-04 | 2013-12-19 | Apple Inc. | Mobile device with localized app recommendations |
| US20140280103A1 (en) * | 2013-03-15 | 2014-09-18 | Geofeedr, Inc. | System and method for predicting a geographic origin of content and accuracy of geotags related to content obtained from social media and other content providers |
| US20140274122A1 (en) * | 2013-03-15 | 2014-09-18 | Erick Tseng | Multi-Factor Location Verification |
| US20140298207A1 (en) * | 2013-03-29 | 2014-10-02 | Intertrust Technologies Corporation | Systems and Methods for Managing Documents and Other Electronic Content |
| US20150019520A1 (en) * | 2013-07-15 | 2015-01-15 | Az.Mo.Sh Ltd. | System and method for conducting spatio-temporal search using real time crowd sourcing |
| US20150112963A1 (en) * | 2013-10-23 | 2015-04-23 | Tilofy, Inc. | Time and location based information search and discovery |
| US20150128020A1 (en) * | 2013-11-03 | 2015-05-07 | Oscar Garcia Chávez | System and method for collaboration based on geographical location |
| US20150356183A1 (en) * | 2014-06-04 | 2015-12-10 | Facebook, Inc. | Recommending Objects To A User Of A Social Networking System Based On The Location Of The User |
| US20170091202A1 (en) * | 2015-09-25 | 2017-03-30 | Yahoo! Inc. | Region of search based on context |
| US20170091203A1 (en) * | 2015-09-28 | 2017-03-30 | Yahoo! Inc. | Predicting locations for web pages and related techniques |
| US20170249956A1 (en) * | 2016-02-29 | 2017-08-31 | International Business Machines Corporation | Inferring User Intentions Based on User Conversation Data and Spatio-Temporal Data |
| US20200075153A1 (en) * | 2018-08-31 | 2020-03-05 | Nutristyle Inc. | Geofenced equivalence recommendations for meal plan menu |
Non-Patent Citations (1)
| Title |
|---|
| Xu, Rui et al., A New Indoor Positioning System Architecture Using GPS Signals, Sensors, vol. 15, No. 5, (2015), pp. 10074-10087. DOI: 10.3390/s150510074. |
Also Published As
| Publication number | Publication date |
|---|---|
| US20210192002A1 (en) | 2021-06-24 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US11550863B2 (en) | Spatially dynamic document retrieval | |
| US11870704B2 (en) | Instant notification of load balance and resource scheduling based on resource capacities and event recognition | |
| US9838840B1 (en) | Detecting proximity using WiFi hotspots | |
| CN106416318B (en) | Methods, devices, and systems for determining data associated with proximate computing devices | |
| Assad et al. | PersonisAD: Distributed, active, scrutable model framework for context-aware services | |
| US9055400B1 (en) | Detecting proximity using WiFi hotspots | |
| JP6591672B2 (en) | Dueling deep neural network | |
| JP6911603B2 (en) | How to generate predictive models for the categories of facilities visited by users, programs, server equipment, and processing equipment | |
| Kwan et al. | Space-time research in GIScience | |
| US10582342B2 (en) | Location based computerized system and method thereof | |
| US20150170048A1 (en) | Determining a Type of Predictive Model for Training Data | |
| CN107430631B (en) | Determining Semantic Place Names from Location Reports | |
| US11023465B2 (en) | Cross-asset data modeling in multi-asset databases | |
| Toth | Ilona: indoor localization and navigation system | |
| US20180315019A1 (en) | Multinodal job-search control system | |
| US20220386071A1 (en) | Road side positioning method and apparatus, device, and storage medium | |
| CN105339927B (en) | The system and method for the position of user are inferred in online social media platform using social network analysis | |
| US20190287121A1 (en) | Speculative check-ins and importance reweighting to improve venue coverage | |
| US20230289586A1 (en) | Hybrid graph-based prediction machine learning frameworks | |
| US11593383B1 (en) | Apparatuses, methods, and computer program products for triggering component workflows within a multi-component system | |
| US20230100107A1 (en) | Apparatuses, methods, and computer program products for generating and presenting component score interfaces within a multi-component system | |
| US11727329B2 (en) | Method and system for receiving label for digital task executed within crowd-sourced environment | |
| Laube et al. | Deferred decentralized movement pattern mining for geosensor networks | |
| Heinrich et al. | Decision support for the usage of mobile information services: A context-aware service selection approach that considers the effects of context interdependencies | |
| Wang | [Retracted] Optimizing Multitask Assignment of Internet of Things Devices by Reinforcement Learning in Mobile Crowdsensing Scenes |
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: LARGE ENTITY |
|
| AS | Assignment |
Owner name: ATLASSIAN PTY LTD., AUSTRALIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LI, SHUAI;CHENG, JERRY;SIGNING DATES FROM 20191220 TO 20191223;REEL/FRAME:051366/0157 Owner name: ATLASSIAN INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LI, SHUAI;CHENG, JERRY;SIGNING DATES FROM 20191220 TO 20191223;REEL/FRAME:051366/0157 |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
| 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 RECEIVED |
|
| 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 |
|
| AS | Assignment |
Owner name: ATLASSIAN US, INC., CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:ATLASSIAN, INC.;REEL/FRAME:068654/0022 Effective date: 20220701 |