Movements under the water

, 03 February 2023
Movements under the water
Sprat shoal © Paul Naylor

By Ella Garrud

Living Seas Officer 

Shoals

Did you know? A shoal of fish is a group of fish swimming in a loose cluster, unorganised and moving in different directions. A school of fish is a synchronised group of the same species, all swimming in the same direction. Amazingly, a school of fish does not have a leader. They self-organise, by co-ordinating with their direct neighbours, using sight and their lateral line – an organ along the side of a fish’s body which can sense very subtle water pressure changes. If a neighbouring fish changes direction or speeds up, their lateral line will feel it and they can adapt their movement to that of their neighbour. In this way, a school of thousands of fish can move in a mesmerising, synchronised display.

Fishy tails

Bottlenose-dolphin © Caroline Weir
Bottlenose-dolphin © Caroline Weir

Have you ever wondered why the tails of fish and cetaceans (dolphins and whales) move differently? Whales and dolphins evolved from terrestrial mammals which walked on four legs positioned underneath their bodies, which meant their backbones bent up and down. As they evolved, whales and dolphins retained this motion, resulting in their flukes (tail fins) being positioned horizontally, propelling them through the water by moving up and down. This is called dorsoventral undulation. Fun fact: Whales and dolphins still actually have pelvic (hip) bones, despite no longer having back legs.

Stickleback © Derek Middleton
Stickleback © Derek Middleton

The ancestors of fish on the other hand, never walked on land on four legs, so their spines did not evolve to move up and down, but side to side. This means that fish have vertical tail fins that move from side to side, a movement called lateral undulation.

