# # The infamous Teapot data as four B-spline surfaces. # echosrc = false; Body = sbspline( 4, 4, list( list( ctlpt( E3, 1.4, 2.25, 0 ), ctlpt( E3, 1.3375, 2.38125, 0 ), ctlpt( E3, 1.4375, 2.38125, 0 ), ctlpt( E3, 1.5, 2.25, 0 ), ctlpt( E3, 1.75, 1.725, 0 ), ctlpt( E3, 2, 1.2, 0 ), ctlpt( E3, 2, 0.75, 0 ), ctlpt( E3, 2, 0.3, 0 ), ctlpt( E3, 1.5, 0.075, 0 ), ctlpt( E3, 1.5, 0, 0 ) ), list( ctlpt( E3, 1.4, 2.25, 0.784 ), ctlpt( E3, 1.3375, 2.38125, 0.749 ), ctlpt( E3, 1.4375, 2.38125, 0.805 ), ctlpt( E3, 1.5, 2.25, 0.84 ), ctlpt( E3, 1.75, 1.725, 0.98 ), ctlpt( E3, 2, 1.2, 1.12 ), ctlpt( E3, 2, 0.75, 1.12 ), ctlpt( E3, 2, 0.3, 1.12 ), ctlpt( E3, 1.5, 0.075, 0.84 ), ctlpt( E3, 1.5, 0, 0.84 ) ), list( ctlpt( E3, 0.784, 2.25, 1.4 ), ctlpt( E3, 0.749, 2.38125, 1.3375 ), ctlpt( E3, 0.805, 2.38125, 1.4375 ), ctlpt( E3, 0.84, 2.25, 1.5 ), ctlpt( E3, 0.98, 1.725, 1.75 ), ctlpt( E3, 1.12, 1.2, 2 ), ctlpt( E3, 1.12, 0.75, 2 ), ctlpt( E3, 1.12, 0.3, 2 ), ctlpt( E3, 0.84, 0.075, 1.5 ), ctlpt( E3, 0.84, 0, 1.5 ) ), list( ctlpt( E3, 0, 2.25, 1.4 ), ctlpt( E3, 0, 2.38125, 1.3375 ), ctlpt( E3, 0, 2.38125, 1.4375 ), ctlpt( E3, 0, 2.25, 1.5 ), ctlpt( E3, 0, 1.725, 1.75 ), ctlpt( E3, 0, 1.2, 2 ), ctlpt( E3, 0, 0.75, 2 ), ctlpt( E3, 0, 0.3, 2 ), ctlpt( E3, 0, 0.075, 1.5 ), ctlpt( E3, 0, 0, 1.5 ) ), list( ctlpt( E3, -0.784, 2.25, 1.4 ), ctlpt( E3, -0.749, 2.38125, 1.3375 ), ctlpt( E3, -0.805, 2.38125, 1.4375 ), ctlpt( E3, -0.84, 2.25, 1.5 ), ctlpt( E3, -0.98, 1.725, 1.75 ), ctlpt( E3, -1.12, 1.2, 2 ), ctlpt( E3, -1.12, 0.75, 2 ), ctlpt( E3, -1.12, 0.3, 2 ), ctlpt( E3, -0.84, 0.075, 1.5 ), ctlpt( E3, -0.84, 0, 1.5 ) ), list( ctlpt( E3, -1.4, 2.25, 0.784 ), ctlpt( E3, -1.3375, 2.38125, 0.749 ), ctlpt( E3, -1.4375, 2.38125, 0.805 ), ctlpt( E3, -1.5, 2.25, 0.84 ), ctlpt( E3, -1.75, 1.725, 0.98 ), ctlpt( E3, -2, 1.2, 1.12 ), ctlpt( E3, -2, 0.75, 1.12 ), ctlpt( E3, -2, 0.3, 1.12 ), ctlpt( E3, -1.5, 0.075, 0.84 ), ctlpt( E3, -1.5, 0, 0.84 ) ), list( ctlpt( E3, -1.4, 2.25, 0 ), ctlpt( E3, -1.3375, 2.38125, 0 ), ctlpt( E3, -1.4375, 2.38125, 0 ), ctlpt( E3, -1.5, 2.25, 0 ), ctlpt( E3, -1.75, 1.725, 0 ), ctlpt( E3, -2, 1.2, 0 ), ctlpt( E3, -2, 0.75, 0 ), ctlpt( E3, -2, 0.3, 0 ), ctlpt( E3, -1.5, 0.075, 0 ), ctlpt( E3, -1.5, 0, 0 ) ), list( ctlpt( E3, -1.4, 2.25, -0.784 ), ctlpt( E3, -1.3375, 2.38125, -0.749 ), ctlpt( E3, -1.4375, 2.38125, -0.805 ), ctlpt( E3, -1.5, 2.25, -0.84 ), ctlpt( E3, -1.75, 1.725, -0.98 ), ctlpt( E3, -2, 1.2, -1.12 ), ctlpt( E3, -2, 0.75, -1.12 ), ctlpt( E3, -2, 0.3, -1.12 ), ctlpt( E3, -1.5, 0.075, -0.84 ), ctlpt( E3, -1.5, 0, -0.84 ) ), list( ctlpt( E3, -0.784, 2.25, -1.4 ), ctlpt( E3, -0.749, 2.38125, -1.3375 ), ctlpt( E3, -0.805, 2.38125, -1.4375 ), ctlpt( E3, -0.84, 2.25, -1.5 ), ctlpt( E3, -0.98, 1.725, -1.75 ), ctlpt( E3, -1.12, 1.2, -2 ), ctlpt( E3, -1.12, 0.75, -2 ), ctlpt( E3, -1.12, 0.3, -2 ), ctlpt( E3, -0.84, 0.075, -1.5 ), ctlpt( E3, -0.84, 0, -1.5 ) ), list( ctlpt( E3, 0, 2.25, -1.4 ), ctlpt( E3, 0, 2.38125, -1.3375 ), ctlpt( E3, 0, 2.38125, -1.4375 ), ctlpt( E3, 0, 2.25, -1.5 ), ctlpt( E3, 0, 1.725, -1.75 ), ctlpt( E3, 0, 1.2, -2 ), ctlpt( E3, 0, 0.75, -2 ), ctlpt( E3, 0, 0.3, -2 ), ctlpt( E3, 0, 0.075, -1.5 ), ctlpt( E3, 0, 0, -1.5 ) ), list( ctlpt( E3, 0.784, 2.25, -1.4 ), ctlpt( E3, 0.749, 2.38125, -1.3375 ), ctlpt( E3, 0.805, 2.38125, -1.4375 ), ctlpt( E3, 0.84, 2.25, -1.5 ), ctlpt( E3, 0.98, 1.725, -1.75 ), ctlpt( E3, 1.12, 1.2, -2 ), ctlpt( E3, 1.12, 0.75, -2 ), ctlpt( E3, 1.12, 0.3, -2 ), ctlpt( E3, 0.84, 0.075, -1.5 ), ctlpt( E3, 0.84, 0, -1.5 ) ), list( ctlpt( E3, 1.4, 2.25, -0.784 ), ctlpt( E3, 1.3375, 2.38125, -0.749 ), ctlpt( E3, 1.4375, 2.38125, -0.805 ), ctlpt( E3, 1.5, 2.25, -0.84 ), ctlpt( E3, 1.75, 1.725, -0.98 ), ctlpt( E3, 2, 1.2, -1.12 ), ctlpt( E3, 2, 0.75, -1.12 ), ctlpt( E3, 2, 0.3, -1.12 ), ctlpt( E3, 1.5, 0.075, -0.84 ), ctlpt( E3, 1.5, 0, -0.84 ) ), list( ctlpt( E3, 1.4, 2.25, 0 ), ctlpt( E3, 1.3375, 2.38125, 0 ), ctlpt( E3, 1.4375, 2.38125, 0 ), ctlpt( E3, 1.5, 2.25, 0 ), ctlpt( E3, 1.75, 1.725, 0 ), ctlpt( E3, 2, 1.2, 0 ), ctlpt( E3, 2, 0.75, 0 ), ctlpt( E3, 2, 0.3, 0 ), ctlpt( E3, 1.5, 0.075, 0 ), ctlpt( E3, 1.5, 0, 0 ) ) ), list( list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3 ), list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 4 ) ) ); Spout = sbspline( 4, 4, list( list( ctlpt( E3, 1.7, 1.275, 0 ), ctlpt( E3, 2.6, 1.275, 0 ), ctlpt( E3, 2.3, 1.95, 0 ), ctlpt( E3, 2.7, 2.25, 0 ), ctlpt( E3, 2.8, 2.325, 0 ), ctlpt( E3, 2.9, 2.325, 0 ), ctlpt( E3, 2.8, 2.25, 0 ) ), list( ctlpt( E3, 1.7, 1.275, 0.66 ), ctlpt( E3, 2.6, 1.275, 0.66 ), ctlpt( E3, 2.3, 1.95, 0.25 ), ctlpt( E3, 2.7, 2.25, 0.25 ), ctlpt( E3, 2.8, 2.325, 0.25 ), ctlpt( E3, 2.9, 2.325, 0.15 ), ctlpt( E3, 2.8, 2.25, 0.15 ) ), list( ctlpt( E3, 1.7, 0.45, 0.66 ), ctlpt( E3, 3.1, 0.675, 0.66 ), ctlpt( E3, 2.4, 1.875, 0.25 ), ctlpt( E3, 3.3, 2.25, 0.25 ), ctlpt( E3, 3.525, 2.34375, 0.25 ), ctlpt( E3, 3.45, 2.3625, 0.15 ), ctlpt( E3, 3.2, 2.25, 0.15 ) ), list( ctlpt( E3, 1.7, 0.45, 0 ), ctlpt( E3, 3.1, 0.675, 0 ), ctlpt( E3, 2.4, 1.875, 0 ), ctlpt( E3, 3.3, 2.25, 0 ), ctlpt( E3, 3.525, 2.34375, 0 ), ctlpt( E3, 3.45, 2.3625, 0 ), ctlpt( E3, 3.2, 2.25, 0 ) ), list( ctlpt( E3, 1.7, 0.45, -0.66 ), ctlpt( E3, 3.1, 0.675, -0.66 ), ctlpt( E3, 2.4, 1.875, -0.25 ), ctlpt( E3, 3.3, 2.25, -0.25 ), ctlpt( E3, 3.525, 2.34375, -0.25 ), ctlpt( E3, 3.45, 2.3625, -0.15 ), ctlpt( E3, 3.2, 2.25, -0.15 ) ), list( ctlpt( E3, 1.7, 1.275, -0.66 ), ctlpt( E3, 2.6, 1.275, -0.66 ), ctlpt( E3, 2.3, 1.95, -0.25 ), ctlpt( E3, 2.7, 2.25, -0.25 ), ctlpt( E3, 2.8, 2.325, -0.25 ), ctlpt( E3, 2.9, 2.325, -0.15 ), ctlpt( E3, 2.8, 2.25, -0.15 ) ), list( ctlpt( E3, 1.7, 1.275, 0 ), ctlpt( E3, 2.6, 1.275, 0 ), ctlpt( E3, 2.3, 1.95, 0 ), ctlpt( E3, 2.7, 2.25, 0 ), ctlpt( E3, 2.8, 2.325, 0 ), ctlpt( E3, 2.9, 2.325, 0 ), ctlpt( E3, 2.8, 2.25, 0 ) ) ), list( list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 ), list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 ) ) ); Handle = sbspline( 4, 4, list( list( ctlpt( E3, -1.595, 1.875, 0 ), ctlpt( E3, -2.295, 1.875, 0 ), ctlpt( E3, -2.695, 1.875, 0 ), ctlpt( E3, -2.695, 1.65, 0 ), ctlpt( E3, -2.695, 1.425, 0 ), ctlpt( E3, -2.495, 0.975, 0 ), ctlpt( E3, -1.995, 0.75, 0 ) ), list( ctlpt( E3, -1.595, 1.875, 0.3 ), ctlpt( E3, -2.295, 1.875, 0.3 ), ctlpt( E3, -2.695, 1.875, 0.3 ), ctlpt( E3, -2.695, 1.65, 0.3 ), ctlpt( E3, -2.695, 1.425, 0.3 ), ctlpt( E3, -2.495, 0.975, 0.3 ), ctlpt( E3, -1.995, 0.75, 0.3 ) ), list( ctlpt( E3, -1.495, 2.1, 0.3 ), ctlpt( E3, -2.495, 2.1, 0.3 ), ctlpt( E3, -2.995, 2.1, 0.3 ), ctlpt( E3, -2.995, 1.65, 0.3 ), ctlpt( E3, -2.995, 1.2, 0.3 ), ctlpt( E3, -2.645, 0.7875, 0.3 ), ctlpt( E3, -1.895, 0.45, 0.3 ) ), list( ctlpt( E3, -1.495, 2.1, 0 ), ctlpt( E3, -2.495, 2.1, 0 ), ctlpt( E3, -2.995, 2.1, 0 ), ctlpt( E3, -2.995, 1.65, 0 ), ctlpt( E3, -2.995, 1.2, 0 ), ctlpt( E3, -2.645, 0.7875, 0 ), ctlpt( E3, -1.895, 0.45, 0 ) ), list( ctlpt( E3, -1.495, 2.1, -0.3 ), ctlpt( E3, -2.495, 2.1, -0.3 ), ctlpt( E3, -2.995, 2.1, -0.3 ), ctlpt( E3, -2.995, 1.65, -0.3 ), ctlpt( E3, -2.995, 1.2, -0.3 ), ctlpt( E3, -2.645, 0.7875, -0.3 ), ctlpt( E3, -1.895, 0.45, -0.3 ) ), list( ctlpt( E3, -1.595, 1.875, -0.3 ), ctlpt( E3, -2.295, 1.875, -0.3 ), ctlpt( E3, -2.695, 1.875, -0.3 ), ctlpt( E3, -2.695, 1.65, -0.3 ), ctlpt( E3, -2.695, 1.425, -0.3 ), ctlpt( E3, -2.495, 0.975, -0.3 ), ctlpt( E3, -1.995, 0.75, -0.3 ) ), list( ctlpt( E3, -1.595, 1.875, 0 ), ctlpt( E3, -2.295, 1.875, 0 ), ctlpt( E3, -2.695, 1.875, 0 ), ctlpt( E3, -2.695, 1.65, 0 ), ctlpt( E3, -2.695, 1.425, 0 ), ctlpt( E3, -2.495, 0.975, 0 ), ctlpt( E3, -1.995, 0.75, 0 ) ) ), list( list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 ), list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 ) ) ); Cap = sbspline( 4, 4, list( list( ctlpt( E3, 0, 3, 0 ), ctlpt( E3, 0.8, 3, 0 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.2, 2.55, 0 ), ctlpt( E3, 0.4, 2.4, 0 ), ctlpt( E3, 1.3, 2.4, 0 ), ctlpt( E3, 1.3, 2.25, 0 ) ), list( ctlpt( E3, 0, 3, 0.002 ), ctlpt( E3, 0.8, 3, 0.45 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.2, 2.55, 0.112 ), ctlpt( E3, 0.4, 2.4, 0.224 ), ctlpt( E3, 1.3, 2.4, 0.728 ), ctlpt( E3, 1.3, 2.25, 0.728 ) ), list( ctlpt( E3, 0.002, 3, 0 ), ctlpt( E3, 0.45, 3, 0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.112, 2.55, 0.2 ), ctlpt( E3, 0.224, 2.4, 0.4 ), ctlpt( E3, 0.728, 2.4, 1.3 ), ctlpt( E3, 0.728, 2.25, 1.3 ) ), list( ctlpt( E3, 0, 3, 0 ), ctlpt( E3, 0, 3, 0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0, 2.55, 0.2 ), ctlpt( E3, 0, 2.4, 0.4 ), ctlpt( E3, 0, 2.4, 1.3 ), ctlpt( E3, 0, 2.25, 1.3 ) ), list( ctlpt( E3, -0.002, 3, 0 ), ctlpt( E3, -0.45, 3, 0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, -0.112, 2.55, 0.2 ), ctlpt( E3, -0.224, 2.4, 0.4 ), ctlpt( E3, -0.728, 2.4, 1.3 ), ctlpt( E3, -0.728, 2.25, 1.3 ) ), list( ctlpt( E3, 0, 3, 0.002 ), ctlpt( E3, -0.8, 3, 0.45 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, -0.2, 2.55, 0.112 ), ctlpt( E3, -0.4, 2.4, 0.224 ), ctlpt( E3, -1.3, 2.4, 0.728 ), ctlpt( E3, -1.3, 2.25, 0.728 ) ), list( ctlpt( E3, 0, 3, 0 ), ctlpt( E3, -0.8, 3, 0 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, -0.2, 2.55, 0 ), ctlpt( E3, -0.4, 2.4, 0 ), ctlpt( E3, -1.3, 2.4, 0 ), ctlpt( E3, -1.3, 2.25, 0 ) ), list( ctlpt( E3, 0, 3, -0.002 ), ctlpt( E3, -0.8, 3, -0.45 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, -0.2, 2.55, -0.112 ), ctlpt( E3, -0.4, 2.4, -0.224 ), ctlpt( E3, -1.3, 2.4, -0.728 ), ctlpt( E3, -1.3, 2.25, -0.728 ) ), list( ctlpt( E3, -0.002, 3, 0 ), ctlpt( E3, -0.45, 3, -0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, -0.112, 2.55, -0.2 ), ctlpt( E3, -0.224, 2.4, -0.4 ), ctlpt( E3, -0.728, 2.4, -1.3 ), ctlpt( E3, -0.728, 2.25, -1.3 ) ), list( ctlpt( E3, 0, 3, 0 ), ctlpt( E3, 0, 3, -0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0, 2.55, -0.2 ), ctlpt( E3, 0, 2.4, -0.4 ), ctlpt( E3, 0, 2.4, -1.3 ), ctlpt( E3, 0, 2.25, -1.3 ) ), list( ctlpt( E3, 0.002, 3, 0 ), ctlpt( E3, 0.45, 3, -0.8 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.112, 2.55, -0.2 ), ctlpt( E3, 0.224, 2.4, -0.4 ), ctlpt( E3, 0.728, 2.4, -1.3 ), ctlpt( E3, 0.728, 2.25, -1.3 ) ), list( ctlpt( E3, 0, 3, -0.002 ), ctlpt( E3, 0.8, 3, -0.45 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.2, 2.55, -0.112 ), ctlpt( E3, 0.4, 2.4, -0.224 ), ctlpt( E3, 1.3, 2.4, -0.728 ), ctlpt( E3, 1.3, 2.25, -0.728 ) ), list( ctlpt( E3, 0, 3, 0 ), ctlpt( E3, 0.8, 3, 0 ), ctlpt( E3, 0, 2.7, 0 ), ctlpt( E3, 0.2, 2.55, 0 ), ctlpt( E3, 0.4, 2.4, 0 ), ctlpt( E3, 1.3, 2.4, 0 ), ctlpt( E3, 1.3, 2.25, 0 ) ) ), list( list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2 ), list( 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 4 ) ) ); echosrc = true; Teapot = list( Body, Spout, Handle, Cap ); interact( Teapot, 0 );