Hem Personliga finanser Räkna objekt i en dataström - dummies

Räkna objekt i en dataström - dummies

Video: Räkna med x i omkrets av objekt! 2024

Video: Räkna med x i omkrets av objekt! 2024
Anonim

Att lära dig att räkna objekt i en ström kan hjälpa dig att hitta de vanligaste föremålen eller rangordna vanliga och ovanliga händelser. Denna algoritm utnyttjar hashfunktioner och approximativa skisser. Det gör det efter att ha filtrerat duplicerade objekt och räknat med separata element som har dykt upp i dataströmmen.

Du använder den här tekniken för att lösa problem som att hitta de vanligaste frågorna i en sökmotor, de bästsäljande föremålen från en online-återförsäljare, de populäraste sidorna på en webbplats eller de mest flyktiga bestånden (genom att räkna hur många gånger en aktie är såld och köpt).

Du tillämpar lösningen på detta problem, Count-Min Sketch, till en dataström. Det kräver bara ett datapass och lagrar så lite information som möjligt. Denna algoritm tillämpas i många verkliga situationer (t.ex. analys av nätverkstrafik eller hantering av distribuerade dataflöden). Receptet kräver att man använder en massa hashfunktioner, var och en i samband med en bitvektor, på ett sätt som liknar ett Bloom-filter, som visas i figuren:

  1. Initiera alla bitvektorer till nollor i alla positioner.
  2. Använd hashfunktionen för varje bitvektor när du tar emot ett objekt från en ström. Använd den resulterande numeriska adressen för att öka värdet vid den positionen.
  3. Applicera hash-funktionen på ett objekt och hämta värdet i tillhörande position när du uppmanas att uppskatta frekvensen för ett objekt. Av alla värden som tas emot från bitvektorerna tar du det minsta som frekvensen av strömmen.

Hur värden uppdateras i en Count-Min Sketch.

Eftersom kollisioner alltid är möjliga när en hashfunktion används, speciellt om den associerade bitvektorn har få slitsar, så har flera bitvektorer till hands dig att minst en av dem håller rätt värde. Valet av valet ska vara det minsta eftersom det inte blandas med falska positiva räkningar på grund av kollisioner.

Räkna objekt i en dataström - dummies

Redaktörens val

Hur man lägger till text i en sätter () Funktion i C Programmering

Hur man lägger till text i en sätter () Funktion i C Programmering

När du behöver visa en annan textrad, använd C-programmeringsfärdigheterna för att skapa en annan puts () -funktion i källkoden, som visas i Visa två textlinjer. VISA TILL TEXTFINER # inkludera int main () {sätter ("Hickory, Dickory, Dock,"); sätter ("musen sprang klockan."); returnera (0);} Den andra ...

Förklarar variabler i C-dummies

Förklarar variabler i C-dummies

Variabler är det som gör dina program zooma. Programmering kan bara inte bli gjort utan dem. Så om du inte har introducerats till variabler än, här går du. Valerie Variable är en numerisk variabel. Hon älskar att hålla nummer - vilket nummer som helst; det spelar ingen roll. När hon ser ett lika tecken tar hon ett värde och ...

Redaktörens val

Gör rädsla för din vän - dummies

Gör rädsla för din vän - dummies

Rädsla är lika verklig som mod. Även om värdet av rädsla inte är lika uppenbart som modets värde, har det dess fördelar. Rädsla är din instinkt som säger att du är obehaglig - även om situationen inte kommer att skada dig. Alla har haft den känslan när man hellre drar locket ...

Hur man ökar din självmedvetenhet - dummies

Hur man ökar din självmedvetenhet - dummies

Du kommer att vara med dig själv under en livstid. Ingenting kommer att förändra det faktum. Att lära känna, som att lyssna på och uppskatta själv är avgörande för din sanity. Kanske kommer du till att älska, acceptera och omfamna alla du är, är svår för dig att föreställa dig just nu, men du kan göra ...

Hur man ökar din mentala flexibilitet - dummies

Hur man ökar din mentala flexibilitet - dummies

ÄR flexibel i arbete och relationer är ett tecken på en högpresterande. Medan perfektionister är styva och obehagliga i sitt arbete och hur de interagerar med andra, är högpresterande mer öppna och tillmötesgående. Att vara mer flexibel på jobbet gav Ralph aldrig förslag under brainstorming vid gruppmöten. Han kände att hans lag ...

Redaktörens val

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Linux är i sig ett kommandoradsorienterat operativsystem. Grafiska användargränssnitt - inklusive installationsprogrammets GUI - tillhandahålls av en valfri komponent som heter X Window System. Men medan du arbetar med det grafiska användargränssnittet för installationsprogrammet, håller Linux flera ytterligare kommandorads-konsoler öppna. Normalt behöver du inte ...

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Alla användare som åtkomst ett Linux-system, lokalt eller över ett nätverk, måste verifieras av ett giltigt användarkonto på systemet. I det följande får du veta hur du loggar in och ut på ett Linux-system och hur du stänger av systemet. Logga in När Linux startar upp visas det ...

Nätverksadministration: Licensserver - Dummies

Nätverksadministration: Licensserver - Dummies

I vissa program kan du köpa nätverkslicenser som gör att du kan installera programvaran på många datorer som du vill, men reglera antalet personer som kan använda programvaran vid en viss tidpunkt. För att styra hur många som använder programvaran, är en särskild licensserver inrättad. När en användare börjar ...