• 数学图形之螺旋管


    上一节讲的是螺旋曲面,这一节中将曲面绕个圈,生成螺旋管.提供了若干种生成螺旋管的脚本代码,最后还生成麻花的图形.

     

    相关软件参见:数学图形可视化工具,使用自己定义语法的脚本代码生成数学图形.

    (1)螺旋管

    vertices = D1:720 D2:72
    u = from 0 to (10*PI) D1
    v = from 0 to (2*PI) D2
    
    a = 3
    
    x = (a + cos(v)) * cos(u)
    z = (a + cos(v)) * sin(u)
    y = sin(v) + u

    (2)螺旋管随机

    vertices = D1:720 D2:72
    u = from 0 to (6*PI) D1
    v = from 0 to (2*PI) D2
    
    a = rand2(2, 5)
    b = rand2(0.5, 1)
    c = rand2(0.5, 2)
    
    x = c * (a + b * cos(v)) * cos(u)
    y = c * (a + b * cos(v)) * sin(u)
    z = c * b * sin(v) + u * 2/PI - 6

    (3)螺旋管(逐渐变细)

    可以将螺旋管想象成一个圆圈曲线绕一轴旋转+平移

    vertices = D1:720 D2:72
    u = from 0 to 1 D1
    v = from 0 to (2*PI) D2
    
    a = 3
    b = 5
    
    x = (1 - u)*(a + cos(v)) * cos(b*PI*u)
    z = (1 - u)*(a + cos(v)) * sin(b*PI*u)
    y = (1 - u)*sin(v) + a*u + PI
    
    u = u*10

    (4)Circle 旋转管

    vertices = D1:100 D2:600
    
    u = from (0) to (2*PI) D1
    v = from 0 to (12*PI) D2
    
    r = 2
    m = rand2(r, r*10)
    
    n = r*cos(u) + m
    
    y = r*sin(u) + v
    
    x = n*cos(v)
    z = n*sin(v)

    (5)麻花曲面

    vertices = D1:3600 D2:100
    u = from 0 to (PI*10) D1
    v = from 0 to (PI*2) D2
    
    a = 10
    b = rand2(5, 10)
    
    x = a*cos(u)*cos(v)
    z = a*sin(u)*cos(v)
    y = a*sin(v) + b*u

  • 相关阅读:
    作业DAY002
    作业DAY001
    作业 5:词频统计——增强功能
    在JdbcTemplate里面关于queryForMap返回值的疑问
    直接打印map, 为什么能直接输出value
    JdbcTemplate jar包 下载
    edge 修改链接打开方式
    Java中的判断实例
    关于Junit4 和 Junit5.4
    关于函数式接口, printable 自定义
  • 原文地址:https://www.cnblogs.com/WhyEngine/p/3881496.html
Copyright © 2020-2023  润新知