Hem Personliga finanser Hur man hittar antalet element i en dataström - dummies

Hur man hittar antalet element i en dataström - dummies

Video: Elements and atoms | Atoms, compounds, and ions | Chemistry | Khan Academy 2024

Video: Elements and atoms | Atoms, compounds, and ions | Chemistry | Khan Academy 2024
Anonim

Även om ett Bloom-filter kan spåra objekt som kommer från en ström, kan det inte berätta hur många objekt som finns. En liten vektor fylld av en kan (beroende på antalet haschar och sannolikheten för kollision) gömma det sanna antalet objekt som har hashed på samma adress.

Att veta det distinkta antalet objekt är användbart i olika situationer, till exempel när du vill veta hur många distinkta användare som har sett en viss webbsida eller antalet olika sökmotorfrågor. Att lagra alla element och hitta dubbletter bland dem kan inte fungera med miljontals element, särskilt från en ström. När du vill veta antalet separata objekt i en ström måste du fortfarande förlita dig på en hashfunktion, men det innebär att du tar en numerisk skiss.

Sketching betyder att en approximation, som är ett inexakt men inte helt fel värde som ett svar. Approximation är acceptabelt eftersom det verkliga värdet inte är för långt från det. I denna smarta algoritmen, HyperLogLog, som är baserad på sannolikhet och approximation, observerar du egenskaperna hos tal som genereras från strömmen. HyperLogLog härrör från studierna av datavetenskapare Nigel Martin och Philippe Flajolet. Flajolet förbättrade sin initiala algoritm, Flajolet-Martin (eller LogLog-algoritmen) till den mer robusta HyperLogLog-versionen, som fungerar så här:

  1. En hasj konverterar varje element som tas emot från strömmen till ett tal.
  2. Algoritmen omvandlar numret till binärt, bas 2-standarden som datorer använder.
  3. Algoritmen räknar antalet initiala nollor i det binära numret och spåren i det maximala antalet som det ser, vilket är n.
  4. Algoritmen uppskattar antalet separata element som passerade i strömmen med hjälp av n. Antalet separata element är 2 ^ n.

Till exempel är det första elementet i strängen ordet hund. Algoritmen har det till ett heltal och omvandlar det till binärt, med ett resultat av 01101010. Endast en noll visas i början av numret, så algoritmen registrerar det som det maximala antalet efterföljande nollor. Algoritmen ser då orden papegoja och varg, vars binära ekvivalenter är 11101011 och 01101110, vilket lämnar n oförändrad. När ordet katt passerar är emellertid utgången 00101110, så n blir 2. För att uppskatta antalet separata element beräknar algoritmen 2 ^ n, det vill säga 2 ^ 2 = 4. Figuren visar denna process.

Räkna endast ledande nollor.

Algoritmens knep är att om din hash producerar slumpmässiga resultat, lika fördelade (som i ett Bloom-filter), genom att titta på binär representation, kan du beräkna sannolikheten för att en sekvens av nollor uppstod. Eftersom sannolikheten för ett enda binärt tal att vara 0 är en i två, för att beräkna sannolikheten för sekvenser av nollor multiplicerar du bara den 1/2 sannolikheten så många gånger som längden av sekvensen av nollor:

  • 50 procent (1/2) sannolikhet för siffror som börjar med 0
  • 25 procent (1/2 * 1/2) sannolikhet för siffror som börjar med 00
  • 12. 5% (1/2 * 1/2 * 1/2) sannolikhet för tal som börjar med 000
  • (1/2) ^ k sannolikhet för tal som börjar med k zeros (du använder befogenheter för snabbare beräkningar av många multiplikationer av samma antal)

Ju färre siffrorna som HyperLogLog ser desto större är precisionen. Noggrannhet ökar när du använder HyperLogLog-beräkningen många gånger med olika hashfunktioner och i genomsnitt sammanfattar svaren från varje beräkning, men hashing många gånger tar tid och strömmar är snabba. Som ett alternativ kan du använda samma hash men dela strömmen till grupper (t.ex. genom att separera elementen i grupper när de kommer utifrån deras ankomstorder) och för varje grupp håller du reda på det maximala antalet efterföljande nollor. I slutändan beräknar du den skilda grundberäkningen för varje grupp och beräknar det aritmetiska medelvärdet av alla uppskattningar. Detta tillvägagångssätt är stokastiskt medelvärde och ger mer exakta uppskattningar än att tillämpa algoritmen på hela strömmen.

Hur man hittar antalet element 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 ...