Wikipedia:Reference desk/Computing
of the Wikipedia reference desk.
Main page: Help searching Wikipedia
How can I get my question answered?
- Select the section of the desk that best fits the general topic of your question (see the navigation column to the right).
- Post your question to only one section, providing a short header that gives the topic of your question.
- Type '~~~~' (that is, four tilde characters) at the end – this signs and dates your contribution so we know who wrote what and when.
- Don't post personal contact information – it will be removed. Any answers will be provided here.
- Please be as specific as possible, and include all relevant context – the usefulness of answers may depend on the context.
- Note:
- We don't answer (and may remove) questions that require medical diagnosis or legal advice.
- We don't answer requests for opinions, predictions or debate.
- We don't do your homework for you, though we'll help you past the stuck point.
- We don't conduct original research or provide a free source of ideas, but we'll help you find information you need.
How do I answer a question?
Main page: Wikipedia:Reference desk/Guidelines
- The best answers address the question directly, and back up facts with wikilinks and links to sources. Do not edit others' comments and do not give any medical or legal advice.
January 1
[edit]Question(s) about Arch Linux
[edit]@TheTechie ... A question? Do you used archinstall to install Arch Linux? I think i will install Arch Linux, cause, i want BTW Vitorperrut555 (talk) 23:31, 1 January 2025 (UTC)
- Moved this here as I found this to be a better place for it. As for your question, no, I used text commands. Though I may be able to help. Any specific questions? TheTechie@enwiki (she/they | talk) 00:32, 2 January 2025 (UTC)
- @Vitorperrut555 TheTechie@enwiki (she/they | talk) 00:41, 2 January 2025 (UTC)
- When I installed Arch Linux, I used a live-boot USB. Once booted, it has an "install" icon that can be used to do a basic install. Then, once installed, you can customize it by removing and adding the packages you like. 68.187.174.155 (talk) 15:42, 2 January 2025 (UTC)
- 68.187.174.155, I think you're confused. Archinstall is a command on Arch Linux, and the Arch Installer boots in text mode. You may be thinking of an Arch derivative like Manjaro or EndeavourOS, which do indeed boot up in graphical environments. TheTechie@enwiki (she/they | talk) 20:23, 2 January 2025 (UTC)
- When I installed Arch Linux, I used a live-boot USB. Once booted, it has an "install" icon that can be used to do a basic install. Then, once installed, you can customize it by removing and adding the packages you like. 68.187.174.155 (talk) 15:42, 2 January 2025 (UTC)
January 2
[edit]Bayeux Tapestry website
[edit]What image-serving technology is the new Bayeux Tapestry website using, and how can high-res images be downloaded? Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 20:59, 2 January 2025 (UTC)
- @Pigsonthewing Welcome to the Reference Desk for Computing. Are you trying to download all images, or only specific ones? If you reply here, please ping me. Thanks, TheTechie@enwiki (she/they | talk) 00:54, 3 January 2025 (UTC)
- The former preferably, but an answer for either would be of interest, as the technology is likely in use elsewhere. Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 16:46, 3 January 2025 (UTC)
- According to their terms of use, "Access to this panorama is free for a private or public non-commercial use. Any commercial use of this tool is prohibited, as well as the extraction of images from this panorama" (my emphasis). This may or may not bother you. Chuntuk (talk) 18:24, 3 January 2025 (UTC)
- Even more, the "images" which get loaded are tiled portions of the actual image. TheTechie@enwiki (she/they | talk) 19:11, 3 January 2025 (UTC)
January 4
[edit]Zoomify
[edit]Is it possible to download the map La ligne de démarcation that is shown via Zoomify?--Antemister (talk) 22:48, 4 January 2025 (UTC)
- Yes, if you google "download zoomify image" you will see various ways. Polygnotus (talk) 23:44, 4 January 2025 (UTC)
- Ah, of course I googled before and found that but was not successful. So I asked here.--Antemister (talk) 11:31, 5 January 2025 (UTC)
- Please mention what you've already tried before and what did not work and what happened instead (e.g. error messages). Polygnotus (talk) 04:57, 6 January 2025 (UTC)
- Tried [1] and of course also the dezoomify tool but got immediately stuck because I was not able to find an URL. Very few programming skills, none regarding HTML, that's why I ask here.--Antemister (talk) 10:46, 6 January 2025 (UTC)
- Please mention what you've already tried before and what did not work and what happened instead (e.g. error messages). Polygnotus (talk) 04:57, 6 January 2025 (UTC)
- Ah, of course I googled before and found that but was not successful. So I asked here.--Antemister (talk) 11:31, 5 January 2025 (UTC)
- @Antemister:
- I wasn't able to download the file as it was taking forever, but this URL appeared to download the files for 30+ minutes on a fast internet. Let us know if this works. TheTechie@enwiki (she/they | talk) 03:19, 8 January 2025 (UTC)
- I've successfully taken images off the IWM via their source code and dezoomify, but I'm puzzled as to how to extract images here, as Dezoomify appears to be perpetually stuck on 'preparing tiles load'. The longest I've seen it take for large images in the past is a couple of minutes. Like Antemister, I've little programming knowledge, but I think the following elements in the code are related:
- <script type="text/javascript" src="ZoomifyImageViewerFree-min.js"></script>
- <script type="text/javascript"> Z.showImage("myContainer", "images/France_LD"); </script>
- On going to http://cartesmich.free.fr/images/France_LD/ I get error 403. Perhaps this website is savvy about theft of its most high-resolution public domain images. Maybe someone has the patience to hunt about in the browser console. JayCubby 04:51, 8 January 2025 (UTC)
- If they're public domain images, it's not "theft". Please avoid such misleading and perjorative language. Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 10:52, 8 January 2025 (UTC)
- It's still potentially in violation of their ToS (not that I much care) and could, per my reading of my law (assuming this is an american website, which it isn't) run afoul of something like the Computer Fraud and Abuse Act.
- The ToS is a reasonable concern, which is why I said theft. JayCubby 15:53, 8 January 2025 (UTC)
- Even if all you say were true (It's highly doubtful; there appear to be no published terms of service - much less any that a user agrees to before viewing the site; and in any case we are not all in the USA), it's still not theft. Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 16:11, 8 January 2025 (UTC)
- You're right--there are no terms (though the host website, free.fr, appears to have a TOS page). JayCubby 16:53, 8 January 2025 (UTC)
- Even if all you say were true (It's highly doubtful; there appear to be no published terms of service - much less any that a user agrees to before viewing the site; and in any case we are not all in the USA), it's still not theft. Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 16:11, 8 January 2025 (UTC)
- If they're public domain images, it's not "theft". Please avoid such misleading and perjorative language. Andy Mabbett (Pigsonthewing); Talk to Andy; Andy's edits 10:52, 8 January 2025 (UTC)
Yes, I came to that cited code, but had no idea to open that container Also tried again dezoomify, and also waited a long time, and after 1-2 hours i get an error message. And it includes a link, [2], if you alter the numbers you can find various tiles of the map.is it possible to proceed with that, download that folder?--Antemister (talk) 22:34, 8 January 2025 (UTC)
- Hmm! So I pasted this conversation into ChatGPT, and told it to generate code for use in Google Colab. The code is here (it doesn't really do what it's supposed to, at all, but a start).
- The really screwed-up image it generated is here. Hopefully these are of help to someone with more Python experience than I.JayCubby 02:35, 9 January 2025 (UTC)
I gave this another try. This time it was able to actually download the image correctly, but only a horizontal section. The code is collapsed below. I think it needs only some slight tweaking.
Extended content
|
---|
import os ::import requests ::from PIL import Image ::# Base URL and directory setup ::BASE_URL = "http://cartesmich.free.fr/images/France_LD/TileGroup8/" ::OUTPUT_DIR = "tiles" ::MERGED_IMAGE = "merged_image.jpg" ::# Ensure the output directory exists ::os.makedirs(OUTPUT_DIR, exist_ok=True) ::# Function to download a tile ::def download_tile(url, save_path): :: response = requests.get(url) :: if response.status_code == 200: :: with open(save_path, "wb") as f: :: f.write(response.content) :: return True :: return False ::# Function to stitch the tiles together ::def stitch_tiles(tiles, tile_size): :: max_x = max(x for x, y in tiles.keys()) + 1 :: max_y = max(y for x, y in tiles.keys()) + 1 :: # Create a blank canvas for the final image :: merged_image = Image.new("RGB", (max_x * tile_size, max_y * tile_size)) :: # Paste tiles onto the canvas :: for (x, y), tile_path in tiles.items(): :: tile_image = Image.open(tile_path) :: merged_image.paste(tile_image, (x * tile_size, y * tile_size)) :: return merged_image ::# Set parameters for downloading tiles ::tile_size = 256 # Assume each tile is 256x256 ::x_range = range(36, 50) # Adjust based on your needs (x-coordinate range) ::y_range = range(24, 40) # Adjust based on your needs (y-coordinate range) ::# Dictionary to store downloaded tile paths ::downloaded_tiles = {} ::# Download tiles ::for x in x_range: :: for y in y_range: :: tile_url = f"{BASE_URL}6-{x}-{y}.jpg" :: tile_path = os.path.join(OUTPUT_DIR, f"6-{x}-{y}.jpg") :: if download_tile(tile_url, tile_path): :: downloaded_tiles[(x - min(x_range), y - min(y_range))] = tile_path :: print(f"Downloaded: {tile_url}") :: else: :: print(f"Tile not found: {tile_url}") ::# Stitch the tiles into a single image ::if downloaded_tiles: :: merged_image = stitch_tiles(downloaded_tiles, tile_size) :: merged_image.save(MERGED_IMAGE) :: print(f"Merged image saved as {MERGED_IMAGE}") ::else: :: print("No tiles were downloaded!") |
-- JayCubby 16:09, 9 January 2025 (UTC)
- Oh, again some progress! What horizontal slide? Maybe iterate through the TileGroup folders?--Antemister (talk) 16:56, 9 January 2025 (UTC)
- User:Antemister, it was one of the bottom sections of the map, I have some silly 2FA on my devices and can't access the one I ran it on for a couple of hours. You should be able to run the above code in Colab and ask ChatGPT (or Gemini) for further help. JayCubby 17:02, 9 January 2025 (UTC)
- First heard about Colab but tried, and it seems the Code does something. What is the Folder you got the files downlaoded?--Antemister (talk) 17:30, 9 January 2025 (UTC)
Antemister In a new cell, type
from google.colab import files
files.download('merged_image.jpg')
Apologies for putting all of this inside a hat template, I can't figure out how to correct it. JayCubby 18:15, 9 January 2025 (UTC)
- Again progress, have gotten such a merged image that shows a part of the map. The iteration is just a guess... Shouldnt there be a possibility to list all the files in the folder?--Antemister (talk) 22:58, 9 January 2025 (UTC)
- @Antemister, I very nearly got it to work, the final image is 12,000x12,000px but has errors. import os
- import requests
- from PIL import Image
- from concurrent.futures import ThreadPoolExecutor
- Base URL and output setup
- BASE_URL = "http://cartesmich.free.fr/images/France_LD/"
- OUTPUT_DIR = "tiles"
- MERGED_IMAGE = "merged_image.jpg"
- Ensure output directory exists
- os.makedirs(OUTPUT_DIR, exist_ok=True)
- Function to download a tile
- def download_tile(group, x, y):
- url = f"{BASE_URL}TileGroup{group}/6-{x}-{y}.jpg"
- save_path = os.path.join(OUTPUT_DIR, f"TileGroup{group}_6-{x}-{y}.jpg")
- try:
- response = requests.get(url, timeout=10)
- if response.status_code == 200:
- with open(save_path, "wb") as f:
- f.write(response.content)
- print(f"Downloaded: {url}")
- return (group, x, y, save_path)
- else:
- print(f"Tile not found: {url}")
- except Exception as e:
- print(f"Error downloading {url}: {e}")
- return None
- Function to download all tiles (no detection, brute force)
- def download_all_tiles(groups, x_range, y_range):
- tiles = []
- print("Starting brute force tile download...")
- with ThreadPoolExecutor(max_workers=10) as executor:
- futures = []
- for group in groups:
- for x in x_range:
- for y in y_range:
- futures.append(executor.submit(download_tile, group, x, y))
- for future in futures:
- result = future.result()
- if result:
- tiles.append(result)
- return tiles
- Function to stitch tiles together
- def stitch_tiles(tiles, tile_size):
- if not tiles:
- print("No tiles to stitch.")
- return None
- Determine the range of x and y coordinates
- all_coords = [(x, y) for _, x, y, _ in tiles]
- min_x = min(x for x, y in all_coords)
- max_x = max(x for x, y in all_coords)
- min_y = min(y for x, y in all_coords)
- max_y = max(y for x, y in all_coords)
- Create a blank canvas for the final image
- width = (max_x - min_x + 1) * tile_size
- height = (max_y - min_y + 1) * tile_size
- merged_image = Image.new("RGB", (width, height))
- Paste tiles onto the canvas
- for group, x, y, tile_path in tiles:
- tile_image = Image.open(tile_path)
- merged_image.paste(
- tile_image, ((x - min_x) * tile_size, (y - min_y) * tile_size)
- )
- return merged_image
- Main script execution
- tile_size = 256 # Assume each tile is 256x256
- groups = range(0, 16) # TileGroup0 to TileGroup15
- x_range = range(0, 50) # x-coordinates: 0–49
- y_range = range(0, 50) # y-coordinates: 0–49
- tiles = download_all_tiles(groups, x_range, y_range)
- Stitch the tiles into a single image
- if tiles:
- merged_image = stitch_tiles(tiles, tile_size)
- if merged_image:
- merged_image.save(MERGED_IMAGE)
- print(f"Merged image saved as {MERGED_IMAGE}")
- else:
- print("No tiles were downloaded!") JayCubby 03:31, 11 January 2025 (UTC)
- Here's the link. https://limewire.com/d/50995585-f881-4ff5-9186-e0eb55978a5e#Tcw-4kZBQKVH0GS9yZPb-vUvH8t-V04gV-t8MQp8O7k JayCubby 03:38, 11 January 2025 (UTC)
- Thank you, that is sufficient, what I need is the ceasefire/demarcation line. Can you sent me the code with correct formatting? Maybe I can use it in future, to download other zoomified images.--Antemister (talk) 14:18, 11 January 2025 (UTC)
- Here's the link. https://limewire.com/d/50995585-f881-4ff5-9186-e0eb55978a5e#Tcw-4kZBQKVH0GS9yZPb-vUvH8t-V04gV-t8MQp8O7k JayCubby 03:38, 11 January 2025 (UTC)
January 13
[edit]Absolute value inequality
[edit]A meteorite is 600ft from a satellite and travelling toward the satellite at 42ft/sec. At what times will the meteorite be less than 50ft away from the satellite? Write an appropriate absolute value inequality for the given situation and solve: Let|42t-600|<50 and 42t-600<50 and 42t-600>-50. Thus, 13.10<t<15.48. Afrazer123 (talk) 22:21, 13 January 2025 (UTC)
- What is the question?
- The given data do not specify where the meteorite is at time t = 0, and also not with which speed the satellite is moving. Your solution is based on the (not unreasonable) assumptions that the person who drew up this assignment meant t = 0 to be the initial moment when the meteorite is 600ft away from the satellite, and that the speed of 42ft/s is the speed of the meteorite relative to the satellite. Your solution assumes that the meteorite will not hit the satellite, but pass by it. Under these assumptions, the derived inequations are correct, as is your solution, although not with exact values but with numeric values rounded to two decimals.
- If the meteorite hits the satellite, we don't know what happens after t = 14.29. If the satellite disintegrates, the notion of the distance between the bodies becomes meaningless. --Lambiam 23:59, 13 January 2025 (UTC)