python turtle,random,math
# List imports here:
import turtle
import random
import math
# List constants here (NO MAGIC NUMBERS!):
NUMBER_DARTS = 1000
LEFT_BOUND = -2
RIGHT_BOUND = 2
TOP_BOUND = -2
BOTTOM_BOUND = 2
PEN_SIZE = 3
SQUARE_WIDTH = 2
SQUARE_TOP = 1
SQUARE_LEFT = -1
DOT_SIZE = 5
# Draws square given turtle, width and top left XY position
# param grapher (Turtle)
# param width (int)
# param topLeftX (int)
# param topLeftY (int)
def drawSquare( grapher, width, topLeftX, topLeftY ):
grapher.penup()
grapher.setpos(topLeftX, topLeftY)
grapher.setheading(0)
grapher.pendown()
grapher.forward(width)
grapher.right(90)
grapher.forward(width)
grapher.right(90)
grapher.forward(width)
grapher.right(90)
grapher.forward(width)
grapher.penup()
# Draws line given turtle and endpoints
# param grapher (Turtle)
# param xStart (int)
# param yStart (int)
# param xEnd (int)
# param yEnd (int)
def drawLine( grapher, xStart, yStart, xEnd, yEnd ):
grapher.penup()
grapher.setpos(xStart, yStart)
grapher.setheading(0)
angle_rad = math.atan2(yEnd - yStart, xEnd - xStart)
angle = angle_rad * 180.0 / math.pi
dist = math.sqrt((yEnd - yStart) * (yEnd - yStart) + (xEnd - xStart) * (xEnd - xStart))
grapher.pendown()
grapher.left(angle)
grapher.forward(dist)
grapher.penup()
# Draws a dot with given x, y coordinates
# param grapher (Turtle)
# param x (double)
# param y (double)
# param color (string)
def drawDot( grapher, x, y, color ):
#grapher.pencolor(color)
grapher.penup()
grapher.setpos(x, y)
grapher.dot(DOT_SIZE, color)
grapher.penup()
# Sets up 4X4 area with x- and y-axis to simulate dartboard
# param board - window that will simulate board
# param grapher - turtle that will do drawing
def setUpDartboard( board, grapher ):
# set up 4X4 area and set pensize
board.setworldcoordinates(LEFT_BOUND, TOP_BOUND, RIGHT_BOUND, BOTTOM_BOUND)
grapher.pensize(PEN_SIZE)
# Draw board
drawSquare( grapher, SQUARE_WIDTH, SQUARE_LEFT, SQUARE_TOP )
# Draw x- and y-axes
drawLine( grapher, LEFT_BOUND, 0, RIGHT_BOUND, 0 )
drawLine( grapher, 0, TOP_BOUND, 0, BOTTOM_BOUND )
# (Predicate Function)
# Determines whether or not dart falls inside unit circle with center at 0,0
# param dart (Turtle)
# return True if in circle, False if not
def inCircle( x, y ):
if x*x + y*y <= 1:
return True
else:
return False
# Algorithm for Monte Carlo simulation
# param numberDarts (int)
# param grapher (Turtle)
# return approximation of pi (float)
def montePi( numberDarts, grapher ):
# Initialize inCircleCount counter (THIS IS AN ACCUMULATOR)
inCircleCount = 0
# Loop for numberDarts
for i in range(0, numberDarts):
# Get random coordinate and position dart
x = random.random() * 2 - 1
y = random.random() * 2 - 1
# Draw red dot AND INCREMENT COUNTER if in circle, blue dot if not
if inCircle(x, y) == True:
inCircleCount = inCircleCount + 1
drawDot(grapher, x, y, "red")
else:
drawDot(grapher, x, y, "blue")
# return approximation of pi
return float(inCircleCount) / numberDarts * 4
#Performs Monte Carlo simulation to generate approximation of Pi
def main():
# Get number of darts for simulation from user
# Note continuation character <\> so we don't go over 78 columns:
print("This is a program that simulates throwing darts at a dartboard\n" \
"in order to approximate pi: The ratio of darts in a unit circle\n"\
"to the total number of darts in a 2X2 square should be\n"\
"approximately equal to pi/4")
#Create window, turtle, set up window as dartboard
window = turtle.Screen()
t = turtle.Turtle()
setUpDartboard(window, t)
PI = montePi( NUMBER_DARTS, t )
# Include the following code in order to update animation periodically
# instead of for each throw:
window.tracer(500)
#Conduct simulation and print result
print "Pi is approximately equal to " + str(PI)
#Keep the window up until dismissed
window.exitonclick()
main()
如图:
python turtle,random,math的更多相关文章
- 【转载】python 模块 - random生成随机数模块
随机数种子 要每次产生随机数相同就要设置种子,相同种子数的Random对象,相同次数生成的随机数字是完全相同的: random.seed(1) 这样random.randint(0,6, (4,5)) ...
- python使用random函数生成随机数
python使用random函数来生成随机数,常用的方法有: import random #生成0-1之间的数(不包括0和1) random.random() #生成1-5之间的随机整数(包括1和5) ...
- python+turtle 笔记
用Python+turtle绘制佩琪: from turtle import * def nose(x,y):#鼻子 penup()#提起笔 goto(x,y)#定位 pendown()#落笔,开始画 ...
- 从Scratch到Python——python turtle 一种比pygame更加简洁的实现
从Scratch到Python--python turtle 一种比pygame更加简洁的实现 现在很多学校都开设了Scratch课程,学生可以利用Scratch创作丰富的作品,然而Scratch之后 ...
- 让小乌龟可以唱歌——对Python turtle进行拓展
在Scratch中,小猫是可以唱歌的,而且Scratch的声音木块有着丰富的功能,在这方面Python turtle略有欠缺,今天我们就来完善一下. Python声音模块 Python处理声音的模块很 ...
- Python turtle绘制阴阳太极图代码解析
本文详细分析如何使用Python turtle绘制阴阳太极图,先来分解这个图形,图片中有四种颜色,每条曲线上的箭头表示乌龟移动的方向,首先从中心画一个半圆(红线),以红线所示圆的直径作半径画一个校园, ...
- 【转】python之random模块分析(一)
[转]python之random模块分析(一) random是python产生伪随机数的模块,随机种子默认为系统时钟.下面分析模块中的方法: 1.random.randint(start,stop): ...
- python的random()函数
python 的random函数需要调用 #!/usr/bin/python # -*- coding: UTF-8 -*- import random print( random.randint(1 ...
- Note of Python Turtle
Note of Python Turtle Turtle 库函数是 Python语言中一个流行的绘图函数库.Turtle 意思是海龟,在Python中显示为一个小箭头,通过它的移动而留 ...
随机推荐
- 共享IP云主机(VPS)玩转wdcp
目前国内有不少性能还不错的共享IP VPS,但因为没有独立IP,所以环境配置起来会比较麻烦. 因为本人自己现在用的就是共享IP的vps,所以把一些配置方法分享一下,供大家参考. 首先是系统的选择,根据 ...
- [置顶] Win8.1慎用360优化,可能导致安装驱动出现数据无效的问题。附解决方法
2013年9月30日,更新说明: 不知道是不是我禁用了其他驱动造成 今天开机后连接手机,我的电脑里没出现MTP设备 于是打开设备管理器,发现MTP,也就是我的XPERIA U出现了感叹号图标 右键更新 ...
- [Typescript] Function defination
Define a function type and params type: // The function init // Accept two params which are both typ ...
- 在ViewController中View的生命周期
view的生命周期如下(按顺序) -(void)loadView 用代码初始化的时候,第一个调用该方法.可以在这里面addSubView. -(void)viewDidLoad 初始化时一些数据的设置 ...
- C++沉思录之二——虚函数使用的时机
虚函数使用的时机 为什么虚函数不总是适用? 1. 虚函数有事会带来很大的消耗: 2. 虚函数不总是提供所需的行为: 3. 当我们不考虑继承当前类时,不必使用虚函数. 必须使用虚函数的情况: 1. 当你 ...
- 使用Mina框架开发 QQ Android 客户端
Apache MINA是一个网络应用程序框架,用来帮助用户简单地开发高性能和高可靠性的网络应用程序.它提供了一个通过Java NIO在不同的传输例如TCP/IP和UDP/IP上抽象的事件驱动的异步AP ...
- css伪类选择器详细解析及案例使用-----伪类选择器(2)
结构伪类选择器: <div> <ul> /*ul:only-of-type*/ <li>one</li> /*li:first-child li:nth ...
- ORACLE基本SQL语句-查询篇
一.普通查询 /*查询表数据*/select * from STU /*取出前3行数据*/select * from stu where ROWNUM<=3 /*模糊查询*/select * f ...
- Hibernate插入数据效率测试
硬件配置: 4G内存.CPUi3-2.3 数据库SQL2008 package com.pan.test; import org.hibernate.Session; import org.hiber ...
- IOS添加自定义字体库
1.将需要的字体库xxx.ttf添加到工程中,注意一定要在copy bundle resources中存在,如果没有添加上去 2.在info.plist 文件中添加 fonts provided by ...