69 comments

  • nullhole 14 hours ago

    > It then set the name of a channel to the results (either 1-person-in-upl or X-people-in-upl), which others could check.

    I'm not suggesting you don't do this, but you /could/ setup a speaker to play the classic remix of Steve Ballmer's "developers! developers!" whenever there are >=2 people in the room. On April 1st, of course.

    • cptaj 13 hours ago

      I am, in fact, suggesting you do this.

      • alwayslikethis 11 hours ago

        > I'm not suggesting you don't do this

        I hope this is intentional

        • nullhole 6 hours ago

          >> I'm not suggesting you don't do this

          > I hope this is intentional

          I mean, it's not unintentional..

      • eduction 11 hours ago

        I love this company. Yeah!

  • withinrafael 12 hours ago

    I saw "over-engineering" in the title and half expected to see Wi-Fi signals being abused to detect human bodies in the room.

    https://arxiv.org/abs/2301.00250

  • alkh 15 hours ago

    I swear to God that all of these CS labs at different unis look the same. I am getting flashbacks of labs in Toronto that looked exactly like pictures in the post

    • whimsicalism 14 hours ago

      even the physics labs i worked in looked like this

      • chaboud 13 hours ago

        The physics computer lab in Chamberlin Hall at UW in the 90's was a secret treasure trove of idle NeXTstation Turbo machines in an almost always empty room cooled to near refrigeration temperatures. I used to light up at least half of that room to run distributed simulations. There's probably still a 30 year old key to that lab in a junk drawer somewhere.

        Eventually I realized that it just made sense to suck it up and get my own hardware, as it was either going to be esoteric "workstation" hardware with a fifth of the horsepower of a Pentium 75 or it was going to be in a room like the UPL jammed with CRT's and the smell of warm Josta.

        How do students operate these days? Unless one is interacting with hardware, I'd be very tempted to stay in "fits on a laptop" space or slide to "screw it, cloud instances" scale. Anyone with contact in the last 5 years have a sense of how labs are being used now?

        • hansvm 11 hours ago

          It's been nearly a decade now, but we shared a machine with 128 newish physical cores, a terabyte of RAM, and a lot of fast disk. Anyone with a big job just coordinated with the 1-2 other people who might need it at that level and left 10% of the RAM and disk for everyone else (OS scheduling handled the CPU sharing, though we rarely had real conflicts).

          It's firmly in "not a laptop" scale, and for anything that fit it was much faster than all the modern cloud garbage.

          The other lab I was in around that time just collected machines indefinitely and allocated subsets of them for a few months at a time (the usual amount of time a heavily optimized program would take to finish in that field) to any Ph.D. with a reasonable project. They all used the same in-house software for job management and whatnot, with nice abstractions (as nice as you can get in C) for distributed half-sparse half-dense half-whatever linear algebra. You again only had to share between a few people, and a few hundred decent machines per person was solidly better than whatever you could do in the cloud for the same grant money.

        • alkh 12 hours ago

          In my university you could technically use any computer but must ensure that your code would work/compile on lab PCs cause that's where TAs would check it. As a result, during labs most people would just use computers there(too much hassle otherwise)

        • whimsicalism 12 hours ago

          > Unless one is interacting with hardware, I'd be very tempted to stay in "fits on a laptop" space or slide to "screw it, cloud instances" scale. Anyone with contact in the last 5 years have a sense of how labs are being used now?

          In my recent physics experience, this is basically what it was unless you had to rely on some proprietary software only on the lab machines like shudders LabView

        • amosesdev 13 hours ago

          I can only speak for the UPL, but, yeah, it was a hallmark of labs at the time that one of the benefits you were getting was the equipment. Nowadays, most people just come in with their laptops -- we have a kubernetes cluster for projects, but most of the actual computing equipment is brought in by students when they want to hang

        • AStonesThrow 12 hours ago

          I went through community college about 6 years ago. And they still had bona fide computer labs with in-person tech support.

          Computers were also ubiquitous in places like the coffeehouse, the library, practically every classroom, etc. And, of course, there were ubiquitous WiFi and USB charging ports, so that students with BYOD could get by (although WiFi was often overloaded and contentious.)

          Within the main computer lab I was using, there was also a networking hardware lab, with genuine Cisco equipment such as routers and switches. The Cisco certification prep classes would go in there and do experiments on the hardware, so that students could get accustomed to seeing it in action, however outdated it may be.

          The lab itself was chock-a-block with both Apples and Windows PCs, as well as scanners and printers available, and even headphones you could borrow from the desk attendant. You'd need to sign in and sign out. There were strict rules about silence and not leaving your station unattended. There was always space for more users and a generally relaxed atmosphere, where people could feel comfortable studying or doing homework.

          I believe that there was also an A/V lab where students could get access to cameras and recording equipment, as well as software for that kind of thing.

          The library, in addition to allocating lots of space for Windows PCs and Apples, would also loan out Chromebooks to any student, and I believe they had other things for loan, such as WiFi hotspots, for kids who couldn't afford to carry around their own Internet.

          There were also Tutoring Centers, such as the Math one, where most of the desks featured a computer where you could log in to your collegiate account, and access your online course materials.

          And the Testing Center was essentially a big computer lab, with cameras and in-person proctors monitoring it. It was partnered with Pearson and CompTIA, so I took more than one certification exam in there.

          There is a fully-staffed IT Help Center on campus, so during office hours, you could count on a 1:1 in-person interaction to help you get logged in, debug your device's WiFi, or whatever.

          Despite having a great computer setup in the comfort of my own home, and plenty of online courses on my schedule, I still appreciated the immersion of collegiate computer labs, and especially the relaxed coffeehouse access, where I could use Apple systems to work on my English homework and essays.

          During the COVID-19 pandemic, all this went topsy-turvy, and a lot of these labs closed down, or took extreme health precautions, and of course, a lot more classes went online-only. But I was done with classes by that time.

    • kredd 11 hours ago

      That's exactly what I thought! "Is that UofT?"

  • zdw 13 hours ago

    Back in the 90's we used finger - IIRC it would tell you the last machine someone logged into, which could be in the lab

    Someone wrote a script to finger everyone in the entire CS department and tell when the lab was busy, by counting people logged in.

    This work fine, except for on intro courses where some labs had lots of non-CS majors in them.

    • bks 13 hours ago

      I had finger running on login to `finger stacy` I was at SDSU on a very large SunOS system and she was at a private school and I assume that computer was a bit more limited.

      `Finger Stacy` would run every minute and typically be running for 15 minutes max... that is until I moved into the dorms and my machine was online all the time.

      A few weeks go by and I get an email from the SDSU admin requesting that I stop fingering stacy as it was bothering the other Sysadmin. I remarked with a grin that all I was trying to do was in fact try to `name of the command` and they promptly deleted the script from the account.. It still makes me smile as I write this.

      • hotspot_one 8 hours ago

        fdisk or mount?

        • elcritch 7 hours ago

          Sincerely doubt he had permissions for either operation. ;)

          • vasco 3 hours ago

            Everyone knows the right order of commands is date, finger, mount.

  • zimpenfish 2 hours ago

    Back in the man.ac.uk of the early 90s, there were no cameras or YOLO models but we still wanted to know when machines (especially the colour ones! LUXURY!) were available.

    We just had "`rlogin` to every machine in the lab, run `who`, and collate the output". IIRC there was an early version written by 'flup that I extended with a tidier output (including an X11 window), auto-refreshing, and easier machine selection (eg. you could select rooms by name with regex filtering.)

    Good times.

  • zanchey 9 hours ago

    The University Computer Club at UWA also has a door sensor!

    https://door-status.ucc.asn.au/ucc

    Runs off a Raspberry Pi with a bodged-up version of https://github.com/ide/pico-door-sensor/tree/main

    This is at least the third iteration; some previous iterations are documented here:

    https://www.ucc.asn.au/services/door.ucc

    • dbetteridge 9 hours ago

      Still works better than the uwa door card readers

  • rithikjainNd01 14 hours ago

    UW Madison UPL on Hacker News! Great to see, you guys are awesome!

  • urbandw311er 13 hours ago

    Another state of the art people counting system would be ultra wideband. It can literally count the number of heartbeats in a room. See https://m.youtube.com/watch?v=adiUegDxZEs

  • preston4tw 3 hours ago

    room presence detection has been a long standing challenge in the smart home / home assistant community. it's cool to see home assistant used and adapted for this use case.

  • neilparikh 12 hours ago

    I built a similar system for my school’s CS club. I considered using a door sensor, but the eventual solution I settled on was a light sensor, because it’s almost always true for us that the lights are on iff the door is open.

    This way, we don’t need to mount anything on the door, we just have a microcontroller plugged into one of the machines.

    Our previous solution was a webcam that pointed to the lights that did a similar thing (implemented by someone before my time) but then it stopped working due to some driver issues, and I didn’t want to spend time investigating them.

  • changexd 7 hours ago

    Very interesting and fun read! thanks for the post, when I saw the public restful api endpoint I immediately tried to see if I can make request just to see the "NICE TRY!" message, haha, then I kept on reading how you managed this issue.

  • kleiba 3 hours ago

    This would be a nightmare to implement from a legal standpoint in Europe.

  • djsavvy 14 hours ago

    Neat to see discord channel names being used as an information channel.

    • thrdbndndn 9 hours ago

      It's a common practice/trick in Discord communities (particularly gaming) to pin some status, but yeah, I always find it neat.

  • TrackerFF 10 hours ago

    My first thought was to put some motion sensors inside the room, along with a sensor for the door (open/closed), as well as some sensor for counting the people walking through the door. Maybe even some co2 sensor to detect changes.

  • teddarific 14 hours ago

    This is neat. I worked on something similar to college where we built an app to track how long the line was at a popular cafe. We set up a camera + raspberry pi in the cafe and tried to the number of people. There was a lot of noise from overlapping people, random people walking in and out of line, etc. Cool seeing all the techniques and approaches you tried!

  • _visgean 12 hours ago

    In edinburgh we had this: https://devpost.com/software/the-marauder-s-app which showed who was using which computer based on logins.

  • fartfeatures 9 hours ago

    Point the camera at the door, use the camera to detect if the door is open.

    • grahamj 7 hours ago

      Mount the camera on the door facing down and watch for a moving floor

  • mdberkey 9 hours ago

    Love to see the UPL on hacker news :)

  • iwontberude 15 hours ago

    I have a stealth startup that designs privacy first solutions to share coarse data about what is inside of rooms without disclosing secrets. This is useful for many use cases, from detecting the number of people in a room to other motion sensing devices which are critical for health and human safety. Patents are pending.

    • bobbiechen 14 hours ago

      That's great! It does feel like cameras generally collect more data than necessary for some purposes. I have a friend who works at Butlr, which uses thermal sensors to detect body heat (and avoid the privacy risks of cameras) - sounds like your startup is in a similar space.

      I know you mentioned patents pending, but is there anything you can share about your approach?

  • fullstackchris 15 hours ago

    Love the motivation! Reminds me of the first stuff I built back in my university days.

    One thing from and old cranky dev that I notice: it would seem the yml you post has redundancies: either have 4 endpoints, no payload or 4 different payloads, one endpoint (the endpoint itself can tell you what you need to do) However, from the express script it looks like you arrived at this in the final solution anyway. Not sure if I missed something though, is there a reason the API needs such a shape? Cheers!

    • amosesdev 15 hours ago

      Hi! Author here. The yml is from a configuration in Home Assistant. Whenever it received an event from the sensors, it would fire the corresponding POST request (which you have to specify ahead of time, hence the configuration being a little redundant). The main reason for switching to the Express setup is that I was having a few random people look at the code & send their own requests to fudge what the status appeared as. I could have added some security/authentication to the endpoints, but I liked the idea of having the frontends simply querying the site (or my proxy) instead of having to cache a POST request.

      • grahamj 7 hours ago

        You can read and write HA entities via HTTP API so I think you could have done this with nothing but HA, but either way it's a fun project :)

        One of my more fun HA project was scraping my snow removal service's tractor tracking API and passing the result for the closest tractor into HA so I can be notified (by voice with Alexa and/or push notification) when there's one nearby in case I need to move the car.

        • amosesdev 5 hours ago

          Do you mean outside of the API that I talk about in the article? If I exposed the HA API via the frontend, users would be able to just take the bearer token and do whatever they wanted with it (even deleting the entities used for the doors). That's why the express server is sitting in the middle to only expose the relevant information (proxying w/ the bearer token, which the end users have no access to)

  • readthenotes1 15 hours ago

    Scotch tape. Those poor students couldn't afford duct tape!

    • ethbr1 13 hours ago

      These are CS students, not MEs.

      Which is to say, heathens who have yet to accept our lord and savior Duct into their hearts. (And its latter day saint WD-40)

  • davidteather 13 hours ago

    UPL UPL UPL UPL

  • moralestapia 14 hours ago

    Nice project but it could be illegal. Check your jurisdiction.

    Source: have done similar hobby projects for fun, which turned out to be illegal.

    • soggybread 14 hours ago

      What part of this would be illegal? It's just a zigbee door sensor. The only issue I could see is the college getting upset but if anything they'd just say 'take it down'

      • whimsicalism 14 hours ago

        object detection of people from images is probably what they are referring to. there are maybe some state laws that could be stretched to include that but i would say presumptively legal

        • ninju 13 hours ago

          The final solution does not depend on object (people) detection. In fact by the end of the article he has totally eliminated the camera

          • oniony 12 hours ago

            Doors have rights too!

    • alexchantavy 14 hours ago

      Bunch of restaurants use those fancy Nest cams that remember faces. Is this illegal too? Feels like it should be controlled in some way.

      • moralestapia 14 hours ago

        >Feels like it should be controlled in some way.

        It is. Check your jurisdiction.

    • whimsicalism 14 hours ago

      this isn't facial recognition

      • moralestapia 14 hours ago

        ???

        Who's talking about that?

        • whimsicalism 14 hours ago

          why would it be illegal?

          • moralestapia 14 hours ago

            Generally, you cannot just record people without their consent; but this also largely depends on the jurisdiction/situation.

            Almost nowhere (or actually nowhere?) are you allowed to set up a surveillance device into a space that is not public and it is not owned by you.

            • packetlost 14 hours ago

              Public university labs are generally public as they're state property (in this particular case, UW Madison is a public state University). Further, recording video or pictures of people in public places is broadly legal in the US. There are only "presumption of privacy" restrictions which apply to places such as bathrooms and private property that is not visible from a public location (ex. a sidewalk).

              Obv. IANAL and this is not legal advice.

              • almostgotcaught 13 hours ago

                By this logic the dorm room bathrooms at public universities are also public and I should be able to setup cameras /s

                • ozzmotik 11 hours ago

                  just for the sake of conversation…

                  if you did, where would you have set them up at anyway? Asking for a friend

              • moralestapia 14 hours ago

                >Public university labs are generally public as they're state property

                Wrong. They're state property, you even wrote it there.

                >Obv. IANAL

                Obv.

                • icehawk 8 hours ago

                  And thus they'd fall under the legal definition of public: "Under the authority of the government or belonging and available to the people."

                  or

                  "of or relating to a government"

                • jrflowers 12 hours ago

                  This reasoning makes sense. Roads and parks aren’t public, as they are city property. “Public” is only when something has no legal owner, like the moon and stars, or love.

                • exe34 13 hours ago

                  what do you think public mean, they have to belong to Mr. P. Ublic?

            • samatman 11 hours ago

              Generally, in the United States, you can, in fact, just record people. Legally speaking, that is, which doesn't make it a polite or cool thing to do. Necessarily.

              If you're on someone else's property, they can of course set any number of rules, and trespass those who break those rules. But even there, recording people, if against the rules, is still not a crime. The crime is trespass, if this journalist we're speaking of sticks around after being trespassed off the property.