DE202015002394U1 - Einstellen von Attributen für ein System für On-Demand-Dienste basierend auf Echtzeitinformation - Google Patents

Einstellen von Attributen für ein System für On-Demand-Dienste basierend auf Echtzeitinformation Download PDF

Info

Publication number
DE202015002394U1
DE202015002394U1 DE202015002394.0U DE202015002394U DE202015002394U1 DE 202015002394 U1 DE202015002394 U1 DE 202015002394U1 DE 202015002394 U DE202015002394 U DE 202015002394U DE 202015002394 U1 DE202015002394 U1 DE 202015002394U1
Authority
DE
Germany
Prior art keywords
attribute
change
computer system
computing devices
feature
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
Application number
DE202015002394.0U
Other languages
English (en)
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Uber Technologies Inc
Original Assignee
Uber Technologies Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Uber Technologies Inc filed Critical Uber Technologies Inc
Publication of DE202015002394U1 publication Critical patent/DE202015002394U1/de
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/50Service provisioning or reconfiguring
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/04Protocols specially adapted for terminals or networks with limited capabilities; specially adapted for terminal portability
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/52Network services specially adapted for the location of the user terminal
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/38Creation or generation of source code for implementing user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/54Presence management, e.g. monitoring or registration for receipt of user log-on information, or the connection status of the users

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Between Computers (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

Ein Computersystem, umfassend: Einen oder mehrere Prozessoren, ausgelegt zum: Ermitteln einer Änderung, welche an einem Attribut eines Netzwerkdienstes zu implementiert ist, wobei das Attribut einer bestimmten Anwendung entspricht, welche einzelne Nutzer auf jeweiligen Computervorrichtungen betreiben können, um den Netzwerkdienst zu nutzen; Erhalten von Information, welche dieser Computervorrichtung von der auf dieser Computervorrichtung betriebenen bestimmten Anwendung zugeordnet ist, von jeder einer Mehrzahl von Computervorrichtungen, wobei die bestimmte Anwendung in Kommunikation mit dem Computersystem steht, wobei die Information wenigstens eine aktuelle Ortsinformation dieser Computervorrichtung umfasst; und basierend auf der von jeder der Mehrzahl von Computervorrichtungen erhaltenen Information, automatisches Implementieren der Änderung an jeder von einer ersten Gruppe von bestimmten Anwendungen, welche auf einer ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, wobei die Änderung an einer zweiten Gruppe von bestimmten Anwendungen, welche auf einer zweiten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, aber nicht implementiert wird, wobei der eine oder die mehreren Prozessoren die Änderung automatisch implementieren durch (i) Ermitteln eines dem Attribut zugeordneten Nutzerschnittstellenmerkmals und (ii) Veranlassen jeder bestimmten Anwendung, welche auf jeder der ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben wird, das bestimmte Nutzerschnittstellenmerkmal einer durch diese bestimmte Anwendung bereitgestellten Nutzerschnittstelle hinzuzufügen oder zu entfernen.

Description

  • HINTERGRUND DER ERFINDUNG
  • Ein System für On-Demand-Dienste kann veranlassen, dass ein Dienst durch einen Dienstleister einem Nutzer zur Verfügung gestellt wird. In einigen Beispielen können der Nutzer und der Dienstleister individuell eine Computervorrichtung betreiben, welche mit dem System für On-Demand-Dienste kommuniziert. Zum Beispiel betreiben der Nutzer und der Dienstleister jeweils eine bestimmte Anwendung, welche mit dem Dienstesystem auf der Vorrichtung des Nutzers bzw. der Vorrichtung des Dienstleisters kommuniziert.
  • KURZE BESCHREIBUNG DER ZEICHNUNGEN
  • 1 veranschaulicht ein beispielhaftes System zum Einstellen eines oder mehrerer Attribute für einen Echtzeitinformation nutzenden Netzwerkdienst.
  • 2 veranschaulicht ein beispielhaftes Verfahren zum Einstellen eines oder mehrerer Attribute für einen Echtzeitinformation nutzenden Netzwerkdienst.
  • 3 ist ein Blockdiagramm, welches ein Computersystem veranschaulicht, auf dem hier beschriebene Beispiele implementiert werden können.
  • 4 ist ein Blockdiagramm, welches eine mobile Computervorrichtung veranschaulicht, auf der hier beschriebene Beispiele implementiert werden können.
  • DETAILLIERTE BESCHREIBUNG
  • Hier beschriebene Beispiele stellen ein System zur Verfügung, welches einen Nutzer (z. B. einen administrativen Nutzer) des Systems dazu befähigt, ein einem oder mehreren Attributen eines Netzwerkdienstes zugeordnetes Merkmal hinzuzufügen, zu löschen, zu editieren und/oder ab- oder anzuschalten. Das System kann ein einem Attribut zugeordnetes Merkmal auch provisorisch an- oder abschalten, wie z. B. das An- oder Abschalten eines Merkmals für eine Gruppe (oder einen Prozentsatz) von Nutzern und/oder Computervorrichtungen. Gemäß einem Beispiel kann ein System für On-Demand-Dienste (welches den Netzwerkdienst zumindest teilweise implementiert) mit einem Merkmalsanbietersystem kommunizieren, um eine Änderung zu bestimmen, welche bezüglich eines Attributs des Netzwerkdiensts implementiert werden soll. Das System für On-Demand-Dienste kann von Kundenvorrichtungen, Dienstleistervorrichtungen (z. B. Treibervorrichtungen) erhaltene Information und/oder aktuelle dem System für On-Demand-Dienste zugeordnete Konfigurationsinformation nutzen, um die Änderung des Attributs des Netzwerkdienstes zu implementieren.
  • Wie hier beschrieben, kann ein Attribut einer Eigenschaft des Netzwerkdienstes entsprechen, wie beispielsweise eine dem Netzwerkdienst zugeordnete bestimmte Kundenanwendung (z. B. auf einer Kundenvorrichtung betrieben, um mit dem System für On-Demand-Dienste zu kommunizieren), eine dem Netzwerkdienst zugeordnete bestimmte Dienstleister-Anwendung (z. B. auf einer Dienstleistervorrichtung betrieben, um mit dem System für On-Demand-Dienste zu kommunizieren), ein von dem System für On-Demand-Dienste genutzter Vergabeprozess, ein von dem System für On-Demand-Dienste genutzter Preisfestlegungsprozess, andere von dem System für On-Demand-Dienste genutzte Prozesse, welche mit der Bereitstellung von On-Demand-Diensten in Verbindung stehen. Ein Merkmal kann ein Aspekt eines Attributs sein, welches hinzugefügt, entfernt, angepasst etc. werden kann, wie eine Nutzerschnittstelle einer bestimmten Anwendung, Text oder Grafiken der bestimmten Anwendung, auswählbare Merkmale der bestimmten Anwendung, zur Implementierung des Vergabeprozesses oder Preisfestlegungsprozesses benutzte Komponenten, Regeln oder Richtlinien für andere von dem System für On-Demand-Dienste genutzte Prozesse etc. zur Implementierung des Netzwerkdienstes.
  • Das System für On-Demand-Dienste und das Merkmalsanbietersystem können je auf einem oder mehreren Computersystemen oder -vorrichtungen implementiert sein. Gemäß Beispielen können das System für On-Demand-Dienste und das Merkmalsanbietersystem auf verschiedenen Computersystemen oder auf demselben Computersystem implementiert sein. Bei einem Beispiel kann das System für On-Demand-Dienste mit einem Merkmalsanbietersystem periodisch und/oder als Antwort auf eine erhaltene Nutzereingabe (oder mit Hilfe eines Push- oder Pull-Protokolls über eine dauerhafte Verbindung) kommunizieren. Das System für On-Demand-Dienste kann überprüfen, ob Aktualisierungen (engl.: Updates) oder Änderungen, welche an dem einen oder mehreren Attributen vorgenommen werden sollen, vorliegen. Je nach Beispiel kann das System für On-Demand-Dienste auf eine Konfigurationsdatenbank zugreifen, um zu ermitteln, ob eine Änderung an einem Attribut vorgenommen werden soll (z. B. das An- oder Abschalten eines Nutzerschnittstellenmerkmals der bestimmten Anwendung für bestimmte Vorrichtungen), oder über ein Push- oder Pull-Protokoll Anweisungen bezüglich einer an einem Attribut vorzunehmenden Änderung erhalten. Falls das System für On-Demand-Dienste feststellt, dass eine Änderung vorgenommen werden soll, kann das System für On-Demand-Dienste die Änderungen an einer oder mehreren der Kundenvorrichtungen und/oder Dienstleistervorrichtungen, basierend auf von den Vorrichtungen erhaltenen Informationen und basierend auf Konfigurationsdaten von Konfigurationsdateien implementieren, wenn Kundenvorrichtungen und/oder Dienstleistervorrichtungen mit dem System für On-Demand-Dienste das nächste Mal kommunizieren.
  • In einigen Beispielen kann das System für On-Demand-Dienste eine Änderung eines internen Prozesses implementieren, welcher durch das System für On-Demand-Dienste genutzt und/oder durchgeführt wird, um On-Demand-Dienste zu organisieren. Wie hier beschrieben, kann das Vermitteln eines Dienstes darin bestehen, einen Dienstleister auszuwählen, um den Dienst für einen anfragenden Nutzer auszuführen. Bei einem Beispiel kann eine Konfigurationsdatei, welche einem bestimmten Merkmal oder einem Attribut entspricht, das System für On-Demand-Dienste anweisen, einen Vergabe-(oder Fahrerauswahl-)Mechanismus oder -Prozess in einer bestimmten geografischen Region einzustellen (z. B. erhöhen oder erniedrigen eines Vergaberadius zur Auswahl von Fahrern im Vergleich zu einem vorherigen Vergaberadius). Als ein anderes Beispiel kann eine Konfigurationsdatei genutzt werden, um den Testbetrieb für das System für On-Demand-Dienste durchzuführen (z. B. A/B-Tests). Die Konfigurationsdatei kann das System für On-Demand-Dienste anweisen, Fahrer anhand einer Distanz für Fahrer auszuwählen, welche sich in einer geografischen Region befinden, und Fahrer anhand einer geschätzten Ankunftszeit für Fahrer auszuwählen, welche sich in einer anderen geografischen Region befinden.
  • Kundenvorrichtung, Dienstleistervorrichtung, Fahrervorrichtung und/oder Computervorrichtung sollen hier Vorrichtungen bezeichnen, welche Desktop-Computern, Mobilfunkvorrichtungen oder Smartphones, Personal Digital Assistants (PDAs), Laptop-Computern, Tablet-Vorrichtungen, Fernsehern (IP-Fernsehern) etc. entsprechen, welche Netzwerk-Verbindungen und Verarbeitungsressourcen zur Kommunikation mit dem System über ein Netzwerk bereitstellen können. Eine Fahrervorrichtung kann auch anderen Vorrichtungen eines Verkehrsmittels entsprechen, beispielsweise speziell hergestellte Hardware oder Computer in einem Fahrzeug etc. Das Kundenvorrichtung und/oder das Fahrervorrichtung können jeweils auch eine Anwendung ausführen, welche dazu ausgelegt ist, mit dem System zu kommunizieren (z. B. eine bestimmte Anwendung).
  • Obwohl Beispiele des hier beschriebenen Netzwerkdienstes sich auf einen On-Demand-Transportdienst beziehen, kann das System für On-Demand-Dienste auch andere ortsbasierte On-Demand-Dienste ermöglichen, welche zwischen Personen vereinbart werden, die die hier beschriebenen Computervorrichtungen nutzen. Zum Beispiel kann das System für On-Demand-Dienste einen Lieferservice (z. B. Nahrungsmittellieferung, Botendienst oder Produktlieferung), einen Nahrungsmitteldienst (z. B. Nahrungsmitteltransporter), oder einen Unterhaltungsdienst (z. B. Mariachi-Band, Streichquartett) bereitstellen, und ein Dienstleister, beispielsweise ein Fahrer, Nahrungsmittellieferant, Band etc., kann von dem System für On-Demand-Dienste ausgewählt werden, um den Dienst einem Nutzer bereitzustellen.
  • Eine oder mehrere hier beschriebene Ausführungsformen sehen vor, dass durch eine Computervorrichtung durchgeführte Verfahren, Techniken und Handlungen programmatisch oder als computerimplementiertes Verfahren durchgeführt werden. Programmtechnisch, wie hier verwendet, bedeutet: durch Benutzung von Code oder computerausführbaren Instruktionen. Diese Instruktionen können in einem oder mehreren Speicher-Ressourcen der Computervorrichtung gespeichert sein. Ein programmatisch ausgeführter Schritt kann automatisch sein oder nicht.
  • Eine oder mehrere hier beschriebenen Ausführungsformen können mit Hilfe von programmatischen Modulen, Maschinen (engl.: engines) oder Komponenten implementiert sein. Ein(e) programmatische(s) Modul, Maschine oder Komponente kann eines der folgenden umfassen: ein Programm, eine Subroutine, einen Teil eines Programms, oder eine Software-Komponente oder eine Hardware-Komponente, welche, eine oder mehrere festgelegte Aufgaben oder Funktionen durchzuführen kann. Wie hier verwendet, kann ein Modul oder eine Komponente auf einer Hardware-Komponente unabhängig von anderen Modulen oder Komponenten existieren. Alternativ kann ein Modul oder eine Komponente ein gemeinsam genutzter Bestandteil oder Prozess anderer Module, Programme oder Maschinen sein.
  • Einige hier beschriebene Ausführungsformen können im Allgemeinen die Nutzung von Computervorrichtungen benötigen, welche Verarbeitungs- und Speicherressourcen umfassen. Zum Beispiel können eine oder mehrere hier beschriebene Ausführungsform ganz oder teilweise beispielsweise auf Computervorrichtungen implementiert sein, wie zum Beispiel: Server, Desktop-Computer, Mobil- oder Smartphones, persönliche digitale Assistenten (z. B. PDAs), Laptop-Computer, Drucker, digitale Bilderrahmen, Netzwerkausrüstung (z. B. Router) und Tablet-Vorrichtungen. Speicher-, Verarbeitungs- und Netzwerk-Ressourcen können alle in Verbindung mit dem Bereitstellen, Nutzen oder Ausführen jeglicher hier beschriebener Ausführungsformen genutzt werden (welches das Durchführen jegliches Verfahrens oder die Implementierung jeglichen Systems umfasst).
  • Ferner können eine oder mehrere hier beschriebene Ausführungsformen durch das Nutzen von Instruktionen implementiert werden, welche von einem oder mehreren Prozessoren ausführbar sind. Diese Instruktionen können auf einem computerlesbarem Medium gespeichert sein. Maschinen, welche im Zusammenhang mit Zeichnungen unten gezeigt oder beschrieben sind, stellen Beispiele von Verarbeitungsressourcen und computerlesbaren Medien dar, auf welchen Instruktionen für die Erfindung implementierende Ausführungsformen gespeichert und/oder ausgeführt werden können. Insbesondere umfassen die im Zusammenhang mit Ausführungsformen der Erfindung gezeigten zahlreichen Maschinen einen oder mehrere Prozessoren und verschiedene Formen von Speichern, um Daten und Instruktionen zu speichern. Beispiele von computerlesbaren Medien umfassen permanente Speichervorrichtungen sowie zum Beispiel Festplatten von Personal-Computern oder Servern. Andere Beispiele von Computerspeicher-Medien umfassen tragbare Speichereinheiten, wie zum Beispiel CD- oder DVD-Einheiten, Flash-Speicher (wie in Smartphones, Multifunktions-Vorrichtungen oder Tabletcomputern) und magnetische Speicher. Computer, Endvorrichtungen, netzwerkfähige Vorrichtungen (z. B. Mobilvorrichtungen, wie Mobiltelefone) sind Beispiele von Maschinen und Vorrichtungen, welche Prozessoren, Speicher und auf computerlesbaren Medien gespeicherte Instruktionen nutzen. Zusätzlich können Ausführungsformen in Form von Computerprogrammen oder in Form eines von einem Computer nutzbares Speichermedium implementiert sein, das ein solches Programm speichern kann.
  • SYSTEMBESCHREIBUNG
  • 1 veranschaulicht ein beispielhaftes System, um dynamisch ein Attribut(e) für ein Netzwerksystem mit Hilfe von Echtzeit-Information einzustellen. Ein System für On-Demand-Dienste kann mit einem Merkmalsanbietersystem kommunizieren, welches dem System für On-Demand-Dienste mitteilt oder vorschreibt, welche Merkmale von Attributen an- oder ausgeschaltet werden sollen (oder vorübergehend an- oder ausgeschaltet werden sollen). Zum Beispiel kann das Merkmalsanbietersystem eine Nutzerschnittstelle bereitstellen, um einem Nutzer (z. B. einen administrativen Nutzer des Merkmalsanbietersystems und/oder des Systems für On-Demand-Dienste) zu ermöglichen, das System zu veranlassen, Merkmale für bestimmte Vorrichtungen oder für bestimmte durch das System für On-Demand-Dienste durchgeführte Prozesse basierend auf Echtzeit-Bedingungen an- oder abzuschalten, wie Tageszeit, Vorrichtungs- oder Anwendungsinformation, Ort der Vorrichtung, Information über den derzeitigen Vergabestatus etc. Auf diese Weise können das System für On-Demand-Dienste und das Merkmalsanbietersystem zusammenarbeiten, um Änderungen von Attributen des Systems für On-Demand-Dienste mit spezifischer Granularität dynamisch zu implementieren.
  • Gemäß einem Beispiel umfasst ein System 100 ein System für On-Demand-Dienste 110 (auch bezeichnet als das On-Demand-System 110) und ein Merkmalsanbietersystem 140. Das On-Demand-System 110 umfasst eine Merkmalsteuerungskomponente 120, eine Merkmalschnittstelle 130, eine Kunden-Schnittstelle 133, eine Fahrer-Schnittstelle 135, eine Nutzerschnittstellendatenbank 127 und eine Geschäftslogik 190, und das Merkmalsanbietersystem 140 umfasst eine Merkmalverwaltungskomponente 150 (welche eine Merkmalschnittstelle 160 bereitstellt), eine Dienstschnittstelle 155 und eine Konfigurationsdatenbank 165. Eine Mehrzahl von Kundenvorrichtungen 170 und eine Mehrzahl von Fahrervorrichtungen 180 können auch mit dem System 100 über ein oder mehrere Netzwerke kommunizieren. Die Komponenten des Systems 100 können gemeinsam ein Attribut für das On-Demand-System 110 basierend auf Echtzeitinformation (oder nahezu Echtzeitinformation) dynamisch einstellen, welche von den Kundenvorrichtungen 170 und/oder den Fahrervorrichtungen 180 und/oder als dem On-Demand-System 110 zugeordnete aktuelle Konfigurationsinformation erhalten wurde. Logik kann mit verschiedenen Anwendungen (z. B. Software) und/oder mit Hardware eines Computersystems implementiert werden, welches das System 100 implementiert.
  • Je nach Implementierung können eine oder mehrere Komponenten des Systems 100 auf netzwerkseitigen Ressourcen implementiert sein, wie einem oder mehreren Servern. Das System 100 kann auch durch andere Computersysteme in alternativen Architekturen implementiert sein (z. B. Peer-to-Peer-Netzwerke etc.). Zusätzlich oder alternativ können einige oder alle Komponenten des Systems 100 auf Kundenvorrichtungen implementiert sein, wie durch Anwendungen, welche auf den Kundenvorrichtungen 170 und/oder den Fahrervorrichtungen 180 betrieben werden. Zum Beispiel kann eine Kundenanwendung, wie eine bestimmte Dienstanwendung, ausgeführt werden, um eine oder mehrere der beschriebenen Prozesse durch die verschiedenen Komponenten des Systems 100 durchzuführen. Das System 100 kann via einer Netzwerk-Schnittstelle (z. B. drahtlos oder mittels einer Kabelverbindung) über ein Netzwerk kommunizieren, um mit der einen oder mehreren Kundenvorrichtungen 170 oder der einen oder mehreren Fahrervorrichtungen 180 zu kommunizieren.
  • Das System 100 kann über ein oder mehrere Netzwerke mit Kundenvorrichtungen 170 und Fahrervorrichtungen 180 mittels einer Kunden-Schnittstelle 133 bzw. einer Fahrerschnittstelle 135 kommunizieren. Die Vorrichtungsschnittstellen 133, 135 können Kommunikation zwischen dem System 100 und entfernten Computervorrichtungen verwalten. Die Kundenvorrichtungen 170 und Fahrervorrichtungen 180 können jeweils einzeln eine bestimmte Dienstanwendung betreiben, welche mit den Vorrichtungsschnittstellen 133, 135 in Verbindung treten kann, um mit dem System 100 zu kommunizieren. Gemäß einigen Beispielen können die Anwendungen eine Schnittstelle zur Anwendungsprogrammierung (engl.: application programming interface) (API), wie eine nach außen gerichtete API, umfassen oder nutzen, um Daten mit den Vorrichtungsschnittstellen 133, 135 auszutauschen. Die nach außen gerichtete API kann einen Zugang zu dem System 100 mittels sicherer Zugriffskanäle über das Netzwerk mittels einer Vielzahl von Verfahren bereitstellen, wie web-basierte Formulare, programmatischer Zugriff mittels REST-APIs (Anmerkung des Übersetzers: REST = Representational State Transfer), einem Simple Object Access Protocol (SOAP), ein Protokoll für verteilte Anwendungen (engl.: remote procedure call) (RPC), Skriptzugriff etc.
  • In einigen Beispielen kann die Merkmalsteuerungskomponente 120 des On-Demand-Systems 110 mittels der Merkmalschnittstelle 130 und der Dienstschnittstelle 155 mit dem Merkmalsanbietersystem 140 kommunizieren. Die Merkmalschnittstelle 130 und die Dienstschnittstelle 155 können das On-Demand-System 110 und das Merkmalsanbietersystem 140 dazu befähigen, miteinander zu kommunizieren und Daten auszutauschen. Zum Beispiel können die Merkmalschnittstelle 130 und die Dienstschnittstelle 150 ein Protokoll implementieren, wie ein Push-Protokoll oder Pull-Protokoll, welches der Merkmalsteuerungskomponente 120 ermöglicht, auf Updates dahingehend zu prüfen, welche Änderungen seit der letzten Kommunikation gemacht werden sollen. Zum Beispiel kann ein Push-Protokoll des Merkmal-Anbieter-Systems 140 ermöglichen, Informationen über Updates für das On-Demand-System 110 über eine dauerhafte Verbindung (z. B. Web-Sockets, SPDY, Übertragungssteuerungsprotokoll (engl.: transmission control protocol), etc.) per ”Push” zu senden. Die Merkmalsteuerungskomponente 120 kann die Schnittstellen 130, 155 nutzen, um mit dem Merkmalsanbietersystem 140 periodisch (z. B. alle 5 Sekunden, 7 Sekunden etc.) und/oder in Antwort auf das Erhalten einer Nutzereingabe zu kommunizieren, welche die Merkmalsteuerungskomponente 120 anweist, das Merkmalsanbietersystem 140 auf Daten abzufragen. Mittels Kommunikation mit dem Merkmalsanbietersystem 140 kann die Merkmalsteuerungskomponente 120 feststellen, ob es eine Änderung gibt, welche hinsichtlich eines Attributs des On-Demand-Systems 110 implementiert werden soll.
  • Gemäß einem Beispiel kann die Konfigurationsdatenbank 165 eine Mehrzahl von Konfigurationsdateien für eine Mehrzahl von Merkmalen, welche jeweils einem Attribut des On-Demand-Systems 110 entsprechen, speichern. Wie hier beschrieben, betrifft eine Konfigurationsdatei Konfigurationsdaten, welche in einer Datei, Speicher oder einer anderen Datenstruktur oder -speicher gespeichert sind. Die Konfigurationsdatenbank 165 kann durch die Merkmalverwaltungskomponente 150 basierend auf Nutzereingaben aktualisiert und gepflegt werden. In einigen Beispielen kann ein Nutzer (z. B. ein Administrator) des Systems 100 auf eine von der Merkmalschnittstelle 160 der Merkmalverwaltungskomponente 150 bereitgestellten Nutzerschnittstelle 161 zugreifen und mit dieser interagieren, um Merkmale von verschiedenen Attributen des On-Demand-Systems 110 zu erstellen, löschen, bearbeiten und/oder an- oder abzuschalten (durch Bereitstellen von Nutzereingaben 163). Zum Beispiel kann die Nutzerschnittstelle 161 eine Mehrzahl von Optionen bereitstellen, um es dem Nutzer zu ermöglichen, Merkmale zu erstellen, zu löschen, zu bearbeiten und/oder abzuschalten. Die Optionen können erweiterbar sein, so dass Optionen hinzugefügt oder entfernt werden können, um eine Konfigurationsdatei zu erstellen.
  • Für ein bestimmtes Merkmal eines Attributs kann der Nutzer z. B. eine Konfigurationsdatei erstellen durch Bereitstellen von Konfigurationsdaten 167 via Nutzereingaben 163, umfassend (i) Bereitstellen eines Namens oder Identifikation, (ii) Spezifizieren eines Merkmalstyps, (iii) Bereitstellen eines Werts für das Merkmal, wie zum Beispiel einen Preis, Wert oder Schwellwert bezüglich des Merkmals (z. B. eine Distanz für einen Versendungs-Radius, eine Gesamtanzahl von Vorrichtungen, um ein bestimmtes Nutzerschnittstellenmerkmal zu erhalten etc.), (iv) Spezifizieren einer geografischen Region für das Merkmal (z. B. durch Zugreifen oder Verweisen auf eine Geofence-Datenbank, welche eine Mehrzahl von geographischen Begrenzungen (engl.: Geofences speichert), welche jeweils eine geografische Region definieren), (v) Angeben einer Zeit oder Zeitdauer (z. B. wenn das Merkmal an- oder abgeschaltet werden soll oder wie lange das Merkmal an- oder abgeschaltet werden soll, im Fall eines Zeitplans), (vi) Angeben einer Vorrichtung oder Vorrichtungstyps (z. B. nach Hersteller oder Betriebssystems der Vorrichtung), (vii) Angeben einer Anwendungsversion, (viii) Angeben eines Nutzers oder einer Gruppe von Nutzern, (ix) Angeben einer Prozentzahl von einem Merkmal exponierter Nutzer (z. B. 20% der Nutzer sehen das Merkmal A, wohingegen 80% der Nutzer Merkmale B auf der Nutzerschnittstelle der bestimmten Kundenanwendung sehen) und/oder (x) Bereitstellen anderer Informationen für die Konfigurationsdatei.
  • Die Merkmalschnittstelle 160 kann die Nutzereingaben 163 erhalten, und die Merkmalverwaltungskomponente 150 kann basierend auf den Nutzereingaben 163 die Konfigurationsdatei mit entsprechenden Konfigurationsdaten 167 erstellen und speichern. Die in einer Konfigurationsdatei gespeicherten Konfigurationsdaten 167 können die Merkmalsteuerungskomponente 120 dazu anweisen, ein entsprechendes Merkmal nur an jene Vorrichtungen 170, 180 und/oder an jenen Komponenten des On-Demand-Systems 110 zu implementieren, welche die von der Konfigurationsdatei spezifizierten Bedingungen erfüllen, wenn die Konfigurationsdatei angeschaltet ist. Bei einem Beispiel kann eine Konfigurationsdatei für eine Gruppe von Kundenvorrichtungen oder Fahrervorrichtungen zu einer bestimmten Tageszeit (z. B. um acht Uhr vormittags) oder manuell durch den administrativen Nutzer an- oder abgeschaltet werden.
  • Zusätzlich kann die Merkmalverwaltungskomponente 150 dem administrativen Nutzer ermöglichen, über die Nutzereingaben die Merkmale 163 an- oder abzuschalten. Zum Beispiel kann jede der Konfigurationsdateien in der Konfigurationsdatenbank 165 einen Wert (z. B. einen aktiven Wert) umfassen, welcher angibt, ob das entsprechende Merkmal an- oder abgeschaltet ist (z. B., ist das Merkmal aktiv?). Ein ”wahr”- oder ”ja”-Wert gibt an, dass das Merkmal aktiv ist oder an ist, wohingegen ein ”falsch”- oder ”nein”-Wert angibt, dass das Merkmal inaktiv oder aus ist. Der administrative Nutzer kann zeitlich terminieren, warm ein bestimmtes Merkmal automatisch an- oder abgeschaltet werden soll, oder manuell den aktiven Wert einstellen, um ein bestimmtes Merkmal an- oder abzuschalten.
  • Gemäß einigen Beispielen kann die Merkmalsteuerungskomponente 120 periodisch mit dem Merkmalsanbietersystem 140 kommunizieren, um festzustellen, welche Merkmale an- oder abgeschaltet sind. Je nach Implementierung kann die Merkmalverwaltungskomponente 150 für eine Aktualisierung an der Merkmalsteuerungskomponente 120 sorgen, welche angibt, ob und welche Änderungen seit der letzten Kommunikation gemacht wurden, wenn bei einem Beispiel die Merkmalsteuerungskomponente 120 den Merkmalanbieterdienst 140 anspricht. Die Merkmalverwaltungskomponente 150 kann einen Zeitstempel der letzten Kommunikation zwischen der Merkmalsteuerungskomponente 120 und der Merkmalverwaltungskomponenten 140 protokollieren und protokollieren, welche Merkmale damals an- oder abgeschaltet wurden, und einen Vergleich bei der darauffolgenden Kommunikation durchführen, um festzustellen, welche Merkmale Zustände geändert haben. Zum Beispiel kann im Vergleich zur letzten Kommunikation des On-Demand-Systems 110 mit dem Merkmalsanbietersystem 140 ein neues Merkmal 123 als Konfigurationsdatei hinzugefügt oder ein bestehendes Merkmal 121 an- oder abgeschaltet (oder gelöscht) worden sein. Die Merkmalsteuerungskomponente 120 kann von der Merkmalverwaltung 150 die Identifikation der Konfigurationsdateien erhalten, welche seit dem letzten Mal Zustände geändert haben, und auf die Konfigurationsdatenbank 165 zugreifen, um die Konfigurationsdaten 167 für diese Konfigurationsdateien zu ermitteln.
  • Zusätzlich oder alternativ kann die Merkmalsteuerungskomponente 120 auf die Konfigurationsdatenbank 165 zugreifen, um festzustellen, welche Merkmale an- oder abgeschaltet wurden. Zum Beispiel kann die Merkmalsteuerungskomponente 120 eine eigene Konfigurationsdatenbank 125 unterhalten, welche den derzeitigen Zustand der Attribute des On-Demand-Systems 110 angibt (z. B. welche Merkmale an oder aus sind). Die Konfigurationsdatenbank 125 kann angeben, welche Konfigurationsdateien derzeit aktiv sind (z. B. Merkmale haben, welche angeschaltet sind) und/oder welche Konfigurationsdateien derzeit inaktiv sind. Wenn die Merkmalsteuerungskomponente 120 mit dem Merkmalsanbietersystem 140 kommuniziert, kann die Merkmalsteuerungskomponente 120 die aktiven Werte der Konfigurationsdateien von der Konfigurationsdatenbank 165 lesen, um festzustellen, welche Merkmale derzeit angeschaltet oder abgeschaltet sind. Die Merkmalsteuerungskomponente 120 kann einen Vergleich mit Konfigurationsinformation von der Konfigurationsdatenbank 125 und der Konfigurationsinformation durchführen, welche von der Konfigurationsdatenbank 165 ausgelesen wurde, um festzustellen, ob und welche Änderungen seit dem letzten Zugriff der Merkmalsteuerungskomponente 120 auf die Konfigurationsdatenbank 165 vorgenommen worden sind.
  • Zum Beispiel stellt die Merkmalsteuerungskomponente 120 fest, dass eine Änderung implementiert werden soll, falls zum Zeitpunkt der Kommunikation der Merkmalsteuerungskomponente 120 mit dem Merkmalsanbietersystem 140 ein zuvor abgeschaltetes Merkmal (oder nicht existierendes Merkmal) nun angeschaltet (oder erstellt und angeschaltet) ist. In ähnlicher Weise, falls zum Zeitpunkt der Kommunikation der Merkmalsteuerungskomponente 120 mit dem Merkmalsanbietersystem 140 ein zuvor angeschaltetes Merkmal nun ausgeschaltet ist (oder gelöscht), stellt die Merkmalsteuerungskomponente 120 auch fest, dass eine Änderung implementiert werden soll. Die Merkmalsteuerungskomponente 120 kann aus dem Vergleich die Identität der Konfigurationsdateien feststellen, deren Zustand sich geändert hat, und auf die Konfigurationsdatenbank 165 zugreifen, um die Konfigurationsdaten 167 für diese Konfigurationsdateien zu ermitteln. Je nach Implementierung kann die Merkmalsteuerungskomponente 120 durch Feststellen, dass eine Änderung an einem Attribut des On-Demand-Systems 100 implementiert werden soll, die Konfigurationsdatei identifizieren und die entsprechenden Konfigurationsdaten 167 und Echtzeit-Information nutzen, um den Implementierungsprozess durchzuführen.
  • Das On-Demand-System 110 kann den Kundenvorrichtungen 170 zugeordnete Echtzeit-Kundeninformationen 171 und den Fahrervorrichtungen 180 zugeordnete Echtzeit-Fahrerinformationen 181 erhalten. Wenn eine bestimmte Kundenanwendung und/oder eine bestimmte Fahreranwendung auf einer Kundenvorrichtung 170 bzw. einer Fahrervorrichtung 180 ausgeführt wird, kann die Merkmalsteuerungskomponente 120 Kundeninformation 171 und/oder Fahrerinformation 181 von der jeweiligen bestimmten Anwendung periodisch und/oder in Antwort auf das Erhalten von Nutzereingaben auf diesen Vorrichtungen 170, 180 erhalten. Gemäß Beispielen umfasst die von den Vorrichtungen 170, 180 erhaltene Information 171, 181 wenigstens eines von (i) ein derzeitiger Ort der jeweiligen Computervorrichtung, (ii) ein Vorrichtungstyp der jeweiligen Computervorrichtung, (iii) eine der jeweiligen Computervorrichtung zugeordnete Nutzeridentifikation, oder (iv) eine Versionsinformation für die bestimmte Anwendung, welche auf der jeweiligen Computervorrichtung betrieben wird, oder andere mit der bestimmten Anwendung oder der jeweiligen Computervorrichtung zugeordnete Information.
  • Wenn die Merkmalsteuerungskomponente 120 feststellt, dass eine Änderung an einem Merkmal vorgenommen werden soll, kann die Merkmalsteuerungskomponente 120 (i) die entsprechenden Konfigurationsdaten 167, (ii) die Kundeninformation 171 und/oder Fahrerinformation 181 und (iii) andere bekannte Information (wie aktuelle Zeit oder Datum) nutzen, um die Änderung der bestimmten Anwendung auf den entsprechenden Vorrichtungen automatisch zu implementieren. Zum Beispiel können die bestimmten Anwendungen mit dem On-Demand-System 110 mittels eines Protokolls kommunizieren, in welchem Kundeninformation 171 und/oder Vorrichtungsinformation 181 an das On-Demand-System 110 übertragen wird (z. B. ein ping) und das On-Demand-System 110 eine Antwort bereitstellt. Bei einigen beschriebenen Beispielen kann das On-Demand-System 110 eine Antwort bereitstellen, welche einem Kundenanwendung-Steuerungssignal 173 oder einem Fahreranwendung-Steuerungssignal 183 entspricht, welches die jeweiligen bestimmten Dienstanwendungen veranlasst, eine entsprechende Änderung zu implementieren.
  • In einigen Beispielen kann die Merkmalsteuerungskomponente 120 auch auf eine Nutzerschnittstellendatenbank 127 zugreifen, welche verschiedene Nutzerschnittstellenmerkmale, auswählbare Merkmale, Texte, Grafiken etc. für die bestimmte Kundenanwendung und die bestimmte Fahreranwendung speichert. Eine Konfigurationsdatei kann einem Nutzerschnittstellenmerkmal entsprechen, welches an- oder abgeschaltet werden soll (z. B. einer Nutzerschnittstelle einer bestimmten Anwendung auf dem Kundenvorrichtung 170 oder dem Fahrervorrichtung 180 hinzugefügt oder von dort entfernt). Bei einem solchen Beispiel kann die Merkmalsteuerungskomponente 120 die Konfigurationsdaten 167 dieser Konfigurationsdatei nutzen, um Zugriff auf die Nutzerschnittstellendatenbank 127 und Identifikation der geeigneten Nutzerschnittstellendaten 129 zu ermitteln, welches Nutzerschnittstellenmerkmal hinzugefügt oder entfernt wird. Obwohl die Nutzerschnittstellendatenbank 127 als Teil des Systems für On-Demand-Dienste 110 dargestellt ist, kann die Nutzerschnittstellendatenbank 127 je nach Implementierung Teil des Merkmalsanbietersystems 140 oder des Vergabesystems (nicht in 1 gezeigt) sein und kann durch von einem Nutzer des Systems 100 bereitgestellten Eingaben aktualisiert werden.
  • Gemäß einem anderen Beispiel kann die Merkmalsteuerungskomponente 120 ermitteln, ob eine Änderung an einem durch das System für On-Demand-Dienste benutzt oder durchgeführten Prozess implementiert werden soll (im Gegensatz zu einem Merkmal auf den bestimmten Dienstanwendungen). Zum Beispiel kann eine Konfigurationsdatei, welche angeschaltet wurde, einem Merkmal entsprechen, in welchem das Vergabesystem des On-Demand-Systems 110 für eine bestimmte Stadt oder Ballungsgebiet für eine Fahrerauswahl einen zusätzlichen Faktor nutzt, im Vergleich zu einem vorherigen (oder standardmäßigen) Fahrerauswahl-Mechanismus, in welchem weniger Faktoren genutzt werden. Bei einem solchen Beispiel kann die Merkmalsteuerungskomponente 120 die dieser Konfiguration entsprechenden Konfigurationsdaten 167 bestimmen, derzeitige Vergabesystems-Konfigurationsinformation bestimmen (z. B. von dem Vergabesystem erhalten) und die Änderung an dem Vergabesystem automatisch unter Verwendung der Konfigurationsdaten 167 und der derzeitigen Vergabesystems-Konfigurationsinformation implementieren. Die Merkmalsteuerungskomponente 120 kann ein Steuersignal bereitstellen, welches der Änderung an dem Vergabesystem entspricht.
  • Obwohl das Vergabesystem in 1 nicht dargestellt ist, kann das On-Demand-System 110 das Vergabesystem umfassen und/oder in Kommunikation mit dem Vergabesystem sein. Das Vergabesystem kann Anfragen für Transportdienste von Nutzern erhalten, Fahrer für die Nutzer auswählen, um die Transportdienste durchzuführen, Preise für die Transportdienste bereitstellen und Zahlungstransaktionen für die Transportdienste durchführen.
  • Als ein Beispiel kann eine Konfigurationsdatei die Merkmalsteuerungskomponente 120 anweisen, eine Maximalzeitdauer, während der ein Fahrer eine Transportanfrage zu akzeptieren hat, nur für die Fahrer, die sich derzeit in einer bestimmten geografischen Region (z. B. in San Francisco, Kalifornien) aufhalten, von einer Standard-Zeitdauer (z. B. 10 Sek.) auf eine neue Zeitdauer (z. B. 20 Sek.) zu erhöhen. Anfangs kann die Konfigurationsdatei z. B. ausgeschaltet sein. Wenn der Nutzer (über die Merkmalschnittstelle 160) die Konfigurationsdatei anschaltet, kann die Merkmalsteuerungskomponente 120, wenn die Merkmalsteuerungskomponente 120 das nächste Mal an den Merkmalanbieterdienst 140 ein ging sendet (und/oder auf die Konfigurationsdatenbank 165 zugreift) feststellen, dass das Merkmal angeschaltet wurde und dass eine Änderung an diesem Merkmal implementiert werden soll.
  • Die Merkmalsteuerungskomponente 120 kann Fahrerinformation 181 von den Fahrervorrichtungen 180 erhalten und jene Fahrer identifizieren, welche sich in der durch die Konfigurationsdatei bestimmten geografischen Region befinden. Die Merkmalsteuerungskomponente 120 kann dann die Änderung an dem Merkmal an jenen Fahrervorrichtungen 180 implementieren, welche in der spezifizierten geografischen Region sind, indem ein Fahreranwendung-Steuerungssignals 183, welches der Änderung an den bestimmten Fahreranwendungen auf den Fahrervorrichtungen 180 entspricht, übertragen wird. Zusätzlich kann die Merkmalsteuerungskomponente 120 auch die Änderung an dem Merkmal des Vergabesystems implementieren, so dass das Vergabesystem über die erhöhte Akzeptanz-Zeit informiert ist. Auf diese Weise kann das Merkmal der erhöhten Akzeptanz-Zeit für Fahrer in San Francisco, Kalifornien (z. B. spezifiziert durch den San Francisco Geofence) auf deren jeweiligen Fahrervorrichtungen 180 implementiert werden, wohingegen das Merkmal der erhöhten Akzeptanz-Zeit für Fahrer, welche sich woanders befinden, nicht auf deren jeweiligen Fahrervorrichtungen 180 implementiert wird.
  • Zusätzlich oder alternativ kann das On-Demand-System 110 bei einigen Beispielen auf einem Server oder Computervorrichtung implementiert sein (oder einer Gruppe von Servern), wohingegen das Merkmalsanbietersystem 140 auf einem anderen Server oder Computervorrichtung (einer anderen Gruppe von Servern) implementiert sein kann. Obwohl zwei separate Systeme 110, 140 in 1 gezeigt sind, kann bei anderen Beispielen das Merkmalsanbietersystem 140 in dem On-Demand-System 110 als Einzelsystem und/oder in einem einzelnen Server oder Computervorrichtung enthalten sein. Ferner können bei einem anderen Beispiel mehrere On-Demand-Systeme 110 und/oder mehrere Merkmalsanbietersysteme 140 genutzt werden, um System 100 zu implementieren.
  • Zum Beispiel können mehrere Systeme mit dem Merkmalsanbietersystem 140 über die Dienstschnittstelle 155 und der Merkmalschnittstelle 130 des jeweiligen Systems kommunizieren, um Änderungen an Attributen des Netzwerkdienstes festzustellen und/oder zu implementieren. Bei einem anderen Beispiel kann die Geschäftslogik 190 des On-Demand-Systems 110 die Merkmalsteuerungskomponente 120 anweisen, ein oder mehrere andere Systeme des Netzwerkdienstes zu steuern. Die Geschäftslogik 190 kann mittels einer oder mehrerer Regeln oder Parameter konfiguriert sein, um die Merkmalsteuerungskomponente 120 anzuweisen, die geeignete Änderung an einem Merkmal eines anderen Systems des Netzwerkdienstes zu implementieren.
  • Gemäß einiger Beispiele kann das On-Demand-Systems 110 eine Mehrzahl von Systemen und Plattformen darstellen. Zum Beispiel kann das On-Demand-Systems auf jeglichem Betriebssystem ausgeführt werden (z. B. Windows, Linux etc.) und jeglicher Sprachplattform (z. B. Java, Node, Python etc.). Bei einer Implementierung kann die Merkmalsteuerungskomponente 120 grammatikalische Sprache nutzen, um die Konfiguration der Konfigurationsdatenbank zu beschreiben, damit die Merkmalsteuerungskomponente 120 über eine Mehrzahl von Systemen und Plattformen konsistent arbeitet.
  • METHODIK
  • 2 veranschaulicht ein beispielhaftes Verfahren zum Einstellen eines oder mehrerer Attribute für einen Netzwerkdienst mit Hilfe von Echtzeit-Information. Ein Verfahren, wie anhand eines Beispiels von 2 beschrieben, kann z. B. mit Hilfe von Komponenten implementiert werden, welche in Zusammenhang mit einer Ausführungsform von 1 beschrieben wurden. Dementsprechend dienen Verweise auf Elemente von 1 zur Veranschaulichung eines geeigneten Elements oder Komponente zur Durchführung eines beschriebenen Schrittes oder Unterschrittes.
  • Bezugnehmend auf 2 kann ein On-Demand-System 110 mit einem Merkmalsanbietersystem 140 kommunizieren (210). Je nach Implementierung kann das On-Demand-System 100 mit dem Merkmalsanbietersystem 140 periodisch, in Antwort auf Nutzereingaben (erhalten durch das On-Demand-System 110 oder das Merkmalsanbietersystem 140) und/oder als Teil eines zeitlich terminierten Push- oder Pull-Protokolls über eine dauerhafte Verbindung kommunizieren. Das Merkmalsanbietersystem 140 kann eine Konfigurationsdatenbank 165 umfassen, welche eine Mehrzahl von Konfigurationsdateien für eine Mehrzahl von mit dem Netzwerkdienst verknüpften Merkmalen speichert. Die Konfigurationsdateien können basierend auf einer Nutzereingabe oder basierend auf einer bestimmten Planung an- oder abgeschaltet werden, so dass die entsprechenden Merkmale von Attributen als zu ändernd angegeben werden können.
  • Das On-Demand-System 110 kann mit dem Merkmalsanbietersystem 140 kommunizieren, um festzustellen, ob eine Änderung existiert, welche an einem Attribut des Netzwerkdienstes implementiert werden soll (220). Zum Beispiel kann die Merkmalsteuerungskomponente 120 zum Zeitpunkt t = t1 feststellen, welche Merkmale im Vergleich zu einem früheren Zeitpunkt t = t0 an- oder abgeschaltet wurden (z. B. dem vorherigen Zeitpunkt einer Kommunikation des On-Demand-Systems 110 mit dem Merkmalsanbietersystem 140). Falls keine Änderung an einem Attribut vorgenommen werden soll, implementiert die Merkmalsteuerungskomponente 120 keine Änderung. Die Merkmalsteuerungskomponente 120 kann mit dem Merkmalsanbietersystem 140 zum nächstfolgenden Zeitpunkt kommunizieren. Andererseits kann, falls die Merkmalsteuerungskomponente 120 feststellt, dass eine oder mehrere Änderungen an einem Attribut implementiert werden sollen, die Merkmalsteuerungskomponente 120 die eine oder mehreren Konfigurationsdateien identifizieren, welche an- oder abgeschaltet (oder erstellt oder gelöscht) wurden und welche die eine oder mehreren an dem Attribut vorzunehmenden Änderungen vorgehen.
  • Zum Beispiel kann eine Konfigurationsdatei die Merkmalsteuerungskomponente 120 anweisen, für die bestimmten Kundenanwendungen auf Kundenvorrichtungen 170 in einer bestimmten geografischen Region (z. B. Los Angeles, Kalifornien) eine Fahrzeugauswahl-Schnittstelle zu nutzen, welche vier Fahrzeugtypen-Optionen hat (im Gegensatz zu drei Optionen). Zuvor, zum Zeitpunkt t = t0, kann die Konfigurationsdatei ausgeschaltet gewesen sein. Nachdem die Konfigurationsdatei zum Zeitpunkt t = t1 angeschaltet wurde, kann die Merkmalsteuerungskomponente 120, wenn die Merkmalsteuerungskomponente 120 mit dem Merkmalsanbietersystem 140 kommuniziert, feststellen, dass eine Änderung an einer bestimmten Kundenanwendung implementiert werden soll. Die Merkmalsteuerungskomponente 120 kann die Konfigurationsdatei aus der Konfigurationsdatenbank 165 identifizieren und die entsprechenden Konfigurationsdaten 167 ermitteln.
  • Das On-Demand-System 110 kann Informationen von den Kundenvorrichtungen 170 und/oder den Fahrervorrichtungen 180 erhalten (230). Zum Beispiel können die Kundenvorrichtungen 170 und/oder die Fahrervorrichtungen 180 einzeln eine bestimmte Dienstanwendung ausführen, welche mit dem On-Demand-System 110 kommuniziert. Je nach Implementierung kann das On-Demand-System 110 anfangs Informationen erhalten, wenn ein jeweiliger Nutzer oder Fahrer die jeweilige bestimmte Dienstanwendung startet oder öffnet und/oder periodisch danach. Die Vorrichtungen 170, 180 können Information senden, einschließlich (i) eines derzeitigen Orts einer entsprechenden Computervorrichtung (232), (ii) eines Vorrichtungstyps der entsprechenden Computervorrichtung (234), (iii) einer der entsprechenden Computervorrichtung zugeordnete Nutzeridentifikation, wie eine Nutzeridentifikation des Kunden oder Käufers oder die Nutzeridentifikation des Fahrers (236) und/oder (iv) eine Versionsinformation für die bestimmte Anwendung, welche auf der entsprechenden Computervorrichtung ausgeführt wird (238).
  • Die Merkmalsteuerungskomponente 120 kann die Änderung an einem oder mehreren der Kundenvorrichtungen 170 und/oder der Fahrervorrichtungen 180 und/oder an verschiedenen anderen Aspekten des Systems für On-Demand-Dienste basierend auf der erhaltenen Information und der Konfigurationsdaten 167, welche der Änderung an dem Attribut entspricht, implementieren (240). Bezugnehmend zurück auf die Beispiele können die Konfigurationsdaten 167 der Konfigurationsdatei die Merkmalsteuerungskomponente 120 anweisen, eine Fahrzeugauswahl-Schnittstelle zu nutzen, welche vier Auswahlmöglichkeiten (im Gegensatz zu drei Auswahlmöglichkeiten) für die bestimmten Kundenanwendungen auf Kundenvorrichtungen 170 hat, welche sich in einer bestimmten geografischen Region aufhalten. Die Merkmalsteuerungskomponente 120 kann die erhaltene Anwendung und/oder Anwendungs-Versionsinformation nutzen, um festzustellen, welche Vorrichtungen die Kundenanwendung ausführen und auch feststellen, welche Vorrichtungen sich derzeit in der geografischen Region befinden. Die Merkmalsteuerungskomponente 120 kann dann die Änderung an nur jenen Vorrichtungen implementieren, welche die in der Konfigurationsdatei festgelegten Bedingungen erfüllen. Bei einem Beispiel kann die Merkmalsteuerungskomponente 120 auf eine Nutzerschnittstellendatenbank 127 zugreifen, um die Nutzerschnittstellendaten 129 jener Fahrzeugauswahl-Schnittstellte festzustellen, welche vier Auswahlmöglichkeiten (im Gegensatz zu drei Auswahlmöglichkeiten) hat, so dass die Nutzerschnittstellendaten 129 zu den identifizierten Vorrichtungen als Teil der oder parallel zur Kundenanwendung-Steuerung 173 übermittelt werden können. Die Kundenanwendung-Steuerung 173 kann die bestimmten Kundenanwendungen veranlassen, die entsprechende Änderung zu implementieren.
  • Je nach Implementierung können eine Vielzahl von verschiedenen Änderungen an Attributen des On-Demand-Systems 110 implementiert werden. Bei einem Beispiel kann ein bestimmtes Anwendungs-Nutzerschnittstellenmerkmal auf der Kundenanwendung und/oder Fahreranwendung an- oder abgeschaltet (z. B. hinzugefügt, entfernt, ausgetauscht) werden (242). Dies kann umfassen das Ändern von auswählbaren Merkmalen, Bereitstellen von unterschiedlichem Text, Ändern von Grafiken (z. B. anstatt eines Bildes von einem sich auf einer Karte bewegenden Automobils wie auf einer Standard-Ansicht eines Fahrzeugtyps, ein Bild einer Katze oder eines Fußballs anzuzeigen), Ändern von Farben oder Konfigurationen der Anwendung etc. In einigen Beispielen können bestimmte Anwendungen auch dadurch geändert werden, dass eine Anwendungsaktualisierung für Anwendungen bestimmter Versionen per Push gesendet wird (244), z. B. falls eine Gruppe von Fahrern die Anwendungsversion 2.5 nutzt, aber die Version 2.3 (z. B. die ältere Version) besser mit weniger Problemen arbeitet, kann das Umschalten eines Merkmals zur Nutzung der älteren Version (während Version 2.5 geändert oder repariert wird), die Merkmalsteuerungskomponente 120 dazu veranlassen, festzustellen, welche Fahrer die Anwendung mit Version 2.5 betreiben. Die Merkmalsteuerungskomponente 120 kann dann automatisch die Änderung bei dieser Gruppe von Fahrern implementieren, um die Aktualisierung auf die Version 2.3 voranzutreiben.
  • Bei einem anderen Beispiel kann die Merkmalsteuerungskomponente 120 eine Änderung an einer Systemkomponente oder einem Prozess implementieren (246). Ein Merkmal kann einer Regel oder Vorschrift entsprechen, welche zur Vergabe von Fahrern, Festlegung von Preisen, Durchführung von Zahlungen etc. genutzt wird, und welche durch das Vergabesystem und/oder das On-Demand-System 110 durchgeführt wird. Solche Regeln oder Vorschriften können durch die Merkmalsteuerungskomponente 120 dynamisch eingestellt werden. Ferner umfassen andere Beispiele das An- oder Abschalten eines Dienstes, wodurch eine Änderung an Nutzerschnittstellenmerkmalen der bestimmten Dienst-Anwendungen, sowie an Komponenten oder Merkmalen des Vergabesystems und/oder des On-Demand-Systems 110 veranlasst wird (248). Zum Beispiel kann ein Dienst dem Aufteilen eines Fahrpreises zwischen mehreren Nutzern für einen Transportdienst entsprechen. Der Dienst zum Aufteilen eines Fahrpreises kann lediglich für jene Nutzer aktiviert werden, welche Administratoren des Systems sind (im Gegensatz zu anderen Kunden, welche nicht Administratoren sind) (z. B. zu Testzwecken vor Veröffentlichung). Ein entsprechendes Nutzerschnittstellenmerkmal (z. B. eine Menü-Option), um den Dienst zum Aufteilen eines Fahrpreises zu nutzen, kann für Kundenanwendungen angeschaltet werden, welche auf Vorrichtungen gespeichert sind, die lediglich Administratoren gehören. Zusätzlich kann die Merkmalsteuerungskomponente 120 die Ausführung des Dienstes zum Teilen eines Fahrpreises durch das On-Demand-System 110 lediglich für diese Administratoren ermöglichen.
  • Bei einem anderen Beispiel können als weiteres Nutzungsszenario Transportdienste je nach Land oder geografischer Region verschiedenen Regeln oder Vorschriften unterworfen sein. Die Konfigurationsdateien können veranlassen, dass verschiedene Regeln oder Vorschriften für verschiedene Nutzer implementiert werden, je nachdem, ob der Nutzer ein Kunde oder ein Fahrer ist und je nach derzeitigem Ort der Nutzer. Zum Beispiel können Kunden in einem bestimmten Staat oder Region ein Nutzerschnittstellenmerkmal haben, welches für ihre Kundenanwendungen angeschaltet ist, welche es einem Kunden ermöglichen, das On-Demand-System 110 zu benachrichtigen, falls der Fahrer anscheinend unter Einfluss [sic] von Alkohol/Drogen steht. Andere Kunden in anderen Regionen können dasselbe Nutzerschnittstellenmerkmal nicht angeschaltet haben.
  • ANWENDUNGSBEISPIELE
  • Zur Veranschaulichung werden im Folgenden Anwendungsbeispiele beschrieben. Bei einem Beispiel kann eine Einheit, welche den Netzwerkdienst bereitstellt, ein Sonderangebot oder einen Spezialdienst für Nutzer in einer geografischen Region anbieten. Dieses Sonderangebot oder Spezialdienst können für eine Zeitdauer oder permanent bis zur Abschaltung durch einen administrativen Nutzer der Einheit verfügbar sein. Zum Beispiel kann ein Transportdienstsystem typischerweise eine Gruppe von Fahrzeugtypen anbieten, welche ein Nutzer wählen kann, wenn er eine Transportanfrage für einen Transportdienst stellt. Ein administrativer Nutzer kann einen Spezialdienst erstellen, welcher von Nutzern in einer vorgegebenen geografischen Region während einer bestimmten Zeitdauer (z. B. während eines Monats, einer Woche oder bis zu einem bestimmten Datum und/oder Zeit etc.) angefragt werden kann. Der Spezialdienst kann einem bestimmten Fahrzeugtyp entsprechen, welcher in dieser geografischen Region zuvor nicht verfügbar war oder einem Lieferdienst für Nahrung (oder Katzen z. B. in Verbindung mit einer Partnerschaft mit einem Tierheim) an einen bestimmten Ort.
  • Wenn die Konfigurationsdatei für den Spezialdienst angeschaltet ist, z. B. bei dem Merkmalsanbietersystem 140, kann das On-Demand-System 110 feststellen, dass eine Änderung an einem Attribut (z. B. die Kundenanwendung und/oder das Vergabesystem) des Netzwerkdienstes implementiert werden soll. Das On-Demand-System 110 kann feststellen, welche Kundenanwendungen auf welchem Kundenvorrichtung 170 geändert werden sollen, so dass das dem Spezialdienst entsprechende Nutzerschnittstellenmerkmal durch diese Kundenanwendungen z. B. mit einbezogen und/oder angezeigt werden sollen. Das On-Demand-System 100 kann Kundeninformation 171 von den Kundenvorrichtungen 170 erhalten, ermitteln (basierend auf dem Geofence, welcher in der Konfigurationsdatei der geografischen Region zugeordnet ist), welche dieser Kundenvorrichtungen 170 sich in dem Geofence dieser geografischen Region befinden, und die Kundenanwendungen auf diesen Kundenvorrichtungen 170 veranlassen, die Änderung an der Nutzerschnittstelle zu implementieren. Bei einem Beispiel kann die Änderung dem Anzeigen einer Option zur Auswahl des Spezialdienstes (z. B. ein neues auswählbares Merkmal) entsprechen, welche zuvor nicht auf der Nutzerschnittstelle der Kundenanwendung verfügbar war. Zusätzlich oder alternativ kann die Änderung dem Anzeigen von grafischen Bildern entsprechen, welche zu dem Spezialdienst gehören (z. B. Bilder von Katzen oder Speiseeiswaffeln etc.) anstatt von Standard-Bildern von Automobilen, welche Standard-Transportdiensten zugeordnet sind. Bei einem solchen Beispiel würden diese Bilder die Bilder von Automobilen ersetzen, welche anderenfalls auf einer Karte der Nutzerschnittstelle angezeigt werden würden, um die nahezu Echtzeit-Orte dieser Automobile zu zeigen. Auf diese Weise können die Kundenvorrichtungen 170 in der geografischen Region andere Transportdienstangebote anzeigen, im Vergleich zu Kundenvorrichtungen 170, welche sich nicht in dieser geografischen Region befinden, wodurch das Attribut für den Netzwerkdienst für bestimmte Nutzergruppen geändert wird.
  • Falls die Konfigurationsdatei eine Zeitdauer angibt (z. B. drei Tage), während der der Spezialdienst Kundenvorrichtungen in der geografischen Region zur Verfügung gestellt wird, kann die Merkmalsteuerungskomponente 120 am Ende der Zeitdauer wieder eine Änderung an dem Attribut implementieren, um das Attribut zurück auf den vorherigen Zustand zu schalten. Bei diesem Beispiel kann die Merkmalsteuerungskomponente 120 nach Ablauf des Spezialdienstes veranlassen, dass das neue auswählbare Merkmal für den Spezialdienst von der Nutzerschnittstelle der Kundenanwendung entfernt wird und das oder die Standard-Merkmal(e) präsent sind und/oder veranlassen, dass die grafischen Bilder, welche dem Spezialdienst entsprechen, von der Karte der Nutzerschnittstelle der Kundenanwendung entfernt werden sollen.
  • Bei einem anderen Beispiel kann eine Konfigurationsdatei, falls angeschaltet, die einer bestimmten Gruppe von Nutzern zugeordneten Kundenanwendungen veranlassen, Nutzerschnittstellenmerkmale anzuzeigen, die sich von Kundenanwendungen unterscheiden, welche einer anderen Gruppe von Nutzern zugeordnet sind. Die Gruppe von Nutzern kann durch Nutzeridentifikation, Anwendungsidentifikation, E-Mail-Domainnamen, Mobilvorrichtung-Identifikationsnummern etc. identifiziert werden. Die Gruppe von Nutzern kann auch dadurch identifiziert werden, dass die Konten der Nutzer als einer bestimmten Organisation zugehörig oder als Angestellter der den Netzwerkdienst anbietenden Einheit gekennzeichnet sind.
  • Bei einem anderen Anwendungsbeispiel kann das On-Demand-System 110 ferner ermitteln, dass eine Änderung an einem Fahrerauswahlprozess implementiert werden soll, welcher durch das On-Demand-System 110 (und/oder das Vergabesystem) durchgeführt wird. Das On-Demand-System 100 kann feststellen, welche Gruppe von Regeln (die die Weise der Durchführung eines Fahrerauswahlprozesses spezifizieren) in einer bestimmten geografischen Region und/oder hinsichtlich Fahrern und Nutzern in dieser Region angewendet werden soll. Zum Beispiel kann eine Konfigurationsdatei angeben, dass, wenn das Vergabesystem eine Anfrage für einen Transportdienst von einem Nutzer mit einer Kundenvorrichtung 170 in dieser Region erhält (oder eine Anfrage mit Abholort in dieser Region), das Vergabesystem verfügbarer Fahrer identifizieren soll, welche innerhalb einer vorbestimmten Distanz (z. B. drei Meilen) vom Ort der Kundenvorrichtung 170 (oder des angegebenen Abholorts) sind. Das Vergabesystem würde die Änderung nicht in anderen Regionen implementieren, so dass, wenn das Vergabesystem eine Anfrage für einen Transportdienst von einem Nutzer mit einer Kundenvorrichtung 170 in einer anderen geografischen Region erhält (oder eine Anfrage mit Abholort in einer anderen geografischen Region), das Vergabesystem weiterhin verfügbare Fahrer innerhalb der zuvor angegebenen Distanz (z. B. fünf Meilen vom Ort der Kundenvorrichtung 170, der des bestimmten Abholorts) identifizieren kann.
  • Bei einem anderen Beispiel kann eine Konfigurationsdatei angeben, dass das Vergabesystem einen Fahrer aus einer Gruppe von für den Transportdienst verfügbaren Fahrern für einen Nutzer auswählt, indem der Fahrer bestimmt wird, welcher dem Abholort des Nutzers am nächsten ist (z. B. mit der kürzesten Distanz im Vergleich zu anderen verfügbaren Fahrern). Alternativ kann eine Konfigurationsdatei angeben, dass das Vergabesystem einen Fahrer aus einer Gruppe von für den Transportdienst verfügbaren Fahrern für einen Nutzer auswählt, indem der Fahrer bestimmt wird, welcher die kürzeste geschätzte Fahrzeit zu dem Abholort des Nutzers hat, wenn der Fahrerauswahlprozess für den Nutzer durchgeführt wird.
  • HARDWARE-DIAGRAMME
  • 3 ist ein Blockdiagramm, welches ein Computersystem veranschaulicht, auf dem hier beschriebene Beispiele implementiert werden können. Im Kontext der 1 kann das System 100 zum Beispiel mit einem oder mehreren Computersystemen, wie in 3 beschrieben, implementiert werden. Das System 100 kann auch einer Kombination von mehreren Computersystemen, wie in 3 beschrieben, implementiert werden.
  • Bei einer Implementierung umfasst ein Computersystem 300 Verarbeitungsressourcen 310, einen Hauptspeicher 320, einen Lese-Speicher (ROM) 330, eine Speichervorrichtung 340 und eine Kommunikationsschnittstelle 350. Das Computersystem 300 umfasst wenigsten einen Prozessor 310 zur Verarbeitung von Informationen und den Hauptspeicher 320, wie ein Random Access Memory (RAM) oder eine andere dynamische Speichervorrichtung, zum Speichern von Information und durch den Prozessor 310 auszuführenden Instruktionen. Der Hautspeicher 320 kann auch genutzt werden, um temporäre Variablen oder andere Zwischeninformation während der Verarbeitung von Instruktionen durch den Prozessor 310 zu speichern. Das Computersystem 300 kann auch den ROM 330 oder eine andere statische Speichervorrichtung zur Speicherung statischer Informationen und Instruktionen für den Prozessor 310 umfassen. Das Speichervorrichtung 340, z. B. eine Solid-State-Vorrichtung, eine magnetische Disk oder eine optische Disk, dient der Speicherung von Information und Instruktionen. Zum Beispiel kann die Speichervorrichtung 340 einem computerlesbaren Medium entsprechen, welches Merkmalverwaltungs- und Merkmalsteuerungsinstruktionen zur Durchführung von bezüglich 1 bis 2 diskutierten Vorgängen speichert. Bei einem anderen Beispiel kann die Speichervorrichtung 340 Konfigurationsdaten und Nutzerschnittstellendaten speichern, wie bezüglich 1 bis 2 diskutiert.
  • Die Kommunikationsschnittstelle 350 kann dem Computersystem 300 ermöglichen, mit einem oder mehreren Netzwerken 380 (z. B. ein mobiles Telefonnetzwerk) mittels der Netzwerkverbindung (drahtlos und/oder kabelgebunden) zu kommunizieren. Mittels der Netzwerkverbindung kann das Computersystem 300 mit einer Mehrzahl von Vorrichtungen kommunizieren, wie beispielsweise den mobilen Computervorrichtungen der Kunden und Dienstanbietern. Gemäß einigen Beispielen kann das Computersystem 300 eine Änderung ermitteln, welche an einem Attribut des Systems für On-Demand-Dienste implementiert werden soll. Das Computersystem 300 kann mittels der Netzwerkverbindung auch Kunden- und/oder Fahrerinformation 352 von den Kunden- und Fahrervorrichtungen erhalten. Der Prozessor 310 kann die von den Vorrichtungen erhaltene Kunden- und/oder Fahrerinformation 352 (sowie andere Information) nutzen, um ermitteln, an welchen Vorrichtungen die Änderung implementiert werden soll. Der Prozessor 310 kann mittels der Kommunikationsschnittstelle 350 über das Netzwerk 380 Anwendungs-Steuerungen 354 an die jeweiligen Vorrichtungen übermitteln, welche als die Änderung benötigend identifiziert wurden. Die Anwendungs-Steuerungen 354 können z. B. Änderungen veranlassen, welche an einer bestimmten Dienstanwendung auf einem Kundenvorrichtung und/oder einem Fahrervorrichtung implementiert werden.
  • Das Computersystem 300 kann auch ein Anzeigevorrichtung 360, wie einen Röhrenmonitor (CRT), einen LCD-Monitor oder eine Fernsehvorrichtung, zum Anzeigen von Grafiken und Information für einen Nutzer umfassen. Ein Eingabemechanismus 370, wie eine Tastatur mit alphanumerischen Tasten und anderen Tasten, kann an das Computersystem 300 angeschlossen werden, um Information und die Auswahl von Instruktionen an den Prozessor 310 zu übermitteln. Andere, nicht einschränkende, veranschaulichende Beispiele von Eingabemechanismen 370 umfassen eine Maus, einen Trackball, einen berührungsempfindlichen Monitor oder Pfeiltasten zum Kommunizieren von Richtungsinformation und Befehlsauswahlen an den Prozessor 310 und zum Steuern der Bewegung eines Cursors auf dem Display 360.
  • Hier beschriebene Beispiele betreffen die Nutzung des Computersystems 300 zum Implementieren von hier beschriebenen Techniken. Gemäß einem Beispiel werden diese Techniken durch das Computersystem 300 in Antwort darauf durchgeführt, dass der Prozessor eine oder mehrere Sequenzen einer oder mehrerer Instruktionen ausführt, welche in dem Hauptspeicher 320 einhalten sind, wie Merkmalverwaltungs- und Merkmalsteuerungsinstruktionen. Solche Instruktionen können von einem anderen maschinenlesbaren Medium, wie beispielsweise der Speichervorrichtung 340, in den Hauptspeicher 320 gelesen werden. Ausführen der Sequenzen von Instruktionen aus dem Hauptspeicher 320 veranlasst den Prozessor 310 die hier beschriebenen Verfahrensschritte durchzuführen. Bei alternativen Implementierungen können anstatt oder in Kombination mit Software-Instruktionen fest verdrahtete Schaltungen genutzt werden, um die hier beschriebenen Beispiel zu implementieren. Somit sind die beschriebenen Beispiele nicht auf eine bestimmte Kombination von Hardwareschaltungen und Software beschränkt.
  • 4 ist ein Blockdiagram, welches eine mobile Computervorrichtung veranschaulicht, auf dem hier beschriebene Beispiele implementiert werden können. Bei einem Beispiel kann eine mobile Computervorrichtung 400 einer mobilen Computervorrichtung, wie einer Mobilfunkvorrichtung mit Telefonie-, Nachrichten- und Datendienst-Fähigkeiten, entsprechen. Die mobile Computervorrichtung kann eine Kundenvorrichtung oder einer Fahrervorrichtung entsprechen. Beispiele solcher Vorrichtungen umfassen Smartphones, Handvorrichtungen oder Tablet-Vorrichtungen für Mobilfunknetze. Die mobile Computervorrichtung 400 umfasst einen Prozessor 410, Speicherressourcen 420, eine Anzeigevorrichtung 430 (z. B. als berührungsempfindliche Anzeigevorrichtung), ein oder mehrere Kommunikations-Untersysteme 440 (umfassend drahtlose Kommunikations-Untersysteme), Eingabemechanismen 450 (z. B. kann ein Eingabemechanismus die berührungsempfindliche Display-Vorrichtung umfassen oder eine Teil davon sein) und einen oder mehrere Ortsbestimmungsmechanismen (z. B. GPS-Komponente) 460. Bei einem Beispiel sendet und empfängt wenigstens eines der Kommunikations-Untersysteme 440 mobile Daten über Daten- und Sprachkanäle.
  • Der Prozessor 410 ist mithilfe von Software und/oder anderer Logik dazu ausgelegt, einen oder mehrere Verfahren, Schritte und andere Funktionen auszuführen, welche bei den in 1 bis 2 beschriebenen Implementierungen und andernorts in der Anmeldung beschrieben sind. Der Prozessor 410 ist mittels in den Speicherressourcen 420 gespeicherten Instruktionen und Daten dazu ausgelegt, eine bestimmte Dienstanwendung auszuführen, wie in 12 beschrieben. Zum Beispiel können Instruktionen zum Betrieb der bestimmten Dienstanwendung zum Anzeigen von Nutzerschnittstellen 415 in den Speicherressourcen 420 der mobilen Computervorrichtung 400 gespeichert sein.
  • Ein Kunde oder Dienstanbieter kann zum Beispiel eine jeweilige mobile Computervorrichtung (wie die mobile Computervorrichtung 400) betreiben, um die bestimmte Kunden- bzw. Anbieteranwendung auszuführen. Die GPS-Komponente 460 kann Ortsinformation ermitteln, wie die derzeitige Ortsinformation der Computervorrichtung 400. Die Ortsinformation 465 kann drahtlos an das System für On-Demand-Dienste über die Kommunikations-Untersysteme 440 periodisch und/oder als Teil einer Statusnachricht übertragen werden. Zum Beispiel kann Information über die mobile Computervorrichtung 400, welche Ortsinformation 465, einen Vorrichtungstyp, eine mit der Vorrichtung verknüpfte Nutzeridentifikation und oder eine Versionsinformation für die bestimmte Dienstanwendung umfassen kann, periodisch an das System für On-Demand-Dienste übertragen werden. Zusätzlich kann ein Dienstanbieter Statusnachrichten (nicht in 4 gezeigt) für das System für On-Demand-Dienste bereitstellen, um beispielsweise anzuzeigen, dass er oder sie für das Anbieten von Diensten verfügbar ist (zum Beispiel Dienst hat) oder dass er oder sie eine Dienstleistung abgeschlossen hat und untätig ist.
  • Das System für On-Demand-Dienste kann die Information von der mobilen Computervorrichtung 400 erhalten, und, wenn das System feststellt, dass eine Änderung an einem Attribut des Systems für On-Demand-Dienste, wie an der auf der mobilen Computervorrichtung 400 gespeicherten bestimmten Dienstanwendung, implementiert werden soll, kann das System die Anwendungssteuerung 445 über die Kommunikations-Untersysteme 440 an die mobile Computervorrichtung 400 übertragen. Der Prozessor 410 kann die Anwendungssteuerung 445 verarbeiten, welche eine an der bestimmten Dienstanwendung zu implementierende Änderung (zum Beispiel das An- oder Abschalten eines Nutzerschnittstellenmerkmals der Dienstanwendung, Bereitstellen für einen Nutzer einer anderen Option welche vor der Änderung nicht verfügbar war etc.) veranlassen kann.
  • Zum Beispiel kann der Prozessor 410 eine Vielzahl von Inhalten für das Display 430 bereitstellen indem Instruktionen und/oder Anwendungen ausgeführt werden, welche in den Speicherressourcen 420 gespeichert sind. Eine oder mehrere Nutzerschnittstellen 415 können durch den Prozessor 410 bereitgestellt werden, wie beispielsweise eine Nutzerschnittstelle für die Dienstanwendungen. Die Änderung kann an einer Nutzerboberfläche 415 implementiert werden, Obwohl 4 für eine mobiles Computervorrichtung dargestellt ist, können ein oder mehrere Beispiele auf anderen Typen von Vorrichtungen implementiert sein, darunter vollfunktionale Computer, wie Laptops oder Desktop Computer (zum Beispiel PC).
  • Es ist vorgesehen, dass hier beschriebene Beispiele sich auf hier beschriebene einzelne Elemente und Konzepte erstrecken, unabhängig von anderen Konzepten, Ideen oder Systemen, sowie auf Beispiele, die Kombinationen von hier beschriebenen Elementen umfassen. Obwohl Bespiele im Detail hier mit Bezug auf die Figuren beschrieben sind, ist vorgesehen, dass die Konzepte nicht auf diese genauen Beispiele beschränkt sind. Dementsprechend ist vorgesehen, dass der Umfang der Konzepte durch die folgenden Ansprüche und deren Äquivalente definiert ist. Ferner ist vorgesehen, dass ein bestimmtes Beispiel, welches entweder einzeln oder als Teil eines Beispiels beschrieben ist, mit anderen einzeln beschriebenen Merkmalen oder als Teil von anderen Beispielen kombiniert werden kann, selbst wenn die anderen Merkmalen und Beispiel dieses bestimmte Merkmal nicht erwähnen. Somit soll das Fehlen einer Beschreibung von Kombinationen nicht das Recht auf solche Kombination ausschließen.

Claims (19)

  1. Ein Computersystem, umfassend: Einen oder mehrere Prozessoren, ausgelegt zum: Ermitteln einer Änderung, welche an einem Attribut eines Netzwerkdienstes zu implementiert ist, wobei das Attribut einer bestimmten Anwendung entspricht, welche einzelne Nutzer auf jeweiligen Computervorrichtungen betreiben können, um den Netzwerkdienst zu nutzen; Erhalten von Information, welche dieser Computervorrichtung von der auf dieser Computervorrichtung betriebenen bestimmten Anwendung zugeordnet ist, von jeder einer Mehrzahl von Computervorrichtungen, wobei die bestimmte Anwendung in Kommunikation mit dem Computersystem steht, wobei die Information wenigstens eine aktuelle Ortsinformation dieser Computervorrichtung umfasst; und basierend auf der von jeder der Mehrzahl von Computervorrichtungen erhaltenen Information, automatisches Implementieren der Änderung an jeder von einer ersten Gruppe von bestimmten Anwendungen, welche auf einer ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, wobei die Änderung an einer zweiten Gruppe von bestimmten Anwendungen, welche auf einer zweiten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, aber nicht implementiert wird, wobei der eine oder die mehreren Prozessoren die Änderung automatisch implementieren durch (i) Ermitteln eines dem Attribut zugeordneten Nutzerschnittstellenmerkmals und (ii) Veranlassen jeder bestimmten Anwendung, welche auf jeder der ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben wird, das bestimmte Nutzerschnittstellenmerkmal einer durch diese bestimmte Anwendung bereitgestellten Nutzerschnittstelle hinzuzufügen oder zu entfernen.
  2. Das Computersystem gemäß Anspruch 1, wobei das Computersystem dazu ausgelegt ist, über eines oder mehrere Netzwerke mit einem Merkmalsanbietersystem (i) periodisch, (ii) in Antwort auf den Erhalt einer Nutzereingabe oder (iii) unter Verwendung eines Push-Protokolls über eine dauerhafte Verbindung zu kommunizieren.
  3. Das Computersystem gemäß Anspruch 1, wobei der eine oder die mehreren Prozessoren dazu auslegt ist bzw. sind, die an dem Attribut des Netzwerkdienstes zu implementierende Änderung durch Zugriff auf eine Konfigurationsdatenbank zu ermitteln, wobei die Konfigurationsdatenbank eine Mehrzahl von Konfigurationsdateien umfasst, welche jeweils einem Attribut des Netzwerkdienstes entsprechen.
  4. Das Computersystem gemäß Anspruch 1, wobei der eine oder die mehreren Prozessoren dazu ausgelegt ist bzw. sind, die an dem Attribut des Netzwerkdienstes zu implementierende Änderung durch (i) Kommunizieren über eines oder mehrere Netzwerke mit einem Merkmalsanbietersystem, welches eine Konfigurationsdatenbank unterhält, wobei die Konfigurationsdatenbank eine Mehrzahl von Konfigurationsdateien umfasst, welche jeweils einem Attribut des Netzwerkdienstes entsprechen, und durch (ii) Identifizieren einer Konfigurationsdatei, die die Änderung an dem Attribut anweist, zu ermitteln.
  5. Das Computersystem gemäß Anspruch 4, wobei die Konfigurationsdatei angibt, dass die Änderung an dem Attribut für diejenigen bestimmten Anwendungen zu implementieren ist, welche auf Computervorrichtungen innerhalb einer bestimmten geografischen Region betrieben werden.
  6. Das Computersystem gemäß Anspruch 4, wobei die Konfigurationsdatei angibt, dass die Änderung an dem Attribut für diejenigen bestimmten Anwendungen zu implementieren ist, welche auf Computervorrichtungen innerhalb einer bestimmten geografischen Region für eine bestimmte Zeitdauer betrieben werden, und ferner umfassend: wobei der eine oder die mehreren Prozessoren dazu ausgelegt ist bzw. sind, nach der bestimmten Zeitdauer, eine zweite Änderung an jeder der ersten Gruppe von bestimmten Anwendungen, welche auf der ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, automatisch zu implementieren, um zu veranlassen, dass die durch diese bestimmte Anwendung bereitgestellte Nutzerschnittstelle zu einem vorherigen Zustand vor der Änderung zurückkehrt.
  7. Das Computersystem gemäß Anspruch 3, wobei jede der Mehrzahl von Konfigurationsdateien durch einen Nutzer des Merkmalsanbietersystems konfigurierbar ist.
  8. Das Computersystem gemäß Anspruch 3, wobei die von jedem der Mehrzahl von Computervorrichtungen erhaltene Information ferner wenigstens eines des Folgenden (i) einen Vorrichtungstyp der jeweiligen Computervorrichtung, (ii) eine der jeweiligen Computervorrichtung zugeordnete Nutzeridentifikation oder (iii) eine Versionsinformation für die auf der jeweiligen Computervorrichtung betriebene bestimmte Anwendung umfasst.
  9. Das Computersystem gemäß Anspruch 1, wobei der Netzwerkdienst einem Transportvermittlungssystem entspricht und wobei das dem Attribut zugeordnete Nutzerschnittstellenmerkmal einem ersten grafischen Bild entspricht, und wobei jede auf jeder der ersten Gruppe der Mehrzahl von Computervorrichtungen betriebene bestimmte Anwendung das erste grafische Bild auf der von dieser bestimmten Anwendung bereitgestellten Nutzerschnittstelle anzeigt und jede auf jeder der zweiten Gruppe der Mehrzahl von Computervorrichtungen betriebene bestimmte Anwendung ein anderes zweites grafisches Bild auf der von dieser bestimmten Anwendung bereitgestellten Nutzerschnittstelle anzeigt
  10. Ein Computersystem, umfassend: Einen oder mehrere Prozessoren, ausgelegt zum: Ermitteln, an dem Computersystem, einer Änderung an einem Attribut des Transportvermittlungsdienstes, wobei das Attribut einem Fahrerauswahlprozess entspricht, welcher durch den Transportvermittlungsdient für Nutzer innerhalb einer bestimmten Region genutzt wird; Erhalten von Information, welche dieser Computervorrichtung zugeordnet ist von einer bestimmten Anwendung, welche auf diesem Computervorrichtung betrieben wird, von jedem einer Mehrzahl von Computervorrichtungen, wobei die bestimmte Anwendung in Kommunikation mit dem Computersystem steht, wobei die Information wenigstens eine aktuelle Ortsinformation dieses Computervorrichtung umfasst; und Basierend auf der von jedem der Mehrzahl von Computervorrichtungen erhaltenen Information, automatischen Implementieren der Änderung an dem Fahrerauswahlprozess, so dass eine Gruppe der Mehrzahl von Computervorrichtungen, welche sich in der bestimmten Region befinden, einer ersten Gruppe von mit dem Fahrerauswahlprozess verknüpften Regeln unterzogen werden, im Vergleich zu einer vorherigen anderen Gruppe von dem Fahrerauswahlprozess zugeordneten Regeln, wobei die erste Gruppe von Regeln eine Weise angeben, in der das Computersystem einen Fahrer für einen anfragenden Nutzer dieser bestimmten Region auswählt.
  11. Das Computersystem gemäß Anspruch 10, wobei das Computersystem dazu ausgelegt ist über eines oder mehrere Netzwerke mit einem Merkmalsanbietersystem (i) periodisch, (ii) in Antwort auf den Erhalt einer Nutzereingabe, oder (iii) mithilfe eines Push-Protokolls über eine dauerhafte Verbindung zu kommunizieren.
  12. Das Computersystem gemäß Anspruch 10, wobei der eine oder die mehreren Prozessoren dazu auslegt ist bzw. sind, die an dem Attribut des Netzwerkdienstes zu implementierende Änderung durch Zugriff auf eine Konfigurationsdatenbank zu ermitteln, wobei die Konfigurationsdatenbank eine Mehrzahl von Konfigurationsdateien umfasst, welche jeweils einem Attribut des Netzwerkdienstes entsprechen.
  13. Das Computersystem gemäß Anspruch 10, wobei der eine oder die mehreren Prozessoren dazu ausgelegt ist bzw. sind, die an dem Attribut des Netzwerkdienstes zu implementierende Änderung durch (i) Kommunizieren über eines oder mehrere Netzwerke mit einem Merkmalsanbietersystem, welches eine Konfigurationsdatenbank unterhält, wobei die Konfigurationsdatenbank eine Mehrzahl von Konfigurationsdateien umfasst, welche jeweils einem Attribut des Netzwerkdienstes entsprechen, und durch (ii) Identifizieren einer Konfigurationsdatei, welche die Änderung an dem Attribut anweist, zu bestimmen
  14. Das Computersystem gemäß Anspruch 13, wobei die Konfigurationsdatei angibt, dass die Änderung an dem Attribut für diejenigen bestimmten Anwendungen zu implementieren ist, welche auf Computervorrichtungen innerhalb einer bestimmten geografischen Region betrieben werden.
  15. Das Computersystem gemäß Anspruch 13, wobei die Konfigurationsdatei angibt, dass die Änderung an dem Attribut für diejenigen bestimmten Anwendungen zu implementieren ist, welche auf Computervorrichtungen innerhalb einer bestimmten geografischen Region für eine bestimmte Zeitdauer betrieben werden, und ferner umfassend: nach der bestimmten Zeitdauer, eine zweite Änderung an jedem der ersten Gruppe von bestimmten Anwendungen, welche auf der ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben werden, automatisch zu implementieren, um zu veranlassen, dass die durch diese bestimmte Anwendung bereitgestellte Nutzerschnittstelle zu einem vorherigen Zustand vor der Änderung zurückkehrt.
  16. Das Computersystem gemäß Anspruch 12, wobei jede der Mehrzahl von Konfigurationsdateien durch einen Nutzer des Merkmalsanbietersystems konfigurierbar ist.
  17. Das Computersystem gemäß Anspruch 12, wobei die von jedem der Mehrzahl von Computervorrichtungen erhaltene Information ferner wenigstens eines des Folgenden (i) einen Vorrichtungstyp der jeweiligen Computervorrichtung, (ii) eine der jeweiligen Computervorrichtung zugeordnete Nutzeridentifikation, oder (iii) eine Versionsinformation für die auf dem jeweiligen Computervorrichtung betriebene bestimmte Anwendung umfasst.
  18. Ein nicht-flüchtiges computerlesbares Medium, welches Instruktionen speichert, die, wenn sie durch einen oder mehrere Prozessoren eines Computersystems ausgeführt werden, das Computersystem veranlassen, Funktionen auszuführen, welche umfassen: Ermitteln, an dem Computersystem, einer Änderung an einem Attribut eines Transportdienstvermittlungsdienstes, wobei das Attribut einer bestimmten Anwendung entspricht, welche einzelne Nutzer auf jeweiligen Computervorrichtungen betreiben können, um den Netzwerkdienst zu nutzen; Erhalten von Information, welche dieser Computervorrichtung zugeordnet ist von einer bestimmten Anwendung, die auf diesem Computervorrichtung betrieben wird, von jedem einer Mehrzahl von Computervorrichtungen, wobei die bestimmte Anwendung in Kommunikation mit dem Computersystem steht, wobei die Information wenigstens eine derzeitige Ortsinformation dieses Computervorrichtung umfasst; und Basierend auf der von jedem der Mehrzahl von Computervorrichtungen erhaltenen Information, automatisches Implementieren der Änderung an jeder von einer ersten Gruppe von bestimmten Anwendungen, welche auf einer ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben wird, wobei die Anwendung an einer zweiten Gruppe von bestimmten Anwendungen, welche auf einer zweiten Gruppe der Mehrzahl von Computervorrichtungen betrieben wird, aber nicht implementiert wird, wobei Implementieren der Änderung umfasst (i) Bestimmen eines dem Attribut zugeordneten Nutzerschnittstellenmerkmals und (ii) Veranlassen jeder bestimmter Anwendung, welche auf jedem der ersten Gruppe der Mehrzahl von Computervorrichtungen betrieben wird, das bestimmte Nutzerschnittstellenmerkmal einer durch diese bestimmte Anwendung bereitgestellte Nutzerschnittstelle hinzuzufügen oder zu entfernen.
  19. Das nicht-flüchtige computer-lesbare Medium gemäß Anspruch 18, wobei Bestimmen der an dem Attribut des Netzwerkdienstes zu implementierende Änderungen umfasst: Zugreifen auf eine Mehrzahl von Konfigurationsdateien, welche jeweils einem Attribut des Netzwerkdienstes entsprechen.
DE202015002394.0U 2014-03-31 2015-03-31 Einstellen von Attributen für ein System für On-Demand-Dienste basierend auf Echtzeitinformation Active DE202015002394U1 (de)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US201461973154P 2014-03-31 2014-03-31
US61/973,154 2014-03-31
US14/671,480 US9888087B2 (en) 2014-03-31 2015-03-27 Adjusting attributes for an on-demand service system based on real-time information
US14/671,480 2015-03-27

Publications (1)

Publication Number Publication Date
DE202015002394U1 true DE202015002394U1 (de) 2015-07-16

Family

ID=53008993

Family Applications (1)

Application Number Title Priority Date Filing Date
DE202015002394.0U Active DE202015002394U1 (de) 2014-03-31 2015-03-31 Einstellen von Attributen für ein System für On-Demand-Dienste basierend auf Echtzeitinformation

Country Status (3)

Country Link
US (4) US9888087B2 (de)
AU (1) AU2015100404A4 (de)
DE (1) DE202015002394U1 (de)

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9888087B2 (en) 2014-03-31 2018-02-06 Uber Technologies, Inc. Adjusting attributes for an on-demand service system based on real-time information
US11086771B2 (en) * 2015-10-13 2021-08-10 Apptimize Llc Dynamic management and control of test features in native applications
CN106657189A (zh) * 2015-11-02 2017-05-10 天脉聚源(北京)科技有限公司 一种微信摇一摇应用推送方法及系统
US9939279B2 (en) 2015-11-16 2018-04-10 Uber Technologies, Inc. Method and system for shared transport
US11176500B2 (en) 2016-08-16 2021-11-16 Teleport Mobility, Inc. Interactive real time system and real time method of use thereof in conveyance industry segments
US11182709B2 (en) 2016-08-16 2021-11-23 Teleport Mobility, Inc. Interactive real time system and real time method of use thereof in conveyance industry segments
US11087252B2 (en) 2016-08-16 2021-08-10 Teleport Mobility, Inc. Interactive real time system and real time method of use thereof in conveyance industry segments
US9813510B1 (en) 2016-09-26 2017-11-07 Uber Technologies, Inc. Network system to compute and transmit data based on predictive information
US9898791B1 (en) 2017-02-14 2018-02-20 Uber Technologies, Inc. Network system to filter requests by destination and deadline
US11797937B2 (en) 2018-02-26 2023-10-24 Mark Lamoncha System and method for hiring and authenticating persons to perform services on a temporary basis
US11093100B2 (en) * 2018-03-08 2021-08-17 Microsoft Technology Licensing, Llc Virtual reality device with varying interactive modes for document viewing and editing
US11507877B2 (en) * 2019-03-13 2022-11-22 Autodesk, Inc. Application functionality optimization
US11526337B2 (en) * 2021-02-26 2022-12-13 Atlassian Pty Ltd. Systems and methods for consistent feature flag evaluation

Family Cites Families (173)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4023753A (en) 1974-11-22 1977-05-17 International Standard Electric Corporation Vehicle control system
WO1995027964A1 (en) 1994-04-12 1995-10-19 Qualcomm Incorporated Method and apparatus for freight transportation using a satellite navigation system
US5604676A (en) 1994-07-25 1997-02-18 Lucent Technologies Inc. System and method for coordinating personal transportation
US5945919A (en) 1996-05-30 1999-08-31 Trimble Navigation Limited Dispatcher free vehicle allocation system
CA2282294C (en) 1996-10-21 2009-12-08 Orissa, Inc. Transportation network system
IL123420A0 (en) 1998-02-24 1998-09-24 Jaffe Shai Request dispatch system
US20020194129A1 (en) 1999-04-08 2002-12-19 Hitachi, Ltd. IC card reader/writer
FI991411A (fi) 1999-06-21 2000-12-22 Nokia Networks Oy Mikroprosessorin alkulatausohjelmiston päivittäminen
US6212393B1 (en) 1999-08-02 2001-04-03 Motorola, Inc. Method and apparatus for communication within a vehicle dispatch system
US6756913B1 (en) 1999-11-01 2004-06-29 Mourad Ben Ayed System for automatically dispatching taxis to client locations
US6587851B1 (en) 1999-12-22 2003-07-01 Bellsouth Intellectual Property Corporation Notification system and method
US6516056B1 (en) 2000-01-07 2003-02-04 Vesta Corporation Fraud prevention system and method
US6697730B2 (en) 2000-04-04 2004-02-24 Georgia Tech Research Corp. Communications and computing based urban transit system
US20010056363A1 (en) 2000-06-26 2001-12-27 Gantz Donald T. System for providing ride matching services using e-mail and the internet
US6356838B1 (en) 2000-07-25 2002-03-12 Sunil Paul System and method for determining an efficient transportation route
KR20000063909A (ko) 2000-08-10 2000-11-06 기준성 통신망을 이용한 운송정보 처리시스템과 그 방법
US20020034292A1 (en) 2000-08-22 2002-03-21 Tuoriniemi Veijo M. System and a method to match demand and supply based on geographical location derived from a positioning system
JP2002133592A (ja) 2000-10-24 2002-05-10 Yoshiteru Miyama 配車システム
US6456207B1 (en) 2001-02-20 2002-09-24 John Yen Intelligent taxi total service system
US7080019B1 (en) 2001-03-04 2006-07-18 Ducktrip, Llc Ride share contact system
US6944443B2 (en) 2001-07-11 2005-09-13 International Business Machines Corporation Method, apparatus and system for notifying a user of a portable wireless device
US20030030666A1 (en) 2001-08-07 2003-02-13 Amir Najmi Intelligent adaptive navigation optimization
EP1433109A2 (de) 2001-10-01 2004-06-30 The Boeing Company System zur verwaltung von reiserouten
GB0126809D0 (en) 2001-11-07 2002-01-02 Isaac Stephen J A car-sharing system
US7174547B2 (en) 2002-03-25 2007-02-06 Ciena Corporation Method for updating and restoring operating software in an active region of a network element
US20040049424A1 (en) 2002-06-21 2004-03-11 Murray Thomas A. System and method for facilitating ridesharing
AU2003258018A1 (en) 2002-08-02 2004-02-23 Limoq, Inc. Method, system and apparatus for providing transportation services
US20040104927A1 (en) 2002-09-16 2004-06-03 Husain Syed Mohammad Amir System and method for automatic software retrieval on a peer-to-peer network
US7216343B2 (en) 2002-09-20 2007-05-08 International Business Machines Corporation Method and apparatus for automatic updating and testing of software
US7899862B2 (en) * 2002-11-18 2011-03-01 Aol Inc. Dynamic identification of other users to an online user
US20040107110A1 (en) 2002-12-02 2004-06-03 Jens Gottlieb Optimization of transport with multiple vehicles
GB0302886D0 (en) 2003-02-07 2003-03-12 Faith Jonathan D Transportation ordering system
EP1450321A1 (de) 2003-02-21 2004-08-25 Swisscom Mobile AG Verfahren und System zur Aufdeckung von möglichen Betrügen in Zahlungstransaktionen
JP2004334527A (ja) 2003-05-07 2004-11-25 Intelligent Wave Inc 不正判定のスコア値算出プログラム、不正判定のスコア値算出方法、及びクレジットカードの不正判定スコア値算出システム
US20040260470A1 (en) 2003-06-14 2004-12-23 Rast Rodger H. Conveyance scheduling and logistics system
US6925381B2 (en) 2003-06-24 2005-08-02 Bellsouth Intellectual Property Corporation Methods, systems and computer program products for ride matching based on current location information
EP1494119A1 (de) 2003-06-30 2005-01-05 Thomson Multimedia Broadband Belgium Netzeinrichtung und Verfahren zur Überwachung des Starts von einer solchen Einrichtung
WO2005013588A1 (en) 2003-08-01 2005-02-10 St Electronics (Info-Comm Systems) Pte. Ltd. Automated taxi/vehicle booking and despatching system
JP2005107942A (ja) 2003-09-30 2005-04-21 Fujitsu Ltd 経路案内情報提示プログラムおよび経路案内情報提示システム
US7313682B2 (en) 2004-04-29 2007-12-25 Alcatel Lucent Method and system for updating boot memory that stores a fail-safe reset code and is configured to store boot code and boot updater code
US20060004590A1 (en) 2004-07-02 2006-01-05 Denis Khoo Travel planning for social networks
JP2006040007A (ja) 2004-07-28 2006-02-09 Nobutoshi Umeda タクシー配車システム及び配車方法
US7536486B2 (en) 2004-07-30 2009-05-19 Microsoft Corporation Automatic protocol determination for portable devices supporting multiple protocols
JP2006065857A (ja) 2004-08-24 2006-03-09 Lg Electronics Inc 移動通信端末機のプログラム強制ダウンロード方法及び装置
US20060136254A1 (en) 2004-11-24 2006-06-22 Mark Greenstein System and method for dispatching transportation to persons who want transportation
US20060155591A1 (en) 2005-01-10 2006-07-13 Faheem Altaf Systems, methods, and media for managing a travel itinerary
US8370054B2 (en) 2005-03-24 2013-02-05 Google Inc. User location driven identification of service vehicles
US7624024B2 (en) 2005-04-18 2009-11-24 United Parcel Service Of America, Inc. Systems and methods for dynamically updating a dispatch plan
WO2006128946A1 (en) 2005-05-02 2006-12-07 Ecolane Finland Oy Method and arrangement for arranging practical aspects of a demand responsive transport system
JP2006339810A (ja) 2005-05-31 2006-12-14 Tsubame Kotsu Kyodo Kumiai 配車受付システム
US20060293937A1 (en) 2005-06-24 2006-12-28 Mark Sohm System and method of wireless carpool scheduling
US7908600B2 (en) 2005-06-30 2011-03-15 Oracle International Corporation Fault-tolerant patching system
US9002342B2 (en) * 2005-12-02 2015-04-07 Nokia Corporation System, apparatus, and method for dynamically customizing and configuring applications
US7738891B2 (en) * 2005-12-02 2010-06-15 Nokia Corporation System, apparatus, and method for dynamically configuring application access point settings
US20140172727A1 (en) 2005-12-23 2014-06-19 Raj V. Abhyanker Short-term automobile rentals in a geo-spatial environment
US20070255627A1 (en) 2006-03-03 2007-11-01 Hallowell Zachary E Transport Ordering Systems and Methods
US10520325B2 (en) 2006-05-25 2019-12-31 Rideshark Corporation Method of selective ride-sharing among multiple users along an optimized travel route
US8020149B2 (en) 2006-08-04 2011-09-13 Apple Inc. System and method for mitigating repeated crashes of an application resulting from supplemental code
GB0616257D0 (en) 2006-08-16 2006-09-27 Ibm Storage management system for preserving consistency of remote copy data
US20080091342A1 (en) 2006-10-11 2008-04-17 Jeffrey Assael System and method for ride matching
US20080125964A1 (en) 2006-11-27 2008-05-29 Carani Sherry L Tracking System and Method with Automatic Map Selector And Geo Fence Defining Features
US7870548B2 (en) 2007-01-05 2011-01-11 Inventec Corporation Method for updating an image file
CN101652789A (zh) 2007-02-12 2010-02-17 肖恩·奥沙利文 共享运输系统和服务网络
US7756633B2 (en) 2007-05-11 2010-07-13 Palo Alto Research Center Incorporated System and method for security enhanced rideshare
TW200847021A (en) 2007-05-17 2008-12-01 Asustek Comp Inc Automatic backup, restore and update BIOS computer system
US20080303694A1 (en) * 2007-06-05 2008-12-11 Frank Ury Traffic control system employing location based services
MX2010000881A (es) 2007-07-23 2010-05-19 R & L Carriers Inc Metodos y sistemas de procesamiento y transmision de informacion para transportistas de mercancias.
US20090030885A1 (en) 2007-07-26 2009-01-29 Ridecharge Method and system for on-demand and scheduled services relating to travel and transportation
EP2650783A1 (de) * 2007-08-17 2013-10-16 Salesforce.Com, Inc. Datenbankdienstsytem auf Anfrage, Verfahren und Computerprogrammprodukt zur Überprüfung einer Entwickelten Anwendung auf ihre Ordnungsgemässe Funktionsweise mit Mindestens einer anderen Anwendung
EP3367176B1 (de) 2007-09-04 2022-07-13 Kabushiki Kaisha Toshiba Kartuschengehäuse, tonerkartusche und bilderzeugungsvorrichtung mit tonerkartusche
US8613096B2 (en) 2007-11-30 2013-12-17 Microsoft Corporation Automatic data patch generation for unknown vulnerabilities
TWI359393B (en) 2007-12-03 2012-03-01 Univ Nat Taiwan Vehicle dispatch system
WO2009089182A1 (en) 2008-01-03 2009-07-16 Lubeck Olaf M Method for requesting transportation services
US20090192851A1 (en) 2008-01-25 2009-07-30 Bishop Paul L Location-Based Transportation Management
EP2088550A1 (de) 2008-02-08 2009-08-12 SkiData AG Verfahren zur Bestellung von ortsspezifischen Dienstleistungen
US20090216600A1 (en) 2008-02-27 2009-08-27 Montiss Llc Systems and methods for arranging a transport transaction
US8839227B2 (en) 2008-02-29 2014-09-16 Arris Enterprises, Inc. Preventing overwrite of nonessential code during essential code update
US20090254270A1 (en) 2008-04-02 2009-10-08 O2Micro, Inc. System and method for tracking a path of a vehicle
US9596359B2 (en) 2008-06-26 2017-03-14 Visa International Service Association Mobile communication device configured for transit application
US9519921B2 (en) 2008-06-27 2016-12-13 E-Lantis Corporation GPS and wireless integrated fleet management system and method
US8977567B2 (en) 2008-09-22 2015-03-10 Visa International Service Association Recordation of electronic payment transaction information
US20100153279A1 (en) 2008-09-30 2010-06-17 Walter Zahn Systems and methods for global transportation,vetting, and payment
US20110225269A1 (en) 2008-11-15 2011-09-15 Shong Clement Yap Wee System For Efficient Allocating And Monitoring Of Public Transport
JP2010198155A (ja) 2009-02-24 2010-09-09 Fujitsu Ten Ltd プログラム更新装置、プログラム更新方法、及び情報処理装置
US20100299664A1 (en) * 2009-05-21 2010-11-25 Salesforce.Com, Inc. System, method and computer program product for pushing an application update between tenants of a multi-tenant on-demand database service
US8639787B2 (en) 2009-06-01 2014-01-28 Oracle International Corporation System and method for creating or reconfiguring a virtual server image for cloud deployment
US8856294B2 (en) 2009-06-01 2014-10-07 Oracle International Corporation System and method for converting a Java application into a virtual server image for cloud deployment
US8776053B2 (en) 2009-09-25 2014-07-08 Oracle International Corporation System and method to reconfigure a virtual machine image suitable for cloud deployment
KR101119117B1 (ko) 2009-07-10 2012-03-16 엘지전자 주식회사 차량 호출 방법 및 차량 배차 방법 및 이를 위한 이동 단말기
US10002198B2 (en) 2009-10-28 2018-06-19 Verizon Patent And Licensing Inc. Mobile taxi dispatch system
WO2011066327A1 (en) 2009-11-25 2011-06-03 Cubic Corporation Mobile wireless payment and access
CA2782611C (en) 2009-12-04 2018-07-10 Uber Technologies, Inc. System and method for arranging transport amongst parties through use of mobile devices
US9280605B2 (en) 2010-03-11 2016-03-08 Flightstats, Inc. Systems and methods for itinerary messaging service
US8670933B2 (en) 2010-03-23 2014-03-11 United Parcel Service Of America, Inc. Geofence-based triggers for automated data collection
US8332517B2 (en) * 2010-03-31 2012-12-11 Incnetworks, Inc. Method, computer program, and algorithm for computing network service value pricing based on communication service experiences delivered to consumers and merchants over a smart multi-services (SMS) communication network
US20110251951A1 (en) 2010-04-13 2011-10-13 Dan Kolkowitz Anti-fraud event correlation
US8554608B1 (en) 2010-04-17 2013-10-08 James O'Connor Driver controlled automated taxi service and devices
US20110320794A1 (en) 2010-06-28 2011-12-29 Chung-Jen Yang Flash System And Method For Updating The Flash System
US20120059661A1 (en) 2010-09-02 2012-03-08 Brian Colodny Maintaining and Using a Lost Item Database
US20120072249A1 (en) 2010-09-22 2012-03-22 Mobiata LLC System and method for sending travel information to a wireless mobile device
US20120078672A1 (en) 2010-09-29 2012-03-29 IT Curves LLC Efficient Automated Ride Sharing System
US8566026B2 (en) 2010-10-08 2013-10-22 Trip Routing Technologies, Inc. Selected driver notification of transitory roadtrip events
US8442848B2 (en) 2011-03-09 2013-05-14 David Myr Automatic optimal taxicab mobile location based dispatching system
GB201106555D0 (en) 2011-04-19 2011-06-01 Tomtom Int Bv Taxi dispatching system
US8686852B2 (en) 2011-05-30 2014-04-01 Microsoft Corporation Location-based notification services
AU2012267210A1 (en) 2011-06-09 2013-05-09 Ingogo Pty Ltd Public booking and payment system
US8738529B2 (en) 2011-07-15 2014-05-27 Wal-Mart Stores, Inc. Multi-channel data driven, real-time fraud determination system for electronic payment cards
US20130031001A1 (en) 2011-07-26 2013-01-31 Stephen Patrick Frechette Method and System for the Location-Based Discovery and Validated Payment of a Service Provider
US8943220B2 (en) 2011-08-04 2015-01-27 Microsoft Corporation Continuous deployment of applications
US8898656B2 (en) * 2011-08-29 2014-11-25 Salesforce.Com, Inc. Mechanism for facilitating dynamic format transformation of software applications in an on-demand services environment
US20130073327A1 (en) 2011-09-20 2013-03-21 Benjamin J. Edelberg Urban transportation system and method
US20130102333A1 (en) 2011-10-19 2013-04-25 General Electric Company Systems and methods for dispatching utility repairs
US8768614B2 (en) 2011-12-19 2014-07-01 Sap Ag Increasing throughput for carpool assignment matching
US20130179215A1 (en) 2012-01-10 2013-07-11 Bank Of America Corporation Risk assessment of relationships
US20140156556A1 (en) 2012-03-06 2014-06-05 Tal Lavian Time variant rating system and method thereof
JP5921358B2 (ja) 2012-06-21 2016-05-24 キヤノン株式会社 情報処理装置、プログラム更新方法及びプログラム
US8904162B2 (en) 2012-08-01 2014-12-02 Intel Corporation Methods and apparatus for performing secure BIOS upgrade
US9208397B2 (en) * 2012-08-27 2015-12-08 Paypal, Inc. Codeless QR code
US20140067488A1 (en) 2012-08-30 2014-03-06 Frias Transportation Infrastructure Llc Mobile for-hire-vehicle hailing system and method
JP5972121B2 (ja) 2012-09-07 2016-08-17 キヤノン株式会社 アプリケーション管理システム、管理装置、アプリケーション実行端末、アプリケーション管理方法、アプリケーション実行端末の制御方法及びプログラム
US20140073300A1 (en) * 2012-09-10 2014-03-13 Genband Us Llc Managing Telecommunication Services using Proximity-based Technologies
WO2014049442A1 (en) 2012-09-27 2014-04-03 Aegis Mobility, Inc. Mobile device context incorporating near field communications
US8594850B1 (en) 2012-09-30 2013-11-26 Nest Labs, Inc. Updating control software on a network-connected HVAC controller
CA2889853C (en) 2012-11-08 2017-02-21 Shalin Amin Providing on-demand services through use of portable computing devices
US20140149157A1 (en) 2012-11-27 2014-05-29 GoEuro Corp. Travel planning
US20140156410A1 (en) 2012-11-30 2014-06-05 Ebay Inc. Systems and methods to provide transport aware geofences
GB201300006D0 (en) 2013-01-01 2013-02-13 Tomtom Dev Germany Gmbh Vehicle management system
US20140258894A1 (en) * 2013-03-05 2014-09-11 Research In Motion Limited Visual Timeline Of An Application History
US10521761B2 (en) * 2013-03-12 2019-12-31 United Parcel Service Of America, Inc. Systems and methods of delivering parcels using attended delivery/pickup locations
US10467554B2 (en) 2013-03-14 2019-11-05 Lyft, Inc. System for connecting a driver and a rider
US20170286884A1 (en) 2013-03-15 2017-10-05 Via Transportation, Inc. System and Method for Transportation
US20140279707A1 (en) 2013-03-15 2014-09-18 CAA South Central Ontario System and method for vehicle data analysis
US20140365250A1 (en) 2013-06-05 2014-12-11 Fujitsu Limited Transportation service reservation method and apparatus
WO2014205763A1 (en) 2013-06-28 2014-12-31 Nokia Corporation Method and apparatus for facilitating meeting
US20150032485A1 (en) 2013-07-25 2015-01-29 Mark Nelson Digital method For Providing Transportation Services
GB201314091D0 (en) 2013-08-07 2013-09-18 Smart Ship Holdings Ltd Ordering products/services
US20150095198A1 (en) 2013-09-30 2015-04-02 David Edward Eramian Systems and methods for altering travel routes with a transaction location
US20150161563A1 (en) 2013-12-09 2015-06-11 Crowdshipping, Inc. Systems and Methods for Crowdsourced Shipping
EP3080774A4 (de) 2013-12-11 2017-06-07 Uber Technologies Inc. Optimierung der auswahl von treibern für transportaufträge
US20150176997A1 (en) 2013-12-22 2015-06-25 Andreas Kurt PURSCHE Adaptive transportation framework
US9984574B2 (en) 2014-01-21 2018-05-29 Tribal Rides, Inc. Method and system for anticipatory deployment of autonomously controlled vehicles
WO2015112669A1 (en) 2014-01-22 2015-07-30 Khanna Jahan Systems and methods for providing a transportation marketplace
US9888087B2 (en) 2014-03-31 2018-02-06 Uber Technologies, Inc. Adjusting attributes for an on-demand service system based on real-time information
US9228841B2 (en) 2014-06-02 2016-01-05 Xerox Corporation Methods and systems for determining routes in a navigation system
CN106716066A (zh) 2014-07-22 2017-05-24 莱夫特公司 链式乘坐
US20160104122A1 (en) 2014-10-10 2016-04-14 Bank Of America Corporation Remote video conferencing system
CN105575103A (zh) 2014-10-16 2016-05-11 西安景行数创信息科技有限公司 一种出租车拼车应用系统
US10628758B2 (en) 2014-10-28 2020-04-21 Fujitsu Limited Transportation service reservation method, transportation service reservation apparatus, and computer-readable storage medium
US10197410B2 (en) 2014-11-18 2019-02-05 International Business Machines Corporation Dynamic real-time carpool matching
US10083448B2 (en) 2014-12-19 2018-09-25 Sap Se System and method for intermediary agency to find better service providers
US9575837B2 (en) 2015-02-03 2017-02-21 Uber Technologies, Inc. System and method for introducing functionality to an application for use with a network service
US10282684B2 (en) 2015-02-26 2019-05-07 Uber Technologies, Inc. Performing selective operations based on mobile device locations
US20160334232A1 (en) 2015-05-11 2016-11-17 General Motors, Llc Real-time carpooling
US9904900B2 (en) 2015-06-11 2018-02-27 Bao Tran Systems and methods for on-demand transportation
US10984498B2 (en) 2015-06-15 2021-04-20 International Business Machines Corporation Managing transportation deployment using customer activity
US10158528B2 (en) 2015-10-13 2018-12-18 Uber Technologies, Inc. Application service configuration system
US10467561B2 (en) 2015-11-05 2019-11-05 Gt Gettaxi Limited System for identifying events and preemptively navigating drivers to transport passengers from the events
US9939279B2 (en) 2015-11-16 2018-04-10 Uber Technologies, Inc. Method and system for shared transport
US20170169366A1 (en) 2015-12-14 2017-06-15 Google Inc. Systems and Methods for Adjusting Ride-Sharing Schedules and Routes
US9953389B2 (en) 2015-12-29 2018-04-24 Gt Gettaxi Limited System for preemptively navigating drivers to passengers based on passenger device activity
US10379533B2 (en) 2016-01-04 2019-08-13 GM Global Technology Operations LLC System and method for autonomous vehicle fleet routing
US10282681B2 (en) 2016-02-03 2019-05-07 Operr Technologies, Inc. System and method for customizable prescheduled dispatching for transportation services
US10395333B2 (en) 2016-06-07 2019-08-27 Uber Technologies, Inc. Hierarchical selection process
US20170365030A1 (en) 2016-06-21 2017-12-21 Via Transportation, Inc. Systems and Methods for Vehicle Ridesharing Management
US20180018683A1 (en) 2016-07-18 2018-01-18 Airbnb, Inc. Demand Prediction for Time-Expiring Inventory
US9813510B1 (en) 2016-09-26 2017-11-07 Uber Technologies, Inc. Network system to compute and transmit data based on predictive information
US10325442B2 (en) 2016-10-12 2019-06-18 Uber Technologies, Inc. Facilitating direct rider driver pairing for mass egress areas
US9898791B1 (en) 2017-02-14 2018-02-20 Uber Technologies, Inc. Network system to filter requests by destination and deadline
US20190340554A1 (en) 2018-05-07 2019-11-07 Microsoft Technology Licensing, Llc Engagement levels and roles in projects
US11537953B2 (en) 2018-11-29 2022-12-27 Here Global B.V. Method and apparatus for proactive booking of a shared vehicle
US11829904B2 (en) 2019-09-27 2023-11-28 Uber Technologies, Inc. On-demand transport selection process based on pick-up/drop-off zone utilization
MX2022004989A (es) 2019-10-28 2022-07-21 Abraxis Bioscience Llc Composiciones farmaceuticas de albumina y rapamicina.
WO2020098829A2 (en) 2020-01-13 2020-05-22 Alipay (Hangzhou) Information Technology Co., Ltd. Method and system for personalizing offers

Also Published As

Publication number Publication date
US10887411B2 (en) 2021-01-05
US20150281387A1 (en) 2015-10-01
US20210152652A1 (en) 2021-05-20
US12010192B2 (en) 2024-06-11
US20180159946A1 (en) 2018-06-07
AU2015100404A4 (en) 2015-05-07
US11503133B2 (en) 2022-11-15
US20220329670A1 (en) 2022-10-13
US9888087B2 (en) 2018-02-06

Similar Documents

Publication Publication Date Title
DE202015002394U1 (de) Einstellen von Attributen für ein System für On-Demand-Dienste basierend auf Echtzeitinformation
DE102017121758A1 (de) Intelligente Assistenz für wiederholte Aktionen
DE102008058862B4 (de) Medien-Empfehlungs- und Beschaffungs-System
DE202012012895U1 (de) Benutzerendgerät, Serversystem sowie Datenspeichermedium welche ein Teilen von Inhalt zwischen mehreren Geräten ermöglichen
DE112016000805T5 (de) Techniken zum Implementieren von ortsbasierten Vorrichtungsdiensten
DE112018002633T5 (de) Standortbasierte Verwaltung von Dienstzonen für eine geografische Region
DE112018002636T5 (de) Verwaltung standortbezogener Dienstzonen für mehrere Anbieter
DE112016005473T5 (de) Verfahren zur standortbezogenen Werbung und System dafür
DE102012220390A1 (de) Verwenden des geografischen Ortes zum Ermitteln von Element- und Gebietsdaten zum Bereitstellen an eine Datenverarbeitungseinheit
DE202014010950U1 (de) Das Anzeigen von dynamischen Inhalten auf einer Karte auf Basis des Standorts des Benutzers und der geplanten Aufgabe
DE102016107273A1 (de) Systeme und verfahren zur verbesserung der privatsphäre in verbindung mit standortbasierten diensten
DE102013206354A1 (de) Adaptive Bewertung der Objektrelevanz auf der Grundlage dynamischer Benutzereigenschaften
DE112018008127T5 (de) Verfahren und vorrichtung zum mappen von network-slices auf netzinfrastrukturen mit sla-garantie
DE202014010904U1 (de) Benachrichtigungsmodul
DE102016007400A1 (de) Techniken zum Evaluieren von Anwendungen durch die Verwendung einer Hilfsanwendung
DE202012012333U1 (de) Verwaltung einer Anwendungsausführung und eines Datenzugriffs auf einer Vorrichtung
DE102016124464A1 (de) Navigations-anwendungsprogrammierungsschnittstelle
DE112021000619T5 (de) Adaptive zustandsverwaltung für statusunabhängige services
DE202013005673U1 (de) Stapelverarbeitete Aktivitätsstrom-Aktualisierungen
CN106716467A (zh) 针对多身份应用的策略应用
DE112020005326T5 (de) Erzeugen eines skalierungsplans für externe systeme während eines cloud-tenant-onboardings/offboardings
DE102015108724A1 (de) Verfahren und Gerät zum Verwalten von temporärem Inhalt auf einem mobilen Gerät
DE112014005183T5 (de) Speicherdienstnetz
DE102021124620B4 (de) Proaktives auswählen von virtual-reality-inhaltskontexten
DE112011106057T5 (de) Energieeffiziente Abfrageoptimierung

Legal Events

Date Code Title Description
R207 Utility model specification
R150 Utility model maintained after payment of first maintenance fee after three years
R151 Utility model maintained after payment of second maintenance fee after six years
R152 Utility model maintained after payment of third maintenance fee after eight years