2019-06-06 09:58:14 +03:00
|
|
|
|
-- Example 17, pulled from our benchmarking suite.
|
2019-12-31 18:44:22 +03:00
|
|
|
|
import Prelude ((<$>), ($), zip3, fmap, fromIntegral, (*), (/))
|
2019-12-31 17:26:37 +03:00
|
|
|
|
import Graphics.Implicit (union, translate, rect3R, writeSTL)
|
|
|
|
|
import Graphics.Implicit.Definitions (Fastℕ, ℝ, ℝ3, SymbolicObj3)
|
2019-06-06 09:58:14 +03:00
|
|
|
|
|
|
|
|
|
default (Fastℕ, ℝ)
|
|
|
|
|
|
|
|
|
|
object2 :: SymbolicObj3
|
2020-12-05 12:25:01 +03:00
|
|
|
|
object2 = squarePipe (10, 10, 10) 1 100
|
2019-06-06 09:58:14 +03:00
|
|
|
|
where
|
2019-12-31 17:26:37 +03:00
|
|
|
|
squarePipe :: ℝ3 -> ℝ -> ℝ -> SymbolicObj3
|
2019-06-06 09:58:14 +03:00
|
|
|
|
squarePipe (x,y,z) diameter precision =
|
|
|
|
|
union
|
2020-12-05 12:25:01 +03:00
|
|
|
|
((\start -> translate start
|
|
|
|
|
$ cubeR 0 False (diameter, diameter, diameter)
|
2019-12-31 20:18:25 +03:00
|
|
|
|
)
|
|
|
|
|
<$>
|
2020-12-05 12:25:01 +03:00
|
|
|
|
zip3 (fmap (\n -> (fromIntegral n / precision) * x) [0..100])
|
|
|
|
|
(fmap (\n -> (fromIntegral n / precision) * y) [0..100])
|
|
|
|
|
(fmap (\n -> (fromIntegral n / precision) * z) [0..100]))
|
2019-06-06 09:58:14 +03:00
|
|
|
|
|
|
|
|
|
main = writeSTL 1 "example17.stl" object2
|