Skip to main content

cfmdarts is a Python library that simulates the projectile motion of darts.

Project description

cfmdarts

cfmdarts is a Python library that simulates the projectile motion of darts.

Table of Contents

  1. Introduction
  2. Installation
  3. Tutorials
  4. How To Guides
  5. Explanation
  6. License

Introduction

This project has an extremely trivial goal. Simply input 3 values relating to the throw of a dart

  • tilt angle
  • swivel angle (both in degrees)
  • initial velocity (in metres per second).

Then output the score of which is obtained. This project involves many areas of mathematics to solve. Primarily Mechanics and Geometry.

Installation

Use the package manager pip to install cfmdarts.

pip install cfmdarts

NOTE: It is recommended to have a Python version which is greater that 3.6 to be installed.

Tutorial

In order to use cfmdarts is really simple. To use in your project, you type

from cfmdarts import*

How To Guides

These next guides are simple pieces of code to get you started using cfmdarts.

Creating a new Projectile object.

from cfmdarts import*

#Creating a new Projectile object called Object1
#with tilt_angle=2, swivel_angle=1.5 and initial_velocity=21

Object1 = cfmdarts.Projectile(2, 1.5, 21)

Outputting a new Projectile objects range, height and shift values.

from cfmdarts import*

#Creating a new Projectile object called Object1
#with tilt_angle=2, swivel_angle=1.5 and initial_velocity=21

Object1 = cfmdarts.Projectile(2,1.5,21)

##This outputs the follow
print(Object1.range())
print(Object1.height())
print(Object1.shift())

Output:

2.370812418203357
0.02019783552359672
0.06206063411897303

Creating a coordinates object to calculate and output the cartesian and polar coordinates

from cfmdarts import*

#Creating a coordinates object called coord1
#with tilt_angle=2, swivel_angle=1.5 and initial_velocity=21

Coord1 = cfmdarts.coordinates(2,1.5,21)

## These two statements below print out the
## cartesian and polar coordinates.
print(Coord1.cartesian_coordinates())
print(Coord1.polar_coordinates())

Output:

[0.06206063411897303, 0.02019783552359672]
[0.06526465250874554, 18.027647207949578]

Creating a data simulation using the dart_simulation that returns a final score.

from cfmdarts import*

#Creating a variable called 'simulation1'.
simulation1 = cfmdarts.dart_simulation(2, 1.5, 21)

##Outputs the final score from simulation1
print(simulation1)

Output:

13

Example of a dart simulation that has an incorrect input case with tilt_angle being an invalid input

from cfmdarts import*

#Creating a variable called 'simulation1'.
simulation1 = cfmdarts.dart_simulation(-91, 2, 29)

##Outputs the final score from simulation1
print(simulation1)

Output:

null shot, please ensure the tilt and swivel angles are both between -90 and 90, and that the velocity is positive

Explanation

Phase I - Projectile In 3D

We must first consider the 2-dimensional plane $(x,y)$ in which our dart travels through. Doing, we can model the trajectory of the dart using projectile motion in order to obtain the range, height, and shift of the dart relative to the bullseye. We can say that air resistance of the dart is negligible.

Phase II - Geometry Of Dartboard

Determining the score is precisely the same as determining the position at which the dart landed on the dartboard. We will obtain (via the specified throw) 2 distances relative to the distance from the bullseye. Using these 2 values as Cartesian coordinates, we can translate the position into polar form $r, \theta $ via similar methods to determining the modulus and argument of a complex number. See the ``coordinates" class in how this was achieved.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cfmdarts-0.0.7.tar.gz (5.6 kB view details)

Uploaded Source

File details

Details for the file cfmdarts-0.0.7.tar.gz.

File metadata

  • Download URL: cfmdarts-0.0.7.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.10

File hashes

Hashes for cfmdarts-0.0.7.tar.gz
Algorithm Hash digest
SHA256 8a4803081daff35c71f1e9bcbc8728d19b4e95f8136175445633abd815ede00b
MD5 8bf5940cc11eea121ddf1236c0b18996
BLAKE2b-256 2c563d056ba5ff9c247f874457f6af7facd907f34e4439e8f46620bf23c2b2e2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page