Chais

joined 2 years ago
[–] Chais 1 points 9 hours ago

Getting an explanation is one thing, getting a complete solution is another. Even if you then verify with a more suited tool. It's still not your solution and you didn't fully understand it.

[–] Chais 11 points 23 hours ago* (last edited 23 hours ago) (4 children)

Or, and hear me out on this, you could actually learn and understand it yourself! You know? The thing you go to university for?
What would you say if, say, it came to light that an engineer had outsourced the statical analysis of a bridge to some half baked autocomplete? I'd lose any trust in that bridge and respect for that engineer and would hope they're stripped of their title and held personally responsible.

These things currently are worse than useless, by sometimes being right. It gives people the wrong impression that you can actually rely on them.

[–] Chais 4 points 6 days ago

Spezifisch die CSU. Es gibt kein Niveau das die nicht unterbieten.

[–] Chais 1 points 6 days ago (2 children)

Not sure where you take the N from. Plus it's needlessly derogatory. How about FMAGA instead? Because F MAGA!

[–] Chais 5 points 6 days ago (1 children)

Wouldn't that be a great use case for a QR-code?

[–] Chais 1 points 1 week ago* (last edited 1 week ago) (1 children)

Didn't weigh them before drying because they were still on the branches. But post drying the flowers were very brittle and in the swamp bags the hygrometer initially showed <30% humidity. It eventually crept up to ~55% over the two week cure, thanks to the Boveda packs.

[–] Chais 2 points 1 week ago

Well, Wile E. Coyote, no? Road Runner just runs away.

[–] Chais 2 points 1 week ago

Ist ein schönes Land. Aber die Leute… 🙄

[–] Chais 2 points 1 week ago (3 children)

42,39g dry. Think I overdried it a little.

[–] Chais 2 points 2 weeks ago

Here's a wild idea: sit on the blunt side.
Yes, it still won't be comfortable, but I doubt sitting on a stick with your full weight is, either.

[–] Chais 1 points 2 weeks ago (1 children)

Yes, most times gamescope isn't required. Thing is, sometimes it is and not having the option is an inconvenience in the best case and makes games unplayable in the worst case.

[–] Chais 2 points 3 weeks ago (5 children)

My partner is currently running PopOS. They somehow managed to combine the chronically outdated Ubuntu packages with a rather counterintuitive UI.
Updates frequently fail, commonly used packages like gamescope aren't available, overall wouldn't recommend.

29
submitted 1 month ago by Chais to c/[email protected]
 

First tent-grow. Zkittlez OG Auto from Barney's Farm. Today marks day 70 since putting the seed into the peat pad. I expect maybe a week more. Two, tops.

12
Stuck on day 6, part 2 (self.advent_of_code)
submitted 6 months ago* (last edited 6 months ago) by Chais to c/[email protected]
 

I'm not looking for a solution or even code, just a hint. Here's what I currently do:

  1. Add the current position and heading to the recorded path
  2. Check if turning right would lead back onto the recorded path in the same direction we walked it before
  3. Check if the next field is obstructed
    1. If so, turn right
    2. Repeat until no longer blocked
  4. Update current position

This approach works fine for the unit test, but yields a result too low for the puzzle input. I tried adding recursion to the party check, but even 20 levels of recursion didn't sufficiently increase the amount of options found, suggesting I'm missing a mechanism to identify them.

Any clues?

Current state of affairs:

from math import sumprod
from operator import add
from pathlib import Path


def parse_input(input: str) -> list[list[int]]:
    return input.strip().splitlines()


def find_guard(world: list[list[int]]) -> tuple[int]:
    for y, line in enumerate(world):
        x = line.find("^")
        if x > -1:
            return (y, x)
    return (-1, -1)  # No guard


def turn(heading: tuple[int]) -> tuple[int]:
    mat = [(0, 1), (-1, 0)]
    return tuple([sumprod(col, heading) for col in mat])


def step(pos: tuple[int], heading: tuple[int]) -> tuple[int]:
    return tuple(map(add, pos, heading))


def is_blocked(world: list[list[str]], guard: tuple[int], heading: tuple[int]) -> bool:
    pos = step(guard, heading)
    try:
        return world[pos[0]][pos[1]] == "#"
    except IndexError:
        return False


def cast_ray(
    world: list[list[int]], start: tuple[int], heading: tuple[int]
) -> list[tuple[int]]:
    pos = step(start, heading)
    ray = []
    try:
        while world[pos[0]][pos[1]] != "#":
            ray.append(pos)
            pos = step(pos, heading)
    except IndexError:
        # Left the world
        ...
    return ray


