from shapely import Point, LineString
from shapely.affinity import scale, translate

# quantum corral points inside a 1x1 grid
QUANTUM_CORRAL_POINTS = [
    Point(0.178, 0.07),
    Point(0.72, 0.337),
    Point(0.756, 0.354),
    Point(0.194, 0.341),
    Point(0.264, 0.372),
    Point(0.198, 0),
    Point(0.334, 0.4),
    Point(0.353, 0.038),
    Point(0.871, 0.418),
    Point(0.023, 0.24),
    Point(0.001, 0.276),
    Point(0.386, 0.107),
    Point(0.978, 0.47),
    Point(0.407, 0.143),
    Point(0.483, 0.153),
    Point(0.544, 0.191),
    Point(0.564, 0.227),
    Point(0.81, 0.124),
    Point(0.745, 0.242),
    Point(0.778, 0.27),
    Point(0.671, 0.256),
    Point(0.704, 0.299),
    Point(0.178, 1.019),
    Point(0.778, 0.689),
    Point(0.218, 0.07),
    Point(0.137, 0.07),
    Point(0.137, 1.019),
    Point(0.218, 1.019),
    Point(0.82, 0.689),
    Point(0.258, 0.07),
    Point(0.098, 0.07),
    Point(0.098, 1.019),
    Point(0.258, 1.019),
    Point(0.871, 0.672),
    Point(0.298, 0.07),
    Point(0.058, 0.07),
    Point(0.058, 1.019),
    Point(0.298, 1.019),
    Point(0.892, 0.639),
    Point(0.158, 0),
    Point(0.158, 1.089),
    Point(0.198, 1.089),
    Point(0.914, 0.606),
    Point(0.353, 1.051),
    Point(0.572, 0.4),
    Point(0.936, 0.572),
    Point(0.698, 0.4),
    Point(0.978, 0.619),
    Point(0.739, 0.4),
    Point(0.01, 0.098),
    Point(0.142, 0.299),
    Point(0.142, 0.79),
    Point(0.01, 0.991),
    Point(0.778, 0.4),
    Point(0.032, 0.132),
    Point(0.12, 0.265),
    Point(0.12, 0.824),
    Point(0.032, 0.957),
    Point(0.82, 0.4),
    Point(0.054, 0.166),
    Point(0.098, 0.232),
    Point(0.098, 0.858),
    Point(0.054, 0.924),
    Point(0.076, 0.199),
    Point(0.076, 0.891),
    Point(0.892, 0.45),
    Point(0.023, 0.849),
    Point(0.914, 0.483),
    Point(0.001, 0.813),
    Point(0.936, 0.517),
    Point(0.386, 0.983),
    Point(0.407, 0.946),
    Point(0.483, 0.937),
    Point(0.72, 0.753),
    Point(0.544, 0.899),
    Point(0.756, 0.735),
    Point(0.564, 0.862),
    Point(0.194, 0.748),
    Point(0.81, 0.965),
    Point(0.264, 0.718),
    Point(0.745, 0.848),
    Point(0.334, 0.689),
    Point(0.778, 0.819),
    Point(0.572, 0.689),
    Point(0.671, 0.833),
    Point(0.698, 0.689),
    Point(0.704, 0.791),
    Point(0.739, 0.689)
]

class QuantumCorral():
    def __init__(self, scale: float = 1.0, offset: Point = Point(0.0, 0.0)):
        self.scale = scale
        self.offset = offset
        self.quantum_corral_linestring = LineString([(p.x, p.y) for p in QUANTUM_CORRAL_POINTS])
        self.__transform_points()

    def __transform_points(self):
        self.quantum_corral_linestring = scale(self.quantum_corral_linestring, xfact=self.scale, yfact=self.scale, origin=(0,0))
        self.quantum_corral_linestring = translate(self.quantum_corral_linestring, xoff=self.offset.x, yoff=self.offset.y)

    def get_points(self):
        return self.quantum_corral_linestring