Ich möchte Daten mit Python analysieren können (Teil 4)

(Teil 4)

(Siehe die Seite im Text Statistik ist die stärkste Studie [Praxis] Gedanken und Methoden zur Datenanalyse von Kei Nishiuchi Dies ist die Seite des Buches /9784478028230.html).

Wenn Sie 16 Münzen werfen

Das Ergebnis des 16-fachen Werfens von Münzen, auf dem auf P63 "Als Referenz" steht.

Der Autor betont, dass "die Summe der Daten zu einer Normalverteilung konvergiert", selbst wenn eine asymmetrische Münze mit einer Wahrscheinlichkeit von 1/3 geworfen wird, in der Tabelle zu erscheinen.

Der Grund, warum es wie ein "Berg" geformt ist, ist, dass es am einfachsten zu verstehen ist, dass, wenn die Daten als 2x2-, 3x3- oder 8x8-Tabelle dargestellt werden, "ein anderes Muster, das das gleiche Ergebnis liefert", von rechts oben nach links unten. Es gibt viele "", und durch Addition, je näher an der Diagonale, desto größer der Gesamtwert = der höchste Punkt des Berges.

Code

Dieses Mal werde ich nur ein Balkendiagramm erstellen, daher werde ich die Daten nicht vorbereiten, um daraus eine Tabelle zu machen.


from random import randint
from decimal import Decimal
import numpy as np

def tossBiasedCoin():
    """ Returns 0 or 1 with 0 having 2/3 chance """
    return randint(0,2) % 2

# Prepare counters
tossCount = 16
counts = [0]*tossCount

# Toss a coin many times to get counts
sampleCount = 50000
for num in range(sampleCount):    
    headCount = 0
    for i in range(tossCount): # Toss the coin 16 times
        headCount += tossBiasedCoin()
    counts[headCount] += 1

# Conert all counts to perentage
TWOPLACES = Decimal(10) ** -2 
for i in range(tossCount):
    value = counts[i]        
    counts[i] = (100 * Decimal(counts[i])/Decimal(sampleCount)).quantize(TWOPLACES)
    print("Converted the value {} to percentage {}".format(value, counts[i]))

# Draw a bar chart
import matplotlib.pyplot as plt
fig, ax = plt.subplots()
rects = plt.bar(np.arange(tossCount),
                 counts, 
                 0.5,
                 alpha=0.4,
                 align="center", 
                 color='b')

plt.xlabel('Number of heads for 16-toss')
plt.ylabel('Probability (%)')
plt.title('Probabilities heads with a biased coin')
plt.xticks(np.arange(tossCount))

plt.tight_layout()
plt.show()

Erstellen Sie eine Zählervariable

Gehorsam erstellt es eine Liste mit 16 Elementen.

# Prepare counters
tossCount = 16
counts = [0]*tossCount

Münzen werfen

Werfen Sie 16 Mal und führen Sie 500.000 Mal aus, um zu sehen, wie viele Blätter sich auf der Vorderseite befinden (obwohl Sie nicht so viel drehen müssen).

## Toss a coin many times to get counts
sampleCount = 50000
for num in range(sampleCount):    
    headCount = 0
    for i in range(tossCount): # Toss the coin 16 times
        headCount += tossBiasedCoin()
    counts[headCount] += 1

In Prozent umrechnen

# Conert all counts to perentage
TWOPLACES = Decimal(10) ** -2 
for i in range(tossCount):
    value = counts[i]        
    counts[i] = (100 * Decimal(counts[i])/Decimal(sampleCount)).quantize(TWOPLACES)
    print("Converted the value {} to percentage {}".format(value, counts[i]))

Erstellen Sie ein Balkendiagramm

Ich habe nichts Besonderes gemacht.

# Draw a bar chart
import matplotlib.pyplot as plt
fig, ax = plt.subplots()
rects = plt.bar(np.arange(tossCount),
                 counts, 
                 0.5,
                 alpha=0.4,
                 align="center", 
                 color='b')

plt.xlabel('Number of heads for 16-toss')
plt.ylabel('Probability (%)')
plt.title('Probabilities heads with a biased coin')
plt.xticks(np.arange(tossCount))

plt.tight_layout()
plt.show()

Ergebnis

Ein Diagramm ähnlich Diagramm 1-21 auf Seite 64 wurde erstellt.