def part_one(input: str) -> int:
    world = parse_input(input)
    guard = find_guard(world)
    heading = (-1, 0)
    while (
        guard[0] >= 0
        and guard[0] < len(world)
        and guard[1] >= 0
        and guard[1] < len(world[guard[0]])
    ):
        while is_blocked(world, guard, heading):
            heading = turn(heading)
        world[guard[0]] = f"{world[guard[0]][:guard[1]]}X{world[guard[0]][guard[1]+1:]}"
        guard = tuple(map(add, guard, heading))
    return sum([line.count("X") for line in world])


def part_two(input: str) -> int:
    world = parse_input(input)
    guard = find_guard(world)
    heading = (-1, 0)
    path = {}
    options = 0
    while (
        guard[0] >= 0
        and guard[0] < len(world)
        and guard[1] >= 0
        and guard[1] < len(world[guard[0]])
    ):
        path.setdefault(guard, []).append(heading)
        turned = turn(heading)
        if turned in path.get(guard, []) or turned in [
            d
            for p in set(cast_ray(world, guard, turned)).intersection(set(path.keys()))
            for d in path[p]
        ]:
            # Crossing previous path and turning would cause us to retrace our steps
            # or turning would lead us back into our previous path
            options += 1
        while is_blocked(world, guard, heading):
            heading = turned
        world[guard[0]] = f"{world[guard[0]][:guard[1]]}X{world[guard[0]][guard[1]+1:]}"
        guard = tuple(map(add, guard, heading))
    return options


if __name__ == "__main__":
    input = Path("input").read_text("utf-8")
    print(part_one(input))
    print(part_two(input))
26
100% Rye sourdough (sh.itjust.works)
submitted 8 months ago by Chais to c/[email protected]
 
 

Fermented with black cardamom and garlic (which I'm just noticing I forgot to put on the label 🤷) and puréed with mango and pear.
Added a little rice vinegar and salt to balance the fruit.
It's a little spicier than Sriracha, but not at all unpleasant. Nicely sweet and spicy. You can taste it with a spoon without regretting it.

 
 

I'm trying to get networkd to connect to a wireguard endpoint, specifically ProtonVPN, in case it matters. I just can't get it to connect. Has anyone had success with that? Specifically without using wg-quick.

 

Auf der Tastatur sitzen drückt Knöpfe. Knöpfe gedrückt halten macht warm. Happy Kitty.

18
submitted 1 year ago by Chais to c/pizza
 
44
WIP Wednesday update (sh.itjust.works)
submitted 1 year ago by Chais to c/[email protected]
 

Update since mid November. Finished the central panel of the cardigan. Started on the edge panel. 24 rows down, 488 to go.

 

Looking for someone to take over our lease for a 3 1/2 apartment in Petite-Patrie (H2S) starting February 1st 2024.
Lease goes until 31st of October 2024 with option of renewal.
Monthly rent is $1665 including hot water and parking behind the house (electric bill is extra).

The apartment was completely renovated in 2018 with new isolation, windows and doors. It is on the ground floor, very quiet and in walking distance to metro stations (Fabre and Beaubien), supermarkets, cafés and shops.
The bedroom and office both have built-in storage closets. You have full access to the garden in the back and can use it as you wish. Cats are no problem but you will have to check for other pets.
Appliances are NOT included in the lease and we bought them new in 2018 (Stove, fridge with freezer drawer, dishwasher, washing machine and dryer). All are good quality appliances (Whirlpool, Maytag) that work great and we'd prefer them taken over from us (price is negotiable).
All our furniture is also up for sale.

Please send me a message if interested.

https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/b1/b15abf7d-2828-4e00-ab1a-c3c5639e3260?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/76/760166c5-2421-4693-90fa-63658fff07cc?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/82/826354e8-a2e8-4246-8cb8-d831eeb1ef9f?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/e6/e6110cdd-c164-4e58-a83d-8f980e23ca5e?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/6f/6fb34ec2-cbc8-47da-9859-beaa414f3f6c?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/3e/3ef5d1ab-7c43-4edc-bcc8-afe22b2c4ce8?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/24/24b6ccd4-1159-48a8-a456-e5530561670c?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/7d/7d683809-d303-43fc-a78b-3e3677731aa2?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/9f/9f9c5d9c-fcc3-43f5-9395-350f4ff76015?rule=kijijica-640-webp
https://media.kijiji.ca/api/v1/ca-prod-fsbo-ads/images/6c/6cd0de76-e63b-4a7c-8e75-54b0d0dd6b5e?rule=kijijica-640-webp

 

Probably even more relevant than it was back then.

view more: next ›