Leave a comment
Time Δ Debug Message - Perch Runway 3.2
1782930583.70480 [906] SELECT p.pagePath, pr.routePattern, pr.routeRegExp, p.pageTemplate, pr.routeOrder, s.settingValue AS siteOffline FROM swt_pages_staging p LEFT JOIN swt_page_routes pr ON p.pageID=pr.pageID LEFT JOIN swt_settings s ON s.settingID='siteOffline' UNION SELECT NULL AS pagePath, pr2.routePattern, pr2.routeRegExp, pr2.templatePath AS pageTemplate, pr2.routeOrder, NULL AS siteOffline FROM swt_page_routes pr2 WHERE templateID!=0 ORDER BY routeOrder ASC, pagePath ASC
1782930583.73080.0261Matched route: news/[slug:s]
1782930583.7310.0002Server address: 216.73.217.103
1782930583.73110.0001Using master page: /templates/pages/blog/post.php
1782930583.73110Page arguments:
Array
(
    [0] => /news/movements-under-the-water
    [s] => movements-under-the-water
    [1] => movements-under-the-water
)
1782930583.73140.0003 [1] SELECT * FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.73240.001 [86] SELECT DISTINCT settingID, settingValue FROM swt_settings WHERE userID=0
1782930583.73410.0017 [1] SELECT locationID FROM swt_shop_tax_locations WHERE locationIsHome=1 LIMIT 1
1782930583.73470.0006INSERT INTO swt_shop_cart(memberID,locationID,currencyID,cartPricing,cartProperties) VALUES(NULL,'1',47,'standard','[]')
1782930583.73660.0019 [1] SELECT * FROM swt_shop_cart WHERE cartID=22492436
1782930583.73710.0005 [1] SELECT * FROM swt_shop_cart WHERE cartID=22492436
1782930583.73760.0005 [nil] SELECT * FROM swt_shop_sales WHERE saleFrom<='2026-07-01 18:29:00' AND saleTo>'2026-07-01 18:29:00' AND saleActive=1 AND saleDeleted IS NULL ORDER BY saleOrder ASC
1782930583.73870.0011 [1] SELECT SQL_CALC_FOUND_ROWS DISTINCT tbl.* FROM ( SELECT idx.itemID, main.*, idx2.indexValue as sortval FROM swt_blog_index idx JOIN swt_blog_posts main ON idx.itemID=main.postID AND idx.itemKey='postID' JOIN swt_blog_index idx2 ON idx.itemID=idx2.itemID AND idx.itemKey='postID' AND idx2.indexKey='_id' WHERE 1=1 AND ((idx.indexKey='postSlug' AND idx.indexValue='movements-under-the-water')) AND idx.itemID=idx2.itemID AND idx.itemKey=idx2.itemKey GROUP BY idx.itemID, idx2.indexValue, postID ) as tbl WHERE (postStatus='Published' AND postDateTime<='2026-07-01 18:29:00' ) GROUP BY itemID, sortval ORDER BY sortval ASC LIMIT 0, 10
1782930583.74110.0024 [1] SELECT FOUND_ROWS() AS `count`
1782930583.74170.0005 [1] SELECT * FROM swt_blog_posts WHERE postID=3001 AND postStatus='Published' AND postDateTime<='2026-07-01 18:29:00'
1782930583.74240.0007 [13] SELECT * FROM swt_blog_sections ORDER BY sectionTitle ASC
1782930583.74310.0007 [1] SELECT * FROM swt_blogs ORDER BY blogTitle ASC
1782930583.74370.0006 [1] SELECT * FROM swt_categories WHERE catID=207 LIMIT 1
1782930583.74420.0005 [1] SELECT * FROM swt_categories WHERE catID=44 LIMIT 1
1782930583.74470.0005Using template: /templates/blog/post.html
1782930583.74490.0002 [162] SELECT catID, catPath FROM swt_categories
1782930583.74580.0009 [1] SELECT * FROM swt_blog_posts WHERE postStatus='Published' AND postDateTime<='2026-07-01 18:29:00' AND postSlug='movements-under-the-water'
1782930583.76670.0209Using template: /templates/blog/post.html
1782930583.76720.0005 [250] SELECT country, countryID FROM swt_shop_countries WHERE countryActive=1 ORDER BY country ASC
1782930583.76890.0017Using template: /templates/pages/attributes/seo.html
1782930583.76910.0002 [1] SELECT regionID, regionTemplate, regionPage, regionRev AS rev FROM swt_content_regions WHERE regionKey='Banner image' AND (regionPage='/news/post' OR regionPage='*')
1782930583.76990.0008 [nil] SELECT * FROM ( SELECT idx.itemID, c.regionID, idx.pageID, c.itemJSON, idx2.indexValue as sortval FROM swt_content_index idx JOIN swt_content_items c ON idx.itemID=c.itemID AND idx.itemRev=c.itemRev AND idx.regionID=c.regionID JOIN swt_content_index idx2 ON idx.itemID=idx2.itemID AND idx.itemRev=idx2.itemRev AND idx2.indexKey='_order' WHERE ((idx.regionID=104 AND idx.itemRev=0)) AND idx.itemID=idx2.itemID AND idx.itemRev=idx2.itemRev ) as tbl GROUP BY itemID, pageID, itemJSON, sortval, regionID ORDER BY sortval ASC
1782930583.77120.0012 [82] SELECT * FROM swt_pages_staging WHERE pageNew=0 AND pageHidden=0 AND pageDepth >=0 AND pageDepth<=2 ORDER BY pageTreePosition ASC
1782930583.77410.0029 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.77470.0006 [2] SELECT pageID FROM swt_pages_staging WHERE pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition DESC
1782930583.77670.002Using template: /templates/navigation/ps_nav_template.html
1782930583.77680 [6] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.77750.0007 [4] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.7780.0005 [29] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.77980.0018 [10] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.78060.0009 [7] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.78130.0007 [9] Using template: /templates/navigation/ps_nav_template_children.html
1782930583.78330.002 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' OR pageSortPath='/news/post' LIMIT 1
1782930583.78420.0009 [1] SELECT * FROM swt_pages_staging WHERE pageHidden=0 AND pageNew=0 AND pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition
1782930583.78610.002 [1] Using template: /templates/navigation/breadcrumbs.html
1782930583.78650.0004Using template: /templates/blog/post.html
1782930583.78660.0002 [1] SELECT * FROM swt_blog_authors WHERE authorID='1' LIMIT 1
1782930583.78730.0007Using template: /templates/blog/author.html
1782930583.78770.0004 [1] SELECT SQL_CALC_FOUND_ROWS DISTINCT tbl.* FROM ( SELECT idx.itemID, main.*, idx2.indexValue as sortval FROM swt_blog_index idx JOIN swt_blog_posts main ON idx.itemID=main.postID AND idx.itemKey='postID' JOIN swt_blog_index idx2 ON idx.itemID=idx2.itemID AND idx.itemKey='postID' AND idx2.indexKey='_id' WHERE 1=1 AND ((idx.indexKey='postSlug' AND idx.indexValue='movements-under-the-water')) AND idx.itemID=idx2.itemID AND idx.itemKey=idx2.itemKey GROUP BY idx.itemID, idx2.indexValue, postID ) as tbl WHERE (postStatus='Published' AND postDateTime<='2026-07-01 18:29:00' ) GROUP BY itemID, sortval ORDER BY sortval ASC LIMIT 0, 1
1782930583.78950.0018 [1] SELECT FOUND_ROWS() AS `count`
1782930583.790.0005 [1] Using template: /templates/blog/post.html
1782930583.79240.0023Using template: /templates/blog/comment_form.html
1782930583.79320.0008 [nil] SELECT * FROM swt_blog_comments WHERE 1=1 AND postID=3001 AND commentStatus='LIVE' ORDER BY FIELD(webmentionType, 'like', 'repost', 'comment', NULL) ASC, commentDateTime ASC
1782930583.84230.0492 [0] Using template: /templates/blog/comment.html
1782930583.84260.0002Using template: /templates/blog/post.html
1782930583.84280.0002 [1] SELECT * FROM swt_blog_authors WHERE authorID='1' LIMIT 1
1782930583.84350.0007 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pagePath='/what-we-do' OR pageSortPath='/what-we-do' LIMIT 1
1782930583.84410.0007 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pageTreePosition='000-002' LIMIT 1
1782930583.84470.0006 [7] SELECT * FROM swt_pages_staging WHERE pageNew=0 AND pageHidden=0 AND pageTreePosition LIKE '000-002%' AND pageDepth >=1 AND pageDepth<=2 ORDER BY pageTreePosition ASC
1782930583.84670.002 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.84720.0005 [2] SELECT pageID FROM swt_pages_staging WHERE pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition DESC
1782930583.84890.0017 [6] Using template: /templates/navigation/footer-nav.html
1782930583.84950.0005 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pagePath='/make-a-difference' OR pageSortPath='/make-a-difference' LIMIT 1
1782930583.850.0005 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pageTreePosition='000-005' LIMIT 1
1782930583.85040.0004 [38] SELECT * FROM swt_pages_staging WHERE pageNew=0 AND pageHidden=0 AND pageTreePosition LIKE '000-005%' ORDER BY pageTreePosition ASC
1782930583.85250.0021 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.8530.0005 [2] SELECT pageID FROM swt_pages_staging WHERE pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition DESC
1782930583.85470.0017 [10] Using template: /templates/navigation/footer-nav.html
1782930583.85770.003 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pagePath='/visit' OR pageSortPath='/visit' LIMIT 1
1782930583.85830.0006 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pageTreePosition='000-004' LIMIT 1
1782930583.85880.0004 [30] SELECT * FROM swt_pages_staging WHERE pageNew=0 AND pageHidden=0 AND pageTreePosition LIKE '000-004%' AND pageDepth >=1 AND pageDepth<=2 ORDER BY pageTreePosition ASC
1782930583.86090.0022 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.86150.0005 [2] SELECT pageID FROM swt_pages_staging WHERE pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition DESC
1782930583.86330.0018 [29] Using template: /templates/navigation/footer-nav.html
1782930583.86560.0023 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pagePath='/make-a-difference' OR pageSortPath='/make-a-difference' LIMIT 1
1782930583.86620.0006 [1] SELECT pageID, pageParentID, pageDepth, pageTreePosition FROM swt_pages_staging WHERE pageTreePosition='000-005' LIMIT 1
1782930583.86670.0005 [11] SELECT * FROM swt_pages_staging WHERE pageNew=0 AND pageHidden=0 AND pageTreePosition LIKE '000-005%' AND pageDepth >=1 AND pageDepth<=2 ORDER BY pageTreePosition ASC
1782930583.86870.0021 [1] SELECT pageTreePosition FROM swt_pages_staging WHERE pagePath='/news/post' LIMIT 1
1782930583.86930.0006 [2] SELECT pageID FROM swt_pages_staging WHERE pageTreePosition IN ('000-006-001', '000-006', '000') ORDER BY pageTreePosition DESC
1782930583.87160.0023 [10] Using template: /templates/navigation/footer-nav.html
1782930583.87260.0011Request time: 0.1699
1782930583.87260Process time: 0.1698
1782930583.87260Memory: 1.6217