
            <!DOCTYPE html>
            <html lang="en">
            <head>
                <meta charset="UTF-8">
                <meta name="viewport" content="width=device-width, initial-scale=1.0">
                <title>noconstraints : side view of cabinet with drawers in opposite directions3</title>
                <style>
                    table {
                        width: 100%;
                        border-collapse: collapse;
                    }
                    th, td {
                        padding: 10px;
                        text-align: left;
                        vertical-align: top;
                        border: none;
                    }
                    img {
                        max-width: 300px;
                        max-height: 300px;
                    }
                    td:hover {
                        background-color: #f1f1f1;
                    }
                </style>
            </head>
            <body>

                <h2><a href="../../noconstraints_with_clip_scores.html">noconstraints</a>/<a href="../../noconstraints_with_clip_scores.html#side view of cabinet with drawers in opposite directions">side view of cabinet with drawers in opposite directions</a>/side view of cabinet with drawers in opposite directions3</h2>
                <table>
                    <tbody>
                        <tr><td><h3>Image</h3></td><td><h3>Program</h3></td><td><h3>Conversation</h3></td></tr>
                        <tr>
                            <td><img src="../../images/noconstraints/side view of cabinet with drawers in opposite directions3.png" alt="side view of cabinet with drawers in opposite directions3 image"></td><h3><br>CLIP Score: 31.71</h3>
                            <td>
                <pre>
                
from AIDL import *

def cabinet_with_drawers(
        height: float = 3.0 * feet,
        width: float = 1.5 * feet,
        depth: float = 2.0 * feet,
        num_drawers: int = 4,
        drawer_height: float = 0.5 * feet
):
    """
    Creates a side view of a cabinet with drawers that open in opposite directions.
    """

    # Define the Solid structure for the cabinet.
    cabinet = Solid()

    # Define the main body of the cabinet.
    cabinet.body = Rectangle((0, 0), width, height, axis_aligned=True)

    # Create the drawer Solid structures and add them to the cabinet.
    for i in range(num_drawers):
        drawer = Solid(shift=(0, (i * drawer_height) - (height / 2 - drawer_height / 2)))
        setattr(cabinet, f"drawer_{i}", drawer)

        # Drawer front as a rectangle.
        drawer.face = Rectangle((0, 0), width, drawer_height, axis_aligned=True)

        # Drawer handle as a hole.
        handle_shift_x = -width / 4 if i % 2 == 0 else width / 4
        drawer.handle = Hole(shift=(handle_shift_x, 0))
        drawer.handle.hole = Circle((0, 0), 2 * inches)

    return cabinet

with AIDL_2D:
    model = cabinet_with_drawers()
print(model.Solve())
model.Render()

                </pre>
                </td>
                <td>
                <pre>
                Please write an AIDL program to generate a side view of cabinet with drawers in opposite directions

Sure, let's break down the task of creating a side view of a cabinet with drawers that open in opposite directions step-by-step:

1. We'll start by defining the overall shape of the cabinet.
2. We'll add the drawers inside the cabinet, ensuring they are oriented to open in opposite directions.
3. We'll structure the AIDL program by defining the necessary solids and holes, and by specifying how they fit together.

Let's define some parameters for customization:
- Overall height `height`
- Overall width `width`
- Overall depth `depth`
- Number of drawers `num_drawers`
- Drawer height `drawer_height`

Here is the complete AIDL program:

```python
from AIDL import *

def cabinet_with_drawers(
        height: float = 3.0 * feet,
        width: float = 1.5 * feet,
        depth: float = 2.0 * feet,
        num_drawers: int = 4,
        drawer_height: float = 0.5 * feet
):
    """
    Creates a side view of a cabinet with drawers that open in opposite directions.
    """

    # Define the Solid structure for the cabinet.
    cabinet = Solid()

    # Define the main body of the cabinet.
    cabinet.body = Rectangle((0, 0), width, height, axis_aligned=True)

    # Create the drawer Solid structure and add it to the cabinet.
    drawers = [Solid(shift=(0, i * drawer_height - height / 2)) for i in range(num_drawers)]
    for i, drawer in enumerate(drawers):
        cabinet.add_child(drawer)

        # Drawer front as a rectangle.
        drawer.face = Rectangle((0, 0), width, drawer_height, axis_aligned=True)
        
        # Drawer handle as a hole.
        if i % 2 == 0:
            # Drawers that open to the left
            drawer.handle = Hole(shift=(-width / 4, 0))
        else:
            # Drawers that open to the right
            drawer.handle = Hole(shift=(width / 4, 0))

        drawer.handle.hole = Circle((0, 0), 2 * inches)

    return cabinet

with AIDL_2D:
    model = cabinet_with_drawers()
print(model.Solve())
model.Render()
```

### Explanation:
1. **Cabinet Body**: A rectangle that represents the main body of the cabinet.
2. **Drawers**: A list of `Solid` structures representing each drawer. Each drawer is shifted vertically to stack them.
3. **Drawer Front**: Each drawer has a rectangle representing the front face.
4. **Drawer Handle**: Each drawer has a circular hole for the handle. Drawers are alternately shifted to different sides to symbolize opening in opposite directions.

This program will provide a side view of a cabinet where drawers open in opposite directions. If you have specific requirements or further customizations, feel free to specify!

Traceback (most recent call last):
  File "/net/projects/ranalab/jz/aidl/AIDL/generation/backend.py", line 21, in dumbrun
    exec(code, env)
  File "<string>", line 42, in <module>
  File "<string>", line 24, in cabinet_with_drawers
  File "/net/projects/ranalab/jz/aidl/AIDL/structure.py", line 1242, in __getattr__
    return self.bb.__getattribute__(name)
AttributeError: 'BoundingBox' object has no attribute 'add_child'


I apologize for that mistake. In AIDL, you should add structures using direct attribute assignment rather than a method call like `add_child`. Let's correct that and ensure we structure our program properly. Here is the revised version:

```python
from AIDL import *

def cabinet_with_drawers(
        height: float = 3.0 * feet,
        width: float = 1.5 * feet,
        depth: float = 2.0 * feet,
        num_drawers: int = 4,
        drawer_height: float = 0.5 * feet
):
    """
    Creates a side view of a cabinet with drawers that open in opposite directions.
    """

    # Define the Solid structure for the cabinet.
    cabinet = Solid()

    # Define the main body of the cabinet.
    cabinet.body = Rectangle((0, 0), width, height, axis_aligned=True)

    # Create the drawer Solid structures and add them to the cabinet.
    for i in range(num_drawers):
        drawer = Solid(shift=(0, (i * drawer_height) - (height / 2 - drawer_height / 2)))
        setattr(cabinet, f"drawer_{i}", drawer)

        # Drawer front as a rectangle.
        drawer.face = Rectangle((0, 0), width, drawer_height, axis_aligned=True)

        # Drawer handle as a hole.
        handle_shift_x = -width / 4 if i % 2 == 0 else width / 4
        drawer.handle = Hole(shift=(handle_shift_x, 0))
        drawer.handle.hole = Circle((0, 0), 2 * inches)

    return cabinet

with AIDL_2D:
    model = cabinet_with_drawers()
print(model.Solve())
model.Render()
```

### Changes:
1. **Corrected Attribute Assignment**: Used `setattr` to dynamically assign drawer attributes to the cabinet.
2. **Handles Placement**: Correctly shifted handles based on the index to alternate between left and right.

Try this version and let me know if you encounter any further issues or if you need additional adjustments!


                </pre>
                </td>
                </tr>
                </tbody>
                </table>
                </body>
            </html>
            