August 2023 to June 2024
View the Project on GitHub sfremy/csablog
by
A simulation is the use of a computer software to represent the dynamic responses of one system by the behaviour of another system modeled after it. A simulation uses a mathematical descriptions, or models, of a real system in the form of a computer program.
Simulation are absractions of more complex objects or phenomena for a specific purpose
Simulations utilize varying sets of values to reflect the changings states of a phenomenon
Simulations work best when the real world experemnts are too impractical or time consuming. For example, simulating how different cars behave when they crash, would be much better than crashng actual cars in the real world, which would be expensive and dangerous.
Simulating something like a dice roll in real life would require accounting for things like: weight, flaws in design, thrust, and gravity.
- KEEP IT SIMPLE! just use a random-number generator! Ignore minor causes of variablility
#imports random module so we can use it in our code
import random
#sets variable random_number as a random number between 1 and 100
random_number = random.randint(1, 100)
#Printing out your random Number
print(random_number)
import random
def flip_coin():
return random.choice(["Heads", "Tails"])
def coin_flip_simulation(num_flips):
heads_count = 0
tails_count = 0
for _ in range(num_flips):
result = flip_coin()
if result == "Heads":
heads_count += 1
else:
tails_count += 1
return heads_count, tails_count
if __name__ == "__main__":
num_flips = 1000 #This is the number of coin flips you want to simulate
heads, tails = coin_flip_simulation(num_flips)
print("Number of Heads: "+ str(heads))
print("Number of Tails: " + str(tails))
print("Heads Probability: "+ str({heads / num_flips}))
print("Tails Probability: "+ str({tails / num_flips}))
Utilize “random” to create a basic simulation of a rolling TWO dice. Print the sum of both dice rolls. Remember to practice good syntax when naming your variables.
import random
#Code, Code, Code
d1 = random.randint(1,6)
d2 = random.randint(1,6)
d1 + d2
7
Simulations often utilize algorithms and equations to perform tasks because simulations don’t always have the same output
- the output of a simulation depends on the input
An algorithm is a finite sequence of instructions used to solve problems or perform computations.
- commonly used alongside functions
#Defining Function
def algorithm(input):
#Manipulating input and preparing it for the output.
output = input+2
#Return the output
return output
#Call the Function to start the algorithm
algorithm(5)
7
Simulate how long an object will fall for using an algorithm, with user-inputed variables for height dropped. Use the following formula as a reference.
# Constant, Acceleration due to gravity (m/s^2)
G = 9.81
def simulation(height_dropped):
# Code Code Code
t = (2*height_dropped/G)**0.5
return t
print(simulation(85))
4.162842281586698
For loops can also be used in simulations
- They can simulate events that repeat but don’t always have the same output
# Example For Loop
#Creating For Loop to repeat 4 times
for i in range(4):
#Action that happens inside for loop
print("This is run number: " + str(i))
This is run number: 0
This is run number: 1
This is run number: 2
This is run number: 3
You are gambling addict (sigma).
Each session you roll 2 dice.
If your dice roll is greater than or equal to 9 you win the session.
If you win over 5 sessions, you win the jackpot.
Simulate your odds to predict if you will hit the jackpot (how many rounds did you win?) using a for loop and random.
# Code Code Code
win_count = 0
for i in range(10):
d1 = random.randint(1,6)
d2 = random.randint(1,6)
if d1 + d2 >= 9:
print("Session Won")
win_count += 1
if win_count > 5:
print("Won Jackpot")
Session Won
Session Won
Session Won
Session Won
Session Won
Session Won
Won Jackpot
Welcome to Flight Simulator! Your goal is to complete a Python program that simulates a flight We’ve set up some initial values for altitude, speed, and fuel. Your task is to update these values to make the flight more realistic.
import random
import numpy as np
# Initial parameters
altitude = 0
speed = 0
fuel = 100
print("Welcome to Flight Simulator!")
# I'm going to assume this is arbitrary.
flight_status = True
while flight_status == True:
speed += (10+random.randint(-10,10))
altitude += speed*(random.randint(-10,20))
fuel -= speed*(np.random.uniform(0,0.1))
if altitude > 10000:
print("10,000 feet reached")
flight_status = False
if fuel < 0:
print("Crashed")
flight_status = False
Welcome to Flight Simulator!
Crashed
T or F
- A simulation will always have the same result. False T or F
- A simulation investigates a phenomenom without real-world constraints of time, money, or safety. True T or F
- A simulation has results which are more accurate than an experiment, False T or F
- A simulation can model real-worl events that are not practical for experiments True
First finish Popcorn Hack #3. Expand the simulation to involve your own money.
starting money: $100
(Dice Roll <= 3) → lose $70
( 6> Dice Roll >3) → lose $40
( 9> Dice Roll >=6) → win $20
( Dice Roll>= 9 + Session Win) → win $50
Jackpot → win $100
# Code Code Code
s = 100
win_count = 0
for i in range(10):
roll = random.randint(1,6) + random.randint(1,6)
if roll <= 3:
s -= 70
elif roll < 6:
s -= 40
elif roll < 9:
s += 20
elif roll >= 9:
s += 50
win_count += 1
if win_count > 5:
s += 100
print(s)
90
Given initial parameters for a car simulation, including its initial speed, acceleration rate, deceleration rate, maximum speed, and initial distance, write a program to simulate the car’s journey and determine the final speed, distance covered, and time taken before it either covers 1000 meters or slows down to below 5 m/s?
# Initial parameters
speed = 10 # Initial speed
acceleration = 2 # Acceleration rate in m/s^2
deceleration = 1 # Deceleration rate in m/s^2
max_speed = 60 # Maximum speed in m/s
distance = 0 # Initial distance
time = 0 # Initial time
#Code Code Code
import matplotlib.pyplot as plt
import numpy as np
cont = True
t = 1
d_arr = [0]
while cont == True:
if (acceleration - deceleration)*t < 60:
v_inst = (acceleration - deceleration)*t + speed
else:
v_inst = 60
d_inst = v_inst*t + d_arr[t-1]
d_arr.append(d_inst)
t += 1
if v_inst < 5 or d_inst > 1000:
cont = False
plt.figure()
plt.plot(np.arange(0,t),d_arr)
[<matplotlib.lines.Line2D at 0x11538f8d0>]