在乌龟上绘制函数

时间:2019-02-14 20:54:52

标签: python turtle-graphics

我需要在乌龟上绘制函数f1(x)。我需要从x = -7开始并前进.01,直到达到x = -3。我还需要使用25的比例因子

我在主函数中创建了一个for循环。当我转到坐标(i,i)并向前移动.01时,会画一条对角线,但是当我用第二个i代替f1(i)时,什么也不会发生。

def f1(x):
    return 2 * sqrt((-abs(abs(x)-1)) * abs(3 - abs(x))/((abs(x)-1)*  (3-abs(x)))) * \(1 + abs(abs(x)-3)/(abs(x)-3))*sqrt(1-(x/7)**2)+(5+0.97* (abs(x-0.5)+abs(x+0.5))-\3*(abs(x-0.75)+abs(x+0.75)))*(1+abs(1- abs(x))/(1-abs(x)))
def main():
    wn=turtle.Screen()
    wn.bgcolor("white")
    wn.title("plotting")
    draw=turtle.Turtle()
    draw.fillcolor("black")
    draw.speed(10)
    draw.penup()
    scale=25
    for i in range(-700,-300,1):
        draw.goto(((i/100)*scale),((f1(i)/100)*scale))
        draw.pendown()

我不确定应该绘制什么内容,因为那是我们应该找出的内容,但是现在什么都没有绘制,运行时发生的所有事情就是打开乌龟窗口。

2 个答案:

答案 0 :(得分:1)

我认为问题是,您正在对负数进行平方运算。更正的代码:

import turtle
from math import sqrt

def f1(x):
    return 2 * sqrt(abs(abs(x)-1)) * abs(3 - abs(x))/((abs(x)-1)*  (3-abs(x))) * (1 + abs(abs(x)-3)/(abs(x)-3))*sqrt(abs(1-(x/7)**2))+(5+0.97* (abs(x-0.5)+abs(x+0.5))-3*(abs(x-0.75)+abs(x+0.75)))*(1+abs(1- abs(x))/(1-abs(x)))
def main():
    wn=turtle.Screen()
    wn.bgcolor("white")
    wn.title("plotting")
    draw=turtle.Turtle()
    draw.fillcolor("black")
    draw.speed(10)
    draw.penup()
    scale=25
    for i in range(-700,-300):
        draw.goto(i*(scale/100),(f1(i)*(scale/100)))
        draw.pendown()
main()

答案 1 :(得分:0)

我发现将代码强制放入range()可能导致更多问题,而简单的while循环有时可能是解决问题的方法:

from math import sqrt
from turtle import Screen, Turtle

SCALE = 25

def f1(x):  # long line broken up based on where parentheses balance
    return 2 * \
        sqrt((-abs(abs(x) - 1)) * abs(3 - abs(x)) / ((abs(x) - 1) * (3 - abs(x)))) * (1 + abs(abs(x) - 3) / (abs(x) - 3)) * \
        sqrt(1 - (x / 7) ** 2) + \
        (5 + 0.97 * (abs(x - 0.5) + abs(x + 0.5)) - 3 * (abs(x - 0.75) + abs(x + 0.75))) * \
        (1 + abs(1 - abs(x)) / (1 - abs(x)))

wn = Screen()
wn.title("plotting")

draw = Turtle()
draw.speed('fastest')
draw.penup()

i = -7.0

while i < -3.0:
    draw.goto(i * SCALE, f1(i) * SCALE)
    draw.pendown()

    i += 1.0 / 100

wn.exitonclick()

在Python 3或Python 2下似乎可以为我工作。