Hi~!

I’m getting familiar with Perchance and the text to image plugin, so I modified a script from the guides to test tags blending a bit more. I’m trying to visualize task blending, but when the prompt is not fixed (contains other lists that are being evaluated than the blended tags). In that case, I would like in each row to only change the blended tags, and to keep the same seed and evaluations of the other lists the same (e.g., here I want the same animal). But I didn’t manage to do that yet, as the animals are changing within the same row. I wonder if there is a way to partially evaluate the prompt a first time for each row and a second time for the blended tag.

Another way would be to do string formatting to handle the tag blending instead of using perchance lists (with a trick like this: blending_value = [blending_values.selectAll[counter]]), but I didn’t see a part about that in the guides, and I’m not familiar with JavaScript at all.

Do you have some solutions for this?

Here’s the generator I started: https://perchance.org/7zk7cvxzzl

I coded it to blend 2 dimensions of tags within a matrix, I use only 1 dimension here, so it should not be relevant.

Notes: The idea behind this is to visualize the tag blending on a sample of the possible prompts rather than a fixed one. Here, there are 6 animals, so we could try them all on a bunch of seed, but in practice, it’s not doable, that’s why I’m doing the sampling in the first place.

  • wthit56@lemmy.world
    link
    fedilink
    English
    arrow-up
    2
    ·
    2 months ago

    I don’t see the code blending_value = [blending_values.selectAll[counter]] in there at all.

    next_matrix_image() is very hard to read… you can use if and else statements so it’s easier to understand (and code, I’d say).

    …None of which really matters to your question. I’m just finding it very difficult to even understand what your code is doing or trying to do. 🫠

    Is the problem that it changes animal? Looks to me like it’s not changing animal. It always renders horses for me. Is that what you wanted, or didn’t want? What do you actually want to happen? I’m so confused… 😅

    • Zaringers@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      edit-2
      2 months ago

      Sorry if it’s confusing haha, and thanks for helping !

      There is no blending_value = [blending_values.selectAll[counter]] in the code but val_row = [row_values.selectAll[row_counter]], since it was written for a matrix in the first place.

      you can use if and else statements

      Well, I’d like to do that, but I didn’t manage to use the regular if else in the function lol. That function would be much more understandable with regular nested for loops, one level for rows, one for columns, one for seeds, but is that even possible in Perchance? I kinda did this intricate work around by handling manually the indices (I need those indices/counter to get the values here val_row = [row_values.selectAll[row_counter]]).

      What the code does is generating images for each combination of 2 parameters, the next_matrix_image() handles the indices to know which parameter corresponds to a particular image in the matrix at a given column and row (I don’t pass the argument to the function because I need to update there values, like passing the reference of the arguments instead of the arguments themselves, and I don’t know if it’s possible). I added comments basically everywhere, sorry if it was confusing.

      Is the problem that it changes animal?

      Yep, that it changes animals within a row.

      I commented other animals because I wanted to see what it would look like if there wasn’t the problem, and I forgot to revert is, sorry.

      animal
        // dog
        // cat
        // mouse
        horse
        // cow
        // lion
      

      I uncommented, and they are changing like I was describing now.

      What I would like to do, is to force the animal to be the same within a row (only the row parameter changes, the rest of the prompt remain the same) and the animal to change only between different rows (like the seed of the image, actually). (In the matrix case, like here, it would be that the animal are the same within a matrix, and to change between different matrices, like the seed. In the code, I commented the values varying within columns, so they are one column matrices, meaning that what we visually see as a different row in the image is a different matrix, with different seed (and different animals, if that was working)). I hope that makes sense ehh, but I get that it’s intricate. Sorry about that.

      • wthit56@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        2 months ago

        Perchance is built on JS. Code blocks are [JavaScript expressions]. Functions just have fn() => JavaScript code in them. Plus, you could just put a script tag in the HTML of the page and put JS direct in there if you wanted to. So yeah, you can do loops as usual. 👍

        This also means you can call something like the image generator with just a simple js object, normal strings, and so on. Which can make things a lot easier and encapsulated.

        Personally, I’d write the image function as not changing values, and just creating the needed HTML and returning that. But you can do things however you want to.

        I’m not sure I fully understood, but I got the jist ;p

        To generate a random value from a list, access it with .selectOne to get a random item, or .evaluateItem to get a finalised string value. And store that in a variable. So like row_animal = animals.evaluateItem. Then use that in the prompt you send to the image generator function. If you want that to change between rows, after a row ends just run that code again to grab a new random item.

        • Zaringers@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 months ago

          Thank you, I didn’t understand everything in the last part, but I’ll rewrite that stuff with proper JavaScript then, it shouldn’t be that hard!