image

Zusammenfassung

Es ist ein Händchen dafür, Daten mit Python analysieren zu können, oder etwas, von dem ich glaube, dass ich es in Zukunft tun muss.

Recommended Posts

Ich möchte Daten mit Python analysieren können (Teil 3)
Ich möchte Daten mit Python analysieren können (Teil 1)
Ich möchte Daten mit Python analysieren können (Teil 4)
Ich möchte Daten mit Python analysieren können (Teil 2)
Ich möchte Protokolle mit Python analysieren
Ich möchte mit Python debuggen
Ich möchte Python mit VS-Code ausführen können
Ich möchte mit aws mit Python spielen
☆ Mr. Anzai… !! Ich möchte die Daten analysieren …… Teil 1 Datenvorbereitung ☆ Analysieren wir die NBA-Spielerstatistiken (Ergebnisse) mit Python. Basketball
[Pandas] Ich habe versucht, Verkaufsdaten mit Python zu analysieren. [Für Anfänger]
Ich möchte MATLAB feval mit Python verwenden
Ich möchte ein Spiel mit Python machen
Ich möchte OREMO mit setParam sein!
Ich habe versucht, CloudWatch-Daten mit Python abzurufen
Ich möchte Temporäres Verzeichnis mit Python2 verwenden
#Unresolved Ich möchte Gobject-Introspection mit Python3 kompilieren
Ich möchte APG4b mit Python lösen (Kapitel 2)
Ich möchte mit Python in eine Datei schreiben
Ich möchte die Optimierung mit Python und CPlex behandeln
Ich möchte mit Python-Datenklasse nach hinten erben
Ich möchte mit einem Roboter in Python arbeiten.
Ich möchte Lambda mit Python auf Mac AWS!
Ich möchte einen Quantencomputer mit Python betreiben
Ich möchte eine andere Version von Python mit pyvenv angeben
Ich habe versucht, mit Python faker verschiedene "Dummy-Daten" zu erstellen
Ich möchte automatisch an Online-Kursen mit Python + Selen teilnehmen!
[Python] Ich möchte die Option -h mit argparse verwenden
Ich möchte ○○ mit Pandas machen
Ich habe Python satt, also habe ich versucht, die Daten mit nehan zu analysieren (ich möchte sogar mit Corona live gehen) - Teil 2)
Ich habe Python satt, also habe ich versucht, die Daten mit nehan zu analysieren (ich möchte sogar mit Corona live gehen) - Teil 1)
Ich kenne? Datenanalyse mit Python oder Dingen, die Sie mit numpy verwenden möchten, wenn Sie möchten
Ich möchte einen Platzhalter verwenden, den ich mit Python entfernen möchte
Ich möchte APG4b mit Python lösen (nur 4.01 und 4.04 in Kapitel 4)
Ich möchte den Anfang des nächsten Monats mit Python ausgeben
Versuchen Sie, Online-Familien-Mahjong mit Python zu analysieren (TEIL 1: Daten aufnehmen)
Ich möchte den vollständigen Text mit elasticsearch + python durchsuchen
[Einführung] Ich möchte mit Python einen Mastodon-Bot erstellen! 【Anfänger】
Ich möchte Objekte mit OpenCV erkennen
Verarbeiten Sie Pubmed .xml-Daten mit Python [Teil 2]
Ich möchte mit dem Reim Teil1 umgehen
Ich möchte einen Blog mit Jupyter Notebook schreiben
Ich möchte mit dem Reim part3 umgehen
Konvertieren Sie Excel-Daten mit Python in JSON
Ich möchte ein Glas aus Python verwenden
Ich wollte ABC160 mit Python lösen
Ich möchte eine Python-Umgebung erstellen
Ich möchte eine Pip-Installation mit PythonAnywhere durchführen
[Teil1] Scraping mit Python → Organisieren Sie bis zu CSV!
Ich wollte ABC172 mit Python lösen
Ich möchte mit dem Reim part2 umgehen
Ich möchte mit dem Reim part5 umgehen
Ich möchte mit dem Reim part4 umgehen
Ich möchte es mit Python Lambda Django machen, aber ich werde aufhören
[Data Science-Grundlagen] Ich habe versucht, mit Python von CSV auf MySQL zu speichern
Ich möchte Twitter mit Python twittern, bin aber süchtig danach