• fubo@lemmy.world
    link
    fedilink
    arrow-up
    199
    ·
    11 months ago

    Meanwhile over in the mechanical engineering department, someone is complaining that they have to learn physics when they just wanted to build cool cars.

  • Lakso@ttrpg.network
    link
    fedilink
    arrow-up
    108
    arrow-down
    6
    ·
    11 months ago

    …then don’t study computer science. I study CS and it’s annoying when someone in a more math/logic oriented course is like “If I get a job at a tech company I won’t need this”. All that IS computer science, if you just wanna code, learn to code.

    • Zetaphor@zemmy.cc
      link
      fedilink
      English
      arrow-up
      50
      arrow-down
      1
      ·
      11 months ago

      The problem is a lot of people who want to learn to code, and are conditioned to desire the college route of education, don’t actually know that there is a difference and that you can be completely self-taught in the field without ever stepping foot in a university.

      • QuazarOmega@lemmy.world
        link
        fedilink
        English
        arrow-up
        15
        ·
        11 months ago

        I always wanted to believe this, but, at least in my country, not even a specialized high school degree is enough to get me anywhere for months, it’s crazy.
        Maybe you could even make it without formal education, but everyone’s always looking for those sweet 3+ years of experience in the field (ಥ﹏ಥ)

        • Zetaphor@zemmy.cc
          link
          fedilink
          English
          arrow-up
          6
          ·
          11 months ago

          I certainly experienced this at the start of my career. Everyone wanted me to have at least bachelors degree despite the fact that I was able to run circles around fresh college graduates. It wasn’t until someone gave me a chance and I had real world experience that people stopped asking me about my college education. In fact later into my career when they learn about the level of experience I have and that I’m entirely self-taught, it’s often seen as something positive. It’s a shitty catch-22

          • QuazarOmega@lemmy.world
            link
            fedilink
            English
            arrow-up
            1
            ·
            11 months ago

            So it really is like that eh?
            Do you have any tips for what could help me, even a little bit, to have better chances?

            • Zetaphor@zemmy.cc
              link
              fedilink
              English
              arrow-up
              4
              ·
              11 months ago

              Build an open source portfolio. Being able to show employers what I was capable of was a massive benefit both then and now. You can say you know all of these things, but when you’re looking at hundreds of applications one of the first things they do to reduce the pile is filter out people who don’t have some kind of online presence like Github. This allows them to see that you’re actively engaged with the field and if they want to interview you, to look at your code quality and experience.

              A personal website that highlights your best work is also a good idea, as it helps to even further distill down the things you’re ultimately going to end up talking about in an interview. It doesn’t need to be anything fancy, just something that shows your competent. I wouldn’t expect the person interviewing you to actually hit view source and criticize your choice in frontend framework.

              • QuazarOmega@lemmy.world
                link
                fedilink
                English
                arrow-up
                1
                ·
                11 months ago

                Yeah, I do that actually, though I keep a “serious” profile where there’s little activity and another one where I can just do whatever so I engage a lot more with other projects and make some experiments for myself, so it also ends up being the most active, but I don’t show it, maybe I should?

                In my experience interviewers look very pleased when I show them what I made, but they don’t seem to dig into it much most of the time, so I don’t know how important they really find it.
                I’ll definitely try to put more emphasis on those anyway, so they can see a good showcase.

                A personal website that highlights your best work

                That sounds interesting, I’ll definitely try that, thanks!

                • Zetaphor@zemmy.cc
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  ·
                  11 months ago

                  Just a heads up, you replied multiple times to this. If the client you’re using doesn’t submit immediately, that just means it’s not doing error handling properly and not disabling submit buttons while the request is in flight. You’ve actually submitted once for each time you pressed the button

              • Faresh
                link
                fedilink
                English
                arrow-up
                1
                ·
                11 months ago

                Without any prior professional experience, is an extensive open-source/[other non-professional software development related experience] portfolio perceived as more valuable than a degree to employers?

                • Zetaphor@zemmy.cc
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  ·
                  11 months ago

                  That entirely depends on the employer, but in my anecdotal experience that has been the case. Especially in more recent years versus the start of my career (nearly 20 years ago).

                  The reality is that Computer Science is useful for building strong engineers over the long-term, but it doesn’t at all prepare you for the reality of working in a team environment and contributing code to a living project. They don’t even teach you git as far as I’m aware.

                  Contributing to open source demonstrates a lot of the real-world skills that are required in a workplace, beyond just having the comprehension and skill in the language/tool of choice you’re interviewing for.

      • oce 🐆@jlai.lu
        link
        fedilink
        English
        arrow-up
        18
        arrow-down
        4
        ·
        11 months ago

        We’re not closing schools despite having libraries and the internet, having (good) teachers is useful to learn faster and get pushed further. There are some good programming schools that can make it more efficient for you. I think the main problem is rather the insane cost of higher education in the USA which create anxiety about being certain that you can repay it in the future it may open for you. It is sad.

    • Neato@kbin.social
      link
      fedilink
      arrow-up
      22
      arrow-down
      2
      ·
      11 months ago

      Can you get well paying coding jobs with upward mobility without at least a BA in CS?

      • AnarchoYeasty@beehaw.org
        link
        fedilink
        arrow-up
        20
        arrow-down
        1
        ·
        11 months ago

        It’s harder to break into but I make 150k and barely graduated high school. Software engineering is largely a field that doesn’t care about degrees but about ability. It’s harder these days to break into the field than it was 10 years ago when I did but it’s absolutely still possible

        • Tavarin@lemmy.world
          link
          fedilink
          arrow-up
          20
          arrow-down
          1
          ·
          11 months ago

          When I was looking for coding jobs with a decent portfolio, but no computer science degree I got 1 interview out of 300 applications. They absolutely will not look at you if you don’t have the CS degree, or already know someone at the company who can force you in.

          • Zetaphor@zemmy.cc
            link
            fedilink
            arrow-up
            3
            ·
            11 months ago

            This is also just the reality of the job market, especially in this industry. Dev positions get hundreds if not thousands of applications which all vary widely in quality.

            I have 20 years of experience and a six figure salary, the last time I went looking for work and was putting out applications I sent out easily over 100 applications and only had 4 interviews. I’ve found it’s best to form a relationship with a competent recruiter, and work with them anytime you’re back on the market. They’re incentivized to find you a decent position so that they can make their commission. Of course finding one that is decent is almost as hard as the process of sending out applications, but once you do it’s a relationship worth maintaining.

        • itsJoelle@lemmy.world
          link
          fedilink
          English
          arrow-up
          3
          ·
          11 months ago

          I can agree with this. Landed my first dev job after working as a tradesman for a decade, but I liked computers enough to learn on my own. My ‘trade’ offered a ‘unique persepective,’ I guess.

      • fred
        link
        fedilink
        arrow-up
        9
        ·
        11 months ago

        I have a fine arts degree and I’m a lead dev 🤷‍♂️

          • CallumWells
            link
            fedilink
            arrow-up
            5
            ·
            11 months ago

            It’s all ASCII art, but it runs like shit ;P More seriously; what constitutes beautiful code is very open to interpretation. Someone would say that a single line of list comprehension expression is beautiful while another would say the same thing expressed over several lines making the logic abundantly clear is beautiful.

      • oce 🐆@jlai.lu
        link
        fedilink
        arrow-up
        7
        arrow-down
        1
        ·
        11 months ago

        Maybe not what you’re asking but people with a non-CS M.Sc or PhD commonly switch to coding, especially in the data fields.

      • Regular Human@lemmy.world
        link
        fedilink
        arrow-up
        4
        ·
        11 months ago

        Anecdotally, I have an associates degree in horticulture and am currently the engineering lead for a team of six

      • breakfastburrito@sh.itjust.works
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        11 months ago

        I used to work at a small tech company (5-10 employees) and when we hired for entry level coders we’d receive hundreds of applications. Most of them would be grads from bootcamps, some with undergraduate degrees and some without. My boss would just throw out any that didn’t have a bs in something, but preferred a stem degree. He knew they didn’t need a degree, he knew you didn’t need actual coding experience, it was just a quick (maybe illegal) way to make that list of applications more manageable. Edit: as other people have said - after your first job you are basically “in” and are a very desirable candidate. Your education matters much less after your first job.

      • sheepyowl@lemmy.sdf.org
        link
        fedilink
        arrow-up
        2
        ·
        11 months ago

        If you entered the field 10 years ago, sure. If you’re trying to enter the field now, I have bad news…

      • Zetaphor@zemmy.cc
        link
        fedilink
        English
        arrow-up
        2
        ·
        edit-2
        11 months ago

        I’ve never been to college and my job title today is Software Architect, I’ve been doing this for nearly 20 years.

        It was extremely hard at first to get a job because everyone wanted a BA, but that was also 20 years ago. Once I had some experience and could clearly demonstrate my capabilities they were more open to hiring me. The thing a degree shows is that you have some level of experience and commitment, but the reality is a BA in CompSci doesn’t actually prepare you for the reality of 99% of software development.

        I think most companies these days have come to realize this. Unless you’re trying to apply to one of the FANG corps (or whatever the acronym is now) you’ll be just fine if you have a decent portfolio and can demonstrate an understanding of the fundamentals.

    • cosmicboi@lemmy.world
      link
      fedilink
      arrow-up
      4
      ·
      11 months ago

      I would have done CS if every math class at my school didn’t have 500 people in it. Even college algebra. They basically made everything a weed-out class

      I do think many of the CS concepts are pretty cool :)

    • panCat@lemmy.world
      link
      fedilink
      arrow-up
      3
      ·
      11 months ago

      Well what i felt working at a tech company that there are instances where we run into specific problems those may need to devise an algo ,and most of my non computer science peers fail to understand why!!

    • Zetaphor@zemmy.cc
      link
      fedilink
      arrow-up
      10
      ·
      11 months ago

      I was interviewed with complex logic problems and a rigorous testing of my domain knowledge.

      Most of what I do is updating copy and images.

  • where_am_i@sh.itjust.works
    link
    fedilink
    arrow-up
    77
    arrow-down
    5
    ·
    11 months ago

    A few failed exams later you end up programming cyberpunk and since you’re so oblivious to algorithms’ complexity it becomes a meme not a game.

    • Chadus_Maximus@lemmy.zip
      link
      fedilink
      arrow-up
      37
      ·
      11 months ago

      But it’s ok because now Nvidia has to deal with your garbage code due to Cyberpunk being the only game that supports the latest graphics tech.

    • jakoma02@czech-lemmy.eu
      link
      fedilink
      arrow-up
      50
      arrow-down
      1
      ·
      11 months ago

      The point of these lectures is mostly not to teach how to work with Turing machines, it is to understand the theoretical limits of computers. The Turing machine is just a simple to describe and well-studied tool used to explore that.

      For example, are there things there that cannot be computed on a computer, no matter for how long it computes? What about if the computer is able to make guesses along the way, can it compute more? Because of this comic, no — it would only be a lot faster.

      Arguably, many programmers can do their job even without knowing any of that. But it certainly helps with seeing the big picture.

      • Riskable@programming.dev
        link
        fedilink
        arrow-up
        10
        arrow-down
        3
        ·
        11 months ago

        Arguably, a much more important thing for the students to learn is the limits of humans. The limits of the computer will never be a problem for 99% of these students or they’ll just learn on the job the types of problems they’re good at solving and the ones that aren’t.

        • SkyeStarfall@lemmy.blahaj.zone
          link
          fedilink
          arrow-up
          11
          arrow-down
          1
          ·
          11 months ago

          The limits of computers would be the same as the limits for humans. We have no reason to think the human brain has a stronger computation power than a Turing machine.

          So, in a way, learning about the limits of computers is the exact same as learning the limits of humans.

          But also, learning what the limits of computers are is absolutely relevant. You get asked to create an algorithm for a problem and its useful to be able to figure out whether it actually is solvable, or how fast it theoretically can be. Avoids wasting everyone’s time trying to build an infinite loop detector.

          • Riskable@programming.dev
            link
            fedilink
            English
            arrow-up
            6
            arrow-down
            1
            ·
            11 months ago

            The “limits of humans” I was referring to were things like:

            • How long can you push a deadline before someone starts to get really mad
            • How many dark patterns you can cram into an app before the users stop using it
            • The extremes of human stupidity

            👍

            • SkyeStarfall@lemmy.blahaj.zone
              link
              fedilink
              English
              arrow-up
              5
              ·
              edit-2
              11 months ago

              …none of which would be relevant for most people working in back-end, which would be most people that take compsci.

              I would hate to go to a compsci study and learn management instead. It’s not what I signed up for.

              University also shouldn’t just be a job training program.

        • bh11235@infosec.pub
          link
          fedilink
          arrow-up
          6
          ·
          11 months ago

          Two govt spooks are hunting a dangerous fugitive who is also a humanities graduate. He escapes into a sprawling maze of tunnels. “It’s hopeless,” one of the spooks says. But the other simply says, “Watch.” then proclaims loudly, “studying linear algebra is important because of its use in stochastic processes and image manipulation.” Before he finishes the sentence, the fugitive emerges back out the tunnel and shouts, “but what’s even more important --” and is immediately knocked unconscious and taken for questioning

    • dtxer@lemmy.world
      link
      fedilink
      arrow-up
      21
      ·
      11 months ago

      I didn’t go to university, because I wanted to learn useful stuff, but because I’m curiousity driven. There is so much cool stuff and it’s very cool to learn it. That’s the point of university that it prepares you for a scientific career where the ultimate goal is knowledge not profit maximisation (super idealistically).

      Talking about Turing Machines it’s such a fun concept. People use this to build computers out of everything - like really - it became a Sport by this point. When the last Zelda was Released the first question for many was, if they can build a computer inside it.

      Does it serve a practical purpose? At the end of the day 99% of the time the answer will be no, we have computing machines built from transistors that are the fastest we know of, lets just use these.

      But 1% of the time people recognize something useful… hey we now found out in principle one can build computers from quantum particles… we found an algorithm that could beat classical computers in a certain task… we found a way to actually do this in reality, but it’s more proof of concept (15 = 5×3)… and so on

    • z500@startrek.website
      link
      fedilink
      arrow-up
      7
      ·
      11 months ago

      Never used a Turing machine, but I have a project that generates NFAs and converts them to DFAs so they run faster.

        • CallumWells
          link
          fedilink
          English
          arrow-up
          4
          arrow-down
          1
          ·
          11 months ago

          I thought it was Non-Fungible Articles and Decentralised Federated Articles

    • Blamemeta@lemmy.world
      link
      fedilink
      arrow-up
      4
      arrow-down
      1
      ·
      11 months ago

      Ram is literally just the tape. Modern computers are just multitape turing machines, albeit the tape ends at some point.

    • tr00st@lemmy.tr00st.co.uk
      link
      fedilink
      arrow-up
      2
      ·
      11 months ago

      About 15 years on, I’m still so happy I got good coursework marks for the route-finding equivalent of a bogosort. Picked a bunch of random routes and pick the fastest. Sure, that guy who set up a neural net to figure it out did well, but mine didn’t take days of training, and still did about as well in the same sort of execution time.

      • WolfhoundRO@lemmy.world
        link
        fedilink
        arrow-up
        0
        ·
        edit-2
        11 months ago

        Given that the guy that undertook the neural net path had consumed both time and more resources to make it happen, the good old sort is an efficient, sufficient, tried and true algorithm to quickly implement

  • GTG3000@programming.dev
    link
    fedilink
    arrow-up
    32
    ·
    11 months ago

    But you can make games that much more interesting if your algorithms are on point.

    Otherwise it’s all “well I don’t know why it generated map that’s insane”. Or “well AI has this weird bug but I don’t understand where it’s coming from”.

    • blivet@kbin.social
      link
      fedilink
      arrow-up
      7
      ·
      11 months ago

      I’m grateful to this strip because reading it caused me to learn the correct spelling of “abstruse”. I’ve never heard anyone say the word, and for some reason I had always read it as “abtruse”, without the first S.

  • Lmaydev@programming.dev
    link
    fedilink
    arrow-up
    13
    ·
    11 months ago

    I did games technology at university. We had a module that was just playing board games and eventually making one. Also did an unreal engine module that ended with making a game and a cinematic.

    It was awesome.

    • Gork@lemm.ee
      link
      fedilink
      arrow-up
      3
      ·
      11 months ago

      I never really understood the point of Lambda calculus. Why have an anonymous function? I thought it was good practice to meticulously segment code into functions and subroutines and call them as needed, rather than have some psuedo-function embedded somewhere.

      • rabirabirara@programming.dev
        link
        fedilink
        arrow-up
        4
        ·
        11 months ago

        I think you’re confusing lambdas with lambda calculus. Lambda calculus is more than just anonymous functions.

        To put it extremely simply, let’s just say functional programming (the implementation of lambda calculus) is code with functions as data and without shared mutable state (or side effects).

        The first one increases expressiveness tremendously, the second one increases safety and optimization. Of course, you don’t need to write anonymous functions in a functional language if you don’t want to.

        As for why those “pseudo-functions” are useful, you’re probably thinking of closures, which capture state from the context they are defined in. That is pretty useful. But it’s not the whole reason lambda calculus exists.

      • linuxduck@nerdly.dev
        link
        fedilink
        arrow-up
        2
        ·
        11 months ago

        I suppose it has to do with being stateless.

        I just loved learning about lambda calculus.

        I think the idea is to remove complexity by never dealing with state, so you just have one long reduction till you get to the final state…

        But someone who’s more into lambdas etc should speak about this and not me (a weirdo)

      • Zangoose@lemmy.one
        link
        fedilink
        arrow-up
        2
        ·
        11 months ago

        See the other comments about lambdas vs. lambda calculus, but lambdas are supposed to be for incredibly simple tasks that don’t need a full function definition, things that could be done in a line or two, like simple comparisons or calling another function. This is most useful for abstractions like list filtering, mapping, folding/reducing, etc. where you usually don’t need a very advanced function call.

        I was always taught in classes that if your lambda needs more than just the return statement, it should probably be its own function.

      • static_motion@programming.dev
        link
        fedilink
        arrow-up
        3
        arrow-down
        1
        ·
        11 months ago

        “Introduction to the Theory of Computation” by Michael Sipser, a book commonly referred to as simply “Sipser”. My ToC course in uni was based around that book and while I didn’t read the whole thing I enjoyed it a ton.

    • Christian
      link
      fedilink
      arrow-up
      1
      ·
      11 months ago

      I read it cover-to-cover like fifteen years ago. I’ve lost most of that knowledge since I haven’t touched it in so long, but I remember I really enjoyed it.

  • Saigonauticon@voltage.vn
    link
    fedilink
    English
    arrow-up
    2
    ·
    11 months ago

    Hm, I wonder if I could make these students more miserable by introducing a CPU that permits static operation, then clocking that with a true random number generator?

    So now it has output that is deterministic from the standpoint of the CPU but nondeterministic to an outside observer. Probably wouldn’t affect the O(n) notation though, come to think of it. It would be funny though.

    • garyyo@lemmy.world
      link
      fedilink
      arrow-up
      16
      arrow-down
      1
      ·
      11 months ago

      Wait till you hear about oracle machines. They can solve any problem, even the halting problem.

      (It’s just another mathematical construct that you can do cool things with to prove certain things)

      • Julian@lemm.ee
        link
        fedilink
        arrow-up
        5
        arrow-down
        1
        ·
        11 months ago

        Thanks for the fun rabbit hole. They can’t really solve the halting problem though, you can make an oracle solve the halting problem for a turning machine but not for itself. Then of course you can make another oracle machine that solves the halting problem for that oracle machine, and so on and so forth, but an oracle machine can never solve its own halting problem.

    • fubo@lemmy.world
      link
      fedilink
      arrow-up
      8
      ·
      11 months ago

      If you augment a TM with nondeterminism, it can still be reduced to a deterministic TM.

    • rockSlayer@lemmy.world
      link
      fedilink
      arrow-up
      6
      arrow-down
      2
      ·
      11 months ago

      Nondeterministic turing machines are the same kind of impossible theoretical automaton as an NFA. They can theoretically solve NP problems.

      • Christian
        link
        fedilink
        arrow-up
        1
        ·
        11 months ago

        It’s been a long long time since I touched this but I’m still almost positive deterministic machines can solve everything in NP already.

        • rockSlayer@lemmy.world
          link
          fedilink
          arrow-up
          1
          arrow-down
          1
          ·
          11 months ago

          They exist in the same grammatical hierarchy so theoretically they can solve the same problems. What I should have said was that nondeterministic turing machines can solve NP problems